harperdb 4.5.1 → 4.5.2

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.
Files changed (49) hide show
  1. package/README.md +1 -1
  2. package/bin/harperdb.js +74 -74
  3. package/bin/lite.js +72 -72
  4. package/launchServiceScripts/launchNatsIngestService.js +72 -72
  5. package/launchServiceScripts/launchNatsReplyService.js +72 -72
  6. package/launchServiceScripts/launchUpdateNodes4-0-0.js +74 -74
  7. package/npm-shrinkwrap.json +242 -242
  8. package/package.json +1 -1
  9. package/server/jobs/jobProcess.js +72 -72
  10. package/server/threads/threadServer.js +71 -71
  11. package/studio/build-local/asset-manifest.json +34 -34
  12. package/studio/build-local/index.html +1 -1
  13. package/studio/build-local/static/js/164.f552d832.chunk.js +1 -0
  14. package/studio/build-local/static/js/{873.55a21fe5.chunk.js → 708.1805e937.chunk.js} +2 -2
  15. package/studio/build-local/static/js/{833.22ea9ecd.chunk.js → 833.5847bc85.chunk.js} +1 -1
  16. package/studio/build-local/static/js/{browse-csvupload.1345356f.chunk.js → browse-csvupload.97e20c4a.chunk.js} +1 -1
  17. package/studio/build-local/static/js/{browse-datatable.8d180288.chunk.js → browse-datatable.339fb83c.chunk.js} +1 -1
  18. package/studio/build-local/static/js/{browse-entitymanager.3f0871ba.chunk.js → browse-entitymanager.fd37a083.chunk.js} +1 -1
  19. package/studio/build-local/static/js/{browse-jsonviewer.7ef3cb49.chunk.js → browse-jsonviewer.f57cc39c.chunk.js} +1 -1
  20. package/studio/build-local/static/js/{custom-functions.d7869749.chunk.js → custom-functions.f682aa33.chunk.js} +1 -1
  21. package/studio/build-local/static/js/{instance-cluster.ded77459.chunk.js → instance-cluster.e2dba73f.chunk.js} +1 -1
  22. package/studio/build-local/static/js/{instance-config.f3087710.chunk.js → instance-config.4e2c4644.chunk.js} +1 -1
  23. package/studio/build-local/static/js/{instance-logs.fb150c6f.chunk.js → instance-logs.bcec2256.chunk.js} +1 -1
  24. package/studio/build-local/static/js/{instance-roles.32b7be24.chunk.js → instance-roles.1ad69c74.chunk.js} +1 -1
  25. package/studio/build-local/static/js/{instance-status.d7ddf38a.chunk.js → instance-status.4e190908.chunk.js} +1 -1
  26. package/studio/build-local/static/js/{instance-users-datatable.68cb8e34.chunk.js → instance-users-datatable.4a2c57e4.chunk.js} +1 -1
  27. package/studio/build-local/static/js/{instance-users-edit.8de84af8.chunk.js → instance-users-edit.ecf717d1.chunk.js} +1 -1
  28. package/studio/build-local/static/js/{instance-users.ff289f79.chunk.js → instance-users.967796d9.chunk.js} +1 -1
  29. package/studio/build-local/static/js/{instance.127e14b8.chunk.js → instance.809ece1e.chunk.js} +1 -1
  30. package/studio/build-local/static/js/{instances.1dd2b960.chunk.js → instances.2eb16b86.chunk.js} +1 -1
  31. package/studio/build-local/static/js/{main.20cb1d9f.js → main.2384076c.js} +2 -2
  32. package/studio/build-local/static/js/{offline-app.029491be.chunk.js → offline-app.86377447.chunk.js} +1 -1
  33. package/studio/build-local/static/js/{online-app.80d24598.chunk.js → online-app.e65f9ef3.chunk.js} +1 -1
  34. package/studio/build-local/static/js/{organization-billing.586a6019.chunk.js → organization-billing.1c318ac1.chunk.js} +1 -1
  35. package/studio/build-local/static/js/{organization-users.0facdb34.chunk.js → organization-users.36a2ed5a.chunk.js} +1 -1
  36. package/studio/build-local/static/js/{organization.4e2c7ae6.chunk.js → organization.9a81d022.chunk.js} +1 -1
  37. package/studio/build-local/static/js/{organizations.c8c00251.chunk.js → organizations.af48c8e8.chunk.js} +1 -1
  38. package/studio/build-local/static/js/{profile.a5fbf515.chunk.js → profile.190afea3.chunk.js} +1 -1
  39. package/studio/build-local/static/js/{resetPassword.9ad8cde1.chunk.js → resetPassword.50fa5b91.chunk.js} +1 -1
  40. package/studio/build-local/static/js/{roles-jsonviewer.ad6e2622.chunk.js → roles-jsonviewer.b5d5a908.chunk.js} +1 -1
  41. package/studio/build-local/static/js/{signIn.3d65d81a.chunk.js → signIn.8fbf4021.chunk.js} +1 -1
  42. package/studio/build-local/static/js/{signUp.eaa5b3f0.chunk.js → signUp.459d42df.chunk.js} +1 -1
  43. package/studio/build-local/static/js/{structure-reloader.8c8f5e18.chunk.js → structure-reloader.ceaf6675.chunk.js} +1 -1
  44. package/studio/build-local/static/js/{topnav.73def1f2.chunk.js → topnav.79dbd3ab.chunk.js} +1 -1
  45. package/studio/build-local/static/js/{updatePassword.e0a672ee.chunk.js → updatePassword.b05821cb.chunk.js} +1 -1
  46. package/utility/scripts/restartHdb.js +72 -72
  47. package/studio/build-local/static/js/164.a6861c91.chunk.js +0 -1
  48. /package/studio/build-local/static/js/{873.55a21fe5.chunk.js.LICENSE.txt → 708.1805e937.chunk.js.LICENSE.txt} +0 -0
  49. /package/studio/build-local/static/js/{main.20cb1d9f.js.LICENSE.txt → main.2384076c.js.LICENSE.txt} +0 -0
package/bin/harperdb.js CHANGED
@@ -1,137 +1,137 @@
1
1
  #!/usr/bin/env node
2
- "use strict";var S2=Object.create;var yf=Object.defineProperty;var T2=Object.getOwnPropertyDescriptor;var A2=Object.getOwnPropertyNames;var R2=Object.getPrototypeOf,y2=Object.prototype.hasOwnProperty;var a=(e,t)=>yf(e,"name",{value:t,configurable:!0});var be=(e,t)=>()=>(e&&(t=e(e=0)),t);var w=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),ve=(e,t)=>{for(var r in t)yf(e,r,{get:t[r],enumerable:!0})},aD=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of A2(t))!y2.call(e,s)&&s!==r&&yf(e,s,{get:()=>t[s],enumerable:!(n=T2(t,s))||n.enumerable});return e};var M=(e,t,r)=>(r=e!=null?S2(R2(e)):{},aD(t||!e||!e.__esModule?yf(r,"default",{value:e,enumerable:!0}):r,e)),C=e=>aD(yf({},"__esModule",{value:!0}),e);var it=w((Fye,uD)=>{var{join:b2,dirname:cD}=require("node:path"),{existsSync:O2,readFileSync:N2}=require("node:fs");function w2(){let t=__dirname,r,n=0;for(;!O2(r=b2(t,"package.json"));)if(t===(t=cD(t))||n++>10)throw new Error("Could not find package root");return r}a(w2,"findPackageJson");var lD=w2(),I2=JSON.parse(N2(lD,"utf8")),C2=cD(lD);uD.exports={packageJson:I2,PACKAGE_ROOT:C2}});var nm=w((qye,dD)=>{if(__filename.endsWith("dev.js")){let e=require("fast-glob"),{tmpdir:t}=require("node:os"),{relative:r,join:n}=require("node:path"),{existsSync:s,statSync:i,readFileSync:o,writeFileSync:c}=require("node:fs"),{isMainThread:l}=require("node:worker_threads"),{spawnSync:u,spawn:f}=require("node:child_process");process.setSourceMapsEnabled(!0);let{PACKAGE_ROOT:d}=it(),p=["bin","components","dataLayer","resources","server","sqlTranslator","upgrade","utility","validation"],_="ts-build";if(l){let g=!1,R=!1;if((R=s(n(d,_)))?g=e.sync(p.map(E=>`${E}/**/*.ts`),{cwd:d}).some(E=>{let T=0,b=0;try{T=i(n(d,E)).mtimeMs-5e3,b=i(n(d,_,E.replace(/.ts$/,".js"))).mtimeMs}catch{}return T>b}):g=!0,g){console.log("Compiling TypeScript...");let E=u("npx",["tsc"],{cwd:d});if(E.stdout?.length&&console.log(E.stdout.toString()),E.stderr?.length&&console.log(E.stderr.toString()),R){let T=n(t(),"harperdb-tsc.pid"),b=!1;if(s(T))try{process.kill(+o(T,"utf8"),0),b=!0}catch{}if(!b){console.log("Starting background TypeScript compilation...");let v=f("npx",["tsc","--watch"],{detached:!0,cwd:d,stdio:"ignore"});c(T,v.pid.toString()),v.unref()}}}}let h=dD.constructor,S=h._findPath;h._findPath=function(g,R,E){if(g.startsWith(".")&&!E&&R.length===1&&R[0].startsWith(d)&&!R[0].includes("node_modules")){let T=r(d,R[0]),b;T.startsWith(_)?b=n(d,r(_,T)):b=n(d,_,T);let v=n(b,g),F=v+".js";if(s(F))return F;if(v.includes(".")&&s(v))return v}return S(g,R,E)}}});var G={};ve(G,{AUTH_AUDIT_STATUS:()=>Ys,AUTH_AUDIT_TYPES:()=>la,BOOT_PROPS_FILE_NAME:()=>eQ,BOOT_PROP_PARAMS:()=>pD,CLUSTERING_FLAG:()=>NQ,CLUSTERING_PROCESSES:()=>k2,CLUSTER_MESSAGE_TYPE_ENUM:()=>JA,CLUSTER_OPERATIONS:()=>mQ,CONFIG_PARAMS:()=>x,CONFIG_PARAM_MAP:()=>hD,DATABASES_DIR_NAME:()=>Nc,DATABASES_PARAM_CONFIG:()=>TQ,DEFAULT_DATABASE_NAME:()=>G2,ESCAPED_FORWARD_SLASH_REGEX:()=>Q2,FORWARD_SLASH_REGEX:()=>j2,FUNC_VAL:()=>LQ,GEO_CONVERSION_ENUM:()=>gQ,HDB_COMPONENT_CONFIG_FILE:()=>L2,HDB_CONFIG_FILE:()=>P2,HDB_DEFAULT_CONFIG_FILE:()=>D2,HDB_FILE_PERMISSIONS:()=>rQ,HDB_HOME_DIR_NAME:()=>Z2,HDB_PID_FILE:()=>F2,HDB_PROCESS_SERVICES:()=>H2,HDB_PROC_NAME:()=>M2,HDB_RESTART_SCRIPT:()=>v2,HDB_ROOT_DIR_NAME:()=>KA,HDB_SETTINGS_NAMES:()=>jA,HDB_SUPPORT_ADDRESS:()=>_D,INFO_TABLE_HASH_ATTRIBUTE:()=>cQ,INSERT_MAX_CHARACTER_SIZE:()=>oQ,INSTALL_PROMPTS:()=>iQ,ITC_EVENT_TYPES:()=>XA,JOB_STATUS_ENUM:()=>fQ,JOB_TYPE_ENUM:()=>AQ,JWT_ENUM:()=>Of,LAUNCH_SERVICE_SCRIPTS:()=>V2,LEGACY_CONFIG_PARAMS:()=>SQ,LEGACY_DATABASES_DIR_NAME:()=>om,LICENSE_FILE_NAME:()=>dQ,LICENSE_KEY_DIR_NAME:()=>zA,LICENSE_VALUES:()=>RQ,LOG_LEVELS:()=>$2,LOG_NAMES:()=>q2,MEM_SETTING_KEY:()=>X2,METADATA_PROPERTY:()=>OQ,NODE_ERROR_CODES:()=>bQ,OPERATIONS_ENUM:()=>Yt,PERMS_CRUD_ENUM:()=>PQ,PERMS_UPDATE_RELEASE_TIMESTAMP:()=>CQ,PRE_4_0_0_VERSION:()=>MQ,PROCESS_DESCRIPTORS:()=>B2,PROCESS_NAME_ENV_PROP:()=>sQ,RAM_ALLOCATION_ENUM:()=>yQ,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:()=>cm,REG_KEY_FILE_NAME:()=>uQ,RESTART_TIMEOUT_MS:()=>tQ,ROLE_TYPES_ENUM:()=>K2,S3_BUCKET_AUTH_KEYS:()=>pQ,SEARCH_NOT_FOUND_MESSAGE:()=>W2,SEARCH_WILDCARDS:()=>DQ,SERVICE_ACTIONS_ENUM:()=>EQ,SUPPORT_HELP_MSG:()=>Y2,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:()=>lQ,SYSTEM_SCHEMA_NAME:()=>bf,SYSTEM_TABLE_NAMES:()=>fu,THREAD_TYPES:()=>ZA,TIME_STAMP_NAMES:()=>IQ,TIME_STAMP_NAMES_ENUM:()=>wQ,TRANSACTIONS_DIR_NAME:()=>nQ,UNICODE_FORWARD_SLASH:()=>J2,UNICODE_PERIOD:()=>z2,UPGRADE_JSON_FIELD_NAMES_ENUM:()=>aQ,VALID_S3_FILE_TYPES:()=>_Q,VALID_SQL_OPS_ENUM:()=>hQ,VALUE_SEARCH_COMPARATORS:()=>am,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:()=>QA});var sm,im,P2,D2,KA,L2,M2,v2,fD,VA,YA,WA,U2,x2,B2,H2,k2,F2,G2,q2,$2,V2,K2,_D,Y2,W2,z2,j2,J2,Q2,X2,bf,Z2,zA,eQ,tQ,rQ,Nc,om,nQ,sQ,pD,iQ,oQ,aQ,fu,cQ,lQ,uQ,dQ,fQ,Yt,_Q,pQ,hQ,mQ,EQ,gQ,jA,SQ,x,hD,TQ,AQ,JA,RQ,yQ,bQ,OQ,NQ,mD,ED,wQ,IQ,CQ,am,QA,PQ,DQ,LQ,cm,Of,XA,ZA,MQ,Ys,la,H=be(()=>{sm=require("node:path"),im=M(it()),P2="harperdb-config.yaml",D2="defaultConfig.yaml",KA="hdb",L2="config.yaml",M2="harperdb.js",v2="restartHdb.js",fD="HarperDB",VA="Custom Functions",YA="Clustering Hub",WA="Clustering Leaf",U2="Clustering Ingest Service",x2="Clustering Reply Service",B2={HDB:fD,CLUSTERING_HUB:YA,CLUSTERING_LEAF:WA,CLUSTERING_INGEST_SERVICE:U2,CLUSTERING_REPLY_SERVICE:x2,CUSTOM_FUNCTIONS:VA,RESTART_HDB:"Restart HDB",INSTALL:"Install",RUN:"Run",STOP:"Stop",UPGRADE:"Upgrade",REGISTER:"Register",JOB:"Job",CLUSTERING_UPGRADE_4_0_0:"Upgrade-4-0-0"},H2={harperdb:fD,"clustering hub":YA,"clustering leaf":WA,"custom functions":VA,custom_functions:VA,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers",http:"http"},k2={CLUSTERING_HUB_PROC_DESCRIPTOR:YA,CLUSTERING_LEAF_PROC_DESCRIPTOR:WA},F2="hdb.pid",G2="data",q2={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},$2={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},V2={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:(0,sm.join)(im.PACKAGE_ROOT,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:(0,sm.join)(im.PACKAGE_ROOT,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:(0,sm.join)(im.PACKAGE_ROOT,"launchServiceScripts/launchUpdateNodes4-0-0.js")},K2={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},_D="support@harperdb.io",Y2=`For support, please submit a request at https://harperdbhelp.zendesk.com/hc/en-us/requests/new or contact ${_D}`,W2="None of the specified records were found.",z2="U+002E",j2=/\//g,J2="U+002F",Q2=/U\+002F/g,X2="--max-old-space-size=",bf="system",Z2=".harperdb",zA="keys",eQ="hdb_boot_properties.file",tQ=6e4,rQ=448,Nc="database",om="schema",nQ="transactions",sQ="PROCESS_NAME",pD={SETTINGS_PATH_KEY:"settings_path"},iQ={TC_AGREEMENT:"TC_AGREEMENT",CLUSTERING_USER:"CLUSTERING_USER",CLUSTERING_PASSWORD:"CLUSTERING_PASSWORD",HDB_ADMIN_USERNAME:"HDB_ADMIN_USERNAME",HDB_ADMIN_PASSWORD:"HDB_ADMIN_PASSWORD",OPERATIONSAPI_ROOT:"OPERATIONSAPI_ROOT",ROOTPATH:"ROOTPATH",CLUSTERING_NODENAME:"CLUSTERING_NODENAME",CLUSTERING_ENABLED:"CLUSTERING_ENABLED",HDB_CONFIG:"HDB_CONFIG",DEFAULTS_MODE:"DEFAULTS_MODE",REPLICATION_HOSTNAME:"REPLICATION_HOSTNAME",CLUSTERING_PORT:"CLUSTERING_PORT",HDB_ROOT:"HDB_ROOT",SERVER_PORT:"SERVER_PORT",NODE_NAME:"NODE_NAME",CLUSTERING:"CLUSTERING"},oQ=250,aQ={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},fu={JOB_TABLE_NAME:"hdb_job",NODE_TABLE_NAME:"hdb_nodes",ATTRIBUTE_TABLE_NAME:"hdb_attribute",LICENSE_TABLE_NAME:"hdb_license",ROLE_TABLE_NAME:"hdb_role",SCHEMA_TABLE_NAME:"hdb_schema",TABLE_TABLE_NAME:"hdb_table",USER_TABLE_NAME:"hdb_user",INFO_TABLE_NAME:"hdb_info"},cQ="info_id",lQ={ATTR_ATTRIBUTE_KEY:"attribute",ATTR_CREATEDDATE_KEY:"createddate",ATTR_HASH_ATTRIBUTE_KEY:"hash_attribute",ATTR_ID_KEY:"id",ATTR_NAME_KEY:"name",ATTR_PASSWORD_KEY:"password",ATTR_RESIDENCE_KEY:"residence",ATTR_ROLE_KEY:"role",ATTR_SCHEMA_KEY:"schema",ATTR_SCHEMA_TABLE_KEY:"schema_table",ATTR_TABLE_KEY:"table",ATTR_USERNAME_KEY:"username"},uQ="060493.ks",dQ=".license",fQ={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},Yt={INSERT:"insert",UPDATE:"update",UPSERT:"upsert",SEARCH_BY_CONDITIONS:"search_by_conditions",SEARCH_BY_HASH:"search_by_hash",SEARCH_BY_ID:"search_by_id",SEARCH_BY_VALUE:"search_by_value",SEARCH:"search",SQL:"sql",CSV_DATA_LOAD:"csv_data_load",CSV_FILE_LOAD:"csv_file_load",CSV_URL_LOAD:"csv_url_load",CREATE_SCHEMA:"create_schema",CREATE_DATABASE:"create_database",CREATE_TABLE:"create_table",CREATE_ATTRIBUTE:"create_attribute",DROP_SCHEMA:"drop_schema",DROP_DATABASE:"drop_database",DROP_TABLE:"drop_table",DESCRIBE_SCHEMA:"describe_schema",DESCRIBE_DATABASE:"describe_database",DESCRIBE_TABLE:"describe_table",DESCRIBE_ALL:"describe_all",DELETE:"delete",ADD_USER:"add_user",ALTER_USER:"alter_user",DROP_USER:"drop_user",LIST_USERS:"list_users",LIST_ROLES:"list_roles",ADD_ROLE:"add_role",ALTER_ROLE:"alter_role",DROP_ROLE:"drop_role",USER_INFO:"user_info",READ_LOG:"read_log",ADD_NODE:"add_node",UPDATE_NODE:"update_node",SET_NODE_REPLICATION:"set_node_replication",EXPORT_TO_S3:"export_to_s3",IMPORT_FROM_S3:"import_from_s3",DELETE_FILES_BEFORE:"delete_files_before",DELETE_RECORDS_BEFORE:"delete_records_before",EXPORT_LOCAL:"export_local",SEARCH_JOBS_BY_START_DATE:"search_jobs_by_start_date",GET_JOB:"get_job",DELETE_JOB:"delete_job",UPDATE_JOB:"update_job",GET_FINGERPRINT:"get_fingerprint",SET_LICENSE:"set_license",GET_REGISTRATION_INFO:"registration_info",CONFIGURE_CLUSTER:"configure_cluster",SET_CONFIGURATION:"set_configuration",CLUSTER_STATUS:"cluster_status",CLUSTER_NETWORK:"cluster_network",DROP_ATTRIBUTE:"drop_attribute",REMOVE_NODE:"remove_node",RESTART:"restart",RESTART_SERVICE:"restart_service",CATCHUP:"catchup",SYSTEM_INFORMATION:"system_information",DELETE_AUDIT_LOGS_BEFORE:"delete_audit_logs_before",READ_AUDIT_LOG:"read_audit_log",CREATE_AUTHENTICATION_TOKENS:"create_authentication_tokens",LOGIN:"login",LOGOUT:"logout",REFRESH_OPERATION_TOKEN:"refresh_operation_token",GET_CONFIGURATION:"get_configuration",CUSTOM_FUNCTIONS_STATUS:"custom_functions_status",GET_CUSTOM_FUNCTIONS:"get_custom_functions",GET_CUSTOM_FUNCTION:"get_custom_function",SET_CUSTOM_FUNCTION:"set_custom_function",GET_COMPONENTS:"get_components",GET_COMPONENT_FILE:"get_component_file",SET_COMPONENT_FILE:"set_component_file",DROP_COMPONENT:"drop_component",DROP_CUSTOM_FUNCTION:"drop_custom_function",ADD_CUSTOM_FUNCTION_PROJECT:"add_custom_function_project",ADD_COMPONENT:"add_component",DROP_CUSTOM_FUNCTION_PROJECT:"drop_custom_function_project",PACKAGE_CUSTOM_FUNCTION_PROJECT:"package_custom_function_project",DEPLOY_CUSTOM_FUNCTION_PROJECT:"deploy_custom_function_project",PACKAGE_COMPONENT:"package_component",DEPLOY_COMPONENT:"deploy_component",CLUSTER_SET_ROUTES:"cluster_set_routes",CLUSTER_DELETE_ROUTES:"cluster_delete_routes",CLUSTER_GET_ROUTES:"cluster_get_routes",READ_TRANSACTION_LOG:"read_transaction_log",DELETE_TRANSACTION_LOGS_BEFORE:"delete_transaction_logs_before",INSTALL_NODE_MODULES:"install_node_modules",AUDIT_NODE_MODULES:"audit_node_modules",PURGE_STREAM:"purge_stream",GET_BACKUP:"get_backup",SIGN_CERTIFICATE:"sign_certificate",CREATE_CSR:"create_csr",LIST_CERTIFICATES:"list_certificates",ADD_CERTIFICATES:"add_certificate",REMOVE_CERTIFICATE:"remove_certificate",ADD_NODE_BACK:"add_node_back",REMOVE_NODE_BACK:"remove_node_back",ADD_SSH_KEY:"add_ssh_key",UPDATE_SSH_KEY:"update_ssh_key",DELETE_SSH_KEY:"delete_ssh_key",LIST_SSH_KEYS:"list_ssh_keys",SET_SSH_KNOWN_HOSTS:"set_ssh_known_hosts",GET_SSH_KNOWN_HOSTS:"get_ssh_known_hosts",GET_KEY:"get_key"},_Q={CSV:".csv",JSON:".json"},pQ={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},hQ={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},mQ={[Yt.INSERT]:Yt.INSERT,[Yt.UPDATE]:Yt.UPDATE,[Yt.UPSERT]:Yt.UPSERT,[Yt.DELETE]:Yt.DELETE},EQ={DEV:"dev",RUN:"run",START:"start",INSTALL:"install",REGISTER:"register",STOP:"stop",RESTART:"restart",VERSION:"version",UPGRADE:"upgrade",HELP:"help",STATUS:"status",OPERATION:"operation",RENEWCERTS:"renew-certs",COPYDB:"copy-db"},gQ={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},jA={HDB_ROOT_KEY:"HDB_ROOT",SERVER_PORT_KEY:"SERVER_PORT",CERT_KEY:"CERTIFICATE",PRIVATE_KEY_KEY:"PRIVATE_KEY",HTTP_SECURE_ENABLED_KEY:"HTTPS_ON",CORS_ENABLED_KEY:"CORS_ON",CORS_WHITELIST_KEY:"CORS_WHITELIST",LOG_LEVEL_KEY:"LOG_LEVEL",LOGGER_KEY:"LOGGER",LOG_PATH_KEY:"LOG_PATH",LOG_ROTATE:"LOG_ROTATE",LOG_ROTATE_MAX_SIZE:"LOG_ROTATE_MAX_SIZE",LOG_ROTATE_RETAIN:"LOG_ROTATE_RETAIN",LOG_ROTATE_COMPRESS:"LOG_ROTATE_COMPRESS",LOG_ROTATE_DATE_FORMAT:"LOG_ROTATE_DATE_FORMAT",LOG_ROTATE_ROTATE_MODULE:"LOG_ROTATE_ROTATE_MODULE",LOG_ROTATE_WORKER_INTERVAL:"LOG_ROTATE_WORKER_INTERVAL",LOG_ROTATE_ROTATE_INTERVAL:"LOG_ROTATE_ROTATE_INTERVAL",LOG_ROTATE_TIMEZONE:"LOG_ROTATE_TIMEZONE",LOG_DAILY_ROTATE_KEY:"LOG_DAILY_ROTATE",LOG_MAX_DAILY_FILES_KEY:"LOG_MAX_DAILY_FILES",PROPS_ENV_KEY:"NODE_ENV",SETTINGS_PATH_KEY:"settings_path",CLUSTERING_PORT_KEY:"CLUSTERING_PORT",CLUSTERING_NODE_NAME_KEY:"NODE_NAME",CLUSTERING_ENABLED_KEY:"CLUSTERING",ALLOW_SELF_SIGNED_SSL_CERTS:"ALLOW_SELF_SIGNED_SSL_CERTS",MAX_HDB_PROCESSES:"MAX_HDB_PROCESSES",INSTALL_USER:"install_user",CLUSTERING_USER_KEY:"CLUSTERING_USER",MAX_CLUSTERING_PROCESSES:"MAX_CLUSTERING_PROCESSES",SERVER_TIMEOUT_KEY:"SERVER_TIMEOUT_MS",SERVER_KEEP_ALIVE_TIMEOUT_KEY:"SERVER_KEEP_ALIVE_TIMEOUT",SERVER_HEADERS_TIMEOUT_KEY:"SERVER_HEADERS_TIMEOUT",DISABLE_TRANSACTION_LOG_KEY:"DISABLE_TRANSACTION_LOG",OPERATION_TOKEN_TIMEOUT_KEY:"OPERATION_TOKEN_TIMEOUT",REFRESH_TOKEN_TIMEOUT_KEY:"REFRESH_TOKEN_TIMEOUT",CUSTOM_FUNCTIONS_ENABLED_KEY:"CUSTOM_FUNCTIONS",CUSTOM_FUNCTIONS_PORT_KEY:"CUSTOM_FUNCTIONS_PORT",CUSTOM_FUNCTIONS_DIRECTORY_KEY:"CUSTOM_FUNCTIONS_DIRECTORY",MAX_CUSTOM_FUNCTION_PROCESSES:"MAX_CUSTOM_FUNCTION_PROCESSES",LOG_TO_FILE:"LOG_TO_FILE",LOG_TO_STDSTREAMS:"LOG_TO_STDSTREAMS",RUN_IN_FOREGROUND:"RUN_IN_FOREGROUND",LOCAL_STUDIO_ON:"LOCAL_STUDIO_ON",STORAGE_WRITE_ASYNC:"STORAGE_WRITE_ASYNC"},SQ={CUSTOMFUNCTIONS_ENABLED:"customFunctions_enabled",CUSTOMFUNCTIONS_NETWORK_PORT:"customFunctions_network_port",CUSTOMFUNCTIONS_TLS_CERTIFICATE:"customFunctions_tls_certificate",CUSTOMFUNCTIONS_NETWORK_CORS:"customFunctions_network_cors",CUSTOMFUNCTIONS_NETWORK_CORSACCESSLIST:"customFunctions_network_corsAccessList",CUSTOMFUNCTIONS_NETWORK_HEADERSTIMEOUT:"customFunctions_network_headersTimeout",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",CUSTOMFUNCTIONS_NETWORK_KEEPALIVETIMEOUT:"customFunctions_network_keepAliveTimeout",CUSTOMFUNCTIONS_TLS_PRIVATEKEY:"customFunctions_tls_privateKey",CUSTOMFUNCTIONS_TLS_CERT_AUTH:"customFunctions_tls_certificateAuthority",CUSTOMFUNCTIONS_NETWORK_TIMEOUT:"customFunctions_network_timeout",CUSTOMFUNCTIONS_NODEENV:"customFunctions_nodeEnv",CUSTOMFUNCTIONS_ROOT:"customFunctions_root"},x={ANALYTICS_AGGREGATEPERIOD:"analytics_aggregatePeriod",AUTHENTICATION_AUTHORIZELOCAL:"authentication_authorizeLocal",AUTHENTICATION_CACHETTL:"authentication_cacheTTL",AUTHENTICATION_ENABLESESSIONS:"authentication_enableSessions",AUTHENTICATION_OPERATIONTOKENTIMEOUT:"authentication_operationTokenTimeout",AUTHENTICATION_REFRESHTOKENTIMEOUT:"authentication_refreshTokenTimeout",AUTHENTICATION_HASHFUNCTION:"authentication_hashFunction",CLUSTERING_USER:"clustering_user",CLUSTERING_ENABLED:"clustering_enabled",CLUSTERING_HUBSERVER_CLUSTER_NAME:"clustering_hubServer_cluster_name",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT:"clustering_hubServer_cluster_network_port",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES:"clustering_hubServer_cluster_network_routes",CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT:"clustering_hubServer_leafNodes_network_port",CLUSTERING_HUBSERVER_NETWORK_PORT:"clustering_hubServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_PORT:"clustering_leafServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_ROUTES:"clustering_leafServer_network_routes",CLUSTERING_LEAFSERVER_STREAMS_MAXAGE:"clustering_leafServer_streams_maxAge",CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES:"clustering_leafServer_streams_maxBytes",CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS:"clustering_leafServer_streams_maxMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS:"clustering_leafServer_streams_maxConsumeMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS:"clustering_leafServer_streams_maxIngestThreads",CLUSTERING_LEAFSERVER_STREAMS_PATH:"clustering_leafServer_streams_path",CLUSTERING_NODENAME:"clustering_nodeName",CLUSTERING_TLS_CERTIFICATE:"clustering_tls_certificate",CLUSTERING_TLS_PRIVATEKEY:"clustering_tls_privateKey",CLUSTERING_TLS_CERT_AUTH:"clustering_tls_certificateAuthority",CLUSTERING_TLS_INSECURE:"clustering_tls_insecure",CLUSTERING_TLS_VERIFY:"clustering_tls_verify",CLUSTERING_LOGLEVEL:"clustering_logLevel",CLUSTERING_REPUBLISHMESSAGES:"clustering_republishMessages",CLUSTERING_DATABASELEVEL:"clustering_databaseLevel",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",THREADS:"threads",THREADS_COUNT:"threads_count",THREADS_DEBUG:"threads_debug",THREADS_DEBUG_STARTINGPORT:"threads_debug_startingPort",THREADS_DEBUG_PORT:"threads_debug_port",THREADS_DEBUG_HOST:"threads_debug_host",THREADS_DEBUG_WAITFORDEBUGGER:"threads_debug_waitForDebugger",THREADS_MAXHEAPMEMORY:"threads_maxHeapMemory",HTTP_SESSIONAFFINITY:"http_sessionAffinity",HTTP_COMPRESSIONTHRESHOLD:"http_compressionThreshold",HTTP_CORS:"http_cors",HTTP_CORSACCESSLIST:"http_corsAccessList",HTTP_CORSACCESSCONTROLALLOWHEADERS:"http_corsAccessControlAllowHeaders",HTTP_HEADERSTIMEOUT:"http_headersTimeout",HTTP_KEEPALIVETIMEOUT:"http_keepAliveTimeout",HTTP_MAXPARAMLENGTH:"http_maxParamLength",HTTP_TIMEOUT:"http_timeout",HTTP_PORT:"http_port",HTTP_SECUREPORT:"http_securePort",HTTP_MTLS:"http_mtls",HTTP_MTLS_REQUIRED:"http_mtls_required",HTTP_MTLS_USER:"http_mtls_user",HTTP_MAXHEADERSIZE:"http_maxHeaderSize",HTTP_THREADRANGE:"http_threadRange",HTTP_HTTP2:"http_http2",LOCALSTUDIO_ENABLED:"localStudio_enabled",LOGGING_CONSOLE:"logging_console",LOGGING_FILE:"logging_file",LOGGING_LEVEL:"logging_level",LOGGING_ROOT:"logging_root",LOGGING_ROTATION_ENABLED:"logging_rotation_enabled",LOGGING_ROTATION_COMPRESS:"logging_rotation_compress",LOGGING_ROTATION_INTERVAL:"logging_rotation_interval",LOGGING_ROTATION_MAXSIZE:"logging_rotation_maxSize",LOGGING_ROTATION_PATH:"logging_rotation_path",LOGGING_ROTATION_RETENTION:"logging_rotation_retention",LOGGING_STDSTREAMS:"logging_stdStreams",LOGGING_AUDITLOG:"logging_auditLog",LOGGING_AUDITRETENTION:"logging_auditRetention",LOGGING_AUDITAUTHEVENTS_LOGFAILED:"logging_auditAuthEvents_logFailed",LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL:"logging_auditAuthEvents_logSuccessful",OPERATIONSAPI_NETWORK_CORS:"operationsApi_network_cors",OPERATIONSAPI_NETWORK_CORSACCESSLIST:"operationsApi_network_corsAccessList",OPERATIONSAPI_NETWORK_HEADERSTIMEOUT:"operationsApi_network_headersTimeout",OPERATIONSAPI_NETWORK_HTTPS:"operationsApi_network_https",OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT:"operationsApi_network_keepAliveTimeout",OPERATIONSAPI_NETWORK_PORT:"operationsApi_network_port",OPERATIONSAPI_NETWORK_DOMAINSOCKET:"operationsApi_network_domainSocket",OPERATIONSAPI_NETWORK_SECUREPORT:"operationsApi_network_securePort",OPERATIONSAPI_NETWORK_HTTP2:"operationsApi_network_http2",OPERATIONSAPI_TLS:"operationsApi_tls",OPERATIONSAPI_TLS_CERTIFICATE:"operationsApi_tls_certificate",OPERATIONSAPI_TLS_PRIVATEKEY:"operationsApi_tls_privateKey",OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY:"operationsApi_tls_certificateAuthority",OPERATIONSAPI_NETWORK_TIMEOUT:"operationsApi_network_timeout",OPERATIONSAPI_SYSINFO_NETWORK:"operationsApi_sysInfo_network",OPERATIONSAPI_SYSINFO_DISK:"operationsApi_sysInfo_disk",REPLICATION:"replication",REPLICATION_HOSTNAME:"replication_hostname",REPLICATION_URL:"replication_url",REPLICATION_PORT:"replication_port",REPLICATION_SECUREPORT:"replication_securePort",REPLICATION_ROUTES:"replication_routes",REPLICATION_DATABASES:"replication_databases",REPLICATION_ENABLEROOTCAS:"replication_enableRootCAs",REPLICATION_SHARD:"replication_shard",REPLICATION_COPYTABLESTOCATCHUP:"replication_copyTablesToCatchUp",ROOTPATH:"rootPath",SERIALIZATION_BIGINT:"serialization_bigInt",STORAGE_WRITEASYNC:"storage_writeAsync",STORAGE_OVERLAPPINGSYNC:"storage_overlappingSync",STORAGE_CACHING:"storage_caching",STORAGE_COMPRESSION:"storage_compression",STORAGE_NOREADAHEAD:"storage_noReadAhead",STORAGE_PREFETCHWRITES:"storage_prefetchWrites",STORAGE_ENCRYPTION:"storage_encryption",STORAGE_MAXTRANSACTIONQUEUETIME:"storage_maxTransactionQueueTime",STORAGE_PATH:"storage_path",STORAGE_BLOBPATHS:"storage_blobPaths",STORAGE_AUDIT_PATH:"storage_audit_path",STORAGE_MAXFREESPACETOLOAD:"storage_maxFreeSpaceToLoad",STORAGE_MAXFREESPACETORETAIN:"storage_maxFreeSpaceToRetain",STORAGE_PAGESIZE:"storage_pageSize",STORAGE_COMPRESSION_DICTIONARY:"storage_compression_dictionary",STORAGE_COMPRESSION_THRESHOLD:"storage_compression_threshold",STORAGE_COMPACTONSTART:"storage_compactOnStart",STORAGE_COMPACTONSTARTKEEPBACKUP:"storage_compactOnStartKeepBackup",STORAGE_RECLAMATION_THRESHOLD:"storage_reclamation_threshold",STORAGE_RECLAMATION_INTERVAL:"storage_reclamation_interval",STORAGE_RECLAMATION_EVICTIONFACTOR:"storage_reclamation_evictionFactor",DATABASES:"databases",IGNORE_SCRIPTS:"ignoreScripts",MQTT_NETWORK_PORT:"mqtt_network_port",MQTT_WEBSOCKET:"mqtt_webSocket",MQTT_NETWORK_SECUREPORT:"mqtt_network_securePort",MQTT_NETWORK_MTLS:"mqtt_network_mtls",MQTT_NETWORK_MTLS_REQUIRED:"mqtt_network_mtls_required",MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY:"mqtt_network_mtls_certificateAuthority",MQTT_NETWORK_MTLS_USER:"mqtt_network_mtls_user",MQTT_REQUIREAUTHENTICATION:"mqtt_requireAuthentication",COMPONENTSROOT:"componentsRoot",TLS_CERTIFICATE:"tls_certificate",TLS_PRIVATEKEY:"tls_privateKey",TLS_CERTIFICATEAUTHORITY:"tls_certificateAuthority",TLS_CIPHERS:"tls_ciphers",TLS:"tls",CLONED:"cloned"},hD={settings_path:pD.SETTINGS_PATH_KEY,hdb_root_key:x.ROOTPATH,hdb_root:x.ROOTPATH,rootpath:x.ROOTPATH,server_port_key:x.OPERATIONSAPI_NETWORK_PORT,server_port:x.OPERATIONSAPI_NETWORK_PORT,cert_key:x.TLS_CERTIFICATE,certificate:x.TLS_CERTIFICATE,private_key_key:x.TLS_PRIVATEKEY,private_key:x.TLS_PRIVATEKEY,http_secure_enabled_key:x.OPERATIONSAPI_NETWORK_HTTPS,https_on:x.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:x.OPERATIONSAPI_NETWORK_CORS,cors_on:x.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:x.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:x.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:x.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:x.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:x.LOGGING_LEVEL,log_level:x.LOGGING_LEVEL,log_path_key:x.LOGGING_ROOT,log_path:x.LOGGING_ROOT,clustering_node_name_key:x.CLUSTERING_NODENAME,node_name:x.CLUSTERING_NODENAME,clustering_enabled_key:x.CLUSTERING_ENABLED,clustering:x.CLUSTERING_ENABLED,max_http_threads:x.THREADS_COUNT,max_hdb_processes:x.THREADS_COUNT,server_timeout_key:x.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:x.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:x.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:x.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:x.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:x.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:x.LOGGING_AUDITLOG,disable_transaction_log:x.LOGGING_AUDITLOG,operation_token_timeout_key:x.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:x.AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:x.AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:x.AUTHENTICATION_REFRESHTOKENTIMEOUT,custom_functions_port_key:x.HTTP_PORT,custom_functions_port:x.HTTP_PORT,custom_functions_directory_key:x.COMPONENTSROOT,custom_functions_directory:x.COMPONENTSROOT,max_custom_function_processes:x.THREADS_COUNT,logging_console:x.LOGGING_CONSOLE,log_to_file:x.LOGGING_FILE,log_to_stdstreams:x.LOGGING_STDSTREAMS,local_studio_on:x.LOCALSTUDIO_ENABLED,clustering_port:x.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:x.CLUSTERING_USER,customfunctions_network_port:x.HTTP_PORT,customfunctions_tls_certificate:x.TLS_CERTIFICATE,customfunctions_network_cors:x.HTTP_CORS,customfunctions_network_corsaccesslist:x.HTTP_CORSACCESSLIST,customfunctions_network_headerstimeout:x.HTTP_HEADERSTIMEOUT,customfunctions_network_https:x.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:x.HTTP_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:x.TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:x.TLS_CERTIFICATEAUTHORITY,customfunctions_network_timeout:x.HTTP_TIMEOUT,customfunctions_tls:x.TLS,http_threads:x.THREADS_COUNT,threads:x.THREADS_COUNT,threads_count:x.THREADS_COUNT,customfunctions_processes:x.THREADS_COUNT,customfunctions_root:x.COMPONENTSROOT,operationsapi_root:x.ROOTPATH};for(let e in x){let t=x[e];hD[t.toLowerCase()]=t}TQ={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},AQ={csv_file_load:"csv_file_load",csv_data_load:Yt.CSV_DATA_LOAD,csv_url_load:Yt.CSV_URL_LOAD,delete_files_before:"delete_files_before",delete_records_before:"delete_records_before",delete_audit_logs_before:"delete_audit_logs_before",delete_transaction_logs_before:"delete_transaction_logs_before",empty_trash:"empty_trash",export_local:"export_local",export_to_s3:"export_to_s3",import_from_s3:"import_from_s3",restart_service:"restart_service"},JA={CLUSTERING_PAYLOAD:"clustering_payload",DELEGATE_THREAD_RESPONSE:"delegate_thread_response",CLUSTERING:"clustering",SCHEMA:"schema",CLUSTER_STATUS:"cluster_status",JOB:"job",CHILD_STARTED:"child_started",CHILD_STOPPED:"child_stopped",USER:"user",RESTART:"restart"},RQ={VERSION_DEFAULT:"2.2.0"},yQ={DEVELOPMENT:8192,DEFAULT:512},bQ={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},OQ=Symbol("metadata"),NQ="__clustering__",mD="__createdtime__",ED="__updatedtime__",wQ={CREATED_TIME:mD,UPDATED_TIME:ED},IQ=[mD,ED],CQ=15984864e5,am={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},QA={"<":"LESS","<=":"LESS_OR_EQ",">":"GREATER",">=":"GREATER_OR_EQ","...":"BETWEEN"},PQ={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},DQ=["*","%"],LQ="func_val",cm={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},Of={JWT_PRIVATE_KEY_NAME:".jwtPrivate.key",JWT_PUBLIC_KEY_NAME:".jwtPublic.key",JWT_PASSPHRASE_NAME:".jwtPass"},XA={SHUTDOWN:"shutdown",CHILD_STARTED:"child_started",CHILD_STOPPED:"child_stopped",SCHEMA:"schema",USER:"user",CLUSTER_STATUS_RESPONSE:"cluster_status_response",CLUSTER_STATUS_REQUEST:"cluster_status_request",METRICS:"metrics",GET_METRICS:"get_metrics",RESTART:"restart",START_JOB:"start_job",NATS_CONSUMER_UPDATE:"nats_consumer_update"},ZA={HTTP:"http"},MQ="3.x.x",Ys={SUCCESS:"success",FAILURE:"failure"},la={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"}});var ua=w(($ye,TD)=>{"use strict";var gD=require("minimist");TD.exports=vQ;function vQ(e=[],t=!1){if(!Array.isArray(e))return{};let r,n;t?(r=SD(process.env),n=SD(gD(process.argv))):(r=process.env,n=gD(process.argv));let s={};for(let i=0,o=e.length;i<o;i++){let c=e[i];n[c]!==void 0?s[c]=n[c].toString().trim():r[c]!==void 0&&(s[c]=r[c].toString().trim())}return s}a(vQ,"assignCMDENVVariables");function SD(e){let t,r=Object.keys(e),n=r.length,s={};for(;n--;)t=r[n],s[t.toLowerCase()]=e[t];return s}a(SD,"objKeysToLowerCase")});var Ti=w(Ws=>{"use strict";global.Resource=Ws.Resource=void 0;global.tables=Ws.tables={};global.databases=Ws.databases={};global.getUser=Ws.getUser=void 0;global.authenticateUser=Ws.authenticateUser=void 0;global.server=Ws.server={};global.contentTypes=Ws.contentTypes=null;global.threads=Ws.threads=[];global.logger={};Ws._assignPackageExport=(e,t)=>{global[e]=Ws[e]=t}});var z=w((UD,xD)=>{"use strict";var no=require("fs-extra"),{workerData:UQ,threadId:xQ,isMainThread:BQ}=require("worker_threads"),Ri=require("path"),bD=require("yaml"),OD=require("properties-reader"),Wt=(H(),C(G)),AD=ua(),HQ=require("os"),{PACKAGE_ROOT:nR}=it(),{_assignPackageExport:kQ}=Ti(),RD=process.stdout.nativeWrite||(process.stdout.nativeWrite=process.stdout.write),Er={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},ND={STDOUT:"stdOut",STDERR:"stdErr"},FQ=Ri.join(nR,"logs"),GQ=Ri.join(nR,"config/yaml/",Wt.HDB_DEFAULT_CONFIG_FILE),qQ=1e4,eR,Ai,ms,Pr,lm,Nf,um,da,wf;wf===void 0&&wD();Object.assign(UD,{notify:LD,fatal:MD,error:dm,warn:vD,info:CD,debug:DD,trace:PD,setLogLevel:JQ,log_level:Pr,loggerWithTag:KQ,suppressLogging:YQ,initLogSettings:wD,logCustomLevel:zQ,closeLogFile:sR,logsAtLevel:$Q,getLogFilePath:a(()=>um,"getLogFilePath"),OUTPUTS:ND,AuthAuditLog:ZQ});kQ("logger",xD.exports);var tR;function $Q(e){return Er[Pr]<=Er[e]}a($Q,"logsAtLevel");function wD(e=!1){try{if(wf===void 0||e){sR();let t=jQ(),r=AD(["ROOTPATH"]);try{wf=OD(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!no.pathExistsSync(Ri.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE)))throw n}if({level:Pr,config_log_path:Nf,to_file:Ai,to_stream:ms}=QQ(r.ROOTPATH?Ri.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE):wf.get("settings_path")),lm=Wt.LOG_NAMES.HDB,um=Ri.join(Nf,lm),BQ)try{require("segfault-handler").registerHandler(Ri.join(Nf,"crash.log"))}catch{}}}catch(t){if(wf=void 0,t.code===Wt.NODE_ERROR_CODES.ENOENT||t.code===Wt.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=AD(Object.keys(Wt.CONFIG_PARAM_MAP),!0);for(let o in r){let c=Wt.CONFIG_PARAM_MAP[o];c&&c.toLowerCase();let l=r[o];if(c===Wt.CONFIG_PARAMS.LOGGING_LEVEL){Pr=l;continue}if(c===Wt.CONFIG_PARAMS.LOGGING_STDSTREAMS){ms=l;continue}c===Wt.CONFIG_PARAMS.LOGGING_FILE&&(Ai=c),c===Wt.CONFIG_PARAMS.LOGGING_CONSOLE&&(eR=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=XQ();Ai=Ai===void 0?s:Ai,Ai=yD(Ai),ms=ms===void 0?i:ms,ms=yD(ms),Pr=Pr===void 0?n:Pr,Nf=FQ,lm=Wt.LOG_NAMES.INSTALL,um=Ri.join(Nf,lm);return}throw dm("Error initializing log settings"),dm(t),t}process.env.DEV_MODE&&(ms=!0),VQ()}a(wD,"initLogSettings");var fa=!0;function VQ(){Ai&&(process.stdout.write=function(e){return typeof e=="string"&&fa&&eR!==!1&&(rR(),e=e.toString(),e[e.length-1]===`
3
- `&&(e=e.slice(0,-1)),no.appendFileSync(da,zs("stdout",[e]))),RD.apply(process.stdout,arguments)},process.stderr.write=function(e){return typeof e=="string"&&fa&&eR!==!1&&(rR(),e[e.length-1]===`
4
- `&&(e=e.slice(0,-1)),no.appendFileSync(da,zs("stderr",[e]))),RD.apply(process.stderr,arguments)})}a(VQ,"stdioLogging");function KQ(e,t){let r={tagName:e.replace(/ /g,"-")};return{notify:n(LD,"notify"),fatal:n(MD,"fatal"),error:n(dm,"error"),warn:n(vD,"warn"),info:n(CD,"info"),debug:n(DD,"debug"),trace:n(PD,"trace")};function n(s,i){return!t||Er[Pr]<=Er[i]?function(...o){return s(r,...o)}:null}}a(KQ,"loggerWithTag");function YQ(e){try{fa=!1,e()}finally{fa=!0}}a(YQ,"suppressLogging");var WQ=UQ?.name?.replace(/ /g,"-")||"main";function zs(e,t){let r=new Date(Date.now()).toISOString(),n="",s=t.length,i=s-1,o=[e],c=0,l;for(typeof t[0]=="object"&&(t[0]?.tagName?(o.push(t[0]?.tagName),c++):t[0]?.serviceName&&(l=t[0]?.serviceName,c++)),o.unshift(l||WQ+"/"+xQ);c<s;c++){let u=t[c];if(u instanceof Error&&u.stack)n+=u.stack,Object.keys(u).length>0&&(n+=`
2
+ "use strict";var S2=Object.create;var bf=Object.defineProperty;var T2=Object.getOwnPropertyDescriptor;var A2=Object.getOwnPropertyNames;var R2=Object.getPrototypeOf,y2=Object.prototype.hasOwnProperty;var a=(e,t)=>bf(e,"name",{value:t,configurable:!0});var be=(e,t)=>()=>(e&&(t=e(e=0)),t);var I=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),Ue=(e,t)=>{for(var r in t)bf(e,r,{get:t[r],enumerable:!0})},aD=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of A2(t))!y2.call(e,s)&&s!==r&&bf(e,s,{get:()=>t[s],enumerable:!(n=T2(t,s))||n.enumerable});return e};var M=(e,t,r)=>(r=e!=null?S2(R2(e)):{},aD(t||!e||!e.__esModule?bf(r,"default",{value:e,enumerable:!0}):r,e)),P=e=>aD(bf({},"__esModule",{value:!0}),e);var st=I((Hye,uD)=>{var{join:b2,dirname:cD}=require("node:path"),{existsSync:O2,readFileSync:N2}=require("node:fs");function w2(){let t=__dirname,r,n=0;for(;!O2(r=b2(t,"package.json"));)if(t===(t=cD(t))||n++>10)throw new Error("Could not find package root");return r}a(w2,"findPackageJson");var lD=w2(),I2=JSON.parse(N2(lD,"utf8")),C2=cD(lD);uD.exports={packageJson:I2,PACKAGE_ROOT:C2}});var sm=I((Fye,dD)=>{if(__filename.endsWith("dev.js")){let e=require("fast-glob"),{tmpdir:t}=require("node:os"),{relative:r,join:n}=require("node:path"),{existsSync:s,statSync:i,readFileSync:o,writeFileSync:c}=require("node:fs"),{isMainThread:l}=require("node:worker_threads"),{spawnSync:u,spawn:f}=require("node:child_process");process.setSourceMapsEnabled(!0);let{PACKAGE_ROOT:d}=st(),p=["bin","components","dataLayer","resources","server","sqlTranslator","upgrade","utility","validation"],_="ts-build";if(l){let g=!1,R=!1;if((R=s(n(d,_)))?g=e.sync(p.map(E=>`${E}/**/*.ts`),{cwd:d}).some(E=>{let A=0,N=0;try{A=i(n(d,E)).mtimeMs-5e3,N=i(n(d,_,E.replace(/.ts$/,".js"))).mtimeMs}catch{}return A>N}):g=!0,g){console.log("Compiling TypeScript...");let E=u("npx",["tsc"],{cwd:d});if(E.stdout?.length&&console.log(E.stdout.toString()),E.stderr?.length&&console.log(E.stderr.toString()),R){let A=n(t(),"harperdb-tsc.pid"),N=!1;if(s(A))try{process.kill(+o(A,"utf8"),0),N=!0}catch{}if(!N){console.log("Starting background TypeScript compilation...");let v=f("npx",["tsc","--watch"],{detached:!0,cwd:d,stdio:"ignore"});c(A,v.pid.toString()),v.unref()}}}}let h=dD.constructor,S=h._findPath;h._findPath=function(g,R,E){if(g.startsWith(".")&&!E&&R.length===1&&R[0].startsWith(d)&&!R[0].includes("node_modules")){let A=r(d,R[0]),N;A.startsWith(_)?N=n(d,r(_,A)):N=n(d,_,A);let v=n(N,g),F=v+".js";if(s(F))return F;if(v.includes(".")&&s(v))return v}return S(g,R,E)}}});var G={};Ue(G,{AUTH_AUDIT_STATUS:()=>Ws,AUTH_AUDIT_TYPES:()=>ua,BOOT_PROPS_FILE_NAME:()=>eQ,BOOT_PROP_PARAMS:()=>pD,CLUSTERING_FLAG:()=>NQ,CLUSTERING_PROCESSES:()=>k2,CLUSTER_MESSAGE_TYPE_ENUM:()=>QA,CLUSTER_OPERATIONS:()=>mQ,CONFIG_PARAMS:()=>x,CONFIG_PARAM_MAP:()=>hD,DATABASES_DIR_NAME:()=>wc,DATABASES_PARAM_CONFIG:()=>TQ,DEFAULT_DATABASE_NAME:()=>G2,ESCAPED_FORWARD_SLASH_REGEX:()=>Q2,FORWARD_SLASH_REGEX:()=>j2,FUNC_VAL:()=>LQ,GEO_CONVERSION_ENUM:()=>gQ,HDB_COMPONENT_CONFIG_FILE:()=>L2,HDB_CONFIG_FILE:()=>P2,HDB_DEFAULT_CONFIG_FILE:()=>D2,HDB_FILE_PERMISSIONS:()=>rQ,HDB_HOME_DIR_NAME:()=>Z2,HDB_PID_FILE:()=>F2,HDB_PROCESS_SERVICES:()=>H2,HDB_PROC_NAME:()=>M2,HDB_RESTART_SCRIPT:()=>v2,HDB_ROOT_DIR_NAME:()=>YA,HDB_SETTINGS_NAMES:()=>JA,HDB_SUPPORT_ADDRESS:()=>_D,INFO_TABLE_HASH_ATTRIBUTE:()=>cQ,INSERT_MAX_CHARACTER_SIZE:()=>oQ,INSTALL_PROMPTS:()=>iQ,ITC_EVENT_TYPES:()=>ZA,JOB_STATUS_ENUM:()=>fQ,JOB_TYPE_ENUM:()=>AQ,JWT_ENUM:()=>Nf,LAUNCH_SERVICE_SCRIPTS:()=>V2,LEGACY_CONFIG_PARAMS:()=>SQ,LEGACY_DATABASES_DIR_NAME:()=>am,LICENSE_FILE_NAME:()=>dQ,LICENSE_KEY_DIR_NAME:()=>jA,LICENSE_VALUES:()=>RQ,LOG_LEVELS:()=>$2,LOG_NAMES:()=>q2,MEM_SETTING_KEY:()=>X2,METADATA_PROPERTY:()=>OQ,NODE_ERROR_CODES:()=>bQ,OPERATIONS_ENUM:()=>Kt,PERMS_CRUD_ENUM:()=>PQ,PERMS_UPDATE_RELEASE_TIMESTAMP:()=>CQ,PRE_4_0_0_VERSION:()=>MQ,PROCESS_DESCRIPTORS:()=>B2,PROCESS_NAME_ENV_PROP:()=>sQ,RAM_ALLOCATION_ENUM:()=>yQ,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:()=>lm,REG_KEY_FILE_NAME:()=>uQ,RESTART_TIMEOUT_MS:()=>tQ,ROLE_TYPES_ENUM:()=>K2,S3_BUCKET_AUTH_KEYS:()=>pQ,SEARCH_NOT_FOUND_MESSAGE:()=>W2,SEARCH_WILDCARDS:()=>DQ,SERVICE_ACTIONS_ENUM:()=>EQ,SUPPORT_HELP_MSG:()=>Y2,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:()=>lQ,SYSTEM_SCHEMA_NAME:()=>Of,SYSTEM_TABLE_NAMES:()=>_u,THREAD_TYPES:()=>eR,TIME_STAMP_NAMES:()=>IQ,TIME_STAMP_NAMES_ENUM:()=>wQ,TRANSACTIONS_DIR_NAME:()=>nQ,UNICODE_FORWARD_SLASH:()=>J2,UNICODE_PERIOD:()=>z2,UPGRADE_JSON_FIELD_NAMES_ENUM:()=>aQ,VALID_S3_FILE_TYPES:()=>_Q,VALID_SQL_OPS_ENUM:()=>hQ,VALUE_SEARCH_COMPARATORS:()=>cm,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:()=>XA});var im,om,P2,D2,YA,L2,M2,v2,fD,KA,WA,zA,U2,x2,B2,H2,k2,F2,G2,q2,$2,V2,K2,_D,Y2,W2,z2,j2,J2,Q2,X2,Of,Z2,jA,eQ,tQ,rQ,wc,am,nQ,sQ,pD,iQ,oQ,aQ,_u,cQ,lQ,uQ,dQ,fQ,Kt,_Q,pQ,hQ,mQ,EQ,gQ,JA,SQ,x,hD,TQ,AQ,QA,RQ,yQ,bQ,OQ,NQ,mD,ED,wQ,IQ,CQ,cm,XA,PQ,DQ,LQ,lm,Nf,ZA,eR,MQ,Ws,ua,H=be(()=>{im=require("node:path"),om=M(st()),P2="harperdb-config.yaml",D2="defaultConfig.yaml",YA="hdb",L2="config.yaml",M2="harperdb.js",v2="restartHdb.js",fD="HarperDB",KA="Custom Functions",WA="Clustering Hub",zA="Clustering Leaf",U2="Clustering Ingest Service",x2="Clustering Reply Service",B2={HDB:fD,CLUSTERING_HUB:WA,CLUSTERING_LEAF:zA,CLUSTERING_INGEST_SERVICE:U2,CLUSTERING_REPLY_SERVICE:x2,CUSTOM_FUNCTIONS:KA,RESTART_HDB:"Restart HDB",INSTALL:"Install",RUN:"Run",STOP:"Stop",UPGRADE:"Upgrade",REGISTER:"Register",JOB:"Job",CLUSTERING_UPGRADE_4_0_0:"Upgrade-4-0-0"},H2={harperdb:fD,"clustering hub":WA,"clustering leaf":zA,"custom functions":KA,custom_functions:KA,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers",http:"http"},k2={CLUSTERING_HUB_PROC_DESCRIPTOR:WA,CLUSTERING_LEAF_PROC_DESCRIPTOR:zA},F2="hdb.pid",G2="data",q2={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},$2={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},V2={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:(0,im.join)(om.PACKAGE_ROOT,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:(0,im.join)(om.PACKAGE_ROOT,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:(0,im.join)(om.PACKAGE_ROOT,"launchServiceScripts/launchUpdateNodes4-0-0.js")},K2={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},_D="support@harperdb.io",Y2=`For support, please submit a request at https://harperdbhelp.zendesk.com/hc/en-us/requests/new or contact ${_D}`,W2="None of the specified records were found.",z2="U+002E",j2=/\//g,J2="U+002F",Q2=/U\+002F/g,X2="--max-old-space-size=",Of="system",Z2=".harperdb",jA="keys",eQ="hdb_boot_properties.file",tQ=6e4,rQ=448,wc="database",am="schema",nQ="transactions",sQ="PROCESS_NAME",pD={SETTINGS_PATH_KEY:"settings_path"},iQ={TC_AGREEMENT:"TC_AGREEMENT",CLUSTERING_USER:"CLUSTERING_USER",CLUSTERING_PASSWORD:"CLUSTERING_PASSWORD",HDB_ADMIN_USERNAME:"HDB_ADMIN_USERNAME",HDB_ADMIN_PASSWORD:"HDB_ADMIN_PASSWORD",OPERATIONSAPI_ROOT:"OPERATIONSAPI_ROOT",ROOTPATH:"ROOTPATH",CLUSTERING_NODENAME:"CLUSTERING_NODENAME",CLUSTERING_ENABLED:"CLUSTERING_ENABLED",HDB_CONFIG:"HDB_CONFIG",DEFAULTS_MODE:"DEFAULTS_MODE",REPLICATION_HOSTNAME:"REPLICATION_HOSTNAME",CLUSTERING_PORT:"CLUSTERING_PORT",HDB_ROOT:"HDB_ROOT",SERVER_PORT:"SERVER_PORT",NODE_NAME:"NODE_NAME",CLUSTERING:"CLUSTERING"},oQ=250,aQ={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},_u={JOB_TABLE_NAME:"hdb_job",NODE_TABLE_NAME:"hdb_nodes",ATTRIBUTE_TABLE_NAME:"hdb_attribute",LICENSE_TABLE_NAME:"hdb_license",ROLE_TABLE_NAME:"hdb_role",SCHEMA_TABLE_NAME:"hdb_schema",TABLE_TABLE_NAME:"hdb_table",USER_TABLE_NAME:"hdb_user",INFO_TABLE_NAME:"hdb_info"},cQ="info_id",lQ={ATTR_ATTRIBUTE_KEY:"attribute",ATTR_CREATEDDATE_KEY:"createddate",ATTR_HASH_ATTRIBUTE_KEY:"hash_attribute",ATTR_ID_KEY:"id",ATTR_NAME_KEY:"name",ATTR_PASSWORD_KEY:"password",ATTR_RESIDENCE_KEY:"residence",ATTR_ROLE_KEY:"role",ATTR_SCHEMA_KEY:"schema",ATTR_SCHEMA_TABLE_KEY:"schema_table",ATTR_TABLE_KEY:"table",ATTR_USERNAME_KEY:"username"},uQ="060493.ks",dQ=".license",fQ={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},Kt={INSERT:"insert",UPDATE:"update",UPSERT:"upsert",SEARCH_BY_CONDITIONS:"search_by_conditions",SEARCH_BY_HASH:"search_by_hash",SEARCH_BY_ID:"search_by_id",SEARCH_BY_VALUE:"search_by_value",SEARCH:"search",SQL:"sql",CSV_DATA_LOAD:"csv_data_load",CSV_FILE_LOAD:"csv_file_load",CSV_URL_LOAD:"csv_url_load",CREATE_SCHEMA:"create_schema",CREATE_DATABASE:"create_database",CREATE_TABLE:"create_table",CREATE_ATTRIBUTE:"create_attribute",DROP_SCHEMA:"drop_schema",DROP_DATABASE:"drop_database",DROP_TABLE:"drop_table",DESCRIBE_SCHEMA:"describe_schema",DESCRIBE_DATABASE:"describe_database",DESCRIBE_TABLE:"describe_table",DESCRIBE_ALL:"describe_all",DELETE:"delete",ADD_USER:"add_user",ALTER_USER:"alter_user",DROP_USER:"drop_user",LIST_USERS:"list_users",LIST_ROLES:"list_roles",ADD_ROLE:"add_role",ALTER_ROLE:"alter_role",DROP_ROLE:"drop_role",USER_INFO:"user_info",READ_LOG:"read_log",ADD_NODE:"add_node",UPDATE_NODE:"update_node",SET_NODE_REPLICATION:"set_node_replication",EXPORT_TO_S3:"export_to_s3",IMPORT_FROM_S3:"import_from_s3",DELETE_FILES_BEFORE:"delete_files_before",DELETE_RECORDS_BEFORE:"delete_records_before",EXPORT_LOCAL:"export_local",SEARCH_JOBS_BY_START_DATE:"search_jobs_by_start_date",GET_JOB:"get_job",DELETE_JOB:"delete_job",UPDATE_JOB:"update_job",GET_FINGERPRINT:"get_fingerprint",SET_LICENSE:"set_license",GET_REGISTRATION_INFO:"registration_info",CONFIGURE_CLUSTER:"configure_cluster",SET_CONFIGURATION:"set_configuration",CLUSTER_STATUS:"cluster_status",CLUSTER_NETWORK:"cluster_network",DROP_ATTRIBUTE:"drop_attribute",REMOVE_NODE:"remove_node",RESTART:"restart",RESTART_SERVICE:"restart_service",CATCHUP:"catchup",SYSTEM_INFORMATION:"system_information",DELETE_AUDIT_LOGS_BEFORE:"delete_audit_logs_before",READ_AUDIT_LOG:"read_audit_log",CREATE_AUTHENTICATION_TOKENS:"create_authentication_tokens",LOGIN:"login",LOGOUT:"logout",REFRESH_OPERATION_TOKEN:"refresh_operation_token",GET_CONFIGURATION:"get_configuration",CUSTOM_FUNCTIONS_STATUS:"custom_functions_status",GET_CUSTOM_FUNCTIONS:"get_custom_functions",GET_CUSTOM_FUNCTION:"get_custom_function",SET_CUSTOM_FUNCTION:"set_custom_function",GET_COMPONENTS:"get_components",GET_COMPONENT_FILE:"get_component_file",SET_COMPONENT_FILE:"set_component_file",DROP_COMPONENT:"drop_component",DROP_CUSTOM_FUNCTION:"drop_custom_function",ADD_CUSTOM_FUNCTION_PROJECT:"add_custom_function_project",ADD_COMPONENT:"add_component",DROP_CUSTOM_FUNCTION_PROJECT:"drop_custom_function_project",PACKAGE_CUSTOM_FUNCTION_PROJECT:"package_custom_function_project",DEPLOY_CUSTOM_FUNCTION_PROJECT:"deploy_custom_function_project",PACKAGE_COMPONENT:"package_component",DEPLOY_COMPONENT:"deploy_component",CLUSTER_SET_ROUTES:"cluster_set_routes",CLUSTER_DELETE_ROUTES:"cluster_delete_routes",CLUSTER_GET_ROUTES:"cluster_get_routes",READ_TRANSACTION_LOG:"read_transaction_log",DELETE_TRANSACTION_LOGS_BEFORE:"delete_transaction_logs_before",INSTALL_NODE_MODULES:"install_node_modules",AUDIT_NODE_MODULES:"audit_node_modules",PURGE_STREAM:"purge_stream",GET_BACKUP:"get_backup",SIGN_CERTIFICATE:"sign_certificate",CREATE_CSR:"create_csr",LIST_CERTIFICATES:"list_certificates",ADD_CERTIFICATES:"add_certificate",REMOVE_CERTIFICATE:"remove_certificate",ADD_NODE_BACK:"add_node_back",REMOVE_NODE_BACK:"remove_node_back",ADD_SSH_KEY:"add_ssh_key",UPDATE_SSH_KEY:"update_ssh_key",DELETE_SSH_KEY:"delete_ssh_key",LIST_SSH_KEYS:"list_ssh_keys",SET_SSH_KNOWN_HOSTS:"set_ssh_known_hosts",GET_SSH_KNOWN_HOSTS:"get_ssh_known_hosts",GET_KEY:"get_key"},_Q={CSV:".csv",JSON:".json"},pQ={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},hQ={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},mQ={[Kt.INSERT]:Kt.INSERT,[Kt.UPDATE]:Kt.UPDATE,[Kt.UPSERT]:Kt.UPSERT,[Kt.DELETE]:Kt.DELETE},EQ={DEV:"dev",RUN:"run",START:"start",INSTALL:"install",REGISTER:"register",STOP:"stop",RESTART:"restart",VERSION:"version",UPGRADE:"upgrade",HELP:"help",STATUS:"status",OPERATION:"operation",RENEWCERTS:"renew-certs",COPYDB:"copy-db"},gQ={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},JA={HDB_ROOT_KEY:"HDB_ROOT",SERVER_PORT_KEY:"SERVER_PORT",CERT_KEY:"CERTIFICATE",PRIVATE_KEY_KEY:"PRIVATE_KEY",HTTP_SECURE_ENABLED_KEY:"HTTPS_ON",CORS_ENABLED_KEY:"CORS_ON",CORS_WHITELIST_KEY:"CORS_WHITELIST",LOG_LEVEL_KEY:"LOG_LEVEL",LOGGER_KEY:"LOGGER",LOG_PATH_KEY:"LOG_PATH",LOG_ROTATE:"LOG_ROTATE",LOG_ROTATE_MAX_SIZE:"LOG_ROTATE_MAX_SIZE",LOG_ROTATE_RETAIN:"LOG_ROTATE_RETAIN",LOG_ROTATE_COMPRESS:"LOG_ROTATE_COMPRESS",LOG_ROTATE_DATE_FORMAT:"LOG_ROTATE_DATE_FORMAT",LOG_ROTATE_ROTATE_MODULE:"LOG_ROTATE_ROTATE_MODULE",LOG_ROTATE_WORKER_INTERVAL:"LOG_ROTATE_WORKER_INTERVAL",LOG_ROTATE_ROTATE_INTERVAL:"LOG_ROTATE_ROTATE_INTERVAL",LOG_ROTATE_TIMEZONE:"LOG_ROTATE_TIMEZONE",LOG_DAILY_ROTATE_KEY:"LOG_DAILY_ROTATE",LOG_MAX_DAILY_FILES_KEY:"LOG_MAX_DAILY_FILES",PROPS_ENV_KEY:"NODE_ENV",SETTINGS_PATH_KEY:"settings_path",CLUSTERING_PORT_KEY:"CLUSTERING_PORT",CLUSTERING_NODE_NAME_KEY:"NODE_NAME",CLUSTERING_ENABLED_KEY:"CLUSTERING",ALLOW_SELF_SIGNED_SSL_CERTS:"ALLOW_SELF_SIGNED_SSL_CERTS",MAX_HDB_PROCESSES:"MAX_HDB_PROCESSES",INSTALL_USER:"install_user",CLUSTERING_USER_KEY:"CLUSTERING_USER",MAX_CLUSTERING_PROCESSES:"MAX_CLUSTERING_PROCESSES",SERVER_TIMEOUT_KEY:"SERVER_TIMEOUT_MS",SERVER_KEEP_ALIVE_TIMEOUT_KEY:"SERVER_KEEP_ALIVE_TIMEOUT",SERVER_HEADERS_TIMEOUT_KEY:"SERVER_HEADERS_TIMEOUT",DISABLE_TRANSACTION_LOG_KEY:"DISABLE_TRANSACTION_LOG",OPERATION_TOKEN_TIMEOUT_KEY:"OPERATION_TOKEN_TIMEOUT",REFRESH_TOKEN_TIMEOUT_KEY:"REFRESH_TOKEN_TIMEOUT",CUSTOM_FUNCTIONS_ENABLED_KEY:"CUSTOM_FUNCTIONS",CUSTOM_FUNCTIONS_PORT_KEY:"CUSTOM_FUNCTIONS_PORT",CUSTOM_FUNCTIONS_DIRECTORY_KEY:"CUSTOM_FUNCTIONS_DIRECTORY",MAX_CUSTOM_FUNCTION_PROCESSES:"MAX_CUSTOM_FUNCTION_PROCESSES",LOG_TO_FILE:"LOG_TO_FILE",LOG_TO_STDSTREAMS:"LOG_TO_STDSTREAMS",RUN_IN_FOREGROUND:"RUN_IN_FOREGROUND",LOCAL_STUDIO_ON:"LOCAL_STUDIO_ON",STORAGE_WRITE_ASYNC:"STORAGE_WRITE_ASYNC"},SQ={CUSTOMFUNCTIONS_ENABLED:"customFunctions_enabled",CUSTOMFUNCTIONS_NETWORK_PORT:"customFunctions_network_port",CUSTOMFUNCTIONS_TLS_CERTIFICATE:"customFunctions_tls_certificate",CUSTOMFUNCTIONS_NETWORK_CORS:"customFunctions_network_cors",CUSTOMFUNCTIONS_NETWORK_CORSACCESSLIST:"customFunctions_network_corsAccessList",CUSTOMFUNCTIONS_NETWORK_HEADERSTIMEOUT:"customFunctions_network_headersTimeout",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",CUSTOMFUNCTIONS_NETWORK_KEEPALIVETIMEOUT:"customFunctions_network_keepAliveTimeout",CUSTOMFUNCTIONS_TLS_PRIVATEKEY:"customFunctions_tls_privateKey",CUSTOMFUNCTIONS_TLS_CERT_AUTH:"customFunctions_tls_certificateAuthority",CUSTOMFUNCTIONS_NETWORK_TIMEOUT:"customFunctions_network_timeout",CUSTOMFUNCTIONS_NODEENV:"customFunctions_nodeEnv",CUSTOMFUNCTIONS_ROOT:"customFunctions_root"},x={ANALYTICS_AGGREGATEPERIOD:"analytics_aggregatePeriod",AUTHENTICATION_AUTHORIZELOCAL:"authentication_authorizeLocal",AUTHENTICATION_CACHETTL:"authentication_cacheTTL",AUTHENTICATION_ENABLESESSIONS:"authentication_enableSessions",AUTHENTICATION_OPERATIONTOKENTIMEOUT:"authentication_operationTokenTimeout",AUTHENTICATION_REFRESHTOKENTIMEOUT:"authentication_refreshTokenTimeout",AUTHENTICATION_HASHFUNCTION:"authentication_hashFunction",CLUSTERING_USER:"clustering_user",CLUSTERING_ENABLED:"clustering_enabled",CLUSTERING_HUBSERVER_CLUSTER_NAME:"clustering_hubServer_cluster_name",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT:"clustering_hubServer_cluster_network_port",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES:"clustering_hubServer_cluster_network_routes",CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT:"clustering_hubServer_leafNodes_network_port",CLUSTERING_HUBSERVER_NETWORK_PORT:"clustering_hubServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_PORT:"clustering_leafServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_ROUTES:"clustering_leafServer_network_routes",CLUSTERING_LEAFSERVER_STREAMS_MAXAGE:"clustering_leafServer_streams_maxAge",CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES:"clustering_leafServer_streams_maxBytes",CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS:"clustering_leafServer_streams_maxMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS:"clustering_leafServer_streams_maxConsumeMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS:"clustering_leafServer_streams_maxIngestThreads",CLUSTERING_LEAFSERVER_STREAMS_PATH:"clustering_leafServer_streams_path",CLUSTERING_NODENAME:"clustering_nodeName",CLUSTERING_TLS_CERTIFICATE:"clustering_tls_certificate",CLUSTERING_TLS_PRIVATEKEY:"clustering_tls_privateKey",CLUSTERING_TLS_CERT_AUTH:"clustering_tls_certificateAuthority",CLUSTERING_TLS_INSECURE:"clustering_tls_insecure",CLUSTERING_TLS_VERIFY:"clustering_tls_verify",CLUSTERING_LOGLEVEL:"clustering_logLevel",CLUSTERING_REPUBLISHMESSAGES:"clustering_republishMessages",CLUSTERING_DATABASELEVEL:"clustering_databaseLevel",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",THREADS:"threads",THREADS_COUNT:"threads_count",THREADS_DEBUG:"threads_debug",THREADS_DEBUG_STARTINGPORT:"threads_debug_startingPort",THREADS_DEBUG_PORT:"threads_debug_port",THREADS_DEBUG_HOST:"threads_debug_host",THREADS_DEBUG_WAITFORDEBUGGER:"threads_debug_waitForDebugger",THREADS_MAXHEAPMEMORY:"threads_maxHeapMemory",HTTP_SESSIONAFFINITY:"http_sessionAffinity",HTTP_COMPRESSIONTHRESHOLD:"http_compressionThreshold",HTTP_CORS:"http_cors",HTTP_CORSACCESSLIST:"http_corsAccessList",HTTP_CORSACCESSCONTROLALLOWHEADERS:"http_corsAccessControlAllowHeaders",HTTP_HEADERSTIMEOUT:"http_headersTimeout",HTTP_KEEPALIVETIMEOUT:"http_keepAliveTimeout",HTTP_MAXPARAMLENGTH:"http_maxParamLength",HTTP_TIMEOUT:"http_timeout",HTTP_PORT:"http_port",HTTP_SECUREPORT:"http_securePort",HTTP_MTLS:"http_mtls",HTTP_MTLS_REQUIRED:"http_mtls_required",HTTP_MTLS_USER:"http_mtls_user",HTTP_MAXHEADERSIZE:"http_maxHeaderSize",HTTP_THREADRANGE:"http_threadRange",HTTP_HTTP2:"http_http2",LOCALSTUDIO_ENABLED:"localStudio_enabled",LOGGING_CONSOLE:"logging_console",LOGGING_FILE:"logging_file",LOGGING_LEVEL:"logging_level",LOGGING_ROOT:"logging_root",LOGGING_ROTATION_ENABLED:"logging_rotation_enabled",LOGGING_ROTATION_COMPRESS:"logging_rotation_compress",LOGGING_ROTATION_INTERVAL:"logging_rotation_interval",LOGGING_ROTATION_MAXSIZE:"logging_rotation_maxSize",LOGGING_ROTATION_PATH:"logging_rotation_path",LOGGING_ROTATION_RETENTION:"logging_rotation_retention",LOGGING_STDSTREAMS:"logging_stdStreams",LOGGING_AUDITLOG:"logging_auditLog",LOGGING_AUDITRETENTION:"logging_auditRetention",LOGGING_AUDITAUTHEVENTS_LOGFAILED:"logging_auditAuthEvents_logFailed",LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL:"logging_auditAuthEvents_logSuccessful",OPERATIONSAPI_NETWORK_CORS:"operationsApi_network_cors",OPERATIONSAPI_NETWORK_CORSACCESSLIST:"operationsApi_network_corsAccessList",OPERATIONSAPI_NETWORK_HEADERSTIMEOUT:"operationsApi_network_headersTimeout",OPERATIONSAPI_NETWORK_HTTPS:"operationsApi_network_https",OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT:"operationsApi_network_keepAliveTimeout",OPERATIONSAPI_NETWORK_PORT:"operationsApi_network_port",OPERATIONSAPI_NETWORK_DOMAINSOCKET:"operationsApi_network_domainSocket",OPERATIONSAPI_NETWORK_SECUREPORT:"operationsApi_network_securePort",OPERATIONSAPI_NETWORK_HTTP2:"operationsApi_network_http2",OPERATIONSAPI_TLS:"operationsApi_tls",OPERATIONSAPI_TLS_CERTIFICATE:"operationsApi_tls_certificate",OPERATIONSAPI_TLS_PRIVATEKEY:"operationsApi_tls_privateKey",OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY:"operationsApi_tls_certificateAuthority",OPERATIONSAPI_NETWORK_TIMEOUT:"operationsApi_network_timeout",OPERATIONSAPI_SYSINFO_NETWORK:"operationsApi_sysInfo_network",OPERATIONSAPI_SYSINFO_DISK:"operationsApi_sysInfo_disk",REPLICATION:"replication",REPLICATION_HOSTNAME:"replication_hostname",REPLICATION_URL:"replication_url",REPLICATION_PORT:"replication_port",REPLICATION_SECUREPORT:"replication_securePort",REPLICATION_ROUTES:"replication_routes",REPLICATION_DATABASES:"replication_databases",REPLICATION_ENABLEROOTCAS:"replication_enableRootCAs",REPLICATION_SHARD:"replication_shard",REPLICATION_COPYTABLESTOCATCHUP:"replication_copyTablesToCatchUp",ROOTPATH:"rootPath",SERIALIZATION_BIGINT:"serialization_bigInt",STORAGE_WRITEASYNC:"storage_writeAsync",STORAGE_OVERLAPPINGSYNC:"storage_overlappingSync",STORAGE_CACHING:"storage_caching",STORAGE_COMPRESSION:"storage_compression",STORAGE_NOREADAHEAD:"storage_noReadAhead",STORAGE_PREFETCHWRITES:"storage_prefetchWrites",STORAGE_ENCRYPTION:"storage_encryption",STORAGE_MAXTRANSACTIONQUEUETIME:"storage_maxTransactionQueueTime",STORAGE_PATH:"storage_path",STORAGE_BLOBPATHS:"storage_blobPaths",STORAGE_AUDIT_PATH:"storage_audit_path",STORAGE_MAXFREESPACETOLOAD:"storage_maxFreeSpaceToLoad",STORAGE_MAXFREESPACETORETAIN:"storage_maxFreeSpaceToRetain",STORAGE_PAGESIZE:"storage_pageSize",STORAGE_COMPRESSION_DICTIONARY:"storage_compression_dictionary",STORAGE_COMPRESSION_THRESHOLD:"storage_compression_threshold",STORAGE_COMPACTONSTART:"storage_compactOnStart",STORAGE_COMPACTONSTARTKEEPBACKUP:"storage_compactOnStartKeepBackup",STORAGE_RECLAMATION_THRESHOLD:"storage_reclamation_threshold",STORAGE_RECLAMATION_INTERVAL:"storage_reclamation_interval",STORAGE_RECLAMATION_EVICTIONFACTOR:"storage_reclamation_evictionFactor",DATABASES:"databases",IGNORE_SCRIPTS:"ignoreScripts",MQTT_NETWORK_PORT:"mqtt_network_port",MQTT_WEBSOCKET:"mqtt_webSocket",MQTT_NETWORK_SECUREPORT:"mqtt_network_securePort",MQTT_NETWORK_MTLS:"mqtt_network_mtls",MQTT_NETWORK_MTLS_REQUIRED:"mqtt_network_mtls_required",MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY:"mqtt_network_mtls_certificateAuthority",MQTT_NETWORK_MTLS_USER:"mqtt_network_mtls_user",MQTT_REQUIREAUTHENTICATION:"mqtt_requireAuthentication",COMPONENTSROOT:"componentsRoot",TLS_CERTIFICATE:"tls_certificate",TLS_PRIVATEKEY:"tls_privateKey",TLS_CERTIFICATEAUTHORITY:"tls_certificateAuthority",TLS_CIPHERS:"tls_ciphers",TLS:"tls",CLONED:"cloned"},hD={settings_path:pD.SETTINGS_PATH_KEY,hdb_root_key:x.ROOTPATH,hdb_root:x.ROOTPATH,rootpath:x.ROOTPATH,server_port_key:x.OPERATIONSAPI_NETWORK_PORT,server_port:x.OPERATIONSAPI_NETWORK_PORT,cert_key:x.TLS_CERTIFICATE,certificate:x.TLS_CERTIFICATE,private_key_key:x.TLS_PRIVATEKEY,private_key:x.TLS_PRIVATEKEY,http_secure_enabled_key:x.OPERATIONSAPI_NETWORK_HTTPS,https_on:x.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:x.OPERATIONSAPI_NETWORK_CORS,cors_on:x.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:x.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:x.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:x.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:x.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:x.LOGGING_LEVEL,log_level:x.LOGGING_LEVEL,log_path_key:x.LOGGING_ROOT,log_path:x.LOGGING_ROOT,clustering_node_name_key:x.CLUSTERING_NODENAME,node_name:x.CLUSTERING_NODENAME,clustering_enabled_key:x.CLUSTERING_ENABLED,clustering:x.CLUSTERING_ENABLED,max_http_threads:x.THREADS_COUNT,max_hdb_processes:x.THREADS_COUNT,server_timeout_key:x.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:x.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:x.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:x.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:x.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:x.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:x.LOGGING_AUDITLOG,disable_transaction_log:x.LOGGING_AUDITLOG,operation_token_timeout_key:x.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:x.AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:x.AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:x.AUTHENTICATION_REFRESHTOKENTIMEOUT,custom_functions_port_key:x.HTTP_PORT,custom_functions_port:x.HTTP_PORT,custom_functions_directory_key:x.COMPONENTSROOT,custom_functions_directory:x.COMPONENTSROOT,max_custom_function_processes:x.THREADS_COUNT,logging_console:x.LOGGING_CONSOLE,log_to_file:x.LOGGING_FILE,log_to_stdstreams:x.LOGGING_STDSTREAMS,local_studio_on:x.LOCALSTUDIO_ENABLED,clustering_port:x.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:x.CLUSTERING_USER,customfunctions_network_port:x.HTTP_PORT,customfunctions_tls_certificate:x.TLS_CERTIFICATE,customfunctions_network_cors:x.HTTP_CORS,customfunctions_network_corsaccesslist:x.HTTP_CORSACCESSLIST,customfunctions_network_headerstimeout:x.HTTP_HEADERSTIMEOUT,customfunctions_network_https:x.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:x.HTTP_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:x.TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:x.TLS_CERTIFICATEAUTHORITY,customfunctions_network_timeout:x.HTTP_TIMEOUT,customfunctions_tls:x.TLS,http_threads:x.THREADS_COUNT,threads:x.THREADS_COUNT,threads_count:x.THREADS_COUNT,customfunctions_processes:x.THREADS_COUNT,customfunctions_root:x.COMPONENTSROOT,operationsapi_root:x.ROOTPATH};for(let e in x){let t=x[e];hD[t.toLowerCase()]=t}TQ={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},AQ={csv_file_load:"csv_file_load",csv_data_load:Kt.CSV_DATA_LOAD,csv_url_load:Kt.CSV_URL_LOAD,delete_files_before:"delete_files_before",delete_records_before:"delete_records_before",delete_audit_logs_before:"delete_audit_logs_before",delete_transaction_logs_before:"delete_transaction_logs_before",empty_trash:"empty_trash",export_local:"export_local",export_to_s3:"export_to_s3",import_from_s3:"import_from_s3",restart_service:"restart_service"},QA={CLUSTERING_PAYLOAD:"clustering_payload",DELEGATE_THREAD_RESPONSE:"delegate_thread_response",CLUSTERING:"clustering",SCHEMA:"schema",CLUSTER_STATUS:"cluster_status",JOB:"job",CHILD_STARTED:"child_started",CHILD_STOPPED:"child_stopped",USER:"user",RESTART:"restart"},RQ={VERSION_DEFAULT:"2.2.0"},yQ={DEVELOPMENT:8192,DEFAULT:512},bQ={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},OQ=Symbol("metadata"),NQ="__clustering__",mD="__createdtime__",ED="__updatedtime__",wQ={CREATED_TIME:mD,UPDATED_TIME:ED},IQ=[mD,ED],CQ=15984864e5,cm={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},XA={"<":"LESS","<=":"LESS_OR_EQ",">":"GREATER",">=":"GREATER_OR_EQ","...":"BETWEEN"},PQ={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},DQ=["*","%"],LQ="func_val",lm={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},Nf={JWT_PRIVATE_KEY_NAME:".jwtPrivate.key",JWT_PUBLIC_KEY_NAME:".jwtPublic.key",JWT_PASSPHRASE_NAME:".jwtPass"},ZA={SHUTDOWN:"shutdown",CHILD_STARTED:"child_started",CHILD_STOPPED:"child_stopped",SCHEMA:"schema",USER:"user",CLUSTER_STATUS_RESPONSE:"cluster_status_response",CLUSTER_STATUS_REQUEST:"cluster_status_request",METRICS:"metrics",GET_METRICS:"get_metrics",RESTART:"restart",START_JOB:"start_job",NATS_CONSUMER_UPDATE:"nats_consumer_update"},eR={HTTP:"http"},MQ="3.x.x",Ws={SUCCESS:"success",FAILURE:"failure"},ua={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"}});var da=I((Gye,TD)=>{"use strict";var gD=require("minimist");TD.exports=vQ;function vQ(e=[],t=!1){if(!Array.isArray(e))return{};let r,n;t?(r=SD(process.env),n=SD(gD(process.argv))):(r=process.env,n=gD(process.argv));let s={};for(let i=0,o=e.length;i<o;i++){let c=e[i];n[c]!==void 0?s[c]=n[c].toString().trim():r[c]!==void 0&&(s[c]=r[c].toString().trim())}return s}a(vQ,"assignCMDENVVariables");function SD(e){let t,r=Object.keys(e),n=r.length,s={};for(;n--;)t=r[n],s[t.toLowerCase()]=e[t];return s}a(SD,"objKeysToLowerCase")});var Ai=I(zs=>{"use strict";global.Resource=zs.Resource=void 0;global.tables=zs.tables={};global.databases=zs.databases={};global.getUser=zs.getUser=void 0;global.authenticateUser=zs.authenticateUser=void 0;global.server=zs.server={};global.contentTypes=zs.contentTypes=null;global.threads=zs.threads=[];global.logger={};zs._assignPackageExport=(e,t)=>{global[e]=zs[e]=t}});var W=I((UD,xD)=>{"use strict";var so=require("fs-extra"),{workerData:UQ,threadId:xQ,isMainThread:BQ}=require("worker_threads"),yi=require("path"),bD=require("yaml"),OD=require("properties-reader"),Yt=(H(),P(G)),AD=da(),HQ=require("os"),{PACKAGE_ROOT:sR}=st(),{_assignPackageExport:kQ}=Ai(),RD=process.stdout.nativeWrite||(process.stdout.nativeWrite=process.stdout.write),Er={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},ND={STDOUT:"stdOut",STDERR:"stdErr"},FQ=yi.join(sR,"logs"),GQ=yi.join(sR,"config/yaml/",Yt.HDB_DEFAULT_CONFIG_FILE),qQ=1e4,tR,Ri,Es,Pr,um,wf,dm,fa,If;If===void 0&&wD();Object.assign(UD,{notify:LD,fatal:MD,error:fm,warn:vD,info:CD,debug:DD,trace:PD,setLogLevel:JQ,log_level:Pr,loggerWithTag:KQ,suppressLogging:YQ,initLogSettings:wD,logCustomLevel:zQ,closeLogFile:iR,logsAtLevel:$Q,getLogFilePath:a(()=>dm,"getLogFilePath"),OUTPUTS:ND,AuthAuditLog:ZQ});kQ("logger",xD.exports);var rR;function $Q(e){return Er[Pr]<=Er[e]}a($Q,"logsAtLevel");function wD(e=!1){try{if(If===void 0||e){iR();let t=jQ(),r=AD(["ROOTPATH"]);try{If=OD(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!so.pathExistsSync(yi.join(r.ROOTPATH,Yt.HDB_CONFIG_FILE)))throw n}if({level:Pr,config_log_path:wf,to_file:Ri,to_stream:Es}=QQ(r.ROOTPATH?yi.join(r.ROOTPATH,Yt.HDB_CONFIG_FILE):If.get("settings_path")),um=Yt.LOG_NAMES.HDB,dm=yi.join(wf,um),BQ)try{require("segfault-handler").registerHandler(yi.join(wf,"crash.log"))}catch{}}}catch(t){if(If=void 0,t.code===Yt.NODE_ERROR_CODES.ENOENT||t.code===Yt.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=AD(Object.keys(Yt.CONFIG_PARAM_MAP),!0);for(let o in r){let c=Yt.CONFIG_PARAM_MAP[o];c&&c.toLowerCase();let l=r[o];if(c===Yt.CONFIG_PARAMS.LOGGING_LEVEL){Pr=l;continue}if(c===Yt.CONFIG_PARAMS.LOGGING_STDSTREAMS){Es=l;continue}c===Yt.CONFIG_PARAMS.LOGGING_FILE&&(Ri=c),c===Yt.CONFIG_PARAMS.LOGGING_CONSOLE&&(tR=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=XQ();Ri=Ri===void 0?s:Ri,Ri=yD(Ri),Es=Es===void 0?i:Es,Es=yD(Es),Pr=Pr===void 0?n:Pr,wf=FQ,um=Yt.LOG_NAMES.INSTALL,dm=yi.join(wf,um);return}throw fm("Error initializing log settings"),fm(t),t}process.env.DEV_MODE&&(Es=!0),VQ()}a(wD,"initLogSettings");var _a=!0;function VQ(){Ri&&(process.stdout.write=function(e){return typeof e=="string"&&_a&&tR!==!1&&(nR(),e=e.toString(),e[e.length-1]===`
3
+ `&&(e=e.slice(0,-1)),so.appendFileSync(fa,js("stdout",[e]))),RD.apply(process.stdout,arguments)},process.stderr.write=function(e){return typeof e=="string"&&_a&&tR!==!1&&(nR(),e[e.length-1]===`
4
+ `&&(e=e.slice(0,-1)),so.appendFileSync(fa,js("stderr",[e]))),RD.apply(process.stderr,arguments)})}a(VQ,"stdioLogging");function KQ(e,t){let r={tagName:e.replace(/ /g,"-")};return{notify:n(LD,"notify"),fatal:n(MD,"fatal"),error:n(fm,"error"),warn:n(vD,"warn"),info:n(CD,"info"),debug:n(DD,"debug"),trace:n(PD,"trace")};function n(s,i){return!t||Er[Pr]<=Er[i]?function(...o){return s(r,...o)}:null}}a(KQ,"loggerWithTag");function YQ(e){try{_a=!1,e()}finally{_a=!0}}a(YQ,"suppressLogging");var WQ=UQ?.name?.replace(/ /g,"-")||"main";function js(e,t){let r=new Date(Date.now()).toISOString(),n="",s=t.length,i=s-1,o=[e],c=0,l;for(typeof t[0]=="object"&&(t[0]?.tagName?(o.push(t[0]?.tagName),c++):t[0]?.serviceName&&(l=t[0]?.serviceName,c++)),o.unshift(l||WQ+"/"+xQ);c<s;c++){let u=t[c];if(u instanceof Error&&u.stack)n+=u.stack,Object.keys(u).length>0&&(n+=`
5
5
  `+JSON.stringify(u)),u.cause&&(t[c--]=u.cause,u&&(n+=`
6
6
  Caused by:`));else if(typeof u=="object")try{n+=JSON.stringify(u)}catch{n+="Object ["+Object.keys(u)+"]"}else n+=u;c<i&&(n+=" ")}return`${r} [${o.join("] [")}]: ${n}
7
- `}a(zs,"createLogRecord");function If(e){if(Ai){if(ID(e),ms){fa=!1;try{process.stdout.write(e)}finally{fa=!0}}}else ms&&process.stdout.write(e)}a(If,"logStdOut");function fm(e){if(Ai){if(ID(e),ms){fa=!1;try{process.stderr.write(e)}finally{fa=!0}}}else ms&&process.stderr.write(e)}a(fm,"logStdErr");function ID(e){rR(),da?no.appendFileSync(da,e):tR||console.log(e)}a(ID,"logToFile");function sR(){try{no.closeSync(da)}catch{}da=null}a(sR,"closeLogFile");function rR(){if(!da){try{da=no.openSync(um,"a")}catch(e){tR||(tR=!0,console.error(e))}setTimeout(()=>{sR()},qQ).unref()}}a(rR,"openLogFile");function CD(...e){Er[Pr]<=Er.info&&If(zs("info",e))}a(CD,"info");function PD(...e){Er[Pr]<=Er.trace&&If(zs("trace",e))}a(PD,"trace");function dm(...e){Er[Pr]<=Er.error&&fm(zs("error",e))}a(dm,"error");function DD(...e){Er[Pr]<=Er.debug&&If(zs("debug",e))}a(DD,"debug");function LD(...e){Er[Pr]<=Er.notify&&If(zs("notify",e))}a(LD,"notify");function MD(...e){Er[Pr]<=Er.fatal&&fm(zs("fatal",e))}a(MD,"fatal");function vD(...e){Er[Pr]<=Er.warn&&fm(zs("warn",e))}a(vD,"warn");function zQ(e,t,...r){t===ND.STDERR?fm(zs(e,r)):If(zs(e,r))}a(zQ,"logCustomLevel");function jQ(){let e;try{e=HQ.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=Ri.join(e,Wt.HDB_HOME_DIR_NAME,Wt.BOOT_PROPS_FILE_NAME);return no.existsSync(t)||(t=Ri.join(nR,"utility/hdb_boot_properties.file")),t}a(jQ,"getPropsFilePath");function JQ(e){Pr=e}a(JQ,"setLogLevel");function yD(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(yD,"autoCastBoolean");function QQ(e){try{if(e.includes("config/settings.js")){let o=OD(e);return{level:o.get(Wt.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY),config_log_path:Ri.dirname(o.get(Wt.HDB_SETTINGS_NAMES.LOG_PATH_KEY)),to_file:o.get(Wt.HDB_SETTINGS_NAMES.LOG_TO_FILE),to_stream:o.get(Wt.HDB_SETTINGS_NAMES.LOG_TO_STDSTREAMS)}}let t=bD.parseDocument(no.readFileSync(e,"utf8")),r=t.getIn(["logging","level"]),n=t.getIn(["logging","root"]),s=t.getIn(["logging","file"]),i=t.getIn(["logging","stdStreams"]);return{level:r,config_log_path:n,to_file:s,to_stream:i}}catch(t){if(t.code===Wt.NODE_ERROR_CODES.ENOENT)throw t;console.error("Error accessing config file for logging"),console.error(t)}}a(QQ,"getLogConfig");function XQ(){try{let e=bD.parseDocument(no.readFileSync(GQ,"utf8")),t=e.getIn(["logging","level"]),r=e.getIn(["logging","file"]),n=e.getIn(["logging","stdStreams"]);return{default_level:t,default_to_file:r,default_to_stream:n}}catch(e){console.error("Error accessing default config file for logging"),console.error(e)}}a(XQ,"getDefaultConfig");function ZQ(e,t,r,n,s,i){this.username=e,this.status=t,this.type=r,this.originating_ip=n,this.request_method=s,this.path=i}a(ZQ,"AuthAuditLog")});var iR=w((Wye,BD)=>{"use strict";var e4=require("util"),t4=require("path"),r4=require("child_process"),n4=e4.promisify(r4.execFile),s4=1e3*1e3*10;BD.exports={findPs:i4};async function i4(e){let t={};try{await Promise.all(["comm","args","ppid","uid","%cpu","%mem"].map(async r=>{let{stdout:n}=await n4("ps",["wwxo",`pid,${r}`],{maxBuffer:s4});for(let s of n.trim().split(`
8
- `).slice(1)){s=s.trim();let[i]=s.split(" ",1),o=s.slice(i.length+1).trim();t[i]===void 0&&(t[i]={}),t[i][r]=o}}))}catch(r){throw r}return Object.entries(t).filter(([,r])=>r.comm&&r.args&&r.ppid&&r.uid&&r["%cpu"]&&r["%mem"]&&r.args.includes(e)).map(([r,n])=>({pid:Number.parseInt(r,10),name:t4.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(i4,"findPs")});var xt=w((jye,kD)=>{"use strict";var o4="__dbis__",a4="__txns__",c4="__environment_name__",l4="__dbi_defintion__",u4={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"},d4=["__createdtime__","__updatedtime__"],f4="\uFFFF",HD={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},_4=Object.values(HD);kD.exports={AUDIT_STORE_NAME:a4,INTERNAL_DBIS_NAME:o4,DBI_DEFINITION_NAME:l4,SEARCH_TYPES:u4,TIMESTAMP_NAMES:d4,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:c4,TRANSACTIONS_DBI_NAMES_ENUM:HD,TRANSACTIONS_DBIS:_4,OVERFLOW_MARKER:f4}});var xn=w((Jye,zD)=>{"use strict";var FD=(H(),C(G)),GD=xt(),qD={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},$D=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),VD={500:$D("There was an error processing your request."),400:"Invalid request"},p4=VD[qD.INTERNAL_SERVER_ERROR],h4={OP_NOT_SUPPORTED_FOR_FS:a(e=>`${e} is not available for this instance because it uses the File System data store.`,"OP_NOT_SUPPORTED_FOR_FS"),MISSING_VALUE:a(e=>`${e} is missing.`,"MISSING_VALUE"),INVALID_VALUE:a(e=>`${e} is invalid.`,"INVALID_VALUE"),NOT_FOUND:a(e=>`${e} not found.`,"NOT_FOUND")},m4={CONFIG_VALIDATION:a(e=>`HarperDB config file validation error: ${e}`,"CONFIG_VALIDATION")},E4={DEFAULT_BULK_LOAD_ERR:"There was an error during your bulk load into HarperDB.",DOWNLOAD_FILE_ERR:a(e=>`There was an error downloading '${e}'.`,"DOWNLOAD_FILE_ERR"),INSERT_JSON_ERR:"There was an error inserting the downloaded JSON data.",INSERT_CSV_ERR:"There was an error inserting the downloaded CSV data.",INVALID_ACTION_PARAM_ERR:a(e=>`Bulk load operation failed - ${e} is not a valid 'action' parameter`,"INVALID_ACTION_PARAM_ERR"),INVALID_FILE_EXT_ERR:a(e=>`Error selecting correct parser - valid file type not found in json - ${e}`,"INVALID_FILE_EXT_ERR"),MAX_FILE_SIZE_ERR:a((e,t)=>`File size is ${e} bytes, which exceeded the maximum size allowed of: ${t} bytes`,"MAX_FILE_SIZE_ERR"),PAPA_PARSE_ERR:"There was an error parsing the downloaded CSV data.",S3_DOWNLOAD_ERR:a(e=>`There was an error downloading '${e}' from AWS.`,"S3_DOWNLOAD_ERR"),WRITE_TEMP_FILE_ERR:"Error writing temporary file to storage"},g4={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 ${GD.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${GD.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"},S4={ATTR_NAME_LENGTH_ERR:a(e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${FD.INSERT_MAX_CHARACTER_SIZE} bytes.`,"ATTR_NAME_LENGTH_ERR"),ATTR_NAME_NULLISH_ERR:"transaction aborted due to record(s) with an attribute name that is null, undefined or empty string",HASH_VAL_LENGTH_ERR:`transaction aborted due to record(s) with a hash value that exceeds ${FD.INSERT_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"},KD={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"},T4={DEFAULT_INVALID_REQUEST:"Invalid request",OP_AUTH_PERMS_ERROR:"This operation is not authorized due to role restrictions and/or invalid database items",OP_IS_SU_ONLY:a(e=>`Operation '${e}' is restricted to 'super_user' roles`,"OP_IS_SU_ONLY"),OP_NOT_FOUND:a(e=>`Operation '${e}' not found`,"OP_NOT_FOUND"),SYSTEM_TIMESTAMP_PERMS_ERR:"Internal timestamp attributes - '__createdtime_' and '__updatedtime__' - cannot be inserted to or updated by HDB users.",UNKNOWN_OP_AUTH_ERROR:a((e,t,r)=>`There was an error authorizing ${e} op on table '${t}.${r}'`,"UNKNOWN_OP_AUTH_ERROR"),USER_HAS_NO_PERMS:a(e=>`User ${e} has no role or permissions. Please assign the user a valid role.`,"USER_HAS_NO_PERMS"),DROP_SYSTEM:"The 'system' database, tables and records are used internally by HarperDB and cannot be updated or removed."},A4={ATTR_PERM_MISSING:a((e,t)=>`${e.toUpperCase()} attribute permission missing for '${t}'`,"ATTR_PERM_MISSING"),ATTR_PERM_MISSING_NAME:"Permission object in 'attribute_permission' missing an 'attribute_name'",ATTR_PERM_NOT_BOOLEAN:a((e,t)=>`${e.toUpperCase()} attribute permission for '${t}' must be a boolean`,"ATTR_PERM_NOT_BOOLEAN"),ATTR_PERMS_ARRAY_MISSING:"Missing 'attribute_permissions' array",ATTR_PERMS_NOT_ARRAY:"Value for 'attribute_permissions' must be an array",INVALID_ATTRIBUTE_IN_PERMS:a(e=>`Invalid attribute '${e}' in 'attribute_permissions'`,"INVALID_ATTRIBUTE_IN_PERMS"),INVALID_PERM_KEY:a(e=>`Invalid table permission key value '${e}'`,"INVALID_PERM_KEY"),INVALID_ATTR_PERM_KEY:a(e=>`Invalid attribute permission key value '${e}'`,"INVALID_ATTR_PERM_KEY"),INVALID_ROLE_JSON_KEYS:a(e=>`Invalid ${e.length>1?"keys":"key"} in JSON body - '${e.join("', '")}'`,"INVALID_ROLE_JSON_KEYS"),MISMATCHED_TABLE_ATTR_PERMS:a(e=>`You have a conflict with TABLE permissions for '${e}' being false and ATTRIBUTE permissions being true`,"MISMATCHED_TABLE_ATTR_PERMS"),OUTDATED_PERMS_TRANSLATION_ERROR:"This instance was recently upgraded and uses our new role permissions structure. Please login to this instance in HarperDB Studio, go to 'Roles', and click 'Update Role Permission' for all standard roles to migrate them to the new structure.",ROLE_ALREADY_EXISTS:a(e=>`A role with name '${e}' already exists`,"ROLE_ALREADY_EXISTS"),ROLE_NOT_FOUND:"Role not found",ROLE_PERMS_ERROR:"Errors in the role permissions JSON provided",SCHEMA_PERM_ERROR:a(e=>`Your role does not have permission to view database metadata for '${e}'`,"SCHEMA_PERM_ERROR"),SCHEMA_TABLE_PERM_ERROR:a((e,t)=>`Your role does not have permission to view database.table metadata for '${e}.${t}'`,"SCHEMA_TABLE_PERM_ERROR"),SU_ROLE_MISSING_ERROR:"Missing 'super_user' key/value in permission set",SU_CU_ROLE_BOOLEAN_ERROR:a(e=>`Value for '${e}' permission must be a boolean`,"SU_CU_ROLE_BOOLEAN_ERROR"),STRUCTURE_USER_ROLE_TYPE_ERROR:a(e=>`Value for '${e}' permission must be a boolean or Array`,"STRUCTURE_USER_ROLE_TYPE_ERROR"),SU_CU_ROLE_NO_PERMS_ALLOWED:a(e=>`Roles with '${e}' set to true cannot have other permissions set.`,"SU_CU_ROLE_NO_PERMS_ALLOWED"),SU_CU_ROLE_COMBINED_ERROR:"Roles cannot have both 'super_user' and 'cluster_user' values included in their permissions set.",TABLE_PERM_MISSING:a(e=>`Missing table ${e.toUpperCase()} permission`,"TABLE_PERM_MISSING"),TABLE_PERM_NOT_BOOLEAN:a(e=>`Table ${e.toUpperCase()} permission must be a boolean`,"TABLE_PERM_NOT_BOOLEAN")},R4={ATTR_NOT_FOUND:a((e,t,r)=>`Attribute '${r}' does not exist on '${e}.${t}'`,"ATTR_NOT_FOUND"),ATTR_EXISTS_ERR:a((e,t,r)=>`Attribute '${r}' already exists in ${e}.${t}'`,"ATTR_EXISTS_ERR"),DESCRIBE_ALL_ERR:"There was an error during describeAll. Please check the logs and try again.",INVALID_TABLE_ERR:a(e=>`Invalid table ${JSON.stringify(e)}`,"INVALID_TABLE_ERR"),SCHEMA_NOT_FOUND:a(e=>`database '${e}' does not exist`,"SCHEMA_NOT_FOUND"),SCHEMA_EXISTS_ERR:a(e=>`database '${e}' already exists`,"SCHEMA_EXISTS_ERR"),TABLE_EXISTS_ERR:a((e,t)=>`Table '${t}' already exists in '${e}'`,"TABLE_EXISTS_ERR"),SCHEMA_REQUIRED_ERR:"database is required",TABLE_NOT_FOUND:a((e,t)=>`Table '${e}.${t}' does not exist`,"TABLE_NOT_FOUND"),TABLE_REQUIRED_ERR:"table is required"},y4={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},b4={ALTER_USER_DUP_ROLES:a(e=>`Update failed. There are duplicates for the '${e}' role which is not allowed. Update your roles and try again.`,"ALTER_USER_DUP_ROLES"),ALTER_USER_ROLE_NOT_FOUND:a(e=>`Update failed. Requested '${e}' role not found.`,"ALTER_USER_ROLE_NOT_FOUND"),DUP_ROLES_FOUND:a(e=>`Multiple ${e} roles found. Roles must have unique 'role' value. Please update and try again.`,"DUP_ROLES_FOUND"),ROLE_NAME_NOT_FOUND:a(e=>`${e} role not found`,"ROLE_NAME_NOT_FOUND"),USER_ALREADY_EXISTS:a(e=>`User ${e} already exists`,"USER_ALREADY_EXISTS"),USER_NOT_EXIST:a(e=>`User ${e} does not exist`,"USER_NOT_EXIST")},YD={INVALID_DATE:"Invalid date, must be in ISO-8601 format (YYYY-MM-DD).",SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE:a(e=>`invalid sort attribute '${e}', the attribute must either be the table's hash attribute or an attribute used in conditions.`,"SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE")},WD={INVALID_ITC_DATA_TYPE:"Invalid ITC event data type, must be an object",MISSING_TYPE:"ITC event missing 'type'",MISSING_MSG:"ITC event missing 'message'",MISSING_ORIGIN:"ITC event message missing 'originator' property",INVALID_EVENT:a(e=>`ITC server received invalid event type: ${e}`,"INVALID_EVENT")},O4={FUNCTION_STATUS:"Error getting custom function status, check the log for more details",GET_FUNCTIONS:"Error getting custom functions, check the log for more details",GET_FUNCTION:"Error getting custom function, check the log for more details",SET_FUNCTION:"Error setting custom function, check the log for more details",NO_PROJECT:"Project does not exist. Create one using 'add_custom_function_project'",PROJECT_EXISTS:"Project already exists",VALIDATION_ERR:"Error validating request, check the log for more details",NO_FILE:"File does not exist",BAD_FILE_NAME:"File name can only contain alphanumeric, dash and underscore characters",BAD_PROJECT_NAME:"Project name can only contain alphanumeric, dash and underscores characters",BAD_PACKAGE:"Packaged project must be base64-encoded tar file of project directory",DROP_FUNCTION:"Error dropping custom function, check the log for more details",ADD_FUNCTION:"Error adding custom function project, check the log for more details",DROP_FUNCTION_PROJECT:"Error dropping custom function project, check the log for more details",BAD_FILE_PATH:"Filepath must be valid, and contain the name of the tarball you wish to write",NOT_ENABLED:"Custom functions is not enabled, to enable set fastifyRoutes enabled to true in hdb/harperdb-config.yaml file.",BAD_SSH_KEY_NAME:"SSH key name can only contain alphanumeric, dash and underscore characters"},N4={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},w4={...KD,...E4,...h4,...T4,...A4,...R4,...y4,...b4,...S4,...YD,...WD,...O4,...N4,...m4};zD.exports={CHECK_LOGS_WRAPPER:$D,HDB_ERROR_MSGS:w4,DEFAULT_ERROR_MSGS:VD,DEFAULT_ERROR_RESP:p4,HTTP_STATUS_CODES:qD,LMDB_ERRORS_ENUM:g4,AUTHENTICATION_ERROR_MSGS:KD,VALIDATION_ERROR_MSGS:YD,ITC_ERRORS:WD}});var pe=w((Xye,QD)=>{"use strict";var _u=xn(),I4=z(),C4=(H(),C(G)),_m=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,jD),this.statusCode=n||_u.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(_u.DEFAULT_ERROR_MSGS[n]?_u.DEFAULT_ERROR_MSGS[n]:_u.DEFAULT_ERROR_MSGS[_u.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&&I4[s](i)}},oR=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}},aR=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function jD(e,t,r,n=C4.LOG_LEVELS.ERROR,s=null,i=!1){if(JD(e))return e;let o=new _m(e,t,r,n,s);return i&&delete o.stack,o}a(jD,"handleHDBError");function JD(e){return e.__proto__.constructor.name===_m.name}a(JD,"isHDBError");QD.exports={isHDBError:JD,handleHDBError:jD,ClientError:oR,ServerError:aR,hdb_errors:_u}});var gt=w((ebe,sL)=>{"use strict";var Mf=(H(),C(G)),P4=ie(),fn=ae(),vf=require("path"),D4=require("minimist"),XD=require("fs-extra"),ZD=require("lodash");fn.initSync();var{CONFIG_PARAMS:_a,DATABASES_PARAM_CONFIG:Cf,SYSTEM_SCHEMA_NAME:pm}=Mf,Pf,Df,Lf;function eL(){if(Pf!==void 0)return Pf;if(fn.getHdbBasePath()!==void 0)return Pf=fn.get(_a.STORAGE_PATH)||vf.join(fn.getHdbBasePath(),Mf.DATABASES_DIR_NAME),Pf}a(eL,"getBaseSchemaPath");function tL(){if(Df!==void 0)return Df;if(fn.getHdbBasePath()!==void 0)return Df=nL(pm),Df}a(tL,"getSystemSchemaPath");function rL(){if(Lf!==void 0)return Lf;if(fn.getHdbBasePath()!==void 0)return Lf=fn.get(Mf.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||vf.join(fn.getHdbBasePath(),Mf.TRANSACTIONS_DIR_NAME),Lf}a(rL,"getTransactionAuditStoreBasePath");function L4(e,t){let r=fn.get(_a.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||vf.join(rL(),e.toString())}a(L4,"getTransactionAuditStorePath");function nL(e,t){e=e.toString(),t=t&&t.toString();let r=fn.get(Mf.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||vf.join(eL(),e)}a(nL,"getSchemaPath");function M4(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,D4(process.argv));let n=r[_a.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!P4.isObject(n))throw o;i=n}for(let o of i){let c=o[pm];if(!c)continue;let l=fn.get(_a.DATABASES);l=l??{};let u=c?.tables?.[t]?.[Cf.PATH];if(u)return ZD.set(l,[pm,Cf.TABLES,t,Cf.PATH],u),fn.setProperty(_a.DATABASES,l),u;let f=c?.[Cf.PATH];if(f)return ZD.set(l,[pm,Cf.PATH],f),fn.setProperty(_a.DATABASES,l),f}}let s=r[_a.STORAGE_PATH.toUpperCase()];if(s){if(!XD.pathExistsSync(s))throw new Error(s+" does not exist");let i=vf.join(s,e);return XD.mkdirsSync(i),fn.setProperty(_a.STORAGE_PATH,s),i}return tL()}a(M4,"initSystemSchemaPaths");function v4(){Pf=void 0,Df=void 0,Lf=void 0}a(v4,"resetPaths");sL.exports={getBaseSchemaPath:eL,getSystemSchemaPath:tL,getTransactionAuditStorePath:L4,getTransactionAuditStoreBasePath:rL,getSchemaPath:nL,initSystemSchemaPaths:M4,resetPaths:v4}});var _n=w((sbe,lL)=>{"use strict";var U4=xn().LMDB_ERRORS_ENUM,rbe=require("lmdb"),x4=xt(),nbe=require("buffer").Buffer,{OVERFLOW_MARKER:iL,MAX_SEARCH_KEY_LENGTH:hm}=x4,oL=["number","string","symbol","boolean","bigint"];function B4(e){if(e=e?.primaryStore||e,!e)throw new Error(U4.ENV_REQUIRED)}a(B4,"validateEnv");function H4(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(H4,"stringifyData");function k4(e){return e instanceof Date?e.valueOf():e}a(k4,"convertKeyValueToWrite");function F4(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(oL.includes(typeof e))return e.length>hm?[e.slice(0,hm)+iL]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(oL.includes(typeof i))i.length>hm?r.push(i.slice(0,hm)+iL):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(F4,"getIndexedValues");var mm=0,aL=0;function cL(){aL=Date.now()-performance.now()}a(cL,"adjustStartTime");cL();var G4=6e4;setInterval(cL,G4).unref();function q4(){let e=performance.now()+aL;return e>mm?(mm=e,e):(mm+=488e-6,mm)}a(q4,"getNextMonotonicTime");lL.exports={validateEnv:B4,stringifyData:H4,convertKeyValueToWrite:k4,getNextMonotonicTime:q4,getIndexedValues:F4}});var Uf=w((obe,uL)=>{"use strict";var $4=(H(),C(G)).OPERATIONS_ENUM,cR=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=$4.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};uL.exports=cR});var xf=w((lbe,pL)=>{"use strict";var cbe=Uf(),Em=(H(),C(G)),lR=ie(),dL=z(),V4=require("uuid"),{handleHDBError:gm,hdb_errors:K4}=pe(),{HDB_ERROR_MSGS:Sm,HTTP_STATUS_CODES:Tm}=K4;pL.exports=fL;function fL(e,t,r){for(let s=0;s<t.length;s++)_L(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];Y4(i,r,e.operation)}}a(fL,"processRows");fL.validateAttribute=_L;function _L(e){if(Buffer.byteLength(String(e))>Em.INSERT_MAX_CHARACTER_SIZE)throw gm(new Error,Sm.ATTR_NAME_LENGTH_ERR(e),Tm.BAD_REQUEST,void 0,void 0,!0);if(lR.isEmptyOrZeroLength(e)||lR.isEmpty(e.trim()))throw gm(new Error,Sm.ATTR_NAME_NULLISH_ERR,Tm.BAD_REQUEST,void 0,void 0,!0)}a(_L,"validateAttribute");function Y4(e,t,r){if(!e.hasOwnProperty(t)||lR.isEmptyOrZeroLength(e[t])){if(r===Em.OPERATIONS_ENUM.INSERT||r===Em.OPERATIONS_ENUM.UPSERT){e[t]=V4.v4();return}throw dL.error("Update transaction aborted due to record with no hash value:",e),gm(new Error,Sm.RECORD_MISSING_HASH_ERR,Tm.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>Em.INSERT_MAX_CHARACTER_SIZE)throw dL.error(e),gm(new Error,Sm.HASH_VAL_LENGTH_ERR,Tm.BAD_REQUEST,void 0,void 0,!0)}a(Y4,"validateHash")});var hL,Bn,uR,pu=be(()=>{hL=require("events"),Bn=class extends hL.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new uR;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)}},uR=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}}}});function RL(e){fR=e}function J4(){j4=setInterval(function(){for(let e of dR)if(e.stale){let t=e.getContext()?.url;SL.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},z4).unref()}var _R,gL,SL,TL,AL,mL,dR,W4,Bf,EL,fR,wc,Am,z4,j4,Rm=be(()=>{_R=M(_n()),gL=M(pe()),SL=M(z()),TL=M(ae());H();AL=M(ie()),mL=100,dR=new Set,W4=(0,AL.convertToMS)(TL.get(x.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(RL,"replicationConfirmation");wc=class e{static{a(this,"DatabaseTransaction")}#e;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),dR.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn?.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(dR.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(Bf&&!this.overloadChecked&&performance.now()-EL>W4)throw new gL.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,_R.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 _=d;_<this.validated;_++)this.writes[_]?.validate?.(this.timestamp);let p;for(let _=d;_<this.validated;_++){let h=this.writes[_];h&&(h.before||h.beforeIntermediate)&&(p=!0)}if(p)return(async()=>{try{for(let _=0;_<2;_++){let h;for(let S=d;S<this.validated;S++){let g=this.writes[S];if(!g)continue;let R=g[_===0?"before":"beforeIntermediate"];if(R){let E=R();h?h.push?h.push(E):h=[h,E]:h=E}}h&&await(h.push?Promise.all(h):h)}}catch(_){throw this.abort(),_}return this.commit(t)})()}catch(d){throw this.abort(),d}n||this.doneReadTxn(),this.open=t?.doneWriting?2:1;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 p=d.store.ifVersion(d.key,d.entry?.version??null,l);s=s||p}else l();else for(let p of this.writes)c(p)},"nextCondition"),u=this.lmdbDb;if(this.writes.length>0&&(u?.retryRisk&&(u.retryRisk*=.99),this.writes.length+(u?.retryRisk||0)<mL>>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 Bf||(Bf=s,EL=performance.now(),Bf.then(()=>{Bf=null})),s.then(d=>{if(d){if(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.replicatedConfirmation){let p=this.writes[0].store.rootStore.databaseName,_=this.writes[this.writes.length-1];fR&&_&&i.push(fR(p,_.store.getEntry(_.key).localTime,this.replicatedConfirmation))}return this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))}else return u&&(u.retryRisk=(u.retryRisk||0)+mL/2),t?t.retries=n+1:t={retries:1},this.commit(t)});let f={txnTime:r};if(this.next){let d=this.next?.commit(t);if(d?.then)return d?.then(p=>({txnTime:r,next:p}));f.next=d}return f}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}getContext(){return this.#e}setContext(t){this.#e=t}},Am=class extends wc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,_R.getNextMonotonicTime)())}getReadTxn(){}},z4=3e4;a(J4,"startMonitoringTxns");J4()});function wt(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 wc;e.timestamp&&(n.timestamp=e.timestamp),e.replicatedConfirmation&&(n.replicatedConfirmation=e.replicatedConfirmation),n.setContext(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({doneWriting:!0});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var yL,Ic=be(()=>{yL=M(Ti());Rm();a(wt,"transaction");(0,yL._assignPackageExport)("transaction",wt);wt.commit=function(e){let t=(e.getContext?.()||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};wt.abort=function(e){let t=(e.getContext?.()||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});function hR(e,t,r,n,s,i,o,c){let l=e[0];if(t==="or"){let d=u(l);for(let _=1;_<e.length;_++){let h=e[_],S=u(h);d=d.concat(S)}let p=new Set;return d.filter(_=>{let h=_.key??_;return p.has(h)?!1:(p.add(h),!0)})}else{let d=u(l),p=f(e.slice(1),!0,l.estimated_count);return p.length>0?o(d,p):d}function u(d){return d.conditions?hR(d.conditions,d.operator,r,n,s,i,o,c):Eu(d,n,d.descending||s.reverse===!0,r,s.allowFullScan,c)}a(u,"executeCondition");function f(d,p,_){return d.map((h,S)=>{if(h.conditions){let E=h.operator==="or",T=f(h.conditions,!E,_);return E?(b,v)=>T.some(F=>F(b,v)):(b,v)=>T.every(F=>F(b,v))}let g=(h.attribute||h[0])===r.primaryKey,R=Ff(h,r,i,c,g,_);return p&&S<d.length-1&&_&&(_=i3(r.primaryStore,h.estimated_count,_)),R}).filter(Boolean)}a(f,"mapConditionsToFilters")}function Eu(e,t,r,n,s,i){let o=e[0]??e.attribute,c=e[1]??e.value,l=e.comparator;if(c===void 0&&l!=="sort")throw new hn.ClientError(`Search condition for ${o} must have a value`);if(Array.isArray(o)){let E=o[0],T=bi(n.attributes,E);if(T.relationship){if(o.length<2)throw new hn.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let b=T.definition?.tableClass||T.elements?.definition?.tableClass,v=new Map,F=Eu({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,b,s,v);if(T.relationship.to){i[o[0]]=v;let q=!!bi(b.attributes,T.relationship.to)?.elements;F=t3(F,T,b.primaryStore,q,v)}if(T.relationship.from){let q=a(Y=>(Y?.key!==void 0&&(Y=Y.key),Eu({attribute:T.relationship.from,value:Y},t,r,n,s,v)),"searchEntry");T.elements?(i[o[0]]=v,F=r3(F,T,b.primaryStore,v,q)):F=F.flatMap(q)}return F}else if(o.length===1)o=o[0];else throw new hn.ClientError("Unable to query by attribute "+JSON.stringify(o))}let u,f,d,p;c instanceof Date&&(c=c.getTime());let _;switch(mR[l]||l){case"lt":u=!0,f=c;break;case"le":u=!0,f=c,d=!0;break;case"gt":u=c,p=!0;break;case"ge":u=c;break;case"prefix":Array.isArray(c)?c[c.length-1]!=null&&(c=c.concat(null)):c=[c,null],u=c,f=c.slice(0),f[f.length-1]=yi.MAXIMUM_KEY;break;case"starts_with":u=c.toString(),f=c+"\uFFFF";break;case"between":case"gele":case"gelt":case"gtlt":case"gtle":u=c[0],u instanceof Date&&(u=u.getTime()),f=c[1],f instanceof Date&&(f=f.getTime()),d=l==="gele"||l==="gtle"||l==="between",p=l==="gtlt"||l==="gtle";break;case"equals":case void 0:u=c,f=c,d=!0;break;case"ne":if(c===null){u=c,p=!0;break}case"sort":case"contains":case"ends_with":u=!0,_=!0;break;default:throw new hn.ClientError(`Unknown query comparator "${l}"`)}let h,S=o===n.primaryKey||o==null;if(typeof u=="string"&&u.length>Es.MAX_SEARCH_KEY_LENGTH&&(u=u.slice(0,Es.MAX_SEARCH_KEY_LENGTH)+Es.OVERFLOW_MARKER,p=!1,h=Ff(e,n,null,i,S)),typeof f=="string"&&f.length>Es.MAX_SEARCH_KEY_LENGTH&&(f=f.slice(0,Es.MAX_SEARCH_KEY_LENGTH)+Es.OVERFLOW_MARKER,d=!0,h=h??Ff(e,n,null,i,S)),r){let E=u;u=f,f=E,E=!p,p=!d,d=E}let g=S?n.primaryStore:n.indices[o];if(!g||g.isIndexing||_||c===null&&!g.indexNulls){if(s===!1&&!g)throw new hn.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&_)throw new hn.ClientError(`Can not use ${l||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(g?.isIndexing)throw new hn.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&g&&!g.indexNulls)throw new hn.ClientError(`"${o}" is not indexed for nulls, index needs to be rebuilt to search for nulls, can not search for this attribute`,400);if(h=h??Ff(e,n,null,i,S),!h)throw new hn.ClientError(`Unknown search operator ${e.comparator}`)}let R={start:u,end:f,inclusiveEnd:d,exclusiveStart:p,values:!0,versions:S,transaction:t,reverse:r};if(S){let E=g.getRange(R).map(h?function({key:T,value:b}){return this?.isSync?b&&h(b)?T:pa.SKIP:new Promise((v,F)=>setImmediate(()=>{try{v(b&&h(b)?T:pa.SKIP)}catch(q){F(q)}}))}:T=>T.value==null&&!(T.metadataFlags&(mn|ma))?pa.SKIP:T);return E.hasEntries=!0,E}else return g?g.getRange(R).map(h?function({key:E,value:T}){let b;return typeof E=="string"&&E.length>Es.MAX_SEARCH_KEY_LENGTH?b=n.primaryStore.get(T):b={[o]:E},this.isSync?h(b)?T:pa.SKIP:new Promise((v,F)=>setImmediate(()=>{try{v(h(b)?T:pa.SKIP)}catch(q){F(q)}}))}:({value:E})=>E):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:E,value:T}){return this.isSync?T&&h(T)?E:pa.SKIP:new Promise((b,v)=>setImmediate(()=>{try{b(T&&h(T)?E:pa.SKIP)}catch(F){v(F)}}))})}function bi(e,t){if(Array.isArray(t))if(t.length>1){let r=bi(e,t[0]),n=(r?.definition?.tableClass||r?.elements?.definition?.tableClass)?.attributes??r?.properties;return n?bi(n,t.slice(1)):void 0}else t=t.toString();else typeof t!="string"&&(t=t.toString());return e.find(r=>r.name===t)}function t3(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i;return s.hasMappings=!0,{next(){if(!i){let c=t.relationship.to,l=a((u,f)=>{let d=s.get(u);d?d.push(f):s.set(u,d=[f])},"add_entry");for(let u of e){let f=u.value??r.get(u.key??u),d=f?.[c];if(d!=null&&!s.filters?.some(p=>!p(f)))if(n)for(let p=0;p<d.length;p++)l(d[p],u);else l(d,u)}return i=s.keys()[Symbol.iterator](),this.next()}let o=i.next();return o.done?o:{value:o.value}},return(){if(i?.return)return i.return()}}}})}function r3(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i,o,c=new Set;return{next(){let l;if(o)for(;l=o.next(),!l.done;){let u=l.value;if(!c.has(u))return c.add(u),l}if(!i){let u=new Set;n.fromRecord=f=>f[t.relationship.from]?.filter?.(d=>u.has(d));for(let f of e){if(n.filters){let d=r.get(f);if(n.filters.some(p=>!p(d)))continue}u.add(f)}return i=u[Symbol.iterator](),this.next()}do{let u=i.next();return u.done?u:(o=s(u.value)[Symbol.iterator](),this.next())}while(!0)},return(){return o?.return?.()},throw(){return o?.throw?.()}}}})}function Ff(e,t,r,n,s,i){let o=e.comparator,c=e[0]??e.attribute,l=e[1]??e.value;if(Array.isArray(c)){if(c.length===0)return()=>!0;if(c.length===1)c=c[0];else if(c.length>1){let f=c[0],d=bi(t.attributes,f),p=d.definition?.tableClass||d.elements.definition?.tableClass,_=n?.[f],h=Ff({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:o},p,r,_?.[f]?.joined,c[1]===p.primaryKey,i);if(!h)return;if(_){_.filters||(_.filters=[]),_.filters.push(h);return}let S=t.propertyResolvers?.[f],g,R=a((E,T)=>{let b,v;if(S){if(S.from&&h.idFilter){if(!g)if(h.idFilter.idSet?.size===1){for(let q of h.idFilter.idSet)e={attribute:S.from,value:q};g=u(S.from,h.idFilter,!0,!0)}else g=u(S.from,h.idFilter,!1,!0);let F=g(E);return g.idFilter&&(R.idFilter=g.idFilter),F}v=S(E,r,T),b=v?.value}else b=E[f];return b?Array.isArray(b)?b.some(h):h(b,v):!1},"recordFilter");return R}}switch(l instanceof Date&&(l=l.getTime()),mR[o]||o){case Es.SEARCH_TYPES.EQUALS:case void 0:return u(c,f=>f===l,!0);case"contains":return u(c,f=>f?.toString().includes(l));case"ends_with":return u(c,f=>f?.toString().endsWith(l));case"starts_with":return u(c,f=>typeof f=="string"&&f.startsWith(l),!0);case"prefix":return Array.isArray(l)?l[l.length-1]==null&&(l=l.slice(0,-1)):l=[l],u(c,f=>{if(!Array.isArray(f))return!1;for(let d=0,p=l.length;d<p;d++)if(f[d]!==l[d])return!1;return!0},!0);case"between":return l[0]instanceof Date&&(l[0]=l[0].getTime()),l[1]instanceof Date&&(l[1]=l[1].getTime()),u(c,f=>(0,yi.compareKeys)(f,l[0])>=0&&(0,yi.compareKeys)(f,l[1])<=0,!0);case"gt":return u(c,f=>(0,yi.compareKeys)(f,l)>0);case"ge":return u(c,f=>(0,yi.compareKeys)(f,l)>=0);case"lt":return u(c,f=>(0,yi.compareKeys)(f,l)<0);case"le":return u(c,f=>(0,yi.compareKeys)(f,l)<=0);case"ne":return u(c,f=>(0,yi.compareKeys)(f,l)!==0,!1,!0);case"sort":return()=>!0;default:throw new hn.ClientError(`Unknown query comparator "${o}"`)}function u(f,d,p,_){let h;p=p&&!s&&t?.indices[f]&&i>3,p&&(e.estimated_count==null&&bm(t)(e),h=e.estimated_count>>4,(isNaN(h)||h>=i)&&(p=!1));let S=0,g=3;function R(E){let T=E[f],b;if(typeof T!="object"||!T||_?b=d(T):Array.isArray(T)?b=T.some(d):T instanceof Date&&(b=d(T.getTime())),p&&(g++,!b&&!R.idFilter&&++S/g*(i-g)>h)){let v=Eu(e,r.transaction.getReadTxn(),!1,t).map(gu),F=new Set(v);R.idFilter=q=>F.has(gu(q)),R.idFilter.idSet=F}return b}return a(R,"recordFilter"),s&&(R.idFilter=d),R}a(u,"attributeComparator")}function bm(e){function t(r){if(r.estimated_count===void 0){if(r.conditions){let s;if(r.operator==="or"){s=0;for(let i of r.conditions)t(i),s+=i.estimated_count}else{s=1/0;for(let i of r.conditions)t(i),s=isFinite(s)?s*i.estimated_count/so(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=mR[n]||n,n===Es.SEARCH_TYPES.EQUALS||!n){let s=r[0]??r.attribute;if(s==null||s===e.primaryKey)r.estimated_count=1;else if(Array.isArray(s)&&s.length>1){let i=bi(e.attributes,s[0]),o=i.definition?.tableClass||i.elements.definition?.tableClass,c=bm(o)({value:r.value,attribute:s.length>2?s.slice(1):s[1],comparator:"equals"}),l=e.indices[i.relationship.from];r.estimated_count=c+(l?c*so(e.indices[i.relationship.from])/(so(o.primaryStore)||1):c)}else{let i=e.indices[s];r.estimated_count=i?i.getValuesCount(r[1]??r.value):1/0}}else if(n==="contains"||n==="ends_with"||n==="ne"){let s=r[0]??r.attribute,i=e.indices[s];r.value===null&&n==="ne"?r.estimated_count=so(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=Z4*so(e.primaryStore)+1:n==="between"?r.estimated_count=X4*so(e.primaryStore)+1:n==="sort"?r.estimated_count=so(e.primaryStore)+1:r.estimated_count=Q4*so(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function Om(e){if(e)if(ha=e,hu.lastIndex=0,n3.test(e))try{let t=Hf(new mu,"");if(pn!==ha.length)throw new SyntaxError("Unable to parse query, unexpected end of query");return t}catch(t){throw t.statusCode=400,t.message=`Unable to parse query, ${t.message} at position ${pn} in '${ha}'`,t}else return new URLSearchParams(e)}function Hf(e,t){let r=hu,n,s,i,o,c,l=decodeURIComponent,u;for(;n=r.exec(ha);){pn=r.lastIndex;let[,f,d]=n;if(o){if(f)throw new SyntaxError(`expected operator, but encountered '${f}'`);o=!1,c=!1}else c=!0;let p;switch(d){case"=":if(s!=null){if(f.length<=2)i=f;else throw new SyntaxError(`invalid FIQL operator ${f}`);l=bL}else{if(l=decodeURIComponent,i="equals",!f)throw new SyntaxError("attribute must be specified before equality comparator");s=kf(f)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=e3[d],l=pR[i]?bL:decodeURIComponent,!f)throw new SyntaxError(`attribute must be specified before comparator ${d}`);s=kf(f);break;case"&=":case"|=":case"|":case"&":case"":case void 0:if(s==null){if(s===void 0)throw t?new SyntaxError(`expected '${t}', but encountered ${d[0]?"'"+d[0]+"'":"end of string"}}`):new SyntaxError(`no comparison specified before ${d?"'"+d+"'":"end of string"}`)}else{if(!e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");let h={comparator:i,attribute:s||null,value:l(f)};if(i==="eq"&&OL(h,f),s===""){let S=e.conditions[e.conditions.length-1];S.chainedConditions=S.chainedConditions||[],S.chainedConditions.push(h),S.operator=u}else ym(e,u),e.conditions.push(h)}d==="&"?(u="and",s=void 0):d==="|"?(u="or",s=void 0):d==="&="?(u="and",s=""):d==="|="&&(u="or",s="");break;case",":if(e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");e.push(kf(f)),s=void 0;break;case"(":hu.lastIndex=pn;let _=Hf(f?[]:new mu,")");switch(f){case"":ym(e,u),e.conditions.push(_);break;case"limit":switch(_.length){case 1:e.limit=+_[0];break;case 2:e.offset=+_[0],e.limit=_[1]-e.offset;break;default:throw new SyntaxError("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(_[0])&&_.length===1&&!_[0].name?(e.select=_[0],e.select.asArray=!0):_.length===1?e.select=_[0]:_.length===2&&_[1]===""?e.select=_.slice(0,1):e.select=_;break;case"group-by":throw new SyntaxError("group by is not implemented yet");case"sort":e.sort=NL(_);break;default:throw new SyntaxError(`unknown query function call ${f}`)}ha[pn]===","?r.lastIndex=++pn:o=!0,s=null;break;case"{":if(e.conditions)throw new SyntaxError("property sets are not allowed in a queries");if(!f)throw new SyntaxError("property sets must have a defined parent property name");hu.lastIndex=pn,p=Hf([],"}"),p.name=f,e.push(p),ha[pn]===","?r.lastIndex=++pn:o=!0;break;case"[":hu.lastIndex=pn,f?(p=Hf(new mu,"]"),p.name=f):p=Hf(e.conditions?new mu:[],"]"),e.conditions?(ym(e,u),e.conditions.push(p),s=null):e.push(p),ha[pn]===","?r.lastIndex=++pn:o=!0;break;case")":case"]":case"}":if(t===d[0]){if(e.conditions){if(s){let h={comparator:i||"equals",attribute:s,value:l(f)};i==="eq"&&OL(h,f),ym(e,u),e.conditions.push(h)}else if(f)throw new SyntaxError("no attribute or comparison specified")}else(f||e.length>0&&c)&&e.push(kf(f));return e}else throw t?new SyntaxError(`expected '${t}', but encountered '${d[0]}'`):new SyntaxError(`unexpected token '${d[0]}'`);default:throw new SyntaxError(`unexpected operator '${d}'`)}if(t!==")"&&(r=s?s3:hu,r.lastIndex=pn),pn===ha.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function ym(e,t){if(e.conditions.length>0)if(e.operator){if(e.operator!==t)throw new SyntaxError("Can not mix operators within a condition grouping")}else e.operator=t}function kf(e){return e.indexOf(".")>-1?e.split(".").map(kf):decodeURIComponent(e)}function bL(e){if(e==="null")return null;if(e.indexOf(":")>-1){let[t,r]=e.split(":");if(t==="number")return r[0]==="$"?parseInt(r.slice(1),36):+r;if(t==="boolean")return r==="true";if(t==="date")return new Date(isNaN(r)?decodeURIComponent(r):+r);if(t==="string")return decodeURIComponent(r);throw new hn.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function OL(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new hn.ClientError("wildcard can only be used at the end of a string")}function NL(e){let t=wL(e[0]);return e.length>1&&(t.next=NL(e.slice(1))),t}function wL(e){if(Array.isArray(e)){let t=wL(e[0]);return e[0]=t.attribute,t.attribute=e,t}if(typeof e=="string")switch(e[0]){case"-":return{attribute:e.slice(1),descending:!0};case"+":return{attribute:e.slice(1),descending:!1};default:return{attribute:e,descending:!1}}throw new SyntaxError(`Unknown sort type ${e}`)}function gu(e){return Array.isArray(e)?e.join("\0"):e}function so(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function i3(e,t,r){return t*r/so(e)}var hn,Es,yi,pa,Q4,X4,Z4,e3,pR,mR,n3,hu,s3,pn,ha,mu,Cc,Gf=be(()=>{hn=M(pe()),Es=M(xt()),yi=require("ordered-binary"),pa=require("lmdb");qf();Q4=.3,X4=.1,Z4=.05,e3={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},pR={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(hR,"executeConditions");a(Eu,"searchByIndex");a(bi,"findAttribute");a(t3,"joinTo");a(r3,"joinFrom");mR={eq:"equals",greater_than:"gt",greaterThan:"gt",greater_than_equal:"ge",greaterThanEqual:"ge",less_than:"lt",lessThan:"lt",less_than_equal:"le",lessThanEqual:"le",not_equal:"ne",notEqual:"ne",equal:"equals",sw:"starts_with",startsWith:"starts_with",ew:"ends_with",endsWith:"ends_with",ct:"contains",">":"gt",">=":"ge","<":"lt","<=":"le","...":"between"};a(Ff,"filterByType");a(bm,"estimateCondition");n3=/[()[\]|!<>.]|(=\w*=)/,hu=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,s3=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(Om,"parseQuery");a(Hf,"parseBlock");a(ym,"assignOperator");a(kf,"decodeProperty");a(bL,"typedDecoding");a(OL,"wildcardDecoding");a(NL,"toSortObject");a(wL,"toSortEntry");mu=class{static{a(this,"Query")}constructor(){this.conditions=[]}[Symbol.iterator](){return this.conditions[Symbol.iterator]()}get(t){for(let r=0;r<this.conditions.length;r++){let n=this.conditions[r];if(n.attribute===t)return n.value}}};a(gu,"flattenKey");a(so,"estimatedEntryCount");a(i3,"intersectionEstimate");Cc=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});var gR={};ve(gR,{MultiPartId:()=>wm,Resource:()=>$r,snake_case:()=>a3,transformForSelect:()=>Im});function a3(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function IL(e,t){if(Pc=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(Pc=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new wm;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Pc=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return Pc=!0,null;e[e.length-1]==="/"&&(Pc=!0)}return t.coerceId(decodeURIComponent(e))}function Hn(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,l,u,f;if(r?(o?(f=i,o=o.getContext?.()||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(f=s,c=f[this.primaryKey]??null,o=i.getContext?.()||i):f=i:(f=s,s=void 0,c=f.getId?.()??f[this.primaryKey]),c===null&&(u=!0)):i?o=i.getContext?.()||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="object"&&s){if(l=s,typeof(c=s.url)=="string")if(this.directURLMapping)c=c.slice(1);else{let _=c.indexOf("?");if(_>-1){let S=this.parseQuery(c.slice(_+1));l?S&&(l=Object.assign(S,l)):l=S,c=c.slice(0,_)}let h=this.parsePath(c,o,l);h?.id!==void 0?(h.query&&(l?l=Object.assign(h.query,l):l=h.query),u=h.isCollection,c=h.id):c=h}else if(s[Symbol.iterator]){c=[],u=!0;for(let _ of s){if(typeof _=="object"&&_)break;c.push(_)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=null,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new Cc(c),c==null&&(u=!0);o||(o={});let d;if(l?.ensureLoaded!=null||l?.async||u?(d={...t},l?.ensureLoaded!=null&&(d.ensureLoaded=l.ensureLoaded),l?.async&&(d.async=l.async),u&&(d.isCollection=!0)):d=t,o.transaction){let _=this.getResource(c,o,d);return _.then?_.then(p):p(_)}else return wt(o,()=>{let _=this.getResource(c,o,d);return _.then?_.then(p):p(_)},d);function p(_){if(o.authorize){o.authorize=!1;let h=t.type==="read"?_.allowRead(o.user,l,o):t.type==="update"?_.doesExist?.()===!1?_.allowCreate(o.user,f,o):_.allowUpdate(o.user,f,o):t.type==="create"?_.allowCreate(o.user,f,o):_.allowDelete(o.user,l,o);if(h?.then)return h.then(S=>{if(!S)throw new Nm(o.user);return typeof f?.then=="function"?f.then(g=>e(_,l,o,g)):e(_,l,o,f)});if(!h)throw new Nm(o.user)}return typeof f?.then=="function"?f.then(h=>e(_,l,o,h)):e(_,l,o,f)}a(p,"authorizeActionOnResource")}}function kn(e,t){let r=new DL.ClientError(`The ${e.constructor.name} does not have a ${t} method implemented`,405);r.allow=[],r.method=t;for(let n of["get","put","post","delete","query","move","copy"])typeof e[n]=="function"&&r.allow.push(n);throw r}function ER(e,t,r){let n=e.getRecord?.();if(n){let s=e.getChanges?.();return i=>{let o,c;return e.hasOwnProperty(i)&&typeof(o=e[i])!="function"?o:s&&i in s?s[i]:(c=t?.[i])?c(e,r):n[i]}}else return t?s=>{let i=t[s];return i?i(e,r):e[s]}:s=>e[s]}function Im(e,t){let r=t.propertyResolvers,n=t.getContext?.(),s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):ER(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(c);let u=[],f=i(ER(l,r,n));for(let d of e)u.push(f(d));return u},"transform");let o=e.forceNulls;return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(p=>p&&typeof p=="object"?c(p):p);let u={},f=i(ER(l,r,n)),d;for(let p of e){let _=f(p);_===void 0&&o&&(_=null),_?.then?(d||(d=[]),d.push(_.then(h=>u[p.name||p]=h))):u[p.name||p]=_}return d?Promise.all(d).then(()=>u):u},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(o){return c=>{if(typeof c=="string")return o(c);if(typeof c=="object")if(c.name){s||(s={});let l=s[c.name];if(!l){let f=r[c.name]?.definition?.tableClass;l=s[c.name]=Im(c.select||c,f)}let u=o(c.name);return l(u)}else return o(c);else return c}}a(i,"handleProperty")}var CL,PL,DL,o3,$r,Nm,Pc,wm,Ea=be(()=>{CL=require("crypto");pu();PL=M(Ti()),DL=M(pe());Ic();Gf();o3={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},$r=class{static{a(this,"Resource")}#e;#t;#n;static transactions;static directURLMapping=!1;constructor(t,r){this.#e=t;let n=r?.getContext?r.getContext()??null:void 0;this.#t=n!==void 0?n:r||null}static get=Hn(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let l;if((l=r?.select)&&c!=null&&!c.selectApplied){let u=Im(l,t.constructor);return typeof c?.map=="function"?c.map(u):u(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=Hn(function(t,r,n,s){if(Array.isArray(s)&&t.#n){let i=[],o=n.authorize;for(let c of s){let l=t.constructor,u=l.getResource(c[l.primaryKey],n,{async:!0});u.then?i.push(u.then(f=>f.put(c,n))):i.push(u.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):kn(t,"put")},{hasContent:!0,type:"update"});static patch=Hn(function(t,r,n,s){return t.patch?t.patch(s,r):kn(t,"patch")},{hasContent:!0,type:"update"});static delete=Hn(function(t,r,n,s){return t.delete?t.delete(r):kn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,CL.randomUUID)()}static create(t,r,n){let s;return t==null?s=r?.[this.primaryKey]??this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=r?.[this.primaryKey]??[...t,this.getNewId()]:typeof t!="object"?s=r?.[this.primaryKey]??[t,this.getNewId()]:(s=t?.[this.primaryKey]??this.getNewId(),n=r||{},r=t),n||(n={}),wt(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):kn(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=Hn(function(t,r,n,s){return t.invalidate?t.invalidate(r):kn(t,"delete")},{hasContent:!1,type:"update"});static post=Hn(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=Hn(function(t,r,n,s){return t.connect?t.connect(s,r):kn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=Hn(function(t,r,n,s){return t.subscribe?t.subscribe(r):kn(t,"subscribe")},{type:"read"});static publish=Hn(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.publish?t.publish(s,r):kn(t,"publish")},{hasContent:!0,type:"create"});static search=Hn(function(t,r,n,s){let i=t.search?t.search(r):kn(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=Im(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=Hn(function(t,r,n,s){return t.search?t.search(s,r):kn(t,"search")},{hasContent:!0,type:"read"});static copy=Hn(function(t,r,n,s){return t.copy?t.copy(s,r):kn(t,"copy")},{hasContent:!0,type:"create"});static move=Hn(function(t,r,n,s){return t.move?t.move(s,r):kn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this.#n)return(await this.constructor.create(this.#e,t,this.#t)).#e;kn(this,"post")}static isCollection(t){return t&&t.#n}get isCollection(){return this.#n}static coerceId(t){return t}static parseQuery(t){return Om(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1),c=r?.headers&&o3[o];if(c)r.requestedContentType=c,t=t.slice(0,s);else if(this.attributes?.find(l=>l.name===o))if(t=t.slice(0,s),n)n.property=o;else return{query:{property:o},id:IL(t,this),isCollection:Pc}}let i=IL(t,this);return Pc?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r.getContext?.(),o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let u=l.asMap.get(t);if(s=u?.find(f=>f.constructor===c),s)return s;u||l.asMap.set(t,u=[]),u.push(s=new c(t,i))}else{if(s=l.find(u=>u.#e===t&&u.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let u=new Map;for(let f of l){let d=f.#e,p=u.get(d);p?p.push(f):u.set(d,[f])}i.resourceCache.length=0,i.resourceCache.asMap=u}}}else s=new c(t,i);return o&&(s.#n=!0),s}subscribe(t){return new Bn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new Bn}allowRead(t){return t?.role.permission.super_user}allowUpdate(t){return t?.role.permission.super_user}allowCreate(t){return t?.role.permission.super_user}allowDelete(t){return t?.role.permission.super_user}getId(){return this.#e}getContext(){return this.#t}};(0,PL._assignPackageExport)("Resource",$r);a(a3,"snake_case");Nm=class extends Error{static{a(this,"AccessError")}constructor(t){t?(super("Unauthorized access to resource"),this.statusCode=403):(super("Must login"),this.statusCode=401)}};a(IL,"pathToId");wm=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(Hn,"transactional");a(kn,"missingMethod");a(ER,"selectFromObject");a(Im,"transformForSelect")});var ga,SR=be(()=>{ga=class{constructor(t){this.error=t}static{a(this,"ErrorResource")}isError=!0;allowRead(){throw this.error}allowUpdate(){throw this.error}allowCreate(){throw this.error}allowDelete(){throw this.error}getId(){throw this.error}getContext(){throw this.error}get(){throw this.error}post(){throw this.error}put(){throw this.error}delete(){throw this.error}connect(){throw this.error}getResource(){return this}publish(){throw this.error}subscribe(){throw this.error}}});var vL={};ve(vL,{Resources:()=>Cm,keyArrayToString:()=>Su,resetResources:()=>c3,resources:()=>Oi});function c3(){return Oi=new Cm}function Su(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var LL,ML,Cm,Oi,Tu=be(()=>{Ic();SR();LL=M(z()),ML=M(pe()),Cm=class extends Map{static{a(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,exportTypes:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s){let c=new ML.ServerError(`Conflicting paths for ${t}`);LL.default.error(c),i.Resource=new ga(c)}super.set(t,i);for(let[c,l]of this){let u=2;for(;(u=c.indexOf("/",u))>-1;){let f=this.get(c.slice(0,u));f&&(f.hasSubPaths=!0),u+=2}}}getMatch(t,r){let n=2,s=0,i,o=t.length;for(;n<o;){s=n,n=t.indexOf("/",n),n===-1&&(n=o);let u=n===o?t:t.slice(0,n),f=this.get(u),d=-1;if(!f&&n===o&&(d=u.indexOf("?",s),d!==-1)){let p=u.slice(0,d);f=this.get(p)}if(f&&(!r||f.exportTypes?.[r]!==!1)){if(f.relativeURL=t.slice(d!==-1?d:n),!f.hasSubPaths)return f;i=f}n+=2}if(i)return i;let c=t.indexOf("?"),l=c>-1?t.slice(0,c):t;return i=this.get(l),!i&&l.indexOf(".")>-1&&(i=this.get(l.split(".")[0])),i&&(!r||i.exportTypes?.[r]!==!1)?i.relativeURL=c>-1?t.slice(c):"":i||(i=this.get(""),i&&(!r||i.exportTypes?.[r]!==!1)&&(t.charAt(0)!=="/"&&(t="/"+t),i.relativeURL=t)),i}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return wt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(c3,"resetResources");a(Su,"keyArrayToString")});var Au={};ve(Au,{server:()=>We});var UL,We,Vr=be(()=>{UL=M(Ti()),We={};(0,UL._assignPackageExport)("server",We)});var RR={};ve(RR,{loadGQLSchema:()=>d3,start:()=>AR,startOnMainThread:()=>u3});function AR({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:u,StringValueNode:f}=await import("graphql"),d=o(new c(r.toString(),s)),p=new Map,_=[],h;for(let R of d.definitions)switch(R.kind){case l.OBJECT_TYPE_DEFINITION:let F=function(Y){if(Y.kind==="NonNullType"){let Q=F(Y.type);return Q.nullable=!1,Q}if(Y.kind==="ListType")return{type:"array",elements:F(Y.type)};let se={type:Y.name?.value};return Object.defineProperty(se,"location",{value:Y.loc.startToken}),se};a(F,"getProperty");let E=R.name.value,T=[],b={table:null,database:null,properties:T};p.set(E,b);for(let Y of R.directives){if(Y.name.value==="table"){for(let se of Y.arguments)b[se.name.value]=se.value.value;b.schema&&(b.database=b.schema),b.table||(b.table=E),b.audit&&(b.audit=b.audit!=="false"),b.attributes=b.properties,_.push(b)}if(Y.name.value==="sealed"&&(b.sealed=!0),Y.name.value==="splitSegments"&&(b.splitSegments=!0),Y.name.value==="replicate"&&(b.replicate=!0),Y.name.value==="export"){b.export=!0;for(let se of Y.arguments)typeof b.export!="object"&&(b.export={}),b.export[se.name.value]=se.value.value}}let v=!1,q={};for(let Y of R.fields){let Z=F(Y.type);Z.name=Y.name.value,T.push(Z),q[Z.name]=void 0;for(let se of Y.directives){let Q=se.name.value;if(Q==="primaryKey")v?console.warn("Can not define two attributes as a primary key at",se.loc):(Z.isPrimaryKey=!0,v=!0);else if(Q==="indexed")Z.indexed=!0;else if(Q==="computed"){for(let ne of se.arguments||[])if(ne.name.value==="from"){let J=ne.value.value;Z.computed={from:g(J,ne,q)},Z.version==null&&(Z.version=J)}else ne.name.value==="version"&&(Z.version=ne.value.value);Z.computed=Z.computed||!0}else if(Q==="relationship"){let ne={};for(let J of se.arguments)ne[J.name.value]=J.value.value;Z.relationship=ne}else if(Q==="createdTime")Z.assignCreatedTime=!0;else if(Q==="updatedTime")Z.assignUpdatedTime=!0;else if(Q==="expiresAt")Z.expiresAt=!0;else if(Q==="allow"){let ne=Z.authorizedRoles=[];for(let J of se.arguments)J.name.value==="role"&&ne.push(J.value.value)}else server.knownGraphQLDirectives.includes(Q)&&console.warn(`@${Q} is an unknown directive, at`,se.loc)}}b.type=E,E==="Query"&&(h=b)}function S(R){let E=p.get(R.type);E?(Object.defineProperty(R,"properties",{value:E.properties}),Object.defineProperty(R,"definition",{value:E})):R.type==="array"?S(R.elements):l3.includes(R.type)||(0,BL.getWorkerIndex)()===0&&console.error(`The type ${R.type} is unknown at line ${R.location.line}, column ${R.location.column}, in ${s}`)}a(S,"connectPropertyType");for(let R of p.values())for(let E of R.properties)S(E);for(let R of _)R.tableClass=e(R),R.export&&(R.export.name===""?i.set((0,TR.dirname)(n),R.tableClass):i.set((0,TR.dirname)(n)+"/"+(R.export.name||R.type),R.tableClass,R.export));function g(R,E,T){return new xL.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${R}; } } } } computed;`,{filename:s,lineOffset:E.loc.startToken.line-1,columnOffset:E.loc.startToken.column}).runInThisContext()(T)}a(g,"createComputedFrom")}}var TR,xL,BL,l3,u3,d3,HL=be(()=>{TR=require("path"),xL=require("node:vm");De();BL=M(rt()),l3=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt","Blob"];server.knownGraphQLDirectives&&(server.knownGraphQLDirectives=["table","sealed","export","primaryKey","indexed","computed","relationship","createdTime","updatedTime","expiresAt","allow"]);a(AR,"start");u3=AR,d3=AR({ensureTable:ft}).handleFile});var KL={};ve(KL,{parse:()=>bR,streamAsJSON:()=>$f,stringify:()=>Dc});function $f(e){return new yR({value:e})}function kL(e){return console.error(e),JSON.stringify(e.toString())}function FL(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Dc(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===$L)return VL(e);if(t.resolution)return t.resolution.then(()=>Dc(e));throw t}}function VL(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+=VL(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Dc(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function bR(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),p3.test(e)?f3.parse(e):JSON.parse(e)):null}var GL,qL,f3,_3,$L,yR,p3,OR=be(()=>{GL=require("stream"),qL=M(require("json-bigint-fixes")),f3=(0,qL.default)({useNativeBigInt:!0}),_3=1e4,$L={message:"Cannot serialize BigInt to JSON"};BigInt.prototype.toJSON=function(){throw $L};a($f,"streamAsJSON");yR=class extends GL.Readable{static{a(this,"JSONStream")}constructor(t){super(t),this.buffer=[],this.bufferSize=0,this.iterator=this.serialize(t.value,!0),this.activeIterators=[]}*serialize(t){if(t&&typeof t=="object"){let r=t[Symbol.asyncIterator],n=t[Symbol.iterator];if((n||r)&&!t.then){yield"[";let s=!0;if((r||n)&&!(t instanceof Array)){let i=r?t[Symbol.asyncIterator]():t[Symbol.iterator]();this.activeIterators.push(i);let o;for(;;){try{o=i.next(),o.then&&(yield o.then(c=>(o=c,""),c=>(o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")},"")))}catch(c){o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")}}if(o.done){this.activeIterators.splice(this.activeIterators.indexOf(i),1),yield"]";return}else s?s=!1:yield",",yield*this.serialize(o.value)}}for(let i of t)s?s=!1:yield",",yield*this.serialize(i);yield"]";return}if(t.then)try{yield t.then(s=>this.serialize(s),kL)}catch(s){yield kL(s)}else yield Dc(t)}else yield Dc(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);FL(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>_3?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 FL(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(kL,"handleError");a(FL,"when");a(Dc,"stringify");a(VL,"jsStringify");p3=/[[,:]\s*-?\d{16,}/;a(bR,"parse")});var Ni=w(Dm=>{var Pm=z();for(let e of["trace","debug","info","warn","error","fatal","notify"])Pm.logsAtLevel(e)&&(Dm[e]=Pm[e]);Dm.loggerWithTag=e=>Pm.loggerWithTag(e,!0);Dm.setLogLevel=Pm.setLogLevel});var Gm={};ve(Gm,{Blob:()=>wi,blobsWereEncoded:()=>Mc,databasePaths:()=>vm,decodeBlobsWithWrites:()=>CR,decodeFromDatabase:()=>vc,decodeWithBlobCallback:()=>PR,deleteBlob:()=>eM,deleteBlobsInObject:()=>Ta,deleteRootBlobPathsForDB:()=>IR,encodeBlobsAsBuffers:()=>b3,encodeBlobsWithFilePath:()=>Fm,findBlobsInObject:()=>yu,getFileId:()=>Hm,getFilePathForBlob:()=>rM,getRootBlobPathsForDB:()=>km,setDeletionDelay:()=>g3});function XL(){}function eM(e){let t=rM(e);t&&setTimeout(()=>{(0,Je.unlink)(t,r=>{r&&Sa.default.debug?.("Error trying to remove blob file",r)})},ZL)}function g3(e){ZL=e}function tM(e){let t=En.get(e);if(!t)t={storageIndex:0,fileId:null,store:js},En.set(e,t);else{if(t.saving)return t;t.store=js}return T3(t),t.source?NR(e,t.source,t):t.contentBuffer?S3(e,t):NR(e,Kf.Readable.from(e.stream()),t),t}function NR(e,t,r){let{filePath:n,fileId:s,store:i,compress:o,flush:c}=r;return r.saving=new Promise((l,u)=>{let f=s+":blob";if(!i.attemptLock(f,0))throw new Error(`Unable to get lock for blob file ${s}`);let d=(0,Je.createWriteStream)(n,{autoClose:!1,flags:"w"});if(t.errored){let g=Buffer.from(t.errored.toString());d.end(Buffer.concat([h(BigInt(g.length)+0xff000000000000n),g]));return}let p=!1;e.size!==void 0&&(d.write(h(e.size)),p=!0);let _;o?(p||d.write(m3),_=(0,xm.createDeflate)(),t.pipe(_).pipe(d)):(p||d.write(h3),t.pipe(d)),t.on("error",S);function h(g){let R=BigInt(g),E=new Uint8Array(gr),T=new DataView(E.buffer);return R|=BigInt(o?wR:QL)<<48n,T.setBigInt64(0,R),E}a(h,"createHeader");function S(g){i.unlock(f,0);let R=d.fd;g?(R&&(0,Je.close)(R),u(g)):c?(0,Je.fdatasync)(R,E=>{E&&u(E),l(),(0,Je.close)(R)}):(l(),(0,Je.close)(R))}a(S,"finished"),d.on("error",S).on("finish",()=>{if(p)S();else{let g=_?_.bytesWritten:d.bytesWritten-gr;e.size=g,(0,Je.write)(d.fd,h(g),0,gr,0,S)}})}),e}function Hm(e){return En.get(e)?.fileId}function rM(e){let t=En.get(e);return t?.fileId&&Yf(t)}function km(e){if(!e)throw new Error("No store specified, can not determine blob storage path");let t=vm.get(e);if(!t){if(!e.databaseName)throw new Error("No database name specified, can not determine blob storage path");let r=(0,Bm.get)(x.STORAGE_BLOBPATHS);r?t=r.map(n=>(0,oo.join)(n,e.databaseName)):t=[(0,oo.join)((0,Bm.getHdbBasePath)(),"blobs",e.databaseName)],vm.set(e,t)}return t}async function IR(e){let t=vm.get(e);t&&await Promise.all(t.map(r=>nM(r)))}async function nM(e){for(let t of await(0,Js.readdir)(e,{withFileTypes:!0}))if(t.isDirectory())await nM((0,oo.join)(e,t.name));else try{await(0,Js.unlink)((0,oo.join)(e,t.name))}catch(r){Sa.default.warn?.("Error deleting file",r)}try{await(0,Js.rmdir)(e)}catch(t){Sa.default.warn?.("Error deleting directory",t)}}function Yf({storageIndex:e,fileId:t,store:r}){let n=km(r);return(0,oo.join)(n[e],t.slice(-9,-6)||"0",t.slice(-6,-3)||"0",t.length<=9?t.slice(-3):t.slice(0,-9)+t.slice(-3))}function S3(e,t){let r=t.contentBuffer,n=r.length;if(!(n<JL))return e.size=n,NR(e,Kf.Readable.from([r]),t)}function T3(e){let t=km(e.store),r=A3(),n=t?.length>1?R3(t,r):0,s=r.toString(16);e.storageIndex=n,e.fileId=s;let i=Yf(e),o=(0,oo.dirname)(i);(0,Je.existsSync)(o)||(0,jL.ensureDirSync)(o),e.filePath=i}function A3(){let e=zL.get(js);if(!e){let t=0,r=km(js);for(let n of r){let s=0;for(let i=0;i<3;i++){s=s*4096;let o=0;if((0,Je.existsSync)(n))for(let c of(0,Je.readdirSync)(n)){let l=parseInt(c,16);i===2&&c.length>3&&(l=parseInt(c.slice(-3),16),l+=parseInt(c.slice(0,-3),16)*68719476736),l>o&&(o=l)}s+=o,n=(0,oo.join)(n,o.toString(16))}t=Math.max(t,s)}e=new BigInt64Array([BigInt(t)+1n]),e=new BigInt64Array(js.getUserSharedBuffer("blob-file-id",e.buffer)),zL.set(js,e)}return Number(Atomics.add(e,0,1n))}function R3(e,t){let r=Date.now();if(!e.frequencyTable){e.lastUpdated=0;let s=new Array(Um);for(let i=0;i<s.length;i++)s[i]=i%e.length;e.frequencyTable=s}return(e.lastUpdated??0)+6e4<r&&(e.lastUpdated=r,y3(e)),e.frequencyTable[t%Um]}async function y3(e){if(!Js.statfs)return;let t=await Promise.all(e.map(async(s,i)=>{let o=await(0,Js.statfs)(s),c=o.bavail*o.bsize;return Math.pow(c,.8)})),r=new Array(Um),n=t.map(s=>1/s);for(let s=0;s<Um;s++){let i=1/0,o=0;for(let c=0;c<n.length;c++)n[c]<i&&(o=c,i=n[c]);n[o]+=1/t[o],r[s]=o}e.frequencyTable=r}function Fm(e,t,r){Ru=t,js=r,Mc=!1;try{return e()}finally{Ru=void 0,js=void 0}}function b3(e){Dr=[];let t;try{t=e()}catch(n){throw Dr=void 0,n}let r=Dr.length<2?Dr[0]:Promise.all(Dr);return Dr=void 0,r?r.then(()=>e()):t}function CR(e,t){try{Dr=[],Lc=t,e()}catch(n){throw Lc=void 0,Dr=void 0,n}Lc=void 0;let r=Dr.length<2?Dr[0]:Promise.all(Dr);return Dr=void 0,r}function PR(e,t){try{return Lc=t,e()}finally{Lc=void 0}}function vc(e,t){return js=t,e()}function Ta(e){yu(e,t=>{eM(t)})}function yu(e,t){if(e instanceof wi)t(e);else if(Array.isArray(e))for(let r of e)typeof r=="object"&&r&&yu(r,t);else if(e.constructor===Object)for(let r in e){let n=e[r];typeof n=="object"&&n&&yu(e[r],t)}}function O3(){return class{static{a(this,"Blob")}content;constructor(t){this.content=t[0]}stream(){return new ReadableStream({start(t){t.enqueue(this.content),t.close()}})}text(){return Promise.resolve(this.content.toString())}arrayBuffer(){return Promise.resolve(this.content.buffer)}get size(){return this.content.length}slice(){throw new Error("Not implemented")}bytes(){return Promise.resolve(this.content)}get type(){return""}}}var io,Js,Je,xm,Kf,jL,Bm,oo,Sa,JL,gr,QL,wR,YL,h3,m3,WL,En,Lc,wi,Ru,Dr,js,Mc,Vf,Lm,E3,Mm,ZL,vm,zL,Um,gs=be(()=>{io=require("msgpackr"),Js=require("node:fs/promises"),Je=require("node:fs"),xm=require("node:zlib"),Kf=require("node:stream"),jL=require("fs-extra"),Bm=M(ae());H();oo=require("path"),Sa=M(Ni());ao();JL=8192,gr=8,QL=0,wR=1,YL=255,h3=new Uint8Array([0,QL,255,255,255,255,255,255]),m3=new Uint8Array([0,wR,255,255,255,255,255,255]),WL=0xffffffffffff,En=new WeakMap,wi=global.Blob||O3(),Mc=!1,Vf=new Uint8Array(8),Lm=new DataView(Vf.buffer),E3=6e4;a(XL,"InstanceOfBlobWithNoConstructor");XL.prototype=wi.prototype;Mm=class e extends XL{static{a(this,"FileBackedBlob")}type="";size;#e;#t;constructor(t){super(),t?.type&&(this.type=t.type),t?.size!=null&&(this.size=t.size)}on(t,r){if(t==="error")this.#e??=[],this.#e.push(r);else if(t==="size")this.#t??=[],this.#t.push(r);else throw new Error("Only 'error' and 'size' events are supported")}toJSON(){if(this.type?.startsWith("text")){let t=En.get(this),{start:r,end:n,contentBuffer:s,asString:i}=t;return i||(s&&(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),s?(t.asString=s.toString(),t.asString):(LR()&&DR(this.bytes().then(o=>t.contentBuffer=o)),`[blob: ${this.type}, ${this.size} bytes]`))}return{description:"Blobs that are not of type text/* can not be directly serialized as JSON, use as the body of a response or convert to another type"}}async text(){return(await this.bytes()).toString()}bytes(){let t=En.get(this),{start:r,end:n,contentBuffer:s}=t;if(s)return(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),Promise.resolve(s);let i=Yf(t),o,c=a(async()=>{let l,u=gr;try{if(l=await(0,Js.readFile)(i),l.length>=gr){l.copy(Vf,0,0,gr);let d=Lm.getBigUint64(0);if(Number(d>>48n)===YL)throw new Error("Error in blob: "+buffer.subarray(gr));if(u=Number(d&0xffffffffffffn),u<n&&(u=n),u<WL&&(this.size=u,this.#t))for(let p of this.#t)p(u)}}catch(d){if(d.code!=="ENOENT")throw d;l=Buffer.alloc(0)}function f(d){if(u>d.length){let p=t.store,_=t.fileId+":blob";if(o)throw new Error("Incomplete blob");return new Promise((h,S)=>{if(p.attemptLock(_,0,()=>(o=!0,p.unlock(_,0),h(c()))))return o=!0,p.unlock(_,0),h(c())})}return(n!=null||r!=null)&&(d=d.subarray(r??0,n??d.length)),d}return a(f,"checkCompletion"),l[1]===wR?new Promise((d,p)=>{(0,xm.deflate)(l.subarray(gr),(_,h)=>{_?p(_):d(f(h))})}):f(l.subarray(gr))},"readContents");return c()}async arrayBuffer(){let t=await this.bytes(),r=new ArrayBuffer(t.length);return new Uint8Array(r).set(t),r}stream(){let t=En.get(this),{contentBuffer:r,start:n,end:s}=t;if(r)return(s!=null||n!=null)&&(r=r.subarray(n??0,s??t.contentBuffer.length)),new ReadableStream({pull(S){S.enqueue(r),S.close()}});let i=Yf(t),o,c=0,l=0,u,f,d,p=!1,_=this;return new ReadableStream({start(){let S=1e3,g=a((R,E)=>{(0,Je.open)(i,"r",(T,b)=>{if(T){if(T.code==="ENOENT"&&d!==!1&&(Sa.default.debug?.("File does not exist yet, waiting for it to be created",i,S),S-- >0))return setTimeout(()=>{h(),g(R,E)},20).unref();E(T),_.#e?.forEach(v=>v(T))}else o=b,R(b)})},"openFile");return new Promise(g)},pull:a(S=>{let g=0,R=100;return new Promise(a(function E(T,b){function v(q){(0,Je.close)(o),clearTimeout(f),u&&u.close(),b(q),_.#e?.forEach(Y=>Y(q))}a(v,"onError");let F=Buffer.allocUnsafe(262144);(0,Je.read)(o,F,0,F.length,c,(q,Y,Z)=>{if(l+=Y,q)return v(q);if(c===0){if(Y<gr){R-- >0&&d!==!1?(h(),Sa.default.debug?.("File was empty, waiting for data to be written",i,R),setTimeout(()=>E(T,b),20).unref()):(Sa.default.debug?.("File was empty, throwing error",i,R),b(new Error(`Blob ${t.fileId} was empty`)));return}Z.copy(Vf,0,0,gr);let se=Lm.getBigUint64(0);if(Number(se>>48n)===YL)return v(new Error("Error in blob: "+Z.subarray(gr)));if(g=Number(se&0xffffffffffffn),g<WL&&_.size!==g&&(_.size=g,_.#t))for(let Q of _.#t)Q(g);Z=Z.subarray(gr,Y),l-=gr}else if(Y===0){let se=Buffer.allocUnsafe(8);return(0,Je.read)(o,se,0,gr,0,Q=>{if(Q)return v(Q);if(Vf.set(se),g=Number(Lm.getBigUint64(0)&0xffffffffffffn),g>l){h()?u?f=setTimeout(()=>{v(new Error("File read timed out"))},E3).unref():(u=(0,Je.watch)(i,{persistent:!1},()=>{u.close(),u=null,f&&(clearTimeout(f),f=null,E(T,b))}),E(T,b)):p?v(new Error("Blob is incomplete")):(p=!0,E(T,b));return}(0,Je.close)(o),S.close(),T()})}else Z=Z.subarray(0,Y);if(n!==void 0||s!==void 0){if(n&&l<n)return c+=Y,E(T,b);s&&l>=s&&(l>s&&(Z=Z.subarray(0,s-c)),l=g=s),n&&n>c&&(Z=Z.subarray(n-c))}c+=Y;try{S.enqueue(Z)}catch(se){return Sa.default.debug?.("Error enqueuing chunk",se),T()}l===g&&((0,Je.close)(o),S.close()),T()})},"readMore"))},"pull"),cancel(){(0,Je.close)(o),clearTimeout(f),u&&u.close()}});function h(){if(d===void 0){let S=t.store,g=t.fileId+":blob";d=!S.attemptLock(g,0,()=>{d=!1,S.unlock(g,0)}),d||S.unlock(g,0)}return d}}slice(t,r,n){let s=En.get(this),i=new e(n&&{type:n});if(s?.fileId){let o={...s,start:t,end:r};En.set(i,o),this.size!=null&&(i.size=(r==null?this.size:Math.min(r,this.size))-(t??0))}else if(s?.contentBuffer&&!s.storageBuffer){let o={...s,contentBuffer:s.contentBuffer.subarray(t,r)};En.set(i,o),i.size=(r??this.size)-t}else throw new Error("Can not slice a streaming blob that is not backed by a file");return i}save(t){if(!t?.primaryStore?.rootStore)throw new Error("No target table specified");return tM(this).saving??Promise.resolve()}},ZL=500;a(eM,"deleteBlob");a(g3,"setDeletionDelay");global.createBlob=function(e,t){let r=new Mm(t),n={storageIndex:0,fileId:null,flush:t?.flush,compress:t?.compress};if(En.set(r,n),e instanceof Uint8Array)r.size=e.length,n.contentBuffer=e;else if(e instanceof Kf.Readable)n.source=e;else if(typeof e=="string")n.contentBuffer=Buffer.from(e);else if(e?.[Symbol.asyncIterator]||e?.[Symbol.iterator])n.source=Kf.Readable.from(e);else throw new Error("Invalid source type");return r};a(tM,"saveBlob");a(NR,"writeBlobWithStream");a(Hm,"getFileId");a(rM,"getFilePathForBlob");vm=new Map;a(km,"getRootBlobPathsForDB");a(IR,"deleteRootBlobPathsForDB");a(nM,"rimrafSteadily");a(Yf,"getFilePath");a(S3,"writeBlobWithBuffer");a(T3,"generateFilePath");zL=new Map;a(A3,"getNextFileId");Um=128;a(R3,"getNextStorageIndex");a(y3,"createFrequencyTableForStoragePaths");a(Fm,"encodeBlobsWithFilePath");a(b3,"encodeBlobsAsBuffers");a(CR,"decodeBlobsWithWrites");a(PR,"decodeWithBlobCallback");a(vc,"decodeFromDatabase");a(Ta,"deleteBlobsInObject");a(yu,"findBlobsInObject");(0,io.addExtension)({Class:wi,type:11,unpack:a(function(e){let t=(0,io.unpack)(e),r=new Mm;if(Object.assign(r,t[0]),typeof t[1]!="object"){if(!js)throw new Error("No store specified, can not load blob from storage");if(En.set(r,{storageIndex:t[1],fileId:t[2],store:js}),Lc)return Lc(r)??r}else En.set(r,{storageIndex:0,fileId:null,storageBuffer:e,contentBuffer:t[1]}),r.size=t[1]?.length;return r},"unpack"),pack:a(function(e){let t=En.get(e);if(Ru!==void 0&&(Mc=!0,t?.recordId!==void 0&&t.recordId!==Ru))throw new Error("Cannot use the same blob in two different records");let r={...e};if(e.type&&(r.type=e.type),e.size!==void 0&&(r.size=e.size),t){if(t.storageBuffer)return t.storageBuffer;if(t.contentBuffer?.length<JL)return r.size=t.contentBuffer.length,(0,io.pack)([r,t.contentBuffer])}if(Ru!==void 0){if(t=tM(e),!t.fileId)throw new Error("Unable to save blob without file id");return t.recordId=Ru,(0,io.pack)([r,t.storageIndex,t.fileId])}if(t)try{let n=(0,Je.readFileSync)(Yf(t));if(n.length>=gr&&(n.copy(Vf,0,0,gr),Number(Lm.getBigUint64(0)&0xffffffffffffn)===n.length-gr))return Buffer.concat([(0,io.pack)([r]),n]);if(Dr)Dr.push(e.bytes());else throw new Error("Incomplete blob");return Buffer.alloc(0)}catch(n){if(n.code==="ENOENT"&&Dr)return Dr.push(e.bytes()),Buffer.alloc(0);throw n}else throw new Error("Blob has no storage info or buffer attached to it")},"pack")});(0,io.addExtension)({Class:Promise,type:12,pack(){throw new Error("Cannot encode a promise")}});a(O3,"polyfillBlob")});var dM={};ve(dM,{asyncSerialization:()=>DR,contentTypes:()=>xR,findBestSerializer:()=>$m,getDeserializer:()=>uo,hasAsyncSerialization:()=>LR,registerContentHandlers:()=>jf,serialize:()=>Jf,serializeMessage:()=>Aa,toCsvStream:()=>qm});function w3(e){try{return e?.[0]===123?UR(e):e}catch{return e}}function jf(e){e.register(C3,{serializers:[{regex:/^application\/json$/,serializer:$f},{regex:/^application\/cbor$/,serializer:a(function(t){return new Uc.EncoderStream(zf).end(t)},"serializer")},{regex:/^application\/(x-)?msgpack$/,serializer:a(function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?xc.Readable.from((0,Ii.encodeIter)(t,zf)):(0,Ii.pack)(t)},"serializer")},{regex:/^text\/csv$/,serializer:a(function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),qm(t)},"serializer")}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Ii.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Uc.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function $m(e){let t=e.headers.asObject||e.headers,r=e.requestedContentType??t.accept,n,s=0,i,o,c=r?r.toLowerCase().split(/\s*,\s*/):[];for(let l of c){let[u,...f]=l.split(/\s*;\s*/),d=1,p={q:1};for(let h of f){let S=h.indexOf("=");p[h.substring(0,S)]=h.substring(S+1)}d=+p.q;let _=Kr.get(u);if(_){let h=(_.q||1)*d;h>s&&(n=_,i=_.type||u,s=h,o=p)}}if(!n){if(r)throw new oM.ClientError("No supported content types found in Accept header, supported types include: "+Array.from(Kr.keys()).join(", "),406);n=Kr.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function Jf(e,t,r){let n=iM&&t.headers.asObject?.["accept-encoding"]?.includes("br"),s;if(e?.contentType!=null&&e.data!=null)r.headers.set("Content-Type",e.contentType),r.headers.set("Vary","Accept-Encoding"),s=e.data;else if(e instanceof Uint8Array||e instanceof wi)r.headers.set("Content-Type","application/octet-stream"),r.headers.set("Vary","Accept-Encoding"),s=e;else{let i=$m(t);if(i.serializer.compressible===!1&&(n=!1),r.headers.set("Vary","Accept, Accept-Encoding"),r.headers.set("Content-Type",i.type),typeof e=="object"&&e&&(e[Symbol.iterator]||e[Symbol.asyncIterator])&&i.serializer.serializeStream){if(e.mapError){let c=e.getColumns;e=e.mapError(l=>(l.toJSON=()=>({error:l.name,message:l.message,...l.partialObject}),vR.default.warn?.(`Error serializing error ${t?.url||t}: ${l}`),l)),e.getColumns=c}let o=i.serializer.serializeStream(e,r);return n&&(r.headers.set("Content-Encoding","br"),o=o.pipe((0,lo.createBrotliCompress)({params:{[lo.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?lo.constants.BROTLI_MODE_TEXT:lo.constants.BROTLI_MODE_GENERIC,[lo.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>iM?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,lo.brotliCompress)(s,(c,l)=>{c?o(c):i(l)}))):s}function Aa(e,t,r){if(e?.contentType!=null&&e.data!=null)return e.data;co=r?void 0:[];try{let n;if(t){let s=t.serialize;if(s)n=s(e);else{let i=$m(t);s=t.serialize=i.serializer.serialize,n=s(e)}}else n=Wf(e);return co?.length>0?(co.length===1?co[0]:Promise.all(co)).then(()=>Aa(e,t,!0)):n}finally{co=void 0}}function DR(e){if(co)co.push(e);else throw new Error("Unable to serialize asynchronously")}function LR(){return!!co}function P3(e){return new Promise((t,r)=>{let n=[];e.on("data",s=>n.push(s)),e.on("end",()=>t(Buffer.concat(n))),e.on("error",r)})}function L3(e){return D3.includes(e)}function M3(e){let t=e.indexOf(";"),r;if(t>-1){r={};let n=e.slice(t+1).split(";");for(let s of n){let[i,o]=s.split("=");r[i.trim()]=o.trim()}e=e.slice(0,t)}return{type:e,parameters:r}}function uo(e="",t=!1){let r=M3(e),n=r.type&&Kr.get(r.type)?.deserialize||v3(r);return t?s=>P3(s).then(n):n}function v3(e){return e.type.startsWith("text/")?(e.parameters?.charset&&!L3(e.parameters.charset)&&vR.default.info(`Unknown Buffer encoding ${e.parameters.charset} in content-type. Proceeding anyways.`),t=>({contentType:e.type,data:t.toString(e.parameters?.charset||"utf-8")})):e.type==="application/octet-stream"?t=>t:t=>{if(e.type==="")try{if(t?.[0]===123)return UR(t)}catch{}return{contentType:e.type||"application/octet-stream",data:t}}}function U3(e,t){return{[Symbol.asyncIterator](){let r=e[Symbol.asyncIterator]?e[Symbol.asyncIterator]():e[Symbol.iterator]();return{next(){let n=r.next();return n.then?n.then(s=>({value:t(s.value),done:s.done})):{value:t(n.value),done:n.done}},return(n){return r.return(n)},throw(n){return r.throw(n)}}}}}function qm(e,t){let r=xc.default.Readable.from(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator]?e:[e]),n={};t&&(n.fields=t.map(o=>({label:o,value:o})));let s={objectMode:!0},i=new N3(n,s);return r.pipe(i)}var Ii,Uc,lo,oM,xc,aM,MR,cM,vR,N3,lM,Wf,UR,zf,Kr,xR,sM,uM,I3,C3,iM,co,D3,ao=be(()=>{OR();Ii=require("msgpackr"),Uc=require("cbor-x"),lo=require("zlib"),oM=M(pe()),xc=M(require("stream"));Vr();aM=M(Ti()),MR=M(ae());H();cM=M(require("yaml")),vR=M(Ni());gs();({Transform:N3}=require("json2csv")),lM=MR.default.get(x.SERIALIZATION_BIGINT)!==!1,Wf=lM?Dc:JSON.stringify,UR=lM?bR:JSON.parse,zf={useRecords:!1,useToJSON:!0},Kr=new Map,xR=Kr;We.contentTypes=xR;(0,aM._assignPackageExport)("contentTypes",xR);Kr.set("application/json",{serializeStream:$f,serialize:Wf,deserialize(e){return UR(e)},q:.8});sM=new Uc.Encoder(zf);Kr.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new Uc.EncoderStream(zf).end(e)},serialize:sM.encode,deserialize:sM.decode,q:1});Kr.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?xc.Readable.from((0,Ii.encodeIter)(e,zf)):(0,Ii.pack)(e)},serialize:Ii.pack,deserialize:Ii.unpack,q:.9});Kr.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),qm(e,e?.getColumns?.())},serialize(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),e&&!e[Symbol.iterator]&&(e=[e.toJSON?e.toJSON():e]),qm(e,e?.getColumns?.())},q:.1});Kr.set("text/plain",{serialize(e){return e.toString()},serializeStream(e){return xc.Readable.from(e.map?e.map(t=>t.toString()):e)},deserialize(e){return e.toString()},q:.2});Kr.set("text/yaml",{serialize(e){return cM.stringify(e,{aliasDuplicateObjects:!1})},q:.7});Kr.set("text/event-stream",{serializeStream:a(function(e){return xc.Readable.from(U3(e,this.serialize))},"serializeStream"),serialize:a(function(e){if(e.acknowledge&&e.acknowledge(),typeof e=="object"&&"value"in e&&e.timestamp&&(e={data:e.value,event:e.type,id:e.timestamp}),e.data||e.event){let t="";if(e.event&&(t+="event: "+e.event+`
9
- `),e.data){let r=e.data;typeof r=="object"&&(r=Wf(r)),t+="data: "+r+`
7
+ `}a(js,"createLogRecord");function Cf(e){if(Ri){if(ID(e),Es){_a=!1;try{process.stdout.write(e)}finally{_a=!0}}}else Es&&process.stdout.write(e)}a(Cf,"logStdOut");function _m(e){if(Ri){if(ID(e),Es){_a=!1;try{process.stderr.write(e)}finally{_a=!0}}}else Es&&process.stderr.write(e)}a(_m,"logStdErr");function ID(e){nR(),fa?so.appendFileSync(fa,e):rR||console.log(e)}a(ID,"logToFile");function iR(){try{so.closeSync(fa)}catch{}fa=null}a(iR,"closeLogFile");function nR(){if(!fa){try{fa=so.openSync(dm,"a")}catch(e){rR||(rR=!0,console.error(e))}setTimeout(()=>{iR()},qQ).unref()}}a(nR,"openLogFile");function CD(...e){Er[Pr]<=Er.info&&Cf(js("info",e))}a(CD,"info");function PD(...e){Er[Pr]<=Er.trace&&Cf(js("trace",e))}a(PD,"trace");function fm(...e){Er[Pr]<=Er.error&&_m(js("error",e))}a(fm,"error");function DD(...e){Er[Pr]<=Er.debug&&Cf(js("debug",e))}a(DD,"debug");function LD(...e){Er[Pr]<=Er.notify&&Cf(js("notify",e))}a(LD,"notify");function MD(...e){Er[Pr]<=Er.fatal&&_m(js("fatal",e))}a(MD,"fatal");function vD(...e){Er[Pr]<=Er.warn&&_m(js("warn",e))}a(vD,"warn");function zQ(e,t,...r){t===ND.STDERR?_m(js(e,r)):Cf(js(e,r))}a(zQ,"logCustomLevel");function jQ(){let e;try{e=HQ.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=yi.join(e,Yt.HDB_HOME_DIR_NAME,Yt.BOOT_PROPS_FILE_NAME);return so.existsSync(t)||(t=yi.join(sR,"utility/hdb_boot_properties.file")),t}a(jQ,"getPropsFilePath");function JQ(e){Pr=e}a(JQ,"setLogLevel");function yD(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(yD,"autoCastBoolean");function QQ(e){try{if(e.includes("config/settings.js")){let o=OD(e);return{level:o.get(Yt.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY),config_log_path:yi.dirname(o.get(Yt.HDB_SETTINGS_NAMES.LOG_PATH_KEY)),to_file:o.get(Yt.HDB_SETTINGS_NAMES.LOG_TO_FILE),to_stream:o.get(Yt.HDB_SETTINGS_NAMES.LOG_TO_STDSTREAMS)}}let t=bD.parseDocument(so.readFileSync(e,"utf8")),r=t.getIn(["logging","level"]),n=t.getIn(["logging","root"]),s=t.getIn(["logging","file"]),i=t.getIn(["logging","stdStreams"]);return{level:r,config_log_path:n,to_file:s,to_stream:i}}catch(t){if(t.code===Yt.NODE_ERROR_CODES.ENOENT)throw t;console.error("Error accessing config file for logging"),console.error(t)}}a(QQ,"getLogConfig");function XQ(){try{let e=bD.parseDocument(so.readFileSync(GQ,"utf8")),t=e.getIn(["logging","level"]),r=e.getIn(["logging","file"]),n=e.getIn(["logging","stdStreams"]);return{default_level:t,default_to_file:r,default_to_stream:n}}catch(e){console.error("Error accessing default config file for logging"),console.error(e)}}a(XQ,"getDefaultConfig");function ZQ(e,t,r,n,s,i){this.username=e,this.status=t,this.type=r,this.originating_ip=n,this.request_method=s,this.path=i}a(ZQ,"AuthAuditLog")});var oR=I((Kye,BD)=>{"use strict";var e4=require("util"),t4=require("path"),r4=require("child_process"),n4=e4.promisify(r4.execFile),s4=1e3*1e3*10;BD.exports={findPs:i4};async function i4(e){let t={};try{await Promise.all(["comm","args","ppid","uid","%cpu","%mem"].map(async r=>{let{stdout:n}=await n4("ps",["wwxo",`pid,${r}`],{maxBuffer:s4});for(let s of n.trim().split(`
8
+ `).slice(1)){s=s.trim();let[i]=s.split(" ",1),o=s.slice(i.length+1).trim();t[i]===void 0&&(t[i]={}),t[i][r]=o}}))}catch(r){throw r}return Object.entries(t).filter(([,r])=>r.comm&&r.args&&r.ppid&&r.uid&&r["%cpu"]&&r["%mem"]&&r.args.includes(e)).map(([r,n])=>({pid:Number.parseInt(r,10),name:t4.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(i4,"findPs")});var xt=I((Wye,kD)=>{"use strict";var o4="__dbis__",a4="__txns__",c4="__environment_name__",l4="__dbi_defintion__",u4={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"},d4=["__createdtime__","__updatedtime__"],f4="\uFFFF",HD={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},_4=Object.values(HD);kD.exports={AUDIT_STORE_NAME:a4,INTERNAL_DBIS_NAME:o4,DBI_DEFINITION_NAME:l4,SEARCH_TYPES:u4,TIMESTAMP_NAMES:d4,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:c4,TRANSACTIONS_DBI_NAMES_ENUM:HD,TRANSACTIONS_DBIS:_4,OVERFLOW_MARKER:f4}});var Bn=I((zye,zD)=>{"use strict";var FD=(H(),P(G)),GD=xt(),qD={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},$D=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),VD={500:$D("There was an error processing your request."),400:"Invalid request"},p4=VD[qD.INTERNAL_SERVER_ERROR],h4={OP_NOT_SUPPORTED_FOR_FS:a(e=>`${e} is not available for this instance because it uses the File System data store.`,"OP_NOT_SUPPORTED_FOR_FS"),MISSING_VALUE:a(e=>`${e} is missing.`,"MISSING_VALUE"),INVALID_VALUE:a(e=>`${e} is invalid.`,"INVALID_VALUE"),NOT_FOUND:a(e=>`${e} not found.`,"NOT_FOUND")},m4={CONFIG_VALIDATION:a(e=>`HarperDB config file validation error: ${e}`,"CONFIG_VALIDATION")},E4={DEFAULT_BULK_LOAD_ERR:"There was an error during your bulk load into HarperDB.",DOWNLOAD_FILE_ERR:a(e=>`There was an error downloading '${e}'.`,"DOWNLOAD_FILE_ERR"),INSERT_JSON_ERR:"There was an error inserting the downloaded JSON data.",INSERT_CSV_ERR:"There was an error inserting the downloaded CSV data.",INVALID_ACTION_PARAM_ERR:a(e=>`Bulk load operation failed - ${e} is not a valid 'action' parameter`,"INVALID_ACTION_PARAM_ERR"),INVALID_FILE_EXT_ERR:a(e=>`Error selecting correct parser - valid file type not found in json - ${e}`,"INVALID_FILE_EXT_ERR"),MAX_FILE_SIZE_ERR:a((e,t)=>`File size is ${e} bytes, which exceeded the maximum size allowed of: ${t} bytes`,"MAX_FILE_SIZE_ERR"),PAPA_PARSE_ERR:"There was an error parsing the downloaded CSV data.",S3_DOWNLOAD_ERR:a(e=>`There was an error downloading '${e}' from AWS.`,"S3_DOWNLOAD_ERR"),WRITE_TEMP_FILE_ERR:"Error writing temporary file to storage"},g4={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 ${GD.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${GD.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"},S4={ATTR_NAME_LENGTH_ERR:a(e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${FD.INSERT_MAX_CHARACTER_SIZE} bytes.`,"ATTR_NAME_LENGTH_ERR"),ATTR_NAME_NULLISH_ERR:"transaction aborted due to record(s) with an attribute name that is null, undefined or empty string",HASH_VAL_LENGTH_ERR:`transaction aborted due to record(s) with a hash value that exceeds ${FD.INSERT_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"},KD={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"},T4={DEFAULT_INVALID_REQUEST:"Invalid request",OP_AUTH_PERMS_ERROR:"This operation is not authorized due to role restrictions and/or invalid database items",OP_IS_SU_ONLY:a(e=>`Operation '${e}' is restricted to 'super_user' roles`,"OP_IS_SU_ONLY"),OP_NOT_FOUND:a(e=>`Operation '${e}' not found`,"OP_NOT_FOUND"),SYSTEM_TIMESTAMP_PERMS_ERR:"Internal timestamp attributes - '__createdtime_' and '__updatedtime__' - cannot be inserted to or updated by HDB users.",UNKNOWN_OP_AUTH_ERROR:a((e,t,r)=>`There was an error authorizing ${e} op on table '${t}.${r}'`,"UNKNOWN_OP_AUTH_ERROR"),USER_HAS_NO_PERMS:a(e=>`User ${e} has no role or permissions. Please assign the user a valid role.`,"USER_HAS_NO_PERMS"),DROP_SYSTEM:"The 'system' database, tables and records are used internally by HarperDB and cannot be updated or removed."},A4={ATTR_PERM_MISSING:a((e,t)=>`${e.toUpperCase()} attribute permission missing for '${t}'`,"ATTR_PERM_MISSING"),ATTR_PERM_MISSING_NAME:"Permission object in 'attribute_permission' missing an 'attribute_name'",ATTR_PERM_NOT_BOOLEAN:a((e,t)=>`${e.toUpperCase()} attribute permission for '${t}' must be a boolean`,"ATTR_PERM_NOT_BOOLEAN"),ATTR_PERMS_ARRAY_MISSING:"Missing 'attribute_permissions' array",ATTR_PERMS_NOT_ARRAY:"Value for 'attribute_permissions' must be an array",INVALID_ATTRIBUTE_IN_PERMS:a(e=>`Invalid attribute '${e}' in 'attribute_permissions'`,"INVALID_ATTRIBUTE_IN_PERMS"),INVALID_PERM_KEY:a(e=>`Invalid table permission key value '${e}'`,"INVALID_PERM_KEY"),INVALID_ATTR_PERM_KEY:a(e=>`Invalid attribute permission key value '${e}'`,"INVALID_ATTR_PERM_KEY"),INVALID_ROLE_JSON_KEYS:a(e=>`Invalid ${e.length>1?"keys":"key"} in JSON body - '${e.join("', '")}'`,"INVALID_ROLE_JSON_KEYS"),MISMATCHED_TABLE_ATTR_PERMS:a(e=>`You have a conflict with TABLE permissions for '${e}' being false and ATTRIBUTE permissions being true`,"MISMATCHED_TABLE_ATTR_PERMS"),OUTDATED_PERMS_TRANSLATION_ERROR:"This instance was recently upgraded and uses our new role permissions structure. Please login to this instance in HarperDB Studio, go to 'Roles', and click 'Update Role Permission' for all standard roles to migrate them to the new structure.",ROLE_ALREADY_EXISTS:a(e=>`A role with name '${e}' already exists`,"ROLE_ALREADY_EXISTS"),ROLE_NOT_FOUND:"Role not found",ROLE_PERMS_ERROR:"Errors in the role permissions JSON provided",SCHEMA_PERM_ERROR:a(e=>`Your role does not have permission to view database metadata for '${e}'`,"SCHEMA_PERM_ERROR"),SCHEMA_TABLE_PERM_ERROR:a((e,t)=>`Your role does not have permission to view database.table metadata for '${e}.${t}'`,"SCHEMA_TABLE_PERM_ERROR"),SU_ROLE_MISSING_ERROR:"Missing 'super_user' key/value in permission set",SU_CU_ROLE_BOOLEAN_ERROR:a(e=>`Value for '${e}' permission must be a boolean`,"SU_CU_ROLE_BOOLEAN_ERROR"),STRUCTURE_USER_ROLE_TYPE_ERROR:a(e=>`Value for '${e}' permission must be a boolean or Array`,"STRUCTURE_USER_ROLE_TYPE_ERROR"),SU_CU_ROLE_NO_PERMS_ALLOWED:a(e=>`Roles with '${e}' set to true cannot have other permissions set.`,"SU_CU_ROLE_NO_PERMS_ALLOWED"),SU_CU_ROLE_COMBINED_ERROR:"Roles cannot have both 'super_user' and 'cluster_user' values included in their permissions set.",TABLE_PERM_MISSING:a(e=>`Missing table ${e.toUpperCase()} permission`,"TABLE_PERM_MISSING"),TABLE_PERM_NOT_BOOLEAN:a(e=>`Table ${e.toUpperCase()} permission must be a boolean`,"TABLE_PERM_NOT_BOOLEAN")},R4={ATTR_NOT_FOUND:a((e,t,r)=>`Attribute '${r}' does not exist on '${e}.${t}'`,"ATTR_NOT_FOUND"),ATTR_EXISTS_ERR:a((e,t,r)=>`Attribute '${r}' already exists in ${e}.${t}'`,"ATTR_EXISTS_ERR"),DESCRIBE_ALL_ERR:"There was an error during describeAll. Please check the logs and try again.",INVALID_TABLE_ERR:a(e=>`Invalid table ${JSON.stringify(e)}`,"INVALID_TABLE_ERR"),SCHEMA_NOT_FOUND:a(e=>`database '${e}' does not exist`,"SCHEMA_NOT_FOUND"),SCHEMA_EXISTS_ERR:a(e=>`database '${e}' already exists`,"SCHEMA_EXISTS_ERR"),TABLE_EXISTS_ERR:a((e,t)=>`Table '${t}' already exists in '${e}'`,"TABLE_EXISTS_ERR"),SCHEMA_REQUIRED_ERR:"database is required",TABLE_NOT_FOUND:a((e,t)=>`Table '${e}.${t}' does not exist`,"TABLE_NOT_FOUND"),TABLE_REQUIRED_ERR:"table is required"},y4={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},b4={ALTER_USER_DUP_ROLES:a(e=>`Update failed. There are duplicates for the '${e}' role which is not allowed. Update your roles and try again.`,"ALTER_USER_DUP_ROLES"),ALTER_USER_ROLE_NOT_FOUND:a(e=>`Update failed. Requested '${e}' role not found.`,"ALTER_USER_ROLE_NOT_FOUND"),DUP_ROLES_FOUND:a(e=>`Multiple ${e} roles found. Roles must have unique 'role' value. Please update and try again.`,"DUP_ROLES_FOUND"),ROLE_NAME_NOT_FOUND:a(e=>`${e} role not found`,"ROLE_NAME_NOT_FOUND"),USER_ALREADY_EXISTS:a(e=>`User ${e} already exists`,"USER_ALREADY_EXISTS"),USER_NOT_EXIST:a(e=>`User ${e} does not exist`,"USER_NOT_EXIST")},YD={INVALID_DATE:"Invalid date, must be in ISO-8601 format (YYYY-MM-DD).",SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE:a(e=>`invalid sort attribute '${e}', the attribute must either be the table's hash attribute or an attribute used in conditions.`,"SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE")},WD={INVALID_ITC_DATA_TYPE:"Invalid ITC event data type, must be an object",MISSING_TYPE:"ITC event missing 'type'",MISSING_MSG:"ITC event missing 'message'",MISSING_ORIGIN:"ITC event message missing 'originator' property",INVALID_EVENT:a(e=>`ITC server received invalid event type: ${e}`,"INVALID_EVENT")},O4={FUNCTION_STATUS:"Error getting custom function status, check the log for more details",GET_FUNCTIONS:"Error getting custom functions, check the log for more details",GET_FUNCTION:"Error getting custom function, check the log for more details",SET_FUNCTION:"Error setting custom function, check the log for more details",NO_PROJECT:"Project does not exist. Create one using 'add_custom_function_project'",PROJECT_EXISTS:"Project already exists",VALIDATION_ERR:"Error validating request, check the log for more details",NO_FILE:"File does not exist",BAD_FILE_NAME:"File name can only contain alphanumeric, dash and underscore characters",BAD_PROJECT_NAME:"Project name can only contain alphanumeric, dash and underscores characters",BAD_PACKAGE:"Packaged project must be base64-encoded tar file of project directory",DROP_FUNCTION:"Error dropping custom function, check the log for more details",ADD_FUNCTION:"Error adding custom function project, check the log for more details",DROP_FUNCTION_PROJECT:"Error dropping custom function project, check the log for more details",BAD_FILE_PATH:"Filepath must be valid, and contain the name of the tarball you wish to write",NOT_ENABLED:"Custom functions is not enabled, to enable set fastifyRoutes enabled to true in hdb/harperdb-config.yaml file.",BAD_SSH_KEY_NAME:"SSH key name can only contain alphanumeric, dash and underscore characters"},N4={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},w4={...KD,...E4,...h4,...T4,...A4,...R4,...y4,...b4,...S4,...YD,...WD,...O4,...N4,...m4};zD.exports={CHECK_LOGS_WRAPPER:$D,HDB_ERROR_MSGS:w4,DEFAULT_ERROR_MSGS:VD,DEFAULT_ERROR_RESP:p4,HTTP_STATUS_CODES:qD,LMDB_ERRORS_ENUM:g4,AUTHENTICATION_ERROR_MSGS:KD,VALIDATION_ERROR_MSGS:YD,ITC_ERRORS:WD}});var pe=I((Jye,QD)=>{"use strict";var pu=Bn(),I4=W(),C4=(H(),P(G)),pm=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,jD),this.statusCode=n||pu.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(pu.DEFAULT_ERROR_MSGS[n]?pu.DEFAULT_ERROR_MSGS[n]:pu.DEFAULT_ERROR_MSGS[pu.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&&I4[s](i)}},aR=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}},cR=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function jD(e,t,r,n=C4.LOG_LEVELS.ERROR,s=null,i=!1){if(JD(e))return e;let o=new pm(e,t,r,n,s);return i&&delete o.stack,o}a(jD,"handleHDBError");function JD(e){return e.__proto__.constructor.name===pm.name}a(JD,"isHDBError");QD.exports={isHDBError:JD,handleHDBError:jD,ClientError:aR,ServerError:cR,hdb_errors:pu}});var Et=I((Xye,sL)=>{"use strict";var vf=(H(),P(G)),P4=ae(),_n=ce(),Uf=require("path"),D4=require("minimist"),XD=require("fs-extra"),ZD=require("lodash");_n.initSync();var{CONFIG_PARAMS:pa,DATABASES_PARAM_CONFIG:Pf,SYSTEM_SCHEMA_NAME:hm}=vf,Df,Lf,Mf;function eL(){if(Df!==void 0)return Df;if(_n.getHdbBasePath()!==void 0)return Df=_n.get(pa.STORAGE_PATH)||Uf.join(_n.getHdbBasePath(),vf.DATABASES_DIR_NAME),Df}a(eL,"getBaseSchemaPath");function tL(){if(Lf!==void 0)return Lf;if(_n.getHdbBasePath()!==void 0)return Lf=nL(hm),Lf}a(tL,"getSystemSchemaPath");function rL(){if(Mf!==void 0)return Mf;if(_n.getHdbBasePath()!==void 0)return Mf=_n.get(vf.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||Uf.join(_n.getHdbBasePath(),vf.TRANSACTIONS_DIR_NAME),Mf}a(rL,"getTransactionAuditStoreBasePath");function L4(e,t){let r=_n.get(pa.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||Uf.join(rL(),e.toString())}a(L4,"getTransactionAuditStorePath");function nL(e,t){e=e.toString(),t=t&&t.toString();let r=_n.get(vf.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||Uf.join(eL(),e)}a(nL,"getSchemaPath");function M4(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,D4(process.argv));let n=r[pa.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!P4.isObject(n))throw o;i=n}for(let o of i){let c=o[hm];if(!c)continue;let l=_n.get(pa.DATABASES);l=l??{};let u=c?.tables?.[t]?.[Pf.PATH];if(u)return ZD.set(l,[hm,Pf.TABLES,t,Pf.PATH],u),_n.setProperty(pa.DATABASES,l),u;let f=c?.[Pf.PATH];if(f)return ZD.set(l,[hm,Pf.PATH],f),_n.setProperty(pa.DATABASES,l),f}}let s=r[pa.STORAGE_PATH.toUpperCase()];if(s){if(!XD.pathExistsSync(s))throw new Error(s+" does not exist");let i=Uf.join(s,e);return XD.mkdirsSync(i),_n.setProperty(pa.STORAGE_PATH,s),i}return tL()}a(M4,"initSystemSchemaPaths");function v4(){Df=void 0,Lf=void 0,Mf=void 0}a(v4,"resetPaths");sL.exports={getBaseSchemaPath:eL,getSystemSchemaPath:tL,getTransactionAuditStorePath:L4,getTransactionAuditStoreBasePath:rL,getSchemaPath:nL,initSystemSchemaPaths:M4,resetPaths:v4}});var pn=I((rbe,lL)=>{"use strict";var U4=Bn().LMDB_ERRORS_ENUM,ebe=require("lmdb"),x4=xt(),tbe=require("buffer").Buffer,{OVERFLOW_MARKER:iL,MAX_SEARCH_KEY_LENGTH:mm}=x4,oL=["number","string","symbol","boolean","bigint"];function B4(e){if(e=e?.primaryStore||e,!e)throw new Error(U4.ENV_REQUIRED)}a(B4,"validateEnv");function H4(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(H4,"stringifyData");function k4(e){return e instanceof Date?e.valueOf():e}a(k4,"convertKeyValueToWrite");function F4(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(oL.includes(typeof e))return e.length>mm?[e.slice(0,mm)+iL]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(oL.includes(typeof i))i.length>mm?r.push(i.slice(0,mm)+iL):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(F4,"getIndexedValues");var Em=0,aL=0;function cL(){aL=Date.now()-performance.now()}a(cL,"adjustStartTime");cL();var G4=6e4;setInterval(cL,G4).unref();function q4(){let e=performance.now()+aL;return e>Em?(Em=e,e):(Em+=488e-6,Em)}a(q4,"getNextMonotonicTime");lL.exports={validateEnv:B4,stringifyData:H4,convertKeyValueToWrite:k4,getNextMonotonicTime:q4,getIndexedValues:F4}});var xf=I((sbe,uL)=>{"use strict";var $4=(H(),P(G)).OPERATIONS_ENUM,lR=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=$4.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};uL.exports=lR});var Bf=I((abe,pL)=>{"use strict";var obe=xf(),gm=(H(),P(G)),uR=ae(),dL=W(),V4=require("uuid"),{handleHDBError:Sm,hdb_errors:K4}=pe(),{HDB_ERROR_MSGS:Tm,HTTP_STATUS_CODES:Am}=K4;pL.exports=fL;function fL(e,t,r){for(let s=0;s<t.length;s++)_L(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];Y4(i,r,e.operation)}}a(fL,"processRows");fL.validateAttribute=_L;function _L(e){if(Buffer.byteLength(String(e))>gm.INSERT_MAX_CHARACTER_SIZE)throw Sm(new Error,Tm.ATTR_NAME_LENGTH_ERR(e),Am.BAD_REQUEST,void 0,void 0,!0);if(uR.isEmptyOrZeroLength(e)||uR.isEmpty(e.trim()))throw Sm(new Error,Tm.ATTR_NAME_NULLISH_ERR,Am.BAD_REQUEST,void 0,void 0,!0)}a(_L,"validateAttribute");function Y4(e,t,r){if(!e.hasOwnProperty(t)||uR.isEmptyOrZeroLength(e[t])){if(r===gm.OPERATIONS_ENUM.INSERT||r===gm.OPERATIONS_ENUM.UPSERT){e[t]=V4.v4();return}throw dL.error("Update transaction aborted due to record with no hash value:",e),Sm(new Error,Tm.RECORD_MISSING_HASH_ERR,Am.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>gm.INSERT_MAX_CHARACTER_SIZE)throw dL.error(e),Sm(new Error,Tm.HASH_VAL_LENGTH_ERR,Am.BAD_REQUEST,void 0,void 0,!0)}a(Y4,"validateHash")});var hL,Hn,dR,hu=be(()=>{hL=require("events"),Hn=class extends hL.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new dR;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)}},dR=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}}}});function RL(e){_R=e}function J4(){j4=setInterval(function(){for(let e of fR)if(e.stale){let t=e.getContext()?.url;SL.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},z4).unref()}var pR,gL,SL,TL,AL,mL,fR,W4,Hf,EL,_R,Ic,Rm,z4,j4,ym=be(()=>{pR=M(pn()),gL=M(pe()),SL=M(W()),TL=M(ce());H();AL=M(ae()),mL=100,fR=new Set,W4=(0,AL.convertToMS)(TL.get(x.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(RL,"replicationConfirmation");Ic=class e{static{a(this,"DatabaseTransaction")}#e;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),fR.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn?.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(fR.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(Hf&&!this.overloadChecked&&performance.now()-EL>W4)throw new gL.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,pR.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 _=d;_<this.validated;_++)this.writes[_]?.validate?.(this.timestamp);let p;for(let _=d;_<this.validated;_++){let h=this.writes[_];h&&(h.before||h.beforeIntermediate)&&(p=!0)}if(p)return(async()=>{try{for(let _=0;_<2;_++){let h;for(let S=d;S<this.validated;S++){let g=this.writes[S];if(!g)continue;let R=g[_===0?"before":"beforeIntermediate"];if(R){let E=R();h?h.push?h.push(E):h=[h,E]:h=E}}h&&await(h.push?Promise.all(h):h)}}catch(_){throw this.abort(),_}return this.commit(t)})()}catch(d){throw this.abort(),d}n||this.doneReadTxn(),this.open=t?.doneWriting?2:1;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 p=d.store.ifVersion(d.key,d.entry?.version??null,l);s=s||p}else l();else for(let p of this.writes)c(p)},"nextCondition"),u=this.lmdbDb;if(this.writes.length>0&&(u?.retryRisk&&(u.retryRisk*=.99),this.writes.length+(u?.retryRisk||0)<mL>>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 Hf||(Hf=s,EL=performance.now(),Hf.then(()=>{Hf=null})),s.then(d=>{if(d){if(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.replicatedConfirmation){let p=this.writes[0].store.rootStore.databaseName,_=this.writes[this.writes.length-1];_R&&_&&i.push(_R(p,_.store.getEntry(_.key).localTime,this.replicatedConfirmation))}return this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))}else return u&&(u.retryRisk=(u.retryRisk||0)+mL/2),t?t.retries=n+1:t={retries:1},this.commit(t)});let f={txnTime:r};if(this.next){let d=this.next?.commit(t);if(d?.then)return d?.then(p=>({txnTime:r,next:p}));f.next=d}return f}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}getContext(){return this.#e}setContext(t){this.#e=t}},Rm=class extends Ic{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,pR.getNextMonotonicTime)())}getReadTxn(){}},z4=3e4;a(J4,"startMonitoringTxns");J4()});function Nt(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 Ic;e.timestamp&&(n.timestamp=e.timestamp),e.replicatedConfirmation&&(n.replicatedConfirmation=e.replicatedConfirmation),n.setContext(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({doneWriting:!0});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var yL,Cc=be(()=>{yL=M(Ai());ym();a(Nt,"transaction");(0,yL._assignPackageExport)("transaction",Nt);Nt.commit=function(e){let t=(e.getContext?.()||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Nt.abort=function(e){let t=(e.getContext?.()||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});function mR(e,t,r,n,s,i,o,c){let l=e[0];if(t==="or"){let d=u(l);for(let _=1;_<e.length;_++){let h=e[_],S=u(h);d=d.concat(S)}let p=new Set;return d.filter(_=>{let h=_.key??_;return p.has(h)?!1:(p.add(h),!0)})}else{let d=u(l),p=f(e.slice(1),!0,l.estimated_count);return p.length>0?o(d,p):d}function u(d){return d.conditions?mR(d.conditions,d.operator,r,n,s,i,o,c):gu(d,n,d.descending||s.reverse===!0,r,s.allowFullScan,c)}a(u,"executeCondition");function f(d,p,_){return d.map((h,S)=>{if(h.conditions){let E=h.operator==="or",A=f(h.conditions,!E,_);return E?(N,v)=>A.some(F=>F(N,v)):(N,v)=>A.every(F=>F(N,v))}let g=(h.attribute||h[0])===r.primaryKey,R=Gf(h,r,i,c,g,_);return p&&S<d.length-1&&_&&(_=i3(r.primaryStore,h.estimated_count,_)),R}).filter(Boolean)}a(f,"mapConditionsToFilters")}function gu(e,t,r,n,s,i){let o=e[0]??e.attribute,c=e[1]??e.value,l=e.comparator;if(c===void 0&&l!=="sort")throw new mn.ClientError(`Search condition for ${o} must have a value`);if(Array.isArray(o)){let E=o[0],A=Oi(n.attributes,E);if(A.relationship){if(o.length<2)throw new mn.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let N=A.definition?.tableClass||A.elements?.definition?.tableClass,v=new Map,F=gu({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,N,s,v);if(A.relationship.to){i[o[0]]=v;let $=!!Oi(N.attributes,A.relationship.to)?.elements;F=t3(F,A,N.primaryStore,$,v)}if(A.relationship.from){let $=a(Y=>(Y?.key!==void 0&&(Y=Y.key),gu({attribute:A.relationship.from,value:Y},t,r,n,s,v)),"searchEntry");A.elements?(i[o[0]]=v,F=r3(F,A,N.primaryStore,v,$)):F=F.flatMap($)}return F}else if(o.length===1)o=o[0];else throw new mn.ClientError("Unable to query by attribute "+JSON.stringify(o))}let u,f,d,p;c instanceof Date&&(c=c.getTime());let _;switch(ER[l]||l){case"lt":u=!0,f=c;break;case"le":u=!0,f=c,d=!0;break;case"gt":u=c,p=!0;break;case"ge":u=c;break;case"prefix":Array.isArray(c)?c[c.length-1]!=null&&(c=c.concat(null)):c=[c,null],u=c,f=c.slice(0),f[f.length-1]=bi.MAXIMUM_KEY;break;case"starts_with":u=c.toString(),f=c+"\uFFFF";break;case"between":case"gele":case"gelt":case"gtlt":case"gtle":u=c[0],u instanceof Date&&(u=u.getTime()),f=c[1],f instanceof Date&&(f=f.getTime()),d=l==="gele"||l==="gtle"||l==="between",p=l==="gtlt"||l==="gtle";break;case"equals":case void 0:u=c,f=c,d=!0;break;case"ne":if(c===null){u=c,p=!0;break}case"sort":case"contains":case"ends_with":u=!0,_=!0;break;default:throw new mn.ClientError(`Unknown query comparator "${l}"`)}let h,S=o===n.primaryKey||o==null;if(typeof u=="string"&&u.length>gs.MAX_SEARCH_KEY_LENGTH&&(u=u.slice(0,gs.MAX_SEARCH_KEY_LENGTH)+gs.OVERFLOW_MARKER,p=!1,h=Gf(e,n,null,i,S)),typeof f=="string"&&f.length>gs.MAX_SEARCH_KEY_LENGTH&&(f=f.slice(0,gs.MAX_SEARCH_KEY_LENGTH)+gs.OVERFLOW_MARKER,d=!0,h=h??Gf(e,n,null,i,S)),r){let E=u;u=f,f=E,E=!p,p=!d,d=E}let g=S?n.primaryStore:n.indices[o];if(!g||g.isIndexing||_||c===null&&!g.indexNulls){if(s===!1&&!g)throw new mn.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&_)throw new mn.ClientError(`Can not use ${l||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(g?.isIndexing)throw new mn.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&g&&!g.indexNulls)throw new mn.ClientError(`"${o}" is not indexed for nulls, index needs to be rebuilt to search for nulls, can not search for this attribute`,400);if(h=h??Gf(e,n,null,i,S),!h)throw new mn.ClientError(`Unknown search operator ${e.comparator}`)}let R={start:u,end:f,inclusiveEnd:d,exclusiveStart:p,values:!0,versions:S,transaction:t,reverse:r};if(S){let E=g.getRange(R).map(h?function({key:A,value:N}){return this?.isSync?N&&h(N)?A:ha.SKIP:new Promise((v,F)=>setImmediate(()=>{try{v(N&&h(N)?A:ha.SKIP)}catch($){F($)}}))}:A=>A.value==null&&!(A.metadataFlags&(En|Ea))?ha.SKIP:A);return E.hasEntries=!0,E}else return g?g.getRange(R).map(h?function({key:E,value:A}){let N;return typeof E=="string"&&E.length>gs.MAX_SEARCH_KEY_LENGTH?N=n.primaryStore.get(A):N={[o]:E},this.isSync?h(N)?A:ha.SKIP:new Promise((v,F)=>setImmediate(()=>{try{v(h(N)?A:ha.SKIP)}catch($){F($)}}))}:({value:E})=>E):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:E,value:A}){return this.isSync?A&&h(A)?E:ha.SKIP:new Promise((N,v)=>setImmediate(()=>{try{N(A&&h(A)?E:ha.SKIP)}catch(F){v(F)}}))})}function Oi(e,t){if(Array.isArray(t))if(t.length>1){let r=Oi(e,t[0]),n=(r?.definition?.tableClass||r?.elements?.definition?.tableClass)?.attributes??r?.properties;return n?Oi(n,t.slice(1)):void 0}else t=t.toString();else typeof t!="string"&&(t=t.toString());return e.find(r=>r.name===t)}function t3(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i;return s.hasMappings=!0,{next(){if(!i){let c=t.relationship.to,l=a((u,f)=>{let d=s.get(u);d?d.push(f):s.set(u,d=[f])},"add_entry");for(let u of e){let f=u.value??r.get(u.key??u),d=f?.[c];if(d!=null&&!s.filters?.some(p=>!p(f)))if(n)for(let p=0;p<d.length;p++)l(d[p],u);else l(d,u)}return i=s.keys()[Symbol.iterator](),this.next()}let o=i.next();return o.done?o:{value:o.value}},return(){if(i?.return)return i.return()}}}})}function r3(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i,o,c=new Set;return{next(){let l;if(o)for(;l=o.next(),!l.done;){let u=l.value;if(!c.has(u))return c.add(u),l}if(!i){let u=new Set;n.fromRecord=f=>f[t.relationship.from]?.filter?.(d=>u.has(d));for(let f of e){if(n.filters){let d=r.get(f);if(n.filters.some(p=>!p(d)))continue}u.add(f)}return i=u[Symbol.iterator](),this.next()}do{let u=i.next();return u.done?u:(o=s(u.value)[Symbol.iterator](),this.next())}while(!0)},return(){return o?.return?.()},throw(){return o?.throw?.()}}}})}function Gf(e,t,r,n,s,i){let o=e.comparator,c=e[0]??e.attribute,l=e[1]??e.value;if(Array.isArray(c)){if(c.length===0)return()=>!0;if(c.length===1)c=c[0];else if(c.length>1){let f=c[0],d=Oi(t.attributes,f),p=d.definition?.tableClass||d.elements.definition?.tableClass,_=n?.[f],h=Gf({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:o},p,r,_?.[f]?.joined,c[1]===p.primaryKey,i);if(!h)return;if(_){_.filters||(_.filters=[]),_.filters.push(h);return}let S=t.propertyResolvers?.[f],g,R=a((E,A)=>{let N,v;if(S){if(S.from&&h.idFilter){if(!g)if(h.idFilter.idSet?.size===1){for(let $ of h.idFilter.idSet)e={attribute:S.from,value:$};g=u(S.from,h.idFilter,!0,!0)}else g=u(S.from,h.idFilter,!1,!0);let F=g(E);return g.idFilter&&(R.idFilter=g.idFilter),F}v=S(E,r,A),N=v?.value}else N=E[f];return N?Array.isArray(N)?N.some(h):h(N,v):!1},"recordFilter");return R}}switch(l instanceof Date&&(l=l.getTime()),ER[o]||o){case gs.SEARCH_TYPES.EQUALS:case void 0:return u(c,f=>f===l,!0);case"contains":return u(c,f=>f?.toString().includes(l));case"ends_with":return u(c,f=>f?.toString().endsWith(l));case"starts_with":return u(c,f=>typeof f=="string"&&f.startsWith(l),!0);case"prefix":return Array.isArray(l)?l[l.length-1]==null&&(l=l.slice(0,-1)):l=[l],u(c,f=>{if(!Array.isArray(f))return!1;for(let d=0,p=l.length;d<p;d++)if(f[d]!==l[d])return!1;return!0},!0);case"between":return l[0]instanceof Date&&(l[0]=l[0].getTime()),l[1]instanceof Date&&(l[1]=l[1].getTime()),u(c,f=>(0,bi.compareKeys)(f,l[0])>=0&&(0,bi.compareKeys)(f,l[1])<=0,!0);case"gt":return u(c,f=>(0,bi.compareKeys)(f,l)>0);case"ge":return u(c,f=>(0,bi.compareKeys)(f,l)>=0);case"lt":return u(c,f=>(0,bi.compareKeys)(f,l)<0);case"le":return u(c,f=>(0,bi.compareKeys)(f,l)<=0);case"ne":return u(c,f=>(0,bi.compareKeys)(f,l)!==0,!1,!0);case"sort":return()=>!0;default:throw new mn.ClientError(`Unknown query comparator "${o}"`)}function u(f,d,p,_){let h;p=p&&!s&&t?.indices[f]&&i>3,p&&(e.estimated_count==null&&Om(t)(e),h=e.estimated_count>>4,(isNaN(h)||h>=i)&&(p=!1));let S=0,g=3;function R(E){let A=E[f],N;if(typeof A!="object"||!A||_?N=d(A):Array.isArray(A)?N=A.some(d):A instanceof Date&&(N=d(A.getTime())),p&&(g++,!N&&!R.idFilter&&++S/g*(i-g)>h)){let v=gu(e,r.transaction.getReadTxn(),!1,t).map(Su),F=new Set(v);R.idFilter=$=>F.has(Su($)),R.idFilter.idSet=F}return N}return a(R,"recordFilter"),s&&(R.idFilter=d),R}a(u,"attributeComparator")}function Om(e){function t(r){if(r.estimated_count===void 0){if(r.conditions){let s;if(r.operator==="or"){s=0;for(let i of r.conditions)t(i),s+=i.estimated_count}else{s=1/0;for(let i of r.conditions)t(i),s=isFinite(s)?s*i.estimated_count/io(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=ER[n]||n,n===gs.SEARCH_TYPES.EQUALS||!n){let s=r[0]??r.attribute;if(s==null||s===e.primaryKey)r.estimated_count=1;else if(Array.isArray(s)&&s.length>1){let i=Oi(e.attributes,s[0]),o=i.definition?.tableClass||i.elements.definition?.tableClass,c=Om(o)({value:r.value,attribute:s.length>2?s.slice(1):s[1],comparator:"equals"}),l=e.indices[i.relationship.from];r.estimated_count=c+(l?c*io(e.indices[i.relationship.from])/(io(o.primaryStore)||1):c)}else{let i=e.indices[s];r.estimated_count=i?i.getValuesCount(r[1]??r.value):1/0}}else if(n==="contains"||n==="ends_with"||n==="ne"){let s=r[0]??r.attribute,i=e.indices[s];r.value===null&&n==="ne"?r.estimated_count=io(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=Z4*io(e.primaryStore)+1:n==="between"?r.estimated_count=X4*io(e.primaryStore)+1:n==="sort"?r.estimated_count=io(e.primaryStore)+1:r.estimated_count=Q4*io(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function Nm(e){if(e)if(ma=e,mu.lastIndex=0,n3.test(e))try{let t=kf(new Eu,"");if(hn!==ma.length)throw new SyntaxError("Unable to parse query, unexpected end of query");return t}catch(t){throw t.statusCode=400,t.message=`Unable to parse query, ${t.message} at position ${hn} in '${ma}'`,t}else return new URLSearchParams(e)}function kf(e,t){let r=mu,n,s,i,o,c,l=decodeURIComponent,u;for(;n=r.exec(ma);){hn=r.lastIndex;let[,f,d]=n;if(o){if(f)throw new SyntaxError(`expected operator, but encountered '${f}'`);o=!1,c=!1}else c=!0;let p;switch(d){case"=":if(s!=null){if(f.length<=2)i=f;else throw new SyntaxError(`invalid FIQL operator ${f}`);l=bL}else{if(l=decodeURIComponent,i="equals",!f)throw new SyntaxError("attribute must be specified before equality comparator");s=Ff(f)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=e3[d],l=hR[i]?bL:decodeURIComponent,!f)throw new SyntaxError(`attribute must be specified before comparator ${d}`);s=Ff(f);break;case"&=":case"|=":case"|":case"&":case"":case void 0:if(s==null){if(s===void 0)throw t?new SyntaxError(`expected '${t}', but encountered ${d[0]?"'"+d[0]+"'":"end of string"}}`):new SyntaxError(`no comparison specified before ${d?"'"+d+"'":"end of string"}`)}else{if(!e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");let h={comparator:i,attribute:s||null,value:l(f)};if(i==="eq"&&OL(h,f),s===""){let S=e.conditions[e.conditions.length-1];S.chainedConditions=S.chainedConditions||[],S.chainedConditions.push(h),S.operator=u}else bm(e,u),e.conditions.push(h)}d==="&"?(u="and",s=void 0):d==="|"?(u="or",s=void 0):d==="&="?(u="and",s=""):d==="|="&&(u="or",s="");break;case",":if(e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");e.push(Ff(f)),s=void 0;break;case"(":mu.lastIndex=hn;let _=kf(f?[]:new Eu,")");switch(f){case"":bm(e,u),e.conditions.push(_);break;case"limit":switch(_.length){case 1:e.limit=+_[0];break;case 2:e.offset=+_[0],e.limit=_[1]-e.offset;break;default:throw new SyntaxError("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(_[0])&&_.length===1&&!_[0].name?(e.select=_[0],e.select.asArray=!0):_.length===1?e.select=_[0]:_.length===2&&_[1]===""?e.select=_.slice(0,1):e.select=_;break;case"group-by":throw new SyntaxError("group by is not implemented yet");case"sort":e.sort=NL(_);break;default:throw new SyntaxError(`unknown query function call ${f}`)}ma[hn]===","?r.lastIndex=++hn:o=!0,s=null;break;case"{":if(e.conditions)throw new SyntaxError("property sets are not allowed in a queries");if(!f)throw new SyntaxError("property sets must have a defined parent property name");mu.lastIndex=hn,p=kf([],"}"),p.name=f,e.push(p),ma[hn]===","?r.lastIndex=++hn:o=!0;break;case"[":mu.lastIndex=hn,f?(p=kf(new Eu,"]"),p.name=f):p=kf(e.conditions?new Eu:[],"]"),e.conditions?(bm(e,u),e.conditions.push(p),s=null):e.push(p),ma[hn]===","?r.lastIndex=++hn:o=!0;break;case")":case"]":case"}":if(t===d[0]){if(e.conditions){if(s){let h={comparator:i||"equals",attribute:s,value:l(f)};i==="eq"&&OL(h,f),bm(e,u),e.conditions.push(h)}else if(f)throw new SyntaxError("no attribute or comparison specified")}else(f||e.length>0&&c)&&e.push(Ff(f));return e}else throw t?new SyntaxError(`expected '${t}', but encountered '${d[0]}'`):new SyntaxError(`unexpected token '${d[0]}'`);default:throw new SyntaxError(`unexpected operator '${d}'`)}if(t!==")"&&(r=s?s3:mu,r.lastIndex=hn),hn===ma.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function bm(e,t){if(e.conditions.length>0)if(e.operator){if(e.operator!==t)throw new SyntaxError("Can not mix operators within a condition grouping")}else e.operator=t}function Ff(e){return e.indexOf(".")>-1?e.split(".").map(Ff):decodeURIComponent(e)}function bL(e){if(e==="null")return null;if(e.indexOf(":")>-1){let[t,r]=e.split(":");if(t==="number")return r[0]==="$"?parseInt(r.slice(1),36):+r;if(t==="boolean")return r==="true";if(t==="date")return new Date(isNaN(r)?decodeURIComponent(r):+r);if(t==="string")return decodeURIComponent(r);throw new mn.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function OL(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new mn.ClientError("wildcard can only be used at the end of a string")}function NL(e){let t=wL(e[0]);return e.length>1&&(t.next=NL(e.slice(1))),t}function wL(e){if(Array.isArray(e)){let t=wL(e[0]);return e[0]=t.attribute,t.attribute=e,t}if(typeof e=="string")switch(e[0]){case"-":return{attribute:e.slice(1),descending:!0};case"+":return{attribute:e.slice(1),descending:!1};default:return{attribute:e,descending:!1}}throw new SyntaxError(`Unknown sort type ${e}`)}function Su(e){return Array.isArray(e)?e.join("\0"):e}function io(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function i3(e,t,r){return t*r/io(e)}var mn,gs,bi,ha,Q4,X4,Z4,e3,hR,ER,n3,mu,s3,hn,ma,Eu,Pc,qf=be(()=>{mn=M(pe()),gs=M(xt()),bi=require("ordered-binary"),ha=require("lmdb");$f();Q4=.3,X4=.1,Z4=.05,e3={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},hR={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(mR,"executeConditions");a(gu,"searchByIndex");a(Oi,"findAttribute");a(t3,"joinTo");a(r3,"joinFrom");ER={eq:"equals",greater_than:"gt",greaterThan:"gt",greater_than_equal:"ge",greaterThanEqual:"ge",less_than:"lt",lessThan:"lt",less_than_equal:"le",lessThanEqual:"le",not_equal:"ne",notEqual:"ne",equal:"equals",sw:"starts_with",startsWith:"starts_with",ew:"ends_with",endsWith:"ends_with",ct:"contains",">":"gt",">=":"ge","<":"lt","<=":"le","...":"between"};a(Gf,"filterByType");a(Om,"estimateCondition");n3=/[()[\]|!<>.]|(=\w*=)/,mu=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,s3=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(Nm,"parseQuery");a(kf,"parseBlock");a(bm,"assignOperator");a(Ff,"decodeProperty");a(bL,"typedDecoding");a(OL,"wildcardDecoding");a(NL,"toSortObject");a(wL,"toSortEntry");Eu=class{static{a(this,"Query")}constructor(){this.conditions=[]}[Symbol.iterator](){return this.conditions[Symbol.iterator]()}get(t){for(let r=0;r<this.conditions.length;r++){let n=this.conditions[r];if(n.attribute===t)return n.value}}};a(Su,"flattenKey");a(io,"estimatedEntryCount");a(i3,"intersectionEstimate");Pc=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});var SR={};Ue(SR,{MultiPartId:()=>Im,Resource:()=>Vr,snake_case:()=>a3,transformForSelect:()=>Cm});function a3(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function IL(e,t){if(Dc=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(Dc=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new Im;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Dc=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return Dc=!0,null;e[e.length-1]==="/"&&(Dc=!0)}return t.coerceId(decodeURIComponent(e))}function kn(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,l,u,f;if(r?(o?(f=i,o=o.getContext?.()||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(f=s,c=f[this.primaryKey]??null,o=i.getContext?.()||i):f=i:(f=s,s=void 0,c=f.getId?.()??f[this.primaryKey]),c===null&&(u=!0)):i?o=i.getContext?.()||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="object"&&s){if(l=s,typeof(c=s.url)=="string")if(this.directURLMapping)c=c.slice(1);else{let _=c.indexOf("?");if(_>-1){let S=this.parseQuery(c.slice(_+1));l?S&&(l=Object.assign(S,l)):l=S,c=c.slice(0,_)}let h=this.parsePath(c,o,l);h?.id!==void 0?(h.query&&(l?l=Object.assign(h.query,l):l=h.query),u=h.isCollection,c=h.id):c=h}else if(s[Symbol.iterator]){c=[],u=!0;for(let _ of s){if(typeof _=="object"&&_)break;c.push(_)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=null,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new Pc(c),c==null&&(u=!0);o||(o={});let d;if(l?.ensureLoaded!=null||l?.async||u?(d={...t},l?.ensureLoaded!=null&&(d.ensureLoaded=l.ensureLoaded),l?.async&&(d.async=l.async),u&&(d.isCollection=!0)):d=t,o.transaction){let _=this.getResource(c,o,d);return _.then?_.then(p):p(_)}else return Nt(o,()=>{let _=this.getResource(c,o,d);return _.then?_.then(p):p(_)},d);function p(_){if(o.authorize){o.authorize=!1;let h=t.type==="read"?_.allowRead(o.user,l,o):t.type==="update"?_.doesExist?.()===!1?_.allowCreate(o.user,f,o):_.allowUpdate(o.user,f,o):t.type==="create"?_.allowCreate(o.user,f,o):_.allowDelete(o.user,l,o);if(h?.then)return h.then(S=>{if(!S)throw new wm(o.user);return typeof f?.then=="function"?f.then(g=>e(_,l,o,g)):e(_,l,o,f)});if(!h)throw new wm(o.user)}return typeof f?.then=="function"?f.then(h=>e(_,l,o,h)):e(_,l,o,f)}a(p,"authorizeActionOnResource")}}function Fn(e,t){let r=new DL.ClientError(`The ${e.constructor.name} does not have a ${t} method implemented`,405);r.allow=[],r.method=t;for(let n of["get","put","post","delete","query","move","copy"])typeof e[n]=="function"&&r.allow.push(n);throw r}function gR(e,t,r){let n=e.getRecord?.();if(n){let s=e.getChanges?.();return i=>{let o,c;return e.hasOwnProperty(i)&&typeof(o=e[i])!="function"?o:s&&i in s?s[i]:(c=t?.[i])?c(e,r):n[i]}}else return t?s=>{let i=t[s];return i?i(e,r):e[s]}:s=>e[s]}function Cm(e,t){let r=t.propertyResolvers,n=t.getContext?.(),s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):gR(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(c);let u=[],f=i(gR(l,r,n));for(let d of e)u.push(f(d));return u},"transform");let o=e.forceNulls;return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(p=>p&&typeof p=="object"?c(p):p);let u={},f=i(gR(l,r,n)),d;for(let p of e){let _=f(p);_===void 0&&o&&(_=null),_?.then?(d||(d=[]),d.push(_.then(h=>u[p.name||p]=h))):u[p.name||p]=_}return d?Promise.all(d).then(()=>u):u},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(o){return c=>{if(typeof c=="string")return o(c);if(typeof c=="object")if(c.name){s||(s={});let l=s[c.name];if(!l){let f=r[c.name]?.definition?.tableClass;l=s[c.name]=Cm(c.select||c,f)}let u=o(c.name);return l(u)}else return o(c);else return c}}a(i,"handleProperty")}var CL,PL,DL,o3,Vr,wm,Dc,Im,ga=be(()=>{CL=require("crypto");hu();PL=M(Ai()),DL=M(pe());Cc();qf();o3={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Vr=class{static{a(this,"Resource")}#e;#t;#n;static transactions;static directURLMapping=!1;constructor(t,r){this.#e=t;let n=r?.getContext?r.getContext()??null:void 0;this.#t=n!==void 0?n:r||null}static get=kn(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let l;if((l=r?.select)&&c!=null&&!c.selectApplied){let u=Cm(l,t.constructor);return typeof c?.map=="function"?c.map(u):u(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=kn(function(t,r,n,s){if(Array.isArray(s)&&t.#n){let i=[],o=n.authorize;for(let c of s){let l=t.constructor,u=l.getResource(c[l.primaryKey],n,{async:!0});u.then?i.push(u.then(f=>f.put(c,n))):i.push(u.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):Fn(t,"put")},{hasContent:!0,type:"update"});static patch=kn(function(t,r,n,s){return t.patch?t.patch(s,r):Fn(t,"patch")},{hasContent:!0,type:"update"});static delete=kn(function(t,r,n,s){return t.delete?t.delete(r):Fn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,CL.randomUUID)()}static create(t,r,n){let s;return t==null?s=r?.[this.primaryKey]??this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=r?.[this.primaryKey]??[...t,this.getNewId()]:typeof t!="object"?s=r?.[this.primaryKey]??[t,this.getNewId()]:(s=t?.[this.primaryKey]??this.getNewId(),n=r||{},r=t),n||(n={}),Nt(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):Fn(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=kn(function(t,r,n,s){return t.invalidate?t.invalidate(r):Fn(t,"delete")},{hasContent:!1,type:"update"});static post=kn(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=kn(function(t,r,n,s){return t.connect?t.connect(s,r):Fn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=kn(function(t,r,n,s){return t.subscribe?t.subscribe(r):Fn(t,"subscribe")},{type:"read"});static publish=kn(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.publish?t.publish(s,r):Fn(t,"publish")},{hasContent:!0,type:"create"});static search=kn(function(t,r,n,s){let i=t.search?t.search(r):Fn(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=Cm(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=kn(function(t,r,n,s){return t.search?t.search(s,r):Fn(t,"search")},{hasContent:!0,type:"read"});static copy=kn(function(t,r,n,s){return t.copy?t.copy(s,r):Fn(t,"copy")},{hasContent:!0,type:"create"});static move=kn(function(t,r,n,s){return t.move?t.move(s,r):Fn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this.#n)return(await this.constructor.create(this.#e,t,this.#t)).#e;Fn(this,"post")}static isCollection(t){return t&&t.#n}get isCollection(){return this.#n}static coerceId(t){return t}static parseQuery(t){return Nm(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1),c=r?.headers&&o3[o];if(c)r.requestedContentType=c,t=t.slice(0,s);else if(this.attributes?.find(l=>l.name===o))if(t=t.slice(0,s),n)n.property=o;else return{query:{property:o},id:IL(t,this),isCollection:Dc}}let i=IL(t,this);return Dc?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r.getContext?.(),o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let u=l.asMap.get(t);if(s=u?.find(f=>f.constructor===c),s)return s;u||l.asMap.set(t,u=[]),u.push(s=new c(t,i))}else{if(s=l.find(u=>u.#e===t&&u.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let u=new Map;for(let f of l){let d=f.#e,p=u.get(d);p?p.push(f):u.set(d,[f])}i.resourceCache.length=0,i.resourceCache.asMap=u}}}else s=new c(t,i);return o&&(s.#n=!0),s}subscribe(t){return new Hn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new Hn}allowRead(t){return t?.role.permission.super_user}allowUpdate(t){return t?.role.permission.super_user}allowCreate(t){return t?.role.permission.super_user}allowDelete(t){return t?.role.permission.super_user}getId(){return this.#e}getContext(){return this.#t}};(0,PL._assignPackageExport)("Resource",Vr);a(a3,"snake_case");wm=class extends Error{static{a(this,"AccessError")}constructor(t){t?(super("Unauthorized access to resource"),this.statusCode=403):(super("Must login"),this.statusCode=401)}};a(IL,"pathToId");Im=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(kn,"transactional");a(Fn,"missingMethod");a(gR,"selectFromObject");a(Cm,"transformForSelect")});var Sa,TR=be(()=>{Sa=class{constructor(t){this.error=t}static{a(this,"ErrorResource")}isError=!0;allowRead(){throw this.error}allowUpdate(){throw this.error}allowCreate(){throw this.error}allowDelete(){throw this.error}getId(){throw this.error}getContext(){throw this.error}get(){throw this.error}post(){throw this.error}put(){throw this.error}delete(){throw this.error}connect(){throw this.error}getResource(){return this}publish(){throw this.error}subscribe(){throw this.error}}});var vL={};Ue(vL,{Resources:()=>Pm,keyArrayToString:()=>Tu,resetResources:()=>c3,resources:()=>Ni});function c3(){return Ni=new Pm}function Tu(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var LL,ML,Pm,Ni,Au=be(()=>{Cc();TR();LL=M(W()),ML=M(pe()),Pm=class extends Map{static{a(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,exportTypes:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s){let c=new ML.ServerError(`Conflicting paths for ${t}`);LL.default.error(c),i.Resource=new Sa(c)}super.set(t,i);for(let[c,l]of this){let u=2;for(;(u=c.indexOf("/",u))>-1;){let f=this.get(c.slice(0,u));f&&(f.hasSubPaths=!0),u+=2}}}getMatch(t,r){let n=2,s=0,i,o=t.length;for(;n<o;){s=n,n=t.indexOf("/",n),n===-1&&(n=o);let u=n===o?t:t.slice(0,n),f=this.get(u),d=-1;if(!f&&n===o&&(d=u.indexOf("?",s),d!==-1)){let p=u.slice(0,d);f=this.get(p)}if(f&&(!r||f.exportTypes?.[r]!==!1)){if(f.relativeURL=t.slice(d!==-1?d:n),!f.hasSubPaths)return f;i=f}n+=2}if(i)return i;let c=t.indexOf("?"),l=c>-1?t.slice(0,c):t;return i=this.get(l),!i&&l.indexOf(".")>-1&&(i=this.get(l.split(".")[0])),i&&(!r||i.exportTypes?.[r]!==!1)?i.relativeURL=c>-1?t.slice(c):"":i||(i=this.get(""),i&&(!r||i.exportTypes?.[r]!==!1)&&(t.charAt(0)!=="/"&&(t="/"+t),i.relativeURL=t)),i}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return Nt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(c3,"resetResources");a(Tu,"keyArrayToString")});var Ru={};Ue(Ru,{server:()=>We});var UL,We,Kr=be(()=>{UL=M(Ai()),We={};(0,UL._assignPackageExport)("server",We)});var yR={};Ue(yR,{loadGQLSchema:()=>d3,start:()=>RR,startOnMainThread:()=>u3});function RR({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:u,StringValueNode:f}=await import("graphql"),d=o(new c(r.toString(),s)),p=new Map,_=[],h;for(let R of d.definitions)switch(R.kind){case l.OBJECT_TYPE_DEFINITION:let F=function(Y){if(Y.kind==="NonNullType"){let j=F(Y.type);return j.nullable=!1,j}if(Y.kind==="ListType")return{type:"array",elements:F(Y.type)};let oe={type:Y.name?.value};return Object.defineProperty(oe,"location",{value:Y.loc.startToken}),oe};a(F,"getProperty");let E=R.name.value,A=[],N={table:null,database:null,properties:A};p.set(E,N);for(let Y of R.directives){if(Y.name.value==="table"){for(let oe of Y.arguments)N[oe.name.value]=oe.value.value;N.schema&&(N.database=N.schema),N.table||(N.table=E),N.audit&&(N.audit=N.audit!=="false"),N.attributes=N.properties,_.push(N)}if(Y.name.value==="sealed"&&(N.sealed=!0),Y.name.value==="splitSegments"&&(N.splitSegments=!0),Y.name.value==="replicate"&&(N.replicate=!0),Y.name.value==="export"){N.export=!0;for(let oe of Y.arguments)typeof N.export!="object"&&(N.export={}),N.export[oe.name.value]=oe.value.value}}let v=!1,$={};for(let Y of R.fields){let ee=F(Y.type);ee.name=Y.name.value,A.push(ee),$[ee.name]=void 0;for(let oe of Y.directives){let j=oe.name.value;if(j==="primaryKey")v?console.warn("Can not define two attributes as a primary key at",oe.loc):(ee.isPrimaryKey=!0,v=!0);else if(j==="indexed")ee.indexed=!0;else if(j==="computed"){for(let se of oe.arguments||[])if(se.name.value==="from"){let z=se.value.value;ee.computed={from:g(z,se,$)},ee.version==null&&(ee.version=z)}else se.name.value==="version"&&(ee.version=se.value.value);ee.computed=ee.computed||!0}else if(j==="relationship"){let se={};for(let z of oe.arguments)se[z.name.value]=z.value.value;ee.relationship=se}else if(j==="createdTime")ee.assignCreatedTime=!0;else if(j==="updatedTime")ee.assignUpdatedTime=!0;else if(j==="expiresAt")ee.expiresAt=!0;else if(j==="allow"){let se=ee.authorizedRoles=[];for(let z of oe.arguments)z.name.value==="role"&&se.push(z.value.value)}else server.knownGraphQLDirectives.includes(j)&&console.warn(`@${j} is an unknown directive, at`,oe.loc)}}N.type=E,E==="Query"&&(h=N)}function S(R){let E=p.get(R.type);E?(Object.defineProperty(R,"properties",{value:E.properties}),Object.defineProperty(R,"definition",{value:E})):R.type==="array"?S(R.elements):l3.includes(R.type)||(0,BL.getWorkerIndex)()===0&&console.error(`The type ${R.type} is unknown at line ${R.location.line}, column ${R.location.column}, in ${s}`)}a(S,"connectPropertyType");for(let R of p.values())for(let E of R.properties)S(E);for(let R of _)R.tableClass=e(R),R.export&&(R.export.name===""?i.set((0,AR.dirname)(n),R.tableClass):i.set((0,AR.dirname)(n)+"/"+(R.export.name||R.type),R.tableClass,R.export));function g(R,E,A){return new xL.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${R}; } } } } computed;`,{filename:s,lineOffset:E.loc.startToken.line-1,columnOffset:E.loc.startToken.column}).runInThisContext()(A)}a(g,"createComputedFrom")}}var AR,xL,BL,l3,u3,d3,HL=be(()=>{AR=require("path"),xL=require("node:vm");De();BL=M(rt()),l3=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt","Blob"];server.knownGraphQLDirectives&&(server.knownGraphQLDirectives=["table","sealed","export","primaryKey","indexed","computed","relationship","createdTime","updatedTime","expiresAt","allow"]);a(RR,"start");u3=RR,d3=RR({ensureTable:dt}).handleFile});var KL={};Ue(KL,{parse:()=>OR,streamAsJSON:()=>Vf,stringify:()=>Lc});function Vf(e){return new bR({value:e})}function kL(e){return console.error(e),JSON.stringify(e.toString())}function FL(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Lc(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===$L)return VL(e);if(t.resolution)return t.resolution.then(()=>Lc(e));throw t}}function VL(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+=VL(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Lc(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function OR(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),p3.test(e)?f3.parse(e):JSON.parse(e)):null}var GL,qL,f3,_3,$L,bR,p3,NR=be(()=>{GL=require("stream"),qL=M(require("json-bigint-fixes")),f3=(0,qL.default)({useNativeBigInt:!0}),_3=1e4,$L={message:"Cannot serialize BigInt to JSON"};BigInt.prototype.toJSON=function(){throw $L};a(Vf,"streamAsJSON");bR=class extends GL.Readable{static{a(this,"JSONStream")}constructor(t){super(t),this.buffer=[],this.bufferSize=0,this.iterator=this.serialize(t.value,!0),this.activeIterators=[]}*serialize(t){if(t&&typeof t=="object"){let r=t[Symbol.asyncIterator],n=t[Symbol.iterator];if((n||r)&&!t.then){yield"[";let s=!0;if((r||n)&&!(t instanceof Array)){let i=r?t[Symbol.asyncIterator]():t[Symbol.iterator]();this.activeIterators.push(i);let o;for(;;){try{o=i.next(),o.then&&(yield o.then(c=>(o=c,""),c=>(o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")},"")))}catch(c){o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")}}if(o.done){this.activeIterators.splice(this.activeIterators.indexOf(i),1),yield"]";return}else s?s=!1:yield",",yield*this.serialize(o.value)}}for(let i of t)s?s=!1:yield",",yield*this.serialize(i);yield"]";return}if(t.then)try{yield t.then(s=>this.serialize(s),kL)}catch(s){yield kL(s)}else yield Lc(t)}else yield Lc(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);FL(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>_3?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 FL(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(kL,"handleError");a(FL,"when");a(Lc,"stringify");a(VL,"jsStringify");p3=/[[,:]\s*-?\d{16,}/;a(OR,"parse")});var wi=I(Lm=>{var Dm=W();for(let e of["trace","debug","info","warn","error","fatal","notify"])Dm.logsAtLevel(e)&&(Lm[e]=Dm[e]);Lm.loggerWithTag=e=>Dm.loggerWithTag(e,!0);Lm.setLogLevel=Dm.setLogLevel});var qm={};Ue(qm,{Blob:()=>Ii,blobsWereEncoded:()=>vc,databasePaths:()=>Um,decodeBlobsWithWrites:()=>PR,decodeFromDatabase:()=>Uc,decodeWithBlobCallback:()=>DR,deleteBlob:()=>eM,deleteBlobsInObject:()=>Aa,deleteRootBlobPathsForDB:()=>CR,encodeBlobsAsBuffers:()=>b3,encodeBlobsWithFilePath:()=>Gm,findBlobsInObject:()=>bu,getFileId:()=>km,getFilePathForBlob:()=>rM,getRootBlobPathsForDB:()=>Fm,setDeletionDelay:()=>g3});function XL(){}function eM(e){let t=rM(e);t&&setTimeout(()=>{(0,Qe.unlink)(t,r=>{r&&Ta.default.debug?.("Error trying to remove blob file",r)})},ZL)}function g3(e){ZL=e}function tM(e){let t=gn.get(e);if(!t)t={storageIndex:0,fileId:null,store:Js},gn.set(e,t);else{if(t.saving)return t;t.store=Js}return T3(t),t.source?wR(e,t.source,t):t.contentBuffer?S3(e,t):wR(e,Yf.Readable.from(e.stream()),t),t}function wR(e,t,r){let{filePath:n,fileId:s,store:i,compress:o,flush:c}=r;return r.saving=new Promise((l,u)=>{let f=s+":blob";if(!i.attemptLock(f,0))throw new Error(`Unable to get lock for blob file ${s}`);let d=(0,Qe.createWriteStream)(n,{autoClose:!1,flags:"w"});if(t.errored){let g=Buffer.from(t.errored.toString());d.end(Buffer.concat([h(BigInt(g.length)+0xff000000000000n),g]));return}let p=!1;e.size!==void 0&&(d.write(h(e.size)),p=!0);let _;o?(p||d.write(m3),_=(0,Bm.createDeflate)(),t.pipe(_).pipe(d)):(p||d.write(h3),t.pipe(d)),t.on("error",S);function h(g){let R=BigInt(g),E=new Uint8Array(gr),A=new DataView(E.buffer);return R|=BigInt(o?IR:QL)<<48n,A.setBigInt64(0,R),E}a(h,"createHeader");function S(g){i.unlock(f,0);let R=d.fd;g?(R&&(0,Qe.close)(R),u(g)):c?(0,Qe.fdatasync)(R,E=>{E&&u(E),l(),(0,Qe.close)(R)}):(l(),(0,Qe.close)(R))}a(S,"finished"),d.on("error",S).on("finish",()=>{if(p)S();else{let g=_?_.bytesWritten:d.bytesWritten-gr;e.size=g,(0,Qe.write)(d.fd,h(g),0,gr,0,S)}})}),e}function km(e){return gn.get(e)?.fileId}function rM(e){let t=gn.get(e);return t?.fileId&&Wf(t)}function Fm(e){if(!e)throw new Error("No store specified, can not determine blob storage path");let t=Um.get(e);if(!t){if(!e.databaseName)throw new Error("No database name specified, can not determine blob storage path");let r=(0,Hm.get)(x.STORAGE_BLOBPATHS);r?t=r.map(n=>(0,ao.join)(n,e.databaseName)):t=[(0,ao.join)((0,Hm.getHdbBasePath)(),"blobs",e.databaseName)],Um.set(e,t)}return t}async function CR(e){let t=Um.get(e);t&&await Promise.all(t.map(r=>nM(r)))}async function nM(e){for(let t of await(0,Qs.readdir)(e,{withFileTypes:!0}))if(t.isDirectory())await nM((0,ao.join)(e,t.name));else try{await(0,Qs.unlink)((0,ao.join)(e,t.name))}catch(r){Ta.default.warn?.("Error deleting file",r)}try{await(0,Qs.rmdir)(e)}catch(t){Ta.default.warn?.("Error deleting directory",t)}}function Wf({storageIndex:e,fileId:t,store:r}){let n=Fm(r);return(0,ao.join)(n[e],t.slice(-9,-6)||"0",t.slice(-6,-3)||"0",t.length<=9?t.slice(-3):t.slice(0,-9)+t.slice(-3))}function S3(e,t){let r=t.contentBuffer,n=r.length;if(!(n<JL))return e.size=n,wR(e,Yf.Readable.from([r]),t)}function T3(e){let t=Fm(e.store),r=A3(),n=t?.length>1?R3(t,r):0,s=r.toString(16);e.storageIndex=n,e.fileId=s;let i=Wf(e),o=(0,ao.dirname)(i);(0,Qe.existsSync)(o)||(0,jL.ensureDirSync)(o),e.filePath=i}function A3(){let e=zL.get(Js);if(!e){let t=0,r=Fm(Js);for(let n of r){let s=0;for(let i=0;i<3;i++){s=s*4096;let o=0;if((0,Qe.existsSync)(n))for(let c of(0,Qe.readdirSync)(n)){let l=parseInt(c,16);i===2&&c.length>3&&(l=parseInt(c.slice(-3),16),l+=parseInt(c.slice(0,-3),16)*68719476736),l>o&&(o=l)}s+=o,n=(0,ao.join)(n,o.toString(16))}t=Math.max(t,s)}e=new BigInt64Array([BigInt(t)+1n]),e=new BigInt64Array(Js.getUserSharedBuffer("blob-file-id",e.buffer)),zL.set(Js,e)}return Number(Atomics.add(e,0,1n))}function R3(e,t){let r=Date.now();if(!e.frequencyTable){e.lastUpdated=0;let s=new Array(xm);for(let i=0;i<s.length;i++)s[i]=i%e.length;e.frequencyTable=s}return(e.lastUpdated??0)+6e4<r&&(e.lastUpdated=r,y3(e)),e.frequencyTable[t%xm]}async function y3(e){if(!Qs.statfs)return;let t=await Promise.all(e.map(async(s,i)=>{let o=await(0,Qs.statfs)(s),c=o.bavail*o.bsize;return Math.pow(c,.8)})),r=new Array(xm),n=t.map(s=>1/s);for(let s=0;s<xm;s++){let i=1/0,o=0;for(let c=0;c<n.length;c++)n[c]<i&&(o=c,i=n[c]);n[o]+=1/t[o],r[s]=o}e.frequencyTable=r}function Gm(e,t,r){yu=t,Js=r,vc=!1;try{return e()}finally{yu=void 0,Js=void 0}}function b3(e){Dr=[];let t;try{t=e()}catch(n){throw Dr=void 0,n}let r=Dr.length<2?Dr[0]:Promise.all(Dr);return Dr=void 0,r?r.then(()=>e()):t}function PR(e,t){try{Dr=[],Mc=t,e()}catch(n){throw Mc=void 0,Dr=void 0,n}Mc=void 0;let r=Dr.length<2?Dr[0]:Promise.all(Dr);return Dr=void 0,r}function DR(e,t){try{return Mc=t,e()}finally{Mc=void 0}}function Uc(e,t){return Js=t,e()}function Aa(e){bu(e,t=>{eM(t)})}function bu(e,t){if(e instanceof Ii)t(e);else if(Array.isArray(e))for(let r of e)typeof r=="object"&&r&&bu(r,t);else if(e.constructor===Object)for(let r in e){let n=e[r];typeof n=="object"&&n&&bu(e[r],t)}}function O3(){return class{static{a(this,"Blob")}content;constructor(t){this.content=t[0]}stream(){return new ReadableStream({start(t){t.enqueue(this.content),t.close()}})}text(){return Promise.resolve(this.content.toString())}arrayBuffer(){return Promise.resolve(this.content.buffer)}get size(){return this.content.length}slice(){throw new Error("Not implemented")}bytes(){return Promise.resolve(this.content)}get type(){return""}}}var oo,Qs,Qe,Bm,Yf,jL,Hm,ao,Ta,JL,gr,QL,IR,YL,h3,m3,WL,gn,Mc,Ii,yu,Dr,Js,vc,Kf,Mm,E3,vm,ZL,Um,zL,xm,Ss=be(()=>{oo=require("msgpackr"),Qs=require("node:fs/promises"),Qe=require("node:fs"),Bm=require("node:zlib"),Yf=require("node:stream"),jL=require("fs-extra"),Hm=M(ce());H();ao=require("path"),Ta=M(wi());co();JL=8192,gr=8,QL=0,IR=1,YL=255,h3=new Uint8Array([0,QL,255,255,255,255,255,255]),m3=new Uint8Array([0,IR,255,255,255,255,255,255]),WL=0xffffffffffff,gn=new WeakMap,Ii=global.Blob||O3(),vc=!1,Kf=new Uint8Array(8),Mm=new DataView(Kf.buffer),E3=6e4;a(XL,"InstanceOfBlobWithNoConstructor");XL.prototype=Ii.prototype;vm=class e extends XL{static{a(this,"FileBackedBlob")}type="";size;#e;#t;constructor(t){super(),t?.type&&(this.type=t.type),t?.size!=null&&(this.size=t.size)}on(t,r){if(t==="error")this.#e??=[],this.#e.push(r);else if(t==="size")this.#t??=[],this.#t.push(r);else throw new Error("Only 'error' and 'size' events are supported")}toJSON(){if(this.type?.startsWith("text")){let t=gn.get(this),{start:r,end:n,contentBuffer:s,asString:i}=t;return i||(s&&(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),s?(t.asString=s.toString(),t.asString):(MR()&&LR(this.bytes().then(o=>t.contentBuffer=o)),`[blob: ${this.type}, ${this.size} bytes]`))}return{description:"Blobs that are not of type text/* can not be directly serialized as JSON, use as the body of a response or convert to another type"}}async text(){return(await this.bytes()).toString()}bytes(){let t=gn.get(this),{start:r,end:n,contentBuffer:s}=t;if(s)return(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),Promise.resolve(s);let i=Wf(t),o,c=a(async()=>{let l,u=gr;try{if(l=await(0,Qs.readFile)(i),l.length>=gr){l.copy(Kf,0,0,gr);let d=Mm.getBigUint64(0);if(Number(d>>48n)===YL)throw new Error("Error in blob: "+buffer.subarray(gr));if(u=Number(d&0xffffffffffffn),u<n&&(u=n),u<WL&&(this.size=u,this.#t))for(let p of this.#t)p(u)}}catch(d){if(d.code!=="ENOENT")throw d;l=Buffer.alloc(0)}function f(d){if(u>d.length){let p=t.store,_=t.fileId+":blob";if(o)throw new Error("Incomplete blob");return new Promise((h,S)=>{if(p.attemptLock(_,0,()=>(o=!0,p.unlock(_,0),h(c()))))return o=!0,p.unlock(_,0),h(c())})}return(n!=null||r!=null)&&(d=d.subarray(r??0,n??d.length)),d}return a(f,"checkCompletion"),l[1]===IR?new Promise((d,p)=>{(0,Bm.deflate)(l.subarray(gr),(_,h)=>{_?p(_):d(f(h))})}):f(l.subarray(gr))},"readContents");return c()}async arrayBuffer(){let t=await this.bytes(),r=new ArrayBuffer(t.length);return new Uint8Array(r).set(t),r}stream(){let t=gn.get(this),{contentBuffer:r,start:n,end:s}=t;if(r)return(s!=null||n!=null)&&(r=r.subarray(n??0,s??t.contentBuffer.length)),new ReadableStream({pull(S){S.enqueue(r),S.close()}});let i=Wf(t),o,c=0,l=0,u,f,d,p=!1,_=this;return new ReadableStream({start(){let S=1e3,g=a((R,E)=>{(0,Qe.open)(i,"r",(A,N)=>{if(A){if(A.code==="ENOENT"&&d!==!1&&(Ta.default.debug?.("File does not exist yet, waiting for it to be created",i,S),S-- >0))return setTimeout(()=>{h(),g(R,E)},20).unref();E(A),_.#e?.forEach(v=>v(A))}else o=N,R(N)})},"openFile");return new Promise(g)},pull:a(S=>{let g=0,R=100;return new Promise(a(function E(A,N){function v($){(0,Qe.close)(o),clearTimeout(f),u&&u.close(),N($),_.#e?.forEach(Y=>Y($))}a(v,"onError");let F=Buffer.allocUnsafe(262144);(0,Qe.read)(o,F,0,F.length,c,($,Y,ee)=>{if(l+=Y,$)return v($);if(c===0){if(Y<gr){R-- >0&&d!==!1?(h(),Ta.default.debug?.("File was empty, waiting for data to be written",i,R),setTimeout(()=>E(A,N),20).unref()):(Ta.default.debug?.("File was empty, throwing error",i,R),N(new Error(`Blob ${t.fileId} was empty`)));return}ee.copy(Kf,0,0,gr);let oe=Mm.getBigUint64(0);if(Number(oe>>48n)===YL)return v(new Error("Error in blob: "+ee.subarray(gr)));if(g=Number(oe&0xffffffffffffn),g<WL&&_.size!==g&&(_.size=g,_.#t))for(let j of _.#t)j(g);ee=ee.subarray(gr,Y),l-=gr}else if(Y===0){let oe=Buffer.allocUnsafe(8);return(0,Qe.read)(o,oe,0,gr,0,j=>{if(j)return v(j);if(Kf.set(oe),g=Number(Mm.getBigUint64(0)&0xffffffffffffn),g>l){h()?u?f=setTimeout(()=>{v(new Error("File read timed out"))},E3).unref():(u=(0,Qe.watch)(i,{persistent:!1},()=>{u.close(),u=null,f&&(clearTimeout(f),f=null,E(A,N))}),E(A,N)):p?v(new Error("Blob is incomplete")):(p=!0,E(A,N));return}(0,Qe.close)(o),S.close(),A()})}else ee=ee.subarray(0,Y);if(n!==void 0||s!==void 0){if(n&&l<n)return c+=Y,E(A,N);s&&l>=s&&(l>s&&(ee=ee.subarray(0,s-c)),l=g=s),n&&n>c&&(ee=ee.subarray(n-c))}c+=Y;try{S.enqueue(ee)}catch(oe){return Ta.default.debug?.("Error enqueuing chunk",oe),A()}l===g&&((0,Qe.close)(o),S.close()),A()})},"readMore"))},"pull"),cancel(){(0,Qe.close)(o),clearTimeout(f),u&&u.close()}});function h(){if(d===void 0){let S=t.store,g=t.fileId+":blob";d=!S.attemptLock(g,0,()=>{d=!1,S.unlock(g,0)}),d||S.unlock(g,0)}return d}}slice(t,r,n){let s=gn.get(this),i=new e(n&&{type:n});if(s?.fileId){let o={...s,start:t,end:r};gn.set(i,o),this.size!=null&&(i.size=(r==null?this.size:Math.min(r,this.size))-(t??0))}else if(s?.contentBuffer&&!s.storageBuffer){let o={...s,contentBuffer:s.contentBuffer.subarray(t,r)};gn.set(i,o),i.size=(r??this.size)-t}else throw new Error("Can not slice a streaming blob that is not backed by a file");return i}save(t){if(!t?.primaryStore?.rootStore)throw new Error("No target table specified");return tM(this).saving??Promise.resolve()}},ZL=500;a(eM,"deleteBlob");a(g3,"setDeletionDelay");global.createBlob=function(e,t){let r=new vm(t),n={storageIndex:0,fileId:null,flush:t?.flush,compress:t?.compress};if(gn.set(r,n),e instanceof Uint8Array)r.size=e.length,n.contentBuffer=e;else if(e instanceof Yf.Readable)n.source=e;else if(typeof e=="string")n.contentBuffer=Buffer.from(e);else if(e?.[Symbol.asyncIterator]||e?.[Symbol.iterator])n.source=Yf.Readable.from(e);else throw new Error("Invalid source type");return r};a(tM,"saveBlob");a(wR,"writeBlobWithStream");a(km,"getFileId");a(rM,"getFilePathForBlob");Um=new Map;a(Fm,"getRootBlobPathsForDB");a(CR,"deleteRootBlobPathsForDB");a(nM,"rimrafSteadily");a(Wf,"getFilePath");a(S3,"writeBlobWithBuffer");a(T3,"generateFilePath");zL=new Map;a(A3,"getNextFileId");xm=128;a(R3,"getNextStorageIndex");a(y3,"createFrequencyTableForStoragePaths");a(Gm,"encodeBlobsWithFilePath");a(b3,"encodeBlobsAsBuffers");a(PR,"decodeBlobsWithWrites");a(DR,"decodeWithBlobCallback");a(Uc,"decodeFromDatabase");a(Aa,"deleteBlobsInObject");a(bu,"findBlobsInObject");(0,oo.addExtension)({Class:Ii,type:11,unpack:a(function(e){let t=(0,oo.unpack)(e),r=new vm;if(Object.assign(r,t[0]),typeof t[1]!="object"){if(!Js)throw new Error("No store specified, can not load blob from storage");if(gn.set(r,{storageIndex:t[1],fileId:t[2],store:Js}),Mc)return Mc(r)??r}else gn.set(r,{storageIndex:0,fileId:null,storageBuffer:e,contentBuffer:t[1]}),r.size=t[1]?.length;return r},"unpack"),pack:a(function(e){let t=gn.get(e);if(yu!==void 0&&(vc=!0,t?.recordId!==void 0&&t.recordId!==yu))throw new Error("Cannot use the same blob in two different records");let r={...e};if(e.type&&(r.type=e.type),e.size!==void 0&&(r.size=e.size),t){if(t.storageBuffer)return t.storageBuffer;if(t.contentBuffer?.length<JL)return r.size=t.contentBuffer.length,(0,oo.pack)([r,t.contentBuffer])}if(yu!==void 0){if(t=tM(e),!t.fileId)throw new Error("Unable to save blob without file id");return t.recordId=yu,(0,oo.pack)([r,t.storageIndex,t.fileId])}if(t)try{let n=(0,Qe.readFileSync)(Wf(t));if(n.length>=gr&&(n.copy(Kf,0,0,gr),Number(Mm.getBigUint64(0)&0xffffffffffffn)===n.length-gr))return Buffer.concat([(0,oo.pack)([r]),n]);if(Dr)Dr.push(e.bytes());else throw new Error("Incomplete blob");return Buffer.alloc(0)}catch(n){if(n.code==="ENOENT"&&Dr)return Dr.push(e.bytes()),Buffer.alloc(0);throw n}else throw new Error("Blob has no storage info or buffer attached to it")},"pack")});(0,oo.addExtension)({Class:Promise,type:12,pack(){throw new Error("Cannot encode a promise")}});a(O3,"polyfillBlob")});var dM={};Ue(dM,{asyncSerialization:()=>LR,contentTypes:()=>BR,findBestSerializer:()=>Vm,getDeserializer:()=>fo,hasAsyncSerialization:()=>MR,registerContentHandlers:()=>Jf,serialize:()=>Qf,serializeMessage:()=>Ra,toCsvStream:()=>$m});function w3(e){try{return e?.[0]===123?xR(e):e}catch{return e}}function Jf(e){e.register(C3,{serializers:[{regex:/^application\/json$/,serializer:Vf},{regex:/^application\/cbor$/,serializer:a(function(t){return new xc.EncoderStream(jf).end(t)},"serializer")},{regex:/^application\/(x-)?msgpack$/,serializer:a(function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?Bc.Readable.from((0,Ci.encodeIter)(t,jf)):(0,Ci.pack)(t)},"serializer")},{regex:/^text\/csv$/,serializer:a(function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),$m(t)},"serializer")}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Ci.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,xc.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function Vm(e){let t=e.headers.asObject||e.headers,r=e.requestedContentType??t.accept,n,s=0,i,o,c=r?r.toLowerCase().split(/\s*,\s*/):[];for(let l of c){let[u,...f]=l.split(/\s*;\s*/),d=1,p={q:1};for(let h of f){let S=h.indexOf("=");p[h.substring(0,S)]=h.substring(S+1)}d=+p.q;let _=Yr.get(u);if(_){let h=(_.q||1)*d;h>s&&(n=_,i=_.type||u,s=h,o=p)}}if(!n){if(r)throw new oM.ClientError("No supported content types found in Accept header, supported types include: "+Array.from(Yr.keys()).join(", "),406);n=Yr.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function Qf(e,t,r){let n=iM&&t.headers.asObject?.["accept-encoding"]?.includes("br"),s;if(e?.contentType!=null&&e.data!=null)r.headers.set("Content-Type",e.contentType),r.headers.set("Vary","Accept-Encoding"),s=e.data;else if(e instanceof Uint8Array||e instanceof Ii)r.headers.set("Content-Type","application/octet-stream"),r.headers.set("Vary","Accept-Encoding"),s=e;else{let i=Vm(t);if(i.serializer.compressible===!1&&(n=!1),r.headers.set("Vary","Accept, Accept-Encoding"),r.headers.set("Content-Type",i.type),typeof e=="object"&&e&&(e[Symbol.iterator]||e[Symbol.asyncIterator])&&i.serializer.serializeStream){if(e.mapError){let c=e.getColumns;e=e.mapError(l=>(l.toJSON=()=>({error:l.name,message:l.message,...l.partialObject}),UR.default.warn?.(`Error serializing error ${t?.url||t}: ${l}`),l)),e.getColumns=c}let o=i.serializer.serializeStream(e,r);return n&&(r.headers.set("Content-Encoding","br"),o=o.pipe((0,uo.createBrotliCompress)({params:{[uo.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?uo.constants.BROTLI_MODE_TEXT:uo.constants.BROTLI_MODE_GENERIC,[uo.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>iM?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,uo.brotliCompress)(s,(c,l)=>{c?o(c):i(l)}))):s}function Ra(e,t,r){if(e?.contentType!=null&&e.data!=null)return e.data;lo=r?void 0:[];try{let n;if(t){let s=t.serialize;if(s)n=s(e);else{let i=Vm(t);s=t.serialize=i.serializer.serialize,n=s(e)}}else n=zf(e);return lo?.length>0?(lo.length===1?lo[0]:Promise.all(lo)).then(()=>Ra(e,t,!0)):n}finally{lo=void 0}}function LR(e){if(lo)lo.push(e);else throw new Error("Unable to serialize asynchronously")}function MR(){return!!lo}function P3(e){return new Promise((t,r)=>{let n=[];e.on("data",s=>n.push(s)),e.on("end",()=>t(Buffer.concat(n))),e.on("error",r)})}function L3(e){return D3.includes(e)}function M3(e){let t=e.indexOf(";"),r;if(t>-1){r={};let n=e.slice(t+1).split(";");for(let s of n){let[i,o]=s.split("=");r[i.trim()]=o.trim()}e=e.slice(0,t)}return{type:e,parameters:r}}function fo(e="",t=!1){let r=M3(e),n=r.type&&Yr.get(r.type)?.deserialize||v3(r);return t?s=>P3(s).then(n):n}function v3(e){return e.type.startsWith("text/")?(e.parameters?.charset&&!L3(e.parameters.charset)&&UR.default.info(`Unknown Buffer encoding ${e.parameters.charset} in content-type. Proceeding anyways.`),t=>({contentType:e.type,data:t.toString(e.parameters?.charset||"utf-8")})):e.type==="application/octet-stream"?t=>t:t=>{if(e.type==="")try{if(t?.[0]===123)return xR(t)}catch{}return{contentType:e.type||"application/octet-stream",data:t}}}function U3(e,t){return{[Symbol.asyncIterator](){let r=e[Symbol.asyncIterator]?e[Symbol.asyncIterator]():e[Symbol.iterator]();return{next(){let n=r.next();return n.then?n.then(s=>({value:t(s.value),done:s.done})):{value:t(n.value),done:n.done}},return(n){return r.return(n)},throw(n){return r.throw(n)}}}}}function $m(e,t){let r=Bc.default.Readable.from(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator]?e:[e]),n={};t&&(n.fields=t.map(o=>({label:o,value:o})));let s={objectMode:!0},i=new N3(n,s);return r.pipe(i)}var Ci,xc,uo,oM,Bc,aM,vR,cM,UR,N3,lM,zf,xR,jf,Yr,BR,sM,uM,I3,C3,iM,lo,D3,co=be(()=>{NR();Ci=require("msgpackr"),xc=require("cbor-x"),uo=require("zlib"),oM=M(pe()),Bc=M(require("stream"));Kr();aM=M(Ai()),vR=M(ce());H();cM=M(require("yaml")),UR=M(wi());Ss();({Transform:N3}=require("json2csv")),lM=vR.default.get(x.SERIALIZATION_BIGINT)!==!1,zf=lM?Lc:JSON.stringify,xR=lM?OR:JSON.parse,jf={useRecords:!1,useToJSON:!0},Yr=new Map,BR=Yr;We.contentTypes=BR;(0,aM._assignPackageExport)("contentTypes",BR);Yr.set("application/json",{serializeStream:Vf,serialize:zf,deserialize(e){return xR(e)},q:.8});sM=new xc.Encoder(jf);Yr.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new xc.EncoderStream(jf).end(e)},serialize:sM.encode,deserialize:sM.decode,q:1});Yr.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?Bc.Readable.from((0,Ci.encodeIter)(e,jf)):(0,Ci.pack)(e)},serialize:Ci.pack,deserialize:Ci.unpack,q:.9});Yr.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),$m(e,e?.getColumns?.())},serialize(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),e&&!e[Symbol.iterator]&&(e=[e.toJSON?e.toJSON():e]),$m(e,e?.getColumns?.())},q:.1});Yr.set("text/plain",{serialize(e){return e.toString()},serializeStream(e){return Bc.Readable.from(e.map?e.map(t=>t.toString()):e)},deserialize(e){return e.toString()},q:.2});Yr.set("text/yaml",{serialize(e){return cM.stringify(e,{aliasDuplicateObjects:!1})},q:.7});Yr.set("text/event-stream",{serializeStream:a(function(e){return Bc.Readable.from(U3(e,this.serialize))},"serializeStream"),serialize:a(function(e){if(e.acknowledge&&e.acknowledge(),typeof e=="object"&&"value"in e&&e.timestamp&&(e={data:e.value,event:e.type,id:e.timestamp}),e.data||e.event){let t="";if(e.event&&(t+="event: "+e.event+`
9
+ `),e.data){let r=e.data;typeof r=="object"&&(r=zf(r)),t+="data: "+r+`
10
10
  `}return e.id&&(t+="id: "+e.id+`
11
11
  `),e.retry&&(t+="retry: "+e.retry+`
12
12
  `),t+`
13
- `}else return typeof e=="object"?`data: ${Wf(e)}
13
+ `}else return typeof e=="object"?`data: ${zf(e)}
14
14
 
15
15
  `:`data: ${e}
16
16
 
17
- `},"serialize"),compressible:!1,q:.8});Kr.set("application/x-www-form-urlencoded",{deserialize(e){let t=Buffer.isBuffer(e)?e.toString("utf8"):e,r={};for(let[n,s]of new URLSearchParams(t))if(r.hasOwnProperty(n)){let i=r[n];Array.isArray(i)?i.push(s):r.key=[i,s]}else r[n]=s;return r},serialize(e){let t=new URLSearchParams;for(let r in e)t.set(r,e);return t.toString()}});uM={type:"application/json",serializeStream:$f,serialize:Wf,deserialize:w3,q:.5};Kr.set("*/*",uM);Kr.set("",uM);a(w3,"tryJSONParse");a(jf,"registerContentHandlers");I3=require("fastify-plugin"),C3=I3(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=$m(n.raw);s.type(c),s.serializer(function(l){let u;if(typeof l=="object"&&l&&(l[Symbol.iterator]||l[Symbol.asyncIterator])&&o.serializeStream){if(l.mapError){let f=l.getColumns;l=l.mapError(d=>(d.toJSON=()=>({error:d.name,message:d.message,...d.partialObject}),d)),l.getColumns=f}u=o.serializeStream}else u=o.serialize;return u(l,{headers:{set:a((f,d)=>{s.header(f,d)},"set")}})})}),r()},{name:"content-type-negotiation"});a($m,"findBestSerializer");iM=MR.default.get(x.HTTP_COMPRESSIONTHRESHOLD);a(Jf,"serialize");a(Aa,"serializeMessage");a(DR,"asyncSerialization");a(LR,"hasAsyncSerialization");a(P3,"streamToBuffer");D3=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(L3,"isBufferEncoding");a(M3,"parseContentType");a(uo,"getDeserializer");a(v3,"deserializerUnknownType");a(U3,"transformIterable");a(qm,"toCsvStream")});var HR={};ve(HR,{start:()=>V3});function x3(e){if(e.kind!==Le.Kind.OPERATION_DEFINITION&&e.kind!==Le.Kind.FRAGMENT_DEFINITION)throw new Or(`Unexpected non-executable definition type ${e.kind}.`)}function fM(e){if(typeof e!="object"||e===null)throw new Ci("Request body must be an object.");if(!("query"in e))throw new Ci("Request body must contain a `query` field.");if(typeof e.query!="string")throw new Ci("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new Ci("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new Ci("Request body `operationName` field must be a string.")}function BR(e){return parseInt(e.value,10)}function pM(e){return parseFloat(e.value)}function hM(e,t,r){let n=r.get(e.name.value);return mM(n)?EM(n,t):{attribute:t,value:n}}function mM(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function EM(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],mM(n)?EM(n,t):{attribute:t,value:n}))}function B3(e,t,r){switch(t=[...t,e.name.value],e.value.kind){case Le.Kind.NULL:return{attribute:t,value:null};case Le.Kind.INT:return{attribute:t,value:BR(e.value)};case Le.Kind.FLOAT:return{attribute:t,value:pM(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:t,value:e.value.value};case Le.Kind.VARIABLE:return hM(e.value,t,r);case Le.Kind.OBJECT:return gM(e.value,t,r);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Or(`Value type, ${e.value.kind}, is not supported.`)}}function gM(e,t,r){return e.fields.flatMap(n=>B3(n,t,r))}function H3(e,t){switch(e.value.kind){case Le.Kind.NULL:return{attribute:e.name.value,value:null};case Le.Kind.INT:return{attribute:e.name.value,value:BR(e.value)};case Le.Kind.FLOAT:return{attribute:e.name.value,value:pM(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Le.Kind.VARIABLE:return hM(e.value,e.name.value,t);case Le.Kind.OBJECT:return gM(e.value,[e.name.value],t);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Or(`Argument type, ${e.value.kind}, is not supported.`)}}function k3(e,t){return e.flatMap(r=>H3(r,t))}function Vm(e,t){return e.selections.flatMap(r=>{switch(r.kind){case Le.Kind.FIELD:return r;case Le.Kind.FRAGMENT_SPREAD:{let n=r.name.value,s=t.get(n);if(s==null)throw new Or(`Fragment \`${n}\` not found.`);return Vm(s.selectionSet,t)}case Le.Kind.INLINE_FRAGMENT:return Vm(r.selectionSet,t)}})}function SM(e,t){return Vm(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:SM(r.selectionSet,t)}:r.name.value)}async function F3(e,t,r,n){let s=Oi.getMatch(e.name.value,"graphql");if(s===void 0)throw new Or(`Resource \`${e.name.value}\` not found.`);let i=s.Resource,o={select:SM(e.selectionSet,r),conditions:k3(e.arguments,t)},c=[];n.authorize=!0;for await(let l of i.search(o,n))c.push(l);return[e.name.value,c]}function TM(e){switch(e.kind){case Le.Kind.NULL:return null;case Le.Kind.INT:return BR(e);case Le.Kind.FLOAT:return parseFloat(e.value);case Le.Kind.STRING:case Le.Kind.BOOLEAN:return e.value;case Le.Kind.OBJECT:return e.fields.reduce((t,r)=>({[r.name.value]:TM(r.value),...t}),{});case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Or(`Value type, ${e.kind}, is not supported.`)}}function G3(e,t){let r=new Map;for(let n of e){let s=n.variable.name.value,i=t?.[s];if(i===void 0&&n.defaultValue!==void 0&&(i=TM(n.defaultValue)),n.type.kind===Le.Kind.NON_NULL_TYPE&&!(s in t)&&i===void 0)throw new Or(`Variable $${s} is required, but not provided.`);r.set(n.variable.name.value,i??null)}return r}async function q3(e,t,r,n){if(e.operation===Le.OperationTypeNode.SUBSCRIPTION)throw new Or("Subscriptions are not supported.");if(e.operation===Le.OperationTypeNode.MUTATION)throw new Or("Mutations are not supported yet.");let s=G3(e.variableDefinitions,t),i=await Promise.all(Vm(e.selectionSet,r).map(c=>F3(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function _M({query:e,variables:t={},operationName:r},n){let s=Le.parse(e),i=new Map,o=new Map;for(let u of s.definitions)if(x3(u),u.kind===Le.Kind.FRAGMENT_DEFINITION)o.set(u.name.value,u);else{if(u.name===void 0&&s.definitions.length>1)throw new Or("Unnamed operations are only allowed when there is a single operation in the document.");let f=u.name?.value??"Unnamed Query";if(i.has(f))throw new Or(`Duplicate operation definition: ${f}`);i.set(f,u)}let c;if(r==null)if(i.size===1)c=i.entries().next().value[1];else throw new Or("Operation name is required when there are multiple operations in the document.");else if(c=i.get(r),c==null)throw new Or(`Operation \`${r}\` not found.`);let l=await q3(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function $3(e){switch(e.method){case"GET":{let t=new URLSearchParams(e.url.split("?")[1]),r={};for(let[n,s]of t)r[n]=n==="variables"||n==="extensions"?JSON.parse(s):s;return fM(r),_M(r,e)}case"POST":{let r=await uo(e.headers.get("content-type"),!0)(e._nodeRequest);return fM(r),_M(r,e)}default:throw new Ci("Method Not Allowed",405,{Allow:"GET, POST"})}}function V3(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await $3(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof Ci)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json",...n.headers}};if(n instanceof Le.GraphQLError)return{status:200,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/json"}};if(n instanceof Or)return{status:200,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};break}default:logger.info(`Unsupported accept header, ${s}, defaulting to application/graphql-response+json`);case"application/graphql-response+json":{if(n instanceof Ci)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json",...n.headers}};if(n instanceof Le.GraphQLError)return{status:400,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Or)return{status:400,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};break}}throw n}},{port:e.port,securePort:e.securePort})}var Le,Or,Ci,AM=be(()=>{Le=M(require("graphql"));ao();Tu();a(x3,"assertExecutableDefinitionNode");a(fM,"assertRequestParams");a(BR,"processIntValueNode");a(pM,"processFloatValueNode");a(hM,"processVariableNode");a(mM,"isObject");a(EM,"transformObjectIntoQueryCondition");a(B3,"processObjectFieldNode");a(gM,"processObjectValueNode");a(H3,"processArgumentNode");a(k3,"buildConditionsQuery");a(Vm,"fillInFragments");a(SM,"buildSelectQuery");a(F3,"processFieldNode");a(TM,"processConstValueNode");a(G3,"resolveVariables");a(q3,"executeOperation");a(_M,"resolver");Or=class extends Error{static{a(this,"GraphQLQueryingError")}},Ci=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a($3,"graphqlQueryingHandler");a(V3,"start")});var Di=w((jbe,bM)=>{"use strict";var yM=ie(),RM=(H(),C(G)),bu=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Pi=require("joi"),Ra={schema_format:{pattern:bu,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},K3=Pi.alternatives(Pi.string().min(1).max(Ra.schema_length.maximum).pattern(bu).messages({"string.pattern.base":"{:#label} "+Ra.schema_format.message}),Pi.number(),Pi.array()).required(),Y3=Pi.alternatives(Pi.string().min(1).max(Ra.schema_length.maximum).pattern(bu).messages({"string.pattern.base":"{:#label} "+Ra.schema_format.message}),Pi.number()),W3=Pi.alternatives(Pi.string().min(1).max(Ra.schema_length.maximum).pattern(bu).messages({"string.pattern.base":"{:#label} "+Ra.schema_format.message}),Pi.number()).required();function z3(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>Ra.schema_length.maximum?`'${e}' maximum of 250 characters`:bu.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(z3,"checkValidTable");function j3(e,t){return yM.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(j3,"validateSchemaExists");function J3(e,t){let r=t.state.ancestors[0].schema;return yM.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(J3,"validateTableExists");function Q3(e,t){return e.toLowerCase()===RM.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${RM.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(Q3,"validateSchemaName");bM.exports={common_validators:Ra,schema_regex:bu,hdb_schema_table:K3,validateSchemaExists:j3,validateTableExists:J3,validateSchemaName:Q3,checkValidTable:z3,hdb_database:Y3,hdb_table:W3}});var ot=w((Qbe,OM)=>{"use strict";var gn=require("validate.js");gn.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||gn.validators.type.checks[t](e)?null:` must be a '${t}' value`};gn.validators.type.checks={Object:a(function(e){return gn.isObject(e)&&!gn.isArray(e)},"Object"),Array:gn.isArray,Integer:gn.isInteger,Number:gn.isNumber,String:gn.isString,Date:gn.isDate,Boolean:a(function(e){return typeof e=="boolean"},"Boolean")};gn.validators.hasValidFileExt=function(e,t){return gn.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};OM.exports={validateObject:X3,validateObjectAsync:Z3,validateBySchema:eX};function X3(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=gn(e,t,{format:"flat"});return r?new Error(r):null}a(X3,"validateObject");async function Z3(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await gn.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(Z3,"validateObjectAsync");function eX(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(eX,"validateBySchema")});var FR=w((Zbe,wM)=>{var{hdb_table:tX,hdb_database:NM}=Di(),rX=ot(),kR=require("joi"),nX={undefined:"undefined",null:"null"},sX=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||nX[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"),iX=kR.object({database:NM,schema:NM,table:tX,records:kR.array().items(kR.object().custom(sX)).required()});wM.exports=function(e){return rX.validateBySchema(e,iX)}});var CM=w((tOe,IM)=>{"use strict";var GR=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")}};IM.exports=GR});var DM=w((nOe,PM)=>{"use strict";var qR=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};PM.exports=qR});var xM={};ve(xM,{HAS_EXPIRATION:()=>Wm,HAS_RESIDENCY_ID:()=>jR,HAS_STRUCTURE_UPDATE:()=>jm,LAST_TIMESTAMP_PLACEHOLDER:()=>t_,LOCAL_TIMESTAMP:()=>oX,METADATA:()=>Qf,NEW_TIMESTAMP_PLACEHOLDER:()=>MM,NO_TIMESTAMP:()=>$R,PENDING_LOCAL_TIME:()=>JR,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>zR,RecordEncoder:()=>WR,TIMESTAMP_ASSIGN_LAST:()=>cX,TIMESTAMP_ASSIGN_NEW:()=>vM,TIMESTAMP_ASSIGN_PREVIOUS:()=>UM,TIMESTAMP_PLACEHOLDER:()=>Km,TIMESTAMP_RECORD_PREVIOUS:()=>VR,handleLocalTimeForGets:()=>Jm,recordUpdater:()=>QR,removeEntry:()=>Hc});function uX(){return e_[0]=e_[0]^64,aX.getFloat64(0)}function Jm(e,t){let r=e.getEntry;e.readCount=0,e.cachePuts=!1,e.rootStore=t,e.encoder.rootStore=t,e.getEntry=function(o,c){e.readCount++;let l=r.call(this,o,c),u=l?.value,f=u?.[Qf];return f>=0&&(l.metadataFlags=f,l.localTime=u.localTime,l.value=u.value,l.residencyId=u.residencyId,u.expiresAt>=0&&(l.expiresAt=u.expiresAt)),l&&(l.key=o),l};let n=e.get;e.get=function(o,c){let l=n.call(this,o,c);return l?.[Qf]>=0?l.value:l};let s=e.getRange;e.getRange=function(o){let c=s.call(this,o);return o.valuesForKey?c.map(l=>l?.value):o.values===!1||o.onlyCount?c:c.map(l=>{let u=l.value,f=u[Qf];return f>=0&&(l.metadataFlags=f,l.localTime=u.localTime,l.value=u.value,l.residencyId=u.residencyId,u.expiresAt>=0&&(l.expiresAt=u.expiresAt)),l})};let i=e.useReadTransaction();if(i.done(),!i.done.isTracked){let o=i.constructor,c=i.use,l=i.done;o.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,Bc.push(new WeakRef(this))),c.call(this)},o.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<Bc.length;u++){let f=Bc[u].deref();(!f||f.isDone||f.isCommitted)&&Bc.splice(u--,1)}},o.prototype.done.isTracked=!0}return e}function QR(e,t,r){return function(n,s,i,o,c=-1,l,u,f="put",d,p){d||l==null?Ou=i?.localTime?VR|UM:$R:Ou=l?i?.localTime?VR|16384:vM|16384:$R;let _=u?.expiresAt;if(_>=0&&(c|=Wm),Zf=c,KR=_,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:Ou>0},S,g=0;try{let R=i?.residencyId,E=u?.residencyId;E&&(YR=E,Zf|=jR,g|=kc),R!==E&&(g|=Fc,R||(R=0)),c&Wm&&(g|=n_),u?.originatingOperation&&(g|=r_),d&&(h.ifVersion=S=i?.version??null),i&&i.value&&i.metadataFlags&Fn&&(r.getBinaryFast(i.localTime)||Ta(i.value));let T;if(s!==void 0&&(T=Fm(()=>e.put(n,s,h),n,e.rootStore),Mc&&(g|=Fn)),l){let b=u?.user?.username;if(p&&(Fm(()=>e.encoder.encode(p),n,e.rootStore),Mc&&(g|=Fn)),e.encoder.hasStructureUpdate&&(g|=jm,e.encoder.hasStructureUpdate=!1),d&&i?.localTime){let v=i?.localTime,F=r.get(v);if(F){let q=It(F).previousLocalTime;return T=r.put(v,Nu(o,t,n,q,u?.nodeId??server.replication.getThisNodeId(r)??0,b,f,Xf,g,E,R,_),{ifVersion:S}),T}}T=r.put(s===void 0?MM:t_,Nu(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,b,f,Xf,g,E,R,_,u?.originatingOperation),{append:f!=="invalidate",instructedWrite:!0,ifVersion:S})}return T}catch(R){throw R.message+=" id: "+n+" options: "+h,R}}}function Hc(e,t,r){if(t)return t.value&&t.metadataFlags&Fn&&!e.auditStore.getBinaryFast(t.localTime)&&Ta(t.value),e.remove(t.key,r)}var LM,Ym,Km,t_,zR,MM,oX,Qf,e_,aX,$R,vM,cX,UM,VR,Wm,jR,JR,jm,lX,Xf,Ou,Zf,KR,YR,WR,Bc,wu=be(()=>{LM=require("msgpackr");fo();Ym=M(z());gs();gs();Km=new Uint8Array([1,1,1,1,4,64,0,0]),t_=new Uint8Array([1,1,1,1,1,0,0,0]),zR=new Uint8Array([1,1,1,1,3,64,0,0]),MM=new Uint8Array([1,1,1,1,0,64,0,0]),oX=Symbol("local-timestamp"),Qf=Symbol("metadata"),e_=new Uint8Array(8),aX=new DataView(e_.buffer,0,8),$R=0,vM=0,cX=1,UM=3,VR=4,Wm=16,jR=32,JR=1,jm=256,Ou=0,Zf=-1,KR=-1,YR=0,WR=class extends LM.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(Ou||Zf>=0){let o=0,c=Ou;c&&(o+=8,Ou=0);let l=Zf,u=KR,f=YR;l>=0&&(o+=4,Zf=-1,u>=0&&(o+=8,KR=-1),f&&(o+=4,YR=0));let d=lX=r.call(this,s,i|2048|o);Xf=d.subarray((d.start||0)+o,d.end);let p=d.start||0;return c&&(Km[4]=c,Km[5]=c>>8,d.set(Km,p),p+=8),Mc&&(l|=Fn),l>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(p,l|zm<<24),p+=4,u>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setFloat64(p,u),p+=8),f&&(d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(p,f)),d}else return Xf=r.call(this,s,i),Xf};let n=this.saveStructures;this.saveStructures=function(s,i){let o=n.call(this,s,i);return this.hasStructureUpdate=!0,o}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(e_,0,c),c+=8;else for(let p=0;p<8;p++)e_[p]=t[c++];l=uX(),i=t[c]}let u,f;i<32&&(i===zm?(o=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4):(o=i|t[c+1]<<5,c+=2),o&Wm&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&jR&&(f=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let d=vc(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return{localTime:l,value:d,[Qf]:o,expiresAt:u,residencyId:f}}return r?.valueAsBuffer?t:vc(()=>super.decode(t,r),this.rootStore)}catch(c){return Ym.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};a(uX,"getTimestamp");a(Jm,"handleLocalTimeForGets");Bc=[];setInterval(()=>{for(let e=0;e<Bc.length;e++){let t=Bc[e].deref();!t||t.isDone||t.isCommitted?Bc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(Ym.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):Ym.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(QR,"recordUpdater");a(Hc,"removeEntry")});var s_=w((lOe,HM)=>{"use strict";var BM=ae(),dX=(H(),C(G)),{RecordEncoder:fX}=(wu(),C(xM));BM.initSync();var _X=BM.get(dX.CONFIG_PARAMS.STORAGE_CACHING)!==!1,XR=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=_X&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:fX})}};HM.exports=XR});var i_=w((dOe,kM)=>{"use strict";var Gn=ae(),Ss=(H(),C(G));Gn.initSync();var Qm=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=Gn.get(Ss.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Gn.get(Ss.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Gn.get(Ss.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Gn.get(Ss.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Gn.get(Ss.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Gn.get(Ss.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Gn.get(Ss.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Gn.get(Ss.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Gn.get(Ss.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Gn.get(Ss.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Gn.get(Ss.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Gn.get(Ss.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};kM.exports=Qm;Qm.MAX_DBS=1e4});var _t=w((_Oe,jM)=>{"use strict";var ey=require("lmdb"),Qs=require("fs-extra"),qn=require("path"),Xm=_n(),qM=z(),Sn=xn().LMDB_ERRORS_ENUM,Zm=DM(),ty=s_(),$M=i_(),ya=xt(),FM=(H(),C(G)),{table:pX,resetDatabases:hX}=(De(),C(nt)),GM=ae(),Xs=ya.INTERNAL_DBIS_NAME,VM=ya.DBI_DEFINITION_NAME,mX="data.mdb",EX="lock.mdb",o_=".mdb",gX="-lock",ZR=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=Ts(t,r),this.key_type=this.dbi[ya.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[ya.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new ey.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function eE(e,t){if(e===void 0)throw new Error(Sn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(Sn.ENV_NAME_REQUIRED)}a(eE,"pathEnvNameValidation");async function ry(e,t,r=!0){try{await Qs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Sn.INVALID_BASE_PATH):n}try{let n=qn.join(e,t+o_);return await Qs.access(n,Qs.constants.R_OK|Qs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Qs.access(qn.join(e,t,mX),Qs.constants.R_OK|Qs.constants.F_OK),qn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(Sn.INVALID_ENVIRONMENT)}else throw new Error(Sn.INVALID_ENVIRONMENT);throw n}}a(ry,"validateEnvironmentPath");function tE(e,t){if(Xm.validateEnv(e),t===void 0)throw new Error(Sn.DBI_NAME_REQUIRED)}a(tE,"validateEnvDBIName");async function SX(e,t,r=!1,n=!1){eE(e,t);let s=qn.basename(e);t=t.toString();let i=GM.get(FM.CONFIG_PARAMS.DATABASES);i||GM.setProperty(FM.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await ry(e,t,n),KM(e,t,r)}catch(o){if(o.message===Sn.INVALID_ENVIRONMENT){let c=qn.join(e,t);await Qs.mkdirp(n?c:e);let l=new $M(n?c:c+o_,!1),u=ey.open(l);u.dbis=Object.create(null);let f=new ty(!1);u.openDB(Xs,f),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=ny(e,t,r);return u[ya.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=u,u}throw o}}a(SX,"createEnvironment");async function TX(e,t,r,n=!0){eE(e,t),t=t.toString();let s=qn.join(e,t);return pX({table:t,database:qn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(TX,"copyEnvironment");async function KM(e,t,r=!1){eE(e,t),t=t.toString();let n=ny(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 ry(e,t),i=qn.join(e,t+o_),o=s!=i,c=new $M(s,o),l=ey.open(c);l.dbis=Object.create(null);let u=WM(l);for(let f=0;f<u.length;f++)Ts(l,u[f]);return l[ya.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(KM,"openEnvironment");async function AX(e,t,r=!1){eE(e,t),t=t.toString();let n=qn.join(e,t+o_),s=await ry(e,t);if(global.lmdb_map!==void 0){let i=ny(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await YM(o),delete global.lmdb_map[i]}}await Qs.remove(s),await Qs.remove(s===n?s+gX:qn.join(qn.dirname(s),EX))}a(AX,"deleteEnvironment");async function YM(e){Xm.validateEnv(e);let t=e[ya.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(YM,"closeEnvironment");function ny(e,t,r=!1){let s=`${qn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(ny,"getCachedEnvironmentName");function RX(e){Xm.validateEnv(e);let t=Object.create(null),r=Ts(e,Xs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Xs)try{t[n]=Object.assign(new Zm,s)}catch{qM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(RX,"listDBIDefinitions");function WM(e){Xm.validateEnv(e);let t=[],r=Ts(e,Xs);for(let{key:n}of r.getRange({start:!1}))n!==Xs&&t.push(n);return t}a(WM,"listDBIs");function yX(e,t){let n=Ts(e,Xs).getEntry(t),s=new Zm;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{qM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(yX,"getDBIDefinition");function zM(e,t,r,n=!r){if(tE(e,t),t=t.toString(),t===Xs)throw new Error(Sn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return Ts(e,t)}catch(s){if(s.message===Sn.DBI_DOES_NOT_EXIST){let i=new ty(r,n===!0),o=e.openDB(t,i),c=new Zm(r===!0,n);return o[VM]=c,Ts(e,Xs).putSync(t,c),e.dbis[t]=o,o}throw s}}a(zM,"createDBI");function Ts(e,t){if(tE(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Xs?r=yX(e,t):r=new Zm,r===void 0)throw new Error(Sn.DBI_DOES_NOT_EXIST);let n;try{let s=new ty(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(Sn.DBI_DOES_NOT_EXIST):s}return n[VM]=r,e.dbis[t]=n,n}a(Ts,"openDBI");function bX(e,t){tE(e,t),t=t.toString();let r=Ts(e,t),n=r.getStats();return r[ya.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(bX,"statDBI");async function OX(e,t){try{let r=qn.join(e,t+o_);return(await Qs.stat(r)).size}catch{throw new Error(Sn.INVALID_ENVIRONMENT)}}a(OX,"environmentDataSize");function NX(e,t){if(tE(e,t),t=t.toString(),t===Xs)throw new Error(Sn.CANNOT_DROP_INTERNAL_DBIS_NAME);Ts(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],Ts(e,Xs).removeSync(t)}a(NX,"dropDBI");function wX(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{Ts(e,i)}catch(o){if(o.message===Sn.DBI_DOES_NOT_EXIST)zM(e,i,i!==t,i===t),n=!0;else throw o}}n&&hX()}a(wX,"initializeDBIs");jM.exports={openDBI:Ts,openEnvironment:KM,createEnvironment:SX,listDBIs:WM,listDBIDefinitions:RX,createDBI:zM,dropDBI:NX,statDBI:bX,deleteEnvironment:AX,initializeDBIs:wX,TransactionCursor:ZR,environmentDataSize:OX,copyEnvironment:TX,closeEnvironment:YM}});var QM=w((hOe,JM)=>{"use strict";var sy=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};JM.exports=sy});var ZM=w((EOe,XM)=>{"use strict";var iy=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}};XM.exports=iy});var tv=w((SOe,ev)=>{"use strict";var oy=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};ev.exports=oy});var qc=w((bOe,sv)=>{"use strict";var IX=_t(),CX=QM(),PX=ZM(),DX=tv(),Li=_n(),a_=xn().LMDB_ERRORS_ENUM,LX=xt(),_o=(H(),C(G)),MX=ie(),vX=require("uuid"),AOe=require("lmdb"),{handleHDBError:UX,hdb_errors:xX}=pe(),{OVERFLOW_MARKER:ROe,MAX_SEARCH_KEY_LENGTH:yOe}=LX,rv=ae();rv.initSync();var rE=rv.get(_o.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),ay=_o.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Gc=_o.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function BX(e,t,r,n,s=Li.getNextMonotonicTime()){dy(e,t,r,n),cy(e,t,r);let i=new CX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];nv(u,!0,s);let f=HX(e,t,r,u),d=u[t];o.push(f),c.push(d)}return ly(o,c,n,i,s)}a(BX,"insertRecords");function HX(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 f=c([[{}]]);Array.isArray(f)&&(c=f[0][_o.FUNC_VAL],n[o]=c)}let l=Li.getIndexedValues(c),u=e.dbis[o];if(l){rE&&u.prefetch(l.map(f=>({key:f,value:s})),nE);for(let f=0,d=l.length;f<d;f++)u.put(l[f],s)}}rE&&e.dbis[t].prefetch([s],nE),e.dbis[t].put(s,n,n[Gc])})}a(HX,"insertRecord");function kX(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(kX,"removeSkippedRecords");function nv(e,t,r){let n=r>0;(n||!Number.isInteger(e[Gc]))&&(e[Gc]=r||(r=Li.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[ay]))&&(e[ay]=r||Li.getNextMonotonicTime()):delete e[ay]}a(nv,"setTimestamps");function cy(e,t,r){r.indexOf(_o.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(_o.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(_o.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(_o.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),IX.initializeDBIs(e,t,r)}a(cy,"initializeTransaction");async function FX(e,t,r,n,s=Li.getNextMonotonicTime()){dy(e,t,r,n),cy(e,t,r);let i=new PX,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let f=n[u],d=f[t],p;try{p=uy(e,t,f,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(u);continue}c.push(p),l.push(d)}return ly(c,l,n,i,s,o)}a(FX,"updateRecords");async function GX(e,t,r,n,s=Li.getNextMonotonicTime()){try{dy(e,t,r,n)}catch(l){throw UX(l,l.message,xX.HTTP_STATUS_CODES.BAD_REQUEST)}cy(e,t,r);let i=new DX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],f;MX.isEmpty(u[t])?(f=vX.v4(),u[t]=f):f=u[t];let d=uy(e,t,u,f,i,!1,s);o.push(d),c.push(f)}return ly(o,c,n,i,s)}a(GX,"upsertRecords");async function ly(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||Li.getNextMonotonicTime(),kX(r,i),n}a(ly,"finalizeWrite");function uy(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),u=l?.value,f=u;if(!u){if(i)return!1;u={}}if(nv(r,!f,o),Number.isInteger(r[Gc])&&u[Gc]>r[Gc])return!1;f&&s.original_records.push(u);let d,p=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let S=r[h],g=e.dbis[h];if(g===void 0)continue;let R=u[h];if(typeof S=="function"){let T=S([[u]]);Array.isArray(T)&&(S=T[0][_o.FUNC_VAL],r[h]=S)}if(S===R)continue;let E=Li.getIndexedValues(R);if(E){rE&&g.prefetch(E.map(T=>({key:T,value:n})),nE);for(let T=0,b=E.length;T<b;T++)g.remove(E[T],n)}if(E=Li.getIndexedValues(S),E){rE&&g.prefetch(E.map(T=>({key:T,value:n})),nE);for(let T=0,b=E.length;T<b;T++)g.put(E[T],n)}}let _={...u,...r};c.put(n,_,_[Gc])},"do_put");return l?d=c.ifVersion(n,l.version,p):d=c.ifNoExists(n,p),d.then(_=>_?!0:uy(e,t,r,n,s,i,o))}a(uy,"updateUpsertRecord");function qX(e,t,r){if(Li.validateEnv(e),t===void 0)throw new Error(a_.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(a_.WRITE_ATTRIBUTES_REQUIRED):new Error(a_.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(qX,"validateBasic");function dy(e,t,r,n){if(qX(e,t,r),!Array.isArray(n))throw n===void 0?new Error(a_.RECORDS_REQUIRED):new Error(a_.RECORDS_MUST_BE_ARRAY)}a(dy,"validateWrite");function nE(){}a(nE,"noop");sv.exports={insertRecords:BX,updateRecords:FX,upsertRecords:GX}});var po=w((NOe,$X)=>{$X.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"hash_function"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"revoked_certificates"},{attribute:"shard"}]},hdb_certificate:{hash_attribute:"name",name:"hdb_certificate",schema:"system",attributes:[{attribute:"name"},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var ov=w((wOe,iv)=>{"use strict";var VX=require("uuid"),fy=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||VX.v4(),this.schema_table=`${this.schema}.${this.table}`}};iv.exports=fy});var sE=w((COe,av)=>{"use strict";var KX=ov(),_y=class extends KX{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}};av.exports=_y});var lv=w((DOe,cv)=>{"use strict";cv.exports=WX;var YX="inserted";function WX(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===YX?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(WX,"returnObject")});var iE=w((vOe,dv)=>{"use strict";var zX=(H(),C(G)),py=_t(),jX=qc(),{getSystemSchemaPath:JX,getSchemaPath:QX}=gt(),MOe=po(),{validateBySchema:XX}=ot(),c_=require("joi"),ZX=sE(),e6=lv(),{handleHDBError:t6,hdb_errors:r6,ClientError:n6}=pe(),uv=ie(),{HTTP_STATUS_CODES:s6}=r6,i6="inserted";dv.exports=o6;async function o6(e){let t=XX(e,c_.object({database:c_.string(),schema:c_.string(),table:c_.string().required(),attribute:c_.string().required()}));if(t)throw new n6(t.message);let r=!e.skip_table_check&&uv.checkGlobalSchemaTable(e.schema,e.table);if(r)throw t6(new Error,r,s6.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=uv.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 ZX(e.schema,e.table,e.attribute,e.id);try{let i=await py.openEnvironment(QX(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}`);py.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await py.openEnvironment(JX(),zX.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await jX.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return e6(i6,c,{records:[s]},l)}catch(i){throw i}}a(o6,"lmdbCreateAttribute")});var l_=w((BOe,_v)=>{"use strict";var ho=ie(),fv=z(),xOe=FR(),{getDatabases:a6}=(De(),C(nt)),{ClientError:$c}=pe();_v.exports=c6;function c6(e){if(ho.isEmpty(e))throw new $c("invalid update parameters defined.");if(ho.isEmptyOrZeroLength(e.schema))throw new $c("invalid schema specified.");if(ho.isEmptyOrZeroLength(e.table))throw new $c("invalid table specified.");if(!Array.isArray(e.records))throw new $c("records must be an array");let t=a6()[e.schema]?.[e.table];if(ho.isEmpty(t))throw new $c(`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&&ho.isEmptyOrZeroLength(o[r]))throw fv.error("a valid hash attribute must be provided with update record:",o),new $c("a valid hash attribute must be provided with update record, check log for more info");if(!ho.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw fv.error(`a valid hash value must be provided with ${e.operation} record:`,o),new $c(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!ho.isEmpty(o[r])&&o[r]!==""&&n.has(ho.autoCast(o[r]))&&(o.skip=!0),n.add(ho.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(c6,"insertUpdateValidate")});var hv=w((kOe,pv)=>{"use strict";var hy=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};pv.exports=hy});var gv=w((GOe,Ev)=>{"use strict";var my=_t(),l6=z(),mv=xn().LMDB_ERRORS_ENUM;Ev.exports=u6;async function u6(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 my.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==mv.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await my.closeEnvironment(global.lmdb_map[n]),await my.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==mv.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){l6.error(t)}}a(u6,"cleanLMDBMap")});var Dv=w((VOe,Pv)=>{"use strict";var Ey=require("recursive-iterator"),d6=require("alasql"),gy=require("clone"),Sv=ie(),{handleHDBError:Tv,hdb_errors:f6}=pe(),{HDB_ERROR_MSGS:Av,HTTP_STATUS_CODES:Rv}=f6,{getDatabases:_6}=(De(),C(nt)),p6=["DISTINCT_ARRAY"],yv=Symbol("validateTables"),Sy=Symbol("validateTable"),$Oe=Symbol("getAllColumns"),bv=Symbol("validateAllColumns"),oE=Symbol("findColumn"),Ov=Symbol("validateOrderBy"),u_=Symbol("validateSegment"),Ty=Symbol("validateColumn"),Nv=Symbol("setColumnsForTable"),wv=Symbol("checkColumnsForAsterisk"),Iv=Symbol("validateGroupBy"),Cv=Symbol("hasColumns"),Ay=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[yv](),this[wv](),this[bv]()}[yv](){if(this[Cv]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[Sy](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[Sy](t.table)})}}[Cv](){let t=!1,r=new Ey(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[Sy](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=_6();if(!r[t.databaseid])throw Tv(new Error,Av.SCHEMA_NOT_FOUND(t.databaseid),Rv.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw Tv(new Error,Av.TABLE_NOT_FOUND(t.databaseid,t.tableid),Rv.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=gy(s);i.table=gy(t),this.attributes.push(i)})}[oE](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)}[wv](){let t=new Ey(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[Nv](r.tableid)}[Nv](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new d6.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[bv](){this[u_](this.statement.columns,!1),this[u_](this.statement.joins,!1),this[u_](this.statement.where,!1),this[Iv](this.statement.group,!1),this[u_](this.statement.order,!0)}[u_](t,r){if(!t)return;let n=new Ey(t),s=[];for(let{node:i,path:o}of n)!Sv.isEmpty(i)&&!Sv.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[Ov](i):s.push(this[Ty](i)));return s}[Iv](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&p6.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=gy(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[oE](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[oE](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`}[Ov](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[Ty](t)}[Ty](t){let r=this[oE](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]}};Pv.exports=Ay});var Uv=w((YOe,vv)=>{"use strict";var Lv=require("lodash"),d_=require("mathjs"),h6=require("jsonata"),Mv=ie();vv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?Lv.uniqWith(e,Lv.isEqual):e,"distinct_array"),searchJSON:m6,mad:f_.bind(null,d_.mad),mean:f_.bind(null,d_.mean),mode:f_.bind(null,d_.mode),prod:f_.bind(null,d_.prod),median:f_.bind(null,d_.median)};function f_(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(f_,"aggregateFunction");function m6(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(Mv.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),Mv.isEmpty(this.__ala__.res[r])){let n=h6(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(m6,"searchJSON")});var Bv=w((zOe,xv)=>{"use strict";var er=require("moment"),Ry="YYYY-MM-DDTHH:mm:ss.SSSZZ";er.suppressDeprecationWarnings=!0;xv.exports={current_date:a(()=>er().utc().format("YYYY-MM-DD"),"current_date"),current_time:a(()=>er().utc().format("HH:mm:ss.SSS"),"current_time"),extract:a((e,t)=>{switch(t.toLowerCase()){case"year":return er(e).utc().format("YYYY");case"month":return er(e).utc().format("MM");case"day":return er(e).utc().format("DD");case"hour":return er(e).utc().format("HH");case"minute":return er(e).utc().format("mm");case"second":return er(e).utc().format("ss");case"millisecond":return er(e).utc().format("SSS");default:break}},"extract"),date:a(e=>er(e).utc().format(Ry),"date"),date_format:a((e,t)=>er(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>er(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>er(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=er(e).utc(),s=er(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>er().utc().valueOf(),"now"),get_server_time:a(()=>er().format(Ry),"get_server_time"),offset_utc:a((e,t)=>er(e).utc().utcOffset(t).format(Ry),"offset_utc")}});var Gv=w((JOe,Fv)=>{"use strict";var E6=require("@turf/area"),g6=require("@turf/length"),S6=require("@turf/circle"),T6=require("@turf/difference"),A6=require("@turf/distance"),R6=require("@turf/boolean-contains"),y6=require("@turf/boolean-equal"),b6=require("@turf/boolean-disjoint"),O6=require("@turf/helpers"),Hv=(H(),C(G)),Ge=ie(),mo=z();Fv.exports={geoArea:N6,geoLength:w6,geoCircle:I6,geoDifference:C6,geoDistance:kv,geoNear:P6,geoContains:D6,geoEqual:L6,geoCrosses:M6,geoConvert:v6};function N6(e){if(Ge.isEmpty(e))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return E6.default(e)}catch(t){return mo.trace(t,e),NaN}}a(N6,"geoArea");function w6(e,t){if(Ge.isEmpty(e))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return g6.default(e,{units:t||"kilometers"})}catch(r){return mo.trace(r,e),NaN}}a(w6,"geoLength");function I6(e,t,r){if(Ge.isEmpty(e))return NaN;if(Ge.isEmpty(t))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return S6.default(e,t,{units:r||"kilometers"})}catch(n){return mo.trace(n,e,t),NaN}}a(I6,"geoCircle");function C6(e,t){if(Ge.isEmpty(e))return NaN;if(Ge.isEmpty(t))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return T6(e,t)}catch(r){return mo.trace(r,e,t),NaN}}a(C6,"geoDifference");function kv(e,t,r){if(Ge.isEmpty(e))return NaN;if(Ge.isEmpty(t))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return A6.default(e,t,{units:r||"kilometers"})}catch(n){return mo.trace(n,e,t),NaN}}a(kv,"geoDistance");function P6(e,t,r,n){if(Ge.isEmpty(e)||Ge.isEmpty(t))return!1;if(Ge.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return kv(e,t,n)<=r}catch(s){return mo.trace(s,e,t),!1}}a(P6,"geoNear");function D6(e,t){if(Ge.isEmpty(e)||Ge.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return R6.default(e,t)}catch(r){return mo.trace(r,e,t),!1}}a(D6,"geoContains");function L6(e,t){if(Ge.isEmpty(e)||Ge.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return y6.default(e,t)}catch(r){return mo.trace(r,e,t),!1}}a(L6,"geoEqual");function M6(e,t){if(Ge.isEmpty(e)||Ge.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return!b6.default(e,t)}catch(r){return mo.trace(r,e,t),!1}}a(M6,"geoCrosses");function v6(e,t,r){if(Ge.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(Ge.isEmpty(t))throw new Error("geo_type is required");if(Ge.isEmpty(Hv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(Hv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ge.autoCastJSON(e)),O6[t](e,r)}a(v6,"geoConvert")});var aE=w((XOe,qv)=>{var Vc=Uv(),$n=Bv(),Mi=Gv();qv.exports=e=>{e.aggr.mad=e.aggr.MAD=Vc.mad,e.aggr.mean=e.aggr.MEAN=Vc.mean,e.aggr.mode=e.aggr.MODE=Vc.mode,e.aggr.prod=e.aggr.PROD=Vc.prod,e.aggr.median=e.aggr.MEDIAN=Vc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Vc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Vc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=$n.current_date,e.fn.current_time=e.fn.CURRENT_TIME=$n.current_time,e.fn.extract=e.fn.EXTRACT=$n.extract,e.fn.date=e.fn.DATE=$n.date,e.fn.date_format=e.fn.DATE_FORMAT=$n.date_format,e.fn.date_add=e.fn.DATE_ADD=$n.date_add,e.fn.date_sub=e.fn.DATE_SUB=$n.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=$n.date_diff,e.fn.now=e.fn.NOW=$n.now,e.fn.offset_utc=e.fn.OFFSET_UTC=$n.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=$n.get_server_time,e.fn.getdate=e.fn.GETDATE=$n.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=$n.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Mi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Mi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Mi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Mi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Mi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Mi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Mi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Mi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Mi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Mi.geoNear}});var Yv=w((ZOe,Kv)=>{"use strict";var __=require("lodash"),Tn=require("alasql");Tn.options.cache=!1;var U6=aE(),$v=require("clone"),cE=require("recursive-iterator"),xe=z(),ze=ie(),Iu=Vn(),x6=(H(),C(G)),{hdb_errors:B6}=pe(),{getDatabases:Vv}=(De(),C(nt)),H6="IS NULL",Zs="There was a problem performing this search. Please check the logs and try again.";U6(Tn);var yy=class{static{a(this,"SQLSearch")}constructor(t,r){if(ze.isEmpty(t))throw xe.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(),ze.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!ze.isEmptyOrZeroLength(n))return xe.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw xe.error("Error thrown from checkEmptySQL in SQLSearch class method search."),xe.error(n),new Error(Zs)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw xe.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),xe.error(n),new Error(Zs)}if(Object.keys(this.data).length===0)return xe.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw xe.error("Error thrown from processJoins in SQLSearch class method search."),xe.error(n),new Error(Zs)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw xe.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),xe.error(n),new Error(Zs)}try{return t=await this._finalSQL(),t}catch(n){throw xe.error("Error thrown from finalSQL in SQLSearch class method search."),xe.error(n),new Error(Zs)}}_getColumns(){let t=new cE(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($v(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=__.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=Vv()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(ze.isEmpty(this.statement.where)){xe.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new cE(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!ze.isEmpty(r)&&r.right)if(ze.isNotEmptyAndHasValue(r.right.value)){let n=ze.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new Tn.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=ze.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new Tn.yy.LogicValue({value:i}):n instanceof Tn.yy.StringValue&&ze.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Tn.yy.NumValue({value:i}))});if(t){xe.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new cE(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(!ze.isEmpty(x6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(ze.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(ze.isEmptyOrZeroLength(r.left.columnid)||ze.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(ze.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"=":!ze.isEmpty(r.right.value)||!ze.isEmpty(r.left.value)?n.add(ze.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let l=Array.isArray(r.right)?r.right:r.left;for(let u=0;u<l.length;u++)if(l[u].value)n.add(l[u].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(ze.isEmptyOrZeroLength(this.all_table_attributes)&&ze.isEmptyOrZeroLength(this.statement.from)&&ze.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&&__.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(ze.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);ze.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(ze.isEmptyOrZeroLength(this.all_table_attributes)&&!ze.isEmptyOrZeroLength(this.columns.columns))return t;if(ze.isEmptyOrZeroLength(this.all_table_attributes)&&ze.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await Tn.promise(r)}catch(r){throw xe.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),xe.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($v(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(ze.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(H6)>-1&&this.tables.forEach(s=>{let i={columnid:Vv()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=__.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,u=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!ze.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!ze.isEmptyOrZeroLength(this.exact_search_values[u].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[u].values);let f=await Iu.getDataByHash(c);for(let d of c.hash_values)f.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(f){throw xe.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),xe.error(f),new Error(Zs)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async f=>{let d={...c};d.search_value=f;let p=await Iu.getDataByValue(d);for(let[_,h]of p)this.data[i].__merged_data[_]?this._updateMergedAttribute(i,_,s.attribute,h[s.attribute]):(this.data[i].__merged_data[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,_))}))}catch(f){throw xe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),xe.error(f),new Error(Zs)}else if(!ze.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!ze.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let f=this.comparator_search_values[u].comparators;for(let d=0,p=f.length;d<p;d++){let _=f[d];c.search_attribute=_.attribute,c.search_value=_.search_value;let h=await Iu.getDataByValue(c,_.operation);if(l)for(let[S]of h)this.data[i].__merged_data[S]||(this.data[i].__merged_data[S]=[...n[i]],this._setMergedHashAttribute(i,S));else for(let[S,g]of h)this.data[i].__merged_data[S]?this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]):(this.data[i].__merged_data[S]=[...n[i]],this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]),this._setMergedHashAttribute(i,S))}}catch(f){throw xe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),xe.error(f),new Error(Zs)}else try{c.search_attribute=s.attribute,c.search_value="*";let f=await Iu.getDataByValue(c);if(l)for(let[d]of f)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,p]of f)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,p[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,p[s.attribute]),this._setMergedHashAttribute(i,d))}catch(f){throw xe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),xe.error(f),new Error(Zs)}}}_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 Tn.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 Tn.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new Tn.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 Tn.yy.FuncValue:new Tn.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(_=>{_.joinmode&&_.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(_.table);let h=_.joinmode+" JOIN ? AS "+(_.as?_.as:_.table.tableid);_.on&&(h+=" ON "+_.on.toString()),i.push(h),t.push(Object.values(this.data[`${_.table.databaseid_orig}_${_.table.as?_.table.as_orig:_.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(_=>{let h=this.data[`${_.databaseid_orig}_${_.as?_.as_orig:_.tableid_orig}`].__hash_name,S=_.as?_.as_orig:_.tableid_orig;o.push({key:`'${S}.${h}'`,schema:_.databaseid_orig,table:_.as?_.as_orig:_.tableid_orig,keys:new Set}),r.push(`${_.as?_.as:_.tableid}.\`${h}\` AS "${S}.${h}"`),c[_.as?_.as_orig:_.tableid_orig]=this.data[`${_.databaseid_orig}_${_.as?_.as_orig:_.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let u="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(u="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(_=>{_.is_func?r.push(_.initial_select_column.toString()):_.initial_select_column.tableid?r.push(`${_.initial_select_column.tableid}.${_.initial_select_column.columnid} AS ${_.expression.columnid}`):r.push(`${_.initial_select_column.columnid} AS ${_.expression.columnid}`)}));let f="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(f=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let p=[];try{let _=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${u} ${f} ${d}`,h=this._convertColumnsToIndexes(_,s);p=await Tn.promise(h,t),t=null}catch(_){throw xe.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),xe.error(_),new Error("There was a problem processing the data.")}if(p&&p.length>0){for(let _=0,h=p.length;_<h;_++){let S=p[_];o.forEach(g=>{S[g.key]!==null&&S[g.key]!==void 0&&g.keys.add(S[g.key])})}o.forEach(_=>{let h=Object.keys(this.data[`${_.schema}_${_.table}`].__merged_data),S=__.difference(h,[..._.keys].map(g=>g.toString()));for(let g=0,R=S.length;g<R;g++){let E=S[g];delete this.data[`${_.schema}_${_.table}`].__merged_data[E]}})}return{existing_attributes:c,joined_length:p?p.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new cE(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=__.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 xe.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),xe.error(i),new Error(Zs)}}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 f in i)o.push(i[f][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 Iu.getDataByHash(c),u=s.columns.length;for(let f=0,d=o.length;f<d;f++){let p=o[f],_=l.get(p);for(let h=0;h<u;h++){let S=s.columns[h],g=_[S]===void 0?null:_[S];this.data[n].__merged_data[p].push(g)}}}}catch(r){throw xe.error("Error thrown from getDataByHash function in SQLSearch class method getData."),xe.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();xe.trace(`Final SQL: ${s}`),n=await Tn.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),xe.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw xe.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),xe.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 xe.error(B6.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),xe.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],u=new RegExp(`${l}.\`${o}\``,"g"),f=`${l}.[${c}]`;n=n.replace(u,f)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),u=`[${c}]`;n=n.replace(l,u)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await Iu.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]={...r[s]}),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw xe.error("There was an error when processing this SQL operation. Check your logs"),xe.error(o),new Error(Zs)}}return Object.values(Object.values(this.data)[0].__merged_data)}};Kv.exports=yy});var Yr=w((tNe,Wv)=>{"use strict";var k6=Dv();Wv.exports={searchByConditions:G6,searchByHash:q6,searchByValue:$6,search:V6};var by=Vn(),{transformReq:Oy}=ie(),F6=Yv();async function G6(e){return Oy(e),by.searchByConditions(e)}a(G6,"searchByConditions");async function q6(e){Oy(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of by.searchByHash(e))r&&t.push(r);return t}a(q6,"searchByHash");async function $6(e){Oy(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of by.searchByValue(e))t.push(r);return t}a($6,"searchByValue");function V6(e,t){try{let r=new k6(e);r.validate(),new F6(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(V6,"search")});var Eo=w((nNe,Qv)=>{"use strict";var p_=require("crypto"),K6=ae(),{CONFIG_PARAMS:Y6}=(H(),C(G)),jv="aes-256-cbc",W6=32,z6=16,Ny=64,Jv=32,j6=Ny+Jv,zv=new Map;Qv.exports={encrypt:J6,decrypt:Q6,createNatsTableStreamName:X6};function J6(e){let t=p_.randomBytes(W6),r=p_.randomBytes(z6),n=p_.createCipheriv(jv,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(J6,"encrypt");function Q6(e){let t=e.substr(0,Ny),r=e.substr(Ny,Jv),n=e.substr(j6,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=p_.createDecipheriv(jv,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(Q6,"decrypt");function X6(e,t){let r=K6.get(Y6.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=zv.get(r);return n||(n=p_.createHash("md5").update(r).digest("hex"),zv.set(r,n)),n}a(X6,"createNatsTableStreamName")});var go=w((oNe,tU)=>{"use strict";var iNe=Yr(),h_=z(),{validateBySchema:Xv}=ot(),Kc=require("joi"),Z6=Eo(),lE=ie(),{handleHDBError:uE,hdb_errors:eZ,ClientError:Zv}=pe(),{HDB_ERROR_MSGS:dE,HTTP_STATUS_CODES:wy}=eZ,eU=ae();eU.initSync();var{getDatabases:Iy}=(De(),C(nt)),tZ=require("fs-extra"),rZ=(H(),C(G));tU.exports={describeAll:nZ,describeTable:fE,describeSchema:sZ};async function nZ(e={}){try{let t=lE.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=Iy(),o={},c={},l=[],u=e?.exact_count;for(let d in i){o[d]=!0,!t&&!s&&!r&&(c[d]=e.hdb_user?.role?.permission[d]?.describe);let p=i[d];for(let _ in p)try{let h;if(t||s||r)h=await fE({schema:d,table:_,exact_count:u});else if(n&&n[d].describe&&n[d].tables[_].describe){let S=n[d].tables[_].attribute_permissions;h=await fE({schema:d,table:_,exact_count:u},S)}h&&l.push(h)}catch(h){h_.error(h)}}let f={};for(let d in l)t||s||r?(f[l[d].schema]==null&&(f[l[d].schema]={}),f[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]):c[l[d].schema]&&(f[l[d].schema]==null&&(f[l[d].schema]={}),f[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?f[d]={}:c[d]&&(f[d]={});return f}catch(t){return h_.error("Got an error in describeAll"),h_.error(t),uE(new Error,dE.DESCRIBE_ALL_ERR)}}a(nZ,"describeAll");async function fE(e,t){lE.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=Xv(e,Kc.object({database:Kc.string(),table:Kc.string().required(),exact_count:Kc.boolean().strict()}));if(i)throw new Zv(i.message);let c=Iy()[r];if(!c)throw uE(new Error,dE.SCHEMA_NOT_FOUND(e.schema),wy.NOT_FOUND);let l=c[n];if(!l)throw uE(new Error,dE.TABLE_NOT_FOUND(e.schema,e.table),wy.NOT_FOUND);function u(_){f.push({attribute:_.attribute,type:_.type,elements:_.elements?.type,indexed:_.indexed,is_primary_key:_.isPrimaryKey,assigned_created_time:_.assignCreatedTime,assigned_updated_time:_.assignUpdatedTime,nullable:_.nullable,properties:_.properties?_.properties.map(h=>({type:h.type,name:h.name})):void 0})}a(u,"pushAtt");let f=[];if(s){let _={};s.forEach(h=>{h.describe&&(_[h.attribute_name]=!0)}),l.attributes.forEach(h=>{_[h.name]&&u(h)})}else l.attributes?.forEach(_=>u(_));let d;try{d=(await tZ.stat(l.primaryStore.env.path)).size}catch(_){h_.warn("unable to get database size",_)}let p={schema:r,name:l.tableName,hash_attribute:l.attributes.find(_=>_.isPrimaryKey||_.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:f,db_size:d};l.replicate!==void 0&&(p.replicate=l.replicate),l.expirationMS!==void 0&&(p.expiration=l.expirationMS/1e3+"s"),l.sealed!==void 0&&(p.sealed=l.sealed),l.sources?.length>0&&(p.sources=l.sources.map(_=>_.name).filter(_=>_&&_!=="NATSReplicator"&&_!=="Replicator")),eU.get(rZ.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(p.clustering_stream_name=Z6.createNatsTableStreamName(p.schema,p.name));try{let _=await l.getRecordCount({exactCount:!!e.exact_count});p.record_count=_.recordCount,p.table_size=l.getSize(),p.db_audit_size=l.getAuditSize(),p.estimated_record_range=_.estimatedRange;let h=l.auditStore;if(h)for(let S of h.getKeys({reverse:!0,limit:1}))p.last_updated_record=S[0];if(!p.last_updated_record&&l.indices.__updatedtime__)for(let S of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))p.last_updated_record=S}catch(_){h_.warn(`unable to stat table dbi due to ${_}`)}return p}a(fE,"descTable");async function sZ(e){lE.transformReq(e);let t=Xv(e,Kc.object({database:Kc.string(),exact_count:Kc.boolean().strict()}));if(t)throw new Zv(t.message);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=Iy()[n];if(!i)throw uE(new Error,dE.SCHEMA_NOT_FOUND(e.schema),wy.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),lE.isEmpty(l)||l.describe){let u=await fE({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(sZ,"describeSchema")});var As=w((uNe,oU)=>{var iZ=po(),{callbackify:nU,promisify:oZ}=require("util"),{getDatabases:sU}=(De(),C(nt));oU.exports={setSchemaDataToGlobal:rU,getTableSchema:aZ,getSystemSchema:cZ,setSchemaDataToGlobalAsync:oZ(rU)};var iU=go(),cNe=nU(iU.describeAll),lNe=nU(iU.describeTable);function rU(e){global.hdb_schema=sU(),e&&e()}a(rU,"setSchemaDataToGlobal");function aZ(e,t,r){let n=sU()[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(aZ,"getTableSchema");function cZ(){return iZ}a(cZ,"getSystemSchema")});var Py=w((fNe,lU)=>{var lZ=ot(),Cy=require("joi"),{hdb_table:uZ,hdb_database:aU}=Di(),cU={schema:aU,database:aU,table:uZ},dZ={date:Cy.date().iso().required()},fZ={timestamp:Cy.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};lU.exports=function(e,t){let r=t==="timestamp"?{...cU,...fZ}:{...cU,...dZ},n=Cy.object(r);return lZ.validateBySchema(e,n)}});var fU=w((_Ne,dU)=>{var _Z=ot(),Dy=require("joi"),{hdb_table:pZ,hdb_database:uU}=Di(),hZ=Dy.object({schema:uU,database:uU,table:pZ,hash_values:Dy.array().required(),ids:Dy.array()});dU.exports=function(e){return _Z.validateBySchema(e,hZ)}});var Uy=w((pNe,_U)=>{"use strict";var Ly=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}},My=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}},vy=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};_U.exports={InsertObject:Ly,NoSQLSeachObject:My,DeleteResponseObject:vy}});var zc=w((mNe,gU)=>{"use strict";var hU=Py(),mZ=fU(),Yc=ie(),pU=require("moment"),mU=z(),{promisify:EZ,callbackify:gZ}=require("util"),Wc=(H(),C(G)),SZ=As(),xy=EZ(SZ.getTableSchema),By=Vn(),{DeleteResponseObject:TZ}=Uy(),{handleHDBError:ba,hdb_errors:AZ}=pe(),{HDB_ERROR_MSGS:_E,HTTP_STATUS_CODES:Oa}=AZ,RZ="records successfully deleted",yZ=gZ(EU);gU.exports={delete:yZ,deleteRecord:EU,deleteFilesBefore:bZ,deleteAuditLogsBefore:OZ};async function bZ(e){let t=hU(e,"date");if(t)throw ba(t,t.message,Oa.BAD_REQUEST,void 0,void 0,!0);if(Yc.transformReq(e),!pU(e.date,pU.ISO_8601).isValid())throw ba(new Error,_E.INVALID_DATE,Oa.BAD_REQUEST,Wc.LOG_LEVELS.ERROR,_E.INVALID_DATE,!0);let n=Yc.checkSchemaTableExist(e.schema,e.table);if(n)throw ba(new Error,n,Oa.NOT_FOUND,Wc.LOG_LEVELS.ERROR,n,!0);let s=await By.deleteRecordsBefore(e);if(await xy(e.schema,e.table),mU.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(bZ,"deleteFilesBefore");async function OZ(e){let t=hU(e,"timestamp");if(t)throw ba(t,t.message,Oa.BAD_REQUEST,void 0,void 0,!0);if(Yc.transformReq(e),isNaN(e.timestamp))throw ba(new Error,_E.INVALID_VALUE("Timestamp"),Oa.BAD_REQUEST,Wc.LOG_LEVELS.ERROR,_E.INVALID_VALUE("Timestamp"),!0);let r=Yc.checkSchemaTableExist(e.schema,e.table);if(r)throw ba(new Error,r,Oa.NOT_FOUND,Wc.LOG_LEVELS.ERROR,r,!0);let n=await By.deleteAuditLogsBefore(e);return await xy(e.schema,e.table),mU.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(OZ,"deleteAuditLogsBefore");async function EU(e){e.ids&&(e.hash_values=e.ids);let t=mZ(e);if(t)throw ba(t,t.message,Oa.BAD_REQUEST,void 0,void 0,!0);Yc.transformReq(e);let r=Yc.checkSchemaTableExist(e.schema,e.table);if(r)throw ba(new Error,r,Oa.NOT_FOUND,Wc.LOG_LEVELS.ERROR,r,!0);try{await xy(e.schema,e.table);let n=await By.deleteRecords(e);return Yc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${RZ}`),n}catch(n){if(n.message===Wc.SEARCH_NOT_FOUND_MESSAGE){let s=new TZ;return s.message=Wc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(EU,"deleteRecord")});var pE={};ve(pE,{HASH_FUNCTION:()=>g_,hash:()=>Fy,validate:()=>Gy});function Hy(e=E_){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(m_.randomBytes(e)).map(r=>t[r%t.length]).join("")}function Fy(e,t=g_[TU?.toUpperCase()]??"sha256"){return ky[t](e)}function Gy(e,t,r=g_[TU?.toUpperCase()]??"sha256"){return e?NZ[r](e,t):!1}var m_,Cu,SU,TU,E_,AU,g_,ky,NZ,hE=be(()=>{m_=M(require("node:crypto")),Cu=M(require("argon2")),SU=M(ae());H();TU=(0,SU.get)(x.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),E_=16,AU=9,g_=(n=>(n.MD5="md5",n.SHA256="sha256",n.ARGON2ID="argon2id",n))(g_||{});a(Hy,"generateSalt");ky={md5:a((e,t=void 0)=>{t=t??Hy(AU);let r=m_.createHash("md5").update(e+t).digest("hex");return t+r},"md5"),sha256:a((e,t=void 0)=>{t=t??Hy(E_);let r=m_.createHash("sha256").update(e+t).digest("hex");return t+r},"sha256"),argon2id:a(async e=>{let t=Hy(E_),r=await Cu.hash(e,{type:Cu.argon2id,salt:Buffer.from(t)});return t+r},"argon2id")},NZ={md5:a((e,t)=>{let r=e.slice(0,AU);return e===ky.md5(t,r)},"md5"),sha256:a((e,t)=>{let r=e.slice(0,E_);return e===ky.sha256(t,r)},"sha256"),argon2id:a(async(e,t)=>await Cu.verify(e.slice(E_),t),"argon2id")};a(Fy,"hash");a(Gy,"validate")});var yU=w((TNe,RU)=>{var qy=ot(),Wr={username:{presence:!0,exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function wZ(e){return Wr.password.presence=!0,Wr.username.presence=!0,Wr.role.presence=!0,Wr.active.presence=!0,qy.validateObject(e,Wr)}a(wZ,"addUserValidation");function IZ(e){return Wr.password.presence=!1,Wr.username.presence=!0,Wr.role.presence=!1,Wr.active.presence=!1,qy.validateObject(e,Wr)}a(IZ,"alterUserValidation");function CZ(e){return Wr.password.presence=!1,Wr.username.presence=!0,Wr.role.presence=!1,Wr.active.presence=!1,qy.validateObject(e,Wr)}a(CZ,"dropUserValidation");RU.exports={addUserValidation:wZ,alterUserValidation:IZ,dropUserValidation:CZ}});var Tt=w((yNe,OU)=>{"use strict";var{platform:RNe}=require("os"),PZ="nats-server.zip",$y="nats-server",DZ=process.platform==="win32"?`${$y}.exe`:$y,LZ=/^[^\s.,*>]+$/,bU="__request__",MZ=a(e=>`${e}.${bU}`,"REQUEST_SUBJECT"),vZ={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},UZ={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},xZ={HUB:"hub.pid",LEAF:"leaf.pid"},BZ={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},HZ={SUCCESS:"success",ERROR:"error"},kZ={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},FZ={TXN:"txn",MSGID:"msgid"},Pu={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},GZ={[Pu.ERR]:1,[Pu.WRN]:2,[Pu.INF]:3,[Pu.DBG]:4,[Pu.TRC]:5},qZ={debug:"-D",trace:"-DVV"};OU.exports={NATS_SERVER_ZIP:PZ,NATS_SERVER_NAME:$y,NATS_BINARY_NAME:DZ,PID_FILES:xZ,NATS_CONFIG_FILES:UZ,SERVER_SUFFIX:BZ,NATS_TERM_CONSTRAINTS_RX:LZ,REQUEST_SUFFIX:bU,UPDATE_REMOTE_RESPONSE_STATUSES:HZ,CLUSTER_STATUS_STATUSES:kZ,REQUEST_SUBJECT:MZ,SUBJECT_PREFIXES:FZ,MSG_HEADERS:vZ,LOG_LEVELS:Pu,LOG_LEVEL_FLAGS:qZ,LOG_LEVEL_HIERARCHY:GZ}});var Vy=w(NU=>{"use strict";var $Z={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
17
+ `},"serialize"),compressible:!1,q:.8});Yr.set("application/x-www-form-urlencoded",{deserialize(e){let t=Buffer.isBuffer(e)?e.toString("utf8"):e,r={};for(let[n,s]of new URLSearchParams(t))if(r.hasOwnProperty(n)){let i=r[n];Array.isArray(i)?i.push(s):r.key=[i,s]}else r[n]=s;return r},serialize(e){let t=new URLSearchParams;for(let r in e)t.set(r,e);return t.toString()}});uM={type:"application/json",serializeStream:Vf,serialize:zf,deserialize:w3,q:.5};Yr.set("*/*",uM);Yr.set("",uM);a(w3,"tryJSONParse");a(Jf,"registerContentHandlers");I3=require("fastify-plugin"),C3=I3(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=Vm(n.raw);s.type(c),s.serializer(function(l){let u;if(typeof l=="object"&&l&&(l[Symbol.iterator]||l[Symbol.asyncIterator])&&o.serializeStream){if(l.mapError){let f=l.getColumns;l=l.mapError(d=>(d.toJSON=()=>({error:d.name,message:d.message,...d.partialObject}),d)),l.getColumns=f}u=o.serializeStream}else u=o.serialize;return u(l,{headers:{set:a((f,d)=>{s.header(f,d)},"set")}})})}),r()},{name:"content-type-negotiation"});a(Vm,"findBestSerializer");iM=vR.default.get(x.HTTP_COMPRESSIONTHRESHOLD);a(Qf,"serialize");a(Ra,"serializeMessage");a(LR,"asyncSerialization");a(MR,"hasAsyncSerialization");a(P3,"streamToBuffer");D3=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(L3,"isBufferEncoding");a(M3,"parseContentType");a(fo,"getDeserializer");a(v3,"deserializerUnknownType");a(U3,"transformIterable");a($m,"toCsvStream")});var kR={};Ue(kR,{start:()=>V3});function x3(e){if(e.kind!==Le.Kind.OPERATION_DEFINITION&&e.kind!==Le.Kind.FRAGMENT_DEFINITION)throw new Or(`Unexpected non-executable definition type ${e.kind}.`)}function fM(e){if(typeof e!="object"||e===null)throw new Pi("Request body must be an object.");if(!("query"in e))throw new Pi("Request body must contain a `query` field.");if(typeof e.query!="string")throw new Pi("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new Pi("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new Pi("Request body `operationName` field must be a string.")}function HR(e){return parseInt(e.value,10)}function pM(e){return parseFloat(e.value)}function hM(e,t,r){let n=r.get(e.name.value);return mM(n)?EM(n,t):{attribute:t,value:n}}function mM(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function EM(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],mM(n)?EM(n,t):{attribute:t,value:n}))}function B3(e,t,r){switch(t=[...t,e.name.value],e.value.kind){case Le.Kind.NULL:return{attribute:t,value:null};case Le.Kind.INT:return{attribute:t,value:HR(e.value)};case Le.Kind.FLOAT:return{attribute:t,value:pM(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:t,value:e.value.value};case Le.Kind.VARIABLE:return hM(e.value,t,r);case Le.Kind.OBJECT:return gM(e.value,t,r);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Or(`Value type, ${e.value.kind}, is not supported.`)}}function gM(e,t,r){return e.fields.flatMap(n=>B3(n,t,r))}function H3(e,t){switch(e.value.kind){case Le.Kind.NULL:return{attribute:e.name.value,value:null};case Le.Kind.INT:return{attribute:e.name.value,value:HR(e.value)};case Le.Kind.FLOAT:return{attribute:e.name.value,value:pM(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Le.Kind.VARIABLE:return hM(e.value,e.name.value,t);case Le.Kind.OBJECT:return gM(e.value,[e.name.value],t);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Or(`Argument type, ${e.value.kind}, is not supported.`)}}function k3(e,t){return e.flatMap(r=>H3(r,t))}function Km(e,t){return e.selections.flatMap(r=>{switch(r.kind){case Le.Kind.FIELD:return r;case Le.Kind.FRAGMENT_SPREAD:{let n=r.name.value,s=t.get(n);if(s==null)throw new Or(`Fragment \`${n}\` not found.`);return Km(s.selectionSet,t)}case Le.Kind.INLINE_FRAGMENT:return Km(r.selectionSet,t)}})}function SM(e,t){return Km(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:SM(r.selectionSet,t)}:r.name.value)}async function F3(e,t,r,n){let s=Ni.getMatch(e.name.value,"graphql");if(s===void 0)throw new Or(`Resource \`${e.name.value}\` not found.`);let i=s.Resource,o={select:SM(e.selectionSet,r),conditions:k3(e.arguments,t)},c=[];n.authorize=!0;for await(let l of i.search(o,n))c.push(l);return[e.name.value,c]}function TM(e){switch(e.kind){case Le.Kind.NULL:return null;case Le.Kind.INT:return HR(e);case Le.Kind.FLOAT:return parseFloat(e.value);case Le.Kind.STRING:case Le.Kind.BOOLEAN:return e.value;case Le.Kind.OBJECT:return e.fields.reduce((t,r)=>({[r.name.value]:TM(r.value),...t}),{});case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Or(`Value type, ${e.kind}, is not supported.`)}}function G3(e,t){let r=new Map;for(let n of e){let s=n.variable.name.value,i=t?.[s];if(i===void 0&&n.defaultValue!==void 0&&(i=TM(n.defaultValue)),n.type.kind===Le.Kind.NON_NULL_TYPE&&!(s in t)&&i===void 0)throw new Or(`Variable $${s} is required, but not provided.`);r.set(n.variable.name.value,i??null)}return r}async function q3(e,t,r,n){if(e.operation===Le.OperationTypeNode.SUBSCRIPTION)throw new Or("Subscriptions are not supported.");if(e.operation===Le.OperationTypeNode.MUTATION)throw new Or("Mutations are not supported yet.");let s=G3(e.variableDefinitions,t),i=await Promise.all(Km(e.selectionSet,r).map(c=>F3(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function _M({query:e,variables:t={},operationName:r},n){let s=Le.parse(e),i=new Map,o=new Map;for(let u of s.definitions)if(x3(u),u.kind===Le.Kind.FRAGMENT_DEFINITION)o.set(u.name.value,u);else{if(u.name===void 0&&s.definitions.length>1)throw new Or("Unnamed operations are only allowed when there is a single operation in the document.");let f=u.name?.value??"Unnamed Query";if(i.has(f))throw new Or(`Duplicate operation definition: ${f}`);i.set(f,u)}let c;if(r==null)if(i.size===1)c=i.entries().next().value[1];else throw new Or("Operation name is required when there are multiple operations in the document.");else if(c=i.get(r),c==null)throw new Or(`Operation \`${r}\` not found.`);let l=await q3(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function $3(e){switch(e.method){case"GET":{let t=new URLSearchParams(e.url.split("?")[1]),r={};for(let[n,s]of t)r[n]=n==="variables"||n==="extensions"?JSON.parse(s):s;return fM(r),_M(r,e)}case"POST":{let r=await fo(e.headers.get("content-type"),!0)(e._nodeRequest);return fM(r),_M(r,e)}default:throw new Pi("Method Not Allowed",405,{Allow:"GET, POST"})}}function V3(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await $3(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof Pi)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json",...n.headers}};if(n instanceof Le.GraphQLError)return{status:200,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/json"}};if(n instanceof Or)return{status:200,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};break}default:logger.info(`Unsupported accept header, ${s}, defaulting to application/graphql-response+json`);case"application/graphql-response+json":{if(n instanceof Pi)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json",...n.headers}};if(n instanceof Le.GraphQLError)return{status:400,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Or)return{status:400,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};break}}throw n}},{port:e.port,securePort:e.securePort})}var Le,Or,Pi,AM=be(()=>{Le=M(require("graphql"));co();Au();a(x3,"assertExecutableDefinitionNode");a(fM,"assertRequestParams");a(HR,"processIntValueNode");a(pM,"processFloatValueNode");a(hM,"processVariableNode");a(mM,"isObject");a(EM,"transformObjectIntoQueryCondition");a(B3,"processObjectFieldNode");a(gM,"processObjectValueNode");a(H3,"processArgumentNode");a(k3,"buildConditionsQuery");a(Km,"fillInFragments");a(SM,"buildSelectQuery");a(F3,"processFieldNode");a(TM,"processConstValueNode");a(G3,"resolveVariables");a(q3,"executeOperation");a(_M,"resolver");Or=class extends Error{static{a(this,"GraphQLQueryingError")}},Pi=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a($3,"graphqlQueryingHandler");a(V3,"start")});var Li=I((Wbe,bM)=>{"use strict";var yM=ae(),RM=(H(),P(G)),Ou=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Di=require("joi"),ya={schema_format:{pattern:Ou,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},K3=Di.alternatives(Di.string().min(1).max(ya.schema_length.maximum).pattern(Ou).messages({"string.pattern.base":"{:#label} "+ya.schema_format.message}),Di.number(),Di.array()).required(),Y3=Di.alternatives(Di.string().min(1).max(ya.schema_length.maximum).pattern(Ou).messages({"string.pattern.base":"{:#label} "+ya.schema_format.message}),Di.number()),W3=Di.alternatives(Di.string().min(1).max(ya.schema_length.maximum).pattern(Ou).messages({"string.pattern.base":"{:#label} "+ya.schema_format.message}),Di.number()).required();function z3(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>ya.schema_length.maximum?`'${e}' maximum of 250 characters`:Ou.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(z3,"checkValidTable");function j3(e,t){return yM.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(j3,"validateSchemaExists");function J3(e,t){let r=t.state.ancestors[0].schema;return yM.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(J3,"validateTableExists");function Q3(e,t){return e.toLowerCase()===RM.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${RM.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(Q3,"validateSchemaName");bM.exports={common_validators:ya,schema_regex:Ou,hdb_schema_table:K3,validateSchemaExists:j3,validateTableExists:J3,validateSchemaName:Q3,checkValidTable:z3,hdb_database:Y3,hdb_table:W3}});var it=I((jbe,OM)=>{"use strict";var Sn=require("validate.js");Sn.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||Sn.validators.type.checks[t](e)?null:` must be a '${t}' value`};Sn.validators.type.checks={Object:a(function(e){return Sn.isObject(e)&&!Sn.isArray(e)},"Object"),Array:Sn.isArray,Integer:Sn.isInteger,Number:Sn.isNumber,String:Sn.isString,Date:Sn.isDate,Boolean:a(function(e){return typeof e=="boolean"},"Boolean")};Sn.validators.hasValidFileExt=function(e,t){return Sn.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};OM.exports={validateObject:X3,validateObjectAsync:Z3,validateBySchema:eX};function X3(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=Sn(e,t,{format:"flat"});return r?new Error(r):null}a(X3,"validateObject");async function Z3(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await Sn.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(Z3,"validateObjectAsync");function eX(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(eX,"validateBySchema")});var GR=I((Qbe,wM)=>{var{hdb_table:tX,hdb_database:NM}=Li(),rX=it(),FR=require("joi"),nX={undefined:"undefined",null:"null"},sX=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||nX[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"),iX=FR.object({database:NM,schema:NM,table:tX,records:FR.array().items(FR.object().custom(sX)).required()});wM.exports=function(e){return rX.validateBySchema(e,iX)}});var CM=I((Zbe,IM)=>{"use strict";var qR=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")}};IM.exports=qR});var DM=I((tOe,PM)=>{"use strict";var $R=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};PM.exports=$R});var xM={};Ue(xM,{HAS_EXPIRATION:()=>zm,HAS_RESIDENCY_ID:()=>JR,HAS_STRUCTURE_UPDATE:()=>Jm,LAST_TIMESTAMP_PLACEHOLDER:()=>r_,LOCAL_TIMESTAMP:()=>oX,METADATA:()=>Xf,NEW_TIMESTAMP_PLACEHOLDER:()=>MM,NO_TIMESTAMP:()=>VR,PENDING_LOCAL_TIME:()=>QR,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>jR,RecordEncoder:()=>zR,TIMESTAMP_ASSIGN_LAST:()=>cX,TIMESTAMP_ASSIGN_NEW:()=>vM,TIMESTAMP_ASSIGN_PREVIOUS:()=>UM,TIMESTAMP_PLACEHOLDER:()=>Ym,TIMESTAMP_RECORD_PREVIOUS:()=>KR,handleLocalTimeForGets:()=>Qm,recordUpdater:()=>XR,removeEntry:()=>kc});function uX(){return t_[0]=t_[0]^64,aX.getFloat64(0)}function Qm(e,t){let r=e.getEntry;e.readCount=0,e.cachePuts=!1,e.rootStore=t,e.encoder.rootStore=t,e.getEntry=function(o,c){e.readCount++;let l=r.call(this,o,c),u=l?.value,f=u?.[Xf];return f>=0&&(l.metadataFlags=f,l.localTime=u.localTime,l.value=u.value,l.residencyId=u.residencyId,u.expiresAt>=0&&(l.expiresAt=u.expiresAt)),l&&(l.key=o),l};let n=e.get;e.get=function(o,c){let l=n.call(this,o,c);return l?.[Xf]>=0?l.value:l};let s=e.getRange;e.getRange=function(o){let c=s.call(this,o);return o.valuesForKey?c.map(l=>l?.value):o.values===!1||o.onlyCount?c:c.map(l=>{let u=l.value,f=u[Xf];return f>=0&&(l.metadataFlags=f,l.localTime=u.localTime,l.value=u.value,l.residencyId=u.residencyId,u.expiresAt>=0&&(l.expiresAt=u.expiresAt)),l})};let i=e.useReadTransaction();if(i.done(),!i.done.isTracked){let o=i.constructor,c=i.use,l=i.done;o.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,Hc.push(new WeakRef(this))),c.call(this)},o.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<Hc.length;u++){let f=Hc[u].deref();(!f||f.isDone||f.isCommitted)&&Hc.splice(u--,1)}},o.prototype.done.isTracked=!0}return e}function XR(e,t,r){return function(n,s,i,o,c=-1,l,u,f="put",d,p){d||l==null?Nu=i?.localTime?KR|UM:VR:Nu=l?i?.localTime?KR|16384:vM|16384:VR;let _=u?.expiresAt;if(_>=0&&(c|=zm),e_=c,YR=_,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:Nu>0},S,g=0;try{let R=i?.residencyId,E=u?.residencyId;E&&(WR=E,e_|=JR,g|=Fc),R!==E&&(g|=Gc,R||(R=0)),c&zm&&(g|=s_),u?.originatingOperation&&(g|=n_),d&&(h.ifVersion=S=i?.version??null),i&&i.value&&i.metadataFlags&Gn&&(r.getBinaryFast(i.localTime)||Aa(i.value));let A;if(s!==void 0&&(A=Gm(()=>e.put(n,s,h),n,e.rootStore),vc&&(g|=Gn)),l){let N=u?.user?.username;if(p&&(Gm(()=>e.encoder.encode(p),n,e.rootStore),vc&&(g|=Gn)),e.encoder.hasStructureUpdate&&(g|=Jm,e.encoder.hasStructureUpdate=!1),d&&i?.localTime){let v=i?.localTime,F=r.get(v);if(F){let $=wt(F).previousLocalTime;return A=r.put(v,wu(o,t,n,$,u?.nodeId??server.replication.getThisNodeId(r)??0,N,f,Zf,g,E,R,_),{ifVersion:S}),A}}A=r.put(s===void 0?MM:r_,wu(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,N,f,Zf,g,E,R,_,u?.originatingOperation),{append:f!=="invalidate",instructedWrite:!0,ifVersion:S})}return A}catch(R){throw R.message+=" id: "+n+" options: "+h,R}}}function kc(e,t,r){if(t)return t.value&&t.metadataFlags&Gn&&!e.auditStore.getBinaryFast(t.localTime)&&Aa(t.value),e.remove(t.key,r)}var LM,Wm,Ym,r_,jR,MM,oX,Xf,t_,aX,VR,vM,cX,UM,KR,zm,JR,QR,Jm,lX,Zf,Nu,e_,YR,WR,zR,Hc,Iu=be(()=>{LM=require("msgpackr");_o();Wm=M(W());Ss();Ss();Ym=new Uint8Array([1,1,1,1,4,64,0,0]),r_=new Uint8Array([1,1,1,1,1,0,0,0]),jR=new Uint8Array([1,1,1,1,3,64,0,0]),MM=new Uint8Array([1,1,1,1,0,64,0,0]),oX=Symbol("local-timestamp"),Xf=Symbol("metadata"),t_=new Uint8Array(8),aX=new DataView(t_.buffer,0,8),VR=0,vM=0,cX=1,UM=3,KR=4,zm=16,JR=32,QR=1,Jm=256,Nu=0,e_=-1,YR=-1,WR=0,zR=class extends LM.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(Nu||e_>=0){let o=0,c=Nu;c&&(o+=8,Nu=0);let l=e_,u=YR,f=WR;l>=0&&(o+=4,e_=-1,u>=0&&(o+=8,YR=-1),f&&(o+=4,WR=0));let d=lX=r.call(this,s,i|2048|o);Zf=d.subarray((d.start||0)+o,d.end);let p=d.start||0;return c&&(Ym[4]=c,Ym[5]=c>>8,d.set(Ym,p),p+=8),vc&&(l|=Gn),l>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(p,l|jm<<24),p+=4,u>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setFloat64(p,u),p+=8),f&&(d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(p,f)),d}else return Zf=r.call(this,s,i),Zf};let n=this.saveStructures;this.saveStructures=function(s,i){let o=n.call(this,s,i);return this.hasStructureUpdate=!0,o}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(t_,0,c),c+=8;else for(let p=0;p<8;p++)t_[p]=t[c++];l=uX(),i=t[c]}let u,f;i<32&&(i===jm?(o=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4):(o=i|t[c+1]<<5,c+=2),o&zm&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&JR&&(f=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let d=Uc(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return{localTime:l,value:d,[Xf]:o,expiresAt:u,residencyId:f}}return r?.valueAsBuffer?t:Uc(()=>super.decode(t,r),this.rootStore)}catch(c){return Wm.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};a(uX,"getTimestamp");a(Qm,"handleLocalTimeForGets");Hc=[];setInterval(()=>{for(let e=0;e<Hc.length;e++){let t=Hc[e].deref();!t||t.isDone||t.isCommitted?Hc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(Wm.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):Wm.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(XR,"recordUpdater");a(kc,"removeEntry")});var i_=I((aOe,HM)=>{"use strict";var BM=ce(),dX=(H(),P(G)),{RecordEncoder:fX}=(Iu(),P(xM));BM.initSync();var _X=BM.get(dX.CONFIG_PARAMS.STORAGE_CACHING)!==!1,ZR=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=_X&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:fX})}};HM.exports=ZR});var o_=I((lOe,kM)=>{"use strict";var qn=ce(),Ts=(H(),P(G));qn.initSync();var Xm=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=qn.get(Ts.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||qn.get(Ts.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||qn.get(Ts.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",qn.get(Ts.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=qn.get(Ts.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),qn.get(Ts.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=qn.get(Ts.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),qn.get(Ts.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=qn.get(Ts.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),qn.get(Ts.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=qn.get(Ts.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=qn.get(Ts.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};kM.exports=Xm;Xm.MAX_DBS=1e4});var ft=I((dOe,jM)=>{"use strict";var ty=require("lmdb"),Xs=require("fs-extra"),$n=require("path"),Zm=pn(),qM=W(),Tn=Bn().LMDB_ERRORS_ENUM,eE=DM(),ry=i_(),$M=o_(),ba=xt(),FM=(H(),P(G)),{table:pX,resetDatabases:hX}=(De(),P(nt)),GM=ce(),Zs=ba.INTERNAL_DBIS_NAME,VM=ba.DBI_DEFINITION_NAME,mX="data.mdb",EX="lock.mdb",a_=".mdb",gX="-lock",ey=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=As(t,r),this.key_type=this.dbi[ba.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[ba.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new ty.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function tE(e,t){if(e===void 0)throw new Error(Tn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(Tn.ENV_NAME_REQUIRED)}a(tE,"pathEnvNameValidation");async function ny(e,t,r=!0){try{await Xs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Tn.INVALID_BASE_PATH):n}try{let n=$n.join(e,t+a_);return await Xs.access(n,Xs.constants.R_OK|Xs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Xs.access($n.join(e,t,mX),Xs.constants.R_OK|Xs.constants.F_OK),$n.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(Tn.INVALID_ENVIRONMENT)}else throw new Error(Tn.INVALID_ENVIRONMENT);throw n}}a(ny,"validateEnvironmentPath");function rE(e,t){if(Zm.validateEnv(e),t===void 0)throw new Error(Tn.DBI_NAME_REQUIRED)}a(rE,"validateEnvDBIName");async function SX(e,t,r=!1,n=!1){tE(e,t);let s=$n.basename(e);t=t.toString();let i=GM.get(FM.CONFIG_PARAMS.DATABASES);i||GM.setProperty(FM.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await ny(e,t,n),KM(e,t,r)}catch(o){if(o.message===Tn.INVALID_ENVIRONMENT){let c=$n.join(e,t);await Xs.mkdirp(n?c:e);let l=new $M(n?c:c+a_,!1),u=ty.open(l);u.dbis=Object.create(null);let f=new ry(!1);u.openDB(Zs,f),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=sy(e,t,r);return u[ba.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=u,u}throw o}}a(SX,"createEnvironment");async function TX(e,t,r,n=!0){tE(e,t),t=t.toString();let s=$n.join(e,t);return pX({table:t,database:$n.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(TX,"copyEnvironment");async function KM(e,t,r=!1){tE(e,t),t=t.toString();let n=sy(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 ny(e,t),i=$n.join(e,t+a_),o=s!=i,c=new $M(s,o),l=ty.open(c);l.dbis=Object.create(null);let u=WM(l);for(let f=0;f<u.length;f++)As(l,u[f]);return l[ba.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(KM,"openEnvironment");async function AX(e,t,r=!1){tE(e,t),t=t.toString();let n=$n.join(e,t+a_),s=await ny(e,t);if(global.lmdb_map!==void 0){let i=sy(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await YM(o),delete global.lmdb_map[i]}}await Xs.remove(s),await Xs.remove(s===n?s+gX:$n.join($n.dirname(s),EX))}a(AX,"deleteEnvironment");async function YM(e){Zm.validateEnv(e);let t=e[ba.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(YM,"closeEnvironment");function sy(e,t,r=!1){let s=`${$n.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(sy,"getCachedEnvironmentName");function RX(e){Zm.validateEnv(e);let t=Object.create(null),r=As(e,Zs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Zs)try{t[n]=Object.assign(new eE,s)}catch{qM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(RX,"listDBIDefinitions");function WM(e){Zm.validateEnv(e);let t=[],r=As(e,Zs);for(let{key:n}of r.getRange({start:!1}))n!==Zs&&t.push(n);return t}a(WM,"listDBIs");function yX(e,t){let n=As(e,Zs).getEntry(t),s=new eE;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{qM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(yX,"getDBIDefinition");function zM(e,t,r,n=!r){if(rE(e,t),t=t.toString(),t===Zs)throw new Error(Tn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return As(e,t)}catch(s){if(s.message===Tn.DBI_DOES_NOT_EXIST){let i=new ry(r,n===!0),o=e.openDB(t,i),c=new eE(r===!0,n);return o[VM]=c,As(e,Zs).putSync(t,c),e.dbis[t]=o,o}throw s}}a(zM,"createDBI");function As(e,t){if(rE(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Zs?r=yX(e,t):r=new eE,r===void 0)throw new Error(Tn.DBI_DOES_NOT_EXIST);let n;try{let s=new ry(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(Tn.DBI_DOES_NOT_EXIST):s}return n[VM]=r,e.dbis[t]=n,n}a(As,"openDBI");function bX(e,t){rE(e,t),t=t.toString();let r=As(e,t),n=r.getStats();return r[ba.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(bX,"statDBI");async function OX(e,t){try{let r=$n.join(e,t+a_);return(await Xs.stat(r)).size}catch{throw new Error(Tn.INVALID_ENVIRONMENT)}}a(OX,"environmentDataSize");function NX(e,t){if(rE(e,t),t=t.toString(),t===Zs)throw new Error(Tn.CANNOT_DROP_INTERNAL_DBIS_NAME);As(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],As(e,Zs).removeSync(t)}a(NX,"dropDBI");function wX(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{As(e,i)}catch(o){if(o.message===Tn.DBI_DOES_NOT_EXIST)zM(e,i,i!==t,i===t),n=!0;else throw o}}n&&hX()}a(wX,"initializeDBIs");jM.exports={openDBI:As,openEnvironment:KM,createEnvironment:SX,listDBIs:WM,listDBIDefinitions:RX,createDBI:zM,dropDBI:NX,statDBI:bX,deleteEnvironment:AX,initializeDBIs:wX,TransactionCursor:ey,environmentDataSize:OX,copyEnvironment:TX,closeEnvironment:YM}});var QM=I((_Oe,JM)=>{"use strict";var iy=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};JM.exports=iy});var ZM=I((hOe,XM)=>{"use strict";var oy=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}};XM.exports=oy});var tv=I((EOe,ev)=>{"use strict";var ay=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};ev.exports=ay});var $c=I((ROe,sv)=>{"use strict";var IX=ft(),CX=QM(),PX=ZM(),DX=tv(),Mi=pn(),c_=Bn().LMDB_ERRORS_ENUM,LX=xt(),po=(H(),P(G)),MX=ae(),vX=require("uuid"),SOe=require("lmdb"),{handleHDBError:UX,hdb_errors:xX}=pe(),{OVERFLOW_MARKER:TOe,MAX_SEARCH_KEY_LENGTH:AOe}=LX,rv=ce();rv.initSync();var nE=rv.get(po.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),cy=po.TIME_STAMP_NAMES_ENUM.CREATED_TIME,qc=po.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function BX(e,t,r,n,s=Mi.getNextMonotonicTime()){fy(e,t,r,n),ly(e,t,r);let i=new CX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];nv(u,!0,s);let f=HX(e,t,r,u),d=u[t];o.push(f),c.push(d)}return uy(o,c,n,i,s)}a(BX,"insertRecords");function HX(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 f=c([[{}]]);Array.isArray(f)&&(c=f[0][po.FUNC_VAL],n[o]=c)}let l=Mi.getIndexedValues(c),u=e.dbis[o];if(l){nE&&u.prefetch(l.map(f=>({key:f,value:s})),sE);for(let f=0,d=l.length;f<d;f++)u.put(l[f],s)}}nE&&e.dbis[t].prefetch([s],sE),e.dbis[t].put(s,n,n[qc])})}a(HX,"insertRecord");function kX(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(kX,"removeSkippedRecords");function nv(e,t,r){let n=r>0;(n||!Number.isInteger(e[qc]))&&(e[qc]=r||(r=Mi.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[cy]))&&(e[cy]=r||Mi.getNextMonotonicTime()):delete e[cy]}a(nv,"setTimestamps");function ly(e,t,r){r.indexOf(po.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(po.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(po.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(po.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),IX.initializeDBIs(e,t,r)}a(ly,"initializeTransaction");async function FX(e,t,r,n,s=Mi.getNextMonotonicTime()){fy(e,t,r,n),ly(e,t,r);let i=new PX,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let f=n[u],d=f[t],p;try{p=dy(e,t,f,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(u);continue}c.push(p),l.push(d)}return uy(c,l,n,i,s,o)}a(FX,"updateRecords");async function GX(e,t,r,n,s=Mi.getNextMonotonicTime()){try{fy(e,t,r,n)}catch(l){throw UX(l,l.message,xX.HTTP_STATUS_CODES.BAD_REQUEST)}ly(e,t,r);let i=new DX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],f;MX.isEmpty(u[t])?(f=vX.v4(),u[t]=f):f=u[t];let d=dy(e,t,u,f,i,!1,s);o.push(d),c.push(f)}return uy(o,c,n,i,s)}a(GX,"upsertRecords");async function uy(e,t,r,n,s,i=[]){let o=await Promise.all(e);for(let c=0,l=o.length;c<l;c++)o[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||Mi.getNextMonotonicTime(),kX(r,i),n}a(uy,"finalizeWrite");function dy(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),u=l?.value,f=u;if(!u){if(i)return!1;u={}}if(nv(r,!f,o),Number.isInteger(r[qc])&&u[qc]>r[qc])return!1;f&&s.original_records.push(u);let d,p=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let S=r[h],g=e.dbis[h];if(g===void 0)continue;let R=u[h];if(typeof S=="function"){let A=S([[u]]);Array.isArray(A)&&(S=A[0][po.FUNC_VAL],r[h]=S)}if(S===R)continue;let E=Mi.getIndexedValues(R);if(E){nE&&g.prefetch(E.map(A=>({key:A,value:n})),sE);for(let A=0,N=E.length;A<N;A++)g.remove(E[A],n)}if(E=Mi.getIndexedValues(S),E){nE&&g.prefetch(E.map(A=>({key:A,value:n})),sE);for(let A=0,N=E.length;A<N;A++)g.put(E[A],n)}}let _={...u,...r};c.put(n,_,_[qc])},"do_put");return l?d=c.ifVersion(n,l.version,p):d=c.ifNoExists(n,p),d.then(_=>_?!0:dy(e,t,r,n,s,i,o))}a(dy,"updateUpsertRecord");function qX(e,t,r){if(Mi.validateEnv(e),t===void 0)throw new Error(c_.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(c_.WRITE_ATTRIBUTES_REQUIRED):new Error(c_.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(qX,"validateBasic");function fy(e,t,r,n){if(qX(e,t,r),!Array.isArray(n))throw n===void 0?new Error(c_.RECORDS_REQUIRED):new Error(c_.RECORDS_MUST_BE_ARRAY)}a(fy,"validateWrite");function sE(){}a(sE,"noop");sv.exports={insertRecords:BX,updateRecords:FX,upsertRecords:GX}});var ho=I((bOe,$X)=>{$X.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"hash_function"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"revoked_certificates"},{attribute:"shard"}]},hdb_certificate:{hash_attribute:"name",name:"hdb_certificate",schema:"system",attributes:[{attribute:"name"},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var ov=I((OOe,iv)=>{"use strict";var VX=require("uuid"),_y=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||VX.v4(),this.schema_table=`${this.schema}.${this.table}`}};iv.exports=_y});var iE=I((wOe,av)=>{"use strict";var KX=ov(),py=class extends KX{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}};av.exports=py});var lv=I((COe,cv)=>{"use strict";cv.exports=WX;var YX="inserted";function WX(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===YX?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(WX,"returnObject")});var oE=I((LOe,dv)=>{"use strict";var zX=(H(),P(G)),hy=ft(),jX=$c(),{getSystemSchemaPath:JX,getSchemaPath:QX}=Et(),DOe=ho(),{validateBySchema:XX}=it(),l_=require("joi"),ZX=iE(),e6=lv(),{handleHDBError:t6,hdb_errors:r6,ClientError:n6}=pe(),uv=ae(),{HTTP_STATUS_CODES:s6}=r6,i6="inserted";dv.exports=o6;async function o6(e){let t=XX(e,l_.object({database:l_.string(),schema:l_.string(),table:l_.string().required(),attribute:l_.string().required()}));if(t)throw new n6(t.message);let r=!e.skip_table_check&&uv.checkGlobalSchemaTable(e.schema,e.table);if(r)throw t6(new Error,r,s6.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=uv.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 ZX(e.schema,e.table,e.attribute,e.id);try{let i=await hy.openEnvironment(QX(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}`);hy.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await hy.openEnvironment(JX(),zX.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await jX.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return e6(i6,c,{records:[s]},l)}catch(i){throw i}}a(o6,"lmdbCreateAttribute")});var u_=I((UOe,_v)=>{"use strict";var mo=ae(),fv=W(),vOe=GR(),{getDatabases:a6}=(De(),P(nt)),{ClientError:Vc}=pe();_v.exports=c6;function c6(e){if(mo.isEmpty(e))throw new Vc("invalid update parameters defined.");if(mo.isEmptyOrZeroLength(e.schema))throw new Vc("invalid schema specified.");if(mo.isEmptyOrZeroLength(e.table))throw new Vc("invalid table specified.");if(!Array.isArray(e.records))throw new Vc("records must be an array");let t=a6()[e.schema]?.[e.table];if(mo.isEmpty(t))throw new Vc(`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&&mo.isEmptyOrZeroLength(o[r]))throw fv.error("a valid hash attribute must be provided with update record:",o),new Vc("a valid hash attribute must be provided with update record, check log for more info");if(!mo.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw fv.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Vc(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!mo.isEmpty(o[r])&&o[r]!==""&&n.has(mo.autoCast(o[r]))&&(o.skip=!0),n.add(mo.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(c6,"insertUpdateValidate")});var hv=I((BOe,pv)=>{"use strict";var my=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};pv.exports=my});var gv=I((kOe,Ev)=>{"use strict";var Ey=ft(),l6=W(),mv=Bn().LMDB_ERRORS_ENUM;Ev.exports=u6;async function u6(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 Ey.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==mv.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await Ey.closeEnvironment(global.lmdb_map[n]),await Ey.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==mv.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){l6.error(t)}}a(u6,"cleanLMDBMap")});var Dv=I((qOe,Pv)=>{"use strict";var gy=require("recursive-iterator"),d6=require("alasql"),Sy=require("clone"),Sv=ae(),{handleHDBError:Tv,hdb_errors:f6}=pe(),{HDB_ERROR_MSGS:Av,HTTP_STATUS_CODES:Rv}=f6,{getDatabases:_6}=(De(),P(nt)),p6=["DISTINCT_ARRAY"],yv=Symbol("validateTables"),Ty=Symbol("validateTable"),GOe=Symbol("getAllColumns"),bv=Symbol("validateAllColumns"),aE=Symbol("findColumn"),Ov=Symbol("validateOrderBy"),d_=Symbol("validateSegment"),Ay=Symbol("validateColumn"),Nv=Symbol("setColumnsForTable"),wv=Symbol("checkColumnsForAsterisk"),Iv=Symbol("validateGroupBy"),Cv=Symbol("hasColumns"),Ry=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[yv](),this[wv](),this[bv]()}[yv](){if(this[Cv]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[Ty](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[Ty](t.table)})}}[Cv](){let t=!1,r=new gy(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[Ty](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=_6();if(!r[t.databaseid])throw Tv(new Error,Av.SCHEMA_NOT_FOUND(t.databaseid),Rv.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw Tv(new Error,Av.TABLE_NOT_FOUND(t.databaseid,t.tableid),Rv.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=Sy(s);i.table=Sy(t),this.attributes.push(i)})}[aE](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)}[wv](){let t=new gy(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[Nv](r.tableid)}[Nv](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new d6.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[bv](){this[d_](this.statement.columns,!1),this[d_](this.statement.joins,!1),this[d_](this.statement.where,!1),this[Iv](this.statement.group,!1),this[d_](this.statement.order,!0)}[d_](t,r){if(!t)return;let n=new gy(t),s=[];for(let{node:i,path:o}of n)!Sv.isEmpty(i)&&!Sv.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[Ov](i):s.push(this[Ay](i)));return s}[Iv](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&p6.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=Sy(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[aE](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[aE](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`}[Ov](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[Ay](t)}[Ay](t){let r=this[aE](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]}};Pv.exports=Ry});var Uv=I((VOe,vv)=>{"use strict";var Lv=require("lodash"),f_=require("mathjs"),h6=require("jsonata"),Mv=ae();vv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?Lv.uniqWith(e,Lv.isEqual):e,"distinct_array"),searchJSON:m6,mad:__.bind(null,f_.mad),mean:__.bind(null,f_.mean),mode:__.bind(null,f_.mode),prod:__.bind(null,f_.prod),median:__.bind(null,f_.median)};function __(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(__,"aggregateFunction");function m6(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(Mv.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),Mv.isEmpty(this.__ala__.res[r])){let n=h6(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(m6,"searchJSON")});var Bv=I((YOe,xv)=>{"use strict";var er=require("moment"),yy="YYYY-MM-DDTHH:mm:ss.SSSZZ";er.suppressDeprecationWarnings=!0;xv.exports={current_date:a(()=>er().utc().format("YYYY-MM-DD"),"current_date"),current_time:a(()=>er().utc().format("HH:mm:ss.SSS"),"current_time"),extract:a((e,t)=>{switch(t.toLowerCase()){case"year":return er(e).utc().format("YYYY");case"month":return er(e).utc().format("MM");case"day":return er(e).utc().format("DD");case"hour":return er(e).utc().format("HH");case"minute":return er(e).utc().format("mm");case"second":return er(e).utc().format("ss");case"millisecond":return er(e).utc().format("SSS");default:break}},"extract"),date:a(e=>er(e).utc().format(yy),"date"),date_format:a((e,t)=>er(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>er(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>er(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=er(e).utc(),s=er(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>er().utc().valueOf(),"now"),get_server_time:a(()=>er().format(yy),"get_server_time"),offset_utc:a((e,t)=>er(e).utc().utcOffset(t).format(yy),"offset_utc")}});var Gv=I((zOe,Fv)=>{"use strict";var E6=require("@turf/area"),g6=require("@turf/length"),S6=require("@turf/circle"),T6=require("@turf/difference"),A6=require("@turf/distance"),R6=require("@turf/boolean-contains"),y6=require("@turf/boolean-equal"),b6=require("@turf/boolean-disjoint"),O6=require("@turf/helpers"),Hv=(H(),P(G)),qe=ae(),Eo=W();Fv.exports={geoArea:N6,geoLength:w6,geoCircle:I6,geoDifference:C6,geoDistance:kv,geoNear:P6,geoContains:D6,geoEqual:L6,geoCrosses:M6,geoConvert:v6};function N6(e){if(qe.isEmpty(e))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e));try{return E6.default(e)}catch(t){return Eo.trace(t,e),NaN}}a(N6,"geoArea");function w6(e,t){if(qe.isEmpty(e))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e));try{return g6.default(e,{units:t||"kilometers"})}catch(r){return Eo.trace(r,e),NaN}}a(w6,"geoLength");function I6(e,t,r){if(qe.isEmpty(e))return NaN;if(qe.isEmpty(t))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e));try{return S6.default(e,t,{units:r||"kilometers"})}catch(n){return Eo.trace(n,e,t),NaN}}a(I6,"geoCircle");function C6(e,t){if(qe.isEmpty(e))return NaN;if(qe.isEmpty(t))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return T6(e,t)}catch(r){return Eo.trace(r,e,t),NaN}}a(C6,"geoDifference");function kv(e,t,r){if(qe.isEmpty(e))return NaN;if(qe.isEmpty(t))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return A6.default(e,t,{units:r||"kilometers"})}catch(n){return Eo.trace(n,e,t),NaN}}a(kv,"geoDistance");function P6(e,t,r,n){if(qe.isEmpty(e)||qe.isEmpty(t))return!1;if(qe.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return kv(e,t,n)<=r}catch(s){return Eo.trace(s,e,t),!1}}a(P6,"geoNear");function D6(e,t){if(qe.isEmpty(e)||qe.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return R6.default(e,t)}catch(r){return Eo.trace(r,e,t),!1}}a(D6,"geoContains");function L6(e,t){if(qe.isEmpty(e)||qe.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return y6.default(e,t)}catch(r){return Eo.trace(r,e,t),!1}}a(L6,"geoEqual");function M6(e,t){if(qe.isEmpty(e)||qe.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return!b6.default(e,t)}catch(r){return Eo.trace(r,e,t),!1}}a(M6,"geoCrosses");function v6(e,t,r){if(qe.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(qe.isEmpty(t))throw new Error("geo_type is required");if(qe.isEmpty(Hv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(Hv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=qe.autoCastJSON(e)),O6[t](e,r)}a(v6,"geoConvert")});var cE=I((JOe,qv)=>{var Kc=Uv(),Vn=Bv(),vi=Gv();qv.exports=e=>{e.aggr.mad=e.aggr.MAD=Kc.mad,e.aggr.mean=e.aggr.MEAN=Kc.mean,e.aggr.mode=e.aggr.MODE=Kc.mode,e.aggr.prod=e.aggr.PROD=Kc.prod,e.aggr.median=e.aggr.MEDIAN=Kc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Kc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Kc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Vn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Vn.current_time,e.fn.extract=e.fn.EXTRACT=Vn.extract,e.fn.date=e.fn.DATE=Vn.date,e.fn.date_format=e.fn.DATE_FORMAT=Vn.date_format,e.fn.date_add=e.fn.DATE_ADD=Vn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Vn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Vn.date_diff,e.fn.now=e.fn.NOW=Vn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Vn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Vn.get_server_time,e.fn.getdate=e.fn.GETDATE=Vn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Vn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=vi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=vi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=vi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=vi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=vi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=vi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=vi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=vi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=vi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=vi.geoNear}});var Yv=I((QOe,Kv)=>{"use strict";var p_=require("lodash"),An=require("alasql");An.options.cache=!1;var U6=cE(),$v=require("clone"),lE=require("recursive-iterator"),Be=W(),ze=ae(),Cu=Kn(),x6=(H(),P(G)),{hdb_errors:B6}=pe(),{getDatabases:Vv}=(De(),P(nt)),H6="IS NULL",ei="There was a problem performing this search. Please check the logs and try again.";U6(An);var by=class{static{a(this,"SQLSearch")}constructor(t,r){if(ze.isEmpty(t))throw Be.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(),ze.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!ze.isEmptyOrZeroLength(n))return Be.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw Be.error("Error thrown from checkEmptySQL in SQLSearch class method search."),Be.error(n),new Error(ei)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw Be.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),Be.error(n),new Error(ei)}if(Object.keys(this.data).length===0)return Be.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw Be.error("Error thrown from processJoins in SQLSearch class method search."),Be.error(n),new Error(ei)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw Be.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),Be.error(n),new Error(ei)}try{return t=await this._finalSQL(),t}catch(n){throw Be.error("Error thrown from finalSQL in SQLSearch class method search."),Be.error(n),new Error(ei)}}_getColumns(){let t=new lE(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($v(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=p_.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=Vv()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(ze.isEmpty(this.statement.where)){Be.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new lE(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!ze.isEmpty(r)&&r.right)if(ze.isNotEmptyAndHasValue(r.right.value)){let n=ze.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new An.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=ze.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new An.yy.LogicValue({value:i}):n instanceof An.yy.StringValue&&ze.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new An.yy.NumValue({value:i}))});if(t){Be.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new lE(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(!ze.isEmpty(x6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(ze.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(ze.isEmptyOrZeroLength(r.left.columnid)||ze.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(ze.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"=":!ze.isEmpty(r.right.value)||!ze.isEmpty(r.left.value)?n.add(ze.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let l=Array.isArray(r.right)?r.right:r.left;for(let u=0;u<l.length;u++)if(l[u].value)n.add(l[u].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(ze.isEmptyOrZeroLength(this.all_table_attributes)&&ze.isEmptyOrZeroLength(this.statement.from)&&ze.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&&p_.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(ze.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);ze.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(ze.isEmptyOrZeroLength(this.all_table_attributes)&&!ze.isEmptyOrZeroLength(this.columns.columns))return t;if(ze.isEmptyOrZeroLength(this.all_table_attributes)&&ze.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await An.promise(r)}catch(r){throw Be.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),Be.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($v(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(ze.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(H6)>-1&&this.tables.forEach(s=>{let i={columnid:Vv()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=p_.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,u=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!ze.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!ze.isEmptyOrZeroLength(this.exact_search_values[u].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[u].values);let f=await Cu.getDataByHash(c);for(let d of c.hash_values)f.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(f){throw Be.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),Be.error(f),new Error(ei)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async f=>{let d={...c};d.search_value=f;let p=await Cu.getDataByValue(d);for(let[_,h]of p)this.data[i].__merged_data[_]?this._updateMergedAttribute(i,_,s.attribute,h[s.attribute]):(this.data[i].__merged_data[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,_))}))}catch(f){throw Be.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),Be.error(f),new Error(ei)}else if(!ze.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!ze.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let f=this.comparator_search_values[u].comparators;for(let d=0,p=f.length;d<p;d++){let _=f[d];c.search_attribute=_.attribute,c.search_value=_.search_value;let h=await Cu.getDataByValue(c,_.operation);if(l)for(let[S]of h)this.data[i].__merged_data[S]||(this.data[i].__merged_data[S]=[...n[i]],this._setMergedHashAttribute(i,S));else for(let[S,g]of h)this.data[i].__merged_data[S]?this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]):(this.data[i].__merged_data[S]=[...n[i]],this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]),this._setMergedHashAttribute(i,S))}}catch(f){throw Be.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),Be.error(f),new Error(ei)}else try{c.search_attribute=s.attribute,c.search_value="*";let f=await Cu.getDataByValue(c);if(l)for(let[d]of f)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,p]of f)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,p[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,p[s.attribute]),this._setMergedHashAttribute(i,d))}catch(f){throw Be.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),Be.error(f),new Error(ei)}}}_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 An.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 An.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new An.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 An.yy.FuncValue:new An.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(_=>{_.joinmode&&_.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(_.table);let h=_.joinmode+" JOIN ? AS "+(_.as?_.as:_.table.tableid);_.on&&(h+=" ON "+_.on.toString()),i.push(h),t.push(Object.values(this.data[`${_.table.databaseid_orig}_${_.table.as?_.table.as_orig:_.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(_=>{let h=this.data[`${_.databaseid_orig}_${_.as?_.as_orig:_.tableid_orig}`].__hash_name,S=_.as?_.as_orig:_.tableid_orig;o.push({key:`'${S}.${h}'`,schema:_.databaseid_orig,table:_.as?_.as_orig:_.tableid_orig,keys:new Set}),r.push(`${_.as?_.as:_.tableid}.\`${h}\` AS "${S}.${h}"`),c[_.as?_.as_orig:_.tableid_orig]=this.data[`${_.databaseid_orig}_${_.as?_.as_orig:_.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let u="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(u="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(_=>{_.is_func?r.push(_.initial_select_column.toString()):_.initial_select_column.tableid?r.push(`${_.initial_select_column.tableid}.${_.initial_select_column.columnid} AS ${_.expression.columnid}`):r.push(`${_.initial_select_column.columnid} AS ${_.expression.columnid}`)}));let f="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(f=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let p=[];try{let _=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${u} ${f} ${d}`,h=this._convertColumnsToIndexes(_,s);p=await An.promise(h,t),t=null}catch(_){throw Be.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),Be.error(_),new Error("There was a problem processing the data.")}if(p&&p.length>0){for(let _=0,h=p.length;_<h;_++){let S=p[_];o.forEach(g=>{S[g.key]!==null&&S[g.key]!==void 0&&g.keys.add(S[g.key])})}o.forEach(_=>{let h=Object.keys(this.data[`${_.schema}_${_.table}`].__merged_data),S=p_.difference(h,[..._.keys].map(g=>g.toString()));for(let g=0,R=S.length;g<R;g++){let E=S[g];delete this.data[`${_.schema}_${_.table}`].__merged_data[E]}})}return{existing_attributes:c,joined_length:p?p.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new lE(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=p_.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 Be.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),Be.error(i),new Error(ei)}}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 f in i)o.push(i[f][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 Cu.getDataByHash(c),u=s.columns.length;for(let f=0,d=o.length;f<d;f++){let p=o[f],_=l.get(p);for(let h=0;h<u;h++){let S=s.columns[h],g=_[S]===void 0?null:_[S];this.data[n].__merged_data[p].push(g)}}}}catch(r){throw Be.error("Error thrown from getDataByHash function in SQLSearch class method getData."),Be.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();Be.trace(`Final SQL: ${s}`),n=await An.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),Be.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw Be.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),Be.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 Be.error(B6.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),Be.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],u=new RegExp(`${l}.\`${o}\``,"g"),f=`${l}.[${c}]`;n=n.replace(u,f)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),u=`[${c}]`;n=n.replace(l,u)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await Cu.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]={...r[s]}),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw Be.error("There was an error when processing this SQL operation. Check your logs"),Be.error(o),new Error(ei)}}return Object.values(Object.values(this.data)[0].__merged_data)}};Kv.exports=by});var Wr=I((ZOe,Wv)=>{"use strict";var k6=Dv();Wv.exports={searchByConditions:G6,searchByHash:q6,searchByValue:$6,search:V6};var Oy=Kn(),{transformReq:Ny}=ae(),F6=Yv();async function G6(e){return Ny(e),Oy.searchByConditions(e)}a(G6,"searchByConditions");async function q6(e){Ny(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of Oy.searchByHash(e))r&&t.push(r);return t}a(q6,"searchByHash");async function $6(e){Ny(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of Oy.searchByValue(e))t.push(r);return t}a($6,"searchByValue");function V6(e,t){try{let r=new k6(e);r.validate(),new F6(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(V6,"search")});var go=I((tNe,Qv)=>{"use strict";var h_=require("crypto"),K6=ce(),{CONFIG_PARAMS:Y6}=(H(),P(G)),jv="aes-256-cbc",W6=32,z6=16,wy=64,Jv=32,j6=wy+Jv,zv=new Map;Qv.exports={encrypt:J6,decrypt:Q6,createNatsTableStreamName:X6};function J6(e){let t=h_.randomBytes(W6),r=h_.randomBytes(z6),n=h_.createCipheriv(jv,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(J6,"encrypt");function Q6(e){let t=e.substr(0,wy),r=e.substr(wy,Jv),n=e.substr(j6,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=h_.createDecipheriv(jv,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(Q6,"decrypt");function X6(e,t){let r=K6.get(Y6.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=zv.get(r);return n||(n=h_.createHash("md5").update(r).digest("hex"),zv.set(r,n)),n}a(X6,"createNatsTableStreamName")});var So=I((sNe,tU)=>{"use strict";var nNe=Wr(),m_=W(),{validateBySchema:Xv}=it(),Yc=require("joi"),Z6=go(),uE=ae(),{handleHDBError:dE,hdb_errors:eZ,ClientError:Zv}=pe(),{HDB_ERROR_MSGS:fE,HTTP_STATUS_CODES:Iy}=eZ,eU=ce();eU.initSync();var{getDatabases:Cy}=(De(),P(nt)),tZ=require("fs-extra"),rZ=(H(),P(G));tU.exports={describeAll:nZ,describeTable:_E,describeSchema:sZ};async function nZ(e={}){try{let t=uE.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=Cy(),o={},c={},l=[],u=e?.exact_count;for(let d in i){o[d]=!0,!t&&!s&&!r&&(c[d]=e.hdb_user?.role?.permission[d]?.describe);let p=i[d];for(let _ in p)try{let h;if(t||s||r)h=await _E({schema:d,table:_,exact_count:u});else if(n&&n[d].describe&&n[d].tables[_].describe){let S=n[d].tables[_].attribute_permissions;h=await _E({schema:d,table:_,exact_count:u},S)}h&&l.push(h)}catch(h){m_.error(h)}}let f={};for(let d in l)t||s||r?(f[l[d].schema]==null&&(f[l[d].schema]={}),f[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]):c[l[d].schema]&&(f[l[d].schema]==null&&(f[l[d].schema]={}),f[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?f[d]={}:c[d]&&(f[d]={});return f}catch(t){return m_.error("Got an error in describeAll"),m_.error(t),dE(new Error,fE.DESCRIBE_ALL_ERR)}}a(nZ,"describeAll");async function _E(e,t){uE.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=Xv(e,Yc.object({database:Yc.string(),table:Yc.string().required(),exact_count:Yc.boolean().strict()}));if(i)throw new Zv(i.message);let c=Cy()[r];if(!c)throw dE(new Error,fE.SCHEMA_NOT_FOUND(e.schema),Iy.NOT_FOUND);let l=c[n];if(!l)throw dE(new Error,fE.TABLE_NOT_FOUND(e.schema,e.table),Iy.NOT_FOUND);function u(_){f.push({attribute:_.attribute,type:_.type,elements:_.elements?.type,indexed:_.indexed,is_primary_key:_.isPrimaryKey,assigned_created_time:_.assignCreatedTime,assigned_updated_time:_.assignUpdatedTime,nullable:_.nullable,properties:_.properties?_.properties.map(h=>({type:h.type,name:h.name})):void 0})}a(u,"pushAtt");let f=[];if(s){let _={};s.forEach(h=>{h.describe&&(_[h.attribute_name]=!0)}),l.attributes.forEach(h=>{_[h.name]&&u(h)})}else l.attributes?.forEach(_=>u(_));let d;try{d=(await tZ.stat(l.primaryStore.env.path)).size}catch(_){m_.warn("unable to get database size",_)}let p={schema:r,name:l.tableName,hash_attribute:l.attributes.find(_=>_.isPrimaryKey||_.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:f,db_size:d};l.replicate!==void 0&&(p.replicate=l.replicate),l.expirationMS!==void 0&&(p.expiration=l.expirationMS/1e3+"s"),l.sealed!==void 0&&(p.sealed=l.sealed),l.sources?.length>0&&(p.sources=l.sources.map(_=>_.name).filter(_=>_&&_!=="NATSReplicator"&&_!=="Replicator")),eU.get(rZ.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(p.clustering_stream_name=Z6.createNatsTableStreamName(p.schema,p.name));try{let _=await l.getRecordCount({exactCount:!!e.exact_count});p.record_count=_.recordCount,p.table_size=l.getSize(),p.db_audit_size=l.getAuditSize(),p.estimated_record_range=_.estimatedRange;let h=l.auditStore;if(h)for(let S of h.getKeys({reverse:!0,limit:1}))p.last_updated_record=S[0];if(!p.last_updated_record&&l.indices.__updatedtime__)for(let S of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))p.last_updated_record=S}catch(_){m_.warn(`unable to stat table dbi due to ${_}`)}return p}a(_E,"descTable");async function sZ(e){uE.transformReq(e);let t=Xv(e,Yc.object({database:Yc.string(),exact_count:Yc.boolean().strict()}));if(t)throw new Zv(t.message);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=Cy()[n];if(!i)throw dE(new Error,fE.SCHEMA_NOT_FOUND(e.schema),Iy.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),uE.isEmpty(l)||l.describe){let u=await _E({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(sZ,"describeSchema")});var Rs=I((cNe,oU)=>{var iZ=ho(),{callbackify:nU,promisify:oZ}=require("util"),{getDatabases:sU}=(De(),P(nt));oU.exports={setSchemaDataToGlobal:rU,getTableSchema:aZ,getSystemSchema:cZ,setSchemaDataToGlobalAsync:oZ(rU)};var iU=So(),oNe=nU(iU.describeAll),aNe=nU(iU.describeTable);function rU(e){global.hdb_schema=sU(),e&&e()}a(rU,"setSchemaDataToGlobal");function aZ(e,t,r){let n=sU()[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(aZ,"getTableSchema");function cZ(){return iZ}a(cZ,"getSystemSchema")});var Dy=I((uNe,lU)=>{var lZ=it(),Py=require("joi"),{hdb_table:uZ,hdb_database:aU}=Li(),cU={schema:aU,database:aU,table:uZ},dZ={date:Py.date().iso().required()},fZ={timestamp:Py.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};lU.exports=function(e,t){let r=t==="timestamp"?{...cU,...fZ}:{...cU,...dZ},n=Py.object(r);return lZ.validateBySchema(e,n)}});var fU=I((dNe,dU)=>{var _Z=it(),Ly=require("joi"),{hdb_table:pZ,hdb_database:uU}=Li(),hZ=Ly.object({schema:uU,database:uU,table:pZ,hash_values:Ly.array().required(),ids:Ly.array()});dU.exports=function(e){return _Z.validateBySchema(e,hZ)}});var xy=I((fNe,_U)=>{"use strict";var My=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}},vy=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}},Uy=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};_U.exports={InsertObject:My,NoSQLSeachObject:vy,DeleteResponseObject:Uy}});var jc=I((pNe,gU)=>{"use strict";var hU=Dy(),mZ=fU(),Wc=ae(),pU=require("moment"),mU=W(),{promisify:EZ,callbackify:gZ}=require("util"),zc=(H(),P(G)),SZ=Rs(),By=EZ(SZ.getTableSchema),Hy=Kn(),{DeleteResponseObject:TZ}=xy(),{handleHDBError:Oa,hdb_errors:AZ}=pe(),{HDB_ERROR_MSGS:pE,HTTP_STATUS_CODES:Na}=AZ,RZ="records successfully deleted",yZ=gZ(EU);gU.exports={delete:yZ,deleteRecord:EU,deleteFilesBefore:bZ,deleteAuditLogsBefore:OZ};async function bZ(e){let t=hU(e,"date");if(t)throw Oa(t,t.message,Na.BAD_REQUEST,void 0,void 0,!0);if(Wc.transformReq(e),!pU(e.date,pU.ISO_8601).isValid())throw Oa(new Error,pE.INVALID_DATE,Na.BAD_REQUEST,zc.LOG_LEVELS.ERROR,pE.INVALID_DATE,!0);let n=Wc.checkSchemaTableExist(e.schema,e.table);if(n)throw Oa(new Error,n,Na.NOT_FOUND,zc.LOG_LEVELS.ERROR,n,!0);let s=await Hy.deleteRecordsBefore(e);if(await By(e.schema,e.table),mU.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(bZ,"deleteFilesBefore");async function OZ(e){let t=hU(e,"timestamp");if(t)throw Oa(t,t.message,Na.BAD_REQUEST,void 0,void 0,!0);if(Wc.transformReq(e),isNaN(e.timestamp))throw Oa(new Error,pE.INVALID_VALUE("Timestamp"),Na.BAD_REQUEST,zc.LOG_LEVELS.ERROR,pE.INVALID_VALUE("Timestamp"),!0);let r=Wc.checkSchemaTableExist(e.schema,e.table);if(r)throw Oa(new Error,r,Na.NOT_FOUND,zc.LOG_LEVELS.ERROR,r,!0);let n=await Hy.deleteAuditLogsBefore(e);return await By(e.schema,e.table),mU.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(OZ,"deleteAuditLogsBefore");async function EU(e){e.ids&&(e.hash_values=e.ids);let t=mZ(e);if(t)throw Oa(t,t.message,Na.BAD_REQUEST,void 0,void 0,!0);Wc.transformReq(e);let r=Wc.checkSchemaTableExist(e.schema,e.table);if(r)throw Oa(new Error,r,Na.NOT_FOUND,zc.LOG_LEVELS.ERROR,r,!0);try{await By(e.schema,e.table);let n=await Hy.deleteRecords(e);return Wc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${RZ}`),n}catch(n){if(n.message===zc.SEARCH_NOT_FOUND_MESSAGE){let s=new TZ;return s.message=zc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(EU,"deleteRecord")});var hE={};Ue(hE,{HASH_FUNCTION:()=>S_,hash:()=>Gy,validate:()=>qy});function ky(e=g_){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(E_.randomBytes(e)).map(r=>t[r%t.length]).join("")}function Gy(e,t=S_[TU?.toUpperCase()]??"sha256"){return Fy[t](e)}function qy(e,t,r=S_[TU?.toUpperCase()]??"sha256"){return e?NZ[r](e,t):!1}var E_,Pu,SU,TU,g_,AU,S_,Fy,NZ,mE=be(()=>{E_=M(require("node:crypto")),Pu=M(require("argon2")),SU=M(ce());H();TU=(0,SU.get)(x.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),g_=16,AU=9,S_=(n=>(n.MD5="md5",n.SHA256="sha256",n.ARGON2ID="argon2id",n))(S_||{});a(ky,"generateSalt");Fy={md5:a((e,t=void 0)=>{t=t??ky(AU);let r=E_.createHash("md5").update(e+t).digest("hex");return t+r},"md5"),sha256:a((e,t=void 0)=>{t=t??ky(g_);let r=E_.createHash("sha256").update(e+t).digest("hex");return t+r},"sha256"),argon2id:a(async e=>{let t=ky(g_),r=await Pu.hash(e,{type:Pu.argon2id,salt:Buffer.from(t)});return t+r},"argon2id")},NZ={md5:a((e,t)=>{let r=e.slice(0,AU);return e===Fy.md5(t,r)},"md5"),sha256:a((e,t)=>{let r=e.slice(0,g_);return e===Fy.sha256(t,r)},"sha256"),argon2id:a(async(e,t)=>await Pu.verify(e.slice(g_),t),"argon2id")};a(Gy,"hash");a(qy,"validate")});var yU=I((gNe,RU)=>{var $y=it(),zr={username:{presence:!0,exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function wZ(e){return zr.password.presence=!0,zr.username.presence=!0,zr.role.presence=!0,zr.active.presence=!0,$y.validateObject(e,zr)}a(wZ,"addUserValidation");function IZ(e){return zr.password.presence=!1,zr.username.presence=!0,zr.role.presence=!1,zr.active.presence=!1,$y.validateObject(e,zr)}a(IZ,"alterUserValidation");function CZ(e){return zr.password.presence=!1,zr.username.presence=!0,zr.role.presence=!1,zr.active.presence=!1,$y.validateObject(e,zr)}a(CZ,"dropUserValidation");RU.exports={addUserValidation:wZ,alterUserValidation:IZ,dropUserValidation:CZ}});var St=I((ANe,OU)=>{"use strict";var{platform:TNe}=require("os"),PZ="nats-server.zip",Vy="nats-server",DZ=process.platform==="win32"?`${Vy}.exe`:Vy,LZ=/^[^\s.,*>]+$/,bU="__request__",MZ=a(e=>`${e}.${bU}`,"REQUEST_SUBJECT"),vZ={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},UZ={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},xZ={HUB:"hub.pid",LEAF:"leaf.pid"},BZ={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},HZ={SUCCESS:"success",ERROR:"error"},kZ={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},FZ={TXN:"txn",MSGID:"msgid"},Du={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},GZ={[Du.ERR]:1,[Du.WRN]:2,[Du.INF]:3,[Du.DBG]:4,[Du.TRC]:5},qZ={debug:"-D",trace:"-DVV"};OU.exports={NATS_SERVER_ZIP:PZ,NATS_SERVER_NAME:Vy,NATS_BINARY_NAME:DZ,PID_FILES:xZ,NATS_CONFIG_FILES:UZ,SERVER_SUFFIX:BZ,NATS_TERM_CONSTRAINTS_RX:LZ,REQUEST_SUFFIX:bU,UPDATE_REMOTE_RESPONSE_STATUSES:HZ,CLUSTER_STATUS_STATUSES:kZ,REQUEST_SUBJECT:MZ,SUBJECT_PREFIXES:FZ,MSG_HEADERS:vZ,LOG_LEVELS:Du,LOG_LEVEL_FLAGS:qZ,LOG_LEVEL_HIERARCHY:GZ}});var Ky=I(NU=>{"use strict";var $Z={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
18
18
  `),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
19
- `)},VZ="certificate.pem",KZ="privateKey.pem",YZ="caCertificate.pem",WZ="natsCertificate.pem",zZ="natsCaCertificate.pem",At={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},jZ={tls_certificate:At.SERVER,tls_certificateAuthority:At.CA,customFunctions_tls_certificate:At.SERVER,customFunctions_tls_certificateAuthority:At.CA,operationsApi_tls_certificate:At["OPERATIONS-API"],operationsApi_tls_certificateAuthority:At["OPERATIONS-CA"]},JZ={[At.SERVER]:2,[At.DEFAULT]:1},QZ={[At["OPERATIONS-API"]]:3,[At.SERVER]:2,[At.DEFAULT]:1},XZ={[At["OPERATIONS-API"]]:3,[At.SERVER]:2,[At.DEFAULT]:1},ZZ={[At["OPERATIONS-CA"]]:3,[At.CA]:2,[At["DEFAULT-CA"]]:1},e8={[At["OPERATIONS-CA"]]:3,[At.CA]:2,[At["DEFAULT-CA"]]:1},t8={[At.CA]:2,[At["DEFAULT-CA"]]:1};Object.assign(NU,{CERTIFICATE_PEM_NAME:VZ,PRIVATEKEY_PEM_NAME:KZ,CA_PEM_NAME:YZ,CERT_NAME:At,CERT_CONFIG_NAME_MAP:jZ,CERT_PREFERENCE_APP:JZ,CERT_PREFERENCE_OPS:QZ,CERT_PREFERENCE_REP:XZ,CA_CERT_PREFERENCE_REP:ZZ,CA_CERT_PREFERENCE_OPS:e8,CA_CERT_PREFERENCE_APP:t8,CERTIFICATE_VALUES:$Z,NATS_CERTIFICATE_PEM_NAME:WZ,NATS_CA_PEM_NAME:zZ})});var Yy=w((wNe,LU)=>{"use strict";var PU=require("fs-extra"),Re=require("joi"),r8=require("os"),{boolean:Be,string:Rt,number:tr,array:Jc}=Re.types(),{totalmem:wU}=require("os"),jc=require("path"),n8=z(),Ky=ie(),NNe=Vy(),IU=(H(),C(G)),s8=ot(),CU="log",i8="components",o8="Invalid logging.rotation.maxSize unit. Available units are G, M or K",a8="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",c8="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",l8="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",u8="rootPath config parameter is undefined",An=Re.alternatives([tr.min(0),Rt]).optional().empty(null),mE=Re.alternatives([Jc.items(Rt,{host:Rt.required(),port:An},{hostname:Rt.required(),port:An}).empty(null),Jc.items(Rt)]),vi,DU=!1;LU.exports={configValidator:d8,routesValidator:E8,route_constraints:mE};function d8(e,t=!1){if(DU=t,vi=e.rootPath,Ky.isEmpty(vi))throw u8;let r=Be.optional(),n=tr.min(0).max(1e3).empty(null).default(m8),s=Rt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(S_),i=Rt.optional().empty(null),o=Rt.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=Re.string().empty(null).default(S_),l=Re.custom(_8).empty(null).default(S_),u=e.clustering?.enabled,f=Re.object({certificate:i,certificateAuthority:i,privateKey:i}),d;return u===!0?d=Re.object({enabled:r,hubServer:Re.object({cluster:Re.object({name:Re.required().empty(null),network:Re.object({port:An,routes:mE}).required()}).required(),leafNodes:Re.object({network:Re.object({port:An}).required()}).required(),network:Re.object({port:An}).required()}).required(),leafServer:Re.object({network:Re.object({port:An,routes:mE}).required(),streams:Re.object({maxAge:tr.min(120).allow(null).optional(),maxBytes:tr.min(1).allow(null).optional(),maxMsgs:tr.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:Re.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:Be.optional(),databaseLevel:Be.optional(),tls:Re.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:Be.required(),verify:Be.optional()}),user:Rt.optional().empty(null)}).optional():d=Re.object({enabled:r,tls:Re.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:Be.optional()})}).optional(),Re.object({authentication:Re.alternatives(Re.object({authorizeLocal:Be,cacheTTL:tr.required(),enableSessions:Be,hashFunction:Rt.valid("md5","sha256","argon2id").optional().empty(null)}),Be).optional(),analytics:Re.object({aggregatePeriod:tr}),replication:Re.object({hostname:Re.alternatives(Rt,tr).optional().empty(null),url:Rt.optional().empty(null),port:An,securePort:An,routes:Jc.optional().empty(null),databases:Re.alternatives(Rt,Jc),enableRootCAs:Be.optional(),copyTablesToCatchUp:Be.optional()}).optional(),componentsRoot:s.optional(),clustering:d,localStudio:Re.object({enabled:r}).required(),logging:Re.object({auditAuthEvents:Re.object({logFailed:Be,logSuccessful:Be}),file:Be.required(),level:Re.valid("notify","fatal","error","warn","info","debug","trace"),rotation:Re.object({enabled:Be.optional(),compress:Be.optional(),interval:Rt.custom(h8).optional().empty(null),maxSize:Rt.custom(p8).optional().empty(null),path:Rt.optional().empty(null).default(S_)}).required(),root:s,stdStreams:Be.required(),auditLog:Be.required()}).required(),operationsApi:Re.object({network:Re.object({cors:Be.optional(),corsAccessList:Jc.optional(),headersTimeout:tr.min(1).optional(),keepAliveTimeout:tr.min(1).optional(),port:An,domainSocket:Re.optional().empty("hdb/operations-server").default(S_),securePort:An,timeout:tr.min(1).optional()}).optional(),tls:Re.alternatives([Re.array().items(f),f])}).required(),rootPath:Rt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:Re.object({network:Re.object({port:An,securePort:An,mtls:Re.alternatives([Be.optional(),Re.object({user:Rt.optional(),certificateAuthority:i,required:Be.optional()})])}).required(),webSocket:Be.optional(),requireAuthentication:Be.optional()}),http:Re.object({compressionThreshold:tr.optional(),cors:Be.optional(),corsAccessList:Jc.optional(),headersTimeout:tr.min(1).optional(),port:An,securePort:An,maxHeaderSize:tr.optional(),mtls:Re.alternatives([Be.optional(),Re.object({user:Rt.optional(),certificateAuthority:i,required:Be.optional()})]),threadRange:Re.alternatives([Jc.optional(),Rt.optional()])}).required(),threads:Re.alternatives(n.optional(),Re.object({count:n.optional(),debug:Re.alternatives(Be.optional(),Re.object({startingPort:tr.min(1).optional(),host:Rt.optional(),waitForDebugger:Be.optional()})),maxHeapMemory:tr.min(0).optional()})),storage:Re.object({writeAsync:Be.required(),overlappingSync:Be.optional(),caching:Be.optional(),compression:Re.alternatives([Be.optional(),Re.object({dictionary:Rt.optional(),threshold:tr.optional()})]),compactOnStart:Be.optional(),compactOnStartKeepBackup:Be.optional(),noReadAhead:Be.optional(),path:l,prefetchWrites:Be.optional(),maxFreeSpaceToLoad:tr.optional(),maxFreeSpaceToRetain:tr.optional()}).required(),ignoreScripts:Be.optional(),tls:Re.alternatives([Re.array().items(f),f])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(d8,"configValidator");function f8(e){return DU||PU.existsSync(e)?null:`Specified path ${e} does not exist.`}a(f8,"doesPathExist");function _8(e,t){Re.assert(e,Rt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=f8(e);if(r)return t.message(r)}a(_8,"validatePath");function p8(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(o8);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(c8):e}a(p8,"validateRotationMaxSize");function h8(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(a8);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(l8):e}a(h8,"validateRotationInterval");function m8(e,t){let r=t.state.path.join("."),n=r8.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||wU();return i=Math.round(Math.min(i,wU())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),n8.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(m8,"setDefaultThreads");function S_(e,t){let r=t.state.path.join(".");if(!Ky.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(Ky.isEmpty(vi))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return jc.join(vi,i8);case"logging.root":return jc.join(vi,CU);case"clustering.leafServer.streams.path":return jc.join(vi,"clustering","leaf");case"storage.path":let n=jc.join(vi,IU.LEGACY_DATABASES_DIR_NAME);return PU.existsSync(n)?n:jc.join(vi,IU.DATABASES_DIR_NAME);case"logging.rotation.path":return jc.join(vi,CU);case"operationsApi.network.domainSocket":return r==null?null:jc.join(vi,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(S_,"setDefaultRoot");function E8(e){let t=Re.object({routes:mE});return s8.validateBySchema({routes:e},t)}a(E8,"routesValidator")});var yt=w($U=>{"use strict";var Rs=(H(),C(G)),Sr=ie(),rr=z(),{configValidator:g8,routesValidator:MU}=Yy(),zr=require("fs-extra"),UU=require("yaml"),Yn=require("path"),S8=require("is-number"),xU=require("properties-reader"),T8=require("lodash"),{handleHDBError:A8}=pe(),{HTTP_STATUS_CODES:R8,HDB_ERROR_MSGS:Du}=xn(),{server:y8}=(Vr(),C(Au)),{PACKAGE_ROOT:BU}=it(),{DATABASES_PARAM_CONFIG:T_,CONFIG_PARAMS:Kn,CONFIG_PARAM_MAP:ei}=Rs,b8="Unable to get config value because config is uninitialized",O8="Config successfully initialized",N8="Error backing up config file",w8="Empty parameter sent to getConfigValue",HU=Yn.join(BU,"config","yaml",Rs.HDB_DEFAULT_CONFIG_FILE),I8=Yn.join(BU,"config","yaml","defaultNatsConfig.yaml"),C8="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",vU={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"},EE,Ct,gE;Object.assign($U,{createConfigFile:P8,getDefaultConfig:D8,getConfigValue:FU,initConfig:SE,flattenConfig:Lu,updateConfigValue:GU,updateConfigObject:M8,getConfiguration:x8,setConfiguration:B8,readConfigFile:Jy,getClusteringRoutes:H8,initOldConfig:qU,getConfigFromFile:k8,getConfigFilePath:Qc,addConfig:F8,deleteConfigFromFile:G8,getConfigObj:q8,resolvePath:Wy,getFlatConfigObj:$8});function Wy(e){if(e?.startsWith("~/"))return Yn.join(Sr.getHomeDir(),e.slice(1));let t=ae();return Yn.resolve(t.getHdbBasePath(),e)}a(Wy,"resolvePath");function P8(e,t=!1){let r=Na(HU);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=UU.parseDocument(zr.readFileSync(I8,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}EE=Lu(r.toJSON());let n;for(let c in e){let l=ei[c.toLowerCase()];if(l===Kn.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(u=>({[u]:e[c][u]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let u=l.split("_"),f=zy(l,e[c]);l==="rootPath"&&f?.endsWith("/")&&(f=f.slice(0,-1));try{r.setIn([...u],f)}catch(d){rr.error(d)}}}n&&kU(r,n),jy(r,t);let s=r.toJSON();Ct=Lu(s);let i=r.getIn(["rootPath"]),o=Yn.join(i,Rs.HDB_CONFIG_FILE);if(zr.createFileSync(o),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);zr.writeFileSync(o,String(r)),rr.trace(`Config file written to ${o}`)}a(P8,"createConfigFile");function kU(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!Sr.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(T_.TABLES))for(let i in n[s][T_.TABLES])for(let o in n[s][T_.TABLES][i]){let c=n[s][T_.TABLES][i][o],l=[Kn.DATABASES,s,T_.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=[Kn.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){rr.error("Error parsing schemas CLI/env config arguments",n)}}a(kU,"setSchemasConfig");function D8(e){if(EE===void 0){let r=Na(HU);EE=Lu(r.toJSON())}let t=ei[e.toLowerCase()];if(t!==void 0)return EE[t.toLowerCase()]}a(D8,"getDefaultConfig");function FU(e){if(e==null){rr.info(w8);return}if(Ct===void 0){rr.trace(b8);return}let t=ei[e.toLowerCase()];if(t!==void 0)return Ct[t.toLowerCase()]}a(FU,"getConfigValue");function Qc(e=Sr.getPropsFilePath()){let t=Sr.getEnvCliRootPath();if(t)return Wy(Yn.join(t,Rs.HDB_CONFIG_FILE));let r=xU(e);return Wy(r.get(Rs.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(Qc,"getConfigFilePath");function SE(e=!1){if(Ct===void 0||e){let t;if(!Sr.noBootFile()){t=Sr.getPropsFilePath();try{zr.accessSync(t,zr.constants.F_OK|zr.constants.R_OK)}catch(i){throw rr.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Qc(t),n;if(r.includes("config/settings.js"))try{qU(r);return}catch(i){if(i.code!==Rs.NODE_ERROR_CODES.ENOENT)throw i}try{n=Na(r)}catch(i){if(i.code===Rs.NODE_ERROR_CODES.ENOENT){rr.trace(`HarperDB config file not found at ${r}.
20
- This can occur during early stages of install where the config file has not yet been created`);return}else throw rr.error(i),new Error(`Error reading HarperDB config file at ${r}`)}L8(n,r),jy(n);let s=n.toJSON();if(y8.config=s,Ct=Lu(s),Ct.logging_rotation_rotate)for(let i in vU)Ct[i]&&rr.error(`Config ${vU[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);rr.trace(O8)}}a(SE,"initConfig");function L8(e,t){let r=e.getIn(["rootPath"]),n=!1;if(e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Yn.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Yn.join(r,"log")),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n){if(rr.trace("Updating config file with missing config params"),e.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${e.errors}`);zr.writeFileSync(t,String(e))}}a(L8,"checkForUpdatedConfig");function jy(e,t=!1){let r=e.toJSON();if(r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads),r.http?.port&&r.http?.port===r.http?.securePort)throw Du.CONFIG_VALIDATION("http.port and http.securePort cannot be the same value");if(r.operationsApi?.network?.port&&r.operationsApi?.network?.port===r.operationsApi?.network?.securePort)throw Du.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=g8(r,t);if(n.error)throw Du.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket),r?.clustering?.enabled&&e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path)}a(jy,"validateConfig");function M8(e,t){Ct===void 0&&(Ct={});let r=ei[e.toLowerCase()];if(r===void 0){rr.trace(`Unable to update config object because config param '${e}' does not exist`);return}Ct[r.toLowerCase()]=t}a(M8,"updateConfigObject");function GU(e,t,r=void 0,n=!1,s=!1,i=!1){Ct===void 0&&SE();let o=FU(ei.hdb_root),c=Yn.join(o,Rs.HDB_CONFIG_FILE),l=Na(c),u;if(r&&Ct){let p=!1;for(let _ in r)if(r[_]!=Ct[_.toLowerCase()]){p=!0;break}if(!p){rr.trace("No changes detected in config parameters, skipping update");return}}if(r===void 0&&e.toLowerCase()===Kn.DATABASES)u=t;else if(r===void 0){let p;if(i)p=e;else if(p=ei[e.toLowerCase()],p===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let _=p.split("_"),h=zy(p,t);l.setIn([..._],h)}else for(let p in r){let _=ei[p.toLowerCase()];if(_===Kn.HTTP_SECUREPORT&&r[p]===Ct[Kn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),_===Kn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[p]===Ct[Kn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),_===Kn.DATABASES){u=r[p];continue}if(_?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!_&&(p.endsWith("_package")||p.endsWith("_port"))&&(_=p),_!==void 0){let h=_.split("_"),S=Rs.LEGACY_CONFIG_PARAMS[p.toUpperCase()];S&&S.startsWith("customFunctions")&&l.hasIn(S.split("_"))&&(_=S,h=S.split("_"));let g=zy(_,r[p]);_==="rootPath"&&g?.endsWith("/")&&(g=g.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],g)}catch(R){rr.error(R)}}}u&&kU(l,u),jy(l);let f=l.getIn(["rootPath"]),d=Yn.join(f,Rs.HDB_CONFIG_FILE);if(n===!0&&v8(c,f),l.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${l.errors}`);zr.writeFileSync(d,String(l)),s&&(Ct=Lu(l.toJSON())),rr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(GU,"updateConfigValue");function v8(e,t){try{let r=Yn.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${Rs.HDB_CONFIG_FILE}.bak`);zr.copySync(e,r),rr.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){rr.error(N8),rr.error(r)}}a(v8,"backupConfigFile");var U8=["databases"];function Lu(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network={...e.http,...e.operationsApi.network}),e?.operationsApi&&(e.operationsApi.tls={...e.tls,...e.operationsApi.tls}),gE=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])&&!U8.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;!Kn[l.toUpperCase()]&&ei[l]&&(s[ei[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Lu,"flattenConfig");function zy(e,t){if(e===Kn.CLUSTERING_NODENAME||e===Kn.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(S8(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Sr.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 Sr.autoCast(t)}a(zy,"castConfigValue");function x8(){let e=Sr.getPropsFilePath(),t=Qc(e);return Na(t).toJSON()}a(x8,"getConfiguration");async function B8(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return GU(void 0,void 0,s,!0),C8}catch(i){throw typeof i=="string"||i instanceof String?A8(i,i,R8.BAD_REQUEST,void 0,void 0,!0):i}}a(B8,"setConfiguration");function Jy(){let e=Sr.getPropsFilePath();try{zr.accessSync(e,zr.constants.F_OK|zr.constants.R_OK)}catch(n){if(!Sr.noBootFile())throw rr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Qc(e);return Na(t).toJSON()}a(Jy,"readConfigFile");function Na(e){return UU.parseDocument(zr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Na,"parseYamlDoc");function H8(){let e=Jy(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Sr.isEmptyOrZeroLength(t)?[]:t;let r=MU(t);if(r)throw Du.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Sr.isEmptyOrZeroLength(n)?[]:n;let s=MU(n);if(s)throw Du.CONFIG_VALIDATION(s.message);if(!Sr.isEmptyOrZeroLength(n)&&!Sr.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Sr.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw Du.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(H8,"getClusteringRoutes");function qU(e){let t=xU(e);Ct={};for(let r in ei){let n=t.get(r.toUpperCase());if(Sr.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=ei[r].toLowerCase();s===Kn.LOGGING_ROOT?Ct[s]=Yn.dirname(n):Ct[s]=n}return Ct}a(qU,"initOldConfig");function k8(e){let t=Jy();return T8.get(t,e.replaceAll("_","."))}a(k8,"getConfigFromFile");async function F8(e,t){let r=Na(Qc());if(r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);await zr.writeFile(Qc(),String(r))}a(F8,"addConfig");function G8(e){let t=Qc(Sr.getPropsFilePath()),r=Na(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Yn.join(n,Rs.HDB_CONFIG_FILE);zr.writeFileSync(s,String(r))}a(G8,"deleteConfigFromFile");function q8(){return gE||(SE(),gE)}a(q8,"getConfigObj");function $8(){return Ct||SE(),Ct}a($8,"getFlatConfigObj")});var Rn=w((DNe,Nr)=>{"use strict";var YU="username is required",WU="nothing to update, must supply active, role or password to update",zU="password cannot be an empty string",jU="If role is specified, it cannot be empty.",JU="active must be true or false";Nr.exports.addUser=X8;Nr.exports.alterUser=Z8;Nr.exports.dropUser=t5;Nr.exports.getSuperUser=o5;Nr.exports.userInfo=r5;Nr.exports.listUsers=AE;Nr.exports.listUsersExternal=n5;Nr.exports.setUsersWithRolesCache=Xc;Nr.exports.findAndValidateUser=ib;Nr.exports.getClusterUser=a5;Nr.exports.getUsersWithRolesCache=i5;Nr.exports.USERNAME_REQUIRED=YU;Nr.exports.ALTERUSER_NOTHING_TO_UPDATE=WU;Nr.exports.EMPTY_PASSWORD=zU;Nr.exports.EMPTY_ROLE=jU;Nr.exports.ACTIVE_BOOLEAN=JU;var QU=yn(),V8=zc(),A_=(hE(),C(pE)),XU=yU(),R_=Yr(),tb=To(),Ui=ie(),ZU=require("validate.js"),rb=z(),{promisify:K8}=require("util"),nb=Eo(),Xy=(H(),C(G)),VU=Tt(),Y8=yt(),W8=ae(),z8=po(),{hdb_errors:j8,ClientError:ti}=pe(),{HTTP_STATUS_CODES:So,AUTHENTICATION_ERROR_MSGS:Qy,HDB_ERROR_MSGS:Mu}=j8,{UserEventMsg:sb}=ri(),Zy=require("lodash"),{server:TE}=(Vr(),C(Au)),J8=z();TE.getUser=(e,t)=>ib(e,t,t!=null);TE.authenticateUser=(e,t)=>ib(e,t);var e0={username:!0,active:!0,role:!0,password:!0},KU=new Map,Q8=K8(V8.delete),eb=W8.get(Xy.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??A_.HASH_FUNCTION.SHA256,xi;async function X8(e){let t=ZU.cleanAttributes(e,e0),r=XU.addUserValidation(t);if(r)throw new ti(r.message);let n=await R_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]});if(!n||n.length<1)throw new ti(Mu.ROLE_NAME_NOT_FOUND(t.role),So.NOT_FOUND);if(n.length>1)throw new ti(Mu.DUP_ROLES_FOUND(t.role),So.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=nb.encrypt(t.password)),t.password=await A_.hash(t.password,eb),t.hash_function=eb,t.role=n[0].id;let s=await QU.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(rb.debug(s),await Xc(),s.skipped_hashes.length===1)throw new ti(Mu.USER_ALREADY_EXISTS(t.username),So.CONFLICT);return tb.signalUserChange(new sb(process.pid)),`${t.username} successfully added`}a(X8,"addUser");async function Z8(e){let t=ZU.cleanAttributes(e,e0);if(Ui.isEmptyOrZeroLength(t.username))throw new Error(YU);if(Ui.isEmptyOrZeroLength(t.password)&&Ui.isEmptyOrZeroLength(t.role)&&Ui.isEmptyOrZeroLength(t.active))throw new Error(WU);if(!Ui.isEmpty(t.password)&&Ui.isEmptyOrZeroLength(t.password.trim()))throw new Error(zU);if(!Ui.isEmpty(t.active)&&!Ui.isBoolean(t.active))throw new Error(JU);if(!Ui.isEmpty(t.password)&&!Ui.isEmptyOrZeroLength(t.password.trim())&&(e5(t.username)&&(t.hash=nb.encrypt(t.password)),t.password=await A_.hash(t.password,eb)),t.role==="")throw new Error(jU);if(t.role){let n=await R_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]});if(!n||n.length===0)throw new ti(Mu.ALTER_USER_ROLE_NOT_FOUND(t.role),So.NOT_FOUND);if(n.length>1)throw new ti(Mu.DUP_ROLES_FOUND(t.role),So.CONFLICT);t.role=n[0].id}let r=await QU.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await Xc(),tb.signalUserChange(new sb(process.pid)),r}a(Z8,"alterUser");function e5(e){let t=!1,r=xi.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(e5,"isClusterUser");async function t5(e){let t=XU.dropUserValidation(e);if(t)throw new ti(t.message);if(xi.get(e.username)===void 0)throw new ti(Mu.USER_NOT_EXIST(e.username),So.NOT_FOUND);let r=await Q8({table:"hdb_user",schema:"system",hash_values:[e.username]});return rb.debug(r),await Xc(),tb.signalUserChange(new sb(process.pid)),`${e.username} successfully deleted`}a(t5,"dropUser");async function r5(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=Zy.cloneDeep(e.hdb_user);let r=await R_.searchByHash({schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]});return t.role=r[0],delete t.password,delete t.refresh_token,delete t.hash,delete t.hash_function,t}a(r5,"userInfo");async function n5(){let e=await AE();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}a(n5,"listUsersExternal");async function AE(){let e=await R_.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=Zy.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await R_.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=Zy.cloneDeep(s),s.role=t[s.role],s5(s.role),n.set(s.username,s);return n}a(AE,"listUsers");function s5(e){if(!e){rb.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(z8)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}a(s5,"appendSystemTablesToRole");async function Xc(e=void 0){e?xi=e:xi=await AE()}a(Xc,"setUsersWithRolesCache");async function i5(){return xi||await Xc(),xi}a(i5,"getUsersWithRolesCache");async function ib(e,t,r=!0){xi||await Xc();let n=xi.get(e);if(!n){if(!r)return{username:e};throw new ti(Qy.GENERIC_AUTH_FAIL,So.UNAUTHORIZED)}if(n&&!n.active)throw new ti(Qy.USER_INACTIVE,So.UNAUTHORIZED);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(KU.get(t)===n.password)return s;{let i=A_.validate(n.password,t,n.hash_function||A_.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)KU.set(t,n.password);else throw new ti(Qy.GENERIC_AUTH_FAIL,So.UNAUTHORIZED)}}return s}a(ib,"findAndValidateUser");async function o5(){xi||await Xc();for(let[,e]of xi)if(e.role.role==="super_user")return e}a(o5,"getSuperUser");async function a5(){let e=await AE(),t=Y8.getConfigFromFile(Xy.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==Xy.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=nb.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+VU.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+VU.SERVER_SUFFIX.ADMIN,r}a(a5,"getClusterUser");var t0=[];TE.invalidateUser=function(e){for(let t of t0)try{t(e)}catch(r){J8.error("Error invalidating user",r)}};TE.onInvalidatedUser=function(e){t0.push(e)}});var b_=w((UNe,i0)=>{"use strict";var Zc=z(),Wn=(H(),C(G)),c5=gv(),MNe=As(),vNe=go(),l5=Rn(),{validateEvent:r0}=ri(),y_=Vn(),u5=require("process"),{resetDatabases:d5}=(De(),C(nt)),f5={[Wn.ITC_EVENT_TYPES.SCHEMA]:_5,[Wn.ITC_EVENT_TYPES.USER]:s0};async function _5(e){let t=r0(e);if(t){Zc.error(t);return}Zc.trace("ITC schemaHandler received schema event:",e),await c5(e.message),await p5(e.message)}a(_5,"schemaHandler");async function p5(e){try{y_.resetReadTxn(Wn.SYSTEM_SCHEMA_NAME,Wn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),y_.resetReadTxn(Wn.SYSTEM_SCHEMA_NAME,Wn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),y_.resetReadTxn(Wn.SYSTEM_SCHEMA_NAME,Wn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=d5();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){Zc.error(t)}}a(p5,"syncSchemaMetadata");var n0=[];async function s0(e){try{try{y_.resetReadTxn(Wn.SYSTEM_SCHEMA_NAME,Wn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),y_.resetReadTxn(Wn.SYSTEM_SCHEMA_NAME,Wn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){Zc.warn(r)}let t=r0(e);if(t){Zc.error(t);return}Zc.trace(`ITC userHandler ${Wn.HDB_ITC_CLIENT_PREFIX}${u5.pid} received user event:`,e),await l5.setUsersWithRolesCache();for(let r of n0)r()}catch(t){Zc.error(t)}}a(s0,"userHandler");s0.addListener=function(e){n0.push(e)};i0.exports=f5});var ri=w((GNe,a0)=>{"use strict";var BNe=z(),ob=ie(),h5=(H(),C(G)),{ITC_ERRORS:O_}=xn(),{parentPort:HNe,threadId:m5,isMainThread:E5,workerData:kNe}=require("worker_threads"),{onMessageFromWorkers:g5,broadcast:FNe,broadcastWithAcknowledgement:S5}=rt();a0.exports={sendItcEvent:T5,validateEvent:o0,SchemaEventMsg:A5,UserEventMsg:R5};var RE;g5(async(e,t)=>{RE=RE||b_(),o0(e),RE[e.type]&&await RE[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function T5(e){return!E5&&e.message&&(e.message.originator=m5),S5(e)}a(T5,"sendItcEvent");function o0(e){if(typeof e!="object")return O_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||ob.isEmpty(e.type))return O_.MISSING_TYPE;if(!e.hasOwnProperty("message")||ob.isEmpty(e.message))return O_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||ob.isEmpty(e.message.originator))return O_.MISSING_ORIGIN;if(h5.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return O_.INVALID_EVENT(e.type)}a(o0,"validateEvent");function A5(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(A5,"SchemaEventMsg");function R5(e){this.originator=e}a(R5,"UserEventMsg")});var To=w((VNe,d0)=>{"use strict";var c0=(H(),C(G)),$Ne=ie(),yE=z(),l0=hv(),vu,{sendItcEvent:u0}=ri();function y5(e){try{yE.info("signalSchemaChange called with message:",e),vu=vu||b_();let t=new l0(c0.ITC_EVENT_TYPES.SCHEMA,e);return vu.schema(t),u0(t)}catch(t){yE.error(t)}}a(y5,"signalSchemaChange");function b5(e){try{yE.trace("signalUserChange called with message:",e),vu=vu||b_();let t=new l0(c0.ITC_EVENT_TYPES.USER,e);return vu.user(t),u0(t)}catch(t){yE.error(t)}}a(b5,"signalUserChange");d0.exports={signalSchemaChange:y5,signalUserChange:b5}});var bE=w((YNe,_0)=>{"use strict";var f0=ie(),O5=(H(),C(G)),N5=z(),w5=iE(),I5=sE(),C5=To(),{SchemaEventMsg:P5}=ri(),D5="already exists in";_0.exports=L5;async function L5(e,t,r){if(f0.isEmptyOrZeroLength(r))return r;let n=[];f0.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 M5(e,t.schema,t.name,i)})),s}a(L5,"lmdbCheckForNewAttributes");async function M5(e,t,r,n){let s=new I5(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await v5(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(D5))N5.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(M5,"createNewAttribute");async function v5(e){let t;return t=await w5(e),C5.signalSchemaChange(new P5(process.pid,O5.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(v5,"createAttribute")});var Uu=w((zNe,p0)=>{"use strict";var ab=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}};p0.exports=ab});var m0=w((JNe,h0)=>{"use strict";var U5=Uu(),x5=(H(),C(G)).OPERATIONS_ENUM,cb=class extends U5{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(x5.INSERT,r,n,s,i),this.records=t}};h0.exports=cb});var g0=w((XNe,E0)=>{"use strict";var B5=Uu(),H5=(H(),C(G)).OPERATIONS_ENUM,lb=class extends B5{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(H5.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};E0.exports=lb});var T0=w((ewe,S0)=>{"use strict";var k5=Uu(),F5=(H(),C(G)).OPERATIONS_ENUM,ub=class extends k5{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(F5.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};S0.exports=ub});var R0=w((rwe,A0)=>{"use strict";var G5=Uu(),q5=(H(),C(G)).OPERATIONS_ENUM,db=class extends G5{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(q5.DELETE,n,s,t,i),this.original_records=r}};A0.exports=db});var N_=w((iwe,N0)=>{"use strict";var swe=require("path"),y0=_t(),$5=m0(),V5=g0(),K5=T0(),Y5=R0(),xu=xt(),b0=ie(),{CONFIG_PARAMS:W5}=(H(),C(G)),O0=ae();O0.initSync();var OE=(H(),C(G)).OPERATIONS_ENUM,{getTransactionAuditStorePath:z5}=gt();N0.exports=j5;async function j5(e,t){if(O0.get(W5.LOGGING_AUDITLOG)===!1)return;let r=z5(e.schema,e.table),n=await y0.openEnvironment(r,e.table,!0),s=J5(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){y0.initializeDBIs(n,xu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,xu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[xu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[xu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),b0.isEmpty(s.user_name)||n.dbis[xu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[xu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(j5,"writeTransaction");function J5(e,t){let r=b0.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===OE.INSERT)return new $5(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===OE.UPDATE)return new V5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===OE.UPSERT)return new K5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===OE.DELETE)return new Y5(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(J5,"createTransactionObject")});var fb=w((cwe,w0)=>{"use strict";var Q5=l_(),awe=Uf(),w_=(H(),C(G)),X5=xf(),Z5=qc().insertRecords,e9=_t(),t9=z(),r9=bE(),{getSchemaPath:n9}=gt(),s9=N_();w0.exports=i9;async function i9(e){try{let{schema_table:t,attributes:r}=Q5(e);X5(e,r,t.hash_attribute),e.schema!==w_.SYSTEM_SCHEMA_NAME&&(r.includes(w_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(w_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(w_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(w_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await r9(e.hdb_auth_header,t,r),s=n9(e.schema,e.table),i=await e9.openEnvironment(s,e.table),o=await Z5(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await s9(e,o)}catch(c){t9.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(i9,"lmdbCreateRecords")});var P0=w((uwe,C0)=>{"use strict";var I0=(H(),C(G)),o9=fb(),a9=Uf(),c9=require("fs-extra"),{getSchemaPath:l9}=gt();C0.exports=u9;async function u9(e){let t=[{name:e.schema,createddate:Date.now()}],r=new a9(I0.SYSTEM_SCHEMA_NAME,I0.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await o9(r),await c9.mkdirp(l9(e.schema))}a(u9,"lmdbCreateSchema")});var L0=w((fwe,D0)=>{"use strict";var _b=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}};D0.exports=_b});var x0=w((Ewe,U0)=>{"use strict";var M0=_t(),pb=_n(),hb=xn().LMDB_ERRORS_ENUM,d9=xt(),v0=z(),pwe=ie(),f9=require("lmdb"),_9=L0(),p9=(H(),C(G)),{OVERFLOW_MARKER:hwe,MAX_SEARCH_KEY_LENGTH:mwe}=d9,h9=p9.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function m9(e,t,r,n){if(pb.validateEnv(e),t===void 0)throw new Error(hb.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(hb.IDS_REQUIRED):new Error(hb.IDS_MUST_BE_ITERABLE);try{let s=M0.listDBIs(e);M0.initializeDBIs(e,t,s);let i=new _9,o,c=[],l=[];for(let p=0,_=r.length;p<_;p++)try{o=r[p];let h=e.dbis[t].get(o);if(!h||n&&h[h9]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,f9.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let g=0;g<s.length;g++){let R=s[g];if(!h.hasOwnProperty(R)||R===t)continue;let E=e.dbis[R],T=h[R];if(T!=null)try{let b=pb.getIndexedValues(T);if(b)for(let v=0,F=b.length;v<F;v++)E.remove(b[v],o)}catch{v0.warn(`cannot delete from attribute: ${R}, ${T}:${o}`)}}});c.push(S),l.push(o),i.original_records.push(h)}catch(h){v0.warn(h),i.skipped.push(o)}let u=[],f=await Promise.all(c);for(let p=0,_=f.length;p<_;p++)f[p]===!0?i.deleted.push(l[p]):(i.skipped.push(l[p]),u.push(p));let d=0;for(let p=0;p<u.length;p++){let _=u[p];i.original_records.splice(_-d,1),d++}return i.txn_time=pb.getNextMonotonicTime(),i}catch(s){throw s}}a(m9,"deleteRecords");U0.exports={deleteRecords:m9}});var I_=w((Swe,H0)=>{"use strict";var Bu=ie(),E9=x0(),g9=_t(),{getSchemaPath:S9}=gt(),T9=N_(),A9=z();H0.exports=R9;async function R9(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Bu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Bu.isEmptyOrZeroLength(e.hash_values)&&!Bu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Bu.isEmpty(l)||e.hash_values.push(l)}}if(Bu.isEmptyOrZeroLength(e.hash_values))return B0([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Bu.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=S9(e.schema,e.table),i=await g9.openEnvironment(s,e.table),o=await E9.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await T9(e,o)}catch(c){A9.error(`unable to write transaction due to ${c.message}`)}return B0(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(R9,"lmdbDeleteRecords");function B0(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(B0,"createDeleteResponse")});var Eb=w((Rwe,k0)=>{"use strict";var y9=(H(),C(G)),Awe=_n();function mb(e,t){let r=Object.create(null);if(t.length===1&&y9.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(mb,"parseRow");function b9(e,t,r,n){let s=mb(r,e);n.push(s)}a(b9,"searchAll");function O9(e,t,r,n){let s=mb(r,e);n[t]=s}a(O9,"searchAllToMap");function N9(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(N9,"iterateDBI");function el(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(el,"pushResults");function w9(e,t,r,n,s,i){t.toString().endsWith(e)&&el(t,r,n,s,i)}a(w9,"endsWith");function I9(e,t,r,n,s,i){t.toString().includes(e)&&el(t,r,n,s,i)}a(I9,"contains");function C9(e,t,r,n,s,i){t>e&&el(t,r,n,s,i)}a(C9,"greaterThanCompare");function P9(e,t,r,n,s,i){t>=e&&el(t,r,n,s,i)}a(P9,"greaterThanEqualCompare");function D9(e,t,r,n,s,i){t<e&&el(t,r,n,s,i)}a(D9,"lessThanCompare");function L9(e,t,r,n,s,i){t<=e&&el(t,r,n,s,i)}a(L9,"lessThanEqualCompare");k0.exports={parseRow:mb,searchAll:b9,searchAllToMap:O9,iterateDBI:N9,endsWith:w9,contains:I9,greaterThanCompare:C9,greaterThanEqualCompare:P9,lessThanCompare:D9,lessThanEqualCompare:L9,pushResults:el}});var Hu=w((wwe,Y0)=>{"use strict";var wa=_t(),bwe=z(),zn=_n(),NE=xt(),zt=xn().LMDB_ERRORS_ENUM,Owe=ie(),M9=(H(),C(G)),wE=Eb(),{parseRow:v9}=wE,Nwe=require("lmdb"),{OVERFLOW_MARKER:F0,MAX_SEARCH_KEY_LENGTH:U9}=NE;function G0(e,t,r,n=!1,s=void 0,i=void 0){return tl(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(G0,"iterateFullIndex");function C_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return tl(e,t,r,(f,d,p,_)=>{let E={transaction:f,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return _===r?(E.values=!1,d.getRange(E).map(T=>({value:T}))):d.getRange(E)})}a(C_,"iterateRangeBetween");function tl(e,t,r,n){let s=e.database||e,i=wa.openDBI(s,r);i[NE.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&wa.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(tl,"setupTransaction");function q0(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(F0)){if(!s)if(r)s=wa.openDBI(e,r);else{let l=wa.listDBIs(e);for(let u=0,f=l.length;u<f&&(s=wa.openDBI(e,l[u]),!s[NE.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(q0,"getOverflowCheck");function x9(e,t,r,n=!1,s=void 0,i=void 0){if(zn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return tl(e,t,t,(o,c,l)=>(IE(r),r=P_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>v9(u.value,r))))}a(x9,"searchAll");function B9(e,t,r,n=!1,s=void 0,i=void 0){if(zn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);IE(r),r=P_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of G0(e,t,t,n,s,i))o.set(c,wE.parseRow(l,r));return o}a(B9,"searchAllToMap");function H9(e,t,r=!1,n=void 0,s=void 0){if(zn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=G0(e,void 0,t,r,n,s),c=o.transaction,l=q0(c.database,c,void 0,t);for(let{key:u,value:f}of o){let d=l(u,f);i[d]===void 0&&(i[d]=[]),i[d].push(f)}return i}a(H9,"iterateDBI");function k9(e,t){if(zn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return wa.statDBI(e,t).entryCount}a(k9,"countAll");function F9(e,t,r,n,s=!1,i=void 0,o=void 0){return Ia(e,r,n),tl(e,t,r,(c,l,u,f)=>(n=zn.convertKeyValueToWrite(n),f===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(F9,"equals");function G9(e,t,r){return Ia(e,t,r),wa.openDBI(e,t).getValuesCount(r)}a(G9,"count");function q9(e,t,r,n,s=!1,i=void 0,o=void 0){return Ia(e,r,n),tl(e,null,r,(c,l)=>{n=zn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let f;if(s===!0){let d;for(let p of l.getKeys({transaction:c,start:n}))if(!p.startsWith(n)){d=p;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),f=l.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(p=>{let{key:_}=p;if(_!==d){if(_.toString().startsWith(n))return p;if(u===!0)return f.DONE}}),f.filter(p=>p)}else return f=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(u===!0)return f.DONE}),u?f:f.filter(d=>d)})}a(q9,"startsWith");function $9(e,t,r,n,s=!1,i=void 0,o=void 0){return $0(e,t,r,n,s,i,o,!0)}a($9,"endsWith");function $0(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Ia(e,r,n),tl(e,null,r,(l,u,f,d)=>{let p=q0(f,l,d,r);return o=Number.isInteger(o)?o:0,u.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(_=>{let h=_.toString();return h.endsWith(F0)?u.getValues(_,{transaction:l}).map(S=>{let g=p(_,S);if(c?g.endsWith(n):g.includes(n))return{key:g,value:S}}).filter(S=>S):(c?h.endsWith(n):h.includes(n))?u[NE.DBI_DEFINITION_NAME].is_hash_attribute?{key:_,value:_}:u.getValues(_,{transaction:l}).map(S=>({key:_,value:S})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a($0,"contains");function V9(e,t,r,n,s=!1,i=void 0,o=void 0){Ia(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),C_(e,t,r,n,l,s,i,o,!0,!1)}a(V9,"greaterThan");function K9(e,t,r,n,s=!1,i=void 0,o=void 0){Ia(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),C_(e,t,r,n,l,s,i,o,!1,!1)}a(K9,"greaterThanEqual");function Y9(e,t,r,n,s=!1,i=void 0,o=void 0){Ia(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),C_(e,t,r,l,n,s,i,o,!1,!0)}a(Y9,"lessThan");function W9(e,t,r,n,s=!1,i=void 0,o=void 0){Ia(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),C_(e,t,r,l,n,s,i,o,!1,!1)}a(W9,"lessThanEqual");function z9(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(zn.validateEnv(e),r===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(zt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(zt.END_VALUE_REQUIRED);if(n=zn.convertKeyValueToWrite(n),s=zn.convertKeyValueToWrite(s),n>s)throw new Error(zt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return C_(e,t,r,n,s,i,o,c)}a(z9,"between");function j9(e,t,r,n){zn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(IE(r),r=P_(s,r),n===void 0)throw new Error(zt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=wE.parseRow(c,r)),o}a(j9,"searchByHash");function J9(e,t,r){zn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(J9,"checkHashExists");function Q9(e,t,r,n,s=[]){return K0(e,t,r,n,s),V0(e,t,r,n,s).map(i=>i[1])}a(Q9,"batchSearchByHash");function X9(e,t,r,n,s=[]){K0(e,t,r,n,s);let i=new Map;for(let[o,c]of V0(e,t,r,n,s))i.set(o,c);return i}a(X9,"batchSearchByHashToMap");function V0(e,t,r,n,s=[]){return tl(e,t,t,(i,o,c)=>{r=P_(c,r);let l=r.length<3;return n.map(u=>{let f=c.dbis[t].get(u,{transaction:i,lazy:l});if(f)return[u,wE.parseRow(f,r)];s.push(u)}).filter(u=>u)})}a(V0,"batchHashSearch");function K0(e,t,r,n,s){if(zn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(IE(r),n==null)throw new Error(zt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(zt.IDS_MUST_BE_ITERABLE)}a(K0,"initializeBatchSearchByHash");function IE(e){if(!Array.isArray(e))throw e===void 0?new Error(zt.FETCH_ATTRIBUTES_REQUIRED):new Error(zt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(IE,"validateFetchAttributes");function Ia(e,t,r){if(zn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.SEARCH_VALUE_REQUIRED);if(r?.length>U9)throw new Error(zt.SEARCH_VALUE_TOO_LARGE)}a(Ia,"validateComparisonFunctions");function P_(e,t){return t.length===1&&M9.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=wa.listDBIs(e)),t}a(P_,"setGetWholeRowAttributes");Y0.exports={searchAll:x9,searchAllToMap:B9,count:G9,countAll:k9,equals:F9,startsWith:q9,endsWith:$9,contains:$0,searchByHash:j9,setGetWholeRowAttributes:P_,batchSearchByHash:Q9,batchSearchByHashToMap:X9,checkHashExists:J9,iterateDBI:H9,greaterThan:V9,greaterThanEqual:K9,lessThan:Y9,lessThanEqual:W9,between:z9}});var ku=w((Cwe,Q0)=>{var W0=require("lodash"),z0=ot(),He=require("joi"),Z9=ie(),{hdb_schema_table:D_,checkValidTable:j0,hdb_table:J0,hdb_database:CE}=Di(),{handleHDBError:e7,hdb_errors:t7}=pe(),{getDatabases:r7}=(De(),C(nt)),{HTTP_STATUS_CODES:n7}=t7,s7=He.object({database:CE,schema:CE,table:J0,search_attribute:D_,search_value:He.any().required(),get_attributes:He.array().min(1).items(He.alternatives(D_,He.object())).optional(),desc:He.bool(),limit:He.number().integer().min(1),offset:He.number().integer().min(0)}),i7=He.object({database:CE,schema:CE,table:J0,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(D_,He.object())).optional(),sort:He.object({attribute:He.alternatives(D_,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(D_,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()});Q0.exports=function(e,t){let r=null;switch(t){case"value":r=z0.validateBySchema(e,s7);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(j0("database",e.schema)),i(j0("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=z0.validateBySchema(e,i7);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=Z9.checkGlobalSchemaTable(e.schema,e.table);if(s)return e7(new Error,s,n7.NOT_FOUND);let o=r7()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(f=>{for(let d=0,p=f.conditions.length;d<p;d++){let _=f.conditions[d];_.conditions?l(_):c.push(_.search_attribute)}},"addConditions");t==="conditions"&&l(e);let u=W0.filter(c,f=>f!=="*"&&!f.startsWith?.("$")&&f.attribute!=="*"&&!Array.isArray(f)&&!f.name&&!W0.some(o,d=>d===f||d.attribute===f||d.attribute===f.attribute));if(u&&u.length>0){let f=u.join(", ");return f=f.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${f}'`)}}return r}});var gb=w((Dwe,X0)=>{"use strict";var o7=_t(),a7=ku(),{getSchemaPath:c7}=gt();X0.exports=l7;function l7(e){let t=a7(e,"hashes");if(t)throw t;let r=c7(e.schema,e.table);return o7.openEnvironment(r,e.table)}a(l7,"initialize")});var Sb=w((Mwe,Z0)=>{"use strict";var u7=Hu(),d7=gb();Z0.exports=f7;async function f7(e){let t=await d7(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return u7.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(f7,"lmdbGetDataByHash")});var Fu=w((Uwe,ex)=>{"use strict";var Tb=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};ex.exports=Tb});var rx=w((Hwe,tx)=>{"use strict";var Bwe=Fu(),_7=Hu(),p7=gb();tx.exports=h7;async function h7(e){let t=await p7(e),r=global.hdb_schema[e.schema][e.table];return _7.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(h7,"lmdbSearchByHash")});var ni=w((Fwe,nx)=>{"use strict";var Ab=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,u=void 0,f=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=u,this.offset=f}};nx.exports=Ab});var PE=w((qwe,lx)=>{"use strict";var jr=Hu(),m7=_t(),E7=ie(),ke=xt(),rl=(H(),C(G)),g7=po(),sx=xn().LMDB_ERRORS_ENUM,{getSchemaPath:S7}=gt(),Ao=rl.SEARCH_WILDCARDS;async function T7(e,t,r){let n;e.schema===rl.SYSTEM_SCHEMA_NAME?n=g7[e.table]:n=global.hdb_schema[e.schema][e.table];let s=cx(e,n.hash_attribute,r,t);return ox(e,s,n.hash_attribute,r)}a(T7,"prepSearch");async function ox(e,t,r,n){let s=S7(e.schema,e.table),i=await m7.openEnvironment(s,e.table),o=ax(i,e,t,r),c=o.transaction||i;if([ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,ke.SEARCH_TYPES.SEARCH_ALL,ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(A7(e,r)===!1){let f=e.search_attribute;if(f===r)return n?ix(o,()=>!0):o.map(p=>({[r]:p.key}));let d=a(p=>({[r]:p.value,[f]:p.key}),"toObject");return n?ix(o,d):o.map(d)}let u=e.search_attribute===r?o.map(f=>f.key):o.map(f=>f.value);return n===!0?jr.batchSearchByHashToMap(c,r,e.get_attributes,u):jr.batchSearchByHash(c,r,e.get_attributes,u)}a(ox,"executeSearch");function ax(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case ke.SEARCH_TYPES.EQUALS:s=jr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.CONTAINS:s=jr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.ENDS_WITH:case ke.SEARCH_TYPES._ENDS_WITH:s=jr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.STARTS_WITH:case ke.SEARCH_TYPES._STARTS_WITH:s=jr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return jr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return jr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case ke.SEARCH_TYPES.SEARCH_ALL:return jr.searchAll(e,n,t.get_attributes,o,c,l);case ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return jr.searchAllToMap(e,n,t.get_attributes,o,c,l);case ke.SEARCH_TYPES.BETWEEN:s=jr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case ke.SEARCH_TYPES.GREATER_THAN:case ke.SEARCH_TYPES._GREATER_THAN:s=jr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.GREATER_THAN_EQUAL:case ke.SEARCH_TYPES._GREATER_THAN_EQUAL:s=jr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.LESS_THAN:case ke.SEARCH_TYPES._LESS_THAN:s=jr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.LESS_THAN_EQUAL:case ke.SEARCH_TYPES._LESS_THAN_EQUAL:s=jr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(ax,"searchByType");function ix(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(ix,"createMapFromIterable");function A7(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(A7,"checkToFetchMore");function cx(e,t,r,n){if(E7.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),Ao.indexOf(s)>-1)return r===!0?ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP:ke.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(Ao[0])<0&&s.indexOf(Ao[1])<0)return c===!0?r===!0?ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:ke.SEARCH_TYPES.EQUALS;if(Ao.indexOf(i)>=0&&Ao.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),ke.SEARCH_TYPES.CONTAINS;if(Ao.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),ke.SEARCH_TYPES.ENDS_WITH;if(Ao.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),ke.SEARCH_TYPES.STARTS_WITH;if(s.includes(Ao[0])||s.includes(Ao[1]))return ke.SEARCH_TYPES.EQUALS;throw new Error(sx.UNKNOWN_SEARCH_TYPE)}else switch(n){case rl.VALUE_SEARCH_COMPARATORS.BETWEEN:return ke.SEARCH_TYPES.BETWEEN;case rl.VALUE_SEARCH_COMPARATORS.GREATER:return ke.SEARCH_TYPES.GREATER_THAN;case rl.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return ke.SEARCH_TYPES.GREATER_THAN_EQUAL;case rl.VALUE_SEARCH_COMPARATORS.LESS:return ke.SEARCH_TYPES.LESS_THAN;case rl.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return ke.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(sx.UNKNOWN_SEARCH_TYPE)}}a(cx,"createSearchTypeFromSearchObject");lx.exports={executeSearch:ox,createSearchTypeFromSearchObject:cx,prepSearch:T7,searchByType:ax}});var dx=w((Kwe,ux)=>{"use strict";var Vwe=ni(),R7=ku(),y7=ie(),b7=(H(),C(G)),O7=PE();ux.exports=N7;function N7(e,t){if(!y7.isEmpty(t)&&b7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=R7(e,"value");if(n)throw n;return O7.prepSearch(e,t,!0)}a(N7,"lmdbGetDataByValue")});var L_=w((zwe,fx)=>{"use strict";var Wwe=ni(),w7=ku(),I7=ie(),C7=(H(),C(G)),P7=PE();fx.exports=D7;async function D7(e,t){if(!I7.isEmpty(t)&&C7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=w7(e,"value");if(n)throw n;return P7.prepSearch(e,t,!1)}a(D7,"lmdbSearchByValue")});var px=w((Qwe,_x)=>{"use strict";var Jwe=xt(),Rb=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}},yb=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},bb=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};_x.exports={SearchByConditionsObject:Rb,SearchCondition:yb,SortAttribute:bb}});var Sx=w((tIe,gx)=>{"use strict";var Zwe=px().SearchByConditionsObject,L7=ni(),M7=ku(),Ob=Hu(),DE=xt(),{Resource:eIe}=(Ea(),C(gR)),Ex=PE(),v7=Eb(),U7=require("lodash"),{getSchemaPath:x7}=gt(),hx=_t(),{handleHDBError:B7,hdb_errors:H7}=pe(),{HTTP_STATUS_CODES:k7}=H7,F7=1e8;gx.exports=G7;async function G7(e){let t=M7(e,"conditions");if(t)throw B7(t,t.message,k7.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=x7(e.schema,e.table),n=await hx.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)hx.openDBI(n,u.search_attribute);let i=U7.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let f=u.search_type;f===DE.SEARCH_TYPES.EQUALS?u.estimated_count=Ob.count(n,u.search_attribute,u.search_value):f===DE.SEARCH_TYPES.CONTAINS||f===DE.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=F7}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await mx(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let u=n.dbis[s.hash_attribute],f=i.slice(1).map(Ex.filterByType),d=f.length,p=Ob.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(_=>u.get(_,{transaction:o,lazy:!0})),d>0&&(l=l.filter(_=>{for(let h=0;h<d;h++)if(!f[h](_))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(_=>v7.parseRow(_,p))}else{for(let d=1;d<i.length;d++){let p=i[d],_=await mx(o,e,p,s.hash_attribute);c=c.concat(_)}let u=new Set,f=e.offset||0;c=c.filter(d=>u.has(d)?!1:(u.add(d),!0)).slice(f,e.limit&&e.limit+f),l=Ob.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(G7,"lmdbSearchByConditions");async function mx(e,t,r,n){let s=new L7(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===DE.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,Ex.searchByType(e,s,i,n).map(o=>o.value)}a(mx,"executeConditionSearch")});var M_=w((nIe,Tx)=>{"use strict";var q7=(H(),C(G)).OPERATIONS_ENUM,Nb=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=q7.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};Tx.exports=Nb});var wb=w((iIe,Ix)=>{"use strict";var bx=ni(),Ox=M_(),Nx=L_(),wx=I_(),bn=(H(),C(G)),Ax=ie(),Rx=_t(),{getTransactionAuditStorePath:$7,getSchemaPath:V7}=gt(),yx=z();Ix.exports=K7;async function K7(e){try{if(Ax.isEmpty(global.hdb_schema[e.schema])||Ax.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await Y7(e),await W7(e);let t=V7(e.schema,e.table);try{await Rx.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")yx.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=$7(e.schema,e.table);await Rx.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")yx.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(K7,"lmdbDropTable");async function Y7(e){let t=new bx(bn.SYSTEM_SCHEMA_NAME,bn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await Nx(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 Ox(bn.SYSTEM_SCHEMA_NAME,bn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await wx(s)}a(Y7,"deleteAttributesFromSystem");async function W7(e){let t=new bx(bn.SYSTEM_SCHEMA_NAME,bn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await Nx(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 Ox(bn.SYSTEM_SCHEMA_NAME,bn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await wx(s)}catch(i){throw i}}a(W7,"dropTableFromSystem")});var Px=w((aIe,Cx)=>{"use strict";var z7=require("fs-extra"),j7=ni(),J7=Fu(),Q7=M_(),X7=wb(),Z7=I_(),eee=Sb(),tee=L_(),Ro=(H(),C(G)),{getSchemaPath:ree}=gt(),{handleHDBError:nee,hdb_errors:see}=pe(),{HDB_ERROR_MSGS:iee,HTTP_STATUS_CODES:oee}=see;Cx.exports=aee;async function aee(e){let t;try{t=await cee(e.schema);let r=new j7(Ro.SYSTEM_SCHEMA_NAME,Ro.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Ro.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Ro.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await tee(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await X7(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new Q7(Ro.SYSTEM_SCHEMA_NAME,Ro.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await Z7(s);let i=ree(t);await z7.remove(i)}catch(r){throw r}}a(aee,"lmdbDropSchema");async function cee(e){let t=new J7(Ro.SYSTEM_SCHEMA_NAME,Ro.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Ro.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await eee(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw nee(new Error,iee.SCHEMA_NOT_FOUND(e),oee.NOT_FOUND,void 0,void 0,!0);return n}a(cee,"validateDropSchema")});var v_=w((lIe,Dx)=>{"use strict";var Ib=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Dx.exports=Ib});var Pb=w((fIe,Lx)=>{"use strict";var lee=require("fs-extra"),LE=_t(),{getTransactionAuditStorePath:uee}=gt(),Cb=xt(),dIe=v_();Lx.exports=dee;async function dee(e){let t;try{let r=uee(e.schema,e.table);await lee.mkdirp(r),t=await LE.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{LE.createDBI(t,Cb.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),LE.createDBI(t,Cb.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),LE.createDBI(t,Cb.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(dee,"createTransactionsAuditEnvironment")});var Ux=w((hIe,vx)=>{"use strict";var Db=(H(),C(G)),Mx=_t(),fee=qc(),{getSystemSchemaPath:_ee,getSchemaPath:pee}=gt(),pIe=po(),hee=iE(),Lb=sE(),mee=z(),Eee=Pb();vx.exports=gee;async function gee(e,t){let r=pee(t.schema,t.table),n=new Lb(t.schema,t.table,Db.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Lb(t.schema,t.table,Db.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Lb(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await Mx.createEnvironment(r,t.table),e!==void 0){let o=await Mx.openEnvironment(_ee(),Db.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await fee.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_table_attributes,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await Mb(n),await Mb(s),await Mb(i)}await Eee(t)}catch(o){throw o}}a(gee,"lmdbCreateTable");async function Mb(e){try{await hee(e)}catch(t){mee.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(Mb,"createAttribute")});var Bx=w((EIe,xx)=>{"use strict";var See=l_(),Tee=xf(),Aee=bE(),U_=(H(),C(G)),Ree=qc().updateRecords,yee=_t(),{getSchemaPath:bee}=gt(),Oee=N_(),Nee=z();xx.exports=wee;async function wee(e){try{let{schema_table:t,attributes:r}=See(e);Tee(e,r,t.hash_attribute),e.schema!==U_.SYSTEM_SCHEMA_NAME&&(r.includes(U_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(U_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(U_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(U_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await Aee(e.hdb_auth_header,t,r),s=bee(e.schema,e.table),i=await yee.openEnvironment(s,e.table),o=await Ree(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await Oee(e,o)}catch(c){Nee.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(wee,"lmdbUpdateRecords")});var kx=w((SIe,Hx)=>{"use strict";var Iee=(H(),C(G)).OPERATIONS_ENUM,vb=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Iee.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Hx.exports=vb});var Gx=w((RIe,Fx)=>{"use strict";var AIe=kx(),Cee=l_(),Pee=xf(),Dee=bE(),x_=(H(),C(G)),Lee=qc().upsertRecords,Mee=_t(),{getSchemaPath:vee}=gt(),Uee=N_(),xee=z(),{handleHDBError:Bee,hdb_errors:Hee}=pe();Fx.exports=kee;async function kee(e){let t;try{t=Cee(e)}catch(l){throw Bee(l,l.message,Hee.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;Pee(e,n,r.hash_attribute),e.schema!==x_.SYSTEM_SCHEMA_NAME&&(n.includes(x_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(x_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(x_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(x_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await Dee(e.hdb_auth_header,r,n),i=vee(e.schema,e.table),o=await Mee.openEnvironment(i,e.table),c=await Lee(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await Uee(e,c)}catch(l){xee.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(kee,"lmdbUpsertRecords")});var $x=w((bIe,qx)=>{"use strict";var Ub=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};qx.exports=Ub});var Kx=w((NIe,Vx)=>{"use strict";var xb=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}};Vx.exports=xb});var zx=w((CIe,Wx)=>{"use strict";var Bb=_t(),{getTransactionAuditStorePath:Fee}=gt(),IIe=$x(),B_=xt(),Gee=ie(),Yx=Kx(),qee=require("util").promisify,$ee=qee(setTimeout),Vee=1e4,Kee=100;Wx.exports=Yee;async function Yee(e){let t=Fee(e.schema,e.table),r=await Bb.openEnvironment(t,e.table,!0),n=Bb.listDBIs(r);Bb.initializeDBIs(r,B_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new Yx;do s=await Wee(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 $ee(Kee);while(s.transactions_deleted>0);return i}a(Yee,"deleteAuditLogsBefore");async function Wee(e,t){let r=new Yx;try{let n=e.dbis[B_.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[B_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];Gee.isEmpty(c)||(s=e.dbis[B_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[B_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>Vee)break}return await s,r}catch(n){throw n}}a(Wee,"deleteTransactions")});var Jx=w((DIe,jx)=>{"use strict";var Hb=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};jx.exports=Hb});var Xx=w((vIe,Qx)=>{"use strict";var zee=ni(),jee=M_(),MIe=Jx(),Bi=(H(),C(G)),Jee=ie(),kb=_t(),Qee=po(),Xee=L_(),Zee=I_(),{getSchemaPath:ete}=gt();Qx.exports=tte;async function tte(e,t=!0){let r;e.schema===Bi.SYSTEM_SCHEMA_NAME?r=Qee[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await nte(e),s=ete(e.schema,e.table),i=await kb.openEnvironment(s,e.table);return t===!0&&await rte(e,i,r.hash_attribute),kb.dropDBI(i,e.attribute),n}a(tte,"lmdbDropAttribute");async function rte(e,t,r){let n=kb.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let u={};for(let f in c)f!==i&&(u[f]=c[f]);s=t.dbis[r].put(o,u,l)}await s}a(rte,"removeAttributeFromAllObjects");async function nte(e){let t=new zee(Bi.SYSTEM_SCHEMA_NAME,Bi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await Xee(t)).filter(o=>o[Bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(Jee.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[Bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new jee(Bi.SYSTEM_SCHEMA_NAME,Bi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return Zee(i)}a(nte,"dropAttributeFromSystem")});var sB=w((BIe,nB)=>{"use strict";var Fb=_t(),Gu=xt(),xIe=_n(),Gb=(H(),C(G)),Zx=ie(),{getTransactionAuditStorePath:ste}=gt(),ite=Hu(),ME=Uu(),ote=z();nB.exports=ate;async function ate(e){let t=ste(e.schema,e.table),r=await Fb.openEnvironment(t,e.table,!0),n=Fb.listDBIs(r);Fb.initializeDBIs(r,Gu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case Gb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return eB(r,e.search_values);case Gb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,lte(r,e.search_values,s);case Gb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return cte(r,e.search_values);default:return eB(r)}}a(ate,"readAuditLog");function eB(e,t=[0,Date.now()]){Zx.isEmpty(t[0])&&(t[0]=0),Zx.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[Gu.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 ME,s))}a(eB,"searchTransactionsByTimestamp");function cte(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[Gu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,rB(e,i))}return Object.fromEntries(r)}a(cte,"searchTransactionsByUsername");function lte(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],f=ite.equals(e,Gu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Gu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:d}of f){let p=Number(d);n.has(p)?n.get(p).push(u.toString()):n.set(p,[u.toString()])}}let s=Array.from(n.keys()),i=rB(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,f=n.get(u);tB(l,"records",r,f,o),tB(l,"original_records",r,f,o)}return Object.fromEntries(o)}a(lte,"searchTransactionsByHashValues");function tB(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let u=s.get(l),f=u[u.length-1];if(f.timestamp===i)f[t]=[c];else{let d=new ME(e.operation,e.user_name,i,void 0);d[t]=[c],u.push(d)}}else{let u=new ME(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}a(tB,"loopRecords");function rB(e,t){let r=[];try{let n=e.dbis[Gu.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 ME,i);r.push(o)}}catch(i){ote.warn(i)}return r}catch(n){throw n}}a(rB,"batchSearchTransactions")});var oB=w((GIe,iB)=>{"use strict";var{getSchemaPath:kIe}=gt(),FIe=_t(),{database:ute}=(De(),C(nt));iB.exports={writeTransaction:dte};async function dte(e,t,r){return ute({database:e,table:t}).transaction(r)}a(dte,"writeTransaction")});var uB=w(($Ie,lB)=>{"use strict";var{getSchemaPath:aB}=gt(),cB=_t();lB.exports={flush:fte,resetReadTxn:_te};async function fte(e,t){return(await cB.openEnvironment(aB(e,t),t.toString())).flushed}a(fte,"flush");async function _te(e,t){try{(await cB.openEnvironment(aB(e,t),t.toString())).resetReadTxn()}catch{}}a(_te,"resetReadTxn")});var pB=w((KIe,_B)=>{"use strict";var{Readable:pte}=require("stream"),{getDatabases:hte}=(De(),C(nt)),{readSync:mte,openSync:Ete,createReadStream:dB}=require("fs"),{open:gte}=require("lmdb"),fB=s_(),Ste=i_(),{AUDIT_STORE_OPTIONS:Tte}=(fo(),C(hB)),{INTERNAL_DBIS_NAME:Ate,AUDIT_STORE_NAME:Rte}=xt();_B.exports=bte;var qb=32768,yte=100;async function bte(e){let t=e.database||e.schema||"data",r=hte()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let u=r[s[0]];if(!u)throw new Error(`Can not find table ${s[0]}`);let f=u.dbisDB,d=gte({noSync:!0,maxDbs:Ste.MAX_DBS}),p,_=d.openDB(Ate,new fB(!1)),h=f.useReadTransaction(),S=0,g=a(async function(E,T){T.encoding="binary",T.encoder=void 0;let b=d.openDB(E,T),v=f.openDB(E,T);for(let{key:F,version:q,value:Y}of v.getRange({start:null,transaction:h,versions:v.useVersions}))p=b.put(F,Y,q),S++%yte===0&&(await new Promise(Z=>setTimeout(Z,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:E,value:T}of f.getRange({transaction:h,start:!1}))if(s.some(b=>E.startsWith?.(b+"/"))){_.put(E,T);let[,b]=E.split("/"),v=!b,F=new fB(!v,v);await g(E,F)}e.include_audit&&await g(Rte,{...Tte}),await p;let R=dB(d.path);return R.headers=l(),R.on("close",()=>{h.done(),d.close()}),R}let o=r[Object.keys(r)[0]].primaryStore,c=Ete(o.path);return o.transaction(()=>{let u=Buffer.alloc(qb);mte(c,u,0,qb),o.resetReadTxn();let f=o.useReadTransaction();f.renew();let d=dB(null,{fd:c,start:qb}),p=new pte.from(async function*(){yield u;for await(let _ of d)f.openTimer&&(f.openTimer=0),yield _;f.done()}());return p.headers=l(),p});function l(){let u=new Map;return u.set("content-type","application/octet-stream"),u.set("content-disposition",`attachment; filename="${t}"`),u.set("date",n),u}}a(bte,"getBackup")});var gB=w((WIe,EB)=>{"use strict";var Ote=z(),{handleHDBError:Nte}=pe(),wte=CM(),Ite=iE(),Cte=fb(),Pte=P0(),Dte=I_(),Lte=Sb(),Mte=rx(),vte=dx(),Ute=L_(),xte=Sx(),Bte=Px(),Hte=Ux(),kte=Bx(),Fte=Gx(),Gte=zx(),qte=wb(),$te=Xx(),Vte=sB(),Kte=oB(),mB=uB(),Yte=pB(),$b=class extends wte{static{a(this,"LMDBBridge")}async searchByConditions(t){return xte(t)}async getDataByHash(t){return await Lte(t)}async searchByHash(t){return await Mte(t)}async getDataByValue(t,r){return await vte(t,r)}async searchByValue(t){return await Ute(t)}async createSchema(t){return await Pte(t)}async dropSchema(t){return await Bte(t)}async createTable(t,r){return await Hte(t,r)}async dropTable(t){return await qte(t)}async createAttribute(t){return await Ite(t)}async createRecords(t){return await Cte(t)}async updateRecords(t){return await kte(t)}async upsertRecords(t){try{return await Fte(t)}catch(r){throw Nte(r,null,null,Ote.ERR,r)}}async deleteRecords(t){return await Dte(t)}async dropAttribute(t){return await $te(t)}async deleteAuditLogsBefore(t){return await Gte(t)}async readAuditLog(t){return await Vte(t)}writeTransaction(t,r,n){return Kte.writeTransaction(t,r,n)}flush(t,r){return mB.flush(t,r)}resetReadTxn(t,r){return mB.resetReadTxn(t,r)}getBackup(t){return Yte(t)}};EB.exports=$b});var Kb={};ve(Kb,{add:()=>vE,applyReverse:()=>SB,getRecordAtTime:()=>Vb,rebuildUpdateBefore:()=>UE});function vE(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n+BigInt(r.value):isNaN(e[t])?e[t]=r.value:e[t]=n+r.value}function UE(e,t,r){let n=null;for(let s in e)if(s in t){let i=t[s];if(i?.__op__){let o=e[s];if(o?.__op__)if(o.__op__===i.__op__)n||(n={}),n[s]=o;else throw new Error("Can not merge updates with different operations");else n||(n={}),n[s]=o,vE(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function SB(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=Wte[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=TB}}function Vb(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),u=It(l);switch(u.type){case"put":s=u.getValue(r);break;case"patch":SB(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===TB&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),u=It(l),f;switch(u.type){case"put":f=u.getValue(r);break;case"patch":f=u.getValue(r);break}for(let d in f)o[d]&&(s[d]=f[d],o[d]=!1,c--);i=u.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var Wte,TB,xE=be(()=>{fo();a(vE,"add");vE.reverse=function(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n-BigInt(r.value):isNaN(e[t])||(e[t]=n-r.value)};Wte={add:vE};a(UE,"rebuildUpdateBefore");a(SB,"applyReverse");TB={};a(Vb,"getRecordAtTime")});function On(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function FE(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let c of s){let l=c.name,u,f;if(c.resolve)f={get(){return c.resolve(this,this.getContext?.())},set(d){return c.set(this,d)},configurable:!0};else{switch(c.type){case"String":u=a(function(d){if(!(typeof d=="string"||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a string, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"ID":u=a(function(d){if(!(typeof d=="string"||d?.length>0&&d.every?.(p=>typeof p=="string")||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a string, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Float":case"Number":u=a(function(d){let p=d?.__op__?d.value:d;if(!(typeof p=="number"||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a number, attempt to assign ${p}`);On(this)[l]=d},"set");break;case"Int":u=a(function(d){let p=d?.__op__?d.value:d;if(!(p>>0===p||d==null&&c.nullable!==!1))if(typeof p=="number"&&Math.abs((p>>0)-p)<=1)p=Math.round(p),d?.__op__?d.value=p:d=p;else throw new jn.ClientError(`${l} must be an integer between -2147483648 and 2147483647, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Long":u=a(function(d){let p=d?.__op__?d.value:d;if(!(Math.round(p)===d&&Math.abs(p)<=9007199254740992||d==null&&c.nullable!==!1))if(typeof p=="number"&&Math.abs(p)<=9007199254740992)p=Math.round(p),d?.__op__?d.value=p:d=p;else throw new jn.ClientError(`${l} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"BigInt":u=a(function(d){let p=d?.__op__?d.value:d;if(!(typeof p=="bigint"||d==null&&c.nullable!==!1))if(typeof p=="string"||typeof p=="number")p=BigInt(p),d?.__op__?d.value=p:d=p;else throw new jn.ClientError(`${l} must be a number, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Boolean":u=a(function(d){if(!(typeof d=="boolean"||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a boolean, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Date":u=a(function(d){if(!(d instanceof Date||d==null&&c.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=new Date(d);else throw new jn.ClientError(`${l} must be a Date, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Bytes":u=a(function(d){if(!(d instanceof Uint8Array||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a Buffer or Uint8Array, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Blob":u=a(function(d){if(!(d instanceof wi||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a Blob, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Any":case void 0:u=a(function(d){On(this)[l]=d},"set");break;default:u=a(function(d){if(!(typeof d=="object"||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be an object, attempt to assign ${d}`);On(this)[l]=d},"set")}f={get(){let d=this.getChanges?.();if(d&&l in d){let _=d[l];if(_?.__op__){let h=this.getRecord()?.[l];return _.update(h)}return _}let p=this.getRecord()?.[l];if(p&&typeof p=="object"){let _=Yb(p,c);if(_)return d||this._setChanges(d=Object.create(null)),d[l]=_}return p},set:u,enumerable:!0,configurable:!0}}f.get.isAttribute=!0,n[l]=f,(!(l in r)||Object.getOwnPropertyDescriptor(r,l)?.get?.isAttribute)&&Object.defineProperty(r,l,f)}i("getProperty",function(c){let l=n[c];if(l)return l.get.call(this);let u=this.getChanges();return u?.[c]!==void 0?u[c]:this.getRecord()?.[c]}),i("set",function(c,l){let u=n[c];if(u)return u.set.call(this,l);if(t.sealed)throw new jn.ClientError("Can not add a property to a sealed table schema");On(this)[c]=l}),i("deleteProperty",function(c){On(this)[c]=void 0}),i("toJSON",function(){let c=this.getChanges?.(),l;for(let f in c){l||(l={...this.getRecord()});let d=c[f];if(d?.__op__){let p=l[f];d=d.update(p)}l[f]=d}return Object.keys(this).length>0&&(l||(l={...this.getRecord()}),Object.assign(l,this)),l||this.getRecord()}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty),r.then||i("then",null);function i(c,l){Object.defineProperty(r,c,{value:l,configurable:!0})}a(i,"setMethod");let o=r;do{let c=Object.getPrototypeOf(o);if(c===Object.prototype){Object.setPrototypeOf(o,RB);break}o=c}while(o&&o!==RB)}function Yb(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends H_{static{a(this,"TrackedObject")}},FE(r,t)),new r(e)):new H_(e);case Array:let n=new HE(e.length,e);for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=Yb(o,t?.elements)),n[s]=o}return n;default:return e}}function GE(e){let t=e.getChanges?.(),r;for(let s in t){r||(r=e.getRecord?{...e.getRecord()}:{});let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=GE(i);r[s]=i}return Object.keys(e).length>0&&(r||(r=e.getRecord?{...e.getRecord()}:{}),Object.assign(r,e)),r||e.getRecord?.()||e}function sl(e,t=e.getChanges?.()){let r;if(e.getRecord&&e.constructor===Array&&!Object.isFrozen(e)){r=e;for(let n=0,s=e.length;n<s;n++){let i=e[n];if(i&&typeof i=="object"){let o=sl(i);o!==i&&r===e&&(r=e.slice(0)),i=o}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r={...e.getRecord?.()});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=Kb[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=sl(s);r[n]=s}if(!Array.isArray(e))for(let n in e)zte.call(e,n)&&(r||(r={...e.getRecord?.()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?.()??e}function BE(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[nl]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.getRecord?.()===s){if(BE(i))return!0}else return!0}}else{let r=e.getChanges?.();if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s.getRecord?.()===i){if(BE(s))return!0}else return!0}else return!0}}return!1}var jn,AB,RB,H_,zte,nl,HE,kE,Wb=be(()=>{jn=M(pe());xE();gs();a(On,"getChanges");a(FE,"assignTrackedAccessors");AB=Object.prototype,RB=new Proxy({},{get(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(AB[t])return AB[t];let n=r.getChanges?.();if(n&&t in n)return n[t];let s=r.getRecord?.()[t];if(s&&typeof s=="object"){let i=Yb(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}});a(Yb,"trackObject");H_=class{static{a(this,"GenericTrackedObject")}#e;#t;constructor(t){if(t?.getRecord)throw new Error("Can not track an already tracked object, check for circular references");this.#e=t}getRecord(){return this.#e}setRecord(t){this.#e=t}getChanges(){return this.#t}_setChanges(t){this.#t=t}};FE(H_,{});a(GE,"collapseData");zte=Object.prototype.hasOwnProperty;a(sl,"updateAndFreeze");a(BE,"hasChanges");nl=Symbol.for("has-array-changes"),HE=class extends Array{static{a(this,"TrackedArray")}#e;[nl];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[nl]=!0,super.splice(...t)}push(...t){return this[nl]=!0,super.push(...t)}pop(){return this[nl]=!0,super.pop()}unshift(...t){return this[nl]=!0,super.unshift(...t)}shift(){return this[nl]=!0,super.shift()}};HE.prototype.constructor=Array;kE=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var PB={};ve(PB,{ResourceBridge:()=>Jb});function Qb({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 bB(e,t){let r=Hi(e),n=Qb(e,r);if(!r)throw new si.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache,replicateFrom:e.replicateFrom},o;wt(i,()=>new Promise(u=>o=u));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let u=c[l++],f;try{f=await r.get({id:u,lazy:s,select:n},i),f=f&&GE(f)}catch(d){f={message:d.toString()}}return t?{value:{key:u,value:f}}:{value:f}}else return o(),{done:!0}},return(u){return o(),{value:u,done:!0}},throw(u){return o(),{done:!0}}}}}}function Hi(e){let t=e.database||e.schema||Jte,r=Xe()[t];if(!r)throw(0,si.handleHDBError)(new Error,jte.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function OB(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*NB(e,t,r,n){let s,i=0;for await(let o of e.getHistory(t,r)){let c=o.operation??o.type;c==="put"&&(c="upsert");let{id:l,version:u,value:f}=o;if(s?.timestamp===u)s.hash_values.push(l),s.records.push(f);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:u,hash_values:[l],records:[f]}}}s&&(yield s)}var wB,qE,si,IB,zb,jb,CB,jte,Jte,Qte,Xte,yB,Jb,DB=be(()=>{"use strict";wB=M(gB()),qE=M(ku()),si=M(pe());De();IB=M(l_());H();zb=M(To()),jb=M(ri()),CB=M(ie());Ic();Wb();({HDB_ERROR_MSGS:jte}=si.hdb_errors),Jte="data",Qte=1e4,Xte=10,Jb=class extends wB.default{static{a(this,"ResourceBridge")}constructor(t){super(t),yB=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,qE.default)(t,"conditions");if(r)throw(0,si.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Hi(t);if(!n)throw new si.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:Qb(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new si.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.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await Hi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Hi(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c={...c},delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(u=>{if(!u){let{value:f,version:d}=r.primaryStore.getEntry(o);return i(o,f,d)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(u=>setImmediate(u));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){Hi(t).dropTable()}createSchema(t){return qu({database:t.schema,table:null}),zb.signalSchemaChange(new jb.SchemaEventMsg(process.pid,Yt.CREATE_SCHEMA,t.schema))}async dropSchema(t){await Xb(t.schema),zb.signalSchemaChange(new jb.SchemaEventMsg(process.pid,Yt.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,yB.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,IB.default)(t),s,i=Xe()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(o.replicateTo=t.replicateTo),t.replicatedConfirmation&&(o.replicatedConfirmation=t.replicatedConfirmation),wt(o,async c=>{if(!i.schemaDefined){s=[];for(let f of n)i.attributes.find(p=>p.name==f)||s.push(f);s.length>0&&await i.addAttributes(s.map(f=>({name:f,indexed:!0})))}let l=[],u=[];for(let f of t.records){let d=f[i.primaryKey],p=d!=null&&await i.get(d,o);if(t.requires_existing&&!p||t.requires_no_existing&&p){u.push(f[i.primaryKey]);continue}p&&(p=GE(p));for(let _ in f)if(Object.prototype.hasOwnProperty.call(f,_)){let h=f[_];if(typeof h=="function")try{let S=h([[p]]);Array.isArray(S)&&(h=S[0].func_val,f[_]=h)}catch(S){throw S.message+="Trying to set key "+_+" on object"+JSON.stringify(f),S}}if(p)for(let _ in p)Object.prototype.hasOwnProperty.call(f,_)||(f[_]=p[_]);await(d==null?i.create(f,o):i.put(f,o)),l.push(f[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:u}})}async deleteRecords(t){let r=Xe()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),wt(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 OB(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Xe()[t.schema][t.table];if(!r.createdTimeProperty)throw new si.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:am.LESS}]}),s=!1,i=[],o=[],c=0,l=[],u=a(async()=>{let f=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...f.deleted_hashes),o.push(...f.skipped_hashes),await(0,CB.async_set_timeout)(Xte),l=[],s=!0},"chunkDelete");for await(let f of n)l.push(f[r.primaryKey]),c++,c%Qte===0&&await u();return l.length>0&&await u(),s?OB(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,qE.default)(t,"hashes");if(r)throw r;return bB(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of bB(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&QA[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,qE.default)(t,"value");if(n)throw n;let s=Hi(t);if(!s)throw new si.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===am.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:Qb(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=Hi(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){Hi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Hi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=Hi(t),n={};switch(t.search_type){case cm.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.operation??o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case cm.USERNAME:let s=t.search_values;for await(let i of NB(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return NB(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(Qb,"getSelect");a(bB,"getRecords");a(Hi,"getTable");a(OB,"createDeleteResponse");a(NB,"groupRecordsInHistory")});var Vn=w((oCe,LB)=>{"use strict";var{ResourceBridge:Zte}=(DB(),C(PB)),ere=ae();ere.initSync();var $E;function tre(){return $E||($E=new Zte,$E)}a(tre,"getBridge");LB.exports=tre()});var yn=w((cCe,xB)=>{"use strict";var KE=FR(),Lr=ie(),rre=require("util"),YE=Vn(),nre=As(),MB=z(),{handleHDBError:il,hdb_errors:sre}=pe(),{HTTP_STATUS_CODES:ol}=sre,ire=rre.promisify(nre.getTableSchema),ore="updated",vB="inserted",UB="upserted";xB.exports={insert:cre,update:lre,upsert:ure,validation:are,flush:dre};async function are(e){if(Lr.isEmpty(e))throw new Error("invalid update parameters defined.");if(Lr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Lr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await ire(e.schema,e.table),r=KE(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&&Lr.isEmptyOrZeroLength(c[n]))throw MB.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(!Lr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw MB.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Lr.isEmpty(c[n])&&c[n]!==""&&s.has(Lr.autoCast(c[n]))&&(c.skip=!0),s.add(Lr.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(are,"validation");async function cre(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=KE(e);if(t)throw il(new Error,t.message,ol.BAD_REQUEST);Lr.transformReq(e);let r=Lr.checkSchemaTableExist(e.schema,e.table);if(r)throw il(new Error,r,ol.BAD_REQUEST);let n=await YE.createRecords(e);return VE(vB,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(cre,"insertData");async function lre(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=KE(e);if(t)throw il(new Error,t.message,ol.BAD_REQUEST);Lr.transformReq(e);let r=Lr.checkSchemaTableExist(e.schema,e.table);if(r)throw il(new Error,r,ol.BAD_REQUEST);let n=await YE.updateRecords(e);return Lr.isEmpty(n.existing_rows)?VE(ore,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):VE(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(lre,"updateData");async function ure(e){if(e.operation!=="upsert")throw il(new Error,"invalid operation, must be upsert",ol.INTERNAL_SERVER_ERROR);let t=KE(e);if(t)throw il(new Error,t.message,ol.BAD_REQUEST);Lr.transformReq(e);let r=Lr.checkSchemaTableExist(e.schema,e.table);if(r)throw il(new Error,r,ol.BAD_REQUEST);let n=await YE.upsertRecords(e);return VE(UB,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(ure,"upsertData");function VE(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===vB?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===UB?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(VE,"returnObject");function dre(e){return Lr.transformReq(e),YE.flush(e.schema,e.table)}a(dre,"flush")});var qB=w((uCe,GB)=>{var $u=require("validate.js"),HB=ot(),Vu=(H(),C(G)),{handleHDBError:fre,hdb_errors:_re}=pe(),{HDB_ERROR_MSGS:jt,HTTP_STATUS_CODES:pre}=_re,Zb=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),hre={STRUCTURE_USER:"structure_user"},BB=Object.values(Vu.ROLE_TYPES_ENUM),mre="attribute_permissions",Ere="attribute_name",{PERMS_CRUD_ENUM:Ku}=Vu,gre=[mre,...Object.values(Ku)],kB=[Ku.READ,Ku.INSERT,Ku.UPDATE],Sre=[Ere,...kB];function Tre(e){let t=Zb();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,FB(e,t)}a(Tre,"addRoleValidation");function Are(e){let t=Zb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,FB(e,t)}a(Are,"alterRoleValidation");function Rre(e){let t=Zb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,HB.validateObject(e,t)}a(Rre,"dropRoleValidation");var yre=["operation","role","id","permission","hdb_user","hdb_auth_header","access"];function FB(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)yre.includes(n[o])||s.push(n[o]);s.length>0&&nr(jt.INVALID_ROLE_JSON_KEYS(s),r);let i=HB.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{nr(o,r)}),e.permission){let o=bre(e);o&&nr(o,r),BB.forEach(c=>{e.permission[c]&&!$u.isBoolean(e.permission[c])&&nr(jt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(BB.indexOf(o)<0){if(o===hre.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let u=0,f=l.length;u<f;u++){let d=l[u];global.hdb_schema[d]||nr(jt.SCHEMA_NOT_FOUND(d),r)}continue}nr(jt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){nr(jt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let u=c.tables[l];if(!l||!global.hdb_schema[o][l]){nr(jt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(f=>{gre.includes(f)||nr(jt.INVALID_PERM_KEY(f),r,o,l)}),Object.values(Ku).forEach(f=>{$u.isDefined(u[f])?$u.isBoolean(u[f])||nr(jt.TABLE_PERM_NOT_BOOLEAN(f),r,o,l):nr(jt.TABLE_PERM_MISSING(f),r,o,l)}),u.attribute_permissions===void 0){nr(jt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){nr(jt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}if(u.attribute_permissions){let f=global.hdb_schema[o][l].attributes.map(({attribute:p})=>p),d={read:!1,insert:!1,update:!1};for(let p in u.attribute_permissions){let _=u.attribute_permissions[p];if(Object.keys(_).forEach(S=>{!Sre.includes(S)&&S!==Ku.DELETE&&nr(jt.INVALID_ATTR_PERM_KEY(S),r,o,l)}),!$u.isDefined(_.attribute_name)){nr(jt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=_.attribute_name;if(!f.includes(h)){nr(jt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}kB.forEach(S=>{$u.isDefined(_[S])?$u.isBoolean(_[S])||nr(jt.ATTR_PERM_NOT_BOOLEAN(S,h),r,o,l):nr(jt.ATTR_PERM_MISSING(S,h),r,o,l)}),!d.read&&_.read===!0&&(d.read=!0),!d.insert&&_.insert===!0&&(d.insert=!0),!d.update&&_.update===!0&&(d.update=!0)}if(u.read===!1&&d.read===!0||u.insert===!1&&d.insert===!0||u.update===!1&&d.update===!0){let p=`${o}.${l}`;nr(jt.MISMATCHED_TABLE_ATTR_PERMS(p),r,o,l)}}}}return Ore(r)}a(FB,"customValidate");GB.exports={addRoleValidation:Tre,alterRoleValidation:Are,dropRoleValidation:Rre};function bre(e){let{operation:t,permission:r}=e;if(t===Vu.OPERATIONS_ENUM.ADD_ROLE||t===Vu.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 jt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?Vu.ROLE_TYPES_ENUM.SUPER_USER:Vu.ROLE_TYPES_ENUM.CLUSTER_USER;return jt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(bre,"validateNoSUPerms");function Ore(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:jt.ROLE_PERMS_ERROR,...e};return fre(new Error,n,pre.BAD_REQUEST)}else return null}a(Ore,"generateRolePermResponse");function nr(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(nr,"addPermError")});var F_=w((_Ce,YB)=>{"use strict";var $B=yn(),VB=Yr(),Nre=zc(),tO=qB(),rO=To(),fCe=require("uuid").v4,wre=require("util"),WE=(H(),C(G)),Ire=ie(),nO=VB.searchByValue,Cre=VB.searchByHash,Pre=wre.promisify(Nre.delete),Dre=ni(),Lre=Fu(),{hdb_errors:Mre,handleHDBError:al}=pe(),{HDB_ERROR_MSGS:KB,HTTP_STATUS_CODES:k_}=Mre,{UserEventMsg:sO}=ri();YB.exports={addRole:vre,alterRole:Ure,dropRole:xre,listRoles:Bre};function eO(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(eO,"scrubRoleDetails");async function vre(e){let t=tO.addRoleValidation(e);if(t)throw t;e=eO(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 nO(r)||[])}catch(i){throw al(i)}if(n&&n.length>0)throw al(new Error,KB.ROLE_ALREADY_EXISTS(e.role),k_.CONFLICT,void 0,void 0,!0);e.id||(e.id=e.role);let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await $B.insert(s),rO.signalUserChange(new sO(process.pid)),e=eO(e),e}a(vre,"addRole");async function Ure(e){let t=tO.alterRoleValidation(e);if(t)throw t;e=eO(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await $B.update(r)}catch(s){throw al(s)}if(n&&n?.message==="updated 0 of 1 records")throw al(new Error,"Invalid role id",k_.BAD_REQUEST,void 0,void 0,!0);return await rO.signalUserChange(new sO(process.pid)),e}a(Ure,"alterRole");async function xre(e){let t=tO.dropRoleValidation(e);if(t)throw al(new Error,t,k_.BAD_REQUEST,void 0,void 0,!0);let r=new Lre(WE.SYSTEM_SCHEMA_NAME,WE.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await Cre(r));if(n.length===0)throw al(new Error,KB.ROLE_NOT_FOUND,k_.NOT_FOUND,void 0,void 0,!0);let s=new Dre(WE.SYSTEM_SCHEMA_NAME,WE.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await nO(s)),o=!1;if(Ire.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw al(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,k_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await Pre(c),rO.signalUserChange(new sO(process.pid)),`${n[0].role} successfully deleted`}a(xre,"dropRole");async function Bre(){return nO({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Bre,"listRoles")});var iO={};ve(iO,{start:()=>jB,startOnMainThread:()=>Fre});function jB({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,WB.parseDocument)(r.toString(),{simpleKeys:!0}).toJSON();for(let s in n){let i=n[s];i.permission||(i={permission:i},i.permission.access&&(i.access=i.permission.access,delete i.permission.access));for(let o in i.permission){if(Hre.includes(o))continue;let c=i.permission[o];c.tables||(i.permission[o]=c={tables:c});for(let l in c.tables){let u=c.tables[l];if(u.read=!!u.read,u.insert=!!u.insert,u.update=!!u.update,u.delete=!!u.delete,u.attributes){let f=[];for(let d in u.attributes){let p=u.attributes[d];p.attribute_name=d,f.push(p)}u.attribute_permissions=f,delete u.attributes}if(u.attribute_permissions){if(!Array.isArray(u.attribute_permissions))throw new Error("attribute_permissions must be an array if defined");for(let f of u.attribute_permissions)f.read=!!f.read,f.insert=!!f.insert,f.update=!!f.update}else u.attribute_permissions=null}}i.role=i.id=s,await kre(i)}}}async function kre(e){let t=Xe().system.hdb_role;for await(let r of t.search([{attribute:"role",value:e.role}])){let{__createdtime__:n,__updatedtime__:s,...i}=r;return(0,zB.isEqual)(i,e)?void 0:(e.id=r.id,(0,zE.alterRole)(e))}return(0,zE.addRole)(e)}var zE,WB,zB,Hre,Fre,JB=be(()=>{De();zE=M(F_()),WB=require("yaml"),zB=require("lodash"),Hre=["super_user","cluster_user","structure_user"];a(jB,"start");a(kre,"ensureRole");Fre=jB});async function jE(e){let t=(0,ZB.pathToFileURL)(e).toString();if(Gre)return G_||(G_=qre(Vre)),(await(await G_).import(t)).namespace;try{return await import(t)}catch(r){try{(await import("internal/util")).default.decorateErrorStack(r)}catch{}throw r}}async function qre(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),G_=new Compartment({console,Math,Date,fetch:$re,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,XB.extname)(r)||(r+=".js"),r)},importHook:a(async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:$r,tables:Jn,databases:qe})}};let n=await(0,QB.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),G_}function $re(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 Vre(){return{Resource:$r,tables:Jn}}var QB,XB,ZB,Gre,G_,oO=be(()=>{Ea();De();QB=require("fs/promises"),XB=require("path"),ZB=require("url"),Gre=!1;a(jE,"secureImport");a(qre,"getCompartment");a($re,"secureOnlyFetch");a(Vre,"getGlobalVars")});var cO={};ve(cO,{handleFile:()=>Kre});async function Kre(e,t,r,n){let s=new Map,i=await jE(r);c(i.default)&&n.set((0,aO.dirname)(t),i.default),o(i,(0,aO.dirname)(t));function o(l,u){for(let f in l){let d=l[f];c(d)?n.set(u+"/"+f,d):typeof d=="object"&&o(d,u+"/"+f)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var aO,eH=be(()=>{oO();aO=require("path");a(Kre,"handleFile")});var uO={};ve(uO,{start:()=>Yre});function Yre({resources:e}){e.set("login",lO),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var lO,tH=be(()=>{Ea();a(Yre,"start");lO=class extends $r{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 W_={};ve(W_,{addAnalyticsListener:()=>Y_,calculateCPUUtilization:()=>TH,diffResourceUsage:()=>AH,recordAction:()=>sr,recordActionBinary:()=>Qn,setAnalyticsEnabled:()=>Wre});function Wre(e){hH=e}function zre(e,t){if(typeof e=="number"){let r=t.values,n=r.index++;if(n>=r.length){let s=r;t.values=r=new Float32Array(n*2),r.set(s),r.index=n+1}r[n]=e,t.total+=e}else if(typeof e=="boolean")e&&t.total++,t.count++;else if(typeof e=="function")t.count++;else throw new TypeError("Invalid metric value type "+typeof e)}function jre(e,t,r,n,s,i){let o={};if(typeof t=="number")o.total=t,o.values=new Float32Array(4),o.values.index=1,o.values[0]=t,o.total=t;else if(typeof t=="boolean")o.total=t?1:0,o.count=1;else if(typeof t=="function")o.count=1,o.callback=t;else throw new TypeError("Invalid metric value type "+typeof t);o.description={metric:r,path:n,method:s,type:i},QE.set(e,o)}function sr(e,t,r,n,s){if(!hH)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=QE.get(i);o?zre(e,o):jre(i,e,t,r,n,s),JE||Jre()}function Qn(e,t,r,n,s){sr(!!e,t,r,n,s)}function Y_(e){gH.push(e)}function Jre(){JE=performance.now(),setTimeout(async()=>{let e=performance.now()-JE;JE=0;let t=[],r={time:Date.now(),period:e,threadId:cl.threadId,metrics:t};for(let[s,i]of QE){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,u=[],f;for(let d of SH){let p=Math.floor(c*d),_=o[p-1];if(p>l){let h=p-l;if(_===f){let S=u[u.length-1];typeof S=="number"?u[u.length-1]={value:S,count:1+h}:S.count+=h}else u.push(h>1?{value:_,count:h}:_),f=_;l=p}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:u,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await RH()}let n=process.memoryUsage();t.push({metric:"memory",threadId:cl.threadId,byThread:!0,...n});for(let s of gH)s(t);QE=new Map,cl.parentPort?cl.parentPort.postMessage({type:EH,report:r}):OH({report:r})},mH).unref()}function XE(e,t,r){let n={id:(0,V_.getNextMonotonicTime)(),metric:t,...r};e.primaryStore.put(n.id,n,{append:!0}).then(s=>{s||e.primaryStore.put(n.id,n)})}function TH(e,t){let r=e.userCPUTime+e.systemCPUTime;return Math.round(r/t*100)/100}function AH(e,t){return{userCPUTime:t.userCPUTime/1e3-(e?.userCPUTime??0),systemCPUTime:t.systemCPUTime/1e3-(e?.systemCPUTime??0),minorPageFault:t.minorPageFault-(e?.minorPageFault??0),majorPageFault:t.majorPageFault-(e?.majorPageFault??0),fsRead:t.fsRead-(e?.fsRead??0),fsWrite:t.fsWrite-(e?.fsWrite??0),voluntaryContextSwitches:t.voluntaryContextSwitches-(e?.voluntaryContextSwitches??0),involuntaryContextSwitches:t.involuntaryContextSwitches-(e?.involuntaryContextSwitches??0)}}function Qre(e,t,r){let n=0;for(let[s,i]of Object.entries(r)){let o=`${t}.${s}`,c=i.getSize(),l={database:t,table:s,size:c};XE(e,"table-size",l),ll.trace?.(`table ${o} size metric: ${JSON.stringify(l)}`),n+=c}return n}function rH(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s.getAuditSize(),o=pH.default.statSync(s.primaryStore.env.path).size,c=Qre(e,r,n),l=o-c,u={database:r,size:o,used:c,free:l,audit:i};XE(e,"database-size",u),ll.trace?.(`database ${r} size metric: ${JSON.stringify(u)}`)}catch(s){ll.warn?.("Error getting DB size metrics",s)}}function nH(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s.getStorageStats(),o={database:r,...i};XE(e,"storage-volume",o),ll.trace?.(`db ${r} storage volume metrics: ${JSON.stringify(o)}`)}catch(s){ll.warn?.("Error getting DB volumne metrics",s)}}async function Xre(e,t=6e4){let r=fO(),n=yH(),s=new Promise(E=>{let T=performance.now();setImmediate(()=>{let b=performance.now();b-T>5e3&&ll.warn?.("Unusually high event queue latency on the main thread of "+Math.round(b-T)+"ms"),T=performance.now()}),n.primaryStore.prefetch([1],()=>{let b=performance.now();b-T>5e3&&ll.warn?.("Unusually high task queue latency on the main thread of "+Math.round(b-T)+"ms"),E(b-T)})}),i;for(let E of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(E.value?.time){i=E.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,u=[],f;for(let{key:E,value:T}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!T)continue;if(o){if(E>o+t)break}else o=E;f=E;let{metrics:b,threadId:v}=T;for(let F of b||[]){let{path:q,method:Y,type:Z,metric:se,count:Q,total:ne,distribution:J,threads:me,...ye}=F;Q||(Q=1);let Pe=se+(q?"-"+q:"");Y!==void 0&&(Pe+="-"+Y),Z!==void 0&&(Pe+="-"+Z);let he=c.get(Pe);if(he){if(he.threads){let dt=he.threads[v];if(dt)he=dt;else{he.threads[v]={...ye};continue}}he.count||(he.count=1);let Nt=he.count;for(let dt in ye){let br=ye[dt];typeof br=="number"&&(he[dt]=(he[dt]*Nt+br*Q)/(Nt+Q))}he.count+=Q,ne>=0&&(he.total+=ne,he.ratio=he.total/he.count)}else he={period:t,...F},delete he.distribution,c.set(Pe,he),he.byThread&&(he.threads=[],he.threads[v]={...ye},u.push(he));if(J){J=J.map(dt=>typeof dt=="number"?{value:dt,count:1}:dt);let Nt=l.get(Pe);Nt?Nt.push(...J):l.set(Pe,J)}}await RH()}for(let E of u){let{path:T,method:b,type:v,metric:F,count:q,total:Y,distribution:Z,threads:se,...Q}=E;se=se.filter(ne=>ne);for(let ne in Q){if(typeof E[ne]!="number")continue;let J=0;for(let me of se){let ye=me[ne];typeof ye=="number"&&(J+=ye)}E[ne]=J}E.count=se.length,delete E.threads,delete E.byThread}for(let[E,T]of l){let b=c.get(E);T.sort((dt,br)=>dt.value>br.value?1:-1);let v=b.count-1,F=[],q=0,Y=0,Z;for(let dt of SH){let br=v*dt;for(;q<br;)Z=T[Y++],q+=Z.count,Y===1&&q--;let hs=T[Y>1?Y-2:0];Z||(Z=T[0]),F.push(Z.value-(Z.value-hs.value)*(q-br)/Z.count)}let[se,Q,ne,J,me,ye,Pe,he,Nt]=F;Object.assign(b,{p1:se,p10:Q,p25:ne,median:J,p75:me,p90:ye,p95:Pe,p99:he,p999:Nt})}let d;for(let[E,T]of c)T.id=(0,V_.getNextMonotonicTime)(),T.time=f,n.primaryStore.put(T.id,T,{append:!0}).then(b=>{b||n.primaryStore.put(T.id,T)}),d=!0;let p=Date.now(),{idle:_,active:h}=performance.eventLoopUtilization();if(d||h*10>_){let E=(0,V_.getNextMonotonicTime)(),T={id:E,metric:"main-thread-utilization",idle:_-sH,active:h-iH,taskQueueLatency:await s,time:p,...process.memoryUsage()};n.primaryStore.put(E,T,{append:!0}).then(b=>{b||n.primaryStore.put(E,T)})}sH=_,iH=h;let S=process.resourceUsage(),g=AH(q_,S);g.time=p,g.period=q_.time?p-q_.time:t,g.cpuUtilization=TH(q_,g.period),XE(n,"resource-usage",g),q_=g;let R=Xe();rH(n,R),rH(n,{system:R.system}),nH(n,R),nH(n,{system:R.system})}async function oH(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function fO(){return aH||(aH=ft({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function yH(){return cH||(cH=ft({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function tne(){bH=!0;let e=(0,K_.get)(x.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await Xre(mH,e),await oH(fO(),Zre),await oH(yH(),ene)},Math.min(e/2,2147483647)).unref()}function OH(e,t){let r=e.report;r.threadId=t?.threadId||cl.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(lH+=n.mean*n.count);r.totalBytesProcessed=lH,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(uH.get(t))}),uH.set(t,t.performance.eventLoopUtilization())),r.id=(0,V_.getNextMonotonicTime)(),fO().primaryStore.put(r.id,r),bH||tne(),rne&&(NH=sne(r))}async function sne(e){if(await NH,!Ca){let r=(0,$_.dirname)((0,fH.getLogFilePath)());try{Ca=await(0,dO.open)((0,$_.join)(r,"analytics.log"),"r+")}catch{Ca=await(0,dO.open)((0,$_.join)(r,"analytics.log"),"w+")}}let t=(await Ca.stat()).size;if(t>nne){let r=Buffer.alloc(t);await Ca.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Ca.write(r,{position:0}),await Ca.truncate(r.length),t=r.length}await Ca.write(JSON.stringify(e)+`
21
- `,t)}var cl,dH,fH,_H,$_,dO,V_,K_,pH,ll,QE,hH,JE,mH,EH,gH,SH,sH,iH,q_,RH,Zre,ene,aH,cH,bH,lH,uH,rne,NH,Ca,nne,ki=be(()=>{cl=require("worker_threads"),dH=M(rt());De();fH=M(z()),_H=M(Ni()),$_=require("path"),dO=require("fs/promises"),V_=M(_n()),K_=M(ae());H();Vr();pH=M(require("node:fs")),ll=(0,_H.loggerWithTag)("analytics");(0,K_.initSync)();QE=new Map,hH=(0,K_.get)(x.ANALYTICS_AGGREGATEPERIOD)>-1;a(Wre,"setAnalyticsEnabled");a(zre,"recordExistingAction");a(jre,"recordNewAction");a(sr,"recordAction");We.recordAnalytics=sr;a(Qn,"recordActionBinary");JE=0,mH=1e3,EH="analytics-report",gH=[];a(Y_,"addAnalyticsListener");SH=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(Jre,"sendAnalytics");a(XE,"storeMetric");a(TH,"calculateCPUUtilization");a(AH,"diffResourceUsage");a(Qre,"storeTableSizeMetrics");a(rH,"storeDBSizeMetrics");a(nH,"storeVolumeMetrics");a(Xre,"aggregation");sH=0,iH=0,q_={},RH=a(()=>new Promise(setImmediate),"rest");a(oH,"cleanup");Zre=36e5,ene=31536e6;a(fO,"getRawAnalyticsTable");a(yH,"getAnalyticsTable");(0,dH.setChildListenerByType)(EH,OH);a(tne,"startScheduledTasks");lH=0,uH=new Map,rne=!1;a(OH,"recordAnalytics");nne=1e6;a(sne,"logAnalytics")});var wH={};ve(wH,{Headers:()=>yo,appendHeader:()=>ZE,mergeHeaders:()=>_O});function ZE(e,t,r,n){if(e.append)e.append(t,r,n);else if(e.set){let s=e.get(t);if(s)if(n)r=(typeof s=="string"?s:s.join(", "))+", "+r;else if(typeof s=="string")r=[s,r];else{s.push(r);return}return e.set(t,r)}else e[t]=(e[t]?e[t]+", ":"")+r}function _O(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new yo(e));for(let[r,n]of t)e.has(r)?r.toLowerCase()==="set-cookie"&&e.append?.(r,n,!0):e.set(r,n);return e}var yo,z_=be(()=>{yo=class extends Map{static{a(this,"Headers")}constructor(t){if(t)if(t[Symbol.iterator])super(t);else{super();for(let r in t)this.set(r,t[r])}else super()}set(t,r){return typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r),super.set(t.toLowerCase(),[t,r])}get(t){return typeof t!="string"&&(t=""+t),super.get(t.toLowerCase())?.[1]}has(t){return typeof t!="string"&&(t=""+t),super.has(t.toLowerCase())}setIfNone(t,r){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let n=t.toLowerCase();if(!super.has(n))return super.set(n,[t,r])}append(t,r,n){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let s=t.toLowerCase(),i=super.get(s);if(i){let o=i[1];if(n)r=(typeof o=="string"?o:o.join(", "))+", "+r;else if(typeof o=="string")r=[o,r];else{o.push(r);return}}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}};a(ZE,"appendHeader");a(_O,"mergeHeaders")});function LH(e){let t={openapi:ine,info:{title:"HarperDB HTTP REST interface",version:DH.packageJson.version},paths:{},components:{schemas:{},securitySchemes:{basicAuth:{type:"http",scheme:"basic"},bearerAuth:{type:"http",scheme:"bearer",bearerFormat:"JWT"}}}},r=[{basicAuth:[],bearerAuth:[]}];for(let[,n]of e){if(!n.path||n.Resource.isError)continue;let{path:s}=n,i=s.split("/").slice(-1),{attributes:o,primaryKey:c,prototype:l}=n.Resource;if(c=c??"id",!c)continue;let u={},f=[];if(o)for(let{type:T,name:b,elements:v,relationship:F,definition:q}of o){if(F)T==="array"?u[b]={type:"array",items:{$ref:Pa+v.type}}:u[b]={$ref:Pa+T};else{let Y=q??v?.definition;if(Y){if(!t.components.schemas[Y.type]){let Z={};Y.properties.forEach(se=>{Z[se.name]=new EO(pO[se.type],se.type)}),t.components.schemas[Y.type]=new PH(Z)}T==="array"?u[b]={type:"array",items:{$ref:Pa+Y.type}}:u[b]={$ref:Pa+Y.type}}else T==="array"?v.type==="Any"||v.type=="ID"?u[b]={type:"array",items:{format:v.type}}:u[b]={type:"array",items:new EO(pO[v.type],v.type)}:T==="Any"||T=="ID"?u[b]={format:T}:u[b]=new EO(pO[T],T)}f.push(new gO(b,"query",u[b]))}let d=Object.keys(u),p=new gO(c,"path",{format:"ID"});p.required=!0,p.description="primary key of record";let _=new gO("property","path",{enum:d});_.required=!0,t.components.schemas[i]=new PH(u);let h=l.post!==Resource.prototype.post||l.update,S=typeof l.put=="function",g=typeof l.get=="function",R=typeof l.delete=="function",E="/"+s+"/";h&&(t.paths[E]={},t.paths[E].post=new one(i,r,"create a new record auto-assigning a primary key")),g&&(t.paths[E]||(t.paths[E]={}),t.paths[E].get=new hO(f,r,{200:new mO({$ref:Pa+i})},"search for records by the specified property name and value pairs")),R&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new CH(f,r,"delete all the records that match the provided query",{204:new IH})),E="/"+s+"/{"+c+"}",g&&(t.paths[E]={},t.paths[E].get=new hO([p],r,{200:new mO({$ref:Pa+i})},"retrieve a record by its primary key")),S&&(t.paths[E]||(t.paths[E]={}),t.paths[E].put=new ane([p],r,i,"create or update the record with the URL path that maps to the record's primary key")),R&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new CH([p],r,"delete a record with the given primary key",{204:new IH})),g&&_.schema.enum.length>0&&(E="/"+s+"/{"+c+"}.{property}",t.paths[E]={},t.paths[E].get=new hO([p,_],r,{200:new mO({enum:d})},"used to retrieve the specified property of the specified record"))}return t}function one(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:Pa+e}}}},this.security=t,this.responses={200:{description:SO,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function hO(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function mO(e){this.description=SO,this.content={"application/json":{schema:e}}}function IH(){this.description="successfully processed request, no content returned to client"}function ane(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:Pa+r}}}},this.responses={200:{description:SO}}}function CH(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function PH(e){this.type="object",this.properties=e}function EO(e,t){this.type=e,this.format=t}function gO(e,t,r){this.name=e,this.in=t,this.schema=r}var DH,ine,pO,Pa,SO,MH=be(()=>{DH=M(it()),ine="3.0.3",pO={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},Pa="#/components/schemas/",SO="successful operation";a(LH,"generateJsonApi");a(one,"Post");a(hO,"Get");a(mO,"Response200");a(IH,"Response204");a(ane,"Put");a(CH,"Delete");a(PH,"ResourceSchema");a(EO,"Type");a(gO,"Parameter")});var tg={};ve(tg,{parseHeaderValue:()=>AO,start:()=>une});async function lne(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream",s=n?"CONNECT":e.method;e.search&&Om(e);let i=new yo;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==vH){let g=eg.getMatch(o,n?"sse":"rest");if(!g)return t(e);e.handlerPath=g.path,c=new Cc(g.relativeURL),c.async=!0,l=g.Resource}if(l?.isCaching){let g=r["cache-control"];if(g){let R=AO(g);for(let E of R)switch(E.name){case"max-age":e.expiresAt=E.value*1e3+Date.now();break;case"only-if-cached":e.onlyIfCached=!0;break;case"no-cache":e.noCache=!0;break;case"no-store":e.noCacheStore=!0;break;case"stale-if-error":e.staleIfError=!0;break;case"must-revalidate":e.mustRevalidate=!0;break}}}let u=r["x-replicate-to"];if(u){let g=AO(u).map(R=>(R.next?.name==="confirm"&&R.next.value>=0&&(e.replicatedConfirmation=+R.next.value),R.name));e.replicateTo=g.length===1&&+g[0]>=0?+g[0]:g[0]==="*"?void 0:g}r["x-replicate-from"]==="none"&&(e.replicateFrom=!1);let d=await wt(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=uo(r["content-type"],!0)(e.body,e.headers)}catch(g){throw new Yu.ClientError(g,400)}if(e.authorize=!0,o===vH&&s==="GET"){if(e?.user?.role?.permission?.super_user)return LH(eg);throw new Yu.ServerError("Forbidden",403)}switch(s){case"GET":case"HEAD":return l.get(c,e);case"POST":return l.post(c,e.data,e);case"PUT":return l.put(c,e.data,e);case"DELETE":return l.delete(c,e);case"PATCH":return l.patch(c,e.data,e);case"OPTIONS":i.setIfNone("Allow","GET, HEAD, POST, PUT, DELETE, PATCH, OPTIONS, TRACE, QUERY, COPY, MOVE");return;case"CONNECT":return l.connect(c,null,e);case"TRACE":return"HarperDB is the terminating server";case"QUERY":return l.query(c,e.data,e);case"COPY":return l.copy(c,r.destination,e);case"MOVE":return l.move(c,r.destination,e);case"BREW":throw new Yu.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Yu.ServerError(`Method ${s} is not recognized`,501)}}),p=200,_;if(d==null)p=s==="GET"||s==="HEAD"?404:204,TO.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(d.status>0&&d.headers){let g=_O(d.headers,i);return d.headers!==g&&(d.headers=g),d.data!==void 0&&(d.body=Jf(d.data,e,d)),d}else if(_=e.lastModified){cne[0]=_;let g=String.fromCharCode(34,(Mr[0]&63)+62,(Mr[0]>>6)+(Mr[1]<<2&63)+62,(Mr[1]>>4)+(Mr[2]<<4&63)+62,(Mr[2]>>2)+62,(Mr[3]&63)+62,(Mr[3]>>6)+(Mr[4]<<2&63)+62,(Mr[4]>>4)+(Mr[5]<<4&63)+62,(Mr[5]>>2)+62,(Mr[6]&63)+62,(Mr[6]>>6)+(Mr[7]<<2&63)+62,34),R=r["if-none-match"];R&&g==R?(d?.onDone&&d.onDone(),p=304,d=void 0):i.setIfNone("ETag",g),TO.lastModified&&i.setIfNone("Last-Modified",new Date(_).toUTCString())}e.createdResource&&(p=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let h={status:p,headers:i,body:void 0},S=d?.wasLoadedFromSource?.();return S!==void 0&&(h.wasCacheMiss=S,!S&&_&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||_))/1e3))),d!==void 0&&(h.body=Jf(d,e,h),s==="HEAD"&&(h.body=void 0)),h}catch(o){o.statusCode?o.statusCode===500?Fi.warn(o):Fi.info(o):Fi.error(o),o.statusCode===405&&(o.method&&(o.message+=` to handle HTTP method ${o.method.toUpperCase()||""}`),o.allow&&(o.allow.push("trace","head","options"),i.setIfNone("Allow",o.allow.map(l=>l.toUpperCase()).join(", "))));let c={status:o.statusCode||500,headers:i,body:void 0};return c.body=Jf(o.contentType?o:o.toString(),e,c),c}}function une(e){TO=e,!UH&&(UH=!0,eg=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return lne(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{j_++;let s=new Bn;xH||(xH=!0,Y_(l=>{j_>0&&l.push({metric:"ws-connections",connections:j_,byThread:!0})}));let i;t.on("error",l=>{i=!0,Fi.warn(l)});let o;t.on("message",a(function(u){o||(o=uo(r.requestedContentType??r.headers.asObject["content-type"],!1));let f=o(u);sr(u.length,"bytes-received",r.handlerPath,"message","ws"),s.push(f)},"message"));let c;t.on("close",()=>{j_--,Qn(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),u=eg.getMatch(l,"ws");if(Qn(!!u,"connection","ws","connect"),u){r.handlerPath=u.path,sr(h=>({count:h.count,total:j_}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let f=new Cc(u.relativeURL),d=u.Resource;c=(await wt(r,()=>d.connect(f,s,r)))[Symbol.asyncIterator]();let _;for(;!(_=await c.next()).done;){let h=await Aa(_.value,r);t.send(h),sr(h.length,"bytes-sent",r.handlerPath,"message","ws"),t._socket.writableNeedDrain&&await new Promise(S=>t._socket.once("drain",S))}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){l.statusCode?l.statusCode===500?Fi.warn(l):Fi.info(l):Fi.error(l),t.close(dne[l.statusCode]||1011,l.toString())}t.close()},e))}function AO(e){return e.trim().split(",").map(t=>{let r,n=t.trim().split(";"),s;for(;s=n.pop();)if(s.includes("=")){let[i,o]=s.trim().split("=");i=i.trim(),o&&(o=o.trim()),r={name:i.toLowerCase(),value:o,next:r}}else r={name:s.toLowerCase(),next:r};return r})}var Fi,Yu,Mr,cne,TO,vH,UH,eg,xH,j_,dne,BH=be(()=>{ao();ki();Fi=M(z()),Yu=M(pe());Gf();pu();Ic();z_();MH();Gf();Mr=new Uint8Array(8),cne=new Float64Array(Mr.buffer,0,1),TO={},vH="openapi";a(lne,"http");j_=0;a(une,"start");dne={401:3e3,403:3003};a(AO,"parseHeaderValue")});var RO=w((qCe,kH)=>{var{recordAction:rg,recordActionBinary:HH}=(ki(),C(W_)),fne=require("fastify-plugin"),_ne=200;kH.exports=fne(function(e,t,r){e.addHook("onResponse",async(n,s)=>{let i=s.elapsedTime}),e.addHook("onSend",async(n,s,i)=>{let o=s.elapsedTime,c=performance.now(),l=s.request.routeOptions,u,f,d;l.config?.isOperation?(u=n.body?.operation,f="operation"):(u=l.url,f="fastify-route",d=l.method),rg(o,"duration",u,d,f),HH(s.raw.statusCode<400,"success",u,d,f),HH(1,"response_"+s.raw.statusCode,u,d,f);let p=_ne;i?.pipe?(i.on("data",g=>{p+=g.length}),i.on("end",()=>{rg(performance.now()-c,"transfer",u,d,f),rg(p,"bytes-sent",u,d,f)})):(p+=i?.length||0,rg(p,"bytes-sent",u,d,f));let _=o.toFixed(3),h=s.getHeader("Server-Timing"),S=`db;dur=${_}`;s.header("Server-Timing",h?`${h}, ${S}`:S)}),r()},{name:"hdb-request-time"})});var GH=w(($Ce,FH)=>{var pne=ot(),hne={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};FH.exports=function(e){return pne.validateObject(e,hne)}});var ng=w((VCe,qH)=>{"use strict";var mne=(H(),C(G)).OPERATIONS_ENUM,yO=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=mne.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};qH.exports=yO});var X_={};ve(X_,{createTokens:()=>gne,getJWTRSAKeys:()=>cg,refreshOperationToken:()=>Sne,validateOperationToken:()=>NO,validateRefreshToken:()=>lg});async function cg(){if(sg)return sg;try{let e=J_.default.join(Q_.default.getHdbBasePath(),zA),t=await ig.default.readFile(J_.default.join(e,Of.JWT_PASSPHRASE_NAME),"utf8"),r=await ig.default.readFile(J_.default.join(e,Of.JWT_PRIVATE_KEY_NAME),"utf8");return sg={publicKey:await ig.default.readFile(J_.default.join(e,Of.JWT_PUBLIC_KEY_NAME),"utf8"),privateKey:r,passphrase:t},sg}catch(e){throw ag.default.error(e),new ii.ClientError(zu.NO_ENCRYPTION_KEYS,Wu.INTERNAL_SERVER_ERROR)}}async function gne(e){let t=(0,bO.validateBySchema)(e,Gi.default.object({username:Gi.default.string().optional(),password:Gi.default.string().optional(),role:Gi.default.string().optional(),expires_in:Gi.default.alternatives(Gi.default.string(),Gi.default.number()).optional()}));if(t)throw new ii.ClientError(t.message);let r;try{let d=e.bypass_auth!==!0;!e.username&&!e.password&&(e.username=e.hdb_user?.username,d=!1),r=await(0,OO.findAndValidateUser)(e.username,e.password,d)}catch(d){throw ag.default.error(d),new ii.ClientError(zu.INVALID_CREDENTIALS,Wu.UNAUTHORIZED)}if(!r)throw new ii.ClientError(zu.INVALID_CREDENTIALS,Wu.UNAUTHORIZED);let n=!1,s=!1;r.role?.permission&&(n=r.role.permission.super_user===!0,s=r.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s};e.role&&(i.role=e.role);let o=await cg(),c=await ju.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:e.expires_in??WH,algorithm:og,subject:"operation"}),l=await ju.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:Ene,algorithm:og,subject:"refresh"}),u=Fy(l,"sha256");if((await(0,$H.update)(new VH.default(bf,fu.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]))).skipped_hashes.length>0)throw new ii.ClientError(zu.REFRESH_TOKEN_SAVE_FAILED,Wu.INTERNAL_SERVER_ERROR);return KH.default.signalUserChange(new YH.UserEventMsg(process.pid)),{operation_token:c,refresh_token:l}}async function Sne(e){let t=(0,bO.validateBySchema)(e,Gi.default.object({refresh_token:Gi.default.string().required()}).required());if(t)throw new ii.ClientError(t.message);let{refresh_token:r}=e;await lg(r);let n=await cg(),s=await ju.default.decode(r);return{operation_token:await ju.default.sign({username:s.username,super_user:s.super_user,cluster_user:s.cluster_user},{key:n.privateKey,passphrase:n.passphrase},{expiresIn:WH,algorithm:og,subject:"operation"})}}async function NO(e){return zH(e,"operation")}async function lg(e){return zH(e,"refresh")}async function zH(e,t){try{let r=await cg(),n=await ju.default.verify(e,r.publicKey,{algorithms:og,subject:t});if(n.role)throw new Error("Invalid token");let s=await(0,OO.findAndValidateUser)(n.username,void 0,!1);if(t==="refresh"&&!Gy(s.refresh_token,e))throw new Error("Invalid token");return s}catch(r){throw ag.default.warn(r),r?.name==="TokenExpiredError"?new ii.ClientError(zu.TOKEN_EXPIRED,Wu.FORBIDDEN):new ii.ClientError(zu.INVALID_TOKEN,Wu.UNAUTHORIZED)}}var ju,ig,J_,Gi,bO,ii,ag,OO,$H,VH,KH,YH,Q_,Wu,zu,WH,Ene,og,sg,Ju=be(()=>{ju=M(require("jsonwebtoken")),ig=M(require("fs-extra")),J_=M(require("node:path")),Gi=M(require("joi")),bO=M(ot());H();ii=M(pe()),ag=M(z());hE();OO=M(Rn()),$H=M(yn()),VH=M(ng()),KH=M(To()),YH=M(ri()),Q_=M(ae()),{HTTP_STATUS_CODES:Wu,AUTHENTICATION_ERROR_MSGS:zu}=ii.hdb_errors;Q_.default.initSync();WH=Q_.default.get(x.AUTHENTICATION_OPERATIONTOKENTIMEOUT)||"1d",Ene=Q_.default.get(x.AUTHENTICATION_REFRESHTOKENTIMEOUT)||"30d",og="RS256";a(cg,"getJWTRSAKeys");a(gne,"createTokens");a(Sne,"refreshOperationToken");a(NO,"validateOperationToken");a(lg,"validateRefreshToken");a(zH,"validateToken")});var wO=w((jCe,QH)=>{"use strict";var Tne=GH(),Qu=require("passport"),Ane=require("passport-local").Strategy,Rne=require("passport-http").BasicStrategy,yne=require("util"),bne=Rn(),JH=yne.callbackify(bne.findAndValidateUser),zCe=xn(),One=(H(),C(G)),jH=(Ju(),C(X_));Qu.use(new Ane(function(e,t,r){JH(e,t,r)}));Qu.use(new Rne(function(e,t,r){JH(e,t,r)}));Qu.serializeUser(function(e,t){t(null,e)});Qu.deserializeUser(function(e,t){t(null,e)});function Nne(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":Qu.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===One.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?jH.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):jH.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:Qu.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(Nne,"authorize");function wne(e,t){let r=Tne(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(wne,"checkPermissions");QH.exports={authorize:Nne,checkPermissions:wne}});var ug=w((QCe,XH)=>{"use strict";var Ine=Vn();XH.exports={writeTransaction:Cne};function Cne(e,t,r){return Ine.writeTransaction(e,t,r)}a(Cne,"writeTransaction")});var rk=w((ePe,tk)=>{"use strict";var Pne=Yr(),Dne=As(),ZH=z(),Lne=yn(),ZCe=ug(),Mne=require("clone"),CO=require("alasql"),vne=aE(),ek=require("util"),Une=ek.promisify(Dne.getTableSchema),xne=ek.promisify(Pne.search),Bne=(H(),C(G)),IO=ie();vne(CO);tk.exports={update:kne};var Hne="There was a problem performing this update. Please check the logs and try again.";async function kne({statement:e,hdb_user:t}){let r=await Une(e.table.databaseid,e.table.tableid),n=Fne(e.columns);IO.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=Mne(s),c=IO.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=CO.parse(l).statements[0],f=await xne(u),d=Gne(n,f);return qne(o,d,t)}a(kne,"update");function Fne(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=CO.compile(`SELECT ${r.expression.toString()} AS [${Bne.FUNC_VAL}] FROM ?`)}),t}catch(t){throw ZH.error(t),new Error(Hne)}}a(Fne,"createUpdateRecord");function Gne(e,t){return IO.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(Gne,"buildUpdateRecords");async function qne(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await Lne.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){ZH.error(`Error delete new_attributes from update response: ${i}`)}return s}a(qne,"updateRecords")});var sk=w((sPe,nk)=>{var $ne=require("alasql"),Vne=Yr(),Kne=z(),Yne=Vn(),DO=require("util"),PO=ie(),Wne=(H(),C(G)),zne=As(),rPe=ug(),nPe=yn(),jne="record",Jne="successfully deleted",Qne=DO.callbackify(tse),Xne=DO.promisify(Vne.search),Zne=DO.promisify(zne.getTableSchema);nk.exports={convertDelete:Qne};function ese(e){return`${e.deleted_hashes.length} ${jne}${e.deleted_hashes.length===1?"":"s"} ${Jne}`}a(ese,"generateReturnMessage");async function tse({statement:e,hdb_user:t}){let r=await Zne(e.table.databaseid,e.table.tableid);PO.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=PO.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=$ne.parse(o).statements[0],l={operation:Wne.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await Xne(c);let u=await Yne.deleteRecords(l);return PO.isEmptyOrZeroLength(u.message)&&(u.message=ese(u)),delete u.txn_time,u}catch(u){throw Kne.error(u),u.hdb_code?u.message:u}}a(tse,"convertDelete")});var lk=w((oPe,ck)=>{"use strict";var rse=go(),{hdb_errors:ik}=pe(),{getDatabases:ok}=(De(),C(nt));ck.exports={checkSchemaExists:ak,checkSchemaTableExists:nse,schema_describe:rse};async function ak(e){if(!ok()[e])return ik.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(ak,"checkSchemaExists");async function nse(e,t){let r=await ak(e);if(r)return r;if(!ok()[e][t])return ik.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(nse,"checkSchemaTableExists")});var xO=w((dPe,Ak)=>{"use strict";var{decode:sse}=require("msgpackr"),{isMainThread:cPe,parentPort:lPe,threadId:uPe}=require("worker_threads"),_g=ir(),Xu=Tt(),vO=(H(),C(G)),Jr=z(),MO=ae(),ise=(H(),C(G)),{onMessageByType:ose}=rt(),_k=Eo(),{recordAction:uk,recordActionBinary:ase}=(ki(),C(W_)),{publishToStream:cse}=_g,{ConsumerEvents:dk}=require("nats"),lse=Yr(),{promisify:use}=require("util"),{decodeBlobsWithWrites:dse}=(gs(),C(Gm)),pk=use(setTimeout),pg=1e4,hg,fg,fse,_se,hk,Z_=new Map,Zu=new Map;Ak.exports={initialize:mk,ingestConsumer:UO,setSubscription:pse,setIgnoreOrigin:Ese,getDatabaseSubscriptions:mse,updateConsumer:Ek};async function mk(){ose(vO.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await Ek(n)}),hk=!0,Jr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await _g.getNATSReferences();hg=e,fg=e.info.server_name,fse=t,_se=r}a(mk,"initialize");async function Ek(e){if(e.status==="start"){let{js:t,jsm:r}=await gk(e.node_domain_name);UO(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=Z_.get(e.stream_name+e.node_domain_name);t&&(Jr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),Z_.set(e.stream_name+e.node_domain_name,"close")),Zu.get(e.node_domain_name)==="failed"&&Zu.set(e.node_domain_name,"close")}}a(Ek,"updateConsumer");var mg=new Map;function pse(e,t,r){let n=mg.get(e);n||mg.set(e,n=new Map),n.set(t,r),hk||mk().then(hse)}a(pse,"setSubscription");async function hse(){let e=await lse.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+Xu.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions||[])if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await gk(r),!n))break;let{schema:o,table:c}=i,l=_k.createNatsTableStreamName(o,c);UO(l,n,s,r)}}}a(hse,"accessConsumers");async function gk(e){let t,r,n=1;for(;!r;)try{t=await hg.jetstream({domain:e}),r=await hg.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(Zu.get(e)==="close")break;Zu.set(e,"failed"),n%10===1&&Jr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<pg?n++*100:pg;await pk(i)}return{js:t,jsm:r}}a(gk,"connectToRemoteJS");function mse(){return mg}a(mse,"getDatabaseSubscriptions");var Sk;function Ese(e){Sk=e}a(Ese,"setIgnoreOrigin");var Tk=100,fk=new Array(Tk),dg=0;async function UO(e,t,r,n){let{connection:s}=await _g.getNATSReferences();hg=s,fg=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,fg),Jr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(Zu.get(n)==="close")break;o%10===1&&Jr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",u.message),u.code==="404"&&(Jr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await _g.createConsumer(r,e,fg,new Date(Date.now()).toISOString()));let f=o++*100<pg?o++*100:pg;await pk(f)}let c=!1,l;for(;!c;){if(Z_.get(e+n)==="close"||Zu.get(n)==="close"){Z_.delete(e+n),c=!0;continue}l=await i.consume({max_messages:MO.get(vO.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),Z_.set(e+n,l);let u=!1;(async()=>{for await(let f of await l.status())if(f.type===dk.ConsumerDeleted&&(await l.close(),c=!0),f.type===dk.HeartbeatsMissed){let d=f.data;Jr.trace(`${d} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),d===100&&(Jr.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${l.consumer.stream}`),l.stop(),u=!0)}})();try{for await(let f of l)await fk[dg],fk[dg]=gse(f).catch(d=>{Jr.error(d)}),++dg>=Tk&&(dg=0)}catch(f){f.message==="consumer deleted"?(Jr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):Jr.error("Error consuming clustering ingest, restarting consumer",f)}}}a(UO,"ingestConsumer");async function gse(e){let t;await dse(()=>{t=sse(e.data)}),uk(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),Jr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=MO.get(vO.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(Xu.MSG_HEADERS.TRANSACTED_NODES)&&r.values(Xu.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(Xu.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!Sk),ase(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(Xu.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:u,records:f,hash_values:d,__origin:p,expiresAt:_}=t;Jr.trace("processing message:",o,c,u,(f?"records: "+f.map(v=>v?.id):"")+(d?"ids: "+d:""),"with sequence:",e.seq),Jr.trace(`messageProcessor nats msg id: ${e.headers.get(Xu.MSG_HEADERS.NATS_MSG_ID)}`);let h;f||(f=d);let S=new Promise(v=>h=v),{timestamp:g,user:R,node_name:E}=p||{},T=mg.get(c)?.get(u);if(!T)throw new Error(`Missing table for replication message: ${u}`);if(o==="define_schema")t.type=o,t.onCommit=h,T.send(t);else if(f.length===1&&!l)T.send({type:LO(o),value:f[0],id:d?.[0],expiresAt:_,timestamp:g,table:u,onCommit:h,user:R,nodeName:E});else{let v=f.map((F,q)=>({type:LO(o),value:F,expiresAt:_,id:d?.[q],table:u}));for(;l;)v.push({type:LO(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;T.send({type:"transaction",writes:v,table:u,timestamp:g,onCommit:h,user:R,nodeName:E})}MO.get(ise.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&cse(e.subject.split(".").slice(0,-1).join("."),_k.createNatsTableStreamName(c,u),e.headers,e.data),await S;let b=Date.now()-g;g&&uk(b,"replication-latency",e.subject,o,"ingest")}catch(o){Jr.error(o)}e.ack()}a(gse,"messageProcessor");function LO(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(LO,"convertOperation")});var ir=w((gPe,Hk)=>{"use strict";var wr=ae();wr.initSync();var Sse=require("fs-extra"),Tse=require("semver"),rp=require("path"),{monotonicFactory:Ase}=require("ulidx"),yk=Ase(),Rse=require("util"),bk=require("child_process"),yse=Rse.promisify(bk.exec),bse=bk.spawn,vr=Tt(),$e=(H(),C(G)),{packageJson:Ose,PACKAGE_ROOT:Nse}=it(),Eg=ie(),oi=z(),gg=Eo(),wse=ug(),ep=yt(),{broadcast:Ise,onMessageByType:Cse,getWorkerIndex:Pse}=rt(),{isMainThread:Ok}=require("worker_threads"),{Encoder:Dse,decode:FO}=require("msgpackr"),Nk=new Dse,{isEmpty:_l}=Eg,wk=Rn(),_Pe=48*36e11;Ok&&Cse($e.ITC_EVENT_TYPES.RESTART,()=>{Qr=void 0,fl=void 0});var{connect:Lse,StorageType:Mse,RetentionPolicy:vse,AckPolicy:GO,DeliverPolicy:qO,DiscardPolicy:Use,NatsConnection:pPe,JetStreamManager:hPe,JetStreamClient:mPe,StringCodec:EPe,JSONCodec:xse,createInbox:$O,headers:Bse,ErrorCode:Rk}=require("nats"),{recordAction:Hse}=(ki(),C(W_)),{encodeBlobsAsBuffers:kse}=(gs(),C(Gm)),Ik=xse(),Fse="clustering",Gse=Ose.engines[vr.NATS_SERVER_NAME],qse=rp.join(Nse,"dependencies"),kO=rp.join(qse,`${process.platform}-${process.arch}`,vr.NATS_BINARY_NAME),BO,HO,tp,ul,dl;Hk.exports={runCommand:Ck,checkNATSServerInstalled:$se,createConnection:VO,getConnection:np,getJetStreamManager:sp,getJetStream:Dk,getNATSReferences:qi,getServerList:Kse,createLocalStream:KO,listStreams:Lk,deleteLocalStream:Yse,getServerConfig:ed,listRemoteStreams:Wse,viewStream:zse,viewStreamIterator:jse,publishToStream:Jse,request:Zse,reloadNATS:YO,reloadNATSHub:eie,reloadNATSLeaf:tie,extractServerName:Xse,requestErrorHandler:rie,createLocalTableStream:xk,createTableStreams:iie,purgeTableStream:Bk,purgeSchemaTableStreams:oie,getStreamInfo:aie,updateLocalStreams:lie,closeConnection:Vse,getJsmServerName:Sg,addNatsMsgHeader:Mk,clearClientCache:Pk,updateRemoteConsumer:nie,createConsumer:vk,updateConsumerIterator:sie};async function Ck(e,t=void 0){let{stdout:r,stderr:n}=await yse(e,{cwd:t});if(n)throw new Error(n.replace(`
19
+ `)},VZ="certificate.pem",KZ="privateKey.pem",YZ="caCertificate.pem",WZ="natsCertificate.pem",zZ="natsCaCertificate.pem",Tt={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},jZ={tls_certificate:Tt.SERVER,tls_certificateAuthority:Tt.CA,customFunctions_tls_certificate:Tt.SERVER,customFunctions_tls_certificateAuthority:Tt.CA,operationsApi_tls_certificate:Tt["OPERATIONS-API"],operationsApi_tls_certificateAuthority:Tt["OPERATIONS-CA"]},JZ={[Tt.SERVER]:2,[Tt.DEFAULT]:1},QZ={[Tt["OPERATIONS-API"]]:3,[Tt.SERVER]:2,[Tt.DEFAULT]:1},XZ={[Tt["OPERATIONS-API"]]:3,[Tt.SERVER]:2,[Tt.DEFAULT]:1},ZZ={[Tt["OPERATIONS-CA"]]:3,[Tt.CA]:2,[Tt["DEFAULT-CA"]]:1},e8={[Tt["OPERATIONS-CA"]]:3,[Tt.CA]:2,[Tt["DEFAULT-CA"]]:1},t8={[Tt.CA]:2,[Tt["DEFAULT-CA"]]:1};Object.assign(NU,{CERTIFICATE_PEM_NAME:VZ,PRIVATEKEY_PEM_NAME:KZ,CA_PEM_NAME:YZ,CERT_NAME:Tt,CERT_CONFIG_NAME_MAP:jZ,CERT_PREFERENCE_APP:JZ,CERT_PREFERENCE_OPS:QZ,CERT_PREFERENCE_REP:XZ,CA_CERT_PREFERENCE_REP:ZZ,CA_CERT_PREFERENCE_OPS:e8,CA_CERT_PREFERENCE_APP:t8,CERTIFICATE_VALUES:$Z,NATS_CERTIFICATE_PEM_NAME:WZ,NATS_CA_PEM_NAME:zZ})});var Wy=I((ONe,LU)=>{"use strict";var PU=require("fs-extra"),Se=require("joi"),r8=require("os"),{boolean:He,string:At,number:tr,array:Qc}=Se.types(),{totalmem:wU}=require("os"),Jc=require("path"),n8=W(),Yy=ae(),bNe=Ky(),IU=(H(),P(G)),s8=it(),CU="log",i8="components",o8="Invalid logging.rotation.maxSize unit. Available units are G, M or K",a8="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",c8="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",l8="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",u8="rootPath config parameter is undefined",Rn=Se.alternatives([tr.min(0),At]).optional().empty(null),EE=Se.alternatives([Qc.items(At,{host:At.required(),port:Rn},{hostname:At.required(),port:Rn}).empty(null),Qc.items(At)]),Ui,DU=!1;LU.exports={configValidator:d8,routesValidator:E8,route_constraints:EE};function d8(e,t=!1){if(DU=t,Ui=e.rootPath,Yy.isEmpty(Ui))throw u8;let r=He.optional(),n=tr.min(0).max(1e3).empty(null).default(m8),s=At.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(T_),i=At.optional().empty(null),o=At.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=Se.string().empty(null).default(T_),l=Se.custom(_8).empty(null).default(T_),u=e.clustering?.enabled,f=Se.object({certificate:i,certificateAuthority:i,privateKey:i}),d;return u===!0?d=Se.object({enabled:r,hubServer:Se.object({cluster:Se.object({name:Se.required().empty(null),network:Se.object({port:Rn,routes:EE}).required()}).required(),leafNodes:Se.object({network:Se.object({port:Rn}).required()}).required(),network:Se.object({port:Rn}).required()}).required(),leafServer:Se.object({network:Se.object({port:Rn,routes:EE}).required(),streams:Se.object({maxAge:tr.min(120).allow(null).optional(),maxBytes:tr.min(1).allow(null).optional(),maxMsgs:tr.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:Se.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:He.optional(),databaseLevel:He.optional(),tls:Se.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:He.required(),verify:He.optional()}),user:At.optional().empty(null)}).optional():d=Se.object({enabled:r,tls:Se.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:He.optional()})}).optional(),Se.object({authentication:Se.alternatives(Se.object({authorizeLocal:He,cacheTTL:tr.required(),enableSessions:He,hashFunction:At.valid("md5","sha256","argon2id").optional().empty(null)}),He).optional(),analytics:Se.object({aggregatePeriod:tr}),replication:Se.object({hostname:Se.alternatives(At,tr).optional().empty(null),url:At.optional().empty(null),port:Rn,securePort:Rn,routes:Qc.optional().empty(null),databases:Se.alternatives(At,Qc),enableRootCAs:He.optional(),copyTablesToCatchUp:He.optional()}).optional(),componentsRoot:s.optional(),clustering:d,localStudio:Se.object({enabled:r}).required(),logging:Se.object({auditAuthEvents:Se.object({logFailed:He,logSuccessful:He}),file:He.required(),level:Se.valid("notify","fatal","error","warn","info","debug","trace"),rotation:Se.object({enabled:He.optional(),compress:He.optional(),interval:At.custom(h8).optional().empty(null),maxSize:At.custom(p8).optional().empty(null),path:At.optional().empty(null).default(T_)}).required(),root:s,stdStreams:He.required(),auditLog:He.required()}).required(),operationsApi:Se.object({network:Se.object({cors:He.optional(),corsAccessList:Qc.optional(),headersTimeout:tr.min(1).optional(),keepAliveTimeout:tr.min(1).optional(),port:Rn,domainSocket:Se.optional().empty("hdb/operations-server").default(T_),securePort:Rn,timeout:tr.min(1).optional()}).optional(),tls:Se.alternatives([Se.array().items(f),f])}).required(),rootPath:At.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:Se.object({network:Se.object({port:Rn,securePort:Rn,mtls:Se.alternatives([He.optional(),Se.object({user:At.optional(),certificateAuthority:i,required:He.optional()})])}).required(),webSocket:He.optional(),requireAuthentication:He.optional()}),http:Se.object({compressionThreshold:tr.optional(),cors:He.optional(),corsAccessList:Qc.optional(),headersTimeout:tr.min(1).optional(),port:Rn,securePort:Rn,maxHeaderSize:tr.optional(),mtls:Se.alternatives([He.optional(),Se.object({user:At.optional(),certificateAuthority:i,required:He.optional()})]),threadRange:Se.alternatives([Qc.optional(),At.optional()])}).required(),threads:Se.alternatives(n.optional(),Se.object({count:n.optional(),debug:Se.alternatives(He.optional(),Se.object({startingPort:tr.min(1).optional(),host:At.optional(),waitForDebugger:He.optional()})),maxHeapMemory:tr.min(0).optional()})),storage:Se.object({writeAsync:He.required(),overlappingSync:He.optional(),caching:He.optional(),compression:Se.alternatives([He.optional(),Se.object({dictionary:At.optional(),threshold:tr.optional()})]),compactOnStart:He.optional(),compactOnStartKeepBackup:He.optional(),noReadAhead:He.optional(),path:l,prefetchWrites:He.optional(),maxFreeSpaceToLoad:tr.optional(),maxFreeSpaceToRetain:tr.optional()}).required(),ignoreScripts:He.optional(),tls:Se.alternatives([Se.array().items(f),f])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(d8,"configValidator");function f8(e){return DU||PU.existsSync(e)?null:`Specified path ${e} does not exist.`}a(f8,"doesPathExist");function _8(e,t){Se.assert(e,At.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=f8(e);if(r)return t.message(r)}a(_8,"validatePath");function p8(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(o8);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(c8):e}a(p8,"validateRotationMaxSize");function h8(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(a8);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(l8):e}a(h8,"validateRotationInterval");function m8(e,t){let r=t.state.path.join("."),n=r8.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||wU();return i=Math.round(Math.min(i,wU())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),n8.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(m8,"setDefaultThreads");function T_(e,t){let r=t.state.path.join(".");if(!Yy.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(Yy.isEmpty(Ui))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return Jc.join(Ui,i8);case"logging.root":return Jc.join(Ui,CU);case"clustering.leafServer.streams.path":return Jc.join(Ui,"clustering","leaf");case"storage.path":let n=Jc.join(Ui,IU.LEGACY_DATABASES_DIR_NAME);return PU.existsSync(n)?n:Jc.join(Ui,IU.DATABASES_DIR_NAME);case"logging.rotation.path":return Jc.join(Ui,CU);case"operationsApi.network.domainSocket":return r==null?null:Jc.join(Ui,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(T_,"setDefaultRoot");function E8(e){let t=Se.object({routes:EE});return s8.validateBySchema({routes:e},t)}a(E8,"routesValidator")});var Rt=I($U=>{"use strict";var ys=(H(),P(G)),Sr=ae(),rr=W(),{configValidator:g8,routesValidator:MU}=Wy(),jr=require("fs-extra"),UU=require("yaml"),Wn=require("path"),S8=require("is-number"),xU=require("properties-reader"),T8=require("lodash"),{handleHDBError:A8}=pe(),{HTTP_STATUS_CODES:R8,HDB_ERROR_MSGS:Lu}=Bn(),{server:y8}=(Kr(),P(Ru)),{PACKAGE_ROOT:BU}=st(),{DATABASES_PARAM_CONFIG:A_,CONFIG_PARAMS:Yn,CONFIG_PARAM_MAP:ti}=ys,b8="Unable to get config value because config is uninitialized",O8="Config successfully initialized",N8="Error backing up config file",w8="Empty parameter sent to getConfigValue",HU=Wn.join(BU,"config","yaml",ys.HDB_DEFAULT_CONFIG_FILE),I8=Wn.join(BU,"config","yaml","defaultNatsConfig.yaml"),C8="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",vU={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"},gE,It,SE;Object.assign($U,{createConfigFile:P8,getDefaultConfig:D8,getConfigValue:FU,initConfig:TE,flattenConfig:Mu,updateConfigValue:GU,updateConfigObject:M8,getConfiguration:x8,setConfiguration:B8,readConfigFile:Qy,getClusteringRoutes:H8,initOldConfig:qU,getConfigFromFile:k8,getConfigFilePath:Xc,addConfig:F8,deleteConfigFromFile:G8,getConfigObj:q8,resolvePath:zy,getFlatConfigObj:$8});function zy(e){if(e?.startsWith("~/"))return Wn.join(Sr.getHomeDir(),e.slice(1));let t=ce();return Wn.resolve(t.getHdbBasePath(),e)}a(zy,"resolvePath");function P8(e,t=!1){let r=wa(HU);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=UU.parseDocument(jr.readFileSync(I8,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}gE=Mu(r.toJSON());let n;for(let c in e){let l=ti[c.toLowerCase()];if(l===Yn.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(u=>({[u]:e[c][u]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let u=l.split("_"),f=jy(l,e[c]);l==="rootPath"&&f?.endsWith("/")&&(f=f.slice(0,-1));try{r.setIn([...u],f)}catch(d){rr.error(d)}}}n&&kU(r,n),Jy(r,t);let s=r.toJSON();It=Mu(s);let i=r.getIn(["rootPath"]),o=Wn.join(i,ys.HDB_CONFIG_FILE);if(jr.createFileSync(o),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);jr.writeFileSync(o,String(r)),rr.trace(`Config file written to ${o}`)}a(P8,"createConfigFile");function kU(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!Sr.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(A_.TABLES))for(let i in n[s][A_.TABLES])for(let o in n[s][A_.TABLES][i]){let c=n[s][A_.TABLES][i][o],l=[Yn.DATABASES,s,A_.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=[Yn.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){rr.error("Error parsing schemas CLI/env config arguments",n)}}a(kU,"setSchemasConfig");function D8(e){if(gE===void 0){let r=wa(HU);gE=Mu(r.toJSON())}let t=ti[e.toLowerCase()];if(t!==void 0)return gE[t.toLowerCase()]}a(D8,"getDefaultConfig");function FU(e){if(e==null){rr.info(w8);return}if(It===void 0){rr.trace(b8);return}let t=ti[e.toLowerCase()];if(t!==void 0)return It[t.toLowerCase()]}a(FU,"getConfigValue");function Xc(e=Sr.getPropsFilePath()){let t=Sr.getEnvCliRootPath();if(t)return zy(Wn.join(t,ys.HDB_CONFIG_FILE));let r=xU(e);return zy(r.get(ys.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(Xc,"getConfigFilePath");function TE(e=!1){if(It===void 0||e){let t;if(!Sr.noBootFile()){t=Sr.getPropsFilePath();try{jr.accessSync(t,jr.constants.F_OK|jr.constants.R_OK)}catch(i){throw rr.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Xc(t),n;if(r.includes("config/settings.js"))try{qU(r);return}catch(i){if(i.code!==ys.NODE_ERROR_CODES.ENOENT)throw i}try{n=wa(r)}catch(i){if(i.code===ys.NODE_ERROR_CODES.ENOENT){rr.trace(`HarperDB config file not found at ${r}.
20
+ This can occur during early stages of install where the config file has not yet been created`);return}else throw rr.error(i),new Error(`Error reading HarperDB config file at ${r}`)}L8(n,r),Jy(n);let s=n.toJSON();if(y8.config=s,It=Mu(s),It.logging_rotation_rotate)for(let i in vU)It[i]&&rr.error(`Config ${vU[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);rr.trace(O8)}}a(TE,"initConfig");function L8(e,t){let r=e.getIn(["rootPath"]),n=!1;if(e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Wn.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Wn.join(r,"log")),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n){if(rr.trace("Updating config file with missing config params"),e.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${e.errors}`);jr.writeFileSync(t,String(e))}}a(L8,"checkForUpdatedConfig");function Jy(e,t=!1){let r=e.toJSON();if(r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads),r.http?.port&&r.http?.port===r.http?.securePort)throw Lu.CONFIG_VALIDATION("http.port and http.securePort cannot be the same value");if(r.operationsApi?.network?.port&&r.operationsApi?.network?.port===r.operationsApi?.network?.securePort)throw Lu.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=g8(r,t);if(n.error)throw Lu.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket),r?.clustering?.enabled&&e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path)}a(Jy,"validateConfig");function M8(e,t){It===void 0&&(It={});let r=ti[e.toLowerCase()];if(r===void 0){rr.trace(`Unable to update config object because config param '${e}' does not exist`);return}It[r.toLowerCase()]=t}a(M8,"updateConfigObject");function GU(e,t,r=void 0,n=!1,s=!1,i=!1){It===void 0&&TE();let o=FU(ti.hdb_root),c=Wn.join(o,ys.HDB_CONFIG_FILE),l=wa(c),u;if(r&&It){let p=!1;for(let _ in r)if(r[_]!=It[_.toLowerCase()]){p=!0;break}if(!p){rr.trace("No changes detected in config parameters, skipping update");return}}if(r===void 0&&e.toLowerCase()===Yn.DATABASES)u=t;else if(r===void 0){let p;if(i)p=e;else if(p=ti[e.toLowerCase()],p===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let _=p.split("_"),h=jy(p,t);l.setIn([..._],h)}else for(let p in r){let _=ti[p.toLowerCase()];if(_===Yn.HTTP_SECUREPORT&&r[p]===It[Yn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),_===Yn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[p]===It[Yn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),_===Yn.DATABASES){u=r[p];continue}if(_?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!_&&(p.endsWith("_package")||p.endsWith("_port"))&&(_=p),_!==void 0){let h=_.split("_"),S=ys.LEGACY_CONFIG_PARAMS[p.toUpperCase()];S&&S.startsWith("customFunctions")&&l.hasIn(S.split("_"))&&(_=S,h=S.split("_"));let g=jy(_,r[p]);_==="rootPath"&&g?.endsWith("/")&&(g=g.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],g)}catch(R){rr.error(R)}}}u&&kU(l,u),Jy(l);let f=l.getIn(["rootPath"]),d=Wn.join(f,ys.HDB_CONFIG_FILE);if(n===!0&&v8(c,f),l.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${l.errors}`);jr.writeFileSync(d,String(l)),s&&(It=Mu(l.toJSON())),rr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(GU,"updateConfigValue");function v8(e,t){try{let r=Wn.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${ys.HDB_CONFIG_FILE}.bak`);jr.copySync(e,r),rr.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){rr.error(N8),rr.error(r)}}a(v8,"backupConfigFile");var U8=["databases"];function Mu(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network={...e.http,...e.operationsApi.network}),e?.operationsApi&&(e.operationsApi.tls={...e.tls,...e.operationsApi.tls}),SE=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])&&!U8.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;!Yn[l.toUpperCase()]&&ti[l]&&(s[ti[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Mu,"flattenConfig");function jy(e,t){if(e===Yn.CLUSTERING_NODENAME||e===Yn.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(S8(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Sr.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 Sr.autoCast(t)}a(jy,"castConfigValue");function x8(){let e=Sr.getPropsFilePath(),t=Xc(e);return wa(t).toJSON()}a(x8,"getConfiguration");async function B8(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return GU(void 0,void 0,s,!0),C8}catch(i){throw typeof i=="string"||i instanceof String?A8(i,i,R8.BAD_REQUEST,void 0,void 0,!0):i}}a(B8,"setConfiguration");function Qy(){let e=Sr.getPropsFilePath();try{jr.accessSync(e,jr.constants.F_OK|jr.constants.R_OK)}catch(n){if(!Sr.noBootFile())throw rr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Xc(e);return wa(t).toJSON()}a(Qy,"readConfigFile");function wa(e){return UU.parseDocument(jr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(wa,"parseYamlDoc");function H8(){let e=Qy(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Sr.isEmptyOrZeroLength(t)?[]:t;let r=MU(t);if(r)throw Lu.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Sr.isEmptyOrZeroLength(n)?[]:n;let s=MU(n);if(s)throw Lu.CONFIG_VALIDATION(s.message);if(!Sr.isEmptyOrZeroLength(n)&&!Sr.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Sr.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw Lu.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(H8,"getClusteringRoutes");function qU(e){let t=xU(e);It={};for(let r in ti){let n=t.get(r.toUpperCase());if(Sr.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=ti[r].toLowerCase();s===Yn.LOGGING_ROOT?It[s]=Wn.dirname(n):It[s]=n}return It}a(qU,"initOldConfig");function k8(e){let t=Qy();return T8.get(t,e.replaceAll("_","."))}a(k8,"getConfigFromFile");async function F8(e,t){let r=wa(Xc());if(r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);await jr.writeFile(Xc(),String(r))}a(F8,"addConfig");function G8(e){let t=Xc(Sr.getPropsFilePath()),r=wa(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Wn.join(n,ys.HDB_CONFIG_FILE);jr.writeFileSync(s,String(r))}a(G8,"deleteConfigFromFile");function q8(){return SE||(TE(),SE)}a(q8,"getConfigObj");function $8(){return It||TE(),It}a($8,"getFlatConfigObj")});var yn=I((CNe,Nr)=>{"use strict";var YU="username is required",WU="nothing to update, must supply active, role or password to update",zU="password cannot be an empty string",jU="If role is specified, it cannot be empty.",JU="active must be true or false";Nr.exports.addUser=X8;Nr.exports.alterUser=Z8;Nr.exports.dropUser=t5;Nr.exports.getSuperUser=o5;Nr.exports.userInfo=r5;Nr.exports.listUsers=RE;Nr.exports.listUsersExternal=n5;Nr.exports.setUsersWithRolesCache=Zc;Nr.exports.findAndValidateUser=ob;Nr.exports.getClusterUser=a5;Nr.exports.getUsersWithRolesCache=i5;Nr.exports.USERNAME_REQUIRED=YU;Nr.exports.ALTERUSER_NOTHING_TO_UPDATE=WU;Nr.exports.EMPTY_PASSWORD=zU;Nr.exports.EMPTY_ROLE=jU;Nr.exports.ACTIVE_BOOLEAN=JU;var QU=bn(),V8=jc(),R_=(mE(),P(hE)),XU=yU(),y_=Wr(),rb=Ao(),xi=ae(),ZU=require("validate.js"),nb=W(),{promisify:K8}=require("util"),sb=go(),Zy=(H(),P(G)),VU=St(),Y8=Rt(),W8=ce(),z8=ho(),{hdb_errors:j8,ClientError:ri}=pe(),{HTTP_STATUS_CODES:To,AUTHENTICATION_ERROR_MSGS:Xy,HDB_ERROR_MSGS:vu}=j8,{UserEventMsg:ib}=ni(),eb=require("lodash"),{server:AE}=(Kr(),P(Ru)),J8=W();AE.getUser=(e,t)=>ob(e,t,t!=null);AE.authenticateUser=(e,t)=>ob(e,t);var e0={username:!0,active:!0,role:!0,password:!0},KU=new Map,Q8=K8(V8.delete),tb=W8.get(Zy.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??R_.HASH_FUNCTION.SHA256,Bi;async function X8(e){let t=ZU.cleanAttributes(e,e0),r=XU.addUserValidation(t);if(r)throw new ri(r.message);let n=await y_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]});if(!n||n.length<1)throw new ri(vu.ROLE_NAME_NOT_FOUND(t.role),To.NOT_FOUND);if(n.length>1)throw new ri(vu.DUP_ROLES_FOUND(t.role),To.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=sb.encrypt(t.password)),t.password=await R_.hash(t.password,tb),t.hash_function=tb,t.role=n[0].id;let s=await QU.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(nb.debug(s),await Zc(),s.skipped_hashes.length===1)throw new ri(vu.USER_ALREADY_EXISTS(t.username),To.CONFLICT);return rb.signalUserChange(new ib(process.pid)),`${t.username} successfully added`}a(X8,"addUser");async function Z8(e){let t=ZU.cleanAttributes(e,e0);if(xi.isEmptyOrZeroLength(t.username))throw new Error(YU);if(xi.isEmptyOrZeroLength(t.password)&&xi.isEmptyOrZeroLength(t.role)&&xi.isEmptyOrZeroLength(t.active))throw new Error(WU);if(!xi.isEmpty(t.password)&&xi.isEmptyOrZeroLength(t.password.trim()))throw new Error(zU);if(!xi.isEmpty(t.active)&&!xi.isBoolean(t.active))throw new Error(JU);if(!xi.isEmpty(t.password)&&!xi.isEmptyOrZeroLength(t.password.trim())&&(e5(t.username)&&(t.hash=sb.encrypt(t.password)),t.password=await R_.hash(t.password,tb)),t.role==="")throw new Error(jU);if(t.role){let n=await y_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]});if(!n||n.length===0)throw new ri(vu.ALTER_USER_ROLE_NOT_FOUND(t.role),To.NOT_FOUND);if(n.length>1)throw new ri(vu.DUP_ROLES_FOUND(t.role),To.CONFLICT);t.role=n[0].id}let r=await QU.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await Zc(),rb.signalUserChange(new ib(process.pid)),r}a(Z8,"alterUser");function e5(e){let t=!1,r=Bi.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(e5,"isClusterUser");async function t5(e){let t=XU.dropUserValidation(e);if(t)throw new ri(t.message);if(Bi.get(e.username)===void 0)throw new ri(vu.USER_NOT_EXIST(e.username),To.NOT_FOUND);let r=await Q8({table:"hdb_user",schema:"system",hash_values:[e.username]});return nb.debug(r),await Zc(),rb.signalUserChange(new ib(process.pid)),`${e.username} successfully deleted`}a(t5,"dropUser");async function r5(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=eb.cloneDeep(e.hdb_user);let r=await y_.searchByHash({schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]});return t.role=r[0],delete t.password,delete t.refresh_token,delete t.hash,delete t.hash_function,t}a(r5,"userInfo");async function n5(){let e=await RE();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}a(n5,"listUsersExternal");async function RE(){let e=await y_.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=eb.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await y_.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=eb.cloneDeep(s),s.role=t[s.role],s5(s.role),n.set(s.username,s);return n}a(RE,"listUsers");function s5(e){if(!e){nb.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(z8)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}a(s5,"appendSystemTablesToRole");async function Zc(e=void 0){e?Bi=e:Bi=await RE()}a(Zc,"setUsersWithRolesCache");async function i5(){return Bi||await Zc(),Bi}a(i5,"getUsersWithRolesCache");async function ob(e,t,r=!0){Bi||await Zc();let n=Bi.get(e);if(!n){if(!r)return{username:e};throw new ri(Xy.GENERIC_AUTH_FAIL,To.UNAUTHORIZED)}if(n&&!n.active)throw new ri(Xy.USER_INACTIVE,To.UNAUTHORIZED);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(KU.get(t)===n.password)return s;{let i=R_.validate(n.password,t,n.hash_function||R_.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)KU.set(t,n.password);else throw new ri(Xy.GENERIC_AUTH_FAIL,To.UNAUTHORIZED)}}return s}a(ob,"findAndValidateUser");async function o5(){Bi||await Zc();for(let[,e]of Bi)if(e.role.role==="super_user")return e}a(o5,"getSuperUser");async function a5(){let e=await RE(),t=Y8.getConfigFromFile(Zy.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==Zy.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=sb.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+VU.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+VU.SERVER_SUFFIX.ADMIN,r}a(a5,"getClusterUser");var t0=[];AE.invalidateUser=function(e){for(let t of t0)try{t(e)}catch(r){J8.error("Error invalidating user",r)}};AE.onInvalidatedUser=function(e){t0.push(e)}});var O_=I((MNe,i0)=>{"use strict";var el=W(),zn=(H(),P(G)),c5=gv(),DNe=Rs(),LNe=So(),l5=yn(),{validateEvent:r0}=ni(),b_=Kn(),u5=require("process"),{resetDatabases:d5}=(De(),P(nt)),f5={[zn.ITC_EVENT_TYPES.SCHEMA]:_5,[zn.ITC_EVENT_TYPES.USER]:s0};async function _5(e){let t=r0(e);if(t){el.error(t);return}el.trace("ITC schemaHandler received schema event:",e),await c5(e.message),await p5(e.message)}a(_5,"schemaHandler");async function p5(e){try{b_.resetReadTxn(zn.SYSTEM_SCHEMA_NAME,zn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),b_.resetReadTxn(zn.SYSTEM_SCHEMA_NAME,zn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),b_.resetReadTxn(zn.SYSTEM_SCHEMA_NAME,zn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=d5();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){el.error(t)}}a(p5,"syncSchemaMetadata");var n0=[];async function s0(e){try{try{b_.resetReadTxn(zn.SYSTEM_SCHEMA_NAME,zn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),b_.resetReadTxn(zn.SYSTEM_SCHEMA_NAME,zn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){el.warn(r)}let t=r0(e);if(t){el.error(t);return}el.trace(`ITC userHandler ${zn.HDB_ITC_CLIENT_PREFIX}${u5.pid} received user event:`,e),await l5.setUsersWithRolesCache();for(let r of n0)r()}catch(t){el.error(t)}}a(s0,"userHandler");s0.addListener=function(e){n0.push(e)};i0.exports=f5});var ni=I((kNe,a0)=>{"use strict";var UNe=W(),ab=ae(),h5=(H(),P(G)),{ITC_ERRORS:N_}=Bn(),{parentPort:xNe,threadId:m5,isMainThread:E5,workerData:BNe}=require("worker_threads"),{onMessageFromWorkers:g5,broadcast:HNe,broadcastWithAcknowledgement:S5}=rt();a0.exports={sendItcEvent:T5,validateEvent:o0,SchemaEventMsg:A5,UserEventMsg:R5};var yE;g5(async(e,t)=>{yE=yE||O_(),o0(e),yE[e.type]&&await yE[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function T5(e){return!E5&&e.message&&(e.message.originator=m5),S5(e)}a(T5,"sendItcEvent");function o0(e){if(typeof e!="object")return N_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||ab.isEmpty(e.type))return N_.MISSING_TYPE;if(!e.hasOwnProperty("message")||ab.isEmpty(e.message))return N_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||ab.isEmpty(e.message.originator))return N_.MISSING_ORIGIN;if(h5.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return N_.INVALID_EVENT(e.type)}a(o0,"validateEvent");function A5(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(A5,"SchemaEventMsg");function R5(e){this.originator=e}a(R5,"UserEventMsg")});var Ao=I((qNe,d0)=>{"use strict";var c0=(H(),P(G)),GNe=ae(),bE=W(),l0=hv(),Uu,{sendItcEvent:u0}=ni();function y5(e){try{bE.info("signalSchemaChange called with message:",e),Uu=Uu||O_();let t=new l0(c0.ITC_EVENT_TYPES.SCHEMA,e);return Uu.schema(t),u0(t)}catch(t){bE.error(t)}}a(y5,"signalSchemaChange");function b5(e){try{bE.trace("signalUserChange called with message:",e),Uu=Uu||O_();let t=new l0(c0.ITC_EVENT_TYPES.USER,e);return Uu.user(t),u0(t)}catch(t){bE.error(t)}}a(b5,"signalUserChange");d0.exports={signalSchemaChange:y5,signalUserChange:b5}});var OE=I((VNe,_0)=>{"use strict";var f0=ae(),O5=(H(),P(G)),N5=W(),w5=oE(),I5=iE(),C5=Ao(),{SchemaEventMsg:P5}=ni(),D5="already exists in";_0.exports=L5;async function L5(e,t,r){if(f0.isEmptyOrZeroLength(r))return r;let n=[];f0.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 M5(e,t.schema,t.name,i)})),s}a(L5,"lmdbCheckForNewAttributes");async function M5(e,t,r,n){let s=new I5(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await v5(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(D5))N5.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(M5,"createNewAttribute");async function v5(e){let t;return t=await w5(e),C5.signalSchemaChange(new P5(process.pid,O5.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(v5,"createAttribute")});var xu=I((YNe,p0)=>{"use strict";var cb=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}};p0.exports=cb});var m0=I((zNe,h0)=>{"use strict";var U5=xu(),x5=(H(),P(G)).OPERATIONS_ENUM,lb=class extends U5{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(x5.INSERT,r,n,s,i),this.records=t}};h0.exports=lb});var g0=I((JNe,E0)=>{"use strict";var B5=xu(),H5=(H(),P(G)).OPERATIONS_ENUM,ub=class extends B5{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(H5.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};E0.exports=ub});var T0=I((XNe,S0)=>{"use strict";var k5=xu(),F5=(H(),P(G)).OPERATIONS_ENUM,db=class extends k5{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(F5.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};S0.exports=db});var R0=I((ewe,A0)=>{"use strict";var G5=xu(),q5=(H(),P(G)).OPERATIONS_ENUM,fb=class extends G5{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(q5.DELETE,n,s,t,i),this.original_records=r}};A0.exports=fb});var w_=I((nwe,N0)=>{"use strict";var rwe=require("path"),y0=ft(),$5=m0(),V5=g0(),K5=T0(),Y5=R0(),Bu=xt(),b0=ae(),{CONFIG_PARAMS:W5}=(H(),P(G)),O0=ce();O0.initSync();var NE=(H(),P(G)).OPERATIONS_ENUM,{getTransactionAuditStorePath:z5}=Et();N0.exports=j5;async function j5(e,t){if(O0.get(W5.LOGGING_AUDITLOG)===!1)return;let r=z5(e.schema,e.table),n=await y0.openEnvironment(r,e.table,!0),s=J5(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){y0.initializeDBIs(n,Bu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Bu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Bu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Bu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),b0.isEmpty(s.user_name)||n.dbis[Bu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Bu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(j5,"writeTransaction");function J5(e,t){let r=b0.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===NE.INSERT)return new $5(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===NE.UPDATE)return new V5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===NE.UPSERT)return new K5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===NE.DELETE)return new Y5(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(J5,"createTransactionObject")});var _b=I((owe,w0)=>{"use strict";var Q5=u_(),iwe=xf(),I_=(H(),P(G)),X5=Bf(),Z5=$c().insertRecords,e9=ft(),t9=W(),r9=OE(),{getSchemaPath:n9}=Et(),s9=w_();w0.exports=i9;async function i9(e){try{let{schema_table:t,attributes:r}=Q5(e);X5(e,r,t.hash_attribute),e.schema!==I_.SYSTEM_SCHEMA_NAME&&(r.includes(I_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(I_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(I_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(I_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await r9(e.hdb_auth_header,t,r),s=n9(e.schema,e.table),i=await e9.openEnvironment(s,e.table),o=await Z5(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await s9(e,o)}catch(c){t9.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(i9,"lmdbCreateRecords")});var P0=I((cwe,C0)=>{"use strict";var I0=(H(),P(G)),o9=_b(),a9=xf(),c9=require("fs-extra"),{getSchemaPath:l9}=Et();C0.exports=u9;async function u9(e){let t=[{name:e.schema,createddate:Date.now()}],r=new a9(I0.SYSTEM_SCHEMA_NAME,I0.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await o9(r),await c9.mkdirp(l9(e.schema))}a(u9,"lmdbCreateSchema")});var L0=I((uwe,D0)=>{"use strict";var pb=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}};D0.exports=pb});var x0=I((hwe,U0)=>{"use strict";var M0=ft(),hb=pn(),mb=Bn().LMDB_ERRORS_ENUM,d9=xt(),v0=W(),fwe=ae(),f9=require("lmdb"),_9=L0(),p9=(H(),P(G)),{OVERFLOW_MARKER:_we,MAX_SEARCH_KEY_LENGTH:pwe}=d9,h9=p9.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function m9(e,t,r,n){if(hb.validateEnv(e),t===void 0)throw new Error(mb.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(mb.IDS_REQUIRED):new Error(mb.IDS_MUST_BE_ITERABLE);try{let s=M0.listDBIs(e);M0.initializeDBIs(e,t,s);let i=new _9,o,c=[],l=[];for(let p=0,_=r.length;p<_;p++)try{o=r[p];let h=e.dbis[t].get(o);if(!h||n&&h[h9]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,f9.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let g=0;g<s.length;g++){let R=s[g];if(!h.hasOwnProperty(R)||R===t)continue;let E=e.dbis[R],A=h[R];if(A!=null)try{let N=hb.getIndexedValues(A);if(N)for(let v=0,F=N.length;v<F;v++)E.remove(N[v],o)}catch{v0.warn(`cannot delete from attribute: ${R}, ${A}:${o}`)}}});c.push(S),l.push(o),i.original_records.push(h)}catch(h){v0.warn(h),i.skipped.push(o)}let u=[],f=await Promise.all(c);for(let p=0,_=f.length;p<_;p++)f[p]===!0?i.deleted.push(l[p]):(i.skipped.push(l[p]),u.push(p));let d=0;for(let p=0;p<u.length;p++){let _=u[p];i.original_records.splice(_-d,1),d++}return i.txn_time=hb.getNextMonotonicTime(),i}catch(s){throw s}}a(m9,"deleteRecords");U0.exports={deleteRecords:m9}});var C_=I((Ewe,H0)=>{"use strict";var Hu=ae(),E9=x0(),g9=ft(),{getSchemaPath:S9}=Et(),T9=w_(),A9=W();H0.exports=R9;async function R9(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Hu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Hu.isEmptyOrZeroLength(e.hash_values)&&!Hu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Hu.isEmpty(l)||e.hash_values.push(l)}}if(Hu.isEmptyOrZeroLength(e.hash_values))return B0([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Hu.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=S9(e.schema,e.table),i=await g9.openEnvironment(s,e.table),o=await E9.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await T9(e,o)}catch(c){A9.error(`unable to write transaction due to ${c.message}`)}return B0(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(R9,"lmdbDeleteRecords");function B0(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(B0,"createDeleteResponse")});var gb=I((Twe,k0)=>{"use strict";var y9=(H(),P(G)),Swe=pn();function Eb(e,t){let r=Object.create(null);if(t.length===1&&y9.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(Eb,"parseRow");function b9(e,t,r,n){let s=Eb(r,e);n.push(s)}a(b9,"searchAll");function O9(e,t,r,n){let s=Eb(r,e);n[t]=s}a(O9,"searchAllToMap");function N9(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(N9,"iterateDBI");function tl(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(tl,"pushResults");function w9(e,t,r,n,s,i){t.toString().endsWith(e)&&tl(t,r,n,s,i)}a(w9,"endsWith");function I9(e,t,r,n,s,i){t.toString().includes(e)&&tl(t,r,n,s,i)}a(I9,"contains");function C9(e,t,r,n,s,i){t>e&&tl(t,r,n,s,i)}a(C9,"greaterThanCompare");function P9(e,t,r,n,s,i){t>=e&&tl(t,r,n,s,i)}a(P9,"greaterThanEqualCompare");function D9(e,t,r,n,s,i){t<e&&tl(t,r,n,s,i)}a(D9,"lessThanCompare");function L9(e,t,r,n,s,i){t<=e&&tl(t,r,n,s,i)}a(L9,"lessThanEqualCompare");k0.exports={parseRow:Eb,searchAll:b9,searchAllToMap:O9,iterateDBI:N9,endsWith:w9,contains:I9,greaterThanCompare:C9,greaterThanEqualCompare:P9,lessThanCompare:D9,lessThanEqualCompare:L9,pushResults:tl}});var ku=I((Owe,Y0)=>{"use strict";var Ia=ft(),Rwe=W(),jn=pn(),wE=xt(),Wt=Bn().LMDB_ERRORS_ENUM,ywe=ae(),M9=(H(),P(G)),IE=gb(),{parseRow:v9}=IE,bwe=require("lmdb"),{OVERFLOW_MARKER:F0,MAX_SEARCH_KEY_LENGTH:U9}=wE;function G0(e,t,r,n=!1,s=void 0,i=void 0){return rl(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(G0,"iterateFullIndex");function P_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return rl(e,t,r,(f,d,p,_)=>{let E={transaction:f,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return _===r?(E.values=!1,d.getRange(E).map(A=>({value:A}))):d.getRange(E)})}a(P_,"iterateRangeBetween");function rl(e,t,r,n){let s=e.database||e,i=Ia.openDBI(s,r);i[wE.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&Ia.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(rl,"setupTransaction");function q0(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(F0)){if(!s)if(r)s=Ia.openDBI(e,r);else{let l=Ia.listDBIs(e);for(let u=0,f=l.length;u<f&&(s=Ia.openDBI(e,l[u]),!s[wE.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(q0,"getOverflowCheck");function x9(e,t,r,n=!1,s=void 0,i=void 0){if(jn.validateEnv(e),t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);return rl(e,t,t,(o,c,l)=>(CE(r),r=D_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>v9(u.value,r))))}a(x9,"searchAll");function B9(e,t,r,n=!1,s=void 0,i=void 0){if(jn.validateEnv(e),t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);CE(r),r=D_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of G0(e,t,t,n,s,i))o.set(c,IE.parseRow(l,r));return o}a(B9,"searchAllToMap");function H9(e,t,r=!1,n=void 0,s=void 0){if(jn.validateEnv(e),t===void 0)throw new Error(Wt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=G0(e,void 0,t,r,n,s),c=o.transaction,l=q0(c.database,c,void 0,t);for(let{key:u,value:f}of o){let d=l(u,f);i[d]===void 0&&(i[d]=[]),i[d].push(f)}return i}a(H9,"iterateDBI");function k9(e,t){if(jn.validateEnv(e),t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);return Ia.statDBI(e,t).entryCount}a(k9,"countAll");function F9(e,t,r,n,s=!1,i=void 0,o=void 0){return Ca(e,r,n),rl(e,t,r,(c,l,u,f)=>(n=jn.convertKeyValueToWrite(n),f===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(F9,"equals");function G9(e,t,r){return Ca(e,t,r),Ia.openDBI(e,t).getValuesCount(r)}a(G9,"count");function q9(e,t,r,n,s=!1,i=void 0,o=void 0){return Ca(e,r,n),rl(e,null,r,(c,l)=>{n=jn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let f;if(s===!0){let d;for(let p of l.getKeys({transaction:c,start:n}))if(!p.startsWith(n)){d=p;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),f=l.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(p=>{let{key:_}=p;if(_!==d){if(_.toString().startsWith(n))return p;if(u===!0)return f.DONE}}),f.filter(p=>p)}else return f=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(u===!0)return f.DONE}),u?f:f.filter(d=>d)})}a(q9,"startsWith");function $9(e,t,r,n,s=!1,i=void 0,o=void 0){return $0(e,t,r,n,s,i,o,!0)}a($9,"endsWith");function $0(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Ca(e,r,n),rl(e,null,r,(l,u,f,d)=>{let p=q0(f,l,d,r);return o=Number.isInteger(o)?o:0,u.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(_=>{let h=_.toString();return h.endsWith(F0)?u.getValues(_,{transaction:l}).map(S=>{let g=p(_,S);if(c?g.endsWith(n):g.includes(n))return{key:g,value:S}}).filter(S=>S):(c?h.endsWith(n):h.includes(n))?u[wE.DBI_DEFINITION_NAME].is_hash_attribute?{key:_,value:_}:u.getValues(_,{transaction:l}).map(S=>({key:_,value:S})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a($0,"contains");function V9(e,t,r,n,s=!1,i=void 0,o=void 0){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),P_(e,t,r,n,l,s,i,o,!0,!1)}a(V9,"greaterThan");function K9(e,t,r,n,s=!1,i=void 0,o=void 0){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),P_(e,t,r,n,l,s,i,o,!1,!1)}a(K9,"greaterThanEqual");function Y9(e,t,r,n,s=!1,i=void 0,o=void 0){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),P_(e,t,r,l,n,s,i,o,!1,!0)}a(Y9,"lessThan");function W9(e,t,r,n,s=!1,i=void 0,o=void 0){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),P_(e,t,r,l,n,s,i,o,!1,!1)}a(W9,"lessThanEqual");function z9(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(jn.validateEnv(e),r===void 0)throw new Error(Wt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Wt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Wt.END_VALUE_REQUIRED);if(n=jn.convertKeyValueToWrite(n),s=jn.convertKeyValueToWrite(s),n>s)throw new Error(Wt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return P_(e,t,r,n,s,i,o,c)}a(z9,"between");function j9(e,t,r,n){jn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);if(CE(r),r=D_(s,r),n===void 0)throw new Error(Wt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=IE.parseRow(c,r)),o}a(j9,"searchByHash");function J9(e,t,r){jn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Wt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(J9,"checkHashExists");function Q9(e,t,r,n,s=[]){return K0(e,t,r,n,s),V0(e,t,r,n,s).map(i=>i[1])}a(Q9,"batchSearchByHash");function X9(e,t,r,n,s=[]){K0(e,t,r,n,s);let i=new Map;for(let[o,c]of V0(e,t,r,n,s))i.set(o,c);return i}a(X9,"batchSearchByHashToMap");function V0(e,t,r,n,s=[]){return rl(e,t,t,(i,o,c)=>{r=D_(c,r);let l=r.length<3;return n.map(u=>{let f=c.dbis[t].get(u,{transaction:i,lazy:l});if(f)return[u,IE.parseRow(f,r)];s.push(u)}).filter(u=>u)})}a(V0,"batchHashSearch");function K0(e,t,r,n,s){if(jn.validateEnv(e),t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);if(CE(r),n==null)throw new Error(Wt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Wt.IDS_MUST_BE_ITERABLE)}a(K0,"initializeBatchSearchByHash");function CE(e){if(!Array.isArray(e))throw e===void 0?new Error(Wt.FETCH_ATTRIBUTES_REQUIRED):new Error(Wt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(CE,"validateFetchAttributes");function Ca(e,t,r){if(jn.validateEnv(e),t===void 0)throw new Error(Wt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Wt.SEARCH_VALUE_REQUIRED);if(r?.length>U9)throw new Error(Wt.SEARCH_VALUE_TOO_LARGE)}a(Ca,"validateComparisonFunctions");function D_(e,t){return t.length===1&&M9.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=Ia.listDBIs(e)),t}a(D_,"setGetWholeRowAttributes");Y0.exports={searchAll:x9,searchAllToMap:B9,count:G9,countAll:k9,equals:F9,startsWith:q9,endsWith:$9,contains:$0,searchByHash:j9,setGetWholeRowAttributes:D_,batchSearchByHash:Q9,batchSearchByHashToMap:X9,checkHashExists:J9,iterateDBI:H9,greaterThan:V9,greaterThanEqual:K9,lessThan:Y9,lessThanEqual:W9,between:z9}});var Fu=I((wwe,Q0)=>{var W0=require("lodash"),z0=it(),ke=require("joi"),Z9=ae(),{hdb_schema_table:L_,checkValidTable:j0,hdb_table:J0,hdb_database:PE}=Li(),{handleHDBError:e7,hdb_errors:t7}=pe(),{getDatabases:r7}=(De(),P(nt)),{HTTP_STATUS_CODES:n7}=t7,s7=ke.object({database:PE,schema:PE,table:J0,search_attribute:L_,search_value:ke.any().required(),get_attributes:ke.array().min(1).items(ke.alternatives(L_,ke.object())).optional(),desc:ke.bool(),limit:ke.number().integer().min(1),offset:ke.number().integer().min(0)}),i7=ke.object({database:PE,schema:PE,table:J0,operator:ke.string().valid("and","or").default("and").lowercase(),offset:ke.number().integer().min(0),limit:ke.number().integer().min(1),get_attributes:ke.array().min(1).items(ke.alternatives(L_,ke.object())).optional(),sort:ke.object({attribute:ke.alternatives(L_,ke.array().min(1)),descending:ke.bool().optional()}).optional(),conditions:ke.array().min(1).items(ke.alternatives(ke.object({operator:ke.string().valid("and","or").default("and").lowercase(),conditions:ke.array()}),ke.object({search_attribute:ke.alternatives(L_,ke.array().min(1)),search_type:ke.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:ke.when("search_type",{switch:[{is:"equals",then:ke.any()},{is:"between",then:ke.array().items(ke.alternatives([ke.string(),ke.number()])).length(2)}],otherwise:ke.alternatives(ke.string(),ke.number())}).required()}))).required()});Q0.exports=function(e,t){let r=null;switch(t){case"value":r=z0.validateBySchema(e,s7);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(j0("database",e.schema)),i(j0("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=z0.validateBySchema(e,i7);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=Z9.checkGlobalSchemaTable(e.schema,e.table);if(s)return e7(new Error,s,n7.NOT_FOUND);let o=r7()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(f=>{for(let d=0,p=f.conditions.length;d<p;d++){let _=f.conditions[d];_.conditions?l(_):c.push(_.search_attribute)}},"addConditions");t==="conditions"&&l(e);let u=W0.filter(c,f=>f!=="*"&&!f.startsWith?.("$")&&f.attribute!=="*"&&!Array.isArray(f)&&!f.name&&!W0.some(o,d=>d===f||d.attribute===f||d.attribute===f.attribute));if(u&&u.length>0){let f=u.join(", ");return f=f.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${f}'`)}}return r}});var Sb=I((Cwe,X0)=>{"use strict";var o7=ft(),a7=Fu(),{getSchemaPath:c7}=Et();X0.exports=l7;function l7(e){let t=a7(e,"hashes");if(t)throw t;let r=c7(e.schema,e.table);return o7.openEnvironment(r,e.table)}a(l7,"initialize")});var Tb=I((Dwe,Z0)=>{"use strict";var u7=ku(),d7=Sb();Z0.exports=f7;async function f7(e){let t=await d7(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return u7.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(f7,"lmdbGetDataByHash")});var Gu=I((Mwe,ex)=>{"use strict";var Ab=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};ex.exports=Ab});var rx=I((xwe,tx)=>{"use strict";var Uwe=Gu(),_7=ku(),p7=Sb();tx.exports=h7;async function h7(e){let t=await p7(e),r=global.hdb_schema[e.schema][e.table];return _7.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(h7,"lmdbSearchByHash")});var si=I((Hwe,nx)=>{"use strict";var Rb=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,u=void 0,f=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=u,this.offset=f}};nx.exports=Rb});var DE=I((Fwe,lx)=>{"use strict";var Jr=ku(),m7=ft(),E7=ae(),Fe=xt(),nl=(H(),P(G)),g7=ho(),sx=Bn().LMDB_ERRORS_ENUM,{getSchemaPath:S7}=Et(),Ro=nl.SEARCH_WILDCARDS;async function T7(e,t,r){let n;e.schema===nl.SYSTEM_SCHEMA_NAME?n=g7[e.table]:n=global.hdb_schema[e.schema][e.table];let s=cx(e,n.hash_attribute,r,t);return ox(e,s,n.hash_attribute,r)}a(T7,"prepSearch");async function ox(e,t,r,n){let s=S7(e.schema,e.table),i=await m7.openEnvironment(s,e.table),o=ax(i,e,t,r),c=o.transaction||i;if([Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,Fe.SEARCH_TYPES.SEARCH_ALL,Fe.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(A7(e,r)===!1){let f=e.search_attribute;if(f===r)return n?ix(o,()=>!0):o.map(p=>({[r]:p.key}));let d=a(p=>({[r]:p.value,[f]:p.key}),"toObject");return n?ix(o,d):o.map(d)}let u=e.search_attribute===r?o.map(f=>f.key):o.map(f=>f.value);return n===!0?Jr.batchSearchByHashToMap(c,r,e.get_attributes,u):Jr.batchSearchByHash(c,r,e.get_attributes,u)}a(ox,"executeSearch");function ax(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 Fe.SEARCH_TYPES.EQUALS:s=Jr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.CONTAINS:s=Jr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.ENDS_WITH:case Fe.SEARCH_TYPES._ENDS_WITH:s=Jr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.STARTS_WITH:case Fe.SEARCH_TYPES._STARTS_WITH:s=Jr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Jr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Jr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case Fe.SEARCH_TYPES.SEARCH_ALL:return Jr.searchAll(e,n,t.get_attributes,o,c,l);case Fe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Jr.searchAllToMap(e,n,t.get_attributes,o,c,l);case Fe.SEARCH_TYPES.BETWEEN:s=Jr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case Fe.SEARCH_TYPES.GREATER_THAN:case Fe.SEARCH_TYPES._GREATER_THAN:s=Jr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.GREATER_THAN_EQUAL:case Fe.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Jr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.LESS_THAN:case Fe.SEARCH_TYPES._LESS_THAN:s=Jr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.LESS_THAN_EQUAL:case Fe.SEARCH_TYPES._LESS_THAN_EQUAL:s=Jr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(ax,"searchByType");function ix(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(ix,"createMapFromIterable");function A7(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(A7,"checkToFetchMore");function cx(e,t,r,n){if(E7.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),o=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),Ro.indexOf(s)>-1)return r===!0?Fe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:Fe.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(Ro[0])<0&&s.indexOf(Ro[1])<0)return c===!0?r===!0?Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:Fe.SEARCH_TYPES.EQUALS;if(Ro.indexOf(i)>=0&&Ro.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),Fe.SEARCH_TYPES.CONTAINS;if(Ro.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),Fe.SEARCH_TYPES.ENDS_WITH;if(Ro.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),Fe.SEARCH_TYPES.STARTS_WITH;if(s.includes(Ro[0])||s.includes(Ro[1]))return Fe.SEARCH_TYPES.EQUALS;throw new Error(sx.UNKNOWN_SEARCH_TYPE)}else switch(n){case nl.VALUE_SEARCH_COMPARATORS.BETWEEN:return Fe.SEARCH_TYPES.BETWEEN;case nl.VALUE_SEARCH_COMPARATORS.GREATER:return Fe.SEARCH_TYPES.GREATER_THAN;case nl.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return Fe.SEARCH_TYPES.GREATER_THAN_EQUAL;case nl.VALUE_SEARCH_COMPARATORS.LESS:return Fe.SEARCH_TYPES.LESS_THAN;case nl.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return Fe.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(sx.UNKNOWN_SEARCH_TYPE)}}a(cx,"createSearchTypeFromSearchObject");lx.exports={executeSearch:ox,createSearchTypeFromSearchObject:cx,prepSearch:T7,searchByType:ax}});var dx=I(($we,ux)=>{"use strict";var qwe=si(),R7=Fu(),y7=ae(),b7=(H(),P(G)),O7=DE();ux.exports=N7;function N7(e,t){if(!y7.isEmpty(t)&&b7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=R7(e,"value");if(n)throw n;return O7.prepSearch(e,t,!0)}a(N7,"lmdbGetDataByValue")});var M_=I((Ywe,fx)=>{"use strict";var Kwe=si(),w7=Fu(),I7=ae(),C7=(H(),P(G)),P7=DE();fx.exports=D7;async function D7(e,t){if(!I7.isEmpty(t)&&C7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=w7(e,"value");if(n)throw n;return P7.prepSearch(e,t,!1)}a(D7,"lmdbSearchByValue")});var px=I((jwe,_x)=>{"use strict";var zwe=xt(),yb=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}},bb=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Ob=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};_x.exports={SearchByConditionsObject:yb,SearchCondition:bb,SortAttribute:Ob}});var Sx=I((Zwe,gx)=>{"use strict";var Qwe=px().SearchByConditionsObject,L7=si(),M7=Fu(),Nb=ku(),LE=xt(),{Resource:Xwe}=(ga(),P(SR)),Ex=DE(),v7=gb(),U7=require("lodash"),{getSchemaPath:x7}=Et(),hx=ft(),{handleHDBError:B7,hdb_errors:H7}=pe(),{HTTP_STATUS_CODES:k7}=H7,F7=1e8;gx.exports=G7;async function G7(e){let t=M7(e,"conditions");if(t)throw B7(t,t.message,k7.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=x7(e.schema,e.table),n=await hx.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)hx.openDBI(n,u.search_attribute);let i=U7.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let f=u.search_type;f===LE.SEARCH_TYPES.EQUALS?u.estimated_count=Nb.count(n,u.search_attribute,u.search_value):f===LE.SEARCH_TYPES.CONTAINS||f===LE.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=F7}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await mx(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let u=n.dbis[s.hash_attribute],f=i.slice(1).map(Ex.filterByType),d=f.length,p=Nb.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(_=>u.get(_,{transaction:o,lazy:!0})),d>0&&(l=l.filter(_=>{for(let h=0;h<d;h++)if(!f[h](_))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(_=>v7.parseRow(_,p))}else{for(let d=1;d<i.length;d++){let p=i[d],_=await mx(o,e,p,s.hash_attribute);c=c.concat(_)}let u=new Set,f=e.offset||0;c=c.filter(d=>u.has(d)?!1:(u.add(d),!0)).slice(f,e.limit&&e.limit+f),l=Nb.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(G7,"lmdbSearchByConditions");async function mx(e,t,r,n){let s=new L7(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===LE.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,Ex.searchByType(e,s,i,n).map(o=>o.value)}a(mx,"executeConditionSearch")});var v_=I((tIe,Tx)=>{"use strict";var q7=(H(),P(G)).OPERATIONS_ENUM,wb=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=q7.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};Tx.exports=wb});var Ib=I((nIe,Ix)=>{"use strict";var bx=si(),Ox=v_(),Nx=M_(),wx=C_(),On=(H(),P(G)),Ax=ae(),Rx=ft(),{getTransactionAuditStorePath:$7,getSchemaPath:V7}=Et(),yx=W();Ix.exports=K7;async function K7(e){try{if(Ax.isEmpty(global.hdb_schema[e.schema])||Ax.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await Y7(e),await W7(e);let t=V7(e.schema,e.table);try{await Rx.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")yx.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=$7(e.schema,e.table);await Rx.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")yx.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(K7,"lmdbDropTable");async function Y7(e){let t=new bx(On.SYSTEM_SCHEMA_NAME,On.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,On.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[On.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await Nx(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 Ox(On.SYSTEM_SCHEMA_NAME,On.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await wx(s)}a(Y7,"deleteAttributesFromSystem");async function W7(e){let t=new bx(On.SYSTEM_SCHEMA_NAME,On.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,On.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[On.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,On.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,On.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await Nx(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 Ox(On.SYSTEM_SCHEMA_NAME,On.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await wx(s)}catch(i){throw i}}a(W7,"dropTableFromSystem")});var Px=I((iIe,Cx)=>{"use strict";var z7=require("fs-extra"),j7=si(),J7=Gu(),Q7=v_(),X7=Ib(),Z7=C_(),eee=Tb(),tee=M_(),yo=(H(),P(G)),{getSchemaPath:ree}=Et(),{handleHDBError:nee,hdb_errors:see}=pe(),{HDB_ERROR_MSGS:iee,HTTP_STATUS_CODES:oee}=see;Cx.exports=aee;async function aee(e){let t;try{t=await cee(e.schema);let r=new j7(yo.SYSTEM_SCHEMA_NAME,yo.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,yo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[yo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await tee(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await X7(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new Q7(yo.SYSTEM_SCHEMA_NAME,yo.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await Z7(s);let i=ree(t);await z7.remove(i)}catch(r){throw r}}a(aee,"lmdbDropSchema");async function cee(e){let t=new J7(yo.SYSTEM_SCHEMA_NAME,yo.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[yo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await eee(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw nee(new Error,iee.SCHEMA_NOT_FOUND(e),oee.NOT_FOUND,void 0,void 0,!0);return n}a(cee,"validateDropSchema")});var U_=I((aIe,Dx)=>{"use strict";var Cb=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Dx.exports=Cb});var Db=I((uIe,Lx)=>{"use strict";var lee=require("fs-extra"),ME=ft(),{getTransactionAuditStorePath:uee}=Et(),Pb=xt(),lIe=U_();Lx.exports=dee;async function dee(e){let t;try{let r=uee(e.schema,e.table);await lee.mkdirp(r),t=await ME.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{ME.createDBI(t,Pb.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),ME.createDBI(t,Pb.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),ME.createDBI(t,Pb.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(dee,"createTransactionsAuditEnvironment")});var Ux=I((_Ie,vx)=>{"use strict";var Lb=(H(),P(G)),Mx=ft(),fee=$c(),{getSystemSchemaPath:_ee,getSchemaPath:pee}=Et(),fIe=ho(),hee=oE(),Mb=iE(),mee=W(),Eee=Db();vx.exports=gee;async function gee(e,t){let r=pee(t.schema,t.table),n=new Mb(t.schema,t.table,Lb.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Mb(t.schema,t.table,Lb.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Mb(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await Mx.createEnvironment(r,t.table),e!==void 0){let o=await Mx.openEnvironment(_ee(),Lb.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await fee.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_table_attributes,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await vb(n),await vb(s),await vb(i)}await Eee(t)}catch(o){throw o}}a(gee,"lmdbCreateTable");async function vb(e){try{await hee(e)}catch(t){mee.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(vb,"createAttribute")});var Bx=I((hIe,xx)=>{"use strict";var See=u_(),Tee=Bf(),Aee=OE(),x_=(H(),P(G)),Ree=$c().updateRecords,yee=ft(),{getSchemaPath:bee}=Et(),Oee=w_(),Nee=W();xx.exports=wee;async function wee(e){try{let{schema_table:t,attributes:r}=See(e);Tee(e,r,t.hash_attribute),e.schema!==x_.SYSTEM_SCHEMA_NAME&&(r.includes(x_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(x_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(x_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(x_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await Aee(e.hdb_auth_header,t,r),s=bee(e.schema,e.table),i=await yee.openEnvironment(s,e.table),o=await Ree(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await Oee(e,o)}catch(c){Nee.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(wee,"lmdbUpdateRecords")});var kx=I((EIe,Hx)=>{"use strict";var Iee=(H(),P(G)).OPERATIONS_ENUM,Ub=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Iee.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Hx.exports=Ub});var Gx=I((TIe,Fx)=>{"use strict";var SIe=kx(),Cee=u_(),Pee=Bf(),Dee=OE(),B_=(H(),P(G)),Lee=$c().upsertRecords,Mee=ft(),{getSchemaPath:vee}=Et(),Uee=w_(),xee=W(),{handleHDBError:Bee,hdb_errors:Hee}=pe();Fx.exports=kee;async function kee(e){let t;try{t=Cee(e)}catch(l){throw Bee(l,l.message,Hee.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;Pee(e,n,r.hash_attribute),e.schema!==B_.SYSTEM_SCHEMA_NAME&&(n.includes(B_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(B_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(B_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(B_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await Dee(e.hdb_auth_header,r,n),i=vee(e.schema,e.table),o=await Mee.openEnvironment(i,e.table),c=await Lee(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await Uee(e,c)}catch(l){xee.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(kee,"lmdbUpsertRecords")});var $x=I((RIe,qx)=>{"use strict";var xb=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};qx.exports=xb});var Kx=I((bIe,Vx)=>{"use strict";var Bb=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}};Vx.exports=Bb});var zx=I((wIe,Wx)=>{"use strict";var Hb=ft(),{getTransactionAuditStorePath:Fee}=Et(),NIe=$x(),H_=xt(),Gee=ae(),Yx=Kx(),qee=require("util").promisify,$ee=qee(setTimeout),Vee=1e4,Kee=100;Wx.exports=Yee;async function Yee(e){let t=Fee(e.schema,e.table),r=await Hb.openEnvironment(t,e.table,!0),n=Hb.listDBIs(r);Hb.initializeDBIs(r,H_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new Yx;do s=await Wee(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 $ee(Kee);while(s.transactions_deleted>0);return i}a(Yee,"deleteAuditLogsBefore");async function Wee(e,t){let r=new Yx;try{let n=e.dbis[H_.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[H_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];Gee.isEmpty(c)||(s=e.dbis[H_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[H_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>Vee)break}return await s,r}catch(n){throw n}}a(Wee,"deleteTransactions")});var Jx=I((CIe,jx)=>{"use strict";var kb=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};jx.exports=kb});var Xx=I((LIe,Qx)=>{"use strict";var zee=si(),jee=v_(),DIe=Jx(),Hi=(H(),P(G)),Jee=ae(),Fb=ft(),Qee=ho(),Xee=M_(),Zee=C_(),{getSchemaPath:ete}=Et();Qx.exports=tte;async function tte(e,t=!0){let r;e.schema===Hi.SYSTEM_SCHEMA_NAME?r=Qee[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await nte(e),s=ete(e.schema,e.table),i=await Fb.openEnvironment(s,e.table);return t===!0&&await rte(e,i,r.hash_attribute),Fb.dropDBI(i,e.attribute),n}a(tte,"lmdbDropAttribute");async function rte(e,t,r){let n=Fb.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let u={};for(let f in c)f!==i&&(u[f]=c[f]);s=t.dbis[r].put(o,u,l)}await s}a(rte,"removeAttributeFromAllObjects");async function nte(e){let t=new zee(Hi.SYSTEM_SCHEMA_NAME,Hi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Hi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Hi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Hi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await Xee(t)).filter(o=>o[Hi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(Jee.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[Hi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new jee(Hi.SYSTEM_SCHEMA_NAME,Hi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return Zee(i)}a(nte,"dropAttributeFromSystem")});var sB=I((UIe,nB)=>{"use strict";var Gb=ft(),qu=xt(),vIe=pn(),qb=(H(),P(G)),Zx=ae(),{getTransactionAuditStorePath:ste}=Et(),ite=ku(),vE=xu(),ote=W();nB.exports=ate;async function ate(e){let t=ste(e.schema,e.table),r=await Gb.openEnvironment(t,e.table,!0),n=Gb.listDBIs(r);Gb.initializeDBIs(r,qu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case qb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return eB(r,e.search_values);case qb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,lte(r,e.search_values,s);case qb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return cte(r,e.search_values);default:return eB(r)}}a(ate,"readAuditLog");function eB(e,t=[0,Date.now()]){Zx.isEmpty(t[0])&&(t[0]=0),Zx.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[qu.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 vE,s))}a(eB,"searchTransactionsByTimestamp");function cte(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[qu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,rB(e,i))}return Object.fromEntries(r)}a(cte,"searchTransactionsByUsername");function lte(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],f=ite.equals(e,qu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,qu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:d}of f){let p=Number(d);n.has(p)?n.get(p).push(u.toString()):n.set(p,[u.toString()])}}let s=Array.from(n.keys()),i=rB(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,f=n.get(u);tB(l,"records",r,f,o),tB(l,"original_records",r,f,o)}return Object.fromEntries(o)}a(lte,"searchTransactionsByHashValues");function tB(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let u=s.get(l),f=u[u.length-1];if(f.timestamp===i)f[t]=[c];else{let d=new vE(e.operation,e.user_name,i,void 0);d[t]=[c],u.push(d)}}else{let u=new vE(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}a(tB,"loopRecords");function rB(e,t){let r=[];try{let n=e.dbis[qu.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 vE,i);r.push(o)}}catch(i){ote.warn(i)}return r}catch(n){throw n}}a(rB,"batchSearchTransactions")});var oB=I((kIe,iB)=>{"use strict";var{getSchemaPath:BIe}=Et(),HIe=ft(),{database:ute}=(De(),P(nt));iB.exports={writeTransaction:dte};async function dte(e,t,r){return ute({database:e,table:t}).transaction(r)}a(dte,"writeTransaction")});var uB=I((GIe,lB)=>{"use strict";var{getSchemaPath:aB}=Et(),cB=ft();lB.exports={flush:fte,resetReadTxn:_te};async function fte(e,t){return(await cB.openEnvironment(aB(e,t),t.toString())).flushed}a(fte,"flush");async function _te(e,t){try{(await cB.openEnvironment(aB(e,t),t.toString())).resetReadTxn()}catch{}}a(_te,"resetReadTxn")});var pB=I(($Ie,_B)=>{"use strict";var{Readable:pte}=require("stream"),{getDatabases:hte}=(De(),P(nt)),{readSync:mte,openSync:Ete,createReadStream:dB}=require("fs"),{open:gte}=require("lmdb"),fB=i_(),Ste=o_(),{AUDIT_STORE_OPTIONS:Tte}=(_o(),P(hB)),{INTERNAL_DBIS_NAME:Ate,AUDIT_STORE_NAME:Rte}=xt();_B.exports=bte;var $b=32768,yte=100;async function bte(e){let t=e.database||e.schema||"data",r=hte()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let u=r[s[0]];if(!u)throw new Error(`Can not find table ${s[0]}`);let f=u.dbisDB,d=gte({noSync:!0,maxDbs:Ste.MAX_DBS}),p,_=d.openDB(Ate,new fB(!1)),h=f.useReadTransaction(),S=0,g=a(async function(E,A){A.encoding="binary",A.encoder=void 0;let N=d.openDB(E,A),v=f.openDB(E,A);for(let{key:F,version:$,value:Y}of v.getRange({start:null,transaction:h,versions:v.useVersions}))p=N.put(F,Y,$),S++%yte===0&&(await new Promise(ee=>setTimeout(ee,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:E,value:A}of f.getRange({transaction:h,start:!1}))if(s.some(N=>E.startsWith?.(N+"/"))){_.put(E,A);let[,N]=E.split("/"),v=!N,F=new fB(!v,v);await g(E,F)}e.include_audit&&await g(Rte,{...Tte}),await p;let R=dB(d.path);return R.headers=l(),R.on("close",()=>{h.done(),d.close()}),R}let o=r[Object.keys(r)[0]].primaryStore,c=Ete(o.path);return o.transaction(()=>{let u=Buffer.alloc($b);mte(c,u,0,$b),o.resetReadTxn();let f=o.useReadTransaction();f.renew();let d=dB(null,{fd:c,start:$b}),p=new pte.from(async function*(){yield u;for await(let _ of d)f.openTimer&&(f.openTimer=0),yield _;f.done()}());return p.headers=l(),p});function l(){let u=new Map;return u.set("content-type","application/octet-stream"),u.set("content-disposition",`attachment; filename="${t}"`),u.set("date",n),u}}a(bte,"getBackup")});var gB=I((KIe,EB)=>{"use strict";var Ote=W(),{handleHDBError:Nte}=pe(),wte=CM(),Ite=oE(),Cte=_b(),Pte=P0(),Dte=C_(),Lte=Tb(),Mte=rx(),vte=dx(),Ute=M_(),xte=Sx(),Bte=Px(),Hte=Ux(),kte=Bx(),Fte=Gx(),Gte=zx(),qte=Ib(),$te=Xx(),Vte=sB(),Kte=oB(),mB=uB(),Yte=pB(),Vb=class extends wte{static{a(this,"LMDBBridge")}async searchByConditions(t){return xte(t)}async getDataByHash(t){return await Lte(t)}async searchByHash(t){return await Mte(t)}async getDataByValue(t,r){return await vte(t,r)}async searchByValue(t){return await Ute(t)}async createSchema(t){return await Pte(t)}async dropSchema(t){return await Bte(t)}async createTable(t,r){return await Hte(t,r)}async dropTable(t){return await qte(t)}async createAttribute(t){return await Ite(t)}async createRecords(t){return await Cte(t)}async updateRecords(t){return await kte(t)}async upsertRecords(t){try{return await Fte(t)}catch(r){throw Nte(r,null,null,Ote.ERR,r)}}async deleteRecords(t){return await Dte(t)}async dropAttribute(t){return await $te(t)}async deleteAuditLogsBefore(t){return await Gte(t)}async readAuditLog(t){return await Vte(t)}writeTransaction(t,r,n){return Kte.writeTransaction(t,r,n)}flush(t,r){return mB.flush(t,r)}resetReadTxn(t,r){return mB.resetReadTxn(t,r)}getBackup(t){return Yte(t)}};EB.exports=Vb});var Yb={};Ue(Yb,{add:()=>UE,applyReverse:()=>SB,getRecordAtTime:()=>Kb,rebuildUpdateBefore:()=>xE});function UE(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n+BigInt(r.value):isNaN(e[t])?e[t]=r.value:e[t]=n+r.value}function xE(e,t,r){let n=null;for(let s in e)if(s in t){let i=t[s];if(i?.__op__){let o=e[s];if(o?.__op__)if(o.__op__===i.__op__)n||(n={}),n[s]=o;else throw new Error("Can not merge updates with different operations");else n||(n={}),n[s]=o,UE(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function SB(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=Wte[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=TB}}function Kb(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),u=wt(l);switch(u.type){case"put":s=u.getValue(r);break;case"patch":SB(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===TB&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),u=wt(l),f;switch(u.type){case"put":f=u.getValue(r);break;case"patch":f=u.getValue(r);break}for(let d in f)o[d]&&(s[d]=f[d],o[d]=!1,c--);i=u.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var Wte,TB,BE=be(()=>{_o();a(UE,"add");UE.reverse=function(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n-BigInt(r.value):isNaN(e[t])||(e[t]=n-r.value)};Wte={add:UE};a(xE,"rebuildUpdateBefore");a(SB,"applyReverse");TB={};a(Kb,"getRecordAtTime")});function Nn(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function GE(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let c of s){let l=c.name,u,f;if(c.resolve)f={get(){return c.resolve(this,this.getContext?.())},set(d){return c.set(this,d)},configurable:!0};else{switch(c.type){case"String":u=a(function(d){if(!(typeof d=="string"||d==null&&c.nullable!==!1))throw new Jn.ClientError(`${l} must be a string, attempt to assign ${d}`);Nn(this)[l]=d},"set");break;case"ID":u=a(function(d){if(!(typeof d=="string"||d?.length>0&&d.every?.(p=>typeof p=="string")||d==null&&c.nullable!==!1))throw new Jn.ClientError(`${l} must be a string, attempt to assign ${d}`);Nn(this)[l]=d},"set");break;case"Float":case"Number":u=a(function(d){let p=d?.__op__?d.value:d;if(!(typeof p=="number"||d==null&&c.nullable!==!1))throw new Jn.ClientError(`${l} must be a number, attempt to assign ${p}`);Nn(this)[l]=d},"set");break;case"Int":u=a(function(d){let p=d?.__op__?d.value:d;if(!(p>>0===p||d==null&&c.nullable!==!1))if(typeof p=="number"&&Math.abs((p>>0)-p)<=1)p=Math.round(p),d?.__op__?d.value=p:d=p;else throw new Jn.ClientError(`${l} must be an integer between -2147483648 and 2147483647, attempt to assign ${d}`);Nn(this)[l]=d},"set");break;case"Long":u=a(function(d){let p=d?.__op__?d.value:d;if(!(Math.round(p)===d&&Math.abs(p)<=9007199254740992||d==null&&c.nullable!==!1))if(typeof p=="number"&&Math.abs(p)<=9007199254740992)p=Math.round(p),d?.__op__?d.value=p:d=p;else throw new Jn.ClientError(`${l} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${d}`);Nn(this)[l]=d},"set");break;case"BigInt":u=a(function(d){let p=d?.__op__?d.value:d;if(!(typeof p=="bigint"||d==null&&c.nullable!==!1))if(typeof p=="string"||typeof p=="number")p=BigInt(p),d?.__op__?d.value=p:d=p;else throw new Jn.ClientError(`${l} must be a number, attempt to assign ${d}`);Nn(this)[l]=d},"set");break;case"Boolean":u=a(function(d){if(!(typeof d=="boolean"||d==null&&c.nullable!==!1))throw new Jn.ClientError(`${l} must be a boolean, attempt to assign ${d}`);Nn(this)[l]=d},"set");break;case"Date":u=a(function(d){if(!(d instanceof Date||d==null&&c.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=new Date(d);else throw new Jn.ClientError(`${l} must be a Date, attempt to assign ${d}`);Nn(this)[l]=d},"set");break;case"Bytes":u=a(function(d){if(!(d instanceof Uint8Array||d==null&&c.nullable!==!1))throw new Jn.ClientError(`${l} must be a Buffer or Uint8Array, attempt to assign ${d}`);Nn(this)[l]=d},"set");break;case"Blob":u=a(function(d){if(!(d instanceof Ii||d==null&&c.nullable!==!1))throw new Jn.ClientError(`${l} must be a Blob, attempt to assign ${d}`);Nn(this)[l]=d},"set");break;case"Any":case void 0:u=a(function(d){Nn(this)[l]=d},"set");break;default:u=a(function(d){if(!(typeof d=="object"||d==null&&c.nullable!==!1))throw new Jn.ClientError(`${l} must be an object, attempt to assign ${d}`);Nn(this)[l]=d},"set")}f={get(){let d=this.getChanges?.();if(d&&l in d){let _=d[l];if(_?.__op__){let h=this.getRecord()?.[l];return _.update(h)}return _}let p=this.getRecord()?.[l];if(p&&typeof p=="object"){let _=Wb(p,c);if(_)return d||this._setChanges(d=Object.create(null)),d[l]=_}return p},set:u,enumerable:!0,configurable:!0}}f.get.isAttribute=!0,n[l]=f,(!(l in r)||Object.getOwnPropertyDescriptor(r,l)?.get?.isAttribute)&&Object.defineProperty(r,l,f)}i("getProperty",function(c){let l=n[c];if(l)return l.get.call(this);let u=this.getChanges();return u?.[c]!==void 0?u[c]:this.getRecord()?.[c]}),i("set",function(c,l){let u=n[c];if(u)return u.set.call(this,l);if(t.sealed)throw new Jn.ClientError("Can not add a property to a sealed table schema");Nn(this)[c]=l}),i("deleteProperty",function(c){Nn(this)[c]=void 0}),i("toJSON",function(){let c=this.getChanges?.(),l;for(let f in c){l||(l={...this.getRecord()});let d=c[f];if(d?.__op__){let p=l[f];d=d.update(p)}l[f]=d}return Object.keys(this).length>0&&(l||(l={...this.getRecord()}),Object.assign(l,this)),l||this.getRecord()}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty),r.then||i("then",null);function i(c,l){Object.defineProperty(r,c,{value:l,configurable:!0})}a(i,"setMethod");let o=r;do{let c=Object.getPrototypeOf(o);if(c===Object.prototype){Object.setPrototypeOf(o,RB);break}o=c}while(o&&o!==RB)}function Wb(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends k_{static{a(this,"TrackedObject")}},GE(r,t)),new r(e)):new k_(e);case Array:let n=new kE(e.length,e);for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=Wb(o,t?.elements)),n[s]=o}return n;default:return e}}function qE(e){let t=e.getChanges?.(),r;for(let s in t){r||(r=e.getRecord?{...e.getRecord()}:{});let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=qE(i);r[s]=i}return Object.keys(e).length>0&&(r||(r=e.getRecord?{...e.getRecord()}:{}),Object.assign(r,e)),r||e.getRecord?.()||e}function il(e,t=e.getChanges?.()){let r;if(e.getRecord&&e.constructor===Array&&!Object.isFrozen(e)){r=e;for(let n=0,s=e.length;n<s;n++){let i=e[n];if(i&&typeof i=="object"){let o=il(i);o!==i&&r===e&&(r=e.slice(0)),i=o}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r={...e.getRecord?.()});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=Yb[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=il(s);r[n]=s}if(!Array.isArray(e))for(let n in e)zte.call(e,n)&&(r||(r={...e.getRecord?.()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?.()??e}function HE(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[sl]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.getRecord?.()===s){if(HE(i))return!0}else return!0}}else{let r=e.getChanges?.();if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s.getRecord?.()===i){if(HE(s))return!0}else return!0}else return!0}}return!1}var Jn,AB,RB,k_,zte,sl,kE,FE,zb=be(()=>{Jn=M(pe());BE();Ss();a(Nn,"getChanges");a(GE,"assignTrackedAccessors");AB=Object.prototype,RB=new Proxy({},{get(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(AB[t])return AB[t];let n=r.getChanges?.();if(n&&t in n)return n[t];let s=r.getRecord?.()[t];if(s&&typeof s=="object"){let i=Wb(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}});a(Wb,"trackObject");k_=class{static{a(this,"GenericTrackedObject")}#e;#t;constructor(t){if(t?.getRecord)throw new Error("Can not track an already tracked object, check for circular references");this.#e=t}getRecord(){return this.#e}setRecord(t){this.#e=t}getChanges(){return this.#t}_setChanges(t){this.#t=t}};GE(k_,{});a(qE,"collapseData");zte=Object.prototype.hasOwnProperty;a(il,"updateAndFreeze");a(HE,"hasChanges");sl=Symbol.for("has-array-changes"),kE=class extends Array{static{a(this,"TrackedArray")}#e;[sl];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[sl]=!0,super.splice(...t)}push(...t){return this[sl]=!0,super.push(...t)}pop(){return this[sl]=!0,super.pop()}unshift(...t){return this[sl]=!0,super.unshift(...t)}shift(){return this[sl]=!0,super.shift()}};kE.prototype.constructor=Array;FE=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var PB={};Ue(PB,{ResourceBridge:()=>Qb});function Xb({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 bB(e,t){let r=ki(e),n=Xb(e,r);if(!r)throw new ii.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache,replicateFrom:e.replicateFrom},o;Nt(i,()=>new Promise(u=>o=u));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let u=c[l++],f;try{f=await r.get({id:u,lazy:s,select:n},i),f=f&&qE(f)}catch(d){f={message:d.toString()}}return t?{value:{key:u,value:f}}:{value:f}}else return o(),{done:!0}},return(u){return o(),{value:u,done:!0}},throw(u){return o(),{done:!0}}}}}}function ki(e){let t=e.database||e.schema||Jte,r=Xe()[t];if(!r)throw(0,ii.handleHDBError)(new Error,jte.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function OB(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*NB(e,t,r,n){let s,i=0;for await(let o of e.getHistory(t,r)){let c=o.operation??o.type;c==="put"&&(c="upsert");let{id:l,version:u,value:f}=o;if(s?.timestamp===u)s.hash_values.push(l),s.records.push(f);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:u,hash_values:[l],records:[f]}}}s&&(yield s)}var wB,$E,ii,IB,jb,Jb,CB,jte,Jte,Qte,Xte,yB,Qb,DB=be(()=>{"use strict";wB=M(gB()),$E=M(Fu()),ii=M(pe());De();IB=M(u_());H();jb=M(Ao()),Jb=M(ni()),CB=M(ae());Cc();zb();({HDB_ERROR_MSGS:jte}=ii.hdb_errors),Jte="data",Qte=1e4,Xte=10,Qb=class extends wB.default{static{a(this,"ResourceBridge")}constructor(t){super(t),yB=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,$E.default)(t,"conditions");if(r)throw(0,ii.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=ki(t);if(!n)throw new ii.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:Xb(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new ii.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}]}dt({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await ki(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=ki(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c={...c},delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(u=>{if(!u){let{value:f,version:d}=r.primaryStore.getEntry(o);return i(o,f,d)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(u=>setImmediate(u));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){ki(t).dropTable()}createSchema(t){return $u({database:t.schema,table:null}),jb.signalSchemaChange(new Jb.SchemaEventMsg(process.pid,Kt.CREATE_SCHEMA,t.schema))}async dropSchema(t){await Zb(t.schema),jb.signalSchemaChange(new Jb.SchemaEventMsg(process.pid,Kt.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,yB.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,IB.default)(t),s,i=Xe()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(o.replicateTo=t.replicateTo),t.replicatedConfirmation&&(o.replicatedConfirmation=t.replicatedConfirmation),Nt(o,async c=>{if(!i.schemaDefined){s=[];for(let f of n)i.attributes.find(p=>p.name==f)||s.push(f);s.length>0&&await i.addAttributes(s.map(f=>({name:f,indexed:!0})))}let l=[],u=[];for(let f of t.records){let d=f[i.primaryKey],p=d!=null&&await i.get(d,o);if(t.requires_existing&&!p||t.requires_no_existing&&p){u.push(f[i.primaryKey]);continue}p&&(p=qE(p));for(let _ in f)if(Object.prototype.hasOwnProperty.call(f,_)){let h=f[_];if(typeof h=="function")try{let S=h([[p]]);Array.isArray(S)&&(h=S[0].func_val,f[_]=h)}catch(S){throw S.message+="Trying to set key "+_+" on object"+JSON.stringify(f),S}}if(p)for(let _ in p)Object.prototype.hasOwnProperty.call(f,_)||(f[_]=p[_]);await(d==null?i.create(f,o):i.put(f,o)),l.push(f[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:u}})}async deleteRecords(t){let r=Xe()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),Nt(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 OB(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Xe()[t.schema][t.table];if(!r.createdTimeProperty)throw new ii.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:cm.LESS}]}),s=!1,i=[],o=[],c=0,l=[],u=a(async()=>{let f=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...f.deleted_hashes),o.push(...f.skipped_hashes),await(0,CB.async_set_timeout)(Xte),l=[],s=!0},"chunkDelete");for await(let f of n)l.push(f[r.primaryKey]),c++,c%Qte===0&&await u();return l.length>0&&await u(),s?OB(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,$E.default)(t,"hashes");if(r)throw r;return bB(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of bB(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&XA[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,$E.default)(t,"value");if(n)throw n;let s=ki(t);if(!s)throw new ii.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===cm.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:Xb(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=ki(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){ki({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return ki(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=ki(t),n={};switch(t.search_type){case lm.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.operation??o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case lm.USERNAME:let s=t.search_values;for await(let i of NB(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return NB(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(Xb,"getSelect");a(bB,"getRecords");a(ki,"getTable");a(OB,"createDeleteResponse");a(NB,"groupRecordsInHistory")});var Kn=I((sCe,LB)=>{"use strict";var{ResourceBridge:Zte}=(DB(),P(PB)),ere=ce();ere.initSync();var VE;function tre(){return VE||(VE=new Zte,VE)}a(tre,"getBridge");LB.exports=tre()});var bn=I((oCe,xB)=>{"use strict";var YE=GR(),Lr=ae(),rre=require("util"),WE=Kn(),nre=Rs(),MB=W(),{handleHDBError:ol,hdb_errors:sre}=pe(),{HTTP_STATUS_CODES:al}=sre,ire=rre.promisify(nre.getTableSchema),ore="updated",vB="inserted",UB="upserted";xB.exports={insert:cre,update:lre,upsert:ure,validation:are,flush:dre};async function are(e){if(Lr.isEmpty(e))throw new Error("invalid update parameters defined.");if(Lr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Lr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await ire(e.schema,e.table),r=YE(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&&Lr.isEmptyOrZeroLength(c[n]))throw MB.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(!Lr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw MB.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Lr.isEmpty(c[n])&&c[n]!==""&&s.has(Lr.autoCast(c[n]))&&(c.skip=!0),s.add(Lr.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(are,"validation");async function cre(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=YE(e);if(t)throw ol(new Error,t.message,al.BAD_REQUEST);Lr.transformReq(e);let r=Lr.checkSchemaTableExist(e.schema,e.table);if(r)throw ol(new Error,r,al.BAD_REQUEST);let n=await WE.createRecords(e);return KE(vB,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(cre,"insertData");async function lre(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=YE(e);if(t)throw ol(new Error,t.message,al.BAD_REQUEST);Lr.transformReq(e);let r=Lr.checkSchemaTableExist(e.schema,e.table);if(r)throw ol(new Error,r,al.BAD_REQUEST);let n=await WE.updateRecords(e);return Lr.isEmpty(n.existing_rows)?KE(ore,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):KE(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(lre,"updateData");async function ure(e){if(e.operation!=="upsert")throw ol(new Error,"invalid operation, must be upsert",al.INTERNAL_SERVER_ERROR);let t=YE(e);if(t)throw ol(new Error,t.message,al.BAD_REQUEST);Lr.transformReq(e);let r=Lr.checkSchemaTableExist(e.schema,e.table);if(r)throw ol(new Error,r,al.BAD_REQUEST);let n=await WE.upsertRecords(e);return KE(UB,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(ure,"upsertData");function KE(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===vB?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===UB?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(KE,"returnObject");function dre(e){return Lr.transformReq(e),WE.flush(e.schema,e.table)}a(dre,"flush")});var qB=I((cCe,GB)=>{var Vu=require("validate.js"),HB=it(),Ku=(H(),P(G)),{handleHDBError:fre,hdb_errors:_re}=pe(),{HDB_ERROR_MSGS:zt,HTTP_STATUS_CODES:pre}=_re,eO=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),hre={STRUCTURE_USER:"structure_user"},BB=Object.values(Ku.ROLE_TYPES_ENUM),mre="attribute_permissions",Ere="attribute_name",{PERMS_CRUD_ENUM:Yu}=Ku,gre=[mre,...Object.values(Yu)],kB=[Yu.READ,Yu.INSERT,Yu.UPDATE],Sre=[Ere,...kB];function Tre(e){let t=eO();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,FB(e,t)}a(Tre,"addRoleValidation");function Are(e){let t=eO();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,FB(e,t)}a(Are,"alterRoleValidation");function Rre(e){let t=eO();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,HB.validateObject(e,t)}a(Rre,"dropRoleValidation");var yre=["operation","role","id","permission","hdb_user","access"];function FB(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)yre.includes(n[o])||s.push(n[o]);s.length>0&&nr(zt.INVALID_ROLE_JSON_KEYS(s),r);let i=HB.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{nr(o,r)}),e.permission){let o=bre(e);o&&nr(o,r),BB.forEach(c=>{e.permission[c]&&!Vu.isBoolean(e.permission[c])&&nr(zt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(BB.indexOf(o)<0){if(o===hre.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let u=0,f=l.length;u<f;u++){let d=l[u];global.hdb_schema[d]||nr(zt.SCHEMA_NOT_FOUND(d),r)}continue}nr(zt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){nr(zt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let u=c.tables[l];if(!l||!global.hdb_schema[o][l]){nr(zt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(f=>{gre.includes(f)||nr(zt.INVALID_PERM_KEY(f),r,o,l)}),Object.values(Yu).forEach(f=>{Vu.isDefined(u[f])?Vu.isBoolean(u[f])||nr(zt.TABLE_PERM_NOT_BOOLEAN(f),r,o,l):nr(zt.TABLE_PERM_MISSING(f),r,o,l)}),u.attribute_permissions===void 0){nr(zt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){nr(zt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}if(u.attribute_permissions){let f=global.hdb_schema[o][l].attributes.map(({attribute:p})=>p),d={read:!1,insert:!1,update:!1};for(let p in u.attribute_permissions){let _=u.attribute_permissions[p];if(Object.keys(_).forEach(S=>{!Sre.includes(S)&&S!==Yu.DELETE&&nr(zt.INVALID_ATTR_PERM_KEY(S),r,o,l)}),!Vu.isDefined(_.attribute_name)){nr(zt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=_.attribute_name;if(!f.includes(h)){nr(zt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}kB.forEach(S=>{Vu.isDefined(_[S])?Vu.isBoolean(_[S])||nr(zt.ATTR_PERM_NOT_BOOLEAN(S,h),r,o,l):nr(zt.ATTR_PERM_MISSING(S,h),r,o,l)}),!d.read&&_.read===!0&&(d.read=!0),!d.insert&&_.insert===!0&&(d.insert=!0),!d.update&&_.update===!0&&(d.update=!0)}if(u.read===!1&&d.read===!0||u.insert===!1&&d.insert===!0||u.update===!1&&d.update===!0){let p=`${o}.${l}`;nr(zt.MISMATCHED_TABLE_ATTR_PERMS(p),r,o,l)}}}}return Ore(r)}a(FB,"customValidate");GB.exports={addRoleValidation:Tre,alterRoleValidation:Are,dropRoleValidation:Rre};function bre(e){let{operation:t,permission:r}=e;if(t===Ku.OPERATIONS_ENUM.ADD_ROLE||t===Ku.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 zt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?Ku.ROLE_TYPES_ENUM.SUPER_USER:Ku.ROLE_TYPES_ENUM.CLUSTER_USER;return zt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(bre,"validateNoSUPerms");function Ore(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:zt.ROLE_PERMS_ERROR,...e};return fre(new Error,n,pre.BAD_REQUEST)}else return null}a(Ore,"generateRolePermResponse");function nr(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(nr,"addPermError")});var G_=I((dCe,YB)=>{"use strict";var $B=bn(),VB=Wr(),Nre=jc(),rO=qB(),nO=Ao(),uCe=require("uuid").v4,wre=require("util"),zE=(H(),P(G)),Ire=ae(),sO=VB.searchByValue,Cre=VB.searchByHash,Pre=wre.promisify(Nre.delete),Dre=si(),Lre=Gu(),{hdb_errors:Mre,handleHDBError:cl}=pe(),{HDB_ERROR_MSGS:KB,HTTP_STATUS_CODES:F_}=Mre,{UserEventMsg:iO}=ni();YB.exports={addRole:vre,alterRole:Ure,dropRole:xre,listRoles:Bre};function tO(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(tO,"scrubRoleDetails");async function vre(e){let t=rO.addRoleValidation(e);if(t)throw t;e=tO(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 sO(r)||[])}catch(i){throw cl(i)}if(n&&n.length>0)throw cl(new Error,KB.ROLE_ALREADY_EXISTS(e.role),F_.CONFLICT,void 0,void 0,!0);e.id||(e.id=e.role);let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await $B.insert(s),nO.signalUserChange(new iO(process.pid)),e=tO(e),e}a(vre,"addRole");async function Ure(e){let t=rO.alterRoleValidation(e);if(t)throw t;e=tO(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await $B.update(r)}catch(s){throw cl(s)}if(n&&n?.message==="updated 0 of 1 records")throw cl(new Error,"Invalid role id",F_.BAD_REQUEST,void 0,void 0,!0);return await nO.signalUserChange(new iO(process.pid)),e}a(Ure,"alterRole");async function xre(e){let t=rO.dropRoleValidation(e);if(t)throw cl(new Error,t,F_.BAD_REQUEST,void 0,void 0,!0);let r=new Lre(zE.SYSTEM_SCHEMA_NAME,zE.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await Cre(r));if(n.length===0)throw cl(new Error,KB.ROLE_NOT_FOUND,F_.NOT_FOUND,void 0,void 0,!0);let s=new Dre(zE.SYSTEM_SCHEMA_NAME,zE.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await sO(s)),o=!1;if(Ire.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw cl(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,F_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await Pre(c),nO.signalUserChange(new iO(process.pid)),`${n[0].role} successfully deleted`}a(xre,"dropRole");async function Bre(){return sO({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Bre,"listRoles")});var oO={};Ue(oO,{start:()=>jB,startOnMainThread:()=>Fre});function jB({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,WB.parseDocument)(r.toString(),{simpleKeys:!0}).toJSON();for(let s in n){let i=n[s];i.permission||(i={permission:i},i.permission.access&&(i.access=i.permission.access,delete i.permission.access));for(let o in i.permission){if(Hre.includes(o))continue;let c=i.permission[o];c.tables||(i.permission[o]=c={tables:c});for(let l in c.tables){let u=c.tables[l];if(u.read=!!u.read,u.insert=!!u.insert,u.update=!!u.update,u.delete=!!u.delete,u.attributes){let f=[];for(let d in u.attributes){let p=u.attributes[d];p.attribute_name=d,f.push(p)}u.attribute_permissions=f,delete u.attributes}if(u.attribute_permissions){if(!Array.isArray(u.attribute_permissions))throw new Error("attribute_permissions must be an array if defined");for(let f of u.attribute_permissions)f.read=!!f.read,f.insert=!!f.insert,f.update=!!f.update}else u.attribute_permissions=null}}i.role=i.id=s,await kre(i)}}}async function kre(e){let t=Xe().system.hdb_role;for await(let r of t.search([{attribute:"role",value:e.role}])){let{__createdtime__:n,__updatedtime__:s,...i}=r;return(0,zB.isEqual)(i,e)?void 0:(e.id=r.id,(0,jE.alterRole)(e))}return(0,jE.addRole)(e)}var jE,WB,zB,Hre,Fre,JB=be(()=>{De();jE=M(G_()),WB=require("yaml"),zB=require("lodash"),Hre=["super_user","cluster_user","structure_user"];a(jB,"start");a(kre,"ensureRole");Fre=jB});async function JE(e){let t=(0,ZB.pathToFileURL)(e).toString();if(Gre)return q_||(q_=qre(Vre)),(await(await q_).import(t)).namespace;try{return await import(t)}catch(r){try{(await import("internal/util")).default.decorateErrorStack(r)}catch{}throw r}}async function qre(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),q_=new Compartment({console,Math,Date,fetch:$re,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,XB.extname)(r)||(r+=".js"),r)},importHook:a(async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Vr,tables:Qn,databases:$e})}};let n=await(0,QB.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),q_}function $re(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 Vre(){return{Resource:Vr,tables:Qn}}var QB,XB,ZB,Gre,q_,aO=be(()=>{ga();De();QB=require("fs/promises"),XB=require("path"),ZB=require("url"),Gre=!1;a(JE,"secureImport");a(qre,"getCompartment");a($re,"secureOnlyFetch");a(Vre,"getGlobalVars")});var lO={};Ue(lO,{handleFile:()=>Kre});async function Kre(e,t,r,n){let s=new Map,i=await JE(r);c(i.default)&&n.set((0,cO.dirname)(t),i.default),o(i,(0,cO.dirname)(t));function o(l,u){for(let f in l){let d=l[f];c(d)?n.set(u+"/"+f,d):typeof d=="object"&&o(d,u+"/"+f)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var cO,eH=be(()=>{aO();cO=require("path");a(Kre,"handleFile")});var dO={};Ue(dO,{start:()=>Yre});function Yre({resources:e}){e.set("login",uO),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var uO,tH=be(()=>{ga();a(Yre,"start");uO=class extends Vr{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 z_={};Ue(z_,{addAnalyticsListener:()=>W_,calculateCPUUtilization:()=>TH,diffResourceUsage:()=>AH,recordAction:()=>sr,recordActionBinary:()=>Xn,setAnalyticsEnabled:()=>Wre});function Wre(e){hH=e}function zre(e,t){if(typeof e=="number"){let r=t.values,n=r.index++;if(n>=r.length){let s=r;t.values=r=new Float32Array(n*2),r.set(s),r.index=n+1}r[n]=e,t.total+=e}else if(typeof e=="boolean")e&&t.total++,t.count++;else if(typeof e=="function")t.count++;else throw new TypeError("Invalid metric value type "+typeof e)}function jre(e,t,r,n,s,i){let o={};if(typeof t=="number")o.total=t,o.values=new Float32Array(4),o.values.index=1,o.values[0]=t,o.total=t;else if(typeof t=="boolean")o.total=t?1:0,o.count=1;else if(typeof t=="function")o.count=1,o.callback=t;else throw new TypeError("Invalid metric value type "+typeof t);o.description={metric:r,path:n,method:s,type:i},XE.set(e,o)}function sr(e,t,r,n,s){if(!hH)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=XE.get(i);o?zre(e,o):jre(i,e,t,r,n,s),QE||Jre()}function Xn(e,t,r,n,s){sr(!!e,t,r,n,s)}function W_(e){gH.push(e)}function Jre(){QE=performance.now(),setTimeout(async()=>{let e=performance.now()-QE;QE=0;let t=[],r={time:Date.now(),period:e,threadId:ll.threadId,metrics:t};for(let[s,i]of XE){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,u=[],f;for(let d of SH){let p=Math.floor(c*d),_=o[p-1];if(p>l){let h=p-l;if(_===f){let S=u[u.length-1];typeof S=="number"?u[u.length-1]={value:S,count:1+h}:S.count+=h}else u.push(h>1?{value:_,count:h}:_),f=_;l=p}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:u,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await RH()}let n=process.memoryUsage();t.push({metric:"memory",threadId:ll.threadId,byThread:!0,...n});for(let s of gH)s(t);XE=new Map,ll.parentPort?ll.parentPort.postMessage({type:EH,report:r}):OH({report:r})},mH).unref()}function ZE(e,t,r){let n={id:(0,K_.getNextMonotonicTime)(),metric:t,...r};e.primaryStore.put(n.id,n,{append:!0}).then(s=>{s||e.primaryStore.put(n.id,n)})}function TH(e,t){let r=e.userCPUTime+e.systemCPUTime;return Math.round(r/t*100)/100}function AH(e,t){return{userCPUTime:t.userCPUTime/1e3-(e?.userCPUTime??0),systemCPUTime:t.systemCPUTime/1e3-(e?.systemCPUTime??0),minorPageFault:t.minorPageFault-(e?.minorPageFault??0),majorPageFault:t.majorPageFault-(e?.majorPageFault??0),fsRead:t.fsRead-(e?.fsRead??0),fsWrite:t.fsWrite-(e?.fsWrite??0),voluntaryContextSwitches:t.voluntaryContextSwitches-(e?.voluntaryContextSwitches??0),involuntaryContextSwitches:t.involuntaryContextSwitches-(e?.involuntaryContextSwitches??0)}}function Qre(e,t,r){let n=0;for(let[s,i]of Object.entries(r)){let o=`${t}.${s}`,c=i.getSize(),l={database:t,table:s,size:c};ZE(e,"table-size",l),ul.trace?.(`table ${o} size metric: ${JSON.stringify(l)}`),n+=c}return n}function rH(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s.getAuditSize(),o=pH.default.statSync(s.primaryStore.env.path).size,c=Qre(e,r,n),l=o-c,u={database:r,size:o,used:c,free:l,audit:i};ZE(e,"database-size",u),ul.trace?.(`database ${r} size metric: ${JSON.stringify(u)}`)}catch(s){ul.warn?.("Error getting DB size metrics",s)}}function nH(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s.getStorageStats(),o={database:r,...i};ZE(e,"storage-volume",o),ul.trace?.(`db ${r} storage volume metrics: ${JSON.stringify(o)}`)}catch(s){ul.warn?.("Error getting DB volumne metrics",s)}}async function Xre(e,t=6e4){let r=_O(),n=yH(),s=new Promise(E=>{let A=performance.now();setImmediate(()=>{let N=performance.now();N-A>5e3&&ul.warn?.("Unusually high event queue latency on the main thread of "+Math.round(N-A)+"ms"),A=performance.now()}),n.primaryStore.prefetch([1],()=>{let N=performance.now();N-A>5e3&&ul.warn?.("Unusually high task queue latency on the main thread of "+Math.round(N-A)+"ms"),E(N-A)})}),i;for(let E of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(E.value?.time){i=E.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,u=[],f;for(let{key:E,value:A}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!A)continue;if(o){if(E>o+t)break}else o=E;f=E;let{metrics:N,threadId:v}=A;for(let F of N||[]){let{path:$,method:Y,type:ee,metric:oe,count:j,total:se,distribution:z,threads:me,...Ae}=F;j||(j=1);let Pe=oe+($?"-"+$:"");Y!==void 0&&(Pe+="-"+Y),ee!==void 0&&(Pe+="-"+ee);let he=c.get(Pe);if(he){if(he.threads){let ut=he.threads[v];if(ut)he=ut;else{he.threads[v]={...Ae};continue}}he.count||(he.count=1);let Ot=he.count;for(let ut in Ae){let br=Ae[ut];typeof br=="number"&&(he[ut]=(he[ut]*Ot+br*j)/(Ot+j))}he.count+=j,se>=0&&(he.total+=se,he.ratio=he.total/he.count)}else he={period:t,...F},delete he.distribution,c.set(Pe,he),he.byThread&&(he.threads=[],he.threads[v]={...Ae},u.push(he));if(z){z=z.map(ut=>typeof ut=="number"?{value:ut,count:1}:ut);let Ot=l.get(Pe);Ot?Ot.push(...z):l.set(Pe,z)}}await RH()}for(let E of u){let{path:A,method:N,type:v,metric:F,count:$,total:Y,distribution:ee,threads:oe,...j}=E;oe=oe.filter(se=>se);for(let se in j){if(typeof E[se]!="number")continue;let z=0;for(let me of oe){let Ae=me[se];typeof Ae=="number"&&(z+=Ae)}E[se]=z}E.count=oe.length,delete E.threads,delete E.byThread}for(let[E,A]of l){let N=c.get(E);A.sort((ut,br)=>ut.value>br.value?1:-1);let v=N.count-1,F=[],$=0,Y=0,ee;for(let ut of SH){let br=v*ut;for(;$<br;)ee=A[Y++],$+=ee.count,Y===1&&$--;let ms=A[Y>1?Y-2:0];ee||(ee=A[0]),F.push(ee.value-(ee.value-ms.value)*($-br)/ee.count)}let[oe,j,se,z,me,Ae,Pe,he,Ot]=F;Object.assign(N,{p1:oe,p10:j,p25:se,median:z,p75:me,p90:Ae,p95:Pe,p99:he,p999:Ot})}let d;for(let[E,A]of c)A.id=(0,K_.getNextMonotonicTime)(),A.time=f,n.primaryStore.put(A.id,A,{append:!0}).then(N=>{N||n.primaryStore.put(A.id,A)}),d=!0;let p=Date.now(),{idle:_,active:h}=performance.eventLoopUtilization();if(d||h*10>_){let E=(0,K_.getNextMonotonicTime)(),A={id:E,metric:"main-thread-utilization",idle:_-sH,active:h-iH,taskQueueLatency:await s,time:p,...process.memoryUsage()};n.primaryStore.put(E,A,{append:!0}).then(N=>{N||n.primaryStore.put(E,A)})}sH=_,iH=h;let S=process.resourceUsage(),g=AH($_,S);g.time=p,g.period=$_.time?p-$_.time:t,g.cpuUtilization=TH($_,g.period),ZE(n,"resource-usage",g),$_=g;let R=Xe();rH(n,R),rH(n,{system:R.system}),nH(n,R),nH(n,{system:R.system})}async function oH(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function _O(){return aH||(aH=dt({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function yH(){return cH||(cH=dt({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function tne(){bH=!0;let e=(0,Y_.get)(x.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await Xre(mH,e),await oH(_O(),Zre),await oH(yH(),ene)},Math.min(e/2,2147483647)).unref()}function OH(e,t){let r=e.report;r.threadId=t?.threadId||ll.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(lH+=n.mean*n.count);r.totalBytesProcessed=lH,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(uH.get(t))}),uH.set(t,t.performance.eventLoopUtilization())),r.id=(0,K_.getNextMonotonicTime)(),_O().primaryStore.put(r.id,r),bH||tne(),rne&&(NH=sne(r))}async function sne(e){if(await NH,!Pa){let r=(0,V_.dirname)((0,fH.getLogFilePath)());try{Pa=await(0,fO.open)((0,V_.join)(r,"analytics.log"),"r+")}catch{Pa=await(0,fO.open)((0,V_.join)(r,"analytics.log"),"w+")}}let t=(await Pa.stat()).size;if(t>nne){let r=Buffer.alloc(t);await Pa.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Pa.write(r,{position:0}),await Pa.truncate(r.length),t=r.length}await Pa.write(JSON.stringify(e)+`
21
+ `,t)}var ll,dH,fH,_H,V_,fO,K_,Y_,pH,ul,XE,hH,QE,mH,EH,gH,SH,sH,iH,$_,RH,Zre,ene,aH,cH,bH,lH,uH,rne,NH,Pa,nne,Fi=be(()=>{ll=require("worker_threads"),dH=M(rt());De();fH=M(W()),_H=M(wi()),V_=require("path"),fO=require("fs/promises"),K_=M(pn()),Y_=M(ce());H();Kr();pH=M(require("node:fs")),ul=(0,_H.loggerWithTag)("analytics");(0,Y_.initSync)();XE=new Map,hH=(0,Y_.get)(x.ANALYTICS_AGGREGATEPERIOD)>-1;a(Wre,"setAnalyticsEnabled");a(zre,"recordExistingAction");a(jre,"recordNewAction");a(sr,"recordAction");We.recordAnalytics=sr;a(Xn,"recordActionBinary");QE=0,mH=1e3,EH="analytics-report",gH=[];a(W_,"addAnalyticsListener");SH=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(Jre,"sendAnalytics");a(ZE,"storeMetric");a(TH,"calculateCPUUtilization");a(AH,"diffResourceUsage");a(Qre,"storeTableSizeMetrics");a(rH,"storeDBSizeMetrics");a(nH,"storeVolumeMetrics");a(Xre,"aggregation");sH=0,iH=0,$_={},RH=a(()=>new Promise(setImmediate),"rest");a(oH,"cleanup");Zre=36e5,ene=31536e6;a(_O,"getRawAnalyticsTable");a(yH,"getAnalyticsTable");(0,dH.setChildListenerByType)(EH,OH);a(tne,"startScheduledTasks");lH=0,uH=new Map,rne=!1;a(OH,"recordAnalytics");nne=1e6;a(sne,"logAnalytics")});var wH={};Ue(wH,{Headers:()=>bo,appendHeader:()=>eg,mergeHeaders:()=>pO});function eg(e,t,r,n){if(e.append)e.append(t,r,n);else if(e.set){let s=e.get(t);if(s)if(n)r=(typeof s=="string"?s:s.join(", "))+", "+r;else if(typeof s=="string")r=[s,r];else{s.push(r);return}return e.set(t,r)}else e[t]=(e[t]?e[t]+", ":"")+r}function pO(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new bo(e));for(let[r,n]of t)e.has(r)?r.toLowerCase()==="set-cookie"&&e.append?.(r,n,!0):e.set(r,n);return e}var bo,j_=be(()=>{bo=class extends Map{static{a(this,"Headers")}constructor(t){if(t)if(t[Symbol.iterator])super(t);else{super();for(let r in t)this.set(r,t[r])}else super()}set(t,r){return typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r),super.set(t.toLowerCase(),[t,r])}get(t){return typeof t!="string"&&(t=""+t),super.get(t.toLowerCase())?.[1]}has(t){return typeof t!="string"&&(t=""+t),super.has(t.toLowerCase())}setIfNone(t,r){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let n=t.toLowerCase();if(!super.has(n))return super.set(n,[t,r])}append(t,r,n){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let s=t.toLowerCase(),i=super.get(s);if(i){let o=i[1];if(n)r=(typeof o=="string"?o:o.join(", "))+", "+r;else if(typeof o=="string")r=[o,r];else{o.push(r);return}}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}};a(eg,"appendHeader");a(pO,"mergeHeaders")});function LH(e){let t={openapi:ine,info:{title:"HarperDB HTTP REST interface",version:DH.packageJson.version},paths:{},components:{schemas:{},securitySchemes:{basicAuth:{type:"http",scheme:"basic"},bearerAuth:{type:"http",scheme:"bearer",bearerFormat:"JWT"}}}},r=[{basicAuth:[],bearerAuth:[]}];for(let[,n]of e){if(!n.path||n.Resource.isError)continue;let{path:s}=n,i=s.split("/").slice(-1),{attributes:o,primaryKey:c,prototype:l}=n.Resource;if(c=c??"id",!c)continue;let u={},f=[];if(o)for(let{type:A,name:N,elements:v,relationship:F,definition:$}of o){if(F)A==="array"?u[N]={type:"array",items:{$ref:Da+v.type}}:u[N]={$ref:Da+A};else{let Y=$??v?.definition;if(Y){if(!t.components.schemas[Y.type]){let ee={};Y.properties.forEach(oe=>{ee[oe.name]=new gO(hO[oe.type],oe.type)}),t.components.schemas[Y.type]=new PH(ee)}A==="array"?u[N]={type:"array",items:{$ref:Da+Y.type}}:u[N]={$ref:Da+Y.type}}else A==="array"?v.type==="Any"||v.type=="ID"?u[N]={type:"array",items:{format:v.type}}:u[N]={type:"array",items:new gO(hO[v.type],v.type)}:A==="Any"||A=="ID"?u[N]={format:A}:u[N]=new gO(hO[A],A)}f.push(new SO(N,"query",u[N]))}let d=Object.keys(u),p=new SO(c,"path",{format:"ID"});p.required=!0,p.description="primary key of record";let _=new SO("property","path",{enum:d});_.required=!0,t.components.schemas[i]=new PH(u);let h=l.post!==Resource.prototype.post||l.update,S=typeof l.put=="function",g=typeof l.get=="function",R=typeof l.delete=="function",E="/"+s+"/";h&&(t.paths[E]={},t.paths[E].post=new one(i,r,"create a new record auto-assigning a primary key")),g&&(t.paths[E]||(t.paths[E]={}),t.paths[E].get=new mO(f,r,{200:new EO({$ref:Da+i})},"search for records by the specified property name and value pairs")),R&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new CH(f,r,"delete all the records that match the provided query",{204:new IH})),E="/"+s+"/{"+c+"}",g&&(t.paths[E]={},t.paths[E].get=new mO([p],r,{200:new EO({$ref:Da+i})},"retrieve a record by its primary key")),S&&(t.paths[E]||(t.paths[E]={}),t.paths[E].put=new ane([p],r,i,"create or update the record with the URL path that maps to the record's primary key")),R&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new CH([p],r,"delete a record with the given primary key",{204:new IH})),g&&_.schema.enum.length>0&&(E="/"+s+"/{"+c+"}.{property}",t.paths[E]={},t.paths[E].get=new mO([p,_],r,{200:new EO({enum:d})},"used to retrieve the specified property of the specified record"))}return t}function one(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:Da+e}}}},this.security=t,this.responses={200:{description:TO,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function mO(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function EO(e){this.description=TO,this.content={"application/json":{schema:e}}}function IH(){this.description="successfully processed request, no content returned to client"}function ane(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:Da+r}}}},this.responses={200:{description:TO}}}function CH(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function PH(e){this.type="object",this.properties=e}function gO(e,t){this.type=e,this.format=t}function SO(e,t,r){this.name=e,this.in=t,this.schema=r}var DH,ine,hO,Da,TO,MH=be(()=>{DH=M(st()),ine="3.0.3",hO={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},Da="#/components/schemas/",TO="successful operation";a(LH,"generateJsonApi");a(one,"Post");a(mO,"Get");a(EO,"Response200");a(IH,"Response204");a(ane,"Put");a(CH,"Delete");a(PH,"ResourceSchema");a(gO,"Type");a(SO,"Parameter")});var rg={};Ue(rg,{parseHeaderValue:()=>RO,start:()=>une});async function lne(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream",s=n?"CONNECT":e.method;e.search&&Nm(e);let i=new bo;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==vH){let g=tg.getMatch(o,n?"sse":"rest");if(!g)return t(e);e.handlerPath=g.path,c=new Pc(g.relativeURL),c.async=!0,l=g.Resource}if(l?.isCaching){let g=r["cache-control"];if(g){let R=RO(g);for(let E of R)switch(E.name){case"max-age":e.expiresAt=E.value*1e3+Date.now();break;case"only-if-cached":e.onlyIfCached=!0;break;case"no-cache":e.noCache=!0;break;case"no-store":e.noCacheStore=!0;break;case"stale-if-error":e.staleIfError=!0;break;case"must-revalidate":e.mustRevalidate=!0;break}}}let u=r["x-replicate-to"];if(u){let g=RO(u).map(R=>(R.next?.name==="confirm"&&R.next.value>=0&&(e.replicatedConfirmation=+R.next.value),R.name));e.replicateTo=g.length===1&&+g[0]>=0?+g[0]:g[0]==="*"?void 0:g}r["x-replicate-from"]==="none"&&(e.replicateFrom=!1);let d=await Nt(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=fo(r["content-type"],!0)(e.body,e.headers)}catch(g){throw new Wu.ClientError(g,400)}if(e.authorize=!0,o===vH&&s==="GET"){if(e?.user?.role?.permission?.super_user)return LH(tg);throw new Wu.ServerError("Forbidden",403)}switch(s){case"GET":case"HEAD":return l.get(c,e);case"POST":return l.post(c,e.data,e);case"PUT":return l.put(c,e.data,e);case"DELETE":return l.delete(c,e);case"PATCH":return l.patch(c,e.data,e);case"OPTIONS":i.setIfNone("Allow","GET, HEAD, POST, PUT, DELETE, PATCH, OPTIONS, TRACE, QUERY, COPY, MOVE");return;case"CONNECT":return l.connect(c,null,e);case"TRACE":return"HarperDB is the terminating server";case"QUERY":return l.query(c,e.data,e);case"COPY":return l.copy(c,r.destination,e);case"MOVE":return l.move(c,r.destination,e);case"BREW":throw new Wu.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Wu.ServerError(`Method ${s} is not recognized`,501)}}),p=200,_;if(d==null)p=s==="GET"||s==="HEAD"?404:204,AO.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(d.status>0&&d.headers){let g=pO(d.headers,i);return d.headers!==g&&(d.headers=g),d.data!==void 0&&(d.body=Qf(d.data,e,d)),d}else if(_=e.lastModified){cne[0]=_;let g=String.fromCharCode(34,(Mr[0]&63)+62,(Mr[0]>>6)+(Mr[1]<<2&63)+62,(Mr[1]>>4)+(Mr[2]<<4&63)+62,(Mr[2]>>2)+62,(Mr[3]&63)+62,(Mr[3]>>6)+(Mr[4]<<2&63)+62,(Mr[4]>>4)+(Mr[5]<<4&63)+62,(Mr[5]>>2)+62,(Mr[6]&63)+62,(Mr[6]>>6)+(Mr[7]<<2&63)+62,34),R=r["if-none-match"];R&&g==R?(d?.onDone&&d.onDone(),p=304,d=void 0):i.setIfNone("ETag",g),AO.lastModified&&i.setIfNone("Last-Modified",new Date(_).toUTCString())}e.createdResource&&(p=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let h={status:p,headers:i,body:void 0},S=d?.wasLoadedFromSource?.();return S!==void 0&&(h.wasCacheMiss=S,!S&&_&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||_))/1e3))),d!==void 0&&(h.body=Qf(d,e,h),s==="HEAD"&&(h.body=void 0)),h}catch(o){o.statusCode?o.statusCode===500?Gi.warn(o):Gi.info(o):Gi.error(o),o.statusCode===405&&(o.method&&(o.message+=` to handle HTTP method ${o.method.toUpperCase()||""}`),o.allow&&(o.allow.push("trace","head","options"),i.setIfNone("Allow",o.allow.map(l=>l.toUpperCase()).join(", "))));let c={status:o.statusCode||500,headers:i,body:void 0};return c.body=Qf(o.contentType?o:o.toString(),e,c),c}}function une(e){AO=e,!UH&&(UH=!0,tg=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return lne(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{J_++;let s=new Hn;xH||(xH=!0,W_(l=>{J_>0&&l.push({metric:"ws-connections",connections:J_,byThread:!0})}));let i;t.on("error",l=>{i=!0,Gi.warn(l)});let o;t.on("message",a(function(u){o||(o=fo(r.requestedContentType??r.headers.asObject["content-type"],!1));let f=o(u);sr(u.length,"bytes-received",r.handlerPath,"message","ws"),s.push(f)},"message"));let c;t.on("close",()=>{J_--,Xn(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),u=tg.getMatch(l,"ws");if(Xn(!!u,"connection","ws","connect"),u){r.handlerPath=u.path,sr(h=>({count:h.count,total:J_}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let f=new Pc(u.relativeURL),d=u.Resource;c=(await Nt(r,()=>d.connect(f,s,r)))[Symbol.asyncIterator]();let _;for(;!(_=await c.next()).done;){let h=await Ra(_.value,r);t.send(h),sr(h.length,"bytes-sent",r.handlerPath,"message","ws"),t._socket.writableNeedDrain&&await new Promise(S=>t._socket.once("drain",S))}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){l.statusCode?l.statusCode===500?Gi.warn(l):Gi.info(l):Gi.error(l),t.close(dne[l.statusCode]||1011,l.toString())}t.close()},e))}function RO(e){return e.trim().split(",").map(t=>{let r,n=t.trim().split(";"),s;for(;s=n.pop();)if(s.includes("=")){let[i,o]=s.trim().split("=");i=i.trim(),o&&(o=o.trim()),r={name:i.toLowerCase(),value:o,next:r}}else r={name:s.toLowerCase(),next:r};return r})}var Gi,Wu,Mr,cne,AO,vH,UH,tg,xH,J_,dne,BH=be(()=>{co();Fi();Gi=M(W()),Wu=M(pe());qf();hu();Cc();j_();MH();qf();Mr=new Uint8Array(8),cne=new Float64Array(Mr.buffer,0,1),AO={},vH="openapi";a(lne,"http");J_=0;a(une,"start");dne={401:3e3,403:3003};a(RO,"parseHeaderValue")});var yO=I((FCe,kH)=>{var{recordAction:ng,recordActionBinary:HH}=(Fi(),P(z_)),fne=require("fastify-plugin"),_ne=200;kH.exports=fne(function(e,t,r){e.addHook("onResponse",async(n,s)=>{let i=s.elapsedTime}),e.addHook("onSend",async(n,s,i)=>{let o=s.elapsedTime,c=performance.now(),l=s.request.routeOptions,u,f,d;l.config?.isOperation?(u=n.body?.operation,f="operation"):(u=l.url,f="fastify-route",d=l.method),ng(o,"duration",u,d,f),HH(s.raw.statusCode<400,"success",u,d,f),HH(1,"response_"+s.raw.statusCode,u,d,f);let p=_ne;i?.pipe?(i.on("data",g=>{p+=g.length}),i.on("end",()=>{ng(performance.now()-c,"transfer",u,d,f),ng(p,"bytes-sent",u,d,f)})):(p+=i?.length||0,ng(p,"bytes-sent",u,d,f));let _=o.toFixed(3),h=s.getHeader("Server-Timing"),S=`db;dur=${_}`;s.header("Server-Timing",h?`${h}, ${S}`:S)}),r()},{name:"hdb-request-time"})});var GH=I((GCe,FH)=>{var pne=it(),hne={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};FH.exports=function(e){return pne.validateObject(e,hne)}});var sg=I((qCe,qH)=>{"use strict";var mne=(H(),P(G)).OPERATIONS_ENUM,bO=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=mne.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};qH.exports=bO});var Z_={};Ue(Z_,{createTokens:()=>gne,getJWTRSAKeys:()=>lg,refreshOperationToken:()=>Sne,validateOperationToken:()=>wO,validateRefreshToken:()=>ug});async function lg(){if(ig)return ig;try{let e=Q_.default.join(X_.default.getHdbBasePath(),jA),t=await og.default.readFile(Q_.default.join(e,Nf.JWT_PASSPHRASE_NAME),"utf8"),r=await og.default.readFile(Q_.default.join(e,Nf.JWT_PRIVATE_KEY_NAME),"utf8");return ig={publicKey:await og.default.readFile(Q_.default.join(e,Nf.JWT_PUBLIC_KEY_NAME),"utf8"),privateKey:r,passphrase:t},ig}catch(e){throw cg.default.error(e),new oi.ClientError(ju.NO_ENCRYPTION_KEYS,zu.INTERNAL_SERVER_ERROR)}}async function gne(e){let t=(0,OO.validateBySchema)(e,qi.default.object({username:qi.default.string().optional(),password:qi.default.string().optional(),role:qi.default.string().optional(),expires_in:qi.default.alternatives(qi.default.string(),qi.default.number()).optional()}));if(t)throw new oi.ClientError(t.message);let r;try{let d=e.bypass_auth!==!0;!e.username&&!e.password&&(e.username=e.hdb_user?.username,d=!1),r=await(0,NO.findAndValidateUser)(e.username,e.password,d)}catch(d){throw cg.default.error(d),new oi.ClientError(ju.INVALID_CREDENTIALS,zu.UNAUTHORIZED)}if(!r)throw new oi.ClientError(ju.INVALID_CREDENTIALS,zu.UNAUTHORIZED);let n=!1,s=!1;r.role?.permission&&(n=r.role.permission.super_user===!0,s=r.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s};e.role&&(i.role=e.role);let o=await lg(),c=await Ju.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:e.expires_in??WH,algorithm:ag,subject:"operation"}),l=await Ju.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:Ene,algorithm:ag,subject:"refresh"}),u=Gy(l,"sha256");if((await(0,$H.update)(new VH.default(Of,_u.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]))).skipped_hashes.length>0)throw new oi.ClientError(ju.REFRESH_TOKEN_SAVE_FAILED,zu.INTERNAL_SERVER_ERROR);return KH.default.signalUserChange(new YH.UserEventMsg(process.pid)),{operation_token:c,refresh_token:l}}async function Sne(e){let t=(0,OO.validateBySchema)(e,qi.default.object({refresh_token:qi.default.string().required()}).required());if(t)throw new oi.ClientError(t.message);let{refresh_token:r}=e;await ug(r);let n=await lg(),s=await Ju.default.decode(r);return{operation_token:await Ju.default.sign({username:s.username,super_user:s.super_user,cluster_user:s.cluster_user},{key:n.privateKey,passphrase:n.passphrase},{expiresIn:WH,algorithm:ag,subject:"operation"})}}async function wO(e){return zH(e,"operation")}async function ug(e){return zH(e,"refresh")}async function zH(e,t){try{let r=await lg(),n=await Ju.default.verify(e,r.publicKey,{algorithms:ag,subject:t});if(n.role)throw new Error("Invalid token");let s=await(0,NO.findAndValidateUser)(n.username,void 0,!1);if(t==="refresh"&&!qy(s.refresh_token,e))throw new Error("Invalid token");return s}catch(r){throw cg.default.warn(r),r?.name==="TokenExpiredError"?new oi.ClientError(ju.TOKEN_EXPIRED,zu.FORBIDDEN):new oi.ClientError(ju.INVALID_TOKEN,zu.UNAUTHORIZED)}}var Ju,og,Q_,qi,OO,oi,cg,NO,$H,VH,KH,YH,X_,zu,ju,WH,Ene,ag,ig,Qu=be(()=>{Ju=M(require("jsonwebtoken")),og=M(require("fs-extra")),Q_=M(require("node:path")),qi=M(require("joi")),OO=M(it());H();oi=M(pe()),cg=M(W());mE();NO=M(yn()),$H=M(bn()),VH=M(sg()),KH=M(Ao()),YH=M(ni()),X_=M(ce()),{HTTP_STATUS_CODES:zu,AUTHENTICATION_ERROR_MSGS:ju}=oi.hdb_errors;X_.default.initSync();WH=X_.default.get(x.AUTHENTICATION_OPERATIONTOKENTIMEOUT)||"1d",Ene=X_.default.get(x.AUTHENTICATION_REFRESHTOKENTIMEOUT)||"30d",ag="RS256";a(lg,"getJWTRSAKeys");a(gne,"createTokens");a(Sne,"refreshOperationToken");a(wO,"validateOperationToken");a(ug,"validateRefreshToken");a(zH,"validateToken")});var IO=I((WCe,QH)=>{"use strict";var Tne=GH(),Xu=require("passport"),Ane=require("passport-local").Strategy,Rne=require("passport-http").BasicStrategy,yne=require("util"),bne=yn(),JH=yne.callbackify(bne.findAndValidateUser),YCe=Bn(),One=(H(),P(G)),jH=(Qu(),P(Z_));Xu.use(new Ane(function(e,t,r){JH(e,t,r)}));Xu.use(new Rne(function(e,t,r){JH(e,t,r)}));Xu.serializeUser(function(e,t){t(null,e)});Xu.deserializeUser(function(e,t){t(null,e)});function Nne(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":Xu.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===One.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?jH.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):jH.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:Xu.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(Nne,"authorize");function wne(e,t){let r=Tne(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(wne,"checkPermissions");QH.exports={authorize:Nne,checkPermissions:wne}});var dg=I((jCe,XH)=>{"use strict";var Ine=Kn();XH.exports={writeTransaction:Cne};function Cne(e,t,r){return Ine.writeTransaction(e,t,r)}a(Cne,"writeTransaction")});var rk=I((XCe,tk)=>{"use strict";var Pne=Wr(),Dne=Rs(),ZH=W(),Lne=bn(),QCe=dg(),Mne=require("clone"),PO=require("alasql"),vne=cE(),ek=require("util"),Une=ek.promisify(Dne.getTableSchema),xne=ek.promisify(Pne.search),Bne=(H(),P(G)),CO=ae();vne(PO);tk.exports={update:kne};var Hne="There was a problem performing this update. Please check the logs and try again.";async function kne({statement:e,hdb_user:t}){let r=await Une(e.table.databaseid,e.table.tableid),n=Fne(e.columns);CO.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=Mne(s),c=CO.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=PO.parse(l).statements[0],f=await xne(u),d=Gne(n,f);return qne(o,d,t)}a(kne,"update");function Fne(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=PO.compile(`SELECT ${r.expression.toString()} AS [${Bne.FUNC_VAL}] FROM ?`)}),t}catch(t){throw ZH.error(t),new Error(Hne)}}a(Fne,"createUpdateRecord");function Gne(e,t){return CO.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(Gne,"buildUpdateRecords");async function qne(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await Lne.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){ZH.error(`Error delete new_attributes from update response: ${i}`)}return s}a(qne,"updateRecords")});var sk=I((rPe,nk)=>{var $ne=require("alasql"),Vne=Wr(),Kne=W(),Yne=Kn(),LO=require("util"),DO=ae(),Wne=(H(),P(G)),zne=Rs(),ePe=dg(),tPe=bn(),jne="record",Jne="successfully deleted",Qne=LO.callbackify(tse),Xne=LO.promisify(Vne.search),Zne=LO.promisify(zne.getTableSchema);nk.exports={convertDelete:Qne};function ese(e){return`${e.deleted_hashes.length} ${jne}${e.deleted_hashes.length===1?"":"s"} ${Jne}`}a(ese,"generateReturnMessage");async function tse({statement:e,hdb_user:t}){let r=await Zne(e.table.databaseid,e.table.tableid);DO.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=DO.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=$ne.parse(o).statements[0],l={operation:Wne.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await Xne(c);let u=await Yne.deleteRecords(l);return DO.isEmptyOrZeroLength(u.message)&&(u.message=ese(u)),delete u.txn_time,u}catch(u){throw Kne.error(u),u.hdb_code?u.message:u}}a(tse,"convertDelete")});var lk=I((sPe,ck)=>{"use strict";var rse=So(),{hdb_errors:ik}=pe(),{getDatabases:ok}=(De(),P(nt));ck.exports={checkSchemaExists:ak,checkSchemaTableExists:nse,schema_describe:rse};async function ak(e){if(!ok()[e])return ik.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(ak,"checkSchemaExists");async function nse(e,t){let r=await ak(e);if(r)return r;if(!ok()[e][t])return ik.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(nse,"checkSchemaTableExists")});var BO=I((lPe,Ak)=>{"use strict";var{decode:sse}=require("msgpackr"),{isMainThread:oPe,parentPort:aPe,threadId:cPe}=require("worker_threads"),pg=ir(),Zu=St(),UO=(H(),P(G)),Qr=W(),vO=ce(),ise=(H(),P(G)),{onMessageByType:ose}=rt(),_k=go(),{recordAction:uk,recordActionBinary:ase}=(Fi(),P(z_)),{publishToStream:cse}=pg,{ConsumerEvents:dk}=require("nats"),lse=Wr(),{promisify:use}=require("util"),{decodeBlobsWithWrites:dse}=(Ss(),P(qm)),pk=use(setTimeout),hg=1e4,mg,_g,fse,_se,hk,ep=new Map,ed=new Map;Ak.exports={initialize:mk,ingestConsumer:xO,setSubscription:pse,setIgnoreOrigin:Ese,getDatabaseSubscriptions:mse,updateConsumer:Ek};async function mk(){ose(UO.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await Ek(n)}),hk=!0,Qr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await pg.getNATSReferences();mg=e,_g=e.info.server_name,fse=t,_se=r}a(mk,"initialize");async function Ek(e){if(e.status==="start"){let{js:t,jsm:r}=await gk(e.node_domain_name);xO(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=ep.get(e.stream_name+e.node_domain_name);t&&(Qr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),ep.set(e.stream_name+e.node_domain_name,"close")),ed.get(e.node_domain_name)==="failed"&&ed.set(e.node_domain_name,"close")}}a(Ek,"updateConsumer");var Eg=new Map;function pse(e,t,r){let n=Eg.get(e);n||Eg.set(e,n=new Map),n.set(t,r),hk||mk().then(hse)}a(pse,"setSubscription");async function hse(){let e=await lse.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+Zu.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions||[])if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await gk(r),!n))break;let{schema:o,table:c}=i,l=_k.createNatsTableStreamName(o,c);xO(l,n,s,r)}}}a(hse,"accessConsumers");async function gk(e){let t,r,n=1;for(;!r;)try{t=await mg.jetstream({domain:e}),r=await mg.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(ed.get(e)==="close")break;ed.set(e,"failed"),n%10===1&&Qr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<hg?n++*100:hg;await pk(i)}return{js:t,jsm:r}}a(gk,"connectToRemoteJS");function mse(){return Eg}a(mse,"getDatabaseSubscriptions");var Sk;function Ese(e){Sk=e}a(Ese,"setIgnoreOrigin");var Tk=100,fk=new Array(Tk),fg=0;async function xO(e,t,r,n){let{connection:s}=await pg.getNATSReferences();mg=s,_g=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,_g),Qr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(ed.get(n)==="close")break;o%10===1&&Qr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",u.message),u.code==="404"&&(Qr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await pg.createConsumer(r,e,_g,new Date(Date.now()).toISOString()));let f=o++*100<hg?o++*100:hg;await pk(f)}let c=!1,l;for(;!c;){if(ep.get(e+n)==="close"||ed.get(n)==="close"){ep.delete(e+n),c=!0;continue}l=await i.consume({max_messages:vO.get(UO.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),ep.set(e+n,l);let u=!1;(async()=>{for await(let f of await l.status())if(f.type===dk.ConsumerDeleted&&(await l.close(),c=!0),f.type===dk.HeartbeatsMissed){let d=f.data;Qr.trace(`${d} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),d===100&&(Qr.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${l.consumer.stream}`),l.stop(),u=!0)}})();try{for await(let f of l)await fk[fg],fk[fg]=gse(f).catch(d=>{Qr.error(d)}),++fg>=Tk&&(fg=0)}catch(f){f.message==="consumer deleted"?(Qr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):Qr.error("Error consuming clustering ingest, restarting consumer",f)}}}a(xO,"ingestConsumer");async function gse(e){let t;await dse(()=>{t=sse(e.data)}),uk(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),Qr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=vO.get(UO.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(Zu.MSG_HEADERS.TRANSACTED_NODES)&&r.values(Zu.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(Zu.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!Sk),ase(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(Zu.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:u,records:f,hash_values:d,__origin:p,expiresAt:_}=t;Qr.trace("processing message:",o,c,u,(f?"records: "+f.map(v=>v?.id):"")+(d?"ids: "+d:""),"with sequence:",e.seq),Qr.trace(`messageProcessor nats msg id: ${e.headers.get(Zu.MSG_HEADERS.NATS_MSG_ID)}`);let h;f||(f=d);let S=new Promise(v=>h=v),{timestamp:g,user:R,node_name:E}=p||{},A=Eg.get(c)?.get(u);if(!A)throw new Error(`Missing table for replication message: ${u}`);if(o==="define_schema")t.type=o,t.onCommit=h,A.send(t);else if(f.length===1&&!l)A.send({type:MO(o),value:f[0],id:d?.[0],expiresAt:_,timestamp:g,table:u,onCommit:h,user:R,nodeName:E});else{let v=f.map((F,$)=>({type:MO(o),value:F,expiresAt:_,id:d?.[$],table:u}));for(;l;)v.push({type:MO(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;A.send({type:"transaction",writes:v,table:u,timestamp:g,onCommit:h,user:R,nodeName:E})}vO.get(ise.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&cse(e.subject.split(".").slice(0,-1).join("."),_k.createNatsTableStreamName(c,u),e.headers,e.data),await S;let N=Date.now()-g;g&&uk(N,"replication-latency",e.subject,o,"ingest")}catch(o){Qr.error(o)}e.ack()}a(gse,"messageProcessor");function MO(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(MO,"convertOperation")});var ir=I((mPe,Hk)=>{"use strict";var wr=ce();wr.initSync();var Sse=require("fs-extra"),Tse=require("semver"),np=require("path"),{monotonicFactory:Ase}=require("ulidx"),yk=Ase(),Rse=require("util"),bk=require("child_process"),yse=Rse.promisify(bk.exec),bse=bk.spawn,vr=St(),Ve=(H(),P(G)),{packageJson:Ose,PACKAGE_ROOT:Nse}=st(),gg=ae(),ai=W(),Sg=go(),wse=dg(),tp=Rt(),{broadcast:Ise,onMessageByType:Cse,getWorkerIndex:Pse}=rt(),{isMainThread:Ok}=require("worker_threads"),{Encoder:Dse,decode:GO}=require("msgpackr"),Nk=new Dse,{isEmpty:pl}=gg,wk=yn(),dPe=48*36e11;Ok&&Cse(Ve.ITC_EVENT_TYPES.RESTART,()=>{Xr=void 0,_l=void 0});var{connect:Lse,StorageType:Mse,RetentionPolicy:vse,AckPolicy:qO,DeliverPolicy:$O,DiscardPolicy:Use,NatsConnection:fPe,JetStreamManager:_Pe,JetStreamClient:pPe,StringCodec:hPe,JSONCodec:xse,createInbox:VO,headers:Bse,ErrorCode:Rk}=require("nats"),{recordAction:Hse}=(Fi(),P(z_)),{encodeBlobsAsBuffers:kse}=(Ss(),P(qm)),Ik=xse(),Fse="clustering",Gse=Ose.engines[vr.NATS_SERVER_NAME],qse=np.join(Nse,"dependencies"),FO=np.join(qse,`${process.platform}-${process.arch}`,vr.NATS_BINARY_NAME),HO,kO,rp,dl,fl;Hk.exports={runCommand:Ck,checkNATSServerInstalled:$se,createConnection:KO,getConnection:sp,getJetStreamManager:ip,getJetStream:Dk,getNATSReferences:$i,getServerList:Kse,createLocalStream:YO,listStreams:Lk,deleteLocalStream:Yse,getServerConfig:td,listRemoteStreams:Wse,viewStream:zse,viewStreamIterator:jse,publishToStream:Jse,request:Zse,reloadNATS:WO,reloadNATSHub:eie,reloadNATSLeaf:tie,extractServerName:Xse,requestErrorHandler:rie,createLocalTableStream:xk,createTableStreams:iie,purgeTableStream:Bk,purgeSchemaTableStreams:oie,getStreamInfo:aie,updateLocalStreams:lie,closeConnection:Vse,getJsmServerName:Tg,addNatsMsgHeader:Mk,clearClientCache:Pk,updateRemoteConsumer:nie,createConsumer:vk,updateConsumerIterator:sie};async function Ck(e,t=void 0){let{stdout:r,stderr:n}=await yse(e,{cwd:t});if(n)throw new Error(n.replace(`
22
22
  `,""));return r.replace(`
23
- `,"")}a(Ck,"runCommand");async function $se(){try{await Sse.access(kO)}catch{return!1}let e=await Ck(`${kO} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return Tse.eq(t,Gse)}a($se,"checkNATSServerInstalled");async function VO(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await wk.getClusterUser();if(_l(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}oi.trace("create nats connection called");let i=await Lse({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:wr.get($e.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:wr.get($e.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:wr.get($e.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),oi.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&oi.error("Error with Nats client connection, connection closed",o),i===Qr&&Pk()}),i}a(VO,"createConnection");function Pk(){Qr=void 0,ul=void 0,dl=void 0,fl=void 0}a(Pk,"clearClientCache");async function Vse(){Qr&&(await Qr.drain(),Qr=void 0,ul=void 0,dl=void 0,fl=void 0)}a(Vse,"closeConnection");var Qr,fl;async function np(){return fl||(fl=VO(wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),Qr=await fl),Qr||fl}a(np,"getConnection");async function sp(){if(ul)return ul;_l(Qr)&&await np();let{domain:e}=ed($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(_l(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return ul=await Qr.jetstreamManager({domain:e,timeout:6e4}),ul}a(sp,"getJetStreamManager");async function Dk(){if(dl)return dl;_l(Qr)&&await np();let{domain:e}=ed($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(_l(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return dl=Qr.jetstream({domain:e,timeout:6e4}),dl}a(Dk,"getJetStream");async function qi(){let e=Qr||await np(),t=ul||await sp(),r=dl||await Dk();return{connection:e,jsm:t,js:r}}a(qi,"getNATSReferences");async function Kse(e){let t=wr.get($e.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await wk.getClusterUser(),s=await VO(t,r,n),i=$O(),o=s.subscribe(i),c=[],l,u=(async()=>{for await(let f of o){let d=Ik.decode(f.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 Eg.async_set_timeout(e),await o.drain(),await s.close(),await u,c}a(Kse,"getServerList");async function KO(e,t){let{jsm:r}=await qi(),n=wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:Mse.File,retention:vse.Limits,subjects:t,discard:Use.Old,max_msgs:s,max_bytes:i,max_age:n})}a(KO,"createLocalStream");async function Lk(){let{jsm:e}=await qi(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(Lk,"listStreams");async function Yse(e){let{jsm:t}=await qi();await t.streams.delete(e)}a(Yse,"deleteLocalStream");async function Wse(e){let{connection:t}=await qi(),r=[],n=$O(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(Ik.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(Wse,"listRemoteStreams");async function zse(e,t=void 0,r=void 0){let{jsm:n,js:s}=await qi(),i=yk(),o={durable_name:i,ack_policy:GO.Explicit};t&&(o.deliver_policy=qO.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let u=[];for await(let f of l){let d=FO(f.data),p={nats_timestamp:f.info.timestampNanos,nats_sequence:f.info.streamSequence,entry:d};if(f.headers&&(p.origin=f.headers.get(vr.MSG_HEADERS.ORIGIN)),u.push(p),f.ack(),f.info.pending===0)break}return await c.delete(),u}a(zse,"viewStream");async function*jse(e,t=void 0,r=void 0){let{jsm:n,js:s}=await qi(),i=yk(),o={durable_name:i,ack_policy:GO.Explicit};t&&(o.deliver_policy=qO.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let u of l){let f=FO(u.data);f[0]||(f=[f]);for(let d of f){let p={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:d};u.headers&&(p.origin=u.headers.get(vr.MSG_HEADERS.ORIGIN)),yield p}if(u.ack(),u.info.pending===0)break}await c.delete()}a(jse,"viewStreamIterator");async function Jse(e,t,r,n){oi.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=Mk(n,r);let{js:s}=await qi(),i=await Sg(),o=`${e}.${i}`,c=await kse(()=>n instanceof Uint8Array?n:Nk.encode(n));try{oi.trace(`publishToStream publishing to subject: ${o}`),Hse(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 Uk(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){oi.trace(`publishToStream creating stream: ${t}`);let f=o.split(".");f[2]="*",await KO(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(Jse,"publishToStream");function Mk(e,t){t===void 0&&(t=Bse());let r=wr.get($e.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(vr.MSG_HEADERS.ORIGIN)&&r&&t.append(vr.MSG_HEADERS.ORIGIN,r),t}a(Mk,"addNatsMsgHeader");function ed(e){e=e.toLowerCase();let t=rp.join(wr.get($e.CONFIG_PARAMS.ROOTPATH),Fse);if(e===$e.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return _l(HO)&&(HO={port:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+vr.SERVER_SUFFIX.HUB,config_file:vr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:rp.join(t,vr.PID_FILES.HUB),hdb_nats_path:t}),HO;if(e===$e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return _l(BO)&&(BO={port:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+vr.SERVER_SUFFIX.LEAF,config_file:vr.NATS_CONFIG_FILES.LEAF_SERVER,domain:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+vr.SERVER_SUFFIX.LEAF,pid_file_path:rp.join(t,vr.PID_FILES.LEAF),hdb_nats_path:t}),BO;oi.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(ed,"getServerConfig");async function vk(e,t,r,n){try{await e.consumers.add(t,{ack_policy:GO.Explicit,durable_name:r,deliver_policy:qO.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(vk,"createConsumer");async function Qse(e,t,r){await e.consumers.delete(t,r)}a(Qse,"removeConsumer");function Xse(e){return e.split(".")[1]}a(Xse,"extractServerName");async function Zse(e,t,r=6e4,n=$O()){if(!Eg.isObject(t))throw new Error("data param must be an object");let s=Nk.encode(t),{connection:i}=await qi(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return FO(c.data)}a(Zse,"request");function YO(e){return new Promise(async(t,r)=>{let n=bse(kO,["--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(YO,"reloadNATS");async function eie(){let{pid_file_path:e}=ed($e.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await YO(e)}a(eie,"reloadNATSHub");async function tie(){let{pid_file_path:e}=ed($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await YO(e)}a(tie,"reloadNATSLeaf");function rie(e,t,r){let n;switch(e.code){case Rk.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case Rk.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(rie,"requestErrorHandler");async function nie(e,t){let r=t+vr.SERVER_SUFFIX.LEAF,{connection:n}=await qi(),{jsm:s}=await die(r),{schema:i,table:o}=e,c=gg.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await Uk(async()=>{if(e.subscribe===!0)await vk(s,c,n.info.server_name,l);else try{await Qse(s,c,n.info.server_name)}catch(u){oi.trace(u)}})}a(nie,"updateRemoteConsumer");async function sie(e,t,r,n){let s=gg.createNatsTableStreamName(e,t),i=r+vr.SERVER_SUFFIX.LEAF,o={type:$e.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!Ok&&Pse()<wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=xO();await c(o)}await Ise(o),n==="stop"&&await Eg.async_set_timeout(1e3)}a(sie,"updateConsumerIterator");function Uk(e){return wse.writeTransaction($e.SYSTEM_SCHEMA_NAME,$e.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(Uk,"exclusiveLock");async function xk(e,t){let r=gg.createNatsTableStreamName(e,t),n=await Sg(),s=cie(e,t,n);await KO(r,[s])}a(xk,"createLocalTableStream");async function iie(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await xk(n,s)}}a(iie,"createTableStreams");async function Bk(e,t,r=void 0){if(wr.get($e.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=gg.createNatsTableStreamName(e,t),{domain:s}=ed($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await np()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")oi.warn(n);else throw n}}a(Bk,"purgeTableStream");async function oie(e,t){if(wr.get($e.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await Bk(e,t[r])}a(oie,"purgeSchemaTableStreams");async function aie(e){return(await sp()).streams.info(e)}a(aie,"getStreamInfo");function cie(e,t,r){return`${vr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(cie,"createSubjectName");async function Sg(){if(tp)return tp;if(tp=(await sp())?.nc?.info?.server_name,tp===void 0)throw new Error("Unable to get jetstream manager server name");return tp}a(Sg,"getJsmServerName");async function lie(){let e=await sp(),t=await Sg(),r=await Lk();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=uie(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let u=i.split(".");u[u.length-1]=t;let f=u.join(".");oi.trace(`Updating stream subject name from: ${i} to: ${f}`),s.subjects[0]=f,await e.streams.update(s.name,s)}}a(lie,"updateLocalStreams");function uie(e){let{config:t}=e,r=!1,n=wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=wr.get($e.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(uie,"updateStreamLimits");async function die(e){let t,r;try{t=await Qr.jetstream({domain:e}),r=await Qr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw oi.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(die,"connectToRemoteJS")});function WO(e){let t=e.get(Tg),r=t?(0,td.unpack)(t):null;r||(r={remoteNameToId:{}});let n=Ze(),s=!1;r.nodeName=Ze();let i=r.remoteNameToId;if(i[n]!==0){let o=0,c;for(let l in i){let u=i[l];u===0?c=l:u>o&&(o=u)}if(c){o++,i[c]=o;let l=[Symbol.for("seq"),o];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:op(e)??1,nodes:[]})})}i[n]=0,e.putSync(Tg,(0,td.pack)(r))}return r}function ip(e){return WO(e).remoteNameToId}function Fk(e,t){let r=WO(t),n=r.remoteNameToId,s=new Map,i=!1;for(let o in e){let c=e[o],l=n[o];if(l==null){let u=0;for(let f in n){let d=n[f];d>u&&(u=d)}l=u+1,n[o]=l,i=!0}s.set(c,l)}return i&&t.putSync(Tg,(0,td.pack)(r)),s}function Ag(e,t){let r=WO(t),n=r.remoteNameToId,s=n[e];if(s==null){let i=0;for(let o in n){let c=n[o];c>i&&(i=c)}s=i+1,n[e]=s,t.putSync(Tg,(0,td.pack)(r))}return kk.trace?.("The remote node name map",e,n,s),s}var kk,td,Tg,zO=be(()=>{kk=M(Ni());Xn();td=require("msgpackr"),Tg=Symbol.for("remote-ids");a(WO,"getIdMappingRecord");a(ip,"exportIdMapping");a(Fk,"remoteToLocalNodeId");a(Ag,"getIdOfRemoteNode")});var jO={};ve(jO,{commits_awaiting_replication:()=>nd,getHDBNodeTable:()=>or,getReplicationSharedStatus:()=>Rg,iterateRoutes:()=>cp,shouldReplicateToNode:()=>ap,subscribeToNodeUpdates:()=>sd});function or(){return Gk||(Gk=ft({table:"hdb_nodes",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"ca"},{attribute:"ca_info"},{attribute:"replicates"},{attribute:"revoked_certificates"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function Rg(e,t,r,n){return new Float64Array(e.getUserSharedBuffer(["replicated",t,r],new ArrayBuffer(32),n&&{callback:n}))}function sd(e){or().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;Kk.debug?.("adding node",n,"on node",Ze()," on process",process.pid),server.nodes=server.nodes.filter(i=>i.name!==n),r.type==="put"&&n!==Ze()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r));let s=new Map;for await(let i of or().search({}))if(i.shard!=null){let o=s.get(i.shard);o||s.set(i.shard,o=[]),o.push(i)}server.shards=s,(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function ap(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&or().primaryStore.get(Ze())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function fie(){sd(e=>{Da({},(t,r)=>{let n=e.name,s=qk.get(n);if(s||qk.set(n,s=new Map),s.has(r))return;let i;for(let o in t)if(i=t[o].auditStore,i)break;if(i){let o=Rg(i,r,n,()=>{let c=o[0],l=o.lastTime;for(let{txnTime:u,onConfirm:f}of nd.get(r)||[])u>l&&u<=c&&f();o.lastTime=c});o.lastTime=0,s.set(r,o)}})})}function*cp(e){for(let t of e.routes||[]){let r=t.url,n;if(typeof t=="string"?t.includes("://")?r=t:n=t:n=t.hostname??t.host,n&&!r){let s=rd.default.get(x.REPLICATION_SECUREPORT)??(!rd.default.get(x.REPLICATION_PORT)&&rd.default.get(x.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||rd.default.get(x.REPLICATION_PORT)||rd.default.get(x.OPERATIONSAPI_NETWORK_PORT);let o=i?.lastIndexOf?.(":");o>0&&(i=+i.slice(o+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){$k.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{replicates:!t.subscriptions,url:r,subscription:t.subscriptions,routes:t.routes,start_time:t.startTime,revoked_certificates:t.revokedCertificates,shard:t.shard}}}var $k,Vk,rd,Kk,Gk,qk,nd,pl=be(()=>{De();Xn();Rm();$k=require("worker_threads"),Vk=M(pe()),rd=M(ae());H();Kk=M(Ni());server.nodes=[];a(or,"getHDBNodeTable");a(Rg,"getReplicationSharedStatus");a(sd,"subscribeToNodeUpdates");a(ap,"shouldReplicateToNode");qk=new Map;RL((e,t,r)=>{if(r>server.nodes.length)throw new Vk.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);nd||(nd=new Map,fie());let n=nd.get(e);return n||(n=[],nd.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(fie,"startSubscriptionToReplications");a(cp,"iterateRoutes")});var jk={};ve(jk,{connectedToNode:()=>hl,disconnectedFromNode:()=>ad,ensureNode:()=>Oo,requestClusterStatus:()=>zk,startOnMainThread:()=>QO});async function QO(e){let t=0,r=Xe();for(let i of Object.getOwnPropertyNames(r)){let o=r[i];for(let c in o){let l=o[c];if(l.auditStore){yg.set(i,op(l.auditStore));break}}}$i.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes?.search([])||[])i.push(o);for(let o of cp(e))try{let c=!o.subscriptions;if(c){let u=Ze(),f=or().primaryStore.get(u);if(f!==null){let d=e.url??La();(f===void 0||f.url!==d||f.shard!==e.shard)&&await Oo(u,{name:u,url:d,shard:e.shard,replicates:!0})}}let l=o.trusted!==!1;if(c&&o.replicates==null&&(o.replicates=!0),i.find(u=>u.url===o.url))continue;s(o)}catch(c){console.error(c)}sd(s)});let n;function s(i,o=i?.name){let c=Ze()&&o===Ze()||La()&&i?.url===La();if(c){let d=!!i?.replicates;if(n!==void 0&&n!==d)for(let p of or().search([]))p.replicates&&p.name!==o&&s(p,p.name);n=d}if(ct.trace("Setting up node replication for",i),!i){for(let[d,p]of bo){let _;for(let[h,{worker:S,nodes:g}]of p){let R=g[0];if(R&&R.name==o){_=!0;for(let[E,{worker:T}]of p)p.delete(E),ct.warn("Node was deleted, unsubscribing from node",o,E,d),T?.postMessage({type:"unsubscribe-from-node",node:o,database:E,url:d});break}}if(_){bo.get(d).iterator.remove(),bo.delete(d);return}}return}if(c)return;if(!i.url){ct.info(`Node ${i.name} is missing url`);return}let l=bo.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(ct.info(`Added node ${i.name} at ${i.url} for process ${Ze()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[d,p]of id)if(i.url===p.url){id.delete(d);break}id.set(i.name,i)}let u=Xe();if(l||(l=new Map,bo.set(i.url,l)),l.iterator=Da(e,(d,p,_)=>{_?f(p,!0):f(p,!1)}),i.subscriptions)for(let d of i.subscriptions){let p=d.database||d.schema;u[p]||(ct.warn(`Database ${p} not found for node ${i.name}, making a subscription anyway`),f(p,!1))}function f(d,p){ct.trace("Setting up replication for database",d,"on node",i.name);let _=l.get(d),h,S=[{replicateByDefault:p,...i}];yg.has(d)&&(S.push({replicateByDefault:p,name:Ze(),start_time:yg.get(d),end_time:Date.now(),replicates:!0}),yg.delete(d));let g=ap(i,d),R=$i.workers.filter(E=>E.name==="http");if(_?(h=_.worker,_.nodes=S):g&&(t=t%R.length,h=R[t++],l.set(d,{worker:h,nodes:S,url:i.url}),h?.on("exit",()=>{l.get(d)?.worker===h&&(l.delete(d),f(d,p))})),g)setTimeout(()=>{let E={type:"subscribe-to-node",database:d,nodes:S};h?h.postMessage(E):od(E)},_ie);else{ct.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[d],or().primaryStore.get(Ze())?.replicates),or().primaryStore.get(Ze())?.replicates||(n=!1);let E={type:"unsubscribe-from-node",database:d,url:i.url,name:i.name};h?h.postMessage(E):Og(E)}}a(f,"onDatabase")}a(s,"onNodeUpdate"),ad=a(function(i){try{ct.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(id.keys()),c=o.sort(),l=c.indexOf(i.name||ai(i.url));if(l===-1){ct.warn("Disconnected node not found in node map",i.name,o);return}let u=bo.get(i.url),f=u?.get(i.database);if(!f){ct.warn("Disconnected node not found in replication map",i.database,u);return}if(f.connected=!1,i.finished)return;let d=f.nodes[0];if(!(d.replicates===!0||d.replicates?.sends||d.subscriptions?.length))return;let p=(l+1)%c.length;for(;l!==p;){let _=c[p],h=id.get(_);u=bo.get(h.url);let S=u?.get(i.database);if(!S){p=(p+1)%c.length;continue}let{worker:g,nodes:R}=S,E=!1;for(let T of f.nodes){if(R.some(b=>b.name===T.name)){ct.info(`Disconnected node is already failing over to ${_} for ${i.database}`);continue}R.push(T),E=!0}if(!E){ct.info(`Disconnected node ${i.name} has no nodes to fail over to ${_}`);return}f.redirectingTo=S,ct.info(`Failing over ${i.database} from ${i.name} to ${_}`),g?g.postMessage({type:"subscribe-to-node",database:i.database,nodes:R}):od({database:i.database,nodes:R});return}ct.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){ct.error("Error failing over node",o)}},"disconnectedFromNode"),hl=a(function(i){let o=bo.get(i.url),c=o?.get(i.database);if(!c){ct.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,o);return}if(c.connected=!0,c.latency=i.latency,c.redirectingTo){let{worker:l,nodes:u}=c.redirectingTo,f=u.find(d=>d.name===i.name);c.redirectingTo=null,f&&(u.splice(u.indexOf(f),1),l?l.postMessage({type:"subscribe-to-node",database:i.database,nodes:u}):od({database:i.database,nodes:u}))}},"connectedToNode"),(0,$i.onMessageByType)("disconnected-from-node",ad),(0,$i.onMessageByType)("connected-to-node",hl),(0,$i.onMessageByType)("request-cluster-status",zk)}function zk(e,t){let r=[];for(let[n,s]of id)try{let i=bo.get(s.url);ct.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let o=[];if(i){for(let[l,{worker:u,connected:f,nodes:d,latency:p}]of i)o.push({database:l,connected:f,latency:p,thread_id:u?.threadId,nodes:d.map(_=>_.name)});let c=(0,JO.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){ct.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function Oo(e,t){let r=or();e=e??ai(t.url),t.name=e;try{if(t.ca){let s=new Wk.X509Certificate(t.ca);t.ca_info={issuer:s.issuer.replace(/\n/g," "),subject:s.subject.replace(/\n/g," "),subject_alt_name:s.subjectAltName,serial_number:s.serialNumber,valid_from:s.validFrom,valid_to:s.validTo}}}catch(s){ct.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(ct.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.put(t);else{t.replicates&&!Yk.default.get(x.CLUSTERING_ENABLED)&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],o=(0,JO.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let u of o)if((c.database??c.schema)===(u.database??u.schema)&&c.table===u.table){u.publish=c.publish,u.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...o,...i];break}if(Array.isArray(t.revoked_certificates)){let s=n.revoked_certificates||[];t.revoked_certificates=[...new Set([...s,...t.revoked_certificates])]}ct.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var $i,bg,ct,JO,Yk,Wk,_ie,bo,ad,hl,id,yg,lp=be(()=>{De();$i=M(rt());Xn();bg=require("worker_threads");pl();ct=M(z()),JO=require("lodash"),Yk=M(ae());H();Wk=require("crypto"),_ie=200,bo=new Map,id=new Map,yg=new Map;a(QO,"startOnMainThread");a(zk,"requestClusterStatus");bg.parentPort&&(ad=a(e=>{bg.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),hl=a(e=>{bg.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,$i.onMessageByType)("subscribe-to-node",e=>{od(e)}),(0,$i.onMessageByType)("unsubscribe-from-node",e=>{Og(e)}));a(Oo,"ensureNode")});var Zn=w(gF=>{"use strict";var ar=require("path"),Nn=require("fs-extra"),cd=require("node-forge"),tF=require("net"),{generateKeyPair:ZO,X509Certificate:No,createPrivateKey:rF}=require("crypto"),pie=require("util");ZO=pie.promisify(ZO);var bt=cd.pki,ci=require("joi"),{v4:nF}=require("uuid"),{validateBySchema:nN}=ot(),pt=z(),ys=ae(),bs=(H(),C(G)),{CONFIG_PARAMS:ld}=bs,li=Vy(),{ClientError:va}=pe(),Ng=require("node:tls"),{relative:sF,join:hie}=require("node:path"),{CERT_PREFERENCE_APP:UPe,CERTIFICATE_VALUES:Jk}=li,mie=ua(),eN=yt(),{table:Eie,getDatabases:gie,databases:XO}=(De(),C(nt)),{getJWTRSAKeys:Qk}=(Ju(),C(X_));Object.assign(gF,{generateKeys:oN,updateConfigCert:fF,createCsr:Nie,signCertificate:wie,setCertTable:ud,loadCertificates:lF,reviewSelfSignedCert:cN,createTLSSelector:pF,listCertificates:mF,addCertificate:Mie,removeCertificate:Uie,createNatsCerts:Pie,generateCertsKeys:Cie,getReplicationCert:dp,getReplicationCertAuth:Oie,renewSelfSigned:Die,hostnamesFromCert:EF,getKey:xie});var{urlToNodeName:iF,getThisNodeUrl:Sie,getThisNodeName:Ig,clearThisNodeName:Tie}=(Xn(),C(wo)),{readFileSync:Aie,watchFile:Rie,statSync:oF}=require("node:fs"),xPe=ae(),{getTicketKeys:yie,onMessageFromWorkers:bie}=rt(),Ma=z(),{isMainThread:aF}=require("worker_threads"),{TLSSocket:cF,createSecureContext:BPe}=require("node:tls"),sN=3650,up=["127.0.0.1","localhost","::1"],iN=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];bie(async e=>{e.type===bs.ITC_EVENT_TYPES.RESTART&&(ys.initSync(!0),await cN())});var Ur;function xa(){return Ur||(Ur=gie().system.hdb_certificate,Ur||(Ur=Eie({table:"hdb_certificate",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]}))),Ur}a(xa,"getCertTable");async function dp(){let e=pF("operations-api"),t={secureContexts:null,setSecureContext:a(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(Ig());if(!r)return;let n=new No(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(dp,"getReplicationCert");async function Oie(){xa();let e=(await dp()).options.cert,r=new No(e).issuer.match(/CN=(.*)/)?.[1];return Ur.get(r)}a(Oie,"getReplicationCertAuth");var Xk,Ua=new Map;function lF(){if(Xk)return;Xk=!0;let e=[{configKey:ld.TLS},{configKey:ld.OPERATIONSAPI_TLS}];xa();let t=ar.dirname(eN.getConfigFilePath()),r;for(let{configKey:n}of e){let s=eN.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&sF(hie(t,"keys"),o);c&&Zk(o,l=>{Ua.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&aF){let f;Zk(u,d=>{if(Jk.cert===d)return;let p=i.hostname??i.hostnames??i.host??i.hosts;p&&!Array.isArray(p)&&(p=[p]);let _=_F(u),h=new No(_),S;try{S=lN(h)}catch(T){pt.error("error extracting common name from certificate",T);return}if(S==null){pt.error("error extracting common name from certificate");return}if(h.checkIssued(new No(Jk.cert)))return;let g=Ur.primaryStore.get(S),R=oF(u).mtimeMs,E=!g||g.is_self_signed?1:g.file_timestamp??g.__updatedtime__;if(g&&R<=E){R<E&&pt.info(`Certificate ${S} at ${u} is older (${new Date(R)}) than the certificate in the database (${E>1?new Date(E):"only self signed certificate available"})`);return}r=Ur.put({name:S,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:_,private_key_name:c,is_authority:l,hostnames:p,file_timestamp:R,details:{issuer:h.issuer.replace(/\n/g," "),subject:h.subject.replace(/\n/g," "),subject_alt_name:h.subjectAltName,serial_number:h.serialNumber,valid_from:h.validFrom,valid_to:h.validTo}})},l?"certificate authority":"certificate")}}}}}return r}a(lF,"loadCertificates");function Zk(e,t,r){let n,s=a((i,o)=>{try{let c=i.mtimeMs;c&&c!==n&&(o&&aF&&pt.warn(`Reloading ${r}:`,e),n=c,t(_F(e)))}catch(c){pt.error(`Error loading ${r}:`,e,c)}},"loadFile");Nn.existsSync(e)?s(oF(e)):pt.error(`${r} file not found:`,e),Rie(e,{persistent:!1},s)}a(Zk,"loadAndWatch");function tN(){let e=Sie();if(e==null){let t=up[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return iF(e)}a(tN,"getHost");function wg(){let e=Ig();if(e==null){let t=up[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(wg,"getCommonName");async function Nie(){let e=await dp(),t=bt.certificateFromPem(e.options.cert),r=bt.privateKeyFromPem(e.options.key);pt.info("Creating CSR with cert named:",e.name);let n=bt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:wg()},...iN];pt.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:uF()}];return pt.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),cd.pki.certificationRequestToPem(n)}a(Nie,"createCsr");function uF(){let e=up.includes(wg())?up:[...up,wg()];return e.includes(tN())||e.push(tN()),[{name:"basicConstraints",cA:!1,critical:!0},{name:"keyUsage",digitalSignature:!0,keyEncipherment:!0,critical:!0},{name:"extKeyUsage",serverAuth:!0,clientAuth:!0},{name:"nsCertType",client:!0,server:!0},{name:"subjectAltName",altNames:e.map(t=>tF.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a(uF,"certExtensions");async function wie(e){let t={},r=ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;xa();for await(let f of Ur.search([]))if(f.is_authority&&!f.details.issuer.includes("HarperDB-Certificate-Authority")){if(Ua.has(f.private_key_name)){n=Ua.get(f.private_key_name),s=f;break}else if(f.private_key_name&&await Nn.exists(ar.join(r,f.private_key_name))){n=Nn.readFile(ar.join(r,f.private_key_name)),s=f;break}}if(!n){let f=await rN();s=f.ca,n=f.private_key}n=bt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=bt.certificateFromPem(s.certificate);pt.info("Signing CSR with cert named",s.name);let o=bt.certificationRequestFromPem(e.csr);try{o.verify()}catch(f){return pt.error(f),new Error("Error verifying CSR: "+f.message)}let c=cd.pki.createCertificate();c.serialNumber=Math.random().toString().slice(2,10),c.validity.notBefore=new Date;let l=new Date;c.validity.notAfter=l,c.validity.notAfter.setDate(l.getDate()+sN),pt.info("sign cert setting validity:",c.validity),pt.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),pt.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=o.getAttribute({name:"extensionRequest"}).extensions;pt.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=o.publicKey,c.sign(n,cd.md.sha256.create()),t.certificate=bt.certificateToPem(c)}else pt.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(wie,"signCertificate");async function Iie(e,t){await ud({name:Ig(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await ud({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:bt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(Iie,"createCertificateTable");async function ud(e){let t=new No(e.certificate);e.details={issuer:t.issuer.replace(/\n/g," "),subject:t.subject.replace(/\n/g," "),subject_alt_name:t.subjectAltName,serial_number:t.serialNumber,valid_from:t.validFrom,valid_to:t.validTo},xa(),await Ur.patch(e)}a(ud,"setCertTable");async function oN(){let e=await ZO("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:bt.publicKeyFromPem(e.publicKey),private_key:bt.privateKeyFromPem(e.privateKey)}}a(oN,"generateKeys");async function aN(e,t,r){let n=bt.createCertificate();if(!t){let o=await dp();t=bt.certificateFromPem(o.options.cert).publicKey}n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+sN);let i=[{name:"commonName",value:wg()},...iN];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(uF()),n.sign(e,cd.md.sha256.create()),bt.certificateToPem(n)}a(aN,"generateCertificates");async function rN(){let e=await mF(),t;for(let r of e){if(!r.is_authority)continue;let n=await hF(r.private_key_name);if(r.private_key_name&&n&&new No(r.certificate).checkPrivateKey(rF(n))){pt.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;pt.trace("No CA found with matching private key")}a(rN,"getCertAuthority");async function dF(e,t,r=!0){let n=bt.createCertificate();n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+sN);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${ys.get(ld.REPLICATION_HOSTNAME)??iF(ys.get(ld.REPLICATION_URL))??nF().split("-")[0]}`},...iN];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,cd.md.sha256.create());let o=ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME),c=ar.join(o,li.PRIVATEKEY_PEM_NAME);return r&&await Nn.writeFile(c,bt.privateKeyToPem(e)),n}a(dF,"generateCertAuthority");async function Cie(){let{private_key:e,public_key:t}=await oN(),r=await dF(e,t),n=await aN(e,t,r);await Iie(n,r),fF()}a(Cie,"generateCertsKeys");async function Pie(){let e=await aN(bt.privateKeyFromPem(li.CERTIFICATE_VALUES.key),void 0,bt.certificateFromPem(li.CERTIFICATE_VALUES.cert)),t=ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME),r=ar.join(t,li.NATS_CERTIFICATE_PEM_NAME);await Nn.exists(r)||await Nn.writeFile(r,e);let n=ar.join(t,li.NATS_CA_PEM_NAME);await Nn.exists(n)||await Nn.writeFile(n,li.CERTIFICATE_VALUES.cert)}a(Pie,"createNatsCerts");async function Die(){xa();for await(let e of Ur.search([{attribute:"is_self_signed",value:!0}]))await Ur.delete(e.name);await cN()}a(Die,"renewSelfSigned");async function cN(){Tie(),await lF(),xa();let e=await rN();if(!e){pt.notify("A matching Certificate Authority and key was not found. A new CA will be created in advance, so it's available if needed.");let r=ys.get(ld.TLS_PRIVATEKEY),n=ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME),s,i=sF(n,r);try{s=bt.privateKeyFromPem(await Nn.readFile(r))}catch(c){pt.warn("Unable to parse the TLS key",r,"A new key will be generated and used to create Certificate Authority",c),{private_key:s}=await oN(),await Nn.exists(ar.join(n,li.PRIVATEKEY_PEM_NAME))&&(i=`privateKey${nF().split("-")[0]}.pem`),await Nn.writeFile(ar.join(n,i),bt.privateKeyToPem(s))}let o=await dF(s,bt.setRsaPublicKey(s.n,s.e),!1);await ud({name:o.subject.getField("CN").value,uses:["https"],certificate:bt.certificateToPem(o),private_key_name:i,is_authority:!0,is_self_signed:!0})}if(!await dp()){let r=Ig();pt.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await rN();let n=bt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await aN(bt.privateKeyFromPem(e.private_key),s,n);await ud({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(cN,"reviewSelfSignedCert");function fF(){let e=mie(Object.keys(bs.CONFIG_PARAM_MAP),!0),t=ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME),r=ar.join(t,li.PRIVATEKEY_PEM_NAME),n=ar.join(t,li.NATS_CERTIFICATE_PEM_NAME),s=ar.join(t,li.NATS_CA_PEM_NAME),i=bs.CONFIG_PARAMS,o={[i.TLS_PRIVATEKEY]:e[i.TLS_PRIVATEKEY.toLowerCase()]?e[i.TLS_PRIVATEKEY.toLowerCase()]:r};e[i.TLS_CERTIFICATE.toLowerCase()]&&(o[i.TLS_CERTIFICATE]=e[i.TLS_CERTIFICATE.toLowerCase()]),e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.TLS_CERTIFICATEAUTHORITY]=e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATE]=e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]),e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_PRIVATEKEY]=e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY]=e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]),(e[i.CLUSTERING_ENABLED.toLowerCase()]||e.clustering)&&(o[i.CLUSTERING_TLS_CERTIFICATE]=e[i.CLUSTERING_TLS_CERTIFICATE.toLowerCase()]??n,o[i.CLUSTERING_TLS_CERT_AUTH]=e[i.CLUSTERING_TLS_CERT_AUTH.toLowerCase()]??s,o[i.CLUSTERING_TLS_PRIVATEKEY]=e[i.CLUSTERING_TLS_PRIVATEKEY.toLowerCase()]??r),eN.updateConfigValue(void 0,void 0,o,!1,!0)}a(fF,"updateConfigCert");function _F(e){return e.startsWith("-----BEGIN")?e:Aie(e,"utf8")}a(_F,"readPEM");var eF=Ng.createSecureContext;Ng.createSecureContext=function(e){if(!e.cert||!e.key)return eF(e);let t={...e};delete t.key,delete t.cert;let r=eF(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var Lie=cF.prototype._init;cF.prototype._init=function(e,t){Lie.call(this,e,t);let r=this;this._handle.oncertcb=function(n){let s=n.servername;r._SNICallback(s,(i,o)=>{this.sni_context=o?.context||o,this.certCbDone()})}};var ml=new Map;function pF(e,t){let r=new Map,n,s=!1;return i.initialize=o=>i.ready?i.ready:(o&&(o.secureContexts=r,o.secureContextsListeners=[]),i.ready=new Promise((c,l)=>{async function u(){try{r.clear(),ml.clear();let f=0;for await(let d of XO.system.hdb_certificate.search([])){let p=d.certificate,_=new No(p);d.is_authority&&(_.asString=p,ml.set(_.subject,p))}for await(let d of XO.system.hdb_certificate.search([]))try{if(d.is_authority)continue;let p=e==="operations-api",_=d.is_self_signed?1:2;p&&d.uses?.includes?.("operations")&&(_+=1);let h=await hF(d.private_key_name),S=d.certificate,g=new No(S);if(ml.has(g.issuer)&&(S+=`
24
- `+ml.get(g.issuer)),!h||!S)throw new Error("Missing private key or certificate for secure server");let R={ciphers:d.ciphers,ticketKeys:yie(),availableCAs:ml,ca:t&&Array.from(ml.values()),cert:S,key:h,key_file:d.private_key_name,is_self_signed:d.is_self_signed};o&&(R.sessionIdContext=o.sessionIdContext);let E=Ng.createSecureContext(R);E.name=d.name,E.options=R,E.quality=_,E.certificateAuthorities=Array.from(ml),E.certStart=S.toString().slice(0,100);let T=d.hostnames??EF(g);Array.isArray(T)||(T=[T]);let b;for(let v of T)if(v){v[0]==="*"&&(s=!0,v=v.slice(1)),v===tN()&&(_+=2),tF.isIP(v)&&(b=!0);let F=r.get(v)?.quality??0;_>F&&r.set(v,E)}else Ma.error("No hostname found for certificate at",Ng.certificate);Ma.trace("Adding TLS",E.name,"for",o.ports||"client","cert named",d.name,"hostnames",T,"quality",_,"best quality",f),_>f&&(i.defaultContext=n=E,f=_,o&&(o.defaultContext=E))}catch(p){Ma.error("Error applying TLS for",d.name,p)}o?.secureContextsListeners.forEach(d=>d()),c(n)}catch(f){l(f)}}a(u,"updateTLS"),XO.system.hdb_certificate.subscribe({listener:a(()=>setTimeout(()=>u(),1500).unref(),"listener"),omitCurrent:!0}),u()})),i;function i(o,c){Ma.info("TLS requested for",o||"(no SNI)");let l=o;for(;;){let f=r.get(l);if(f)return Ma.debug("Found certificate for",o,f.certStart),f.updatedContext&&(f=f.updatedContext),c(null,f);if(s&&l){let d=l.indexOf(".",1);d<0?l="":l=l.slice(d)}else break}o?Ma.debug("No certificate found to match",o,"using the default certificate"):Ma.debug("No SNI, using the default certificate",n?.name);let u=n;u?u.updatedContext&&(u=u.updatedContext):Ma.info("No default certificate found"),c(null,u)}a(i,"SNICallback")}a(pF,"createTLSSelector");async function hF(e){let t=Ua.get(e);return!t&&e?await Nn.readFile(ar.join(ys.get(ld.ROOTPATH),bs.LICENSE_KEY_DIR_NAME,e),"utf8"):t}a(hF,"getPrivateKeyByName");async function mF(){xa();let e=[];for await(let t of Ur.search([]))e.push(t);return e}a(mF,"listCertificates");async function Mie(e){let t=nN(e,ci.object({name:ci.string().required(),certificate:ci.string().required(),is_authority:ci.boolean().required(),private_key:ci.string(),hosts:ci.array(),uses:ci.array()}));if(t)throw new va(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,o=new No(n),c=!1,l=!1,u;for(let[_,h]of Ua)!s&&!c&&o.checkPrivateKey(rF(h))&&(c=!0,u=_),s&&s===h&&(l=!0,u=_);if(!i&&!s&&!c)throw new va("A suitable private key was not found for this certificate");let f;if(!r){try{f=lN(o)}catch(_){pt.error(_)}if(f==null)throw new va("Error extracting certificate common name, please provide a name parameter")}let d=vie(r??f);s&&!c&&!l&&(await Nn.writeFile(ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME,d+".pem"),s),Ua.set(d,s));let p={name:r??f,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&u||i&&s)&&(p.private_key_name=u??d+".pem"),await ud(p),"Successfully added certificate: "+d}a(Mie,"addCertificate");function vie(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(vie,"sanitizeName");async function Uie(e){let t=nN(e,ci.object({name:ci.string().required()}));if(t)throw new va(t.message);let{name:r}=e;xa();let n=await Ur.get(r);if(!n)throw new va(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await Ur.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(pt.info("Removing private key named",s),await Nn.remove(ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME,s)))}return await Ur.delete(r),"Successfully removed "+r}a(Uie,"removeCertificate");function lN(e){return e.subject.match(/CN=(.*)/)?.[1]}a(lN,"extractCommonName");function EF(e){return e.subjectAltName?e.subjectAltName.split(",").map(t=>{let r=t.indexOf(":");if(t=t.slice(r+1),t=t.trim(),t[0]==='"')try{t=JSON.parse(t)}catch{}return t.indexOf("=")>-1?t.match(/CN=([^,]*)/)?.[1]:t}).filter(t=>t):[lN(e)]}a(EF,"hostnamesFromCert");async function xie(e){if(e.bypass_auth!==!0)throw new va("Unauthorized","401");let t=nN(e,ci.object({name:ci.string().required()}));if(t)throw new va(t.message);let{name:r}=e;if(r===".jwtPrivate")return(await Qk()).privateKey;if(r===".jwtPublic")return(await Qk()).publicKey;if(Ua.get(r))return Ua.get(e.name);throw new va("Key not found")}a(xie,"getKey")});var BF={};ve(BF,{CONFIRMATION_STATUS_POSITION:()=>xF,NodeReplicationConnection:()=>fp,OPERATION_REQUEST:()=>pN,RECEIVED_TIME_POSITION:()=>mN,RECEIVED_VERSION_POSITION:()=>hN,SENDING_TIME_POSITION:()=>Mg,createWebSocket:()=>Ug,database_subscriptions:()=>Ha,replicateOverWS:()=>_p,table_update_listeners:()=>gN});async function Ug(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=Ze(),i;if(e.includes("wss://")){if(!dN){let l=(0,MF.createTLSSelector)("operations-api"),u={secureContexts:null};await l.initialize(u),dN=u.secureContexts}if(i=dN.get(s),i&&le.debug?.("Creating web socket for URL",e,"with certificate named:",i.name),!i&&n!==!1)throw new Error("Unable to find a valid certificate to use for replication to connect to "+e)}let o={};r&&(o.Authorization=r);let c={headers:o,localAddress:s?.startsWith("127.0")?s:void 0,servername:(0,UF.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,rejectUnauthorized:n!==!1,secureContext:void 0};return i&&(c.secureContext=vF.createSecureContext({...i.options,ca:Array.from(gl)})),new DF.WebSocket(e,"harperdb-replication-v1",c)}function _p(e,t,r){let n=t.port||t.securePort,s=El.pid%1e3+"-"+LF.threadId+(n?"s:"+n:"c:"+t.url?.slice(-4))+" "+Math.random().toString().slice(2,3),i=0,o=Buffer.allocUnsafeSlow(1024),c=0,l=new DataView(o.buffer,0,1024),u=t.database,f=t.databaseSubscriptions||Ha,d,p,_=!1,h=t.subscription;h?.then&&h.then(m=>h=m);let S=t.tables||u&&Xe()[u];if(!r){le.error?.("No authorization provided"),un(1008,"Unauthorized");return}let g=new Map,R=[],E=r.name;E&&t.connection&&(t.connection.nodeName=E);let T,b,v,F,q,Y,Z,se=1e3,Q,ne=0,J=0,me=0,ye=new Map,Pe=[],he=0,Nt;if(t.url){let m=a(()=>{q&&J===e._socket?.bytesRead&&me===e._socket?.bytesWritten?e.terminate():(q=performance.now(),e.ping(),J=e._socket?.bytesRead,me=e._socket?.bytesWritten)},"send_ping");v=setInterval(m,IF).unref(),m()}else dt();e._socket?.setMaxListeners(200);function dt(){clearTimeout(F),J=e._socket?.bytesRead,me=e._socket?.bytesWritten,F=setTimeout(()=>{J===e._socket?.bytesRead&&me===e._socket?.bytesWritten&&(le.warn?.(`Timeout waiting for ping from ${E}, terminating connection and reconnecting`),e.terminate())},IF*2).unref()}a(dt,"resetPingTimer");function br(){return p||(p=Rg(d,u,E)),p}a(br,"getSharedStatus"),u&&ia(u);let hs,Un,ou=[],au=[],HA,kA=[],vt=[],Ef=[],Jh=150,Qh=25,gf=0,Xh=0,Ie=!1,Sf,ln,Cr,cu;e.on("message",m=>{ne=performance.now();try{let A=m.dataView=new Sl(m.buffer,m.byteOffset,m.byteLength);if(m[0]>127){let P=(0,je.decode)(m),[N,L,k]=P;switch(N){case TF:{if(L){if(E){if(E!==L){le.error?.(s,`Node name mismatch, expecting to connect to ${E}, but peer reported name as ${L}, disconnecting`),e.send((0,je.encode)([dd])),un(1008,"Node name mismatch");return}}else if(E=L,t.connection?.tentativeNode){let U=t.connection.tentativeNode;U.name=E,t.connection.tentativeNode=null,Oo(E,U)}if(t.connection&&(t.connection.nodeName=E),le.debug?.(s,"received node name:",E,"db:",u),!u)try{ia(u=P[2]),u==="system"&&(hs=Da(t,(U,ue)=>{uu(ue)&&oa(ue)}),e.on("close",()=>{hs?.remove()}))}catch(U){le.warn?.(s,"Error setting database",U),e.send((0,je.encode)([dd])),un(1008,U.message);return}Gr()}break}case NF:{le.debug?.(s,"Received table definitions for",L.map(U=>U.table));for(let U of L){let ue=P[2];U.database=ue;let ce;uu(ue)&&(ue==="system"?qe[ue]?.[U.table]||(ce=fN(U,qe[ue]?.[U.table])):ce=fN(U,qe[ue]?.[U.table]),d||(d=ce?.auditStore),S||(S=Xe()?.[ue]))}break}case dd:un();break;case pN:try{let U=r?.replicates||r?.subscribers||r?.name;server.operation(L,{user:r},!U).then(ue=>{Array.isArray(ue)&&(ue={results:ue}),ue.requestId=L.requestId,e.send((0,je.encode)([Pg,ue]))},ue=>{e.send((0,je.encode)([Pg,{requestId:L.requestId,error:ue instanceof Error?ue.toString():ue}]))})}catch(U){e.send((0,je.encode)([Pg,{requestId:L.requestId,error:U instanceof Error?U.toString():U}]))}break;case Pg:let{resolve:D,reject:B}=g.get(L.requestId);L.error?B(new Error(L.error)):D(L),g.delete(L.requestId);break;case uN:let $=P[3];S||(u?le.error?.(s,"No tables found for",u):le.error?.(s,"Database name never received"));let j=S[$];j=fN({table:$,database:u,attributes:L.attributes,schemaDefined:L.schemaDefined},j),ou[k]={name:$,decoder:new je.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:L.typedStructs,structures:L.structures}),getEntry(U){return j.primaryStore.getEntry(U)},rootStore:j.primaryStore.rootStore};break;case AF:cu=d?Fk(L,d):new Map,HA=P[2],le.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${HA}`);break;case RF:let oe=k;Ef[oe]=L;break;case OF:br()[xF]=L,le.trace?.(s,"received and broadcasting committed update",L),br().buffer.notify();break;case bF:T=L,h.send({type:"end_txn",localTime:T,remoteNodeIds:R});break;case Dg:{let U=P[1],{fileId:ue,size:ce,finished:fe,error:te}=U,W=ye.get(ue);le.debug?.("Received blob",ue,"has stream",!!W,"connectedToBlob",!!W?.connectedToBlob,"length",P[2].length,"finished",fe),W||(W=new _N.PassThrough,W.expectedSize=ce,ye.set(ue,W)),W.lastChunk=Date.now(),fe?(te?(W.on("error",()=>{}),W.destroy(new Error("Blob error: "+te))):W.end(P[2]),W.connectedToBlob&&ye.delete(ue)):W.write(P[2]);break}case yF:{let U=L,ue;try{let ce=P[3],fe=au[k]||(au[k]=S[P[4]]);if(!fe)return le.warn?.("Unknown table id trying to handle record request",k);let te=fe.primaryStore.getBinaryFast(Symbol.for("structures")),W=te.length;if(W!==Xh){Xh=W;let Ee=(0,je.decode)(te);e.send((0,je.encode)([uN,{typedStructs:Ee.typed,structures:Ee.named},k,fe.tableName]))}let _e=fe.primaryStore.getBinaryFast(ce);if(_e){let Ee=fe.primaryStore.decoder.decode(_e,{valueAsBuffer:!0});ue=(0,je.encode)([Cg,U,{value:Ee.value,expiresAt:Ee.expiresAt,version:Ee.version,residencyId:Ee.residencyId,nodeId:Ee.nodeId,user:Ee.user}])}else ue=(0,je.encode)([Cg,U])}catch(ce){ue=(0,je.encode)([Cg,U,{error:ce.message}])}e.send(ue);break}case Cg:{let{resolve:U,reject:ue,tableId:ce,key:fe}=g.get(P[1]),te=P[2];if(te?.error)ue(new Error(te.error));else if(te){let W=ou[ce].decoder.decode(te.value);te.value=W,te.key=fe,U(te)}else U();g.delete(P[1]);break}case SF:{Cr=L;let U,ue,ce=!1;if(h){if(u!==h.databaseName&&!h.then){le.error?.("Subscription request for wrong database",u,h.databaseName);return}}else h=f.get(u);if(le.debug?.(s,"received subscription request for",u,"at",Cr),!h){let ge;h=new Promise(Qe=>{le.debug?.("Waiting for subscription to database "+u),ge=Qe}),h.ready=ge,Ha.set(u,h)}if(r.name)ue=or().subscribe(r.name),ue.then(async ge=>{U=ge;for await(let Qe of U){let st=Qe.value;if(!(st?.replicates===!0||st?.replicates?.receives||st?.subscriptions?.some(Vt=>(Vt.database||Vt.schema)===u&&Vt.publish!==!1))){ce=!0,e.send((0,je.encode)([dd])),un(1008,`Unauthorized database subscription to ${u}`);return}}},ge=>{le.error?.(s,"Error subscribing to HDB nodes",ge)});else if(!(r?.role?.permission?.super_user||r.replicates)){e.send((0,je.encode)([dd])),un(1008,`Unauthorized database subscription to ${u}`);return}if(ln&&(le.debug?.(s,"stopping previous subscription",u),ln.emit("close")),Cr.length===0)return;let fe=Cr[0],te=a(ge=>{if(ge&&(fe.replicateByDefault?!fe.tables.includes(ge.tableName):fe.tables.includes(ge.tableName)))return{table:ge}},"tableToTableEntry"),W={txnTime:0},_e,Ee,Se=1/0,tt,Ye=a((ge,Qe)=>{if(ge.type==="end_txn"){W.txnTime&&(o[i]!==66&&le.error?.("Invalid encoding of message"),du(9),du(vg),Rc(tt=Qe),mr()),i=c,W.txnTime=0;return}let st=ge.nodeId,Vt=ge.tableId,Kt=Ee[Vt];if(!Kt&&(Kt=Ee[Vt]=te(h.tableById[Vt]),!Kt))return le.debug?.("Not subscribed to table",Vt);let qr=Kt.table,yc=qr.primaryStore,Ut=yc.encoder;(ge.extendedType&jm||!Ut.typedStructs)&&(Ut._mergeStructures(Ut.getStructures()),Ut.typedStructs&&(Ut.lastTypedStructuresLength=Ut.typedStructs.length));let em=_e[st];if(!(em&&em.startTime<Qe&&(!em.endTime||em.endTime>Qe)))return Lg&&le.trace?.(s,"skipping replication update",ge.recordId,"to:",E,"from:",st,"subscribed:",_e),oD();Lg&&le.trace?.(s,"sending replication update",ge.recordId,"to:",E,"from:",st,"subscribed:",_e);let FA=ge.version;W.txnTime!==FA&&(W.txnTime&&(Lg&&le.trace?.(s,"new txn time, sending queued txn",W.txnTime),o[i]!==66&&le.error?.("Invalid encoding of message"),mr()),W.txnTime=FA,i=c,Rc(FA));let bc=ge.residencyId,GA=lu(bc,qr),tm;if(GA&&!GA.includes(E)){let Oc=lu(ge.previousResidencyId,qr);if(Oc&&!Oc.includes(E)&&(ge.type==="put"||ge.type==="patch")||qr.getResidencyById)return oD();let Rf=ge.recordId;le.trace?.(s,"sending invalidation",Rf,E,"from",st);let ca=0;bc&&(ca|=kc),ge.previousResidencyId&&(ca|=Fc);let Ks,dn=null;for(let rm in qr.indices){if(!dn){if(Ks=ge.getValue(yc,!0),!Ks)break;dn={}}dn[rm]=Ks[rm]}tm=Nu(ge.version,Vt,Rf,null,st,ge.user,ge.type==="put"||ge.type==="patch"?"invalidate":ge.type,Ut.encode(dn),ca,bc,ge.previousResidencyId,ge.expiresAt)}function oD(){le.trace?.(s,"skipping audit record",ge.recordId),Y||(Y=setTimeout(()=>{Y=null,(tt||0)+wF/2<Se&&(Lg&&le.trace?.(s,"sending skipped sequence update",Se),e.send((0,je.encode)([bF,Se])))},wF).unref())}a(oD,"skipAuditRecord");let qA=Ut.typedStructs,$A=Ut.structures;if((qA?.length!=Kt.typed_length||$A?.length!=Kt.structure_length)&&(Kt.typed_length=qA?.length,Kt.structure_length=$A.length,le.debug?.(s,"send table struct",Kt.typed_length,Kt.structure_length),Kt.sentName||(Kt.sentName=!0),e.send((0,je.encode)([uN,{typedStructs:qA,structures:$A,attributes:qr.attributes,schemaDefined:qr.schemaDefined},Vt,Kt.table.tableName]))),bc&&!vt[bc]&&(e.send((0,je.encode)([RF,GA,bc])),vt[bc]=!0),tm)du(tm.length),Ac(tm);else{let Oc=ge.encoded;ge.extendedType&Fn&&PR(()=>ge.getValue(yc),async ca=>{let Ks=Hm(ca);try{let dn;he++;for await(let rm of ca.stream()){if(dn&&(le.debug?.("Sending blob chunk",Ks,"length",dn.length),e.send((0,je.encode)([Dg,{fileId:Ks,size:ca.size},dn]))),dn=rm,ce)return;e._socket.writableNeedDrain&&(le.debug?.("draining",Ks),await new Promise(g2=>e._socket.once("drain",g2)),le.debug?.("drained",Ks))}le.debug?.("Sending final blob chunk",Ks,"length",dn.length),e.send((0,je.encode)([Dg,{fileId:Ks,size:ca.size,finished:!0},dn]))}catch(dn){le.debug?.("Error sending blob",dn),e.send((0,je.encode)([Dg,{fileId:Ks,finished:!0,error:dn.toString()},Buffer.alloc(0)]))}finally{he--,he<Qh&&Nt?.()}});let Rf=Oc[0]===66?8:0;du(Oc.length-Rf),Ac(Oc,Rf),le.trace?.("wrote record",ge.recordId,"length:",Oc.length)}},"sendAuditRecord"),mr=a(()=>{c-i>8?(e.send(o.subarray(i,c)),le.debug?.(s,"Sent message, size:",c-i)):le.debug?.(s,"skipping empty transaction")},"sendQueuedData");ln=new EN.EventEmitter,ln.once("close",()=>{ce=!0,U?.end()});for(let{startTime:ge}of Cr)ge<Se&&(Se=ge);(ue||Promise.resolve()).then(async()=>{h=await h,d=h.auditStore,Ee=h.tableById.map(te),_e=[];for(let{name:Qe,startTime:st,endTime:Vt}of Cr){let Kt=Ag(Qe,d);le.debug?.("subscription to",Qe,"using local id",Kt,"starting",st),_e[Kt]={startTime:st,endTime:Vt}}oa(u),hs||(hs=Tl(Qe=>{Qe.databaseName===u&&oa(u)}),Un=pp(Qe=>{Qe===u&&(e.send((0,je.encode)([dd])),un())}),e.on("close",()=>{hs?.remove(),Un?.remove()})),e.send((0,je.encode)([AF,ip(h.auditStore),Cr.map(({name:Qe})=>Qe)]));let ge=!0;do{isFinite(Se)||(le.warn?.("Invalid sequence id "+Se),un(1008,"Invalid sequence id"+Se));let Qe;if(ge&&!ce&&(ge=!1,!(TN(d)<=Se)&&(PF.default.get(x.REPLICATION_COPYTABLESTOCATCHUP)??Bie)&&server.nodes[0]?.name===E)){le.info?.("Replicating all tables to",E);let Vt=Se,Kt=xg(d);for(let qr in S){if(!te(qr))continue;let yc=S[qr];for(let Ut of yc.primaryStore.getRange({snapshot:!1})){if(ce)return;Ut.localTime>=Se&&(le.trace?.(s,"Copying record from",u,qr,Ut.key,Ut.localTime),Vt=Math.max(Ut.localTime,Vt),Qe=!0,br()[Mg]=1,Ye({recordId:Ut.key,tableId:yc.tableId,type:"put",getValue(){return Ut.value},encoded:yc.primaryStore.getBinary(Ut.key),version:Ut.version,residencyId:Ut.residencyId,nodeId:Kt,extendedType:Ut.metadataFlags},Ut.localTime))}}Se=Vt}for(let{key:st,value:Vt}of d.getRange({start:Se||1,exclusiveStart:!0,snapshot:!1})){if(ce)return;let Kt=It(Vt);le.debug?.("sending audit record",new Date(st)),br()[Mg]=st,Se=st,Ye(Kt,st),e._socket.writableNeedDrain?await new Promise(qr=>{le.debug?.(`Waiting for remote node ${E} to allow more commits ${e._socket.writableNeedDrain?"due to network backlog":"due to requested flow directive"}`),e._socket.once("drain",qr)}):he>Qh?await new Promise(qr=>{Nt=qr}):await new Promise(setImmediate),ln.startTime=st,Qe=!0}Qe&&Ye({type:"end_txn"},Se),br()[Mg]=0,await HF(d)}while(!ce)}).catch(ge=>{le.error?.(s,"Error handling subscription to node",ge),un(1008,"Error handling subscription to node")});break}}return}A.position=8;let I=!0,y,O;do{br();let P=A.readInt();if(P===9&&A.getUint8(A.position)==vg){A.position++,T=O=A.readFloat64(),p[hN]=T,p[mN]=Date.now(),le.trace?.("received remote sequence update",T,u);break}let N=A.position,L=It(m,N,N+P),k=ou[L.tableId];k||le.error?.(`No table found with an id of ${L.tableId}`);let D;L.residencyId&&(D=Ef[L.residencyId],le.trace?.(s,"received residency list",D,L.type,L.recordId));try{CR(()=>{y={table:k.name,id:L.recordId,type:L.type,nodeId:cu.get(L.nodeId),residencyList:D,timestamp:L.version,value:L.getValue(k),user:L.user,beginTxn:I,expiresAt:L.expiresAt}},B=>{let $=Hm(B),j=ye.get($);le.debug?.("Received transaction with blob",$,"has stream",!!j,"ended",!!j?.writableEnded),j?j.writableEnded&&ye.delete($):(j=new _N.PassThrough,ye.set($,j)),j.connectedToBlob=!0,j.lastChunk=Date.now(),B.size===void 0&&j.expectedSize&&(B.size=j.expectedSize);let oe=createBlob(j,B),U=oe.save({primaryStore:h.auditStore});return U&&(U.blobId=$,Pe.push(U),U.finally(()=>{le.debug?.(`Finished receiving blob stream ${$}`),Pe.splice(Pe.indexOf(U),1)})),oe})}catch(B){throw B.message+="typed structures for current decoder"+JSON.stringify(k.decoder.typedStructs),B}I=!1,le.trace?.(s,"received replication message",L.type,"id",y.id,"version",new Date(L.version),"nodeId",y.nodeId),p[hN]=L.version,p[mN]=Date.now(),h.send(y),A.position=N+P}while(A.position<m.byteLength);gf++,sr(m.byteLength,"bytes-received",`${E}.${u}.${y?.table||"unknown_table"}`,"replication","ingest"),gf>Jh&&!Ie&&(Ie=!0,e.pause(),le.debug?.(`Commit backlog causing replication back-pressure, requesting that ${E} pause replication`)),h.send({type:"end_txn",localTime:T,remoteNodeIds:R,async onCommit(){if(y){let P=Date.now()-y.timestamp;sr(P,"replication-latency",E+"."+u+"."+y.table,y.type,"ingest")}gf--,Ie&&(Ie=!1,e.resume(),le.debug?.(`Replication resuming ${E}`)),Pe.length>0&&await Promise.all(Pe),le.trace?.("All blobs finished"),!b&&O&&(le.trace?.(s,"queuing confirmation of a commit at",O),setTimeout(()=>{e.send((0,je.encode)([OF,b])),le.trace?.(s,"sent confirmation of a commit at",b),b=null},Hie)),b=O,le.debug?.("last sequence committed",new Date(O),u)}})}catch(A){le.error?.(s,"Error handling incoming replication message",A)}}),e.on("ping",dt),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-q,hl({name:E,database:u,url:t.url,latency:t.connection.latency})),q=null}),e.on("close",(m,A)=>{clearInterval(v),clearTimeout(F),clearInterval(Z),ln&&ln.emit("close"),Sf&&Sf.end();for(let[I,{reject:y}]of g)y(new Error(`Connection closed ${A?.toString()} ${m}`));le.debug?.(s,"closed",m,A?.toString())});function Tf(){}a(Tf,"recordRemoteNodeSequence");function un(m,A){e.isFinished=!0,e.close(m,A)}a(un,"close");function Gr(){if(_||(_=!0,t.connection?.on("subscriptions-updated",Gr)),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let m=new Map;try{for(let y of h?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let O of y.value.nodes||[])O.lastTxnTime>(m.get(O.id)??0)&&m.set(O.id,O.lastTxnTime)}catch(y){if(!y.message.includes("Can not re"))throw y}let A=t.connection?.nodeSubscriptions?.[0];R=[];let I=t.connection?.nodeSubscriptions.map((y,O)=>{let P=[],{replicateByDefault:N}=y;if(y.subscriptions){for(let B of y.subscriptions)if(B.subscribe&&(B.schema||B.database)===u){let $=B.table;S?.[$]?.replicate!==!1&&P.push($)}N=!1}else for(let B in S)(N?S[B].replicate===!1:S[B].replicate)&&P.push(B);let L=d&&Ag(y.name,d),k=h?.dbisDB?.get([Symbol.for("seq"),L])??1,D=Math.max(k?.seqId??1,(typeof y.start_time=="string"?new Date(y.start_time).getTime():y.start_time)??1);if(le.debug?.("Starting time recorded in db",y.name,L,u,k?.seqId,"start time:",D,new Date(D)),A!==y){let B=d&&Ag(A.name,d),$=h?.dbisDB?.get([Symbol.for("seq"),B])??1;for(let j of $?.nodes||[])j.name===y.name&&(D=j.seqId,le.debug?.("Using sequence id from proxy node",A.name,D))}return R.push(L),m.get(L)>D&&(D=m.get(L),le.debug?.("Updating start time from more recent txn recorded",A.name,D)),{name:y.name,replicateByDefault:N,tables:P,startTime:D,endTime:y.end_time}});if(I)if(le.debug?.(s,"sending subscription request",I,h?.dbisDB?.path),clearTimeout(Q),I.length>0)e.send((0,je.encode)([SF,I]));else{let y=a(()=>{let O=performance.now();Q=setTimeout(()=>{ne<=O?un(1008,"No nodes to subscribe to"):y()},se)},"schedule_close");y()}}a(Gr,"sendSubscriptionRequestUpdate");function lu(m,A){if(!m)return;let I=kA[m];return I||(I=A.getResidencyRecord(m),kA[m]=I),I}a(lu,"getResidence");function uu(m){return!(Ba&&Ba!="*"&&!Ba[m]&&!Ba.includes?.(m)&&!Ba.some?.(A=>A.name===m))}a(uu,"checkDatabaseAccess");function ia(m){if(h=h||f.get(m),!uu(m))throw new Error(`Access to database "${m}" is not permitted`);h||le.warn?.(`No database named "${m}" was declared and registered`),d=h?.auditStore,S||(S=Xe()?.[m]);let A=Ze();if(A===E)throw A?new Error("Should not connect to self",A):new Error("Node name not defined");return Zh(A,m),!0}a(ia,"setDatabase");function Zh(m,A){let I=Xe()?.[A],y=[];for(let O in I){let P=I[O];y.push({table:O,schemaDefined:P.schemaDefined,attributes:P.attributes.map(N=>({name:N.name,type:N.type,isPrimaryKey:N.isPrimaryKey}))})}le.trace?.("Sending database info for node",m,"database name",A),e.send((0,je.encode)([TF,m,A,y]))}a(Zh,"sendNodeDBName");function oa(m){let A=Xe()?.[m],I=[];for(let y in A){if(Cr&&!Cr.some(P=>P.replicateByDefault?!P.tables.includes(y):P.tables.includes(y)))continue;let O=A[y];I.push({table:y,schemaDefined:O.schemaDefined,attributes:O.attributes.map(P=>({name:P.name,type:P.type,isPrimaryKey:P.isPrimaryKey}))})}e.send((0,je.encode)([NF,I,m]))}a(oa,"sendDBSchema"),Z=setInterval(()=>{for(let[m,A]of ye)A.lastChunk+3e4<Date.now()&&(le.warn?.(`Timeout waiting for blob stream to finish ${m} from ${E}`),ye.delete(m),A.end())},3e4).unref();let aa=1,Af=[];return{end(){Sf&&Sf.end(),ln&&ln.emit("close")},getRecord(m){let A=aa++;return new Promise((I,y)=>{let O=[yF,A,m.table.tableId,m.id];Af[m.table.tableId]||(O.push(m.table.tableName),Af[m.table.tableId]=!0),e.send((0,je.encode)(O)),g.set(A,{tableId:m.table.tableId,key:m.id,resolve(P){let{table:N,entry:L}=m;I(P),P&&N._recordRelocate(L,P)},reject:y})})},sendOperation(m){let A=aa++;return m.requestId=A,e.send((0,je.encode)([pN,m])),new Promise((I,y)=>{g.set(A,{resolve:I,reject:y})})}};function du(m){V(5),m<128?o[c++]=m:m<16384?(l.setUint16(c,m|32768),c+=2):m<1056964608?(l.setUint32(c,m|3221225472),c+=4):(o[c]=255,l.setUint32(c+1,m),c+=5)}function Ac(m,A=0,I=m.length){let y=I-A;V(y),m.copy(o,c,A,I),c+=y}function Rc(m){V(8),l.setFloat64(c,m),c+=8}function V(m){if(m+16>o.length-c){let A=Buffer.allocUnsafeSlow(c+m-i+65536>>10<<11);o.copy(A,0,i,c),c=c-i,i=0,o=A,l=new DataView(o.buffer,0,o.length)}}}function fN(e,t){let r=e.database??"data";if(r!=="data"&&!qe[r]){le.warn?.("Database not found",e.database);return}t||(t={});let n=!1,s=e.schemaDefined,i=t.attributes||[];for(let o=0;o<e.attributes?.length;o++){let c=e.attributes[o],l=i[o];(!l||l.name!==c.name||l.type!==c.type)&&(n=!0,s||(c.indexed=!0),i[o]=c)}return n?(le.debug?.("(Re)creating",e),ft({table:e.table,database:e.database,schemaDefined:e.schemaDefined,attributes:i,...t})):t}var PF,je,DF,LF,le,EN,MF,vF,El,UF,_N,SF,TF,AF,dd,RF,uN,yF,Cg,pN,Pg,bF,OF,NF,Dg,xF,hN,mN,Mg,Bie,gN,Ha,Lg,wF,Hie,IF,dN,CF,fp,SN=be(()=>{De();fo();zO();AN();Xn();PF=M(ae());H();wu();je=require("msgpackr"),DF=require("ws"),LF=require("worker_threads"),le=M(Ni());lp();EN=require("events"),MF=M(Zn()),vF=M(require("node:tls"));pl();El=M(require("node:process")),UF=require("node:net");ki();gs();_N=require("node:stream"),SF=129,TF=140,AF=141,dd=142,RF=130,uN=132,yF=133,Cg=134,pN=136,Pg=137,bF=143,OF=144,NF=145,Dg=146,xF=0,hN=1,mN=2,Mg=3,Bie=El.env.HDB_LEADER_URL||El.argv.includes("--HDB_LEADER_URL"),gN=new Map,Ha=new Map,Lg=!0,wF=300,Hie=2,IF=3e4;a(Ug,"createWebSocket");CF=1e3,fp=class extends EN.EventEmitter{constructor(r,n,s,i,o){super();this.url=r;this.subscription=n;this.databaseName=s;this.nodeName=i;this.authorization=o;this.nodeName=this.nodeName??ai(r)}static{a(this,"NodeReplicationConnection")}socket;startTime;retryTime=CF;retries=0;isConnected=!0;isFinished=!1;nodeSubscriptions=[];latency=0;replicateTablesByDefault;session;sessionResolve;sessionReject;async connect(){this.session||this.resetSession();let r=[];this.socket=await Ug(this.url,{serverName:this.nodeName,authorization:this.authorization});let n;le.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${El.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),le[this.isConnected?"info":"warn"]?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=CF,hl({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=_p(this.socket,{database:this.databaseName,subscription:this.subscription,url:this.url,connection:this},{replicates:!0}),this.sessionResolve(n)}),this.socket.on("error",s=>{s.code==="SELF_SIGNED_CERT_IN_CHAIN"?(le.warn?.(`Can not connect to ${this.url}, this server does not have a certificate authority for the certificate provided by ${this.url}`),s.isHandled=!0):s.code!=="ECONNREFUSED"&&(s.code==="UNABLE_TO_VERIFY_LEAF_SIGNATURE"?le.error?.(`Can not connect to ${this.url}, the certificate provided by ${this.url} is not trusted, this node needs to be added to the cluster, or a certificate authority needs to be added`):le.error?.(`Error in connection to ${this.url} due to ${s.message}`)),this.sessionReject(s)}),this.socket.on("close",(s,i)=>{if(this.isConnected&&(ad({name:this.nodeName,database:this.databaseName,url:this.url,finished:this.socket.isFinished}),this.isConnected=!1),this.socket.isFinished){this.isFinished=!0,n?.end(),this.emit("finished");return}if(++this.retries%20===1){let o=i?.toString();le.warn?.(`${n?"Disconnected from":"Failed to connect to"} ${this.url} (db: "${this.databaseName}"), due to ${o?'"'+o+'" ':""}(code: ${s})`)}n=null,this.resetSession(),setTimeout(()=>{this.connect()},this.retryTime).unref(),this.retryTime+=this.retryTime>>3})}resetSession(){this.session=new Promise((r,n)=>{this.sessionResolve=r,this.sessionReject=n})}subscribe(r,n){this.nodeSubscriptions=r,this.replicateTablesByDefault=n,this.emit("subscriptions-updated",r)}unsubscribe(){this.socket.isFinished=!0,this.socket.close(1008,"No longer subscribed")}getRecord(r){return this.session.then(n=>n.getRecord(r))}};a(_p,"replicateOverWS");a(fN,"ensureTableIfChanged")});var wo={};ve(wo,{clearThisNodeName:()=>Yie,disableReplication:()=>qie,enabled_databases:()=>Ba,forEachReplicatedDatabase:()=>Da,getThisNodeId:()=>xg,getThisNodeName:()=>Ze,getThisNodeUrl:()=>La,hostnameToUrl:()=>Fg,lastTimeInAuditStore:()=>op,monitorNodeCAs:()=>YF,replicateOperation:()=>zie,replication_certificate_authorities:()=>gl,sendOperationToNode:()=>mp,servers:()=>Fie,setReplicator:()=>zF,start:()=>Gie,startOnMainThread:()=>QO,subscribeToNode:()=>od,unsubscribeFromNode:()=>Og,urlToNodeName:()=>ai});function Gie(e){if(e.port||(e.port=Os.default.get(x.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=Os.default.get(x.OPERATIONSAPI_NETWORK_SECUREPORT)),!Ze())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let n of cp(e))t.set(ai(n.url),n);$ie(e),e={mtls:!0,isOperationsServer:!0,maxPayload:10*1024*1024*1024,...e};let r=We.ws(async(n,s,i,o)=>{if(s.headers.get("sec-websocket-protocol")!=="harperdb-replication-v1")return o(n,s,i);await i,n._socket.unref(),_p(n,e,s?.user),n.on("error",c=>{c.code!=="ECONNREFUSED"&&cr.error("Error in connection to "+this.url,c.message)})},e);e.runFirst=!0,We.http((n,s)=>{if(n.isWebSocket&&n.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){!n.authorized&&n._nodeRequest.socket.authorizationError&&cr.error(`Incoming client connection from ${n.ip} did not have valid certificate, you may need turn on enableRootCAs in the config if you are using a publicly signed certificate, or add the CA to the server's trusted CAs`,n._nodeRequest.socket.authorizationError);let i=or().primaryStore;if(n.authorized&&n.peerCertificate.subject){let o=n.peerCertificate.subject,c=o&&(i.get(o.CN)||t.get(o.CN));if(c)if(c?.revoked_certificates?.includes(n.peerCertificate.serialNumber)){cr.warn("Revoked certificate used in attempt to connect to node",c.name,"certificate serial number",n.peerCertificate.serialNumber);return}else n.user=c;else cr.warn(`No node found for certificate common name ${o.CN}, available nodes are ${Array.from(i.getRange({}).filter(({value:l})=>l).map(({key:l})=>l)).join(", ")} and routes ${Array.from(t.keys()).join(", ")}, connection will require credentials.`)}else{let o=i.get(n.ip)||t.get(n.ip);o?n.user=o:cr.warn(`No node found for IP address ${n.ip}, available nodes are ${Array.from(new Set([...i.getKeys(),...t.keys()])).join(", ")}, connection will require credentials.`)}}return s(n)},e);for(let n of r)if(n.secureContexts){let s=a(()=>{let i=new Set(n.secureContexts.values());n.defaultContext&&i.add(n.defaultContext);for(let o of i)try{let c=Array.from(gl);o.options.availableCAs&&c.push(...o.options.availableCAs.values());let l={...o.options,ca:c};o.updatedContext=kg.createSecureContext(l)}catch(c){cr.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),YF(s),Os.default.get(x.REPLICATION_ENABLEROOTCAS)!==!1&&s()}}function YF(e){let t=0;sd(r=>{r?.ca&&(gl.add(r.ca),gl.size!==t&&(t=gl.size,e?.()))})}function qie(e=!0){KF=e}function $ie(e){KF||(Xe(),Ba=e.databases,Da(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||Ha;for(let[s,i]of hp){let o=i.get(r);o&&(o.subscribe([],!1),i.delete(r))}n.delete(r);return}for(let n in t){let s=t[n];zF(r,s,e),gN.get(s)?.forEach(i=>i(s))}}))}function zF(e,t,r){if(!t)return console.error(`Attempt to replicate non-existent table ${t.name} from database ${e}`);if(t.replicate===!1||t.sources?.some(s=>s.isReplicator))return;let n;t.sourcedFrom(class WF extends $r{static{a(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||Ha,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(cr.trace("Setting up replicator subscription to database",e),!o?.auditStore)return this.subscription=o=new Bn,i.set(e,o),o.tableById=c,o.auditStore=t.auditStore,o.dbisDB=t.dbisDB,o.databaseName=e,l&&l(o),o;this.subscription=o}static subscribeOnThisThread(i,o){return!0}static async load(i){if(i){let o=i.residencyId,c=i.residency||t.dbisDB.get([Symbol.for("residency_by_id"),o]);if(c){let l,u=new Set;do{let f;for(let p of c){let _=Vie(p,WF.subscription,e);_?.isConnected&&!u.has(_)&&(!f||_.latency<f.latency)&&(f=_)}if(!f)throw l||new $F.ServerError("No connection to any other nodes are available",502);let d={requestId:kie++,table:t,entry:i,id:i.key};u.add(f);try{return await f.getRecord(d)}catch(p){if(f.isConnected)throw p;cr.warn("Error in load from node",Hg,p),l||(l=p)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function jF(e,t,r,n,s){let i=hp.get(e);i||hp.set(e,i=new Map);let o=i.get(r);if(o)return o;if(t)return i.set(r,o=new fp(e,t,r,n,s)),o.connect(),o.once("finished",()=>i.delete(r)),o}function Vie(e,t,r){let n=kF.get(e)?.get(r);if(n)return n;let s=or().primaryStore.get(e);return s?.url&&(n=jF(s.url,t,r,e,s.authorization),kF.set(e,hp.get(s.url))),n}async function mp(e,t,r){r||(r={}),r.serverName=e.name;let n=await Ug(e.url,r),s=_p(n,{},{});return new Promise((i,o)=>{n.on("open",()=>{i(s.sendOperation(t))}),n.on("error",c=>{o(c)}),n.on("close",c=>{cr.info("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function od(e){try{VF.isMainThread&&cr.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=Ha.get(e.database);if(!t){let n;t=new Promise(s=>{cr.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,Ha.set(e.database,t)}let r=jF(e.nodes[0].url,t,e.database,e.nodes[0].name,e.nodes[0].authorization);e.nodes[0].name===void 0?r.tentativeNode=e.nodes[0]:r.nodeName=e.nodes[0].name,r.subscribe(e.nodes.filter(n=>ap(n,e.database)),e.replicateByDefault)}catch(t){cr.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function Og({name:e,url:t,database:r}){cr.trace("Unsubscribing from node",e,t,r,"nodes",Array.from(or().primaryStore.getRange({})));let n=hp.get(t);if(n){let s=n.get(r);s&&(s.unsubscribe(),n.delete(r))}}function Kie(){if(RN!==void 0)return RN;let e=Os.default.get(x.OPERATIONSAPI_TLS_CERTIFICATE)||Os.default.get(x.TLS_CERTIFICATE);if(e)return RN=new GF.X509Certificate((0,qF.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function Ze(){return Hg||(Hg=Os.default.get("replication_hostname")??ai(Os.default.get("replication_url"))??Kie()??FF("operationsapi_network_secureport")??FF("operationsapi_network_port")??"127.0.0.1")}function Yie(){Hg=void 0}function FF(e){let t=Os.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function Bg(e){let t=Os.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function xg(e){return ip(e)?.[Ze()]}function La(){let e=Os.default.get("replication_url");return e||Fg(Ze())}function Fg(e){let t=Bg("replication_port");if(t)return`ws://${e}:${t}`;if(t=Bg("replication_secureport"),t)return`wss://${e}:${t}`;if(t=Bg("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=Bg("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function ai(e){if(e)return new URL(e).hostname}function Da(e,t){for(let n of Object.getOwnPropertyNames(qe))r(n);return pp(n=>{r(n)}),Tl((n,s)=>{r(n.databaseName)});function r(n){let s=qe[n];cr.trace("Checking replication status of ",n,e?.databases),e?.databases===void 0||e.databases==="*"||e.databases.includes(n)||e.databases.some?.(i=>i.name===n)||!s?t(s,n,!0):Wie(n)&&t(s,n,!1)}a(r,"forDatabase")}function Wie(e){let t=qe[e];for(let r in t)if(t[r].replicate)return!0}function op(e){for(let t of e.getKeys({limit:1,reverse:!0}))return t}async function zie(e){let t={message:""};if(e.replicated){e.replicated=!1,cr.trace?.("Replicating operation",e.operation,"to nodes",We.nodes.map(n=>n.name));let r=await Promise.allSettled(We.nodes.map(n=>mp(n,e)));t.replicated=r.map((n,s)=>{let i=n.status==="rejected"?{status:"failed",reason:n.reason.toString()}:n.value;return i.node=We.nodes[s]?.name,i})}return t}var Os,cr,GF,qF,kg,$F,VF,KF,kie,Fie,gl,Ba,hp,kF,RN,Hg,Xn=be(()=>{De();Ea();pu();SN();Vr();Os=M(ae()),cr=M(z()),GF=require("crypto"),qF=require("fs");lp();pl();H();zO();kg=M(require("node:tls")),$F=M(pe()),VF=require("worker_threads"),kie=1,Fie=[],gl=Os.default.get(x.REPLICATION_ENABLEROOTCAS)!==!1?new Set(kg.rootCertificates):new Set;a(Gie,"start");a(YF,"monitorNodeCAs");a(qie,"disableReplication");a($ie,"assignReplicationSource");a(zF,"setReplicator");hp=new Map;a(jF,"getConnection");kF=new Map;a(Vie,"getConnectionByName");a(mp,"sendOperationToNode");a(od,"subscribeToNode");a(Og,"unsubscribeFromNode");a(Kie,"getCommonNameFromCert");a(Ze,"getThisNodeName");a(Yie,"clearThisNodeName");Object.defineProperty(We,"hostname",{get(){return Ze()}});a(FF,"getHostFromListeningPort");a(Bg,"getPortFromListeningPort");a(xg,"getThisNodeId");We.replication={getThisNodeId:xg,exportIdMapping:ip};a(La,"getThisNodeUrl");a(Fg,"hostnameToUrl");a(ai,"urlToNodeName");a(Da,"forEachReplicatedDatabase");a(Wie,"hasExplicitlyReplicatedTable");a(op,"lastTimeInAuditStore");a(zie,"replicateOperation")});var Kg=w((lDe,eG)=>{"use strict";var fd=lk(),{validateBySchema:Ep}=ot(),{common_validators:_d,schema_regex:yN}=Di(),lr=require("joi"),jie=z(),Jie=require("uuid").v4,$g=To(),pd=(H(),C(G)),Qie=require("util"),ka=Vn(),{handleHDBError:Io,hdb_errors:Xie,ClientError:gp}=pe(),{HDB_ERROR_MSGS:Gg,HTTP_STATUS_CODES:Co}=Xie,{SchemaEventMsg:Vg}=ri(),JF=ir(),{getDatabases:Zie}=(De(),C(nt)),{transformReq:hd}=ie(),{replicateOperation:QF}=(Xn(),C(wo)),qg=lr.string().min(1).max(_d.schema_length.maximum).pattern(yN).messages({"string.pattern.base":"{:#label} "+_d.schema_format.message}),eoe=lr.string().min(1).max(_d.schema_length.maximum).pattern(yN).messages({"string.pattern.base":"{:#label} "+_d.schema_format.message}).required(),toe=lr.string().min(1).max(_d.schema_length.maximum).pattern(yN).messages({"string.pattern.base":"{:#label} "+_d.schema_format.message,"any.required":"'primary_key' is required","string.base":"'primary_key' must be a string"}).required();eG.exports={createSchema:roe,createSchemaStructure:XF,createTable:noe,createTableStructure:ZF,createAttribute:coe,dropSchema:soe,dropTable:ioe,dropAttribute:ooe,getBackup:loe};async function roe(e){let t=await XF(e);return $g.signalSchemaChange(new Vg(process.pid,e.operation,e.schema)),t}a(roe,"createSchema");async function XF(e){let t=Ep(e,lr.object({database:qg,schema:qg}));if(t)throw new gp(t.message);if(hd(e),!await fd.checkSchemaExists(e.schema))throw Io(new Error,Gg.SCHEMA_EXISTS_ERR(e.schema),Co.BAD_REQUEST,pd.LOG_LEVELS.ERROR,Gg.SCHEMA_EXISTS_ERR(e.schema),!0);return await ka.createSchema(e),`database '${e.schema}' successfully created`}a(XF,"createSchemaStructure");async function noe(e){return hd(e),e.hash_attribute=e.primary_key??e.hash_attribute,await ZF(e)}a(noe,"createTable");async function ZF(e){let t=Ep(e,lr.object({database:qg,schema:qg,table:eoe,residence:lr.array().items(lr.string().min(1)).optional(),hash_attribute:toe}));if(t)throw new gp(t.message);if(!await fd.checkSchemaTableExists(e.schema,e.table))throw Io(new Error,Gg.TABLE_EXISTS_ERR(e.schema,e.table),Co.BAD_REQUEST,pd.LOG_LEVELS.ERROR,Gg.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:Jie(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await ka.createTable(n,e);else throw Io(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Co.BAD_REQUEST);else await ka.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(ZF,"createTableStructure");async function soe(e){let t=Ep(e,lr.object({database:lr.string(),schema:lr.string()}).or("database","schema").messages({"object.missing":"'database' is required"}));if(t)throw new gp(t.message);hd(e);let r=await fd.checkSchemaExists(e.schema);if(r)throw Io(new Error,r,Co.NOT_FOUND,pd.LOG_LEVELS.ERROR,r,!0);let n=await fd.schema_describe.describeSchema({schema:e.schema}),s=Object.keys(global.hdb_schema[e.schema]);await ka.dropSchema(e),$g.signalSchemaChange(new Vg(process.pid,e.operation,e.schema)),await JF.purgeSchemaTableStreams(e.schema,s);let i=await QF(e);return i.message=`successfully deleted '${e.schema}'`,i}a(soe,"dropSchema");async function ioe(e){let t=Ep(e,lr.object({database:lr.string(),schema:lr.string(),table:lr.string().required()}));if(t)throw new gp(t.message);hd(e);let r=await fd.checkSchemaTableExists(e.schema,e.table);if(r)throw Io(new Error,r,Co.NOT_FOUND,pd.LOG_LEVELS.ERROR,r,!0);await ka.dropTable(e),await JF.purgeTableStream(e.schema,e.table);let n=await QF(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}a(ioe,"dropTable");async function ooe(e){let t=Ep(e,lr.object({database:lr.string(),schema:lr.string(),table:lr.string().required(),attribute:lr.string().required()}));if(t)throw new gp(t.message);hd(e);let r=await fd.checkSchemaTableExists(e.schema,e.table);if(r)throw Io(new Error,r,Co.NOT_FOUND,pd.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw Io(new Error,"You cannot drop a hash attribute",Co.BAD_REQUEST,void 0,void 0,!0);if(pd.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw Io(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Co.BAD_REQUEST,void 0,void 0,!0);try{return await ka.dropAttribute(e),aoe(e),$g.signalSchemaChange(new Vg(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw jie.error(`Got an error deleting attribute ${Qie.inspect(e)}.`),n}}a(ooe,"dropAttribute");function aoe(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(aoe,"dropAttributeFromGlobal");async function coe(e){hd(e);let t=Zie()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw Io(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Co.BAD_REQUEST,void 0,void 0,!0);return await ka.createAttribute(e),$g.signalSchemaChange(new Vg(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(coe,"createAttribute");function loe(e){return ka.getBackup(e)}a(loe,"getBackup")});var rG=w((dDe,tG)=>{"use strict";var{OPERATIONS_ENUM:uoe}=(H(),C(G)),bN=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=uoe.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};tG.exports=bN});var ON=w((pDe,aG)=>{"use strict";var doe=Vn(),_De=rG(),Yg=ie(),Wg=(H(),C(G)),foe=ae(),{handleHDBError:nG,hdb_errors:_oe}=pe(),{HDB_ERROR_MSGS:sG,HTTP_STATUS_CODES:iG}=_oe,poe=Object.values(Wg.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),oG="To use this operation audit log must be enabled in harperdb-config.yaml";aG.exports=hoe;async function hoe(e){if(Yg.isEmpty(e.schema))throw new Error(sG.SCHEMA_REQUIRED_ERR);if(Yg.isEmpty(e.table))throw new Error(sG.TABLE_REQUIRED_ERR);if(!foe.get(Wg.CONFIG_PARAMS.LOGGING_AUDITLOG))throw nG(new Error,oG,iG.BAD_REQUEST,Wg.LOG_LEVELS.ERROR,oG,!0);let t=Yg.checkSchemaTableExist(e.schema,e.table);if(t)throw nG(new Error,t,iG.NOT_FOUND,Wg.LOG_LEVELS.ERROR,t,!0);if(!Yg.isEmpty(e.search_type)&&poe.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await doe.readAuditLog(e)}a(hoe,"readAuditLog")});var lG=w((mDe,cG)=>{"use strict";var{OPERATIONS_ENUM:moe}=(H(),C(G)),NN=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=moe.GET_BACKUP,this.schema=t,this.table=r}};cG.exports=NN});var fG=w((TDe,dG)=>{"use strict";var Eoe=Vn(),gDe=lG(),wN=ie(),goe=(H(),C(G)),SDe=ae(),{handleHDBError:Soe,hdb_errors:Toe}=pe(),{HDB_ERROR_MSGS:uG,HTTP_STATUS_CODES:Aoe}=Toe;dG.exports=Roe;async function Roe(e){if(wN.isEmpty(e.schema))throw new Error(uG.SCHEMA_REQUIRED_ERR);if(wN.isEmpty(e.table))throw new Error(uG.TABLE_REQUIRED_ERR);let t=wN.checkSchemaTableExist(e.schema,e.table);if(t)throw Soe(new Error,t,Aoe.NOT_FOUND,goe.LOG_LEVELS.ERROR,t,!0);return await Eoe.getBackup(read_audit_log_object)}a(Roe,"getBackup")});var mG=w((RDe,hG)=>{"use strict";var yoe=ae(),Fa=require("joi"),boe=ot(),_G=require("moment"),Ooe=require("fs-extra"),IN=require("path"),Noe=require("lodash"),Sp=(H(),C(G)),{LOG_LEVELS:Al}=(H(),C(G)),woe="YYYY-MM-DD hh:mm:ss",Ioe=IN.resolve(__dirname,"../logs");hG.exports=function(e){return boe.validateBySchema(e,Coe)};var Coe=Fa.object({from:Fa.custom(pG),until:Fa.custom(pG),level:Fa.valid(Al.NOTIFY,Al.FATAL,Al.ERROR,Al.WARN,Al.INFO,Al.DEBUG,Al.TRACE),order:Fa.valid("asc","desc"),limit:Fa.number().min(1),start:Fa.number().min(0),log_name:Fa.custom(Poe)});function pG(e,t){if(_G(e,_G.ISO_8601).format(woe)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(pG,"validateDatetime");function Poe(e,t){if(Noe.invert(Sp.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=yoe.get(Sp.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?Sp.LOG_NAMES.HDB:e,i=s===Sp.LOG_NAMES.INSTALL?IN.join(Ioe,Sp.LOG_NAMES.INSTALL):IN.join(n,s);return Ooe.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(Poe,"validateReadLogPath")});var PN=w((bDe,gG)=>{"use strict";var zg=(H(),C(G)),Doe=z(),Loe=ae(),Moe=mG(),CN=require("path"),EG=require("fs-extra"),{once:voe}=require("events"),{handleHDBError:Uoe,hdb_errors:xoe}=pe(),{PACKAGE_ROOT:Boe}=it(),Hoe=CN.join(Boe,"logs"),koe=1e3,Foe=200;gG.exports=Goe;async function Goe(e){let t=Moe(e);if(t)throw Uoe(t,t.message,xoe.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=Loe.get(zg.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?zg.LOG_NAMES.HDB:e.log_name,s=n===zg.LOG_NAMES.INSTALL?CN.join(Hoe,zg.LOG_NAMES.INSTALL):CN.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,l=c?new Date(e.from):void 0,u=e.until!==void 0,f=u?new Date(e.until):void 0,d=e.limit===void 0?koe:e.limit,p=e.order===void 0?void 0:e.order,_=e.start===void 0?0:e.start,h=_+d,S=0;p==="desc"&&!l&&!f&&(S=Math.max(EG.statSync(s).size-(h+5)*Foe,0));let g=EG.createReadStream(s,{start:S});g.on("error",F=>{Doe.error(F)});let R=0,E=[],T="",b;g.on("data",F=>{let q=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;F=T+F;let Y=0,Z;for(;(Z=q.exec(F))&&!g.destroyed;){b&&(b.message=F.slice(Y,Z.index),v(b));let[se,Q,ne]=Z,J=ne.split("] ["),me=J[0],ye=J[1];J.splice(0,2),b={timestamp:Q,thread:me,level:ye,tags:J,message:""},Y=Z.index+se.length}T=F.slice(Y)}),g.on("end",F=>{g.destroyed||b&&(b.message=T.trim(),v(b))}),g.resume();function v(F){let q,Y,Z;switch(!0){case(i&&c&&u):q=new Date(F.timestamp),Y=new Date(l),Z=new Date(f),F.level===o&&q>=Y&&q<=Z&&R<_?R++:F.level===o&&q>=Y&&q<=Z&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case(i&&c):q=new Date(F.timestamp),Y=new Date(l),F.level===o&&q>=Y&&R<_?R++:F.level===o&&q>=Y&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case(i&&u):q=new Date(F.timestamp),Z=new Date(f),F.level===o&&q<=Z&&R<_?R++:F.level===o&&q<=Z&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case(c&&u):q=new Date(F.timestamp),Y=new Date(l),Z=new Date(f),q>=Y&&q<=Z&&R<_?R++:q>=Y&&q<=Z&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case i:F.level===o&&R<_?R++:F.level===o&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case c:q=new Date(F.timestamp),Y=new Date(l),q>=Y&&R<_?R++:q>=Y&&R>=_&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case u:q=new Date(F.timestamp),Z=new Date(f),q<=Z&&R<_?R++:q<=Z&&R>=_&&(Ga(F,p,E),R++,R===h&&g.destroy());break;default:R<_?R++:(Ga(F,p,E),R++,R===h&&g.destroy())}}return a(v,"onLogMessage"),await voe(g,"close"),E}a(Goe,"readLog");function Ga(e,t,r){t==="desc"?qoe(e,r):t==="asc"?$oe(e,r):r.push(e)}a(Ga,"pushLineToResult");function qoe(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(qoe,"insertDescending");function $oe(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($oe,"insertAscending")});var jg=w((PDe,RG)=>{"use strict";var DN=require("joi"),{string:md,boolean:SG,date:Voe}=DN.types(),Koe=ot(),{validateSchemaExists:NDe,validateTableExists:wDe,validateSchemaName:IDe}=Di(),Yoe=(H(),C(G)),Woe=Tt(),TG=ae();TG.initSync();var CDe=md.invalid(TG.get(Yoe.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(Woe.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),AG={operation:md.valid("add_node","update_node","set_node_replication"),node_name:md.optional(),subscriptions:DN.array().items({table:md.optional(),schema:md.optional(),database:md.optional(),subscribe:SG.required(),publish:SG.required().custom(joe),start_time:Voe.iso()})};function zoe(e){return Koe.validateBySchema(e,DN.object(AG))}a(zoe,"addUpdateNodeValidator");function joe(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(joe,"checkForFalsy");RG.exports={addUpdateNodeValidator:zoe,validation_schema:AG}});var Ed=w((LDe,yG)=>{"use strict";var LN=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},MN=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};yG.exports={Node:LN,NodeSubscription:MN}});var OG=w((vDe,bG)=>{"use strict";var Joe=(H(),C(G)).OPERATIONS_ENUM,vN=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Joe.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};bG.exports=vN});var Tp=w((xDe,NG)=>{"use strict";var UN=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},xN=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)}};NG.exports={RemotePayloadObject:UN,RemotePayloadSubscription:xN}});var IG=w((HDe,wG)=>{"use strict";var BN=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}};wG.exports=BN});var PG=w((VDe,CG)=>{"use strict";var Qoe=IG(),FDe=xt(),GDe=_t(),Xoe=z(),{getSchemaPath:qDe,getTransactionAuditStorePath:$De}=gt(),{getDatabases:Zoe}=(De(),C(nt));CG.exports=eae;async function eae(e){let t=new Qoe;try{let r=Zoe()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats();t.schema=e.schema,t.table=e.name,t.record_count=n.entryCount,t.transaction_log_record_count=s.entryCount}catch(r){Xoe.warn(`unable to stat table dbi due to ${r}`)}return t}a(eae,"lmdbGetTableSize")});var LG=w((YDe,DG)=>{"use strict";var HN=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}};DG.exports=HN});var Po=w((XDe,xG)=>{"use strict";var tae=require("fs-extra"),rae=require("path"),Xr=require("systeminformation"),qa=z(),MG=ir(),zDe=Tt(),gd=(H(),C(G)),nae=PG(),sae=go(),{getThreadInfo:vG}=rt(),Ap=ae();Ap.initSync();var iae=LG(),{openEnvironment:jDe}=_t(),{getSchemaPath:JDe}=gt(),{database:QDe,databases:kN}=(De(),C(nt)),Jg;xG.exports={getHDBProcessInfo:$N,getNetworkInfo:KN,getDiskInfo:VN,getMemoryInfo:qN,getCPUInfo:GN,getTimeInfo:FN,getSystemInformation:YN,systemInformation:oae,getTableSize:WN,getMetrics:zN};function FN(){return Xr.time()}a(FN,"getTimeInfo");async function GN(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:u,...f}=await Xr.cpu();f.cpu_speed=await Xr.cpuCurrentSpeed();let{raw_currentload:d,raw_currentload_idle:p,raw_currentload_irq:_,raw_currentload_nice:h,raw_currentload_system:S,raw_currentload_user:g,cpus:R,...E}=await Xr.currentLoad();return E.cpus=[],R.forEach(T=>{let{raw_load:b,raw_load_idle:v,raw_load_irq:F,raw_load_nice:q,raw_load_system:Y,raw_load_user:Z,...se}=T;E.cpus.push(se)}),f.current_load=E,f}catch(e){return qa.error(`error in getCPUInfo: ${e}`),{}}}a(GN,"getCPUInfo");async function qN(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Xr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return qa.error(`error in getMemoryInfo: ${e}`),{}}}a(qN,"getMemoryInfo");async function $N(){let e={core:[],clustering:[]};try{let t=await Xr.processes(),r;try{r=Number.parseInt(await tae.readFile(rae.join(Ap.get(gd.CONFIG_PARAMS.ROOTPATH),gd.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===gd.NODE_ERROR_CODES.ENOENT)qa.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 qa.error(`error in getHDBProcessInfo: ${t}`),e}}a($N,"getHDBProcessInfo");async function VN(){let e={};try{if(!Ap.get(gd.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Xr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...u}=await Xr.fsStats();return e.read_write=u,e.size=await Xr.fsSize(),e}catch(t){return qa.error(`error in getDiskInfo: ${t}`),e}}a(VN,"getDiskInfo");async function KN(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return Ap.get(gd.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await Xr.networkInterfaceDefault(),e.latency=await Xr.inetChecksite("google.com"),(await Xr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:u,ieee8021xState:f,carrier_changes:d,...p}=n;e.interfaces.push(p)}),(await Xr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)})),e}catch(t){return qa.error(`error in getNetworkInfo: ${t}`),e}}a(KN,"getNetworkInfo");async function YN(){if(Jg!==void 0)return Jg;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Xr.osInfo();e=c;let l=await Xr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,Jg=e,Jg}catch(t){return qa.error(`error in getSystemInformation: ${t}`),e}}a(YN,"getSystemInformation");async function WN(){let e=[],t=await sae.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await nae(n));return e}a(WN,"getTableSize");async function zN(){let e={};for(let t in kN){let r=e[t]={},n=r.tables={};for(let s in kN[t])try{let i=kN[t][s];if(!r.readers&&(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[u,f,d]=l.trim().split(" ");return{pid:u,thread:f,txnid:d}}),i.auditStore)){let{treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:f,entryCount:d,overflowPages:p}=i.auditStore.getStats();r.audit={treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:f,entryCount:d,overflowPages:p}}let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){qa.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(zN,"getMetrics");async function UG(){if(Ap.get(gd.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await MG.getNATSReferences(),t=await MG.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(UG,"getNatsStreamInfo");async function oae(e){let t=new iae;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await YN(),t.time=FN(),t.cpu=await GN(),t.memory=await qN(),t.disk=await VN(),t.network=await KN(),t.harperdb_processes=await $N(),t.table_size=await WN(),t.metrics=await zN(),t.threads=await vG(),t.replication=await UG(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await YN();break;case"time":t.time=FN();break;case"cpu":t.cpu=await GN();break;case"memory":t.memory=await qN();break;case"disk":t.disk=await VN();break;case"network":t.network=await KN();break;case"harperdb_processes":t.harperdb_processes=await $N();break;case"table_size":t.table_size=await WN();break;case"database_metrics":case"metrics":t.metrics=await zN();break;case"threads":t.threads=await vG();break;case"replication":t.replication=await UG();break;default:break}return t}a(oae,"systemInformation")});var Do=w((rLe,FG)=>{"use strict";var aae=yn(),jN=ie(),cae=require("util"),Rl=(H(),C(G)),BG=ae();BG.initSync();var lae=wO(),HG=Yr(),{Node:eLe,NodeSubscription:tLe}=Ed(),uae=Fu(),dae=OG(),{RemotePayloadObject:fae,RemotePayloadSubscription:_ae}=Tp(),{handleHDBError:pae,hdb_errors:hae}=pe(),{HTTP_STATUS_CODES:mae,HDB_ERROR_MSGS:Eae}=hae,gae=ni(),Sae=Po(),{packageJson:Tae}=it(),{getDatabases:Aae}=(De(),C(nt)),Rae=cae.promisify(lae.authorize),yae=HG.searchByHash,bae=HG.searchByValue;FG.exports={authHeaderToUser:Oae,isEmpty:Nae,getNodeRecord:wae,upsertNodeRecord:Iae,buildNodePayloads:Cae,checkClusteringEnabled:Pae,getAllNodeRecords:Dae,getSystemInfo:Lae,reverseSubscription:kG};async function Oae(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await Rae(t,null),e}a(Oae,"authHeaderToUser");function Nae(e){return e==null}a(Nae,"isEmpty");async function wae(e){let t=new uae(Rl.SYSTEM_SCHEMA_NAME,Rl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return yae(t)}a(wae,"getNodeRecord");async function Iae(e){let t=new dae(Rl.SYSTEM_SCHEMA_NAME,Rl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return aae.upsert(t)}a(Iae,"upsertNodeRecord");function kG(e){if(jN.isEmpty(e.subscribe)||jN.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(kG,"reverseSubscription");function Cae(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:u}=c,f=jN.getTableHashAttribute(l,u),{subscribe:d,publish:p}=kG(c),_=Aae()[l]?.[u],h=new _ae(l,u,f,p,d,c.start_time,_.schemaDefined?_.attributes:void 0);s.push(h)}return new fae(r,t,s,n)}a(Cae,"buildNodePayloads");function Pae(){if(!BG.get(Rl.CONFIG_PARAMS.CLUSTERING_ENABLED))throw pae(new Error,Eae.CLUSTERING_NOT_ENABLED,mae.BAD_REQUEST,void 0,void 0,!0)}a(Pae,"checkClusteringEnabled");async function Dae(){let e=new gae(Rl.SYSTEM_SCHEMA_NAME,Rl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await bae(e))}a(Dae,"getAllNodeRecords");async function Lae(){let e=await Sae.getSystemInformation();return{hdb_version:Tae.version,node_version:e.node_version,platform:e.platform}}a(Lae,"getSystemInfo")});var JN=w((sLe,zG)=>{"use strict";var Qg=ir(),GG=ie(),qG=Tt(),$G=(H(),C(G)),Xg=z(),VG=Kg(),Mae=v_(),{RemotePayloadObject:vae}=Tp(),{handleHDBError:KG,hdb_errors:Uae}=pe(),{HTTP_STATUS_CODES:YG}=Uae,{NodeSubscription:WG}=Ed();zG.exports=xae;async function xae(e,t){let r;try{r=await Qg.request(`${t}.${qG.REQUEST_SUFFIX}`,new vae($G.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),Xg.trace("Response from remote describe all request:",r)}catch(o){Xg.error(`addNode received error from describe all request to remote node: ${o}`);let c=Qg.requestErrorHandler(o,"add_node",t);throw KG(new Error,c,YG.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===qG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw KG(new Error,o,YG.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===$G.SYSTEM_SCHEMA_NAME){await Qg.createLocalTableStream(l,c);let h=new WG(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let u=GG.doesSchemaExist(l),f=n[l]!==void 0,d=c?GG.doesTableExist(l,c):!0,p=c?n?.[l]?.[c]!==void 0:!0;if(!u&&!f||!d&&!p){s.push(o);continue}if(!u&&f&&(Xg.trace(`addNode creating schema: ${l}`),await VG.createSchema({operation:"create_schema",schema:l})),!d&&p){Xg.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new Mae(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await VG.createTable(h)}await Qg.createLocalTableStream(l,c);let _=new WG(l,c,o.publish,o.subscribe);_.start_time=o.start_time,i.push(_)}return{added:i,skipped:s}}a(xae,"reviewSubscriptions")});var yl={};ve(yl,{addNodeBack:()=>Gae,removeNodeBack:()=>qae,setNode:()=>Fae});async function Fae(e){e.node_name&&!e.hostname&&(e.hostname=e.node_name),e.verify_tls!==void 0&&(e.rejectUnauthorized=e.verify_tls);let{url:t,hostname:r}=e;t?r||(r=e.hostname=ai(t)):t=Fg(r);let n=(0,JG.validateBySchema)(e,kae);if(n)throw(0,Lo.handleHDBError)(n,n.message,Hae.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new Lo.ClientError("url or hostname is required for remove_node operation");let _=r,h=or(),S=await h.get(_);if(!S)throw new Lo.ClientError(_+" does not exist");try{await mp({url:S.url},{operation:Yt.REMOVE_NODE_BACK,name:S?.subscriptions?.length>0?Ze():_},void 0)}catch(g){es.warn(`Error removing node from target node ${_}, if it is offline and we be online in the future, you may need to clean up this node manually, or retry:`,g)}return await h.delete(_),`Successfully removed '${_}' from cluster`}if(!t)throw new Lo.ClientError("url required for this operation");let s=La();if(s==null)throw new Lo.ClientError("replication url is missing from harperdb-config.yaml");let i,o,c;if(t?.startsWith("wss:")){i=await(0,Ns.getReplicationCert)();let _=await(0,Ns.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,Ns.createCsr)(),es.info("Sending CSR to target node:",t)):_&&(c=_.certificate,es.info("Sending CA named",_.name,"to target node",t))}let l={operation:Yt.ADD_NODE_BACK,hostname:(0,Va.get)(x.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:o,cert_auth:c,authorization:e.retain_authorization?e.authorization:null};if((0,Va.get)(x.REPLICATION_SHARD)!==void 0&&(l.shard=(0,Va.get)(x.REPLICATION_SHARD)),e.subscriptions?l.subscriptions=e.subscriptions.map(jG):l.subscriptions=null,e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let _=jG(e);l.subscribe=_.subscribe,l.publish=_.publish}e?.authorization?.username&&e?.authorization?.password&&(e.authorization="Basic "+Buffer.from(e.authorization.username+":"+e.authorization.password).toString("base64"));let u,f;try{u=await mp({url:t},l,e)}catch(_){_.message=`Error returned from ${t}: `+_.message,es.warn("Error adding node:",t,"to cluster:",_),f=_}if(o&&(!u?.certificate||!u?.certificate?.includes?.("BEGIN CERTIFICATE")))throw f?(f.message+=" and connection was required to sign certificate",f):new Error(`Unexpected certificate signature response from node ${t} response: ${JSON.stringify(u)}`);o&&(es.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,Ns.setCertTable)({name:Bae.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,Ns.setCertTable)({name:Ze(),uses:["https","operations","wss"],certificate:u.certificate,private_key_name:i?.options?.key_file,is_authority:!1,is_self_signed:!1}),c=u.signingCA);let d={url:t,ca:u?.usingCA};if(e.hostname&&(d.name=e.hostname),e.subscriptions?d.subscriptions=e.subscriptions:d.replicates=!0,e.start_time&&(d.start_time=typeof e.start_time=="string"?new Date(e.start_time).getTime():e.start_time),e.retain_authorization&&(d.authorization=e.authorization),e.revoked_certificates&&(d.revoked_certificates=e.revoked_certificates),e.shard!==void 0&&(d.shard=e.shard),d.replicates){let _={url:s,ca:c,replicates:!0,subscriptions:null};(0,Va.get)(x.REPLICATION_SHARD)!==void 0&&(_.shard=(0,Va.get)(x.REPLICATION_SHARD)),e.retain_authorization&&(_.authorization=e.authorization),e.start_time&&(_.start_time=e.start_time),await Oo(Ze(),_)}await Oo(u?u.nodeName:d.name??ai(t),d);let p;return e.operation==="update_node"?p=`Successfully updated '${t}'`:p=`Successfully added '${t}' to cluster`,f&&(p+=" but there was an error updating target node: "+f.message),p}async function Gae(e){es.trace("addNodeBack received request:",e);let t=await(0,Ns.signCertificate)(e),r;e.csr?(r=t.signingCA,es.info("addNodeBack received CSR from node:",e.url,"this node will use and respond with CA that was used to issue CSR")):(r=e?.cert_auth,es.info("addNodeBack received CA from node:",e.url));let n={url:e.url,ca:r};e.subscriptions?n.subscriptions=e.subscriptions:(n.replicates=!0,n.subscriptions=null),e.start_time&&(n.start_time=e.start_time),e.authorization&&(n.authorization=e.authorization),e.shard!==void 0&&(n.shard=e.shard);let s=await(0,Ns.getReplicationCertAuth)();if(n.replicates){let i={url:La(),ca:s?.certificate,replicates:!0,subscriptions:null};(0,Va.get)(x.REPLICATION_SHARD)!==void 0&&(i.shard=(0,Va.get)(x.REPLICATION_SHARD)),e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await Oo(Ze(),i)}return await Oo(e.hostname,n),t.nodeName=Ze(),t.usingCA=s?.certificate,es.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function qae(e){es.trace("removeNodeBack received request:",e),await or().delete(e.name)}function jG(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var Ns,JG,$a,Va,es,Lo,Bae,Hae,kae,bl=be(()=>{Ns=M(Zn()),JG=M(ot()),$a=M(require("joi")),Va=M(ae());H();lp();pl();Xn();es=M(z()),Lo=M(pe()),{pki:Bae}=require("node-forge"),{HTTP_STATUS_CODES:Hae}=Lo.hdb_errors,kae=$a.default.object({hostname:$a.default.string(),verify_tls:$a.default.boolean(),replicates:$a.default.boolean(),subscriptions:$a.default.array(),revoked_certificates:$a.default.array(),shard:$a.default.number()});a(Fae,"setNode");a(Gae,"addNodeBack");a(qae,"removeNodeBack");a(jG,"reverseSubscription")});var Sd=w((_Le,XG)=>{"use strict";var{handleHDBError:Zg,hdb_errors:$ae}=pe(),{HTTP_STATUS_CODES:eS}=$ae,{addUpdateNodeValidator:Vae}=jg(),tS=z(),rS=(H(),C(G)),QG=Tt(),Kae=ie(),Rp=ir(),yp=Do(),QN=ae(),Yae=JN(),{Node:Wae,NodeSubscription:zae}=Ed(),{broadcast:jae}=rt(),{setNode:Jae}=(bl(),C(yl)),dLe=ae(),fLe=(H(),C(G)),Qae="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",Xae="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Zae=QN.get(rS.CONFIG_PARAMS.CLUSTERING_NODENAME);XG.exports=ece;async function ece(e,t=!1){if(tS.trace("addNode called with:",e),QN.get(rS.CONFIG_PARAMS.REPLICATION_URL)||QN.get(rS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Jae(e);yp.checkClusteringEnabled();let r=Vae(e);if(r)throw Zg(r,r.message,eS.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await yp.getNodeRecord(n);if(!Kae.isEmptyOrZeroLength(d))throw Zg(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,eS.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await Yae(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=Qae,o;let c=yp.buildNodePayloads(s,Zae,rS.OPERATIONS_ENUM.ADD_NODE,await yp.getSystemInfo()),l=[];for(let d=0,p=s.length;d<p;d++){let _=s[d];s[d].start_time===void 0&&delete s[d].start_time,l.push(new zae(_.schema,_.table,_.publish,_.subscribe))}tS.trace("addNode sending remote payload:",c);let u;try{u=await Rp.request(`${n}.${QG.REQUEST_SUFFIX}`,c)}catch(d){tS.error(`addNode received error from request: ${d}`);for(let _=0,h=s.length;_<h;_++){let S=s[_];S.publish=!1,S.subscribe=!1,await Rp.updateRemoteConsumer(S,n)}let p=Rp.requestErrorHandler(d,"add_node",n);throw Zg(new Error,p,eS.INTERNAL_SERVER_ERROR,"error",p)}if(u.status===QG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${n}: ${u.message}`;throw Zg(new Error,d,eS.INTERNAL_SERVER_ERROR,"error",d)}tS.trace(u);for(let d=0,p=s.length;d<p;d++){let _=s[d];await Rp.updateRemoteConsumer(_,n),_.subscribe===!0&&await Rp.updateConsumerIterator(_.schema,_.table,n,"start")}let f=new Wae(n,l,u.system_info);return await yp.upsertNodeRecord(f),jae({type:"nats_update"}),i.length>0?o.message=Xae:o.message=`Successfully added '${n}' to manifest`,o}a(ece,"addNode")});var tw=w((mLe,eq)=>{"use strict";var{handleHDBError:XN,hdb_errors:tce}=pe(),{HTTP_STATUS_CODES:ZN}=tce,{addUpdateNodeValidator:rce}=jg(),bp=z(),nS=(H(),C(G)),ZG=Tt(),hLe=ie(),Op=ir(),Np=Do(),ew=ae(),{cloneDeep:nce}=require("lodash"),sce=JN(),{Node:ice,NodeSubscription:oce}=Ed(),{broadcast:ace}=rt(),{setNode:cce}=(bl(),C(yl)),lce="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",uce="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",dce=ew.get(nS.CONFIG_PARAMS.CLUSTERING_NODENAME);eq.exports=fce;async function fce(e){if(bp.trace("updateNode called with:",e),ew.get(nS.CONFIG_PARAMS.REPLICATION_URL)??ew.get(nS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return cce(e);Np.checkClusteringEnabled();let t=rce(e);if(t)throw XN(t,t.message,ZN.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Np.getNodeRecord(r);s.length>0&&(n=nce(s));let{added:i,skipped:o}=await sce(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=lce,c;let l=Np.buildNodePayloads(i,dce,nS.OPERATIONS_ENUM.UPDATE_NODE,await Np.getSystemInfo());for(let f=0,d=i.length;f<d;f++){let p=i[f];bp.trace(`updateNode updating work stream for node: ${r} subscription:`,p),i[f].start_time===void 0&&delete i[f].start_time}bp.trace("updateNode sending remote payload:",l);let u;try{u=await Op.request(`${r}.${ZG.REQUEST_SUFFIX}`,l)}catch(f){bp.error(`updateNode received error from request: ${f}`);let d=Op.requestErrorHandler(f,"update_node",r);throw XN(new Error,d,ZN.INTERNAL_SERVER_ERROR,"error",d)}if(u.status===ZG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let f=`Error returned from remote node ${r}: ${u.message}`;throw XN(new Error,f,ZN.INTERNAL_SERVER_ERROR,"error",f)}bp.trace(u);for(let f=0,d=i.length;f<d;f++){let p=i[f];await Op.updateRemoteConsumer(p,r),p.subscribe===!0?await Op.updateConsumerIterator(p.schema,p.table,r,"start"):await Op.updateConsumerIterator(p.schema,p.table,r,"stop")}return n||(n=[new ice(r,[],u.system_info)]),await _ce(n[0],i,u.system_info),o.length>0?c.message=uce:c.message=`Successfully updated '${r}'`,c}a(fce,"updateNode");async function _ce(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let l=0,u=e.subscriptions.length;l<u;l++){let f=n.subscriptions[l];if(f.schema===o.schema&&f.table===o.table){f.publish=o.publish,f.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new oce(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await Np.upsertNodeRecord(n),ace({type:"nats_update"})}a(_ce,"updateNodeTable")});var iq=w((gLe,sq)=>{"use strict";var nq=require("joi"),{string:tq}=nq.types(),pce=ot(),rq=(H(),C(G)),hce=ae(),mce=Tt();sq.exports=Ece;function Ece(e){let t=tq.invalid(hce.get(rq.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(mce.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=nq.object({operation:tq.valid(rq.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return pce.validateBySchema(e,r)}a(Ece,"removeNodeValidator")});var sS=w((TLe,uq)=>{"use strict";var{handleHDBError:oq,hdb_errors:gce}=pe(),{HTTP_STATUS_CODES:aq}=gce,Sce=iq(),wp=z(),cq=Do(),Tce=ie(),Td=(H(),C(G)),lq=Tt(),rw=ir(),nw=ae(),{RemotePayloadObject:Ace}=Tp(),{NodeSubscription:Rce}=Ed(),yce=M_(),bce=zc(),{broadcast:Oce}=rt(),{setNode:Nce}=(bl(),C(yl)),wce=nw.get(Td.CONFIG_PARAMS.CLUSTERING_NODENAME);uq.exports=Ice;async function Ice(e){if(wp.trace("removeNode called with:",e),nw.get(Td.CONFIG_PARAMS.REPLICATION_URL)??nw.get(Td.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Nce(e);cq.checkClusteringEnabled();let t=Sce(e);if(t)throw oq(t,t.message,aq.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await cq.getNodeRecord(r);if(Tce.isEmptyOrZeroLength(n))throw oq(new Error,`Node '${r}' was not found.`,aq.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new Ace(Td.OPERATIONS_ENUM.REMOVE_NODE,wce,[]),i,o=!1;for(let l=0,u=n.subscriptions.length;l<u;l++){let f=n.subscriptions[l];f.subscribe===!0&&await rw.updateConsumerIterator(f.schema,f.table,r,"stop");try{await rw.updateRemoteConsumer(new Rce(f.schema,f.table,!1,!1),r)}catch(d){wp.error(d)}}try{i=await rw.request(`${r}.${lq.REQUEST_SUFFIX}`,s),wp.trace("Remove node reply from remote node:",r,i)}catch(l){wp.error("removeNode received error from request:",l),o=!0}let c=new yce(Td.SYSTEM_SCHEMA_NAME,Td.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await bce.deleteRecord(c),Oce({type:"nats_update"}),i?.status===lq.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(wp.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(Ice,"removeNode")});var _q=w((RLe,fq)=>{"use strict";var dq=require("joi"),{string:Cce,array:Pce}=dq.types(),Dce=ot(),Lce=jg();fq.exports=Mce;function Mce(e){let t=dq.object({operation:Cce.valid("configure_cluster").required(),connections:Pce.items(Lce.validation_schema).required()});return Dce.validateBySchema(e,t)}a(Mce,"configureClusterValidator")});var sw=w((bLe,gq)=>{"use strict";var pq=(H(),C(G)),iS=z(),vce=ie(),Uce=ae(),xce=sS(),Bce=Sd(),Hce=Do(),kce=_q(),{handleHDBError:hq,hdb_errors:Fce}=pe(),{HTTP_STATUS_CODES:mq}=Fce,Gce="Configure cluster complete.",qce="Failed to configure the cluster. Check the logs for more details.",$ce="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";gq.exports=Vce;async function Vce(e){iS.trace("configure cluster called with:",e);let t=kce(e);if(t)throw hq(t,t.message,mq.BAD_REQUEST,void 0,void 0,!0);let r=await Hce.getAllNodeRecords(),n=[];if(Uce.get(pq.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let f=0,d=r.length;f<d;f++){let p=await Eq(xce,{operation:pq.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[f].name},r[f].name);n.push(p)}iS.trace("All results from configure_cluster remove node:",n)}let s=[],i=e.connections.length;for(let f=0;f<i;f++){let d=e.connections[f],p=await Eq(Bce,d,d.node_name);s.push(p)}iS.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,u=n.concat(s);for(let f=0,d=u.length;f<d;f++){let p=u[f];p.status==="rejected"&&(iS.error(p.node_name,p?.error?.message,p?.error?.stack),o.includes(p.node_name)||o.push(p.node_name)),(p?.result?.message?.includes?.("Successfully")||p?.result?.includes?.("Successfully"))&&(l=!0),!(typeof p.result=="string"&&p.result.includes("Successfully removed")||p.status==="rejected")&&c.push({node_name:p?.node_name,response:p?.result})}if(vce.isEmptyOrZeroLength(o))return{message:Gce,connections:c};if(l)return{message:$ce,failed_nodes:o,connections:c};throw hq(new Error,qce,mq.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(Vce,"configureCluster");async function Eq(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(Eq,"functionWrapper")});var Rq=w((NLe,Aq)=>{"use strict";var Ip=require("joi"),Kce=ot(),{validateSchemaExists:Sq,validateTableExists:Yce,validateSchemaName:Tq}=Di(),Wce=Ip.object({operation:Ip.string().valid("purge_stream"),schema:Ip.string().custom(Sq).custom(Tq).optional(),database:Ip.string().custom(Sq).custom(Tq).optional(),table:Ip.string().custom(Yce).required()});function zce(e){return Kce.validateBySchema(e,Wce)}a(zce,"purgeStreamValidator");Aq.exports=zce});var iw=w((ILe,yq)=>{"use strict";var{handleHDBError:jce,hdb_errors:Jce}=pe(),{HTTP_STATUS_CODES:Qce}=Jce,Xce=Rq(),Zce=ir(),ele=Do();yq.exports=tle;async function tle(e){e.schema=e.schema??e.database;let t=Xce(e);if(t)throw jce(t,t.message,Qce.BAD_REQUEST,void 0,void 0,!0);ele.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await Zce.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(tle,"purgeStream")});var cS=w((PLe,Pq)=>{"use strict";var aw=Do(),rle=ir(),aS=ae(),Ad=(H(),C(G)),Ol=Tt(),nle=ie(),ow=z(),{RemotePayloadObject:sle}=Tp(),{ErrorCode:bq}=require("nats"),{parentPort:Oq}=require("worker_threads"),{onMessageByType:ile}=rt(),{getThisNodeName:ole}=(Xn(),C(wo)),{requestClusterStatus:ale}=(lp(),C(jk)),{getReplicationSharedStatus:cle,getHDBNodeTable:lle}=(pl(),C(jO)),{CONFIRMATION_STATUS_POSITION:ule,RECEIVED_VERSION_POSITION:dle,RECEIVED_TIME_POSITION:fle,SENDING_TIME_POSITION:_le}=(SN(),C(BF)),Nq=aS.get(Ad.CONFIG_PARAMS.CLUSTERING_ENABLED),wq=aS.get(Ad.CONFIG_PARAMS.CLUSTERING_NODENAME);Pq.exports={clusterStatus:ple,buildNodeStatus:Cq};var Iq;ile("cluster-status",async e=>{Iq(e)});async function ple(){if(aS.get(Ad.CONFIG_PARAMS.REPLICATION_URL)||aS.get(Ad.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;if(Oq){Oq.postMessage({type:"request-cluster-status"}),n=await new Promise(i=>{Iq=i});for(let i of n.connections){let o=i.name;for(let c of i.database_sockets){let l=c.database,u;for(let d of Object.values(databases[l]||{}))if(u=d.auditStore,u)break;if(!u)continue;let f=cle(u,l,o);c.lastCommitConfirmed=oS(f[ule]),c.lastReceivedRemoteTime=oS(f[dle]),c.lastReceivedLocalTime=oS(f[fle]),c.sendingMessage=oS(f[_le])}}}else n=ale();n.node_name=ole();let s=lle().primaryStore.get(n.node_name);return s?.shard&&(n.shard=s.shard),s?.url&&(n.url=s.url),n.is_enabled=!0,n}let e={node_name:wq,is_enabled:Nq,connections:[]};if(!Nq)return e;let t=await aw.getAllNodeRecords();if(nle.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(Cq(t[n],e.connections));return await Promise.allSettled(r),e}a(ple,"clusterStatus");function oS(e){return e?e===1?"Copying":new Date(e).toUTCString():void 0}a(oS,"asDate");async function Cq(e,t){let r=e.name,n=new sle(Ad.OPERATIONS_ENUM.CLUSTER_STATUS,wq,void 0,await aw.getSystemInfo()),s,i,o=Ol.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await rle.request(Ol.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Ol.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=Ol.CLUSTER_STATUS_STATUSES.CLOSED,ow.error(`Error getting node status from ${r} `,s))}catch(l){ow.warn(`Error getting node status from ${r}`,l),l.code===bq.NoResponders?o=Ol.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===bq.Timeout?o=Ol.CLUSTER_STATUS_STATUSES.TIMEOUT:o=Ol.CLUSTER_STATUS_STATUSES.CLOSED}let c=new hle(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!==Ad.PRE_4_0_0_VERSION&&await aw.upsertNodeRecord(l)}catch(l){ow.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(Cq,"buildNodeStatus");function hle(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(hle,"NodeStatusObject")});var uS=w((LLe,Dq)=>{"use strict";var{handleHDBError:mle,hdb_errors:Ele}=pe(),{HTTP_STATUS_CODES:gle}=Ele,Sle=ir(),Tle=Do(),cw=ie(),lS=require("joi"),Ale=ot(),Rle=2e3,yle=lS.object({timeout:lS.number().min(1),connected_nodes:lS.boolean(),routes:lS.boolean()});Dq.exports=ble;async function ble(e){Tle.checkClusteringEnabled();let t=Ale.validateBySchema(e,yle);if(t)throw mle(t,t.message,gle.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||cw.autoCastBoolean(n),o=s===void 0||cw.autoCastBoolean(s),c={nodes:[]},l=await Sle.getServerList(r??Rle),u={};if(i)for(let f=0,d=l.length;f<d;f++){let p=l[f].statsz;p&&(u[l[f].server.name]=p.routes)}for(let f=0,d=l.length;f<d;f++){if(l[f].statsz)continue;let p=l[f].server,_=l[f].data;if(p.name.endsWith("-hub")){let h={name:p.name.slice(0,-4),response_time:l[f].response_time};i&&(h.connected_nodes=[],u[p.name]&&u[p.name].forEach(S=>{h.connected_nodes.includes(S.name.slice(0,-4))||h.connected_nodes.push(S.name.slice(0,-4))})),o&&(h.routes=_.cluster?.urls?_.cluster?.urls.map(S=>({host:S.split(":")[0],port:cw.autoCast(S.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(ble,"clusterNetwork")});var Uq=w((vLe,vq)=>{"use strict";var lw=require("joi"),Lq=ot(),{route_constraints:Mq}=Yy();vq.exports={setRoutesValidator:Ole,deleteRoutesValidator:Nle};function Ole(e){let t=lw.object({server:lw.valid("hub","leaf"),routes:Mq.required()});return Lq.validateBySchema(e,t)}a(Ole,"setRoutesValidator");function Nle(e){let t=lw.object({routes:Mq.required()});return Lq.validateBySchema(e,t)}a(Nle,"deleteRoutesValidator")});var dS=w((xLe,qq)=>{"use strict";var Mo=yt(),uw=ie(),ws=(H(),C(G)),Rd=ae(),xq=Uq(),{handleHDBError:Bq,hdb_errors:wle}=pe(),{HTTP_STATUS_CODES:Hq}=wle,kq="cluster routes successfully set",Fq="cluster routes successfully deleted";qq.exports={setRoutes:Cle,getRoutes:Ple,deleteRoutes:Dle};function Ile(e){let t=Mo.getClusteringRoutes(),r=e.server==="hub"?t.hub_routes:t.leaf_routes,n=e.server==="hub"?t.leaf_routes:t.hub_routes,s=[],i=[];for(let o=0,c=e.routes.length;o<c;o++){let l=e.routes[o];l.port=uw.autoCast(l.port);let u=r.some(d=>d.host===l.host&&d.port===l.port),f=n.some(d=>d.host===l.host&&d.port===l.port);u||f?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?Mo.updateConfigValue(ws.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):Mo.updateConfigValue(ws.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:kq,set:i,skipped:s}}a(Ile,"setRoutesNats");function Cle(e){let t=xq.setRoutesValidator(e);if(t)throw Bq(t,t.message,Hq.BAD_REQUEST,void 0,void 0,!0);if(Rd.get(ws.CONFIG_PARAMS.CLUSTERING_ENABLED))return Ile(e);let r=[],n=[],s=Rd.get(ws.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{Gq(s,i)?n.push(i):(s.push(i),r.push(i))}),Mo.updateConfigValue(ws.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:kq,set:r,skipped:n}}a(Cle,"setRoutes");function Gq(e,t){return typeof t=="string"?e.includes(t):typeof t=="object"&&t!==null?e.some(r=>(r.host===t.host||r.hostname===t.hostname)&&r.port===t.port):!1}a(Gq,"existsInArray");function Ple(){if(Rd.get(ws.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=Mo.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return Rd.get(ws.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(Ple,"getRoutes");function Dle(e){let t=xq.deleteRoutesValidator(e);if(t)throw Bq(t,t.message,Hq.BAD_REQUEST,void 0,void 0,!0);if(Rd.get(ws.CONFIG_PARAMS.CLUSTERING_ENABLED))return Lle(e);let r=[],n=[],s=Rd.get(ws.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{Gq(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),Mo.updateConfigValue(ws.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:Fq,deleted:r,skipped:n}}a(Dle,"deleteRoutes");function Lle(e){let t=Mo.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],o=!1,c=!1;for(let l=0,u=e.routes.length;l<u;l++){let f=e.routes[l],d=!1;for(let p=0,_=r.length;p<_;p++){let h=r[p];if(f.host===h.host&&f.port===h.port){r.splice(p,1),d=!0,o=!0,s.push(f);break}}if(!d){let p=!0;for(let _=0,h=n.length;_<h;_++){let S=n[_];if(f.host===S.host&&f.port===S.port){n.splice(_,1),c=!0,p=!1,s.push(f);break}}p&&i.push(f)}}return o&&(r=uw.isEmptyOrZeroLength(r)?null:r,Mo.updateConfigValue(ws.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=uw.isEmptyOrZeroLength(n)?null:n,Mo.updateConfigValue(ws.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:Fq,deleted:s,skipped:i}}a(Lle,"deleteRoutesNats")});var Vq=w((HLe,$q)=>{"use strict";var Cp=require("alasql"),Nl=require("recursive-iterator"),ui=z(),Mle=ie(),Pp=(H(),C(G)),dw=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,Ule(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=>Pp.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=>!Pp.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][Pp.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=vle(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(u=>({attribute_name:u.attribute}));let l=this.affected_attributes.get(i).get(o).filter(u=>!Pp.SEARCH_WILDCARDS.includes(u));c.forEach(({attribute_name:u})=>{let f=new Cp.yy.Column({columnid:u});s.tableid&&(f.tableid=s.tableid),this.ast.columns.push(f),l.includes(u)||l.push(u)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function vle(e){return e.filter(t=>t[Pp.PERMS_CRUD_ENUM.READ])}a(vle,"filterReadRestrictedAttrs");function Ule(e,t,r,n,s){xle(e,t,r,n,s)}a(Ule,"interpretAST");function Dp(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(Dp,"addSchemaTableToMap");function xle(e,t,r,n,s){if(!e){ui.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Cp.yy.Insert?Fle(e,t,r):e instanceof Cp.yy.Select?Ble(e,t,r,n,s):e instanceof Cp.yy.Update?Hle(e,t,r):e instanceof Cp.yy.Delete?kle(e,t,r):ui.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(xle,"getRecordAttributesAST");function Ble(e,t,r,n,s){if(!e){ui.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(Mle.isEmptyOrZeroLength(i)){ui.error("No schema specified");return}e.from.forEach(c=>{Dp(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),Dp(c.table,t,r,n,s)});let o=new Nl(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,u=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(u).has(l))if(r.has(l))l=r.get(l);else{ui.info(`table specified as ${l} not found.`);return}t.get(u).get(l).indexOf(c.columnid)<0&&t.get(u).get(l).push(c.columnid)}if(e.where){let c=new Nl(e.where),l=e.from[0].tableid;for(let{node:u}of c)if(u&&u.columnid){let f=u.tableid?u.tableid:l;if(!t.get(i).has(f))if(r.has(f))f=r.get(f);else{ui.info(`table specified as ${f} not found.`);continue}t.get(i).get(f).indexOf(u.columnid)<0&&t.get(i).get(f).push(u.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new Nl(c.on);for(let{node:u}of l)if(u&&u.columnid){let f=u.tableid,d=s.get(f);if(!t.get(d).has(f))if(r.has(f))f=r.get(f);else{ui.info(`table specified as ${f} not found.`);continue}t.get(d).get(f).indexOf(u.columnid)<0&&t.get(d).get(f).push(u.columnid)}}),e.order){let c=new Nl(e.order);for(let{node:l}of c)if(l&&l.columnid){let u=l.tableid,f=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(f).has(u))if(r.has(u))u=r.get(u);else{ui.info(`table specified as ${u} not found.`);return}t.get(f).get(u).indexOf(l.columnid)<0&&t.get(f).get(u).push(l.columnid)}}}a(Ble,"getSelectAttributes");function Hle(e,t,r){if(!e){ui.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new Nl(e.columns),s=e.table.databaseid;Dp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&fw(e.table.tableid,s,i.columnid,t,r)}a(Hle,"getUpdateAttributes");function kle(e,t,r){if(!e){ui.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new Nl(e.where),s=e.table.databaseid;Dp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&fw(e.table.tableid,s,i.columnid,t,r)}a(kle,"getDeleteAttributes");function Fle(e,t,r){if(!e){ui.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new Nl(e.columns),s=e.into.databaseid;Dp(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&fw(e.into.tableid,s,i.columnid,t,r)}a(Fle,"getInsertAttributes");function fw(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(fw,"pushAttribute");$q.exports=dw});var Yq=w((FLe,Kq)=>{"use strict";var fS=(H(),C(G)),_S=class{static{a(this,"BaseLicense")}constructor(t=0,r=fS.RAM_ALLOCATION_ENUM.DEFAULT,n=fS.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},_w=class extends _S{static{a(this,"ExtendedLicense")}constructor(t=0,r=fS.RAM_ALLOCATION_ENUM.DEFAULT,n=fS.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};Kq.exports={BaseLicense:_S,ExtendedLicense:_w}});var Od=w((qLe,Xq)=>{"use strict";var bd=require("fs-extra"),pS=(hE(),C(pE)),zq=require("crypto"),Gle=require("moment"),qle=require("uuid").v4,Zr=z(),hw=require("path"),$le=ie(),wl=(H(),C(G)),{totalmem:Wq}=require("os"),Vle=Yq().ExtendedLicense,yd="invalid license key format",Kle="061183",Yle="mofi25",Wle="aes-256-cbc",zle=16,jle=32,jq=ae(),{resolvePath:Jq}=yt();jq.initSync();var pw;Xq.exports={validateLicense:Qq,generateFingerPrint:Qle,licenseSearch:gw,getLicense:eue,checkMemoryLimit:tue};function mw(){return hw.join(jq.getHdbBasePath(),wl.LICENSE_KEY_DIR_NAME,wl.LICENSE_FILE_NAME)}a(mw,"getLicenseDirPath");function Jle(){let e=mw();return Jq(hw.join(e,wl.LICENSE_FILE_NAME))}a(Jle,"getLicenseFilePath");function Ew(){let e=mw();return Jq(hw.join(e,wl.REG_KEY_FILE_NAME))}a(Ew,"getFingerPrintFilePath");async function Qle(){let e=Ew();try{return await bd.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await Xle();throw Zr.error(`Error writing fingerprint file to ${e}`),Zr.error(t),new Error("There was an error generating the fingerprint")}}a(Qle,"generateFingerPrint");async function Xle(){let e=qle(),t=pS.hash(e,pS.HASH_FUNCTION.MD5),r=Ew();try{await bd.mkdirp(mw()),await bd.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw Zr.error(`Error writing fingerprint file to ${r}`),Zr.error(n),new Error("There was an error generating the fingerprint")}return t}a(Xle,"writeFingerprint");function Qq(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:wl.RAM_ALLOCATION_ENUM.DEFAULT,version:wl.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Zr.error("empty license key passed to validate."),r;let n=Ew(),s=!1;try{s=bd.statSync(n)}catch(i){Zr.error(i)}if(s){let i;try{i=bd.readFileSync(n,"utf8")}catch{Zr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(Yle),c=o[1];c=Buffer.concat([Buffer.from(c)],zle);let l=Buffer.concat([Buffer.from(i)],jle),u=zq.createDecipheriv(Wle,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let f=null;try{f=u.update(o[0],"hex","utf8"),f.trim(),f+=u.final("utf8")}catch{let _=Zle(o[0],i);if(_)f=_;else throw r.valid_license=!1,r.valid_machine=!1,console.error(yd),Zr.error(yd),new Error(yd)}let d;if(isNaN(f))try{d=JSON.parse(f),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(yd),Zr.error(yd),new Error(yd)}else r.exp_date=f;r.exp_date<Gle().valueOf()&&(r.valid_date=!1),pS.validate(o[1],`${Kle}${i}${t}`,pS.HASH_FUNCTION.MD5)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||Zr.error("Invalid licence"),r}a(Qq,"validateLicense");function Zle(e,t){try{let r=zq.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{Zr.warn("Check old license failed")}}a(Zle,"checkOldLicense");function gw(){let e=new Vle,t=[];try{t=bd.readFileSync(Jle(),"utf-8").split(`\r
25
- `)}catch(r){r.code==="ENOENT"?Zr.debug("no license file found"):Zr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if($le.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=Qq(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){Zr.error("There was an error parsing the license string."),Zr.error(s),e.ram_allocation=wl.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return pw=e,e}a(gw,"licenseSearch");async function eue(){return pw||await gw(),pw}a(eue,"getLicense");function tue(){let e=gw().ram_allocation,t=process.constrainedMemory?.()||Wq();if(t=Math.round(Math.min(t,Wq())/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(tue,"checkMemoryLimit")});var mS=w((VLe,r$)=>{var hS=Od(),Zq=require("chalk"),ts=z(),e$=require("prompt"),{promisify:rue}=require("util"),Sw=(H(),C(G)),nue=require("fs-extra"),sue=require("path"),iue=ie(),{packageJson:oue}=it(),t$=ae();t$.initSync();var aue=require("moment"),cue=rue(e$.get),lue=sue.join(t$.getHdbBasePath(),Sw.LICENSE_KEY_DIR_NAME,Sw.LICENSE_FILE_NAME,Sw.LICENSE_FILE_NAME);r$.exports={getFingerprint:due,setLicense:uue,parseLicense:Tw,register:fue,getRegistrationInfo:pue};async function uue(e){if(e&&e.key&&e.company){try{ts.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await Tw(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw ts.error(r),ts.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(uue,"setLicense");async function due(){let e={};try{e=await hS.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw ts.error(r),ts.error(t),new Error(r)}return e}a(due,"getFingerprint");async function Tw(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");ts.info("Validating license input...");let r=hS.validateLicense(e,t);if(ts.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(ts.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(ts.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{ts.info("writing license to disk"),await nue.writeFile(lue,JSON.stringify({license_key:e,company:t}))}catch(n){throw ts.error("Failed to write License"),n}return"Registration successful."}a(Tw,"parseLicense");async function fue(){let e=await _ue();return Tw(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(fue,"register");async function _ue(){let e=await hS.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:Zq.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:Zq.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{e$.start()}catch(n){ts.error(n)}let r;try{r=await cue(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(_ue,"promptForRegistration");async function pue(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await hS.getLicense()}catch(r){throw ts.error(`There was an error when searching licenses due to: ${r.message}`),r}if(iue.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=oue.version,e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=aue.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(pue,"getRegistrationInfo")});var s$=w((YLe,n$)=>{"use strict";var hue=Tt(),Aw=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,u,f,d,p,_,h){this.port=t,o===null&&(o=void 0),this.server_name=r+hue.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.reconnect_error_reports=100,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l},this.leafnodes={port:u,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:f,port:d,routes:p,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:_},HDB:{users:h}},this.system_account="SYS"}};n$.exports=Aw});var a$=w((zLe,o$)=>{"use strict";var i$=Tt(),Rw=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,u,f,d){this.port=t,d===null&&(d=void 0),this.server_name=r+i$.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+i$.SERVER_SUFFIX.LEAF},this.tls={cert_file:u,key_file:f,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"}};o$.exports=Rw});var l$=w((JLe,c$)=>{"use strict";var yw=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};c$.exports=yw});var d$=w((XLe,u$)=>{"use strict";var mue=Tt(),bw=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+mue.SERVER_SUFFIX.ADMIN,this.password=r}};u$.exports=bw});var TS=w((eMe,p$)=>{"use strict";var Il=require("path"),Cl=require("fs-extra"),Eue=s$(),gue=a$(),Sue=l$(),Tue=d$(),Ow=Rn(),wd=ie(),wn=yt(),gS=(H(),C(G)),Lp=Tt(),{CONFIG_PARAMS:Jt}=gS,Id=z(),Mp=ae(),f$=Eo(),Nw=ir(),Aue=Zn(),Nd="clustering",Rue=1e4,_$=50;p$.exports={generateNatsConfig:bue,removeNatsConfig:Oue,getHubConfigPath:yue};function yue(){let e=Mp.get(Jt.ROOTPATH);return Il.join(e,Nd,Lp.NATS_CONFIG_FILES.HUB_SERVER)}a(yue,"getHubConfigPath");async function bue(e=!1,t=void 0){let r=Mp.get(Jt.ROOTPATH);Cl.ensureDirSync(Il.join(r,"clustering","leaf")),Mp.initSync();let n=wn.getConfigFromFile(Jt.CLUSTERING_TLS_CERT_AUTH),s=wn.getConfigFromFile(Jt.CLUSTERING_TLS_PRIVATEKEY),i=wn.getConfigFromFile(Jt.CLUSTERING_TLS_CERTIFICATE);!await Cl.exists(i)&&!await Cl.exists(!n)&&await Aue.createNatsCerts();let o=Il.join(r,Nd,Lp.PID_FILES.HUB),c=Il.join(r,Nd,Lp.PID_FILES.LEAF),l=wn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=Il.join(r,Nd,Lp.NATS_CONFIG_FILES.HUB_SERVER),f=Il.join(r,Nd,Lp.NATS_CONFIG_FILES.LEAF_SERVER),d=wn.getConfigFromFile(Jt.CLUSTERING_TLS_INSECURE),p=wn.getConfigFromFile(Jt.CLUSTERING_TLS_VERIFY),_=wn.getConfigFromFile(Jt.CLUSTERING_NODENAME),h=wn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await Nw.checkNATSServerInstalled()||SS("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let S=await Ow.listUsers(),g=wn.getConfigFromFile(Jt.CLUSTERING_USER),R=await Ow.getClusterUser();(wd.isEmpty(R)||R.active!==!0)&&SS(`Invalid cluster user '${g}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await ES(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await ES(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await ES(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),await ES(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let E=[],T=[];for(let[se,Q]of S.entries())Q.role?.role===gS.ROLE_TYPES_ENUM.CLUSTER_USER&&Q.active&&(E.push(new Tue(Q.username,f$.decrypt(Q.hash))),T.push(new Sue(Q.username,f$.decrypt(Q.hash))));let b=[],{hub_routes:v}=wn.getClusteringRoutes();if(!wd.isEmptyOrZeroLength(v))for(let se of v)b.push(`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@${se.host}:${se.port}`);let F=new Eue(wn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),_,o,i,s,n,d,p,h,wn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NAME),wn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),b,E,T);n==null&&(delete F.tls.ca_file,delete F.leafnodes.tls.ca_file),t=wd.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===gS.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Cl.writeJson(u,F),Id.trace(`Hub server config written to ${u}`));let q=`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@0.0.0.0:${h}`,Y=`tls://${R.uri_encoded_name}:${R.uri_encoded_d_hash}@0.0.0.0:${h}`,Z=new gue(wn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT),_,c,l,[q],[Y],E,T,i,s,n,d);n==null&&delete Z.tls.ca_file,(t===void 0||t===gS.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Cl.writeJson(f,Z),Id.trace(`Leaf server config written to ${f}`))}a(bue,"generateNatsConfig");async function ES(e){let t=Mp.get(e);return wd.isEmpty(t)&&SS(`port undefined for '${e}'`),await wd.isPortTaken(t)&&SS(`'${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(ES,"isPortAvailable");function SS(e){let t=`Error generating clustering config: ${e}`;Id.error(t),console.error(t),process.exit(1)}a(SS,"generateNatsConfigError");async function Oue(e){let{port:t,config_file:r}=Nw.getServerConfig(e),{username:n,decrypt_hash:s}=await Ow.getClusterUser(),i=0,o=2e3;for(;i<_$;){try{let f=await Nw.createConnection(t,n,s,!1);if(f.protocol.connected===!0){f.close();break}}catch(f){Id.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${f}`)}if(i++,i>=_$)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);let u=o*(i*2);u>3e4&&Id.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await wd.async_set_timeout(u)}let c="0".repeat(Rue),l=Il.join(Mp.get(Jt.ROOTPATH),Nd,r);await Cl.writeFile(l,c),await Cl.remove(l),Id.notify(e,"started.")}a(Oue,"removeNatsConfig")});var T$=w((rMe,S$)=>{"use strict";var rs=ae(),Nue=Od(),Fe=(H(),C(G)),vp=Tt(),vo=require("path"),{PACKAGE_ROOT:RS}=it(),h$=ae(),AS=ie(),Cd="/dev/null",wue=vo.join(RS,"launchServiceScripts"),m$=vo.join(RS,"utility/scripts"),Iue=vo.join(m$,Fe.HDB_RESTART_SCRIPT),E$=vo.resolve(RS,"dependencies",`${process.platform}-${process.arch}`,vp.NATS_BINARY_NAME);function g$(){let t=Nue.licenseSearch().ram_allocation||Fe.RAM_ALLOCATION_ENUM.DEFAULT,r=Fe.MEM_SETTING_KEY+t,n={[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return AS.noBootFile()&&(n[Fe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=AS.getEnvCliRootPath()),{name:Fe.PROCESS_DESCRIPTORS.HDB,script:Fe.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:RS}}a(g$,"generateMainServerConfig");var Cue=9930;function Pue(){rs.initSync(!0);let e=rs.get(Fe.CONFIG_PARAMS.ROOTPATH),t=vo.join(e,"clustering",vp.NATS_CONFIG_FILES.HUB_SERVER),r=vo.join(rs.get(Fe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Fe.LOG_NAMES.HDB),n=h$.get(Fe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=vp.LOG_LEVEL_FLAGS[rs.get(Fe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==Cue?"-"+n:""),script:E$,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return rs.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Cd,i.error_file=Cd),i}a(Pue,"generateNatsHubServerConfig");var Due=9940;function Lue(){rs.initSync(!0);let e=rs.get(Fe.CONFIG_PARAMS.ROOTPATH),t=vo.join(e,"clustering",vp.NATS_CONFIG_FILES.LEAF_SERVER),r=vo.join(rs.get(Fe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Fe.LOG_NAMES.HDB),n=h$.get(Fe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=vp.LOG_LEVEL_FLAGS[rs.get(Fe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==Due?"-"+n:""),script:E$,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return rs.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Cd,i.error_file=Cd),i}a(Lue,"generateNatsLeafServerConfig");function Mue(){rs.initSync();let e=vo.join(rs.get(Fe.CONFIG_PARAMS.LOGGING_ROOT),Fe.LOG_NAMES.HDB),t={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:Fe.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:wue,autorestart:!1};return rs.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=Cd,t.error_file=Cd),t}a(Mue,"generateClusteringUpgradeV4ServiceConfig");function vue(){let e={[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.RESTART_HDB};return AS.noBootFile()&&(e[Fe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=AS.getEnvCliRootPath()),{...{name:Fe.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:m$},script:Iue}}a(vue,"generateRestart");function Uue(){return{apps:[g$()]}}a(Uue,"generateAllServiceConfigs");S$.exports={generateAllServiceConfigs:Uue,generateMainServerConfig:g$,generateRestart:vue,generateNatsHubServerConfig:Pue,generateNatsLeafServerConfig:Lue,generateClusteringUpgradeV4ServiceConfig:Mue}});var Pd=w((iMe,v$)=>{"use strict";var et=(H(),C(G)),xue=ie(),xo=TS(),yS=ir(),Uo=Tt(),Ka=T$(),bS=ae(),Pl=z(),Bue=Do(),{startWorker:A$,onMessageFromWorkers:Hue}=rt(),kue=Po(),sMe=require("util"),Fue=require("child_process"),Gue=require("fs"),{execFile:que}=Fue,Ve;v$.exports={enterPM2Mode:$ue,start:Ya,stop:ww,reload:y$,restart:b$,list:Iw,describe:w$,connect:Bo,kill:zue,startAllServices:jue,startService:Cw,getUniqueServicesList:I$,restartAllServices:Jue,isServiceRegistered:C$,reloadStopStart:P$,restartHdb:N$,deleteProcess:Yue,startClusteringProcesses:L$,startClusteringThreads:M$,isHdbRestartRunning:Wue,isClusteringRunning:Xue,stopClustering:Que,reloadClustering:Zue,expectedRestartOfChildren:O$};var Up=!1;Hue(e=>{e.type==="restart"&&bS.initSync(!0)});function $ue(){Up=!0}a($ue,"enterPM2Mode");function Bo(){return Ve||(Ve=require("pm2")),new Promise((e,t)=>{Ve.connect((r,n)=>{r&&t(r),e(n)})})}a(Bo,"connect");var en,Vue=10,R$;function Ya(e,t=!1){if(Up)return Kue(e);let r=que(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let o=en.indexOf(r);o>-1&&en.splice(o,1),!R$&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<Vue&&(Gue.existsSync(xo.getHubConfigPath())?Ya(e):(await xo.generateNatsConfig(!0),Ya(e),await new Promise(c=>setTimeout(c,3e3)),await xo.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await xo.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=bS.get(et.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,u=0,f;for(;l=c.exec(i);){if(l.index&&Uo.LOG_LEVEL_HIERARCHY[o]>=Uo.LOG_LEVEL_HIERARCHY[f||"info"]){let _=f===Uo.LOG_LEVELS.ERR||f===Uo.LOG_LEVELS.WRN?Pl.OUTPUTS.STDERR:Pl.OUTPUTS.STDOUT;Pl.logCustomLevel(f||"info",_,n,i.slice(u,l.index).trim())}let[d,p]=l;u=l.index+d.length,f=Uo.LOG_LEVELS[p]}if(Uo.LOG_LEVEL_HIERARCHY[o]>=Uo.LOG_LEVEL_HIERARCHY[f||"info"]){let d=f===Uo.LOG_LEVELS.ERR||f===Uo.LOG_LEVELS.WRN?Pl.OUTPUTS.STDERR:Pl.OUTPUTS.STDOUT;Pl.logCustomLevel(f||"info",d,n,i.slice(u).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!en&&(en=[],!t)){let i=a(()=>{R$=!0,en&&(en.map(o=>o.kill()),process.exit(0))},"kill_children");process.on("exit",i),process.on("SIGINT",i),process.on("SIGQUIT",i),process.on("SIGTERM",i)}en.push(r)}a(Ya,"start");function Kue(e){return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.start(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(Kue,"startWithPM2");function ww(e){if(!Up){for(let t of en||[])t.name===e&&(en.splice(en.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.stop(e,async(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.delete(e,(i,o)=>{i&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(o)})})})}a(ww,"stop");function y$(e){return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.reload(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(y$,"reload");function b$(e){if(!Up){O$();for(let t of en||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.restart(e,(n,s)=>{Ve.disconnect(),t(s)})})}a(b$,"restart");function O$(){for(let e of en||[])e.config&&(e.config.restarts=0)}a(O$,"expectedRestartOfChildren");function Yue(e){return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.delete(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(Yue,"deleteProcess");async function N$(){await Ya(Ka.generateRestart())}a(N$,"restartHdb");async function Wue(){let e=await Iw();for(let t in e)if(e[t].name===et.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(Wue,"isHdbRestartRunning");function Iw(){return new Promise(async(e,t)=>{try{await Bo()}catch(r){t(r)}Ve.list((r,n)=>{r&&(Ve.disconnect(),t(r)),Ve.disconnect(),e(n)})})}a(Iw,"list");function w$(e){return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.describe(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(w$,"describe");function zue(){if(!Up){for(let e of en||[])e.kill();en=[];return}return new Promise(async(e,t)=>{try{await Bo()}catch(r){t(r)}Ve.killDaemon((r,n)=>{r&&(Ve.disconnect(),t(r)),Ve.disconnect(),e(n)})})}a(zue,"kill");async function jue(){try{await L$(),await M$(),await Ya(Ka.generateAllServiceConfigs())}catch(e){throw Ve?.disconnect(),e}}a(jue,"startAllServices");async function Cw(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case et.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Ka.generateMainServerConfig();break;case et.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Ka.generateNatsIngestServiceConfig();break;case et.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Ka.generateNatsReplyServiceConfig();break;case et.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Ka.generateNatsHubServerConfig(),await Ya(r,t),await xo.removeNatsConfig(e);return;case et.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Ka.generateNatsLeafServerConfig(),await Ya(r,t),await xo.removeNatsConfig(e);return;case et.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Ka.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await Ya(r)}catch(r){throw Ve?.disconnect(),r}}a(Cw,"startService");async function I$(){try{let e=await Iw(),t={};for(let r=0,n=e.length;r<n;r++){let s=e[r];t[s.name]===void 0&&(t[s.name]={name:s.name,exec_mode:s.pm2_env.exec_mode})}return t}catch(e){throw Ve?.disconnect(),e}}a(I$,"getUniqueServicesList");async function Jue(e=[]){try{let t=!1,r=await I$();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===et.PROCESS_DESCRIPTORS.HDB?t=!0:await b$(o))}t&&await P$(et.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Ve?.disconnect(),t}}a(Jue,"restartAllServices");async function C$(e){if(en?.find(r=>r.name===e))return!0;let t=await kue.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(C$,"isServiceRegistered");async function P$(e){let t=bS.get(et.CONFIG_PARAMS.THREADS_COUNT)??bS.get(et.CONFIG_PARAMS.THREADS),r=await w$(e),n=xue.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await ww(e),await Cw(e)):e===et.PROCESS_DESCRIPTORS.HDB?await N$():await y$(e)}a(P$,"reloadStopStart");var D$;async function L$(e=!1){for(let t in et.CLUSTERING_PROCESSES){let r=et.CLUSTERING_PROCESSES[t];await Cw(r,e)}}a(L$,"startClusteringProcesses");async function M$(){D$=A$(et.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:et.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await yS.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await yS.updateLocalStreams();let e=await Bue.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===et.PRE_4_0_0_VERSION){Pl.info("Starting clustering upgrade 4.0.0 process"),A$(et.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(M$,"startClusteringThreads");async function Que(){for(let e in et.CLUSTERING_PROCESSES)if(e!==et.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===et.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await D$.terminate();else{let t=et.CLUSTERING_PROCESSES[e];await ww(t)}}a(Que,"stopClustering");async function Xue(){for(let e in et.CLUSTERING_PROCESSES){let t=et.CLUSTERING_PROCESSES[e];if(await C$(t)===!1)return!1}return!0}a(Xue,"isClusteringRunning");async function Zue(){await xo.generateNatsConfig(!0),await yS.reloadNATSHub(),await yS.reloadNATSLeaf(),await xo.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await xo.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(Zue,"reloadClustering")});var wS={};ve(wS,{compactOnStart:()=>ede,copyDb:()=>F$});async function ede(){Wa.notify("Running compact on start"),console.log("Running compact on start");let e=(0,Pw.get)(x.ROOTPATH),t=new Map,r=Xe();(0,Dw.updateConfigValue)(x.STORAGE_COMPACTONSTART,!1);try{for(let n in r){if(n==="system"||n.endsWith("-copy"))continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,OS.join)(e,"backup",n+".mdb"),o=(0,OS.join)(e,Nc,n+"-copy.mdb"),c=0;try{c=await U$(n),console.log("Database",n,"before compact has a total record count of",c)}catch(l){Wa.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 F$(n,o),console.log("Backing up",n,"to",i),await(0,Dl.move)(s,i,{overwrite:!0})}try{Dd()}catch(n){Wa.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,Dl.move)(i,s,{overwrite:!0}),await(0,Dl.remove)((0,OS.join)(e,Nc,`${n}-copy.mdb-lock`));try{Dd()}catch(n){Wa.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n),process.exit(0)}}catch(n){Wa.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,Dw.updateConfigValue)(x.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,Dl.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw Dd(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await U$(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}.
23
+ `,"")}a(Ck,"runCommand");async function $se(){try{await Sse.access(FO)}catch{return!1}let e=await Ck(`${FO} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return Tse.eq(t,Gse)}a($se,"checkNATSServerInstalled");async function KO(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await wk.getClusterUser();if(pl(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}ai.trace("create nats connection called");let i=await Lse({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:wr.get(Ve.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:wr.get(Ve.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:wr.get(Ve.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),ai.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&ai.error("Error with Nats client connection, connection closed",o),i===Xr&&Pk()}),i}a(KO,"createConnection");function Pk(){Xr=void 0,dl=void 0,fl=void 0,_l=void 0}a(Pk,"clearClientCache");async function Vse(){Xr&&(await Xr.drain(),Xr=void 0,dl=void 0,fl=void 0,_l=void 0)}a(Vse,"closeConnection");var Xr,_l;async function sp(){return _l||(_l=KO(wr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),Xr=await _l),Xr||_l}a(sp,"getConnection");async function ip(){if(dl)return dl;pl(Xr)&&await sp();let{domain:e}=td(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(pl(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return dl=await Xr.jetstreamManager({domain:e,timeout:6e4}),dl}a(ip,"getJetStreamManager");async function Dk(){if(fl)return fl;pl(Xr)&&await sp();let{domain:e}=td(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(pl(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return fl=Xr.jetstream({domain:e,timeout:6e4}),fl}a(Dk,"getJetStream");async function $i(){let e=Xr||await sp(),t=dl||await ip(),r=fl||await Dk();return{connection:e,jsm:t,js:r}}a($i,"getNATSReferences");async function Kse(e){let t=wr.get(Ve.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await wk.getClusterUser(),s=await KO(t,r,n),i=VO(),o=s.subscribe(i),c=[],l,u=(async()=>{for await(let f of o){let d=Ik.decode(f.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 gg.async_set_timeout(e),await o.drain(),await s.close(),await u,c}a(Kse,"getServerList");async function YO(e,t){let{jsm:r}=await $i(),n=wr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=wr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=wr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:Mse.File,retention:vse.Limits,subjects:t,discard:Use.Old,max_msgs:s,max_bytes:i,max_age:n})}a(YO,"createLocalStream");async function Lk(){let{jsm:e}=await $i(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(Lk,"listStreams");async function Yse(e){let{jsm:t}=await $i();await t.streams.delete(e)}a(Yse,"deleteLocalStream");async function Wse(e){let{connection:t}=await $i(),r=[],n=VO(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(Ik.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(Wse,"listRemoteStreams");async function zse(e,t=void 0,r=void 0){let{jsm:n,js:s}=await $i(),i=yk(),o={durable_name:i,ack_policy:qO.Explicit};t&&(o.deliver_policy=$O.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let u=[];for await(let f of l){let d=GO(f.data),p={nats_timestamp:f.info.timestampNanos,nats_sequence:f.info.streamSequence,entry:d};if(f.headers&&(p.origin=f.headers.get(vr.MSG_HEADERS.ORIGIN)),u.push(p),f.ack(),f.info.pending===0)break}return await c.delete(),u}a(zse,"viewStream");async function*jse(e,t=void 0,r=void 0){let{jsm:n,js:s}=await $i(),i=yk(),o={durable_name:i,ack_policy:qO.Explicit};t&&(o.deliver_policy=$O.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let u of l){let f=GO(u.data);f[0]||(f=[f]);for(let d of f){let p={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:d};u.headers&&(p.origin=u.headers.get(vr.MSG_HEADERS.ORIGIN)),yield p}if(u.ack(),u.info.pending===0)break}await c.delete()}a(jse,"viewStreamIterator");async function Jse(e,t,r,n){ai.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=Mk(n,r);let{js:s}=await $i(),i=await Tg(),o=`${e}.${i}`,c=await kse(()=>n instanceof Uint8Array?n:Nk.encode(n));try{ai.trace(`publishToStream publishing to subject: ${o}`),Hse(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 Uk(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){ai.trace(`publishToStream creating stream: ${t}`);let f=o.split(".");f[2]="*",await YO(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(Jse,"publishToStream");function Mk(e,t){t===void 0&&(t=Bse());let r=wr.get(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(vr.MSG_HEADERS.ORIGIN)&&r&&t.append(vr.MSG_HEADERS.ORIGIN,r),t}a(Mk,"addNatsMsgHeader");function td(e){e=e.toLowerCase();let t=np.join(wr.get(Ve.CONFIG_PARAMS.ROOTPATH),Fse);if(e===Ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return pl(kO)&&(kO={port:tp.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:tp.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME)+vr.SERVER_SUFFIX.HUB,config_file:vr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:np.join(t,vr.PID_FILES.HUB),hdb_nats_path:t}),kO;if(e===Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return pl(HO)&&(HO={port:tp.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:tp.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME)+vr.SERVER_SUFFIX.LEAF,config_file:vr.NATS_CONFIG_FILES.LEAF_SERVER,domain:tp.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME)+vr.SERVER_SUFFIX.LEAF,pid_file_path:np.join(t,vr.PID_FILES.LEAF),hdb_nats_path:t}),HO;ai.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(td,"getServerConfig");async function vk(e,t,r,n){try{await e.consumers.add(t,{ack_policy:qO.Explicit,durable_name:r,deliver_policy:$O.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(vk,"createConsumer");async function Qse(e,t,r){await e.consumers.delete(t,r)}a(Qse,"removeConsumer");function Xse(e){return e.split(".")[1]}a(Xse,"extractServerName");async function Zse(e,t,r=6e4,n=VO()){if(!gg.isObject(t))throw new Error("data param must be an object");let s=Nk.encode(t),{connection:i}=await $i(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return GO(c.data)}a(Zse,"request");function WO(e){return new Promise(async(t,r)=>{let n=bse(FO,["--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(WO,"reloadNATS");async function eie(){let{pid_file_path:e}=td(Ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await WO(e)}a(eie,"reloadNATSHub");async function tie(){let{pid_file_path:e}=td(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await WO(e)}a(tie,"reloadNATSLeaf");function rie(e,t,r){let n;switch(e.code){case Rk.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case Rk.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(rie,"requestErrorHandler");async function nie(e,t){let r=t+vr.SERVER_SUFFIX.LEAF,{connection:n}=await $i(),{jsm:s}=await die(r),{schema:i,table:o}=e,c=Sg.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await Uk(async()=>{if(e.subscribe===!0)await vk(s,c,n.info.server_name,l);else try{await Qse(s,c,n.info.server_name)}catch(u){ai.trace(u)}})}a(nie,"updateRemoteConsumer");async function sie(e,t,r,n){let s=Sg.createNatsTableStreamName(e,t),i=r+vr.SERVER_SUFFIX.LEAF,o={type:Ve.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!Ok&&Pse()<wr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=BO();await c(o)}await Ise(o),n==="stop"&&await gg.async_set_timeout(1e3)}a(sie,"updateConsumerIterator");function Uk(e){return wse.writeTransaction(Ve.SYSTEM_SCHEMA_NAME,Ve.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(Uk,"exclusiveLock");async function xk(e,t){let r=Sg.createNatsTableStreamName(e,t),n=await Tg(),s=cie(e,t,n);await YO(r,[s])}a(xk,"createLocalTableStream");async function iie(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await xk(n,s)}}a(iie,"createTableStreams");async function Bk(e,t,r=void 0){if(wr.get(Ve.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=Sg.createNatsTableStreamName(e,t),{domain:s}=td(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await sp()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")ai.warn(n);else throw n}}a(Bk,"purgeTableStream");async function oie(e,t){if(wr.get(Ve.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await Bk(e,t[r])}a(oie,"purgeSchemaTableStreams");async function aie(e){return(await ip()).streams.info(e)}a(aie,"getStreamInfo");function cie(e,t,r){return`${vr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(cie,"createSubjectName");async function Tg(){if(rp)return rp;if(rp=(await ip())?.nc?.info?.server_name,rp===void 0)throw new Error("Unable to get jetstream manager server name");return rp}a(Tg,"getJsmServerName");async function lie(){let e=await ip(),t=await Tg(),r=await Lk();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=uie(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let u=i.split(".");u[u.length-1]=t;let f=u.join(".");ai.trace(`Updating stream subject name from: ${i} to: ${f}`),s.subjects[0]=f,await e.streams.update(s.name,s)}}a(lie,"updateLocalStreams");function uie(e){let{config:t}=e,r=!1,n=wr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=wr.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=wr.get(Ve.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(uie,"updateStreamLimits");async function die(e){let t,r;try{t=await Xr.jetstream({domain:e}),r=await Xr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw ai.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(die,"connectToRemoteJS")});function zO(e){let t=e.get(Ag),r=t?(0,rd.unpack)(t):null;r||(r={remoteNameToId:{}});let n=Ze(),s=!1;r.nodeName=Ze();let i=r.remoteNameToId;if(i[n]!==0){let o=0,c;for(let l in i){let u=i[l];u===0?c=l:u>o&&(o=u)}if(c){o++,i[c]=o;let l=[Symbol.for("seq"),o];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:ap(e)??1,nodes:[]})})}i[n]=0,e.putSync(Ag,(0,rd.pack)(r))}return r}function op(e){return zO(e).remoteNameToId}function Fk(e,t){let r=zO(t),n=r.remoteNameToId,s=new Map,i=!1;for(let o in e){let c=e[o],l=n[o];if(l==null){let u=0;for(let f in n){let d=n[f];d>u&&(u=d)}l=u+1,n[o]=l,i=!0}s.set(c,l)}return i&&t.putSync(Ag,(0,rd.pack)(r)),s}function Rg(e,t){let r=zO(t),n=r.remoteNameToId,s=n[e];if(s==null){let i=0;for(let o in n){let c=n[o];c>i&&(i=c)}s=i+1,n[e]=s,t.putSync(Ag,(0,rd.pack)(r))}return kk.trace?.("The remote node name map",e,n,s),s}var kk,rd,Ag,jO=be(()=>{kk=M(wi());Zn();rd=require("msgpackr"),Ag=Symbol.for("remote-ids");a(zO,"getIdMappingRecord");a(op,"exportIdMapping");a(Fk,"remoteToLocalNodeId");a(Rg,"getIdOfRemoteNode")});var JO={};Ue(JO,{commits_awaiting_replication:()=>sd,getHDBNodeTable:()=>or,getReplicationSharedStatus:()=>yg,iterateRoutes:()=>lp,shouldReplicateToNode:()=>cp,subscribeToNodeUpdates:()=>id});function or(){return Gk||(Gk=dt({table:"hdb_nodes",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"ca"},{attribute:"ca_info"},{attribute:"replicates"},{attribute:"revoked_certificates"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function yg(e,t,r,n){return new Float64Array(e.getUserSharedBuffer(["replicated",t,r],new ArrayBuffer(32),n&&{callback:n}))}function id(e){or().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;Kk.debug?.("adding node",n,"on node",Ze()," on process",process.pid),server.nodes=server.nodes.filter(i=>i.name!==n),r.type==="put"&&n!==Ze()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r));let s=new Map;for await(let i of or().search({}))if(i.shard!=null){let o=s.get(i.shard);o||s.set(i.shard,o=[]),o.push(i)}server.shards=s,(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function cp(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&or().primaryStore.get(Ze())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function fie(){id(e=>{La({},(t,r)=>{let n=e.name,s=qk.get(n);if(s||qk.set(n,s=new Map),s.has(r))return;let i;for(let o in t)if(i=t[o].auditStore,i)break;if(i){let o=yg(i,r,n,()=>{let c=o[0],l=o.lastTime;for(let{txnTime:u,onConfirm:f}of sd.get(r)||[])u>l&&u<=c&&f();o.lastTime=c});o.lastTime=0,s.set(r,o)}})})}function*lp(e){for(let t of e.routes||[]){let r=t.url,n;if(typeof t=="string"?t.includes("://")?r=t:n=t:n=t.hostname??t.host,n&&!r){let s=nd.default.get(x.REPLICATION_SECUREPORT)??(!nd.default.get(x.REPLICATION_PORT)&&nd.default.get(x.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||nd.default.get(x.REPLICATION_PORT)||nd.default.get(x.OPERATIONSAPI_NETWORK_PORT);let o=i?.lastIndexOf?.(":");o>0&&(i=+i.slice(o+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){$k.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{replicates:!t.subscriptions,url:r,subscription:t.subscriptions,routes:t.routes,start_time:t.startTime,revoked_certificates:t.revokedCertificates,shard:t.shard}}}var $k,Vk,nd,Kk,Gk,qk,sd,hl=be(()=>{De();Zn();ym();$k=require("worker_threads"),Vk=M(pe()),nd=M(ce());H();Kk=M(wi());server.nodes=[];a(or,"getHDBNodeTable");a(yg,"getReplicationSharedStatus");a(id,"subscribeToNodeUpdates");a(cp,"shouldReplicateToNode");qk=new Map;RL((e,t,r)=>{if(r>server.nodes.length)throw new Vk.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);sd||(sd=new Map,fie());let n=sd.get(e);return n||(n=[],sd.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(fie,"startSubscriptionToReplications");a(lp,"iterateRoutes")});var jk={};Ue(jk,{connectedToNode:()=>ml,disconnectedFromNode:()=>cd,ensureNode:()=>No,requestClusterStatus:()=>zk,startOnMainThread:()=>XO});async function XO(e){let t=0,r=Xe();for(let i of Object.getOwnPropertyNames(r)){let o=r[i];for(let c in o){let l=o[c];if(l.auditStore){bg.set(i,ap(l.auditStore));break}}}Vi.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes?.search([])||[])i.push(o);for(let o of lp(e))try{let c=!o.subscriptions;if(c){let u=Ze(),f=or().primaryStore.get(u);if(f!==null){let d=e.url??Ma();(f===void 0||f.url!==d||f.shard!==e.shard)&&await No(u,{name:u,url:d,shard:e.shard,replicates:!0})}}let l=o.trusted!==!1;if(c&&o.replicates==null&&(o.replicates=!0),i.find(u=>u.url===o.url))continue;s(o)}catch(c){console.error(c)}id(s)});let n;function s(i,o=i?.name){let c=Ze()&&o===Ze()||Ma()&&i?.url===Ma();if(c){let d=!!i?.replicates;if(n!==void 0&&n!==d)for(let p of or().search([]))p.replicates&&p.name!==o&&s(p,p.name);n=d}if(at.trace("Setting up node replication for",i),!i){for(let[d,p]of Oo){let _;for(let[h,{worker:S,nodes:g}]of p){let R=g[0];if(R&&R.name==o){_=!0;for(let[E,{worker:A}]of p)p.delete(E),at.warn("Node was deleted, unsubscribing from node",o,E,d),A?.postMessage({type:"unsubscribe-from-node",node:o,database:E,url:d});break}}if(_){Oo.get(d).iterator.remove(),Oo.delete(d);return}}return}if(c)return;if(!i.url){at.info(`Node ${i.name} is missing url`);return}let l=Oo.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(at.info(`Added node ${i.name} at ${i.url} for process ${Ze()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[d,p]of od)if(i.url===p.url){od.delete(d);break}od.set(i.name,i)}let u=Xe();if(l||(l=new Map,Oo.set(i.url,l)),l.iterator=La(e,(d,p,_)=>{_?f(p,!0):f(p,!1)}),i.subscriptions)for(let d of i.subscriptions){let p=d.database||d.schema;u[p]||(at.warn(`Database ${p} not found for node ${i.name}, making a subscription anyway`),f(p,!1))}function f(d,p){at.trace("Setting up replication for database",d,"on node",i.name);let _=l.get(d),h,S=[{replicateByDefault:p,...i}];bg.has(d)&&(S.push({replicateByDefault:p,name:Ze(),start_time:bg.get(d),end_time:Date.now(),replicates:!0}),bg.delete(d));let g=cp(i,d),R=Vi.workers.filter(E=>E.name==="http");if(_?(h=_.worker,_.nodes=S):g&&(t=t%R.length,h=R[t++],l.set(d,{worker:h,nodes:S,url:i.url}),h?.on("exit",()=>{l.get(d)?.worker===h&&(l.delete(d),f(d,p))})),g)setTimeout(()=>{let E={type:"subscribe-to-node",database:d,nodes:S};h?h.postMessage(E):ad(E)},_ie);else{at.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[d],or().primaryStore.get(Ze())?.replicates),or().primaryStore.get(Ze())?.replicates||(n=!1);let E={type:"unsubscribe-from-node",database:d,url:i.url,name:i.name};h?h.postMessage(E):Ng(E)}}a(f,"onDatabase")}a(s,"onNodeUpdate"),cd=a(function(i){try{at.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(od.keys()),c=o.sort(),l=c.indexOf(i.name||ci(i.url));if(l===-1){at.warn("Disconnected node not found in node map",i.name,o);return}let u=Oo.get(i.url),f=u?.get(i.database);if(!f){at.warn("Disconnected node not found in replication map",i.database,u);return}if(f.connected=!1,i.finished)return;let d=f.nodes[0];if(!(d.replicates===!0||d.replicates?.sends||d.subscriptions?.length))return;let p=(l+1)%c.length;for(;l!==p;){let _=c[p],h=od.get(_);u=Oo.get(h.url);let S=u?.get(i.database);if(!S){p=(p+1)%c.length;continue}let{worker:g,nodes:R}=S,E=!1;for(let A of f.nodes){if(R.some(N=>N.name===A.name)){at.info(`Disconnected node is already failing over to ${_} for ${i.database}`);continue}R.push(A),E=!0}if(!E){at.info(`Disconnected node ${i.name} has no nodes to fail over to ${_}`);return}f.redirectingTo=S,at.info(`Failing over ${i.database} from ${i.name} to ${_}`),g?g.postMessage({type:"subscribe-to-node",database:i.database,nodes:R}):ad({database:i.database,nodes:R});return}at.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){at.error("Error failing over node",o)}},"disconnectedFromNode"),ml=a(function(i){let o=Oo.get(i.url),c=o?.get(i.database);if(!c){at.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,o);return}if(c.connected=!0,c.latency=i.latency,c.redirectingTo){let{worker:l,nodes:u}=c.redirectingTo,f=u.find(d=>d.name===i.name);c.redirectingTo=null,f&&(u.splice(u.indexOf(f),1),l?l.postMessage({type:"subscribe-to-node",database:i.database,nodes:u}):ad({database:i.database,nodes:u}))}},"connectedToNode"),(0,Vi.onMessageByType)("disconnected-from-node",cd),(0,Vi.onMessageByType)("connected-to-node",ml),(0,Vi.onMessageByType)("request-cluster-status",zk)}function zk(e,t){let r=[];for(let[n,s]of od)try{let i=Oo.get(s.url);at.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let o=[];if(i){for(let[l,{worker:u,connected:f,nodes:d,latency:p}]of i)o.push({database:l,connected:f,latency:p,thread_id:u?.threadId,nodes:d.map(_=>_.name)});let c=(0,QO.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){at.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function No(e,t){let r=or();e=e??ci(t.url),t.name=e;try{if(t.ca){let s=new Wk.X509Certificate(t.ca);t.ca_info={issuer:s.issuer.replace(/\n/g," "),subject:s.subject.replace(/\n/g," "),subject_alt_name:s.subjectAltName,serial_number:s.serialNumber,valid_from:s.validFrom,valid_to:s.validTo}}}catch(s){at.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(at.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.put(t);else{t.replicates&&!Yk.default.get(x.CLUSTERING_ENABLED)&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],o=(0,QO.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let u of o)if((c.database??c.schema)===(u.database??u.schema)&&c.table===u.table){u.publish=c.publish,u.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...o,...i];break}if(Array.isArray(t.revoked_certificates)){let s=n.revoked_certificates||[];t.revoked_certificates=[...new Set([...s,...t.revoked_certificates])]}at.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Vi,Og,at,QO,Yk,Wk,_ie,Oo,cd,ml,od,bg,up=be(()=>{De();Vi=M(rt());Zn();Og=require("worker_threads");hl();at=M(W()),QO=require("lodash"),Yk=M(ce());H();Wk=require("crypto"),_ie=200,Oo=new Map,od=new Map,bg=new Map;a(XO,"startOnMainThread");a(zk,"requestClusterStatus");Og.parentPort&&(cd=a(e=>{Og.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),ml=a(e=>{Og.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Vi.onMessageByType)("subscribe-to-node",e=>{ad(e)}),(0,Vi.onMessageByType)("unsubscribe-from-node",e=>{Ng(e)}));a(No,"ensureNode")});var es=I(gF=>{"use strict";var ar=require("path"),wn=require("fs-extra"),ld=require("node-forge"),tF=require("net"),{generateKeyPair:eN,X509Certificate:wo,createPrivateKey:rF}=require("crypto"),pie=require("util");eN=pie.promisify(eN);var yt=ld.pki,li=require("joi"),{v4:nF}=require("uuid"),{validateBySchema:sN}=it(),_t=W(),bs=ce(),Os=(H(),P(G)),{CONFIG_PARAMS:ud}=Os,ui=Ky(),{ClientError:Ua}=pe(),wg=require("node:tls"),{relative:sF,join:hie}=require("node:path"),{CERT_PREFERENCE_APP:MPe,CERTIFICATE_VALUES:Jk}=ui,mie=da(),tN=Rt(),{table:Eie,getDatabases:gie,databases:ZO}=(De(),P(nt)),{getJWTRSAKeys:Qk}=(Qu(),P(Z_));Object.assign(gF,{generateKeys:aN,updateConfigCert:fF,createCsr:Nie,signCertificate:wie,setCertTable:dd,loadCertificates:lF,reviewSelfSignedCert:lN,createTLSSelector:pF,listCertificates:mF,addCertificate:Mie,removeCertificate:Uie,createNatsCerts:Pie,generateCertsKeys:Cie,getReplicationCert:fp,getReplicationCertAuth:Oie,renewSelfSigned:Die,hostnamesFromCert:EF,getKey:xie});var{urlToNodeName:iF,getThisNodeUrl:Sie,getThisNodeName:Cg,clearThisNodeName:Tie}=(Zn(),P(Io)),{readFileSync:Aie,watchFile:Rie,statSync:oF}=require("node:fs"),vPe=ce(),{getTicketKeys:yie,onMessageFromWorkers:bie}=rt(),va=W(),{isMainThread:aF}=require("worker_threads"),{TLSSocket:cF,createSecureContext:UPe}=require("node:tls"),iN=3650,dp=["127.0.0.1","localhost","::1"],oN=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];bie(async e=>{e.type===Os.ITC_EVENT_TYPES.RESTART&&(bs.initSync(!0),await lN())});var Ur;function Ba(){return Ur||(Ur=gie().system.hdb_certificate,Ur||(Ur=Eie({table:"hdb_certificate",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]}))),Ur}a(Ba,"getCertTable");async function fp(){let e=pF("operations-api"),t={secureContexts:null,setSecureContext:a(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(Cg());if(!r)return;let n=new wo(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(fp,"getReplicationCert");async function Oie(){Ba();let e=(await fp()).options.cert,r=new wo(e).issuer.match(/CN=(.*)/)?.[1];return Ur.get(r)}a(Oie,"getReplicationCertAuth");var Xk,xa=new Map;function lF(){if(Xk)return;Xk=!0;let e=[{configKey:ud.TLS},{configKey:ud.OPERATIONSAPI_TLS}];Ba();let t=ar.dirname(tN.getConfigFilePath()),r;for(let{configKey:n}of e){let s=tN.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&sF(hie(t,"keys"),o);c&&Zk(o,l=>{xa.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&aF){let f;Zk(u,d=>{if(Jk.cert===d)return;let p=i.hostname??i.hostnames??i.host??i.hosts;p&&!Array.isArray(p)&&(p=[p]);let _=_F(u),h=new wo(_),S;try{S=uN(h)}catch(A){_t.error("error extracting common name from certificate",A);return}if(S==null){_t.error("error extracting common name from certificate");return}if(h.checkIssued(new wo(Jk.cert)))return;let g=Ur.primaryStore.get(S),R=oF(u).mtimeMs,E=!g||g.is_self_signed?1:g.file_timestamp??g.__updatedtime__;if(g&&R<=E){R<E&&_t.info(`Certificate ${S} at ${u} is older (${new Date(R)}) than the certificate in the database (${E>1?new Date(E):"only self signed certificate available"})`);return}r=Ur.put({name:S,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:_,private_key_name:c,is_authority:l,hostnames:p,file_timestamp:R,details:{issuer:h.issuer.replace(/\n/g," "),subject:h.subject.replace(/\n/g," "),subject_alt_name:h.subjectAltName,serial_number:h.serialNumber,valid_from:h.validFrom,valid_to:h.validTo}})},l?"certificate authority":"certificate")}}}}}return r}a(lF,"loadCertificates");function Zk(e,t,r){let n,s=a((i,o)=>{try{let c=i.mtimeMs;c&&c!==n&&(o&&aF&&_t.warn(`Reloading ${r}:`,e),n=c,t(_F(e)))}catch(c){_t.error(`Error loading ${r}:`,e,c)}},"loadFile");wn.existsSync(e)?s(oF(e)):_t.error(`${r} file not found:`,e),Rie(e,{persistent:!1},s)}a(Zk,"loadAndWatch");function rN(){let e=Sie();if(e==null){let t=dp[0];return _t.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return iF(e)}a(rN,"getHost");function Ig(){let e=Cg();if(e==null){let t=dp[0];return _t.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(Ig,"getCommonName");async function Nie(){let e=await fp(),t=yt.certificateFromPem(e.options.cert),r=yt.privateKeyFromPem(e.options.key);_t.info("Creating CSR with cert named:",e.name);let n=yt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:Ig()},...oN];_t.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:uF()}];return _t.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),ld.pki.certificationRequestToPem(n)}a(Nie,"createCsr");function uF(){let e=dp.includes(Ig())?dp:[...dp,Ig()];return e.includes(rN())||e.push(rN()),[{name:"basicConstraints",cA:!1,critical:!0},{name:"keyUsage",digitalSignature:!0,keyEncipherment:!0,critical:!0},{name:"extKeyUsage",serverAuth:!0,clientAuth:!0},{name:"nsCertType",client:!0,server:!0},{name:"subjectAltName",altNames:e.map(t=>tF.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a(uF,"certExtensions");async function wie(e){let t={},r=ar.join(bs.getHdbBasePath(),Os.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;Ba();for await(let f of Ur.search([]))if(f.is_authority&&!f.details.issuer.includes("HarperDB-Certificate-Authority")){if(xa.has(f.private_key_name)){n=xa.get(f.private_key_name),s=f;break}else if(f.private_key_name&&await wn.exists(ar.join(r,f.private_key_name))){n=wn.readFile(ar.join(r,f.private_key_name)),s=f;break}}if(!n){let f=await nN();s=f.ca,n=f.private_key}n=yt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=yt.certificateFromPem(s.certificate);_t.info("Signing CSR with cert named",s.name);let o=yt.certificationRequestFromPem(e.csr);try{o.verify()}catch(f){return _t.error(f),new Error("Error verifying CSR: "+f.message)}let c=ld.pki.createCertificate();c.serialNumber=Math.random().toString().slice(2,10),c.validity.notBefore=new Date;let l=new Date;c.validity.notAfter=l,c.validity.notAfter.setDate(l.getDate()+iN),_t.info("sign cert setting validity:",c.validity),_t.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),_t.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=o.getAttribute({name:"extensionRequest"}).extensions;_t.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=o.publicKey,c.sign(n,ld.md.sha256.create()),t.certificate=yt.certificateToPem(c)}else _t.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(wie,"signCertificate");async function Iie(e,t){await dd({name:Cg(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await dd({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:yt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(Iie,"createCertificateTable");async function dd(e){let t=new wo(e.certificate);e.details={issuer:t.issuer.replace(/\n/g," "),subject:t.subject.replace(/\n/g," "),subject_alt_name:t.subjectAltName,serial_number:t.serialNumber,valid_from:t.validFrom,valid_to:t.validTo},Ba(),await Ur.patch(e)}a(dd,"setCertTable");async function aN(){let e=await eN("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:yt.publicKeyFromPem(e.publicKey),private_key:yt.privateKeyFromPem(e.privateKey)}}a(aN,"generateKeys");async function cN(e,t,r){let n=yt.createCertificate();if(!t){let o=await fp();t=yt.certificateFromPem(o.options.cert).publicKey}n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+iN);let i=[{name:"commonName",value:Ig()},...oN];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(uF()),n.sign(e,ld.md.sha256.create()),yt.certificateToPem(n)}a(cN,"generateCertificates");async function nN(){let e=await mF(),t;for(let r of e){if(!r.is_authority)continue;let n=await hF(r.private_key_name);if(r.private_key_name&&n&&new wo(r.certificate).checkPrivateKey(rF(n))){_t.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;_t.trace("No CA found with matching private key")}a(nN,"getCertAuthority");async function dF(e,t,r=!0){let n=yt.createCertificate();n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+iN);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${bs.get(ud.REPLICATION_HOSTNAME)??iF(bs.get(ud.REPLICATION_URL))??nF().split("-")[0]}`},...oN];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,ld.md.sha256.create());let o=ar.join(bs.getHdbBasePath(),Os.LICENSE_KEY_DIR_NAME),c=ar.join(o,ui.PRIVATEKEY_PEM_NAME);return r&&await wn.writeFile(c,yt.privateKeyToPem(e)),n}a(dF,"generateCertAuthority");async function Cie(){let{private_key:e,public_key:t}=await aN(),r=await dF(e,t),n=await cN(e,t,r);await Iie(n,r),fF()}a(Cie,"generateCertsKeys");async function Pie(){let e=await cN(yt.privateKeyFromPem(ui.CERTIFICATE_VALUES.key),void 0,yt.certificateFromPem(ui.CERTIFICATE_VALUES.cert)),t=ar.join(bs.getHdbBasePath(),Os.LICENSE_KEY_DIR_NAME),r=ar.join(t,ui.NATS_CERTIFICATE_PEM_NAME);await wn.exists(r)||await wn.writeFile(r,e);let n=ar.join(t,ui.NATS_CA_PEM_NAME);await wn.exists(n)||await wn.writeFile(n,ui.CERTIFICATE_VALUES.cert)}a(Pie,"createNatsCerts");async function Die(){Ba();for await(let e of Ur.search([{attribute:"is_self_signed",value:!0}]))await Ur.delete(e.name);await lN()}a(Die,"renewSelfSigned");async function lN(){Tie(),await lF(),Ba();let e=await nN();if(!e){_t.notify("A matching Certificate Authority and key was not found. A new CA will be created in advance, so it's available if needed.");let r=bs.get(ud.TLS_PRIVATEKEY),n=ar.join(bs.getHdbBasePath(),Os.LICENSE_KEY_DIR_NAME),s,i=sF(n,r);try{s=yt.privateKeyFromPem(await wn.readFile(r))}catch(c){_t.warn("Unable to parse the TLS key",r,"A new key will be generated and used to create Certificate Authority",c),{private_key:s}=await aN(),await wn.exists(ar.join(n,ui.PRIVATEKEY_PEM_NAME))&&(i=`privateKey${nF().split("-")[0]}.pem`),await wn.writeFile(ar.join(n,i),yt.privateKeyToPem(s))}let o=await dF(s,yt.setRsaPublicKey(s.n,s.e),!1);await dd({name:o.subject.getField("CN").value,uses:["https"],certificate:yt.certificateToPem(o),private_key_name:i,is_authority:!0,is_self_signed:!0})}if(!await fp()){let r=Cg();_t.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await nN();let n=yt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await cN(yt.privateKeyFromPem(e.private_key),s,n);await dd({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(lN,"reviewSelfSignedCert");function fF(){let e=mie(Object.keys(Os.CONFIG_PARAM_MAP),!0),t=ar.join(bs.getHdbBasePath(),Os.LICENSE_KEY_DIR_NAME),r=ar.join(t,ui.PRIVATEKEY_PEM_NAME),n=ar.join(t,ui.NATS_CERTIFICATE_PEM_NAME),s=ar.join(t,ui.NATS_CA_PEM_NAME),i=Os.CONFIG_PARAMS,o={[i.TLS_PRIVATEKEY]:e[i.TLS_PRIVATEKEY.toLowerCase()]?e[i.TLS_PRIVATEKEY.toLowerCase()]:r};e[i.TLS_CERTIFICATE.toLowerCase()]&&(o[i.TLS_CERTIFICATE]=e[i.TLS_CERTIFICATE.toLowerCase()]),e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.TLS_CERTIFICATEAUTHORITY]=e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATE]=e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]),e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_PRIVATEKEY]=e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY]=e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]),(e[i.CLUSTERING_ENABLED.toLowerCase()]||e.clustering)&&(o[i.CLUSTERING_TLS_CERTIFICATE]=e[i.CLUSTERING_TLS_CERTIFICATE.toLowerCase()]??n,o[i.CLUSTERING_TLS_CERT_AUTH]=e[i.CLUSTERING_TLS_CERT_AUTH.toLowerCase()]??s,o[i.CLUSTERING_TLS_PRIVATEKEY]=e[i.CLUSTERING_TLS_PRIVATEKEY.toLowerCase()]??r),tN.updateConfigValue(void 0,void 0,o,!1,!0)}a(fF,"updateConfigCert");function _F(e){return e.startsWith("-----BEGIN")?e:Aie(e,"utf8")}a(_F,"readPEM");var eF=wg.createSecureContext;wg.createSecureContext=function(e){if(!e.cert||!e.key)return eF(e);let t={...e};delete t.key,delete t.cert;let r=eF(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var Lie=cF.prototype._init;cF.prototype._init=function(e,t){Lie.call(this,e,t);let r=this;this._handle.oncertcb=function(n){let s=n.servername;r._SNICallback(s,(i,o)=>{this.sni_context=o?.context||o,this.certCbDone()})}};var El=new Map;function pF(e,t){let r=new Map,n,s=!1;return i.initialize=o=>i.ready?i.ready:(o&&(o.secureContexts=r,o.secureContextsListeners=[]),i.ready=new Promise((c,l)=>{async function u(){try{r.clear(),El.clear();let f=0;for await(let d of ZO.system.hdb_certificate.search([])){let p=d.certificate,_=new wo(p);d.is_authority&&(_.asString=p,El.set(_.subject,p))}for await(let d of ZO.system.hdb_certificate.search([]))try{if(d.is_authority)continue;let p=e==="operations-api",_=d.is_self_signed?1:2;p&&d.uses?.includes?.("operations")&&(_+=1);let h=await hF(d.private_key_name),S=d.certificate,g=new wo(S);if(El.has(g.issuer)&&(S+=`
24
+ `+El.get(g.issuer)),!h||!S)throw new Error("Missing private key or certificate for secure server");let R={ciphers:d.ciphers,ticketKeys:yie(),availableCAs:El,ca:t&&Array.from(El.values()),cert:S,key:h,key_file:d.private_key_name,is_self_signed:d.is_self_signed};o&&(R.sessionIdContext=o.sessionIdContext);let E=wg.createSecureContext(R);E.name=d.name,E.options=R,E.quality=_,E.certificateAuthorities=Array.from(El),E.certStart=S.toString().slice(0,100);let A=d.hostnames??EF(g);Array.isArray(A)||(A=[A]);let N;for(let v of A)if(v){v[0]==="*"&&(s=!0,v=v.slice(1)),v===rN()&&(_+=2),tF.isIP(v)&&(N=!0);let F=r.get(v)?.quality??0;_>F&&r.set(v,E)}else va.error("No hostname found for certificate at",wg.certificate);va.trace("Adding TLS",E.name,"for",o.ports||"client","cert named",d.name,"hostnames",A,"quality",_,"best quality",f),_>f&&(i.defaultContext=n=E,f=_,o&&(o.defaultContext=E))}catch(p){va.error("Error applying TLS for",d.name,p)}o?.secureContextsListeners.forEach(d=>d()),c(n)}catch(f){l(f)}}a(u,"updateTLS"),ZO.system.hdb_certificate.subscribe({listener:a(()=>setTimeout(()=>u(),1500).unref(),"listener"),omitCurrent:!0}),u()})),i;function i(o,c){va.info("TLS requested for",o||"(no SNI)");let l=o;for(;;){let f=r.get(l);if(f)return va.debug("Found certificate for",o,f.certStart),f.updatedContext&&(f=f.updatedContext),c(null,f);if(s&&l){let d=l.indexOf(".",1);d<0?l="":l=l.slice(d)}else break}o?va.debug("No certificate found to match",o,"using the default certificate"):va.debug("No SNI, using the default certificate",n?.name);let u=n;u?u.updatedContext&&(u=u.updatedContext):va.info("No default certificate found"),c(null,u)}a(i,"SNICallback")}a(pF,"createTLSSelector");async function hF(e){let t=xa.get(e);return!t&&e?await wn.readFile(ar.join(bs.get(ud.ROOTPATH),Os.LICENSE_KEY_DIR_NAME,e),"utf8"):t}a(hF,"getPrivateKeyByName");async function mF(){Ba();let e=[];for await(let t of Ur.search([]))e.push(t);return e}a(mF,"listCertificates");async function Mie(e){let t=sN(e,li.object({name:li.string().required(),certificate:li.string().required(),is_authority:li.boolean().required(),private_key:li.string(),hosts:li.array(),uses:li.array()}));if(t)throw new Ua(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,o=new wo(n),c=!1,l=!1,u;for(let[_,h]of xa)!s&&!c&&o.checkPrivateKey(rF(h))&&(c=!0,u=_),s&&s===h&&(l=!0,u=_);if(!i&&!s&&!c)throw new Ua("A suitable private key was not found for this certificate");let f;if(!r){try{f=uN(o)}catch(_){_t.error(_)}if(f==null)throw new Ua("Error extracting certificate common name, please provide a name parameter")}let d=vie(r??f);s&&!c&&!l&&(await wn.writeFile(ar.join(bs.getHdbBasePath(),Os.LICENSE_KEY_DIR_NAME,d+".pem"),s),xa.set(d,s));let p={name:r??f,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&u||i&&s)&&(p.private_key_name=u??d+".pem"),await dd(p),"Successfully added certificate: "+d}a(Mie,"addCertificate");function vie(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(vie,"sanitizeName");async function Uie(e){let t=sN(e,li.object({name:li.string().required()}));if(t)throw new Ua(t.message);let{name:r}=e;Ba();let n=await Ur.get(r);if(!n)throw new Ua(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await Ur.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(_t.info("Removing private key named",s),await wn.remove(ar.join(bs.getHdbBasePath(),Os.LICENSE_KEY_DIR_NAME,s)))}return await Ur.delete(r),"Successfully removed "+r}a(Uie,"removeCertificate");function uN(e){return e.subject.match(/CN=(.*)/)?.[1]}a(uN,"extractCommonName");function EF(e){return e.subjectAltName?e.subjectAltName.split(",").map(t=>{let r=t.indexOf(":");if(t=t.slice(r+1),t=t.trim(),t[0]==='"')try{t=JSON.parse(t)}catch{}return t.indexOf("=")>-1?t.match(/CN=([^,]*)/)?.[1]:t}).filter(t=>t):[uN(e)]}a(EF,"hostnamesFromCert");async function xie(e){if(e.bypass_auth!==!0)throw new Ua("Unauthorized","401");let t=sN(e,li.object({name:li.string().required()}));if(t)throw new Ua(t.message);let{name:r}=e;if(r===".jwtPrivate")return(await Qk()).privateKey;if(r===".jwtPublic")return(await Qk()).publicKey;if(xa.get(r))return xa.get(e.name);throw new Ua("Key not found")}a(xie,"getKey")});var BF={};Ue(BF,{CONFIRMATION_STATUS_POSITION:()=>xF,NodeReplicationConnection:()=>_p,OPERATION_REQUEST:()=>pN,RECEIVED_TIME_POSITION:()=>mN,RECEIVED_VERSION_POSITION:()=>hN,SENDING_TIME_POSITION:()=>vg,createWebSocket:()=>xg,database_subscriptions:()=>ka,replicateOverWS:()=>pp,table_update_listeners:()=>gN});async function xg(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=Ze(),i;if(e==null)throw new TypeError(`Invalid URL: Expected a string URL for node "${s}" but received ${e}`);if(e.includes("wss://")){if(!fN){let l=(0,MF.createTLSSelector)("operations-api"),u={secureContexts:null};await l.initialize(u),fN=u.secureContexts}if(i=fN.get(s),i&&ue.debug?.("Creating web socket for URL",e,"with certificate named:",i.name),!i&&n!==!1)throw new Error("Unable to find a valid certificate to use for replication to connect to "+e)}let o={};r&&(o.Authorization=r);let c={headers:o,localAddress:s?.startsWith("127.0")?s:void 0,servername:(0,UF.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,rejectUnauthorized:n!==!1,secureContext:void 0};return i&&(c.secureContext=vF.createSecureContext({...i.options,ca:Array.from(Sl)})),new DF.WebSocket(e,"harperdb-replication-v1",c)}function pp(e,t,r){let n=t.port||t.securePort,s=gl.pid%1e3+"-"+LF.threadId+(n?"s:"+n:"c:"+t.url?.slice(-4))+" "+Math.random().toString().slice(2,3),i=0,o=Buffer.allocUnsafeSlow(1024),c=0,l=new DataView(o.buffer,0,1024),u=t.database,f=t.databaseSubscriptions||ka,d,p,_=!1,h=t.subscription;h?.then&&h.then(T=>h=T);let S=t.tables||u&&Xe()[u];if(!r){ue.error?.("No authorization provided"),dn(1008,"Unauthorized");return}let g=new Map,R=[],E=r.name;E&&t.connection&&(t.connection.nodeName=E);let A,N,v,F,$,Y,ee,oe=1e3,j,se=0,z=0,me=0,Ae=new Map,Pe=[],he=0,Ot;if(t.url){let T=a(()=>{$&&z===e._socket?.bytesRead&&me===e._socket?.bytesWritten?e.terminate():($=performance.now(),e.ping(),z=e._socket?.bytesRead,me=e._socket?.bytesWritten)},"send_ping");v=setInterval(T,IF).unref(),T()}else ut();e._socket?.setMaxListeners(200);function ut(){clearTimeout(F),z=e._socket?.bytesRead,me=e._socket?.bytesWritten,F=setTimeout(()=>{z===e._socket?.bytesRead&&me===e._socket?.bytesWritten&&(ue.warn?.(`Timeout waiting for ping from ${E}, terminating connection and reconnecting`),e.terminate())},IF*2).unref()}a(ut,"resetPingTimer");function br(){return p||(p=yg(d,u,E)),p}a(br,"getSharedStatus"),u&&oa(u);let ms,xn,au=[],cu=[],kA,FA=[],Mt=[],gf=[],Qh=150,Xh=25,Sf=0,Zh=0,Ie=!1,Tf,un,Cr,lu;e.on("message",T=>{se=performance.now();try{let b=T.dataView=new Tl(T.buffer,T.byteOffset,T.byteLength);if(T[0]>127){let O=(0,je.decode)(T),[U,L,C]=O;switch(U){case TF:{if(L){if(E){if(E!==L){ue.error?.(s,`Node name mismatch, expecting to connect to ${E}, but peer reported name as ${L}, disconnecting`),e.send((0,je.encode)([fd])),dn(1008,"Node name mismatch");return}}else if(E=L,t.connection?.tentativeNode){let de=t.connection.tentativeNode;de.name=E,t.connection.tentativeNode=null,No(E,de)}if(t.connection&&(t.connection.nodeName=E),ue.debug?.(s,"received node name:",E,"db:",u),!u)try{oa(u=O[2]),u==="system"&&(ms=La(t,(de,re)=>{du(re)&&aa(re)}),e.on("close",()=>{ms?.remove()}))}catch(de){ue.warn?.(s,"Error setting database",de),e.send((0,je.encode)([fd])),dn(1008,de.message);return}Gr()}break}case NF:{ue.debug?.(s,"Received table definitions for",L.map(de=>de.table));for(let de of L){let re=O[2];de.database=re;let fe;du(re)&&(re==="system"?$e[re]?.[de.table]||(fe=m(de,$e[re]?.[de.table])):fe=m(de,$e[re]?.[de.table]),d||(d=fe?.auditStore),S||(S=Xe()?.[re]))}break}case fd:dn();break;case pN:try{let de=r?.replicates||r?.subscribers||r?.name;server.operation(L,{user:r},!de).then(re=>{Array.isArray(re)&&(re={results:re}),re.requestId=L.requestId,e.send((0,je.encode)([Dg,re]))},re=>{e.send((0,je.encode)([Dg,{requestId:L.requestId,error:re instanceof Error?re.toString():re}]))})}catch(de){e.send((0,je.encode)([Dg,{requestId:L.requestId,error:de instanceof Error?de.toString():de}]))}break;case Dg:let{resolve:B,reject:q}=g.get(L.requestId);L.error?q(new Error(L.error)):B(L),g.delete(L.requestId);break;case dN:let Q=O[3];S||(u?ue.error?.(s,"No tables found for",u):ue.error?.(s,"Database name never received"));let X=S[Q];X=m({table:Q,database:u,attributes:L.attributes,schemaDefined:L.schemaDefined},X),au[C]={name:Q,decoder:new je.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:L.typedStructs,structures:L.structures}),getEntry(de){return X.primaryStore.getEntry(de)},rootStore:X.primaryStore.rootStore};break;case AF:lu=d?Fk(L,d):new Map,kA=O[2],ue.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${kA}`);break;case RF:let k=C;gf[k]=L;break;case OF:br()[xF]=L,ue.trace?.(s,"received and broadcasting committed update",L),br().buffer.notify();break;case bF:A=L,h.send({type:"end_txn",localTime:A,remoteNodeIds:R});break;case Lg:{let de=O[1],{fileId:re,size:fe,finished:ie,error:J}=de,le=Ae.get(re);ue.debug?.("Received blob",re,"has stream",!!le,"connectedToBlob",!!le?.connectedToBlob,"length",O[2].length,"finished",ie),le||(le=new _N.PassThrough,le.expectedSize=fe,Ae.set(re,le)),le.lastChunk=Date.now(),ie?(J?(le.on("error",()=>{}),le.destroy(new Error("Blob error: "+J))):le.end(O[2]),le.connectedToBlob&&Ae.delete(re)):le.write(O[2]);break}case yF:{let de=L,re;try{let fe=O[3],ie=cu[C]||(cu[C]=S[O[4]]);if(!ie)return ue.warn?.("Unknown table id trying to handle record request",C);let J=ie.primaryStore.getBinaryFast(Symbol.for("structures")),le=J.length;if(le!==Zh){Zh=le;let Te=(0,je.decode)(J);e.send((0,je.encode)([dN,{typedStructs:Te.typed,structures:Te.named},C,ie.tableName]))}let Re=ie.primaryStore.getBinaryFast(fe);if(Re){let Te=ie.primaryStore.decoder.decode(Re,{valueAsBuffer:!0});re=(0,je.encode)([Pg,de,{value:Te.value,expiresAt:Te.expiresAt,version:Te.version,residencyId:Te.residencyId,nodeId:Te.nodeId,user:Te.user}])}else re=(0,je.encode)([Pg,de])}catch(fe){re=(0,je.encode)([Pg,de,{error:fe.message}])}e.send(re);break}case Pg:{let{resolve:de,reject:re,tableId:fe,key:ie}=g.get(O[1]),J=O[2];if(J?.error)re(new Error(J.error));else if(J){let le=au[fe].decoder.decode(J.value);J.value=le,J.key=ie,de(J)}else de();g.delete(O[1]);break}case SF:{Cr=L;let de,re,fe=!1;if(h){if(u!==h.databaseName&&!h.then){ue.error?.("Subscription request for wrong database",u,h.databaseName);return}}else h=f.get(u);if(ue.debug?.(s,"received subscription request for",u,"at",Cr),!h){let ye;h=new Promise(tt=>{ue.debug?.("Waiting for subscription to database "+u),ye=tt}),h.ready=ye,ka.set(u,h)}if(r.name)re=or().subscribe(r.name),re.then(async ye=>{de=ye;for await(let tt of de){let vt=tt.value;if(!(vt?.replicates===!0||vt?.replicates?.receives||vt?.subscriptions?.some(mr=>(mr.database||mr.schema)===u&&mr.publish!==!1))){fe=!0,e.send((0,je.encode)([fd])),dn(1008,`Unauthorized database subscription to ${u}`);return}}},ye=>{ue.error?.(s,"Error subscribing to HDB nodes",ye)});else if(!(r?.role?.permission?.super_user||r.replicates)){e.send((0,je.encode)([fd])),dn(1008,`Unauthorized database subscription to ${u}`);return}if(un&&(ue.debug?.(s,"stopping previous subscription",u),un.emit("close")),Cr.length===0)return;let ie=Cr[0],J=a(ye=>{if(ye&&(ie.replicateByDefault?!ie.tables.includes(ye.tableName):ie.tables.includes(ye.tableName)))return{table:ye}},"tableToTableEntry"),le={txnTime:0},Re,Te,ve=1/0,Je,Zt=a((ye,tt)=>{if(ye.type==="end_txn"){le.txnTime&&(o[i]!==66&&ue.error?.("Invalid encoding of message"),fu(9),fu(Ug),yc(Je=tt),qr()),i=c,le.txnTime=0;return}let vt=ye.nodeId,mr=ye.tableId,Vt=Te[mr];if(!Vt&&(Vt=Te[mr]=J(h.tableById[mr]),!Vt))return ue.debug?.("Not subscribed to table",mr);let $r=Vt.table,bc=$r.primaryStore,Ut=bc.encoder;(ye.extendedType&Jm||!Ut.typedStructs)&&(Ut._mergeStructures(Ut.getStructures()),Ut.typedStructs&&(Ut.lastTypedStructuresLength=Ut.typedStructs.length));let tm=Re[vt];if(!(tm&&tm.startTime<tt&&(!tm.endTime||tm.endTime>tt)))return Mg&&ue.trace?.(s,"skipping replication update",ye.recordId,"to:",E,"from:",vt,"subscribed:",Re),oD();Mg&&ue.trace?.(s,"sending replication update",ye.recordId,"to:",E,"from:",vt,"subscribed:",Re);let GA=ye.version;le.txnTime!==GA&&(le.txnTime&&(Mg&&ue.trace?.(s,"new txn time, sending queued txn",le.txnTime),o[i]!==66&&ue.error?.("Invalid encoding of message"),qr()),le.txnTime=GA,i=c,yc(GA));let Oc=ye.residencyId,qA=uu(Oc,$r),rm;if(qA&&!qA.includes(E)){let Nc=uu(ye.previousResidencyId,$r);if(Nc&&!Nc.includes(E)&&(ye.type==="put"||ye.type==="patch")||$r.getResidencyById)return oD();let yf=ye.recordId;ue.trace?.(s,"sending invalidation",yf,E,"from",vt);let la=0;Oc&&(la|=Fc),ye.previousResidencyId&&(la|=Gc);let Ys,fn=null;for(let nm in $r.indices){if(!fn){if(Ys=ye.getValue(bc,!0),!Ys)break;fn={}}fn[nm]=Ys[nm]}rm=wu(ye.version,mr,yf,null,vt,ye.user,ye.type==="put"||ye.type==="patch"?"invalidate":ye.type,Ut.encode(fn),la,Oc,ye.previousResidencyId,ye.expiresAt)}function oD(){ue.trace?.(s,"skipping audit record",ye.recordId),Y||(Y=setTimeout(()=>{Y=null,(Je||0)+wF/2<ve&&(Mg&&ue.trace?.(s,"sending skipped sequence update",ve),e.send((0,je.encode)([bF,ve])))},wF).unref())}a(oD,"skipAuditRecord");let $A=Ut.typedStructs,VA=Ut.structures;if(($A?.length!=Vt.typed_length||VA?.length!=Vt.structure_length)&&(Vt.typed_length=$A?.length,Vt.structure_length=VA.length,ue.debug?.(s,"send table struct",Vt.typed_length,Vt.structure_length),Vt.sentName||(Vt.sentName=!0),e.send((0,je.encode)([dN,{typedStructs:$A,structures:VA,attributes:$r.attributes,schemaDefined:$r.schemaDefined},mr,Vt.table.tableName]))),Oc&&!Mt[Oc]&&(e.send((0,je.encode)([RF,qA,Oc])),Mt[Oc]=!0),rm)fu(rm.length),Rc(rm);else{let Nc=ye.encoded;ye.extendedType&Gn&&DR(()=>ye.getValue(bc),async la=>{let Ys=km(la);try{let fn;he++;for await(let nm of la.stream()){if(fn&&(ue.debug?.("Sending blob chunk",Ys,"length",fn.length),e.send((0,je.encode)([Lg,{fileId:Ys,size:la.size},fn]))),fn=nm,fe)return;e._socket.writableNeedDrain&&(ue.debug?.("draining",Ys),await new Promise(g2=>e._socket.once("drain",g2)),ue.debug?.("drained",Ys))}ue.debug?.("Sending final blob chunk",Ys,"length",fn.length),e.send((0,je.encode)([Lg,{fileId:Ys,size:la.size,finished:!0},fn]))}catch(fn){ue.debug?.("Error sending blob",fn),e.send((0,je.encode)([Lg,{fileId:Ys,finished:!0,error:fn.toString()},Buffer.alloc(0)]))}finally{he--,he<Xh&&Ot?.()}});let yf=Nc[0]===66?8:0;fu(Nc.length-yf),Rc(Nc,yf),ue.trace?.("wrote record",ye.recordId,"length:",Nc.length)}},"sendAuditRecord"),qr=a(()=>{c-i>8?(e.send(o.subarray(i,c)),ue.debug?.(s,"Sent message, size:",c-i)):ue.debug?.(s,"skipping empty transaction")},"sendQueuedData");un=new EN.EventEmitter,un.once("close",()=>{fe=!0,de?.end()});for(let{startTime:ye}of Cr)ye<ve&&(ve=ye);(re||Promise.resolve()).then(async()=>{h=await h,d=h.auditStore,Te=h.tableById.map(J),Re=[];for(let{name:tt,startTime:vt,endTime:mr}of Cr){let Vt=Rg(tt,d);ue.debug?.("subscription to",tt,"using local id",Vt,"starting",vt),Re[Vt]={startTime:vt,endTime:mr}}aa(u),ms||(ms=Al(tt=>{tt.databaseName===u&&aa(u)}),xn=hp(tt=>{tt===u&&(e.send((0,je.encode)([fd])),dn())}),e.on("close",()=>{ms?.remove(),xn?.remove()})),e.send((0,je.encode)([AF,op(h.auditStore),Cr.map(({name:tt})=>tt)]));let ye=!0;do{isFinite(ve)||(ue.warn?.("Invalid sequence id "+ve),dn(1008,"Invalid sequence id"+ve));let tt;if(ye&&!fe&&(ye=!1,!(TN(d)<=ve)&&(PF.default.get(x.REPLICATION_COPYTABLESTOCATCHUP)??Bie)&&server.nodes[0]?.name===E)){ue.info?.("Replicating all tables to",E);let mr=ve,Vt=Bg(d);for(let $r in S){if(!J($r))continue;let bc=S[$r];for(let Ut of bc.primaryStore.getRange({snapshot:!1})){if(fe)return;Ut.localTime>=ve&&(ue.trace?.(s,"Copying record from",u,$r,Ut.key,Ut.localTime),mr=Math.max(Ut.localTime,mr),tt=!0,br()[vg]=1,Zt({recordId:Ut.key,tableId:bc.tableId,type:"put",getValue(){return Ut.value},encoded:bc.primaryStore.getBinary(Ut.key),version:Ut.version,residencyId:Ut.residencyId,nodeId:Vt,extendedType:Ut.metadataFlags},Ut.localTime))}}ve=mr}for(let{key:vt,value:mr}of d.getRange({start:ve||1,exclusiveStart:!0,snapshot:!1})){if(fe)return;let Vt=wt(mr);ue.debug?.("sending audit record",new Date(vt)),br()[vg]=vt,ve=vt,Zt(Vt,vt),e._socket.writableNeedDrain?await new Promise($r=>{ue.debug?.(`Waiting for remote node ${E} to allow more commits ${e._socket.writableNeedDrain?"due to network backlog":"due to requested flow directive"}`),e._socket.once("drain",$r)}):he>Xh?await new Promise($r=>{Ot=$r}):await new Promise(setImmediate),un.startTime=vt,tt=!0}tt&&Zt({type:"end_txn"},ve),br()[vg]=0,await HF(d)}while(!fe)}).catch(ye=>{ue.error?.(s,"Error handling subscription to node",ye),dn(1008,"Error handling subscription to node")});break}}return}b.position=8;let w=!0,y,D;do{br();let O=b.readInt();if(O===9&&b.getUint8(b.position)==Ug){b.position++,A=D=b.readFloat64(),p[hN]=A,p[mN]=Date.now(),ue.trace?.("received remote sequence update",A,u);break}let U=b.position,L=wt(T,U,U+O),C=au[L.tableId];C||ue.error?.(`No table found with an id of ${L.tableId}`);let B;L.residencyId&&(B=gf[L.residencyId],ue.trace?.(s,"received residency list",B,L.type,L.recordId));try{PR(()=>{y={table:C.name,id:L.recordId,type:L.type,nodeId:lu.get(L.nodeId),residencyList:B,timestamp:L.version,value:L.getValue(C),user:L.user,beginTxn:w,expiresAt:L.expiresAt}},q=>{let Q=km(q),X=Ae.get(Q);ue.debug?.("Received transaction with blob",Q,"has stream",!!X,"ended",!!X?.writableEnded),X?X.writableEnded&&Ae.delete(Q):(X=new _N.PassThrough,Ae.set(Q,X)),X.connectedToBlob=!0,X.lastChunk=Date.now(),q.size===void 0&&X.expectedSize&&(q.size=X.expectedSize);let k=createBlob(X,q),de=k.save({primaryStore:h.auditStore});return de&&(de.blobId=Q,Pe.push(de),de.finally(()=>{ue.debug?.(`Finished receiving blob stream ${Q}`),Pe.splice(Pe.indexOf(de),1)})),k})}catch(q){throw q.message+="typed structures for current decoder"+JSON.stringify(C.decoder.typedStructs),q}w=!1,ue.trace?.(s,"received replication message",L.type,"id",y.id,"version",new Date(L.version),"nodeId",y.nodeId),p[hN]=L.version,p[mN]=Date.now(),h.send(y),b.position=U+O}while(b.position<T.byteLength);Sf++,sr(T.byteLength,"bytes-received",`${E}.${u}.${y?.table||"unknown_table"}`,"replication","ingest"),Sf>Qh&&!Ie&&(Ie=!0,e.pause(),ue.debug?.(`Commit backlog causing replication back-pressure, requesting that ${E} pause replication`)),h.send({type:"end_txn",localTime:A,remoteNodeIds:R,async onCommit(){if(y){let O=Date.now()-y.timestamp;sr(O,"replication-latency",E+"."+u+"."+y.table,y.type,"ingest")}Sf--,Ie&&(Ie=!1,e.resume(),ue.debug?.(`Replication resuming ${E}`)),Pe.length>0&&await Promise.all(Pe),ue.trace?.("All blobs finished"),!N&&D&&(ue.trace?.(s,"queuing confirmation of a commit at",D),setTimeout(()=>{e.send((0,je.encode)([OF,N])),ue.trace?.(s,"sent confirmation of a commit at",N),N=null},Hie)),N=D,ue.debug?.("last sequence committed",new Date(D),u)}})}catch(b){ue.error?.(s,"Error handling incoming replication message",b)}}),e.on("ping",ut),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-$,ml({name:E,database:u,url:t.url,latency:t.connection.latency})),$=null}),e.on("close",(T,b)=>{clearInterval(v),clearTimeout(F),clearInterval(ee),un&&un.emit("close"),Tf&&Tf.end();for(let[w,{reject:y}]of g)y(new Error(`Connection closed ${b?.toString()} ${T}`));ue.debug?.(s,"closed",T,b?.toString())});function Af(){}a(Af,"recordRemoteNodeSequence");function dn(T,b){e.isFinished=!0,e.close(T,b)}a(dn,"close");function Gr(){if(_||(_=!0,t.connection?.on("subscriptions-updated",Gr)),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let T=new Map;try{for(let y of h?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let D of y.value.nodes||[])D.lastTxnTime>(T.get(D.id)??0)&&T.set(D.id,D.lastTxnTime)}catch(y){if(!y.message.includes("Can not re"))throw y}let b=t.connection?.nodeSubscriptions?.[0];R=[];let w=t.connection?.nodeSubscriptions.map((y,D)=>{let O=[],{replicateByDefault:U}=y;if(y.subscriptions){for(let q of y.subscriptions)if(q.subscribe&&(q.schema||q.database)===u){let Q=q.table;S?.[Q]?.replicate!==!1&&O.push(Q)}U=!1}else for(let q in S)(U?S[q].replicate===!1:S[q].replicate)&&O.push(q);let L=d&&Rg(y.name,d),C=h?.dbisDB?.get([Symbol.for("seq"),L])??1,B=Math.max(C?.seqId??1,(typeof y.start_time=="string"?new Date(y.start_time).getTime():y.start_time)??1);if(ue.debug?.("Starting time recorded in db",y.name,L,u,C?.seqId,"start time:",B,new Date(B)),b!==y){let q=d&&Rg(b.name,d),Q=h?.dbisDB?.get([Symbol.for("seq"),q])??1;for(let X of Q?.nodes||[])X.name===y.name&&(B=X.seqId,ue.debug?.("Using sequence id from proxy node",b.name,B))}return R.push(L),T.get(L)>B&&(B=T.get(L),ue.debug?.("Updating start time from more recent txn recorded",b.name,B)),{name:y.name,replicateByDefault:U,tables:O,startTime:B,endTime:y.end_time}});if(w)if(ue.debug?.(s,"sending subscription request",w,h?.dbisDB?.path),clearTimeout(j),w.length>0)e.send((0,je.encode)([SF,w]));else{let y=a(()=>{let D=performance.now();j=setTimeout(()=>{se<=D?dn(1008,"No nodes to subscribe to"):y()},oe)},"schedule_close");y()}}a(Gr,"sendSubscriptionRequestUpdate");function uu(T,b){if(!T)return;let w=FA[T];return w||(w=b.getResidencyRecord(T),FA[T]=w),w}a(uu,"getResidence");function du(T){return!(Ha&&Ha!="*"&&!Ha[T]&&!Ha.includes?.(T)&&!Ha.some?.(b=>b.name===T))}a(du,"checkDatabaseAccess");function oa(T){if(h=h||f.get(T),!du(T))throw new Error(`Access to database "${T}" is not permitted`);h||ue.warn?.(`No database named "${T}" was declared and registered`),d=h?.auditStore,S||(S=Xe()?.[T]);let b=Ze();if(b===E)throw b?new Error("Should not connect to self",b):new Error("Node name not defined");return em(b,T),!0}a(oa,"setDatabase");function em(T,b){let w=Xe()?.[b],y=[];for(let D in w){let O=w[D];y.push({table:D,schemaDefined:O.schemaDefined,attributes:O.attributes.map(U=>({name:U.name,type:U.type,isPrimaryKey:U.isPrimaryKey}))})}ue.trace?.("Sending database info for node",T,"database name",b),e.send((0,je.encode)([TF,T,b,y]))}a(em,"sendNodeDBName");function aa(T){let b=Xe()?.[T],w=[];for(let y in b){if(Cr&&!Cr.some(O=>O.replicateByDefault?!O.tables.includes(y):O.tables.includes(y)))continue;let D=b[y];w.push({table:y,schemaDefined:D.schemaDefined,attributes:D.attributes.map(O=>({name:O.name,type:O.type,isPrimaryKey:O.isPrimaryKey}))})}e.send((0,je.encode)([NF,w,T]))}a(aa,"sendDBSchema"),ee=setInterval(()=>{for(let[T,b]of Ae)b.lastChunk+3e4<Date.now()&&(ue.warn?.(`Timeout waiting for blob stream to finish ${T} from ${E}`),Ae.delete(T),b.end())},3e4).unref();let ca=1,Rf=[];return{end(){Tf&&Tf.end(),un&&un.emit("close")},getRecord(T){let b=ca++;return new Promise((w,y)=>{let D=[yF,b,T.table.tableId,T.id];Rf[T.table.tableId]||(D.push(T.table.tableName),Rf[T.table.tableId]=!0),e.send((0,je.encode)(D)),g.set(b,{tableId:T.table.tableId,key:T.id,resolve(O){let{table:U,entry:L}=T;w(O),O&&U._recordRelocate(L,O)},reject:y})})},sendOperation(T){let b=ca++;return T.requestId=b,e.send((0,je.encode)([pN,T])),new Promise((w,y)=>{g.set(b,{resolve:w,reject:y})})}};function fu(T){V(5),T<128?o[c++]=T:T<16384?(l.setUint16(c,T|32768),c+=2):T<1056964608?(l.setUint32(c,T|3221225472),c+=4):(o[c]=255,l.setUint32(c+1,T),c+=5)}function Rc(T,b=0,w=T.length){let y=w-b;V(y),T.copy(o,c,b,w),c+=y}function yc(T){V(8),l.setFloat64(c,T),c+=8}function V(T){if(T+16>o.length-c){let b=Buffer.allocUnsafeSlow(c+T-i+65536>>10<<11);o.copy(b,0,i,c),c=c-i,i=0,o=b,l=new DataView(o.buffer,0,o.length)}}function m(T,b){let w=T.database??"data";if(w!=="data"&&!$e[w]){ue.warn?.("Database not found",T.database);return}b||(b={});let y=b.schemaDefined,D=!1,O=T.schemaDefined,U=b.attributes||[];for(let L=0;L<T.attributes?.length;L++){let C=T.attributes[L],B=U[L];(!B||B.name!==C.name||B.type!==C.type)&&(y?ue.error?.(`Schema for '${u}.${T.table}' is defined locally, but attribute '${C.name}: ${C.type}' from '${E}' does not match local attribute ${B?"'"+B.name+": "+B.type+"'":"which does not exist"}`):(D=!0,O||(C.indexed=!0),U[L]=C))}return D?(ue.debug?.("(Re)creating",T),dt({table:T.table,database:T.database,schemaDefined:T.schemaDefined,attributes:U,...b})):b}}var PF,je,DF,LF,ue,EN,MF,vF,gl,UF,_N,SF,TF,AF,fd,RF,dN,yF,Pg,pN,Dg,bF,OF,NF,Lg,xF,hN,mN,vg,Bie,gN,ka,Mg,wF,Hie,IF,fN,CF,_p,SN=be(()=>{De();_o();jO();AN();Zn();PF=M(ce());H();Iu();je=require("msgpackr"),DF=require("ws"),LF=require("worker_threads"),ue=M(wi());up();EN=require("events"),MF=M(es()),vF=M(require("node:tls"));hl();gl=M(require("node:process")),UF=require("node:net");Fi();Ss();_N=require("node:stream"),SF=129,TF=140,AF=141,fd=142,RF=130,dN=132,yF=133,Pg=134,pN=136,Dg=137,bF=143,OF=144,NF=145,Lg=146,xF=0,hN=1,mN=2,vg=3,Bie=gl.env.HDB_LEADER_URL||gl.argv.includes("--HDB_LEADER_URL"),gN=new Map,ka=new Map,Mg=!0,wF=300,Hie=2,IF=3e4;a(xg,"createWebSocket");CF=1e3,_p=class extends EN.EventEmitter{constructor(r,n,s,i,o){super();this.url=r;this.subscription=n;this.databaseName=s;this.nodeName=i;this.authorization=o;this.nodeName=this.nodeName??ci(r)}static{a(this,"NodeReplicationConnection")}socket;startTime;retryTime=CF;retries=0;isConnected=!0;isFinished=!1;nodeSubscriptions=[];latency=0;replicateTablesByDefault;session;sessionResolve;sessionReject;async connect(){this.session||this.resetSession();let r=[];this.socket=await xg(this.url,{serverName:this.nodeName,authorization:this.authorization});let n;ue.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${gl.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),ue[this.isConnected?"info":"warn"]?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=CF,ml({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=pp(this.socket,{database:this.databaseName,subscription:this.subscription,url:this.url,connection:this},{replicates:!0}),this.sessionResolve(n)}),this.socket.on("error",s=>{s.code==="SELF_SIGNED_CERT_IN_CHAIN"?(ue.warn?.(`Can not connect to ${this.url}, this server does not have a certificate authority for the certificate provided by ${this.url}`),s.isHandled=!0):s.code!=="ECONNREFUSED"&&(s.code==="UNABLE_TO_VERIFY_LEAF_SIGNATURE"?ue.error?.(`Can not connect to ${this.url}, the certificate provided by ${this.url} is not trusted, this node needs to be added to the cluster, or a certificate authority needs to be added`):ue.error?.(`Error in connection to ${this.url} due to ${s.message}`)),this.sessionReject(s)}),this.socket.on("close",(s,i)=>{if(this.isConnected&&(cd({name:this.nodeName,database:this.databaseName,url:this.url,finished:this.socket.isFinished}),this.isConnected=!1),this.socket.isFinished){this.isFinished=!0,n?.end(),this.emit("finished");return}if(++this.retries%20===1){let o=i?.toString();ue.warn?.(`${n?"Disconnected from":"Failed to connect to"} ${this.url} (db: "${this.databaseName}"), due to ${o?'"'+o+'" ':""}(code: ${s})`)}n=null,this.resetSession(),setTimeout(()=>{this.connect()},this.retryTime).unref(),this.retryTime+=this.retryTime>>3})}resetSession(){this.session=new Promise((r,n)=>{this.sessionResolve=r,this.sessionReject=n})}subscribe(r,n){this.nodeSubscriptions=r,this.replicateTablesByDefault=n,this.emit("subscriptions-updated",r)}unsubscribe(){this.socket.isFinished=!0,this.socket.close(1008,"No longer subscribed")}getRecord(r){return this.session.then(n=>n.getRecord(r))}};a(pp,"replicateOverWS")});var Io={};Ue(Io,{clearThisNodeName:()=>Yie,disableReplication:()=>qie,enabled_databases:()=>Ha,forEachReplicatedDatabase:()=>La,getThisNodeId:()=>Bg,getThisNodeName:()=>Ze,getThisNodeUrl:()=>Ma,hostnameToUrl:()=>Gg,lastTimeInAuditStore:()=>ap,monitorNodeCAs:()=>YF,replicateOperation:()=>zie,replication_certificate_authorities:()=>Sl,sendOperationToNode:()=>Ep,servers:()=>Fie,setReplicator:()=>zF,start:()=>Gie,startOnMainThread:()=>XO,subscribeToNode:()=>ad,unsubscribeFromNode:()=>Ng,urlToNodeName:()=>ci});function Gie(e){if(e.port||(e.port=Ns.default.get(x.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=Ns.default.get(x.OPERATIONSAPI_NETWORK_SECUREPORT)),!Ze())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let n of lp(e))t.set(ci(n.url),n);$ie(e),e={mtls:!0,isOperationsServer:!0,maxPayload:10*1024*1024*1024,...e};let r=We.ws(async(n,s,i,o)=>{if(s.headers.get("sec-websocket-protocol")!=="harperdb-replication-v1")return o(n,s,i);await i,n._socket.unref(),pp(n,e,s?.user),n.on("error",c=>{c.code!=="ECONNREFUSED"&&cr.error("Error in connection to "+this.url,c.message)})},e);e.runFirst=!0,We.http((n,s)=>{if(n.isWebSocket&&n.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){!n.authorized&&n._nodeRequest.socket.authorizationError&&cr.error(`Incoming client connection from ${n.ip} did not have valid certificate, you may need turn on enableRootCAs in the config if you are using a publicly signed certificate, or add the CA to the server's trusted CAs`,n._nodeRequest.socket.authorizationError);let i=or().primaryStore;if(n.authorized&&n.peerCertificate.subject){let o=n.peerCertificate.subject,c=o&&(i.get(o.CN)||t.get(o.CN));if(c)if(c?.revoked_certificates?.includes(n.peerCertificate.serialNumber)){cr.warn("Revoked certificate used in attempt to connect to node",c.name,"certificate serial number",n.peerCertificate.serialNumber);return}else n.user=c;else cr.warn(`No node found for certificate common name ${o.CN}, available nodes are ${Array.from(i.getRange({}).filter(({value:l})=>l).map(({key:l})=>l)).join(", ")} and routes ${Array.from(t.keys()).join(", ")}, connection will require credentials.`)}else{let o=i.get(n.ip)||t.get(n.ip);o?n.user=o:cr.warn(`No node found for IP address ${n.ip}, available nodes are ${Array.from(new Set([...i.getKeys(),...t.keys()])).join(", ")}, connection will require credentials.`)}}return s(n)},e);for(let n of r)if(n.secureContexts){let s=a(()=>{let i=new Set(n.secureContexts.values());n.defaultContext&&i.add(n.defaultContext);for(let o of i)try{let c=Array.from(Sl);o.options.availableCAs&&c.push(...o.options.availableCAs.values());let l={...o.options,ca:c};o.updatedContext=Fg.createSecureContext(l)}catch(c){cr.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),YF(s),Ns.default.get(x.REPLICATION_ENABLEROOTCAS)!==!1&&s()}}function YF(e){let t=0;id(r=>{r?.ca&&(Sl.add(r.ca),Sl.size!==t&&(t=Sl.size,e?.()))})}function qie(e=!0){KF=e}function $ie(e){KF||(Xe(),Ha=e.databases,La(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||ka;for(let[s,i]of mp){let o=i.get(r);o&&(o.subscribe([],!1),i.delete(r))}n.delete(r);return}for(let n in t){let s=t[n];zF(r,s,e),gN.get(s)?.forEach(i=>i(s))}}))}function zF(e,t,r){if(!t)return console.error(`Attempt to replicate non-existent table ${t.name} from database ${e}`);if(t.replicate===!1||t.sources?.some(s=>s.isReplicator))return;let n;t.sourcedFrom(class WF extends Vr{static{a(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||ka,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(cr.trace("Setting up replicator subscription to database",e),!o?.auditStore)return this.subscription=o=new Hn,i.set(e,o),o.tableById=c,o.auditStore=t.auditStore,o.dbisDB=t.dbisDB,o.databaseName=e,l&&l(o),o;this.subscription=o}static subscribeOnThisThread(i,o){return!0}static async load(i){if(i){let o=i.residencyId,c=i.residency||t.dbisDB.get([Symbol.for("residency_by_id"),o]);if(c){let l,u=new Set;do{let f;for(let p of c){let _=Vie(p,WF.subscription,e);_?.isConnected&&!u.has(_)&&(!f||_.latency<f.latency)&&(f=_)}if(!f)throw l||new $F.ServerError("No connection to any other nodes are available",502);let d={requestId:kie++,table:t,entry:i,id:i.key};u.add(f);try{return await f.getRecord(d)}catch(p){if(f.isConnected)throw p;cr.warn("Error in load from node",kg,p),l||(l=p)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function jF(e,t,r,n,s){let i=mp.get(e);i||mp.set(e,i=new Map);let o=i.get(r);if(o)return o;if(t)return i.set(r,o=new _p(e,t,r,n,s)),o.connect(),o.once("finished",()=>i.delete(r)),o}function Vie(e,t,r){let n=kF.get(e)?.get(r);if(n)return n;let s=or().primaryStore.get(e);return s?.url&&(n=jF(s.url,t,r,e,s.authorization),kF.set(e,mp.get(s.url))),n}async function Ep(e,t,r){r||(r={}),r.serverName=e.name;let n=await xg(e.url,r),s=pp(n,{},{});return new Promise((i,o)=>{n.on("open",()=>{i(s.sendOperation(t))}),n.on("error",c=>{o(c)}),n.on("close",c=>{cr.info("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function ad(e){try{VF.isMainThread&&cr.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=ka.get(e.database);if(!t){let n;t=new Promise(s=>{cr.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,ka.set(e.database,t)}let r=jF(e.nodes[0].url,t,e.database,e.nodes[0].name,e.nodes[0].authorization);e.nodes[0].name===void 0?r.tentativeNode=e.nodes[0]:r.nodeName=e.nodes[0].name,r.subscribe(e.nodes.filter(n=>cp(n,e.database)),e.replicateByDefault)}catch(t){cr.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function Ng({name:e,url:t,database:r}){cr.trace("Unsubscribing from node",e,t,r,"nodes",Array.from(or().primaryStore.getRange({})));let n=mp.get(t);if(n){let s=n.get(r);s&&(s.unsubscribe(),n.delete(r))}}function Kie(){if(RN!==void 0)return RN;let e=Ns.default.get(x.OPERATIONSAPI_TLS_CERTIFICATE)||Ns.default.get(x.TLS_CERTIFICATE);if(e)return RN=new GF.X509Certificate((0,qF.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function Ze(){return kg||(kg=Ns.default.get("replication_hostname")??ci(Ns.default.get("replication_url"))??Kie()??FF("operationsapi_network_secureport")??FF("operationsapi_network_port")??"127.0.0.1")}function Yie(){kg=void 0}function FF(e){let t=Ns.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function Hg(e){let t=Ns.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function Bg(e){return op(e)?.[Ze()]}function Ma(){let e=Ns.default.get("replication_url");return e||Gg(Ze())}function Gg(e){let t=Hg("replication_port");if(t)return`ws://${e}:${t}`;if(t=Hg("replication_secureport"),t)return`wss://${e}:${t}`;if(t=Hg("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=Hg("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function ci(e){if(e)return new URL(e).hostname}function La(e,t){for(let n of Object.getOwnPropertyNames($e))r(n);return hp(n=>{r(n)}),Al((n,s)=>{r(n.databaseName)});function r(n){let s=$e[n];cr.trace("Checking replication status of ",n,e?.databases),e?.databases===void 0||e.databases==="*"||e.databases.includes(n)||e.databases.some?.(i=>i.name===n)||!s?t(s,n,!0):Wie(n)&&t(s,n,!1)}a(r,"forDatabase")}function Wie(e){let t=$e[e];for(let r in t)if(t[r].replicate)return!0}function ap(e){for(let t of e.getKeys({limit:1,reverse:!0}))return t}async function zie(e){let t={message:""};if(e.replicated){e.replicated=!1,cr.trace?.("Replicating operation",e.operation,"to nodes",We.nodes.map(n=>n.name));let r=await Promise.allSettled(We.nodes.map(n=>Ep(n,e)));t.replicated=r.map((n,s)=>{let i=n.status==="rejected"?{status:"failed",reason:n.reason.toString()}:n.value;return i.node=We.nodes[s]?.name,i})}return t}var Ns,cr,GF,qF,Fg,$F,VF,KF,kie,Fie,Sl,Ha,mp,kF,RN,kg,Zn=be(()=>{De();ga();hu();SN();Kr();Ns=M(ce()),cr=M(W()),GF=require("crypto"),qF=require("fs");up();hl();H();jO();Fg=M(require("node:tls")),$F=M(pe()),VF=require("worker_threads"),kie=1,Fie=[],Sl=Ns.default.get(x.REPLICATION_ENABLEROOTCAS)!==!1?new Set(Fg.rootCertificates):new Set;a(Gie,"start");a(YF,"monitorNodeCAs");a(qie,"disableReplication");a($ie,"assignReplicationSource");a(zF,"setReplicator");mp=new Map;a(jF,"getConnection");kF=new Map;a(Vie,"getConnectionByName");a(Ep,"sendOperationToNode");a(ad,"subscribeToNode");a(Ng,"unsubscribeFromNode");a(Kie,"getCommonNameFromCert");a(Ze,"getThisNodeName");a(Yie,"clearThisNodeName");Object.defineProperty(We,"hostname",{get(){return Ze()}});a(FF,"getHostFromListeningPort");a(Hg,"getPortFromListeningPort");a(Bg,"getThisNodeId");We.replication={getThisNodeId:Bg,exportIdMapping:op};a(Ma,"getThisNodeUrl");a(Gg,"hostnameToUrl");a(ci,"urlToNodeName");a(La,"forEachReplicatedDatabase");a(Wie,"hasExplicitlyReplicatedTable");a(ap,"lastTimeInAuditStore");a(zie,"replicateOperation")});var Yg=I((aDe,eG)=>{"use strict";var _d=lk(),{validateBySchema:gp}=it(),{common_validators:pd,schema_regex:yN}=Li(),lr=require("joi"),jie=W(),Jie=require("uuid").v4,Vg=Ao(),hd=(H(),P(G)),Qie=require("util"),Fa=Kn(),{handleHDBError:Co,hdb_errors:Xie,ClientError:Sp}=pe(),{HDB_ERROR_MSGS:qg,HTTP_STATUS_CODES:Po}=Xie,{SchemaEventMsg:Kg}=ni(),JF=ir(),{getDatabases:Zie}=(De(),P(nt)),{transformReq:md}=ae(),{replicateOperation:QF}=(Zn(),P(Io)),$g=lr.string().min(1).max(pd.schema_length.maximum).pattern(yN).messages({"string.pattern.base":"{:#label} "+pd.schema_format.message}),eoe=lr.string().min(1).max(pd.schema_length.maximum).pattern(yN).messages({"string.pattern.base":"{:#label} "+pd.schema_format.message}).required(),toe=lr.string().min(1).max(pd.schema_length.maximum).pattern(yN).messages({"string.pattern.base":"{:#label} "+pd.schema_format.message,"any.required":"'primary_key' is required","string.base":"'primary_key' must be a string"}).required();eG.exports={createSchema:roe,createSchemaStructure:XF,createTable:noe,createTableStructure:ZF,createAttribute:coe,dropSchema:soe,dropTable:ioe,dropAttribute:ooe,getBackup:loe};async function roe(e){let t=await XF(e);return Vg.signalSchemaChange(new Kg(process.pid,e.operation,e.schema)),t}a(roe,"createSchema");async function XF(e){let t=gp(e,lr.object({database:$g,schema:$g}));if(t)throw new Sp(t.message);if(md(e),!await _d.checkSchemaExists(e.schema))throw Co(new Error,qg.SCHEMA_EXISTS_ERR(e.schema),Po.BAD_REQUEST,hd.LOG_LEVELS.ERROR,qg.SCHEMA_EXISTS_ERR(e.schema),!0);return await Fa.createSchema(e),`database '${e.schema}' successfully created`}a(XF,"createSchemaStructure");async function noe(e){return md(e),e.hash_attribute=e.primary_key??e.hash_attribute,await ZF(e)}a(noe,"createTable");async function ZF(e){let t=gp(e,lr.object({database:$g,schema:$g,table:eoe,residence:lr.array().items(lr.string().min(1)).optional(),hash_attribute:toe}));if(t)throw new Sp(t.message);if(!await _d.checkSchemaTableExists(e.schema,e.table))throw Co(new Error,qg.TABLE_EXISTS_ERR(e.schema,e.table),Po.BAD_REQUEST,hd.LOG_LEVELS.ERROR,qg.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:Jie(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await Fa.createTable(n,e);else throw Co(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Po.BAD_REQUEST);else await Fa.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(ZF,"createTableStructure");async function soe(e){let t=gp(e,lr.object({database:lr.string(),schema:lr.string()}).or("database","schema").messages({"object.missing":"'database' is required"}));if(t)throw new Sp(t.message);md(e);let r=await _d.checkSchemaExists(e.schema);if(r)throw Co(new Error,r,Po.NOT_FOUND,hd.LOG_LEVELS.ERROR,r,!0);let n=await _d.schema_describe.describeSchema({schema:e.schema}),s=Object.keys(global.hdb_schema[e.schema]);await Fa.dropSchema(e),Vg.signalSchemaChange(new Kg(process.pid,e.operation,e.schema)),await JF.purgeSchemaTableStreams(e.schema,s);let i=await QF(e);return i.message=`successfully deleted '${e.schema}'`,i}a(soe,"dropSchema");async function ioe(e){let t=gp(e,lr.object({database:lr.string(),schema:lr.string(),table:lr.string().required()}));if(t)throw new Sp(t.message);md(e);let r=await _d.checkSchemaTableExists(e.schema,e.table);if(r)throw Co(new Error,r,Po.NOT_FOUND,hd.LOG_LEVELS.ERROR,r,!0);await Fa.dropTable(e),await JF.purgeTableStream(e.schema,e.table);let n=await QF(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}a(ioe,"dropTable");async function ooe(e){let t=gp(e,lr.object({database:lr.string(),schema:lr.string(),table:lr.string().required(),attribute:lr.string().required()}));if(t)throw new Sp(t.message);md(e);let r=await _d.checkSchemaTableExists(e.schema,e.table);if(r)throw Co(new Error,r,Po.NOT_FOUND,hd.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw Co(new Error,"You cannot drop a hash attribute",Po.BAD_REQUEST,void 0,void 0,!0);if(hd.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw Co(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Po.BAD_REQUEST,void 0,void 0,!0);try{return await Fa.dropAttribute(e),aoe(e),Vg.signalSchemaChange(new Kg(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw jie.error(`Got an error deleting attribute ${Qie.inspect(e)}.`),n}}a(ooe,"dropAttribute");function aoe(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(aoe,"dropAttributeFromGlobal");async function coe(e){md(e);let t=Zie()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw Co(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Po.BAD_REQUEST,void 0,void 0,!0);return await Fa.createAttribute(e),Vg.signalSchemaChange(new Kg(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(coe,"createAttribute");function loe(e){return Fa.getBackup(e)}a(loe,"getBackup")});var rG=I((lDe,tG)=>{"use strict";var{OPERATIONS_ENUM:uoe}=(H(),P(G)),bN=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=uoe.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};tG.exports=bN});var ON=I((fDe,aG)=>{"use strict";var doe=Kn(),dDe=rG(),Wg=ae(),zg=(H(),P(G)),foe=ce(),{handleHDBError:nG,hdb_errors:_oe}=pe(),{HDB_ERROR_MSGS:sG,HTTP_STATUS_CODES:iG}=_oe,poe=Object.values(zg.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),oG="To use this operation audit log must be enabled in harperdb-config.yaml";aG.exports=hoe;async function hoe(e){if(Wg.isEmpty(e.schema))throw new Error(sG.SCHEMA_REQUIRED_ERR);if(Wg.isEmpty(e.table))throw new Error(sG.TABLE_REQUIRED_ERR);if(!foe.get(zg.CONFIG_PARAMS.LOGGING_AUDITLOG))throw nG(new Error,oG,iG.BAD_REQUEST,zg.LOG_LEVELS.ERROR,oG,!0);let t=Wg.checkSchemaTableExist(e.schema,e.table);if(t)throw nG(new Error,t,iG.NOT_FOUND,zg.LOG_LEVELS.ERROR,t,!0);if(!Wg.isEmpty(e.search_type)&&poe.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await doe.readAuditLog(e)}a(hoe,"readAuditLog")});var lG=I((pDe,cG)=>{"use strict";var{OPERATIONS_ENUM:moe}=(H(),P(G)),NN=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=moe.GET_BACKUP,this.schema=t,this.table=r}};cG.exports=NN});var fG=I((gDe,dG)=>{"use strict";var Eoe=Kn(),mDe=lG(),wN=ae(),goe=(H(),P(G)),EDe=ce(),{handleHDBError:Soe,hdb_errors:Toe}=pe(),{HDB_ERROR_MSGS:uG,HTTP_STATUS_CODES:Aoe}=Toe;dG.exports=Roe;async function Roe(e){if(wN.isEmpty(e.schema))throw new Error(uG.SCHEMA_REQUIRED_ERR);if(wN.isEmpty(e.table))throw new Error(uG.TABLE_REQUIRED_ERR);let t=wN.checkSchemaTableExist(e.schema,e.table);if(t)throw Soe(new Error,t,Aoe.NOT_FOUND,goe.LOG_LEVELS.ERROR,t,!0);return await Eoe.getBackup(read_audit_log_object)}a(Roe,"getBackup")});var mG=I((TDe,hG)=>{"use strict";var yoe=ce(),Ga=require("joi"),boe=it(),_G=require("moment"),Ooe=require("fs-extra"),IN=require("path"),Noe=require("lodash"),Tp=(H(),P(G)),{LOG_LEVELS:Rl}=(H(),P(G)),woe="YYYY-MM-DD hh:mm:ss",Ioe=IN.resolve(__dirname,"../logs");hG.exports=function(e){return boe.validateBySchema(e,Coe)};var Coe=Ga.object({from:Ga.custom(pG),until:Ga.custom(pG),level:Ga.valid(Rl.NOTIFY,Rl.FATAL,Rl.ERROR,Rl.WARN,Rl.INFO,Rl.DEBUG,Rl.TRACE),order:Ga.valid("asc","desc"),limit:Ga.number().min(1),start:Ga.number().min(0),log_name:Ga.custom(Poe)});function pG(e,t){if(_G(e,_G.ISO_8601).format(woe)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(pG,"validateDatetime");function Poe(e,t){if(Noe.invert(Tp.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=yoe.get(Tp.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?Tp.LOG_NAMES.HDB:e,i=s===Tp.LOG_NAMES.INSTALL?IN.join(Ioe,Tp.LOG_NAMES.INSTALL):IN.join(n,s);return Ooe.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(Poe,"validateReadLogPath")});var PN=I((RDe,gG)=>{"use strict";var jg=(H(),P(G)),Doe=W(),Loe=ce(),Moe=mG(),CN=require("path"),EG=require("fs-extra"),{once:voe}=require("events"),{handleHDBError:Uoe,hdb_errors:xoe}=pe(),{PACKAGE_ROOT:Boe}=st(),Hoe=CN.join(Boe,"logs"),koe=1e3,Foe=200;gG.exports=Goe;async function Goe(e){let t=Moe(e);if(t)throw Uoe(t,t.message,xoe.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=Loe.get(jg.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?jg.LOG_NAMES.HDB:e.log_name,s=n===jg.LOG_NAMES.INSTALL?CN.join(Hoe,jg.LOG_NAMES.INSTALL):CN.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,l=c?new Date(e.from):void 0,u=e.until!==void 0,f=u?new Date(e.until):void 0,d=e.limit===void 0?koe:e.limit,p=e.order===void 0?void 0:e.order,_=e.start===void 0?0:e.start,h=_+d,S=0;p==="desc"&&!l&&!f&&(S=Math.max(EG.statSync(s).size-(h+5)*Foe,0));let g=EG.createReadStream(s,{start:S});g.on("error",F=>{Doe.error(F)});let R=0,E=[],A="",N;g.on("data",F=>{let $=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;F=A+F;let Y=0,ee;for(;(ee=$.exec(F))&&!g.destroyed;){N&&(N.message=F.slice(Y,ee.index),v(N));let[oe,j,se]=ee,z=se.split("] ["),me=z[0],Ae=z[1];z.splice(0,2),N={timestamp:j,thread:me,level:Ae,tags:z,message:""},Y=ee.index+oe.length}A=F.slice(Y)}),g.on("end",F=>{g.destroyed||N&&(N.message=A.trim(),v(N))}),g.resume();function v(F){let $,Y,ee;switch(!0){case(i&&c&&u):$=new Date(F.timestamp),Y=new Date(l),ee=new Date(f),F.level===o&&$>=Y&&$<=ee&&R<_?R++:F.level===o&&$>=Y&&$<=ee&&(qa(F,p,E),R++,R===h&&g.destroy());break;case(i&&c):$=new Date(F.timestamp),Y=new Date(l),F.level===o&&$>=Y&&R<_?R++:F.level===o&&$>=Y&&(qa(F,p,E),R++,R===h&&g.destroy());break;case(i&&u):$=new Date(F.timestamp),ee=new Date(f),F.level===o&&$<=ee&&R<_?R++:F.level===o&&$<=ee&&(qa(F,p,E),R++,R===h&&g.destroy());break;case(c&&u):$=new Date(F.timestamp),Y=new Date(l),ee=new Date(f),$>=Y&&$<=ee&&R<_?R++:$>=Y&&$<=ee&&(qa(F,p,E),R++,R===h&&g.destroy());break;case i:F.level===o&&R<_?R++:F.level===o&&(qa(F,p,E),R++,R===h&&g.destroy());break;case c:$=new Date(F.timestamp),Y=new Date(l),$>=Y&&R<_?R++:$>=Y&&R>=_&&(qa(F,p,E),R++,R===h&&g.destroy());break;case u:$=new Date(F.timestamp),ee=new Date(f),$<=ee&&R<_?R++:$<=ee&&R>=_&&(qa(F,p,E),R++,R===h&&g.destroy());break;default:R<_?R++:(qa(F,p,E),R++,R===h&&g.destroy())}}return a(v,"onLogMessage"),await voe(g,"close"),E}a(Goe,"readLog");function qa(e,t,r){t==="desc"?qoe(e,r):t==="asc"?$oe(e,r):r.push(e)}a(qa,"pushLineToResult");function qoe(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(qoe,"insertDescending");function $oe(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($oe,"insertAscending")});var Jg=I((IDe,RG)=>{"use strict";var DN=require("joi"),{string:Ed,boolean:SG,date:Voe}=DN.types(),Koe=it(),{validateSchemaExists:bDe,validateTableExists:ODe,validateSchemaName:NDe}=Li(),Yoe=(H(),P(G)),Woe=St(),TG=ce();TG.initSync();var wDe=Ed.invalid(TG.get(Yoe.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(Woe.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),AG={operation:Ed.valid("add_node","update_node","set_node_replication"),node_name:Ed.optional(),subscriptions:DN.array().items({table:Ed.optional(),schema:Ed.optional(),database:Ed.optional(),subscribe:SG.required(),publish:SG.required().custom(joe),start_time:Voe.iso()})};function zoe(e){return Koe.validateBySchema(e,DN.object(AG))}a(zoe,"addUpdateNodeValidator");function joe(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(joe,"checkForFalsy");RG.exports={addUpdateNodeValidator:zoe,validation_schema:AG}});var gd=I((PDe,yG)=>{"use strict";var LN=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},MN=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};yG.exports={Node:LN,NodeSubscription:MN}});var OG=I((LDe,bG)=>{"use strict";var Joe=(H(),P(G)).OPERATIONS_ENUM,vN=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Joe.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};bG.exports=vN});var Ap=I((vDe,NG)=>{"use strict";var UN=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},xN=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)}};NG.exports={RemotePayloadObject:UN,RemotePayloadSubscription:xN}});var IG=I((xDe,wG)=>{"use strict";var BN=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}};wG.exports=BN});var PG=I((qDe,CG)=>{"use strict";var Qoe=IG(),HDe=xt(),kDe=ft(),Xoe=W(),{getSchemaPath:FDe,getTransactionAuditStorePath:GDe}=Et(),{getDatabases:Zoe}=(De(),P(nt));CG.exports=eae;async function eae(e){let t=new Qoe;try{let r=Zoe()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats();t.schema=e.schema,t.table=e.name,t.record_count=n.entryCount,t.transaction_log_record_count=s.entryCount}catch(r){Xoe.warn(`unable to stat table dbi due to ${r}`)}return t}a(eae,"lmdbGetTableSize")});var LG=I((VDe,DG)=>{"use strict";var HN=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}};DG.exports=HN});var Do=I((JDe,xG)=>{"use strict";var tae=require("fs-extra"),rae=require("path"),Zr=require("systeminformation"),$a=W(),MG=ir(),YDe=St(),Sd=(H(),P(G)),nae=PG(),sae=So(),{getThreadInfo:vG}=rt(),Rp=ce();Rp.initSync();var iae=LG(),{openEnvironment:WDe}=ft(),{getSchemaPath:zDe}=Et(),{database:jDe,databases:kN}=(De(),P(nt)),Qg;xG.exports={getHDBProcessInfo:$N,getNetworkInfo:KN,getDiskInfo:VN,getMemoryInfo:qN,getCPUInfo:GN,getTimeInfo:FN,getSystemInformation:YN,systemInformation:oae,getTableSize:WN,getMetrics:zN};function FN(){return Zr.time()}a(FN,"getTimeInfo");async function GN(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:u,...f}=await Zr.cpu();f.cpu_speed=await Zr.cpuCurrentSpeed();let{raw_currentload:d,raw_currentload_idle:p,raw_currentload_irq:_,raw_currentload_nice:h,raw_currentload_system:S,raw_currentload_user:g,cpus:R,...E}=await Zr.currentLoad();return E.cpus=[],R.forEach(A=>{let{raw_load:N,raw_load_idle:v,raw_load_irq:F,raw_load_nice:$,raw_load_system:Y,raw_load_user:ee,...oe}=A;E.cpus.push(oe)}),f.current_load=E,f}catch(e){return $a.error(`error in getCPUInfo: ${e}`),{}}}a(GN,"getCPUInfo");async function qN(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Zr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return $a.error(`error in getMemoryInfo: ${e}`),{}}}a(qN,"getMemoryInfo");async function $N(){let e={core:[],clustering:[]};try{let t=await Zr.processes(),r;try{r=Number.parseInt(await tae.readFile(rae.join(Rp.get(Sd.CONFIG_PARAMS.ROOTPATH),Sd.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Sd.NODE_ERROR_CODES.ENOENT)$a.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 $a.error(`error in getHDBProcessInfo: ${t}`),e}}a($N,"getHDBProcessInfo");async function VN(){let e={};try{if(!Rp.get(Sd.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Zr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...u}=await Zr.fsStats();return e.read_write=u,e.size=await Zr.fsSize(),e}catch(t){return $a.error(`error in getDiskInfo: ${t}`),e}}a(VN,"getDiskInfo");async function KN(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return Rp.get(Sd.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await Zr.networkInterfaceDefault(),e.latency=await Zr.inetChecksite("google.com"),(await Zr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:u,ieee8021xState:f,carrier_changes:d,...p}=n;e.interfaces.push(p)}),(await Zr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)})),e}catch(t){return $a.error(`error in getNetworkInfo: ${t}`),e}}a(KN,"getNetworkInfo");async function YN(){if(Qg!==void 0)return Qg;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Zr.osInfo();e=c;let l=await Zr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,Qg=e,Qg}catch(t){return $a.error(`error in getSystemInformation: ${t}`),e}}a(YN,"getSystemInformation");async function WN(){let e=[],t=await sae.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await nae(n));return e}a(WN,"getTableSize");async function zN(){let e={};for(let t in kN){let r=e[t]={},n=r.tables={};for(let s in kN[t])try{let i=kN[t][s];if(!r.readers&&(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[u,f,d]=l.trim().split(" ");return{pid:u,thread:f,txnid:d}}),i.auditStore)){let{treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:f,entryCount:d,overflowPages:p}=i.auditStore.getStats();r.audit={treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:f,entryCount:d,overflowPages:p}}let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){$a.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(zN,"getMetrics");async function UG(){if(Rp.get(Sd.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await MG.getNATSReferences(),t=await MG.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(UG,"getNatsStreamInfo");async function oae(e){let t=new iae;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await YN(),t.time=FN(),t.cpu=await GN(),t.memory=await qN(),t.disk=await VN(),t.network=await KN(),t.harperdb_processes=await $N(),t.table_size=await WN(),t.metrics=await zN(),t.threads=await vG(),t.replication=await UG(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await YN();break;case"time":t.time=FN();break;case"cpu":t.cpu=await GN();break;case"memory":t.memory=await qN();break;case"disk":t.disk=await VN();break;case"network":t.network=await KN();break;case"harperdb_processes":t.harperdb_processes=await $N();break;case"table_size":t.table_size=await WN();break;case"database_metrics":case"metrics":t.metrics=await zN();break;case"threads":t.threads=await vG();break;case"replication":t.replication=await UG();break;default:break}return t}a(oae,"systemInformation")});var Lo=I((tLe,FG)=>{"use strict";var aae=bn(),jN=ae(),cae=require("util"),yl=(H(),P(G)),BG=ce();BG.initSync();var lae=IO(),HG=Wr(),{Node:XDe,NodeSubscription:ZDe}=gd(),uae=Gu(),dae=OG(),{RemotePayloadObject:fae,RemotePayloadSubscription:_ae}=Ap(),{handleHDBError:pae,hdb_errors:hae}=pe(),{HTTP_STATUS_CODES:mae,HDB_ERROR_MSGS:Eae}=hae,gae=si(),Sae=Do(),{packageJson:Tae}=st(),{getDatabases:Aae}=(De(),P(nt)),eLe=cae.promisify(lae.authorize),Rae=HG.searchByHash,yae=HG.searchByValue;FG.exports={isEmpty:bae,getNodeRecord:Oae,upsertNodeRecord:Nae,buildNodePayloads:wae,checkClusteringEnabled:Iae,getAllNodeRecords:Cae,getSystemInfo:Pae,reverseSubscription:kG};function bae(e){return e==null}a(bae,"isEmpty");async function Oae(e){let t=new uae(yl.SYSTEM_SCHEMA_NAME,yl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return Rae(t)}a(Oae,"getNodeRecord");async function Nae(e){let t=new dae(yl.SYSTEM_SCHEMA_NAME,yl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return aae.upsert(t)}a(Nae,"upsertNodeRecord");function kG(e){if(jN.isEmpty(e.subscribe)||jN.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(kG,"reverseSubscription");function wae(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:u}=c,f=jN.getTableHashAttribute(l,u),{subscribe:d,publish:p}=kG(c),_=Aae()[l]?.[u],h=new _ae(l,u,f,p,d,c.start_time,_.schemaDefined?_.attributes:void 0);s.push(h)}return new fae(r,t,s,n)}a(wae,"buildNodePayloads");function Iae(){if(!BG.get(yl.CONFIG_PARAMS.CLUSTERING_ENABLED))throw pae(new Error,Eae.CLUSTERING_NOT_ENABLED,mae.BAD_REQUEST,void 0,void 0,!0)}a(Iae,"checkClusteringEnabled");async function Cae(){let e=new gae(yl.SYSTEM_SCHEMA_NAME,yl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await yae(e))}a(Cae,"getAllNodeRecords");async function Pae(){let e=await Sae.getSystemInformation();return{hdb_version:Tae.version,node_version:e.node_version,platform:e.platform}}a(Pae,"getSystemInfo")});var JN=I((nLe,zG)=>{"use strict";var Xg=ir(),GG=ae(),qG=St(),$G=(H(),P(G)),Zg=W(),VG=Yg(),Dae=U_(),{RemotePayloadObject:Lae}=Ap(),{handleHDBError:KG,hdb_errors:Mae}=pe(),{HTTP_STATUS_CODES:YG}=Mae,{NodeSubscription:WG}=gd();zG.exports=vae;async function vae(e,t){let r;try{r=await Xg.request(`${t}.${qG.REQUEST_SUFFIX}`,new Lae($G.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),Zg.trace("Response from remote describe all request:",r)}catch(o){Zg.error(`addNode received error from describe all request to remote node: ${o}`);let c=Xg.requestErrorHandler(o,"add_node",t);throw KG(new Error,c,YG.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===qG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw KG(new Error,o,YG.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===$G.SYSTEM_SCHEMA_NAME){await Xg.createLocalTableStream(l,c);let h=new WG(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let u=GG.doesSchemaExist(l),f=n[l]!==void 0,d=c?GG.doesTableExist(l,c):!0,p=c?n?.[l]?.[c]!==void 0:!0;if(!u&&!f||!d&&!p){s.push(o);continue}if(!u&&f&&(Zg.trace(`addNode creating schema: ${l}`),await VG.createSchema({operation:"create_schema",schema:l})),!d&&p){Zg.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new Dae(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await VG.createTable(h)}await Xg.createLocalTableStream(l,c);let _=new WG(l,c,o.publish,o.subscribe);_.start_time=o.start_time,i.push(_)}return{added:i,skipped:s}}a(vae,"reviewSubscriptions")});var bl={};Ue(bl,{addNodeBack:()=>kae,removeNodeBack:()=>Fae,setNode:()=>Hae});async function Hae(e){e.node_name&&!e.hostname&&(e.hostname=e.node_name),e.verify_tls!==void 0&&(e.rejectUnauthorized=e.verify_tls);let{url:t,hostname:r}=e;t?r||(r=e.hostname=ci(t)):t=Gg(r);let n=(0,JG.validateBySchema)(e,Bae);if(n)throw(0,Mo.handleHDBError)(n,n.message,xae.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new Mo.ClientError("url or hostname is required for remove_node operation");let _=r,h=or(),S=await h.get(_);if(!S)throw new Mo.ClientError(_+" does not exist");try{await Ep({url:S.url},{operation:Kt.REMOVE_NODE_BACK,name:S?.subscriptions?.length>0?Ze():_},void 0)}catch(g){ts.warn(`Error removing node from target node ${_}, if it is offline and we be online in the future, you may need to clean up this node manually, or retry:`,g)}return await h.delete(_),`Successfully removed '${_}' from cluster`}if(!t)throw new Mo.ClientError("url required for this operation");let s=Ma();if(s==null)throw new Mo.ClientError("replication url is missing from harperdb-config.yaml");let i,o,c;if(t?.startsWith("wss:")){i=await(0,ws.getReplicationCert)();let _=await(0,ws.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,ws.createCsr)(),ts.info("Sending CSR to target node:",t)):_&&(c=_.certificate,ts.info("Sending CA named",_.name,"to target node",t))}let l={operation:Kt.ADD_NODE_BACK,hostname:(0,Ka.get)(x.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:o,cert_auth:c,authorization:e.retain_authorization?e.authorization:null};if((0,Ka.get)(x.REPLICATION_SHARD)!==void 0&&(l.shard=(0,Ka.get)(x.REPLICATION_SHARD)),e.subscriptions?l.subscriptions=e.subscriptions.map(jG):l.subscriptions=null,e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let _=jG(e);l.subscribe=_.subscribe,l.publish=_.publish}e?.authorization?.username&&e?.authorization?.password&&(e.authorization="Basic "+Buffer.from(e.authorization.username+":"+e.authorization.password).toString("base64"));let u,f;try{u=await Ep({url:t},l,e)}catch(_){_.message=`Error returned from ${t}: `+_.message,ts.warn("Error adding node:",t,"to cluster:",_),f=_}if(o&&(!u?.certificate||!u?.certificate?.includes?.("BEGIN CERTIFICATE")))throw f?(f.message+=" and connection was required to sign certificate",f):new Error(`Unexpected certificate signature response from node ${t} response: ${JSON.stringify(u)}`);o&&(ts.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,ws.setCertTable)({name:Uae.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,ws.setCertTable)({name:Ze(),uses:["https","operations","wss"],certificate:u.certificate,private_key_name:i?.options?.key_file,is_authority:!1,is_self_signed:!1}),c=u.signingCA);let d={url:t,ca:u?.usingCA};if(e.hostname&&(d.name=e.hostname),e.subscriptions?d.subscriptions=e.subscriptions:d.replicates=!0,e.start_time&&(d.start_time=typeof e.start_time=="string"?new Date(e.start_time).getTime():e.start_time),e.retain_authorization&&(d.authorization=e.authorization),e.revoked_certificates&&(d.revoked_certificates=e.revoked_certificates),e.shard!==void 0&&(d.shard=e.shard),d.replicates){let _={url:s,ca:c,replicates:!0,subscriptions:null};(0,Ka.get)(x.REPLICATION_SHARD)!==void 0&&(_.shard=(0,Ka.get)(x.REPLICATION_SHARD)),e.retain_authorization&&(_.authorization=e.authorization),e.start_time&&(_.start_time=e.start_time),await No(Ze(),_)}await No(u?u.nodeName:d.name??ci(t),d);let p;return e.operation==="update_node"?p=`Successfully updated '${t}'`:p=`Successfully added '${t}' to cluster`,f&&(p+=" but there was an error updating target node: "+f.message),p}async function kae(e){ts.trace("addNodeBack received request:",e);let t=await(0,ws.signCertificate)(e),r;e.csr?(r=t.signingCA,ts.info("addNodeBack received CSR from node:",e.url,"this node will use and respond with CA that was used to issue CSR")):(r=e?.cert_auth,ts.info("addNodeBack received CA from node:",e.url));let n={url:e.url,ca:r};e.subscriptions?n.subscriptions=e.subscriptions:(n.replicates=!0,n.subscriptions=null),e.start_time&&(n.start_time=e.start_time),e.authorization&&(n.authorization=e.authorization),e.shard!==void 0&&(n.shard=e.shard);let s=await(0,ws.getReplicationCertAuth)();if(n.replicates){let i={url:Ma(),ca:s?.certificate,replicates:!0,subscriptions:null};(0,Ka.get)(x.REPLICATION_SHARD)!==void 0&&(i.shard=(0,Ka.get)(x.REPLICATION_SHARD)),e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await No(Ze(),i)}return await No(e.hostname,n),t.nodeName=Ze(),t.usingCA=s?.certificate,ts.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function Fae(e){ts.trace("removeNodeBack received request:",e),await or().delete(e.name)}function jG(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var ws,JG,Va,Ka,ts,Mo,Uae,xae,Bae,Ol=be(()=>{ws=M(es()),JG=M(it()),Va=M(require("joi")),Ka=M(ce());H();up();hl();Zn();ts=M(W()),Mo=M(pe()),{pki:Uae}=require("node-forge"),{HTTP_STATUS_CODES:xae}=Mo.hdb_errors,Bae=Va.default.object({hostname:Va.default.string(),verify_tls:Va.default.boolean(),replicates:Va.default.boolean(),subscriptions:Va.default.array(),revoked_certificates:Va.default.array(),shard:Va.default.number()});a(Hae,"setNode");a(kae,"addNodeBack");a(Fae,"removeNodeBack");a(jG,"reverseSubscription")});var Td=I((fLe,XG)=>{"use strict";var{handleHDBError:eS,hdb_errors:Gae}=pe(),{HTTP_STATUS_CODES:tS}=Gae,{addUpdateNodeValidator:qae}=Jg(),rS=W(),nS=(H(),P(G)),QG=St(),$ae=ae(),yp=ir(),bp=Lo(),QN=ce(),Vae=JN(),{Node:Kae,NodeSubscription:Yae}=gd(),{broadcast:Wae}=rt(),{setNode:zae}=(Ol(),P(bl)),uLe=ce(),dLe=(H(),P(G)),jae="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",Jae="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Qae=QN.get(nS.CONFIG_PARAMS.CLUSTERING_NODENAME);XG.exports=Xae;async function Xae(e,t=!1){if(rS.trace("addNode called with:",e),QN.get(nS.CONFIG_PARAMS.REPLICATION_URL)||QN.get(nS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return zae(e);bp.checkClusteringEnabled();let r=qae(e);if(r)throw eS(r,r.message,tS.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await bp.getNodeRecord(n);if(!$ae.isEmptyOrZeroLength(d))throw eS(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,tS.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await Vae(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=jae,o;let c=bp.buildNodePayloads(s,Qae,nS.OPERATIONS_ENUM.ADD_NODE,await bp.getSystemInfo()),l=[];for(let d=0,p=s.length;d<p;d++){let _=s[d];s[d].start_time===void 0&&delete s[d].start_time,l.push(new Yae(_.schema,_.table,_.publish,_.subscribe))}rS.trace("addNode sending remote payload:",c);let u;try{u=await yp.request(`${n}.${QG.REQUEST_SUFFIX}`,c)}catch(d){rS.error(`addNode received error from request: ${d}`);for(let _=0,h=s.length;_<h;_++){let S=s[_];S.publish=!1,S.subscribe=!1,await yp.updateRemoteConsumer(S,n)}let p=yp.requestErrorHandler(d,"add_node",n);throw eS(new Error,p,tS.INTERNAL_SERVER_ERROR,"error",p)}if(u.status===QG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${n}: ${u.message}`;throw eS(new Error,d,tS.INTERNAL_SERVER_ERROR,"error",d)}rS.trace(u);for(let d=0,p=s.length;d<p;d++){let _=s[d];await yp.updateRemoteConsumer(_,n),_.subscribe===!0&&await yp.updateConsumerIterator(_.schema,_.table,n,"start")}let f=new Kae(n,l,u.system_info);return await bp.upsertNodeRecord(f),Wae({type:"nats_update"}),i.length>0?o.message=Jae:o.message=`Successfully added '${n}' to manifest`,o}a(Xae,"addNode")});var tw=I((hLe,eq)=>{"use strict";var{handleHDBError:XN,hdb_errors:Zae}=pe(),{HTTP_STATUS_CODES:ZN}=Zae,{addUpdateNodeValidator:ece}=Jg(),Op=W(),sS=(H(),P(G)),ZG=St(),pLe=ae(),Np=ir(),wp=Lo(),ew=ce(),{cloneDeep:tce}=require("lodash"),rce=JN(),{Node:nce,NodeSubscription:sce}=gd(),{broadcast:ice}=rt(),{setNode:oce}=(Ol(),P(bl)),ace="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",cce="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",lce=ew.get(sS.CONFIG_PARAMS.CLUSTERING_NODENAME);eq.exports=uce;async function uce(e){if(Op.trace("updateNode called with:",e),ew.get(sS.CONFIG_PARAMS.REPLICATION_URL)??ew.get(sS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return oce(e);wp.checkClusteringEnabled();let t=ece(e);if(t)throw XN(t,t.message,ZN.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await wp.getNodeRecord(r);s.length>0&&(n=tce(s));let{added:i,skipped:o}=await rce(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=ace,c;let l=wp.buildNodePayloads(i,lce,sS.OPERATIONS_ENUM.UPDATE_NODE,await wp.getSystemInfo());for(let f=0,d=i.length;f<d;f++){let p=i[f];Op.trace(`updateNode updating work stream for node: ${r} subscription:`,p),i[f].start_time===void 0&&delete i[f].start_time}Op.trace("updateNode sending remote payload:",l);let u;try{u=await Np.request(`${r}.${ZG.REQUEST_SUFFIX}`,l)}catch(f){Op.error(`updateNode received error from request: ${f}`);let d=Np.requestErrorHandler(f,"update_node",r);throw XN(new Error,d,ZN.INTERNAL_SERVER_ERROR,"error",d)}if(u.status===ZG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let f=`Error returned from remote node ${r}: ${u.message}`;throw XN(new Error,f,ZN.INTERNAL_SERVER_ERROR,"error",f)}Op.trace(u);for(let f=0,d=i.length;f<d;f++){let p=i[f];await Np.updateRemoteConsumer(p,r),p.subscribe===!0?await Np.updateConsumerIterator(p.schema,p.table,r,"start"):await Np.updateConsumerIterator(p.schema,p.table,r,"stop")}return n||(n=[new nce(r,[],u.system_info)]),await dce(n[0],i,u.system_info),o.length>0?c.message=cce:c.message=`Successfully updated '${r}'`,c}a(uce,"updateNode");async function dce(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let l=0,u=e.subscriptions.length;l<u;l++){let f=n.subscriptions[l];if(f.schema===o.schema&&f.table===o.table){f.publish=o.publish,f.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new sce(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await wp.upsertNodeRecord(n),ice({type:"nats_update"})}a(dce,"updateNodeTable")});var iq=I((ELe,sq)=>{"use strict";var nq=require("joi"),{string:tq}=nq.types(),fce=it(),rq=(H(),P(G)),_ce=ce(),pce=St();sq.exports=hce;function hce(e){let t=tq.invalid(_ce.get(rq.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(pce.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=nq.object({operation:tq.valid(rq.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return fce.validateBySchema(e,r)}a(hce,"removeNodeValidator")});var iS=I((SLe,uq)=>{"use strict";var{handleHDBError:oq,hdb_errors:mce}=pe(),{HTTP_STATUS_CODES:aq}=mce,Ece=iq(),Ip=W(),cq=Lo(),gce=ae(),Ad=(H(),P(G)),lq=St(),rw=ir(),nw=ce(),{RemotePayloadObject:Sce}=Ap(),{NodeSubscription:Tce}=gd(),Ace=v_(),Rce=jc(),{broadcast:yce}=rt(),{setNode:bce}=(Ol(),P(bl)),Oce=nw.get(Ad.CONFIG_PARAMS.CLUSTERING_NODENAME);uq.exports=Nce;async function Nce(e){if(Ip.trace("removeNode called with:",e),nw.get(Ad.CONFIG_PARAMS.REPLICATION_URL)??nw.get(Ad.CONFIG_PARAMS.REPLICATION_HOSTNAME))return bce(e);cq.checkClusteringEnabled();let t=Ece(e);if(t)throw oq(t,t.message,aq.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await cq.getNodeRecord(r);if(gce.isEmptyOrZeroLength(n))throw oq(new Error,`Node '${r}' was not found.`,aq.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new Sce(Ad.OPERATIONS_ENUM.REMOVE_NODE,Oce,[]),i,o=!1;for(let l=0,u=n.subscriptions.length;l<u;l++){let f=n.subscriptions[l];f.subscribe===!0&&await rw.updateConsumerIterator(f.schema,f.table,r,"stop");try{await rw.updateRemoteConsumer(new Tce(f.schema,f.table,!1,!1),r)}catch(d){Ip.error(d)}}try{i=await rw.request(`${r}.${lq.REQUEST_SUFFIX}`,s),Ip.trace("Remove node reply from remote node:",r,i)}catch(l){Ip.error("removeNode received error from request:",l),o=!0}let c=new Ace(Ad.SYSTEM_SCHEMA_NAME,Ad.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Rce.deleteRecord(c),yce({type:"nats_update"}),i?.status===lq.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(Ip.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(Nce,"removeNode")});var _q=I((ALe,fq)=>{"use strict";var dq=require("joi"),{string:wce,array:Ice}=dq.types(),Cce=it(),Pce=Jg();fq.exports=Dce;function Dce(e){let t=dq.object({operation:wce.valid("configure_cluster").required(),connections:Ice.items(Pce.validation_schema).required()});return Cce.validateBySchema(e,t)}a(Dce,"configureClusterValidator")});var sw=I((yLe,gq)=>{"use strict";var pq=(H(),P(G)),oS=W(),Lce=ae(),Mce=ce(),vce=iS(),Uce=Td(),xce=Lo(),Bce=_q(),{handleHDBError:hq,hdb_errors:Hce}=pe(),{HTTP_STATUS_CODES:mq}=Hce,kce="Configure cluster complete.",Fce="Failed to configure the cluster. Check the logs for more details.",Gce="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";gq.exports=qce;async function qce(e){oS.trace("configure cluster called with:",e);let t=Bce(e);if(t)throw hq(t,t.message,mq.BAD_REQUEST,void 0,void 0,!0);let r=await xce.getAllNodeRecords(),n=[];if(Mce.get(pq.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let f=0,d=r.length;f<d;f++){let p=await Eq(vce,{operation:pq.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[f].name},r[f].name);n.push(p)}oS.trace("All results from configure_cluster remove node:",n)}let s=[],i=e.connections.length;for(let f=0;f<i;f++){let d=e.connections[f],p=await Eq(Uce,d,d.node_name);s.push(p)}oS.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,u=n.concat(s);for(let f=0,d=u.length;f<d;f++){let p=u[f];p.status==="rejected"&&(oS.error(p.node_name,p?.error?.message,p?.error?.stack),o.includes(p.node_name)||o.push(p.node_name)),(p?.result?.message?.includes?.("Successfully")||p?.result?.includes?.("Successfully"))&&(l=!0),!(typeof p.result=="string"&&p.result.includes("Successfully removed")||p.status==="rejected")&&c.push({node_name:p?.node_name,response:p?.result})}if(Lce.isEmptyOrZeroLength(o))return{message:kce,connections:c};if(l)return{message:Gce,failed_nodes:o,connections:c};throw hq(new Error,Fce,mq.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(qce,"configureCluster");async function Eq(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(Eq,"functionWrapper")});var Rq=I((OLe,Aq)=>{"use strict";var Cp=require("joi"),$ce=it(),{validateSchemaExists:Sq,validateTableExists:Vce,validateSchemaName:Tq}=Li(),Kce=Cp.object({operation:Cp.string().valid("purge_stream"),schema:Cp.string().custom(Sq).custom(Tq).optional(),database:Cp.string().custom(Sq).custom(Tq).optional(),table:Cp.string().custom(Vce).required()});function Yce(e){return $ce.validateBySchema(e,Kce)}a(Yce,"purgeStreamValidator");Aq.exports=Yce});var iw=I((wLe,yq)=>{"use strict";var{handleHDBError:Wce,hdb_errors:zce}=pe(),{HTTP_STATUS_CODES:jce}=zce,Jce=Rq(),Qce=ir(),Xce=Lo();yq.exports=Zce;async function Zce(e){e.schema=e.schema??e.database;let t=Jce(e);if(t)throw Wce(t,t.message,jce.BAD_REQUEST,void 0,void 0,!0);Xce.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await Qce.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(Zce,"purgeStream")});var lS=I((CLe,Pq)=>{"use strict";var aw=Lo(),ele=ir(),cS=ce(),Rd=(H(),P(G)),Nl=St(),tle=ae(),ow=W(),{RemotePayloadObject:rle}=Ap(),{ErrorCode:bq}=require("nats"),{parentPort:Oq}=require("worker_threads"),{onMessageByType:nle}=rt(),{getThisNodeName:sle}=(Zn(),P(Io)),{requestClusterStatus:ile}=(up(),P(jk)),{getReplicationSharedStatus:ole,getHDBNodeTable:ale}=(hl(),P(JO)),{CONFIRMATION_STATUS_POSITION:cle,RECEIVED_VERSION_POSITION:lle,RECEIVED_TIME_POSITION:ule,SENDING_TIME_POSITION:dle}=(SN(),P(BF)),Nq=cS.get(Rd.CONFIG_PARAMS.CLUSTERING_ENABLED),wq=cS.get(Rd.CONFIG_PARAMS.CLUSTERING_NODENAME);Pq.exports={clusterStatus:fle,buildNodeStatus:Cq};var Iq;nle("cluster-status",async e=>{Iq(e)});async function fle(){if(cS.get(Rd.CONFIG_PARAMS.REPLICATION_URL)||cS.get(Rd.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;if(Oq){Oq.postMessage({type:"request-cluster-status"}),n=await new Promise(i=>{Iq=i});for(let i of n.connections){let o=i.name;for(let c of i.database_sockets){let l=c.database,u;for(let d of Object.values(databases[l]||{}))if(u=d.auditStore,u)break;if(!u)continue;let f=ole(u,l,o);c.lastCommitConfirmed=aS(f[cle]),c.lastReceivedRemoteTime=aS(f[lle]),c.lastReceivedLocalTime=aS(f[ule]),c.sendingMessage=aS(f[dle])}}}else n=ile();n.node_name=sle();let s=ale().primaryStore.get(n.node_name);return s?.shard&&(n.shard=s.shard),s?.url&&(n.url=s.url),n.is_enabled=!0,n}let e={node_name:wq,is_enabled:Nq,connections:[]};if(!Nq)return e;let t=await aw.getAllNodeRecords();if(tle.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(Cq(t[n],e.connections));return await Promise.allSettled(r),e}a(fle,"clusterStatus");function aS(e){return e?e===1?"Copying":new Date(e).toUTCString():void 0}a(aS,"asDate");async function Cq(e,t){let r=e.name,n=new rle(Rd.OPERATIONS_ENUM.CLUSTER_STATUS,wq,void 0,await aw.getSystemInfo()),s,i,o=Nl.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await ele.request(Nl.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Nl.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=Nl.CLUSTER_STATUS_STATUSES.CLOSED,ow.error(`Error getting node status from ${r} `,s))}catch(l){ow.warn(`Error getting node status from ${r}`,l),l.code===bq.NoResponders?o=Nl.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===bq.Timeout?o=Nl.CLUSTER_STATUS_STATUSES.TIMEOUT:o=Nl.CLUSTER_STATUS_STATUSES.CLOSED}let c=new _le(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!==Rd.PRE_4_0_0_VERSION&&await aw.upsertNodeRecord(l)}catch(l){ow.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(Cq,"buildNodeStatus");function _le(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(_le,"NodeStatusObject")});var dS=I((DLe,Dq)=>{"use strict";var{handleHDBError:ple,hdb_errors:hle}=pe(),{HTTP_STATUS_CODES:mle}=hle,Ele=ir(),gle=Lo(),cw=ae(),uS=require("joi"),Sle=it(),Tle=2e3,Ale=uS.object({timeout:uS.number().min(1),connected_nodes:uS.boolean(),routes:uS.boolean()});Dq.exports=Rle;async function Rle(e){gle.checkClusteringEnabled();let t=Sle.validateBySchema(e,Ale);if(t)throw ple(t,t.message,mle.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||cw.autoCastBoolean(n),o=s===void 0||cw.autoCastBoolean(s),c={nodes:[]},l=await Ele.getServerList(r??Tle),u={};if(i)for(let f=0,d=l.length;f<d;f++){let p=l[f].statsz;p&&(u[l[f].server.name]=p.routes)}for(let f=0,d=l.length;f<d;f++){if(l[f].statsz)continue;let p=l[f].server,_=l[f].data;if(p.name.endsWith("-hub")){let h={name:p.name.slice(0,-4),response_time:l[f].response_time};i&&(h.connected_nodes=[],u[p.name]&&u[p.name].forEach(S=>{h.connected_nodes.includes(S.name.slice(0,-4))||h.connected_nodes.push(S.name.slice(0,-4))})),o&&(h.routes=_.cluster?.urls?_.cluster?.urls.map(S=>({host:S.split(":")[0],port:cw.autoCast(S.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(Rle,"clusterNetwork")});var Uq=I((MLe,vq)=>{"use strict";var lw=require("joi"),Lq=it(),{route_constraints:Mq}=Wy();vq.exports={setRoutesValidator:yle,deleteRoutesValidator:ble};function yle(e){let t=lw.object({server:lw.valid("hub","leaf"),routes:Mq.required()});return Lq.validateBySchema(e,t)}a(yle,"setRoutesValidator");function ble(e){let t=lw.object({routes:Mq.required()});return Lq.validateBySchema(e,t)}a(ble,"deleteRoutesValidator")});var fS=I((ULe,qq)=>{"use strict";var vo=Rt(),uw=ae(),Is=(H(),P(G)),yd=ce(),xq=Uq(),{handleHDBError:Bq,hdb_errors:Ole}=pe(),{HTTP_STATUS_CODES:Hq}=Ole,kq="cluster routes successfully set",Fq="cluster routes successfully deleted";qq.exports={setRoutes:wle,getRoutes:Ile,deleteRoutes:Cle};function Nle(e){let t=vo.getClusteringRoutes(),r=e.server==="hub"?t.hub_routes:t.leaf_routes,n=e.server==="hub"?t.leaf_routes:t.hub_routes,s=[],i=[];for(let o=0,c=e.routes.length;o<c;o++){let l=e.routes[o];l.port=uw.autoCast(l.port);let u=r.some(d=>d.host===l.host&&d.port===l.port),f=n.some(d=>d.host===l.host&&d.port===l.port);u||f?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?vo.updateConfigValue(Is.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):vo.updateConfigValue(Is.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:kq,set:i,skipped:s}}a(Nle,"setRoutesNats");function wle(e){let t=xq.setRoutesValidator(e);if(t)throw Bq(t,t.message,Hq.BAD_REQUEST,void 0,void 0,!0);if(yd.get(Is.CONFIG_PARAMS.CLUSTERING_ENABLED))return Nle(e);let r=[],n=[],s=yd.get(Is.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{Gq(s,i)?n.push(i):(s.push(i),r.push(i))}),vo.updateConfigValue(Is.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:kq,set:r,skipped:n}}a(wle,"setRoutes");function Gq(e,t){return typeof t=="string"?e.includes(t):typeof t=="object"&&t!==null?e.some(r=>(r.host===t.host||r.hostname===t.hostname)&&r.port===t.port):!1}a(Gq,"existsInArray");function Ile(){if(yd.get(Is.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=vo.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return yd.get(Is.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(Ile,"getRoutes");function Cle(e){let t=xq.deleteRoutesValidator(e);if(t)throw Bq(t,t.message,Hq.BAD_REQUEST,void 0,void 0,!0);if(yd.get(Is.CONFIG_PARAMS.CLUSTERING_ENABLED))return Ple(e);let r=[],n=[],s=yd.get(Is.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{Gq(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),vo.updateConfigValue(Is.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:Fq,deleted:r,skipped:n}}a(Cle,"deleteRoutes");function Ple(e){let t=vo.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],o=!1,c=!1;for(let l=0,u=e.routes.length;l<u;l++){let f=e.routes[l],d=!1;for(let p=0,_=r.length;p<_;p++){let h=r[p];if(f.host===h.host&&f.port===h.port){r.splice(p,1),d=!0,o=!0,s.push(f);break}}if(!d){let p=!0;for(let _=0,h=n.length;_<h;_++){let S=n[_];if(f.host===S.host&&f.port===S.port){n.splice(_,1),c=!0,p=!1,s.push(f);break}}p&&i.push(f)}}return o&&(r=uw.isEmptyOrZeroLength(r)?null:r,vo.updateConfigValue(Is.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=uw.isEmptyOrZeroLength(n)?null:n,vo.updateConfigValue(Is.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:Fq,deleted:s,skipped:i}}a(Ple,"deleteRoutesNats")});var Vq=I((BLe,$q)=>{"use strict";var Pp=require("alasql"),wl=require("recursive-iterator"),di=W(),Dle=ae(),Dp=(H(),P(G)),dw=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,Mle(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=>Dp.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=>!Dp.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][Dp.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=Lle(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(u=>({attribute_name:u.attribute}));let l=this.affected_attributes.get(i).get(o).filter(u=>!Dp.SEARCH_WILDCARDS.includes(u));c.forEach(({attribute_name:u})=>{let f=new Pp.yy.Column({columnid:u});s.tableid&&(f.tableid=s.tableid),this.ast.columns.push(f),l.includes(u)||l.push(u)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function Lle(e){return e.filter(t=>t[Dp.PERMS_CRUD_ENUM.READ])}a(Lle,"filterReadRestrictedAttrs");function Mle(e,t,r,n,s){vle(e,t,r,n,s)}a(Mle,"interpretAST");function Lp(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(Lp,"addSchemaTableToMap");function vle(e,t,r,n,s){if(!e){di.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Pp.yy.Insert?Hle(e,t,r):e instanceof Pp.yy.Select?Ule(e,t,r,n,s):e instanceof Pp.yy.Update?xle(e,t,r):e instanceof Pp.yy.Delete?Ble(e,t,r):di.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(vle,"getRecordAttributesAST");function Ule(e,t,r,n,s){if(!e){di.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(Dle.isEmptyOrZeroLength(i)){di.error("No schema specified");return}e.from.forEach(c=>{Lp(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),Lp(c.table,t,r,n,s)});let o=new wl(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,u=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(u).has(l))if(r.has(l))l=r.get(l);else{di.info(`table specified as ${l} not found.`);return}t.get(u).get(l).indexOf(c.columnid)<0&&t.get(u).get(l).push(c.columnid)}if(e.where){let c=new wl(e.where),l=e.from[0].tableid;for(let{node:u}of c)if(u&&u.columnid){let f=u.tableid?u.tableid:l;if(!t.get(i).has(f))if(r.has(f))f=r.get(f);else{di.info(`table specified as ${f} not found.`);continue}t.get(i).get(f).indexOf(u.columnid)<0&&t.get(i).get(f).push(u.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new wl(c.on);for(let{node:u}of l)if(u&&u.columnid){let f=u.tableid,d=s.get(f);if(!t.get(d).has(f))if(r.has(f))f=r.get(f);else{di.info(`table specified as ${f} not found.`);continue}t.get(d).get(f).indexOf(u.columnid)<0&&t.get(d).get(f).push(u.columnid)}}),e.order){let c=new wl(e.order);for(let{node:l}of c)if(l&&l.columnid){let u=l.tableid,f=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(f).has(u))if(r.has(u))u=r.get(u);else{di.info(`table specified as ${u} not found.`);return}t.get(f).get(u).indexOf(l.columnid)<0&&t.get(f).get(u).push(l.columnid)}}}a(Ule,"getSelectAttributes");function xle(e,t,r){if(!e){di.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new wl(e.columns),s=e.table.databaseid;Lp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&fw(e.table.tableid,s,i.columnid,t,r)}a(xle,"getUpdateAttributes");function Ble(e,t,r){if(!e){di.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new wl(e.where),s=e.table.databaseid;Lp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&fw(e.table.tableid,s,i.columnid,t,r)}a(Ble,"getDeleteAttributes");function Hle(e,t,r){if(!e){di.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new wl(e.columns),s=e.into.databaseid;Lp(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&fw(e.into.tableid,s,i.columnid,t,r)}a(Hle,"getInsertAttributes");function fw(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(fw,"pushAttribute");$q.exports=dw});var Yq=I((kLe,Kq)=>{"use strict";var _S=(H(),P(G)),pS=class{static{a(this,"BaseLicense")}constructor(t=0,r=_S.RAM_ALLOCATION_ENUM.DEFAULT,n=_S.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},_w=class extends pS{static{a(this,"ExtendedLicense")}constructor(t=0,r=_S.RAM_ALLOCATION_ENUM.DEFAULT,n=_S.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};Kq.exports={BaseLicense:pS,ExtendedLicense:_w}});var Nd=I((GLe,Xq)=>{"use strict";var Od=require("fs-extra"),hS=(mE(),P(hE)),zq=require("crypto"),kle=require("moment"),Fle=require("uuid").v4,en=W(),hw=require("path"),Gle=ae(),Il=(H(),P(G)),{totalmem:Wq}=require("os"),qle=Yq().ExtendedLicense,bd="invalid license key format",$le="061183",Vle="mofi25",Kle="aes-256-cbc",Yle=16,Wle=32,jq=ce(),{resolvePath:Jq}=Rt();jq.initSync();var pw;Xq.exports={validateLicense:Qq,generateFingerPrint:jle,licenseSearch:gw,getLicense:Xle,checkMemoryLimit:Zle};function mw(){return hw.join(jq.getHdbBasePath(),Il.LICENSE_KEY_DIR_NAME,Il.LICENSE_FILE_NAME)}a(mw,"getLicenseDirPath");function zle(){let e=mw();return Jq(hw.join(e,Il.LICENSE_FILE_NAME))}a(zle,"getLicenseFilePath");function Ew(){let e=mw();return Jq(hw.join(e,Il.REG_KEY_FILE_NAME))}a(Ew,"getFingerPrintFilePath");async function jle(){let e=Ew();try{return await Od.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await Jle();throw en.error(`Error writing fingerprint file to ${e}`),en.error(t),new Error("There was an error generating the fingerprint")}}a(jle,"generateFingerPrint");async function Jle(){let e=Fle(),t=hS.hash(e,hS.HASH_FUNCTION.MD5),r=Ew();try{await Od.mkdirp(mw()),await Od.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw en.error(`Error writing fingerprint file to ${r}`),en.error(n),new Error("There was an error generating the fingerprint")}return t}a(Jle,"writeFingerprint");function Qq(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:Il.RAM_ALLOCATION_ENUM.DEFAULT,version:Il.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return en.error("empty license key passed to validate."),r;let n=Ew(),s=!1;try{s=Od.statSync(n)}catch(i){en.error(i)}if(s){let i;try{i=Od.readFileSync(n,"utf8")}catch{en.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(Vle),c=o[1];c=Buffer.concat([Buffer.from(c)],Yle);let l=Buffer.concat([Buffer.from(i)],Wle),u=zq.createDecipheriv(Kle,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let f=null;try{f=u.update(o[0],"hex","utf8"),f.trim(),f+=u.final("utf8")}catch{let _=Qle(o[0],i);if(_)f=_;else throw r.valid_license=!1,r.valid_machine=!1,console.error(bd),en.error(bd),new Error(bd)}let d;if(isNaN(f))try{d=JSON.parse(f),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(bd),en.error(bd),new Error(bd)}else r.exp_date=f;r.exp_date<kle().valueOf()&&(r.valid_date=!1),hS.validate(o[1],`${$le}${i}${t}`,hS.HASH_FUNCTION.MD5)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||en.error("Invalid licence"),r}a(Qq,"validateLicense");function Qle(e,t){try{let r=zq.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{en.warn("Check old license failed")}}a(Qle,"checkOldLicense");function gw(){let e=new qle,t=[];try{t=Od.readFileSync(zle(),"utf-8").split(`\r
25
+ `)}catch(r){r.code==="ENOENT"?en.debug("no license file found"):en.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(Gle.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=Qq(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){en.error("There was an error parsing the license string."),en.error(s),e.ram_allocation=Il.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return pw=e,e}a(gw,"licenseSearch");async function Xle(){return pw||await gw(),pw}a(Xle,"getLicense");function Zle(){let e=gw().ram_allocation,t=process.constrainedMemory?.()||Wq();if(t=Math.round(Math.min(t,Wq())/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(Zle,"checkMemoryLimit")});var ES=I(($Le,r$)=>{var mS=Nd(),Zq=require("chalk"),rs=W(),e$=require("prompt"),{promisify:eue}=require("util"),Sw=(H(),P(G)),tue=require("fs-extra"),rue=require("path"),nue=ae(),{packageJson:sue}=st(),t$=ce();t$.initSync();var iue=require("moment"),oue=eue(e$.get),aue=rue.join(t$.getHdbBasePath(),Sw.LICENSE_KEY_DIR_NAME,Sw.LICENSE_FILE_NAME,Sw.LICENSE_FILE_NAME);r$.exports={getFingerprint:lue,setLicense:cue,parseLicense:Tw,register:uue,getRegistrationInfo:fue};async function cue(e){if(e&&e.key&&e.company){try{rs.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await Tw(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw rs.error(r),rs.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(cue,"setLicense");async function lue(){let e={};try{e=await mS.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw rs.error(r),rs.error(t),new Error(r)}return e}a(lue,"getFingerprint");async function Tw(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");rs.info("Validating license input...");let r=mS.validateLicense(e,t);if(rs.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(rs.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(rs.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{rs.info("writing license to disk"),await tue.writeFile(aue,JSON.stringify({license_key:e,company:t}))}catch(n){throw rs.error("Failed to write License"),n}return"Registration successful."}a(Tw,"parseLicense");async function uue(){let e=await due();return Tw(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(uue,"register");async function due(){let e=await mS.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:Zq.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:Zq.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{e$.start()}catch(n){rs.error(n)}let r;try{r=await oue(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(due,"promptForRegistration");async function fue(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await mS.getLicense()}catch(r){throw rs.error(`There was an error when searching licenses due to: ${r.message}`),r}if(nue.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=sue.version,e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=iue.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(fue,"getRegistrationInfo")});var s$=I((KLe,n$)=>{"use strict";var _ue=St(),Aw=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,u,f,d,p,_,h){this.port=t,o===null&&(o=void 0),this.server_name=r+_ue.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.reconnect_error_reports=100,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l},this.leafnodes={port:u,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:f,port:d,routes:p,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:_},HDB:{users:h}},this.system_account="SYS"}};n$.exports=Aw});var a$=I((WLe,o$)=>{"use strict";var i$=St(),Rw=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,u,f,d){this.port=t,d===null&&(d=void 0),this.server_name=r+i$.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+i$.SERVER_SUFFIX.LEAF},this.tls={cert_file:u,key_file:f,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"}};o$.exports=Rw});var l$=I((jLe,c$)=>{"use strict";var yw=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};c$.exports=yw});var d$=I((QLe,u$)=>{"use strict";var pue=St(),bw=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+pue.SERVER_SUFFIX.ADMIN,this.password=r}};u$.exports=bw});var AS=I((ZLe,p$)=>{"use strict";var Cl=require("path"),Pl=require("fs-extra"),hue=s$(),mue=a$(),Eue=l$(),gue=d$(),Ow=yn(),Id=ae(),In=Rt(),SS=(H(),P(G)),Mp=St(),{CONFIG_PARAMS:jt}=SS,Cd=W(),vp=ce(),f$=go(),Nw=ir(),Sue=es(),wd="clustering",Tue=1e4,_$=50;p$.exports={generateNatsConfig:Rue,removeNatsConfig:yue,getHubConfigPath:Aue};function Aue(){let e=vp.get(jt.ROOTPATH);return Cl.join(e,wd,Mp.NATS_CONFIG_FILES.HUB_SERVER)}a(Aue,"getHubConfigPath");async function Rue(e=!1,t=void 0){let r=vp.get(jt.ROOTPATH);Pl.ensureDirSync(Cl.join(r,"clustering","leaf")),vp.initSync();let n=In.getConfigFromFile(jt.CLUSTERING_TLS_CERT_AUTH),s=In.getConfigFromFile(jt.CLUSTERING_TLS_PRIVATEKEY),i=In.getConfigFromFile(jt.CLUSTERING_TLS_CERTIFICATE);!await Pl.exists(i)&&!await Pl.exists(!n)&&await Sue.createNatsCerts();let o=Cl.join(r,wd,Mp.PID_FILES.HUB),c=Cl.join(r,wd,Mp.PID_FILES.LEAF),l=In.getConfigFromFile(jt.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=Cl.join(r,wd,Mp.NATS_CONFIG_FILES.HUB_SERVER),f=Cl.join(r,wd,Mp.NATS_CONFIG_FILES.LEAF_SERVER),d=In.getConfigFromFile(jt.CLUSTERING_TLS_INSECURE),p=In.getConfigFromFile(jt.CLUSTERING_TLS_VERIFY),_=In.getConfigFromFile(jt.CLUSTERING_NODENAME),h=In.getConfigFromFile(jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await Nw.checkNATSServerInstalled()||TS("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let S=await Ow.listUsers(),g=In.getConfigFromFile(jt.CLUSTERING_USER),R=await Ow.getClusterUser();(Id.isEmpty(R)||R.active!==!0)&&TS(`Invalid cluster user '${g}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await gS(jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await gS(jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await gS(jt.CLUSTERING_HUBSERVER_NETWORK_PORT),await gS(jt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let E=[],A=[];for(let[oe,j]of S.entries())j.role?.role===SS.ROLE_TYPES_ENUM.CLUSTER_USER&&j.active&&(E.push(new gue(j.username,f$.decrypt(j.hash))),A.push(new Eue(j.username,f$.decrypt(j.hash))));let N=[],{hub_routes:v}=In.getClusteringRoutes();if(!Id.isEmptyOrZeroLength(v))for(let oe of v)N.push(`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@${oe.host}:${oe.port}`);let F=new hue(In.getConfigFromFile(jt.CLUSTERING_HUBSERVER_NETWORK_PORT),_,o,i,s,n,d,p,h,In.getConfigFromFile(jt.CLUSTERING_HUBSERVER_CLUSTER_NAME),In.getConfigFromFile(jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),N,E,A);n==null&&(delete F.tls.ca_file,delete F.leafnodes.tls.ca_file),t=Id.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===SS.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Pl.writeJson(u,F),Cd.trace(`Hub server config written to ${u}`));let $=`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@0.0.0.0:${h}`,Y=`tls://${R.uri_encoded_name}:${R.uri_encoded_d_hash}@0.0.0.0:${h}`,ee=new mue(In.getConfigFromFile(jt.CLUSTERING_LEAFSERVER_NETWORK_PORT),_,c,l,[$],[Y],E,A,i,s,n,d);n==null&&delete ee.tls.ca_file,(t===void 0||t===SS.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Pl.writeJson(f,ee),Cd.trace(`Leaf server config written to ${f}`))}a(Rue,"generateNatsConfig");async function gS(e){let t=vp.get(e);return Id.isEmpty(t)&&TS(`port undefined for '${e}'`),await Id.isPortTaken(t)&&TS(`'${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(gS,"isPortAvailable");function TS(e){let t=`Error generating clustering config: ${e}`;Cd.error(t),console.error(t),process.exit(1)}a(TS,"generateNatsConfigError");async function yue(e){let{port:t,config_file:r}=Nw.getServerConfig(e),{username:n,decrypt_hash:s}=await Ow.getClusterUser(),i=0,o=2e3;for(;i<_$;){try{let f=await Nw.createConnection(t,n,s,!1);if(f.protocol.connected===!0){f.close();break}}catch(f){Cd.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${f}`)}if(i++,i>=_$)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);let u=o*(i*2);u>3e4&&Cd.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await Id.async_set_timeout(u)}let c="0".repeat(Tue),l=Cl.join(vp.get(jt.ROOTPATH),wd,r);await Pl.writeFile(l,c),await Pl.remove(l),Cd.notify(e,"started.")}a(yue,"removeNatsConfig")});var T$=I((tMe,S$)=>{"use strict";var ns=ce(),bue=Nd(),Ge=(H(),P(G)),Up=St(),Uo=require("path"),{PACKAGE_ROOT:yS}=st(),h$=ce(),RS=ae(),Pd="/dev/null",Oue=Uo.join(yS,"launchServiceScripts"),m$=Uo.join(yS,"utility/scripts"),Nue=Uo.join(m$,Ge.HDB_RESTART_SCRIPT),E$=Uo.resolve(yS,"dependencies",`${process.platform}-${process.arch}`,Up.NATS_BINARY_NAME);function g$(){let t=bue.licenseSearch().ram_allocation||Ge.RAM_ALLOCATION_ENUM.DEFAULT,r=Ge.MEM_SETTING_KEY+t,n={[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return RS.noBootFile()&&(n[Ge.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=RS.getEnvCliRootPath()),{name:Ge.PROCESS_DESCRIPTORS.HDB,script:Ge.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:yS}}a(g$,"generateMainServerConfig");var wue=9930;function Iue(){ns.initSync(!0);let e=ns.get(Ge.CONFIG_PARAMS.ROOTPATH),t=Uo.join(e,"clustering",Up.NATS_CONFIG_FILES.HUB_SERVER),r=Uo.join(ns.get(Ge.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ge.LOG_NAMES.HDB),n=h$.get(Ge.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=Up.LOG_LEVEL_FLAGS[ns.get(Ge.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==wue?"-"+n:""),script:E$,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return ns.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Pd,i.error_file=Pd),i}a(Iue,"generateNatsHubServerConfig");var Cue=9940;function Pue(){ns.initSync(!0);let e=ns.get(Ge.CONFIG_PARAMS.ROOTPATH),t=Uo.join(e,"clustering",Up.NATS_CONFIG_FILES.LEAF_SERVER),r=Uo.join(ns.get(Ge.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ge.LOG_NAMES.HDB),n=h$.get(Ge.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=Up.LOG_LEVEL_FLAGS[ns.get(Ge.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==Cue?"-"+n:""),script:E$,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return ns.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Pd,i.error_file=Pd),i}a(Pue,"generateNatsLeafServerConfig");function Due(){ns.initSync();let e=Uo.join(ns.get(Ge.CONFIG_PARAMS.LOGGING_ROOT),Ge.LOG_NAMES.HDB),t={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:Ge.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:Oue,autorestart:!1};return ns.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=Pd,t.error_file=Pd),t}a(Due,"generateClusteringUpgradeV4ServiceConfig");function Lue(){let e={[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.RESTART_HDB};return RS.noBootFile()&&(e[Ge.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=RS.getEnvCliRootPath()),{...{name:Ge.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:m$},script:Nue}}a(Lue,"generateRestart");function Mue(){return{apps:[g$()]}}a(Mue,"generateAllServiceConfigs");S$.exports={generateAllServiceConfigs:Mue,generateMainServerConfig:g$,generateRestart:Lue,generateNatsHubServerConfig:Iue,generateNatsLeafServerConfig:Pue,generateClusteringUpgradeV4ServiceConfig:Due}});var Dd=I((sMe,v$)=>{"use strict";var et=(H(),P(G)),vue=ae(),Bo=AS(),bS=ir(),xo=St(),Ya=T$(),OS=ce(),Dl=W(),Uue=Lo(),{startWorker:A$,onMessageFromWorkers:xue}=rt(),Bue=Do(),nMe=require("util"),Hue=require("child_process"),kue=require("fs"),{execFile:Fue}=Hue,Ke;v$.exports={enterPM2Mode:Gue,start:Wa,stop:ww,reload:y$,restart:b$,list:Iw,describe:w$,connect:Ho,kill:Yue,startAllServices:Wue,startService:Cw,getUniqueServicesList:I$,restartAllServices:zue,isServiceRegistered:C$,reloadStopStart:P$,restartHdb:N$,deleteProcess:Vue,startClusteringProcesses:L$,startClusteringThreads:M$,isHdbRestartRunning:Kue,isClusteringRunning:Jue,stopClustering:jue,reloadClustering:Que,expectedRestartOfChildren:O$};var xp=!1;xue(e=>{e.type==="restart"&&OS.initSync(!0)});function Gue(){xp=!0}a(Gue,"enterPM2Mode");function Ho(){return Ke||(Ke=require("pm2")),new Promise((e,t)=>{Ke.connect((r,n)=>{r&&t(r),e(n)})})}a(Ho,"connect");var tn,que=10,R$;function Wa(e,t=!1){if(xp)return $ue(e);let r=Fue(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let o=tn.indexOf(r);o>-1&&tn.splice(o,1),!R$&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<que&&(kue.existsSync(Bo.getHubConfigPath())?Wa(e):(await Bo.generateNatsConfig(!0),Wa(e),await new Promise(c=>setTimeout(c,3e3)),await Bo.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Bo.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=OS.get(et.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,u=0,f;for(;l=c.exec(i);){if(l.index&&xo.LOG_LEVEL_HIERARCHY[o]>=xo.LOG_LEVEL_HIERARCHY[f||"info"]){let _=f===xo.LOG_LEVELS.ERR||f===xo.LOG_LEVELS.WRN?Dl.OUTPUTS.STDERR:Dl.OUTPUTS.STDOUT;Dl.logCustomLevel(f||"info",_,n,i.slice(u,l.index).trim())}let[d,p]=l;u=l.index+d.length,f=xo.LOG_LEVELS[p]}if(xo.LOG_LEVEL_HIERARCHY[o]>=xo.LOG_LEVEL_HIERARCHY[f||"info"]){let d=f===xo.LOG_LEVELS.ERR||f===xo.LOG_LEVELS.WRN?Dl.OUTPUTS.STDERR:Dl.OUTPUTS.STDOUT;Dl.logCustomLevel(f||"info",d,n,i.slice(u).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!tn&&(tn=[],!t)){let i=a(()=>{R$=!0,tn&&(tn.map(o=>o.kill()),process.exit(0))},"kill_children");process.on("exit",i),process.on("SIGINT",i),process.on("SIGQUIT",i),process.on("SIGTERM",i)}tn.push(r)}a(Wa,"start");function $ue(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.start(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a($ue,"startWithPM2");function ww(e){if(!xp){for(let t of tn||[])t.name===e&&(tn.splice(tn.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.stop(e,async(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.delete(e,(i,o)=>{i&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(o)})})})}a(ww,"stop");function y$(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.reload(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(y$,"reload");function b$(e){if(!xp){O$();for(let t of tn||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.restart(e,(n,s)=>{Ke.disconnect(),t(s)})})}a(b$,"restart");function O$(){for(let e of tn||[])e.config&&(e.config.restarts=0)}a(O$,"expectedRestartOfChildren");function Vue(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.delete(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(Vue,"deleteProcess");async function N$(){await Wa(Ya.generateRestart())}a(N$,"restartHdb");async function Kue(){let e=await Iw();for(let t in e)if(e[t].name===et.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(Kue,"isHdbRestartRunning");function Iw(){return new Promise(async(e,t)=>{try{await Ho()}catch(r){t(r)}Ke.list((r,n)=>{r&&(Ke.disconnect(),t(r)),Ke.disconnect(),e(n)})})}a(Iw,"list");function w$(e){return new Promise(async(t,r)=>{try{await Ho()}catch(n){r(n)}Ke.describe(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(w$,"describe");function Yue(){if(!xp){for(let e of tn||[])e.kill();tn=[];return}return new Promise(async(e,t)=>{try{await Ho()}catch(r){t(r)}Ke.killDaemon((r,n)=>{r&&(Ke.disconnect(),t(r)),Ke.disconnect(),e(n)})})}a(Yue,"kill");async function Wue(){try{await L$(),await M$(),await Wa(Ya.generateAllServiceConfigs())}catch(e){throw Ke?.disconnect(),e}}a(Wue,"startAllServices");async function Cw(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case et.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Ya.generateMainServerConfig();break;case et.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Ya.generateNatsIngestServiceConfig();break;case et.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Ya.generateNatsReplyServiceConfig();break;case et.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Ya.generateNatsHubServerConfig(),await Wa(r,t),await Bo.removeNatsConfig(e);return;case et.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Ya.generateNatsLeafServerConfig(),await Wa(r,t),await Bo.removeNatsConfig(e);return;case et.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Ya.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await Wa(r)}catch(r){throw Ke?.disconnect(),r}}a(Cw,"startService");async function I$(){try{let e=await Iw(),t={};for(let r=0,n=e.length;r<n;r++){let s=e[r];t[s.name]===void 0&&(t[s.name]={name:s.name,exec_mode:s.pm2_env.exec_mode})}return t}catch(e){throw Ke?.disconnect(),e}}a(I$,"getUniqueServicesList");async function zue(e=[]){try{let t=!1,r=await I$();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===et.PROCESS_DESCRIPTORS.HDB?t=!0:await b$(o))}t&&await P$(et.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Ke?.disconnect(),t}}a(zue,"restartAllServices");async function C$(e){if(tn?.find(r=>r.name===e))return!0;let t=await Bue.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(C$,"isServiceRegistered");async function P$(e){let t=OS.get(et.CONFIG_PARAMS.THREADS_COUNT)??OS.get(et.CONFIG_PARAMS.THREADS),r=await w$(e),n=vue.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await ww(e),await Cw(e)):e===et.PROCESS_DESCRIPTORS.HDB?await N$():await y$(e)}a(P$,"reloadStopStart");var D$;async function L$(e=!1){for(let t in et.CLUSTERING_PROCESSES){let r=et.CLUSTERING_PROCESSES[t];await Cw(r,e)}}a(L$,"startClusteringProcesses");async function M$(){D$=A$(et.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:et.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await bS.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await bS.updateLocalStreams();let e=await Uue.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===et.PRE_4_0_0_VERSION){Dl.info("Starting clustering upgrade 4.0.0 process"),A$(et.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(M$,"startClusteringThreads");async function jue(){for(let e in et.CLUSTERING_PROCESSES)if(e!==et.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===et.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await D$.terminate();else{let t=et.CLUSTERING_PROCESSES[e];await ww(t)}}a(jue,"stopClustering");async function Jue(){for(let e in et.CLUSTERING_PROCESSES){let t=et.CLUSTERING_PROCESSES[e];if(await C$(t)===!1)return!1}return!0}a(Jue,"isClusteringRunning");async function Que(){await Bo.generateNatsConfig(!0),await bS.reloadNATSHub(),await bS.reloadNATSLeaf(),await Bo.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await Bo.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(Que,"reloadClustering")});var IS={};Ue(IS,{compactOnStart:()=>Xue,copyDb:()=>F$});async function Xue(){za.notify("Running compact on start"),console.log("Running compact on start");let e=(0,Pw.get)(x.ROOTPATH),t=new Map,r=Xe();(0,Dw.updateConfigValue)(x.STORAGE_COMPACTONSTART,!1);try{for(let n in r){if(n==="system"||n.endsWith("-copy"))continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,NS.join)(e,"backup",n+".mdb"),o=(0,NS.join)(e,wc,n+"-copy.mdb"),c=0;try{c=await U$(n),console.log("Database",n,"before compact has a total record count of",c)}catch(l){za.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 F$(n,o),console.log("Backing up",n,"to",i),await(0,Ll.move)(s,i,{overwrite:!0})}try{Ld()}catch(n){za.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,Ll.move)(i,s,{overwrite:!0}),await(0,Ll.remove)((0,NS.join)(e,wc,`${n}-copy.mdb-lock`));try{Ld()}catch(n){za.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n),process.exit(0)}}catch(n){za.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,Dw.updateConfigValue)(x.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,Ll.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw Ld(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await U$(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}.
26
26
  Total record count before compaction: ${i}, total after: ${c}.
27
- Database backup has not been removed and can be found here: ${s}`;Wa.error(l),console.error(l)}(0,Pw.get)(x.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||o===!1||(console.log("Removing backup",s),await(0,Dl.remove)(s))}}async function U$(e){let t=await(0,k$.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}async function F$(e,t){console.log("copyDb start");let r=Xe()[e],n;for(let d in r){n=r[d].primaryStore.rootStore;break}let s=n.dbisDb,i=n.auditStore,o=(0,x$.open)(new B$.default(t)),c=o.openDB(NS.INTERNAL_DBIS_NAME),l,u=0,f=s.useReadTransaction();try{for(let{key:p,value:_}of s.getRange({transaction:f})){let h=_.is_hash_attribute||_.isPrimaryKey,S,g;if(h&&(S=_.compression,g=CS(),g?_.compression=g:delete _.compression,S?.dictionary?.toString()===g?.dictionary?.toString()&&(S=null,g=null)),c.put(p,_),!(h||_.indexed))continue;let R=new H$.default(!h,h);R.encoding="binary",R.compression=S;let E=n.openDB(p,R);E.decoder=null,E.decoderCopies=!1,E.encoding="binary",R.compression=g;let T=o.openDB(p,R);T.encoder=null,console.log("copying",p,"from",e,"to",t),await d(E,T,h,f)}if(i){let p=n.openDB(NS.AUDIT_STORE_NAME,xp);console.log("copying audit log for",e,"to",t),d(i,p,!1,f)}async function d(p,_,h,S){let g=0,R=0,E=1e7,T=null;for(;E-- >0;)try{for(let b of p.getKeys({start:T,transaction:S}))try{T=b;let{value:v,version:F}=p.getEntry(b,{transaction:S});l=_.put(b,v,h?F:void 0),g++,S.openTimer&&(S.openTimer=0),R+=(b?.length||10)+v.length,u++>5e3&&(await l,console.log("copied",g,"entries",R,"bytes"),u=0)}catch(v){console.error("Error copying record",typeof b=="symbol"?"symbol":b,"from",e,"to",t,v)}console.log("finish copying, copied",g,"entries",R,"bytes");return}catch{if(typeof T=="string"){if(T==="z")return console.error("Reached end of dbi",T,"for",e,"to",t);T=T.slice(0,-2)+"z"}else if(typeof T=="number")T++;else return console.error("Unknown key type",T,"for",e,"to",t)}}a(d,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{f.done(),o.close()}}var x$,OS,Dl,Pw,B$,H$,NS,k$,Dw,Wa,IS=be(()=>{De();x$=require("lmdb"),OS=require("path"),Dl=require("fs-extra"),Pw=M(ae()),B$=M(i_()),H$=M(s_()),NS=M(xt());H();fo();k$=M(go()),Dw=M(yt()),Wa=M(z());a(ede,"compactOnStart");a(U$,"getTotalDBRecordCount");a(F$,"copyDb")});var za=w((pMe,W$)=>{"use strict";var tde=require("minimist"),{isMainThread:Mw,parentPort:Hp,threadId:dMe}=require("worker_threads"),at=(H(),C(G)),Vi=z(),vw=ie(),DS=TS(),PS=ir(),fMe=Tt(),V$=yt(),di=Pd(),G$=Po(),{compactOnStart:rde}=(IS(),C(wS)),nde=ua(),{restartWorkers:LS,onMessageByType:sde}=rt(),{handleHDBError:ide,hdb_errors:ode}=pe(),{HTTP_STATUS_CODES:ade}=ode,kp=ae(),{sendOperationToNode:q$,getThisNodeName:cde,monitorNodeCAs:lde}=(Xn(),C(wo)),{getHDBNodeTable:_Me}=(pl(),C(jO));kp.initSync();var Bp=`Restarting HarperDB. This may take up to ${at.RESTART_TIMEOUT_MS/1e3} seconds.`,ude="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",$$="Clustering is not enabled so cannot be restarted",dde="Invalid service",Ld,Is;W$.exports={restart:K$,restartService:Uw};Mw&&sde(at.ITC_EVENT_TYPES.RESTART,async(e,t)=>{e.workerType?await Uw({service:e.workerType}):K$({operation:"restart"}),t.postMessage({type:"restart-complete"})});async function K$(e){Is=Object.keys(e).length===0,Ld=await di.isServiceRegistered(at.PROCESS_DESCRIPTORS.HDB);let t=tde(process.argv);if(t.service){await Uw(t);return}if(Is&&!Ld){console.error(ude);return}if(Is&&console.log(Bp),Ld){di.enterPM2Mode(),Vi.notify(Bp);let r=nde(Object.keys(at.CONFIG_PARAM_MAP),!0);return vw.isEmptyOrZeroLength(Object.keys(r))||V$.updateConfigValue(void 0,void 0,r,!0,!0),fde(),Bp}return Mw?(Vi.notify(Bp),kp.get(at.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await rde(),process.env.HARPER_EXIT_ON_RESTART&&process.exit(0),setTimeout(()=>{LS()},50)):Hp.postMessage({type:at.ITC_EVENT_TYPES.RESTART}),Bp}a(K$,"restart");async function Uw(e){let{service:t}=e;if(at.HDB_PROCESS_SERVICES[t]===void 0)throw ide(new Error,dde,ade.BAD_REQUEST,void 0,void 0,!0);if(di.expectedRestartOfChildren(),Ld=await di.isServiceRegistered(at.PROCESS_DESCRIPTORS.HDB),!Mw){e.replicated&&lde(),Hp.postMessage({type:at.ITC_EVENT_TYPES.RESTART,workerType:t}),Hp.ref(),await new Promise(s=>{Hp.on("message",i=>{i.type==="restart-complete"&&(s(),Hp.unref())})});let n;if(e.replicated){e.replicated=!1,n=[];for(let s of server.nodes){if(s.name===cde())continue;let{job_id:i}=await q$(s,e);n.push(await new Promise((o,c)=>{let u=2400,f=setInterval(async()=>{if(u--<=0){clearInterval(f);let _=new Error("Timed out waiting for restart job to complete");_.replicated=n,c(_)}let p=(await q$(s,{operation:"get_job",id:i})).results[0];if(p.status==="COMPLETE"&&(clearInterval(f),o({node:s.name,message:p.message})),p.status==="ERROR"){clearInterval(f);let _=new Error(p.message);_.replicated=n,c(_)}},250)}))}return{replicated:n}}return}let r;switch(t){case at.HDB_PROCESS_SERVICES.clustering:if(!kp.get(at.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=$$;break}Is&&console.log("Restarting clustering"),Vi.notify("Restarting clustering"),await Y$();break;case at.HDB_PROCESS_SERVICES.clustering_config:case at.HDB_PROCESS_SERVICES["clustering config"]:if(!kp.get(at.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=$$;break}Is&&console.log("Restarting clustering_config"),Vi.notify("Restarting clustering_config"),await di.reloadClustering();break;case"custom_functions":case"custom functions":case at.HDB_PROCESS_SERVICES.harperdb:case at.HDB_PROCESS_SERVICES.http_workers:case at.HDB_PROCESS_SERVICES.http:if(Is&&!Ld){r=`Restart ${t} is not available from the CLI when running in non-pm2 mode. Either call restart ${t} from the API or stop and start HarperDB.`;break}Is&&console.log("Restarting http_workers"),Vi.notify("Restarting http_workers"),Is?await di.restart(at.PROCESS_DESCRIPTORS.HDB):await LS("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(Vi.error(r),Is&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(Uw,"restartService");async function fde(){await Y$(),await di.restart(at.PROCESS_DESCRIPTORS.HDB),await vw.async_set_timeout(2e3),kp.get(at.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await Lw(),Is&&(await PS.closeConnection(),process.exit(0))}a(fde,"restartPM2Mode");async function Y$(){if(!V$.getConfigFromFile(at.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await G$.getHDBProcessInfo()).clustering.length===0)Vi.trace("Clustering not running, restart will start clustering services"),await DS.generateNatsConfig(!0),await di.startClusteringProcesses(),await di.startClusteringThreads(),await Lw(),Is&&await PS.closeConnection();else{await DS.generateNatsConfig(!0),Ld?(Vi.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await di.restart(at.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await di.restart(at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await G$.getHDBProcessInfo()).clustering.forEach(s=>{Vi.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await vw.async_set_timeout(3e3),await Lw(),await PS.updateLocalStreams(),Is&&await PS.closeConnection(),Vi.trace("Restart clustering restarting ingest and reply service threads");let t=LS(at.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=LS(at.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(Y$,"restartClustering");async function Lw(){await DS.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await DS.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(Lw,"removeNatsConfig")});var sV=w((EMe,nV)=>{"use strict";var mMe=require("lodash"),In=(H(),C(G)),{handleHDBError:z$,hdb_errors:_de}=pe(),{HDB_ERROR_MSGS:pde,HTTP_STATUS_CODES:hde}=_de,xw=z();nV.exports={getRolePermissions:Ede};var Ll=Object.create(null),mde=a(e=>({key:e,perms:{}}),"perms_template_obj"),X$=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),Z$=a((e=!1,t=!1,r=!1,n=!1)=>({[In.PERMS_CRUD_ENUM.READ]:e,[In.PERMS_CRUD_ENUM.INSERT]:t,[In.PERMS_CRUD_ENUM.UPDATE]:r,[In.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),Bw=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...Z$(t,r,n,s)}),"table_perms_template"),j$=a((e,t=Z$())=>({attribute_name:e,describe:rV(t),[Fp]:t[Fp],[Hw]:t[Hw],[kw]:t[kw]}),"attr_perms_template"),J$=a((e,t=!1)=>({attribute_name:e,describe:t,[Fp]:t}),"timestamp_attr_perms_template"),{READ:Fp,INSERT:Hw,UPDATE:kw}=In.PERMS_CRUD_ENUM,eV=Object.values(In.PERMS_CRUD_ENUM),tV=[Fp,Hw,kw];function Ede(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r={...global.hdb_schema};delete r[In.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(Ll[t]&&Ll[t].key===n)return Ll[t].perms;let s=gde(e,r);return Ll[t]?Ll[t].key=n:Ll[t]=mde(n),Ll[t].perms=s,s}catch(r){if(!e[In.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[In.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<In.PERMS_UPDATE_RELEASE_TIMESTAMP){let n=`Role permissions for role '${t}' must be updated to align with new structure from the 2.2.0 release.`;throw xw.error(n),xw.debug(r),z$(new Error,pde.OUTDATED_PERMS_TRANSLATION_ERROR,hde.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
28
- ${r.stack}`;throw xw.error(n),z$(new Error)}}}a(Ede,"getRolePermissions");function gde(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[In.SYSTEM_SCHEMA_NAME]=n[In.SYSTEM_SCHEMA_NAME],r.structure_user=n.structure_user;let s=Array.isArray(e.permission.structure_user)||e.permission.structure_user===!0?e.permission.structure_user:[];return Object.keys(t).forEach(i=>{if(s===!0||s.indexOf(i)>-1){r[i]=Sde(t[i]);return}r[i]=X$(),n[i]?(n[i].describe&&(r[i].describe=!0),Object.keys(t[i]).forEach(o=>{if(n[i].tables[o]){let c=n[i].tables[o],l=t[i][o],u=Tde(c,l);r[i].describe||eV.forEach(f=>{u[f]&&(r[i].describe=!0)}),r[i].tables[o]=u}else r[i].tables[o]=Bw()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=Bw()})}),r}a(gde,"translateRolePermissions");function Sde(e){let t=X$(!0);return Object.keys(e).forEach(r=>{t.tables[r]=Bw(!0,!0,!0,!0,!0)}),t}a(Sde,"createStructureUserPermissions");function Tde(e,t){let{attribute_permissions:r}=e;if(r?.length>0){let s={...e};s.attribute_permissions=[];let i=r.reduce((u,f)=>{let{attribute_name:d}=f,p=f;return In.TIME_STAMP_NAMES.includes(d)&&(p=J$(d,f[Fp])),u[d]=p,u},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=j$(o);return t.attributes.forEach(({attribute:u})=>{if(i[u]){let f=i[u];f.describe=rV(f),s.attribute_permissions.push(f),c||Ade(f,l)}else if(u!==o){let f;In.TIME_STAMP_NAMES.includes(u)?f=J$(u):f=j$(u),s.attribute_permissions.push(f)}}),c||s.attribute_permissions.push(l),s.describe=Q$(s),s}else return e.describe=Q$(e),e}a(Tde,"getTableAttrPerms");function Q$(e){return eV.filter(t=>e[t]).length>0}a(Q$,"getSchemaTableDescribePerm");function rV(e){return tV.filter(t=>e[t]).length>0}a(rV,"getAttributeDescribePerm");function Ade(e,t){tV.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(Ade,"checkForHashPerms")});var Gp={};ve(Gp,{authentication:()=>dV,bypassAuth:()=>Ide,login:()=>Pde,logout:()=>Dde,start:()=>Cde});function Ide(){uV=!0}async function dV(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let _=e.isOperationsServer?Ode?bde:[]:yde?Rde:[];if(_.includes(i)||_.includes("*")){if(e.method==="OPTIONS"){let h=ns.get(x.HTTP_CORSACCESSCONTROLALLOWHEADERS)??"Accept, Content-Type, Authorization",S=new yo([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers",h],["Access-Control-Allow-Origin",i]]);return MS&&S.set("Access-Control-Allow-Credentials","true"),{status:200,headers:S}}o.push("Access-Control-Allow-Origin",i),MS&&o.push("Access-Control-Allow-Credentials","true")}}let l,u;if(MS){i||(i=r.host);let _=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.split(/;\s+/)||[];for(let S of h)if(S.startsWith(_)){let g=S.indexOf(";");l=S.slice(_.length,g===-1?S.length:g),u=await iV.get(l);break}e.session=u||(u={})}let f=a((_,h,S)=>{let g=new Md.AuthAuditLog(_,h,la.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);g.auth_strategy=S,l&&(g.session_id=l),r.referer&&(g.referer=r.referer),r.origin&&(g.origin=r.origin),h===Ys.SUCCESS?Fw.notify(g):Fw.error(g)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&Fw.error("Authorization error:",e._nodeRequest.socket.authorizationError),e.mtlsConfig&&e.authorized&&e.peerCertificate.subject){let _=e.mtlsConfig.user;_!==null?((_===void 0||_==="Common Name"||_==="CN")&&(_=e.peerCertificate.subject.CN),e.user=await We.getUser(_,null,e),f(_,Ys.SUCCESS,"mTLS")):(0,Md.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let d;if(!e.user)if(n){if(d=Ml.get(n),!d){let _=n.indexOf(" "),h=n.slice(0,_),S=n.slice(_+1),g,R;try{switch(h){case"Basic":let E=atob(S),T=E.indexOf(":");g=E.slice(0,T),R=E.slice(T+1),d=g||R?await We.getUser(g,R,e):null;break;case"Bearer":try{d=await NO(S)}catch(b){if(b.message==="invalid token")try{return await lg(S),c({status:-1})}catch{throw b}}break}}catch(E){return wde&&(Ml.get(S)||(Ml.set(S,S),f(g,Ys.FAILURE,h))),c({status:401,body:Aa({error:E.message},e)})}Ml.set(n,d),Nde&&f(d.username,Ys.SUCCESS,h)}e.user=d}else u?.user?e.user=await We.getUser(u.user,null,e):(uV&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,aV.getSuperUser)());MS&&(e.session.update=function(_){if(!l){l=(0,cV.v4)();let S=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${l}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",S):p?.headers?.set&&p.headers.set("Set-Cookie",S)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):p?.headers?.set&&(i&&p.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),p.headers.set("X-Hdb-Session","Secure"))),_.id=l,iV.put(_)},e.login=async function(_,h){let S=e.user=await We.authenticateUser(_,h,e);e.session.update({user:S&&(S.getId?.()??S.username)})});let p=await t(e);return p&&(p.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&Oi.loginPath?(p.status=302,p.headers.set("Location",Oi.loginPath(e))):p.headers.set("WWW-Authenticate","Basic")),c(p))}catch(l){throw c(l)}function c(l){let u=o.length;if(u>0){let f=l.headers;f||(l.headers=f=new yo);for(let d=0;d<u;){let p=o[d++];f.set(p,o[d++])}}return o=null,l}a(c,"applyResponseHeaders")}function Cde({server:e,port:t,securePort:r}){e.http(dV,t||r?{port:t,securePort:r}:{port:"all"}),oV||(oV=!0,setInterval(()=>{Ml=new Map},ns.get(x.AUTHENTICATION_CACHETTL)).unref(),lV.user.addListener(()=>{Ml=new Map}))}async function Pde(e){if(!e.baseRequest?.login)throw new Error("No session for login");return e.baseResponse.headers.set=(t,r)=>{e.fastifyResponse.header(t,r)},await e.baseRequest.login(e.username,e.password??""),"Login successful"}async function Dde(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var aV,cV,ns,Md,lV,Fw,Rde,yde,bde,Ode,iV,MS,uV,Nde,wde,Ml,oV,vS=be(()=>{aV=M(Rn());Vr();Tu();Ju();De();cV=require("uuid"),ns=M(ae());H();Md=M(z()),lV=M(b_());z_();ao();Fw=(0,Md.loggerWithTag)("auth-event");ns.initSync();Rde=ns.get(x.HTTP_CORSACCESSLIST),yde=ns.get(x.HTTP_CORS),bde=ns.get(x.OPERATIONSAPI_NETWORK_CORSACCESSLIST),Ode=ns.get(x.OPERATIONSAPI_NETWORK_CORS),iV=ft({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),MS=ns.get(x.AUTHENTICATION_ENABLESESSIONS)??!0,uV=process.env.AUTHENTICATION_AUTHORIZELOCAL??ns.get(x.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,Nde=ns.get(x.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,wde=ns.get(x.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,Ml=new Map;We.onInvalidatedUser(()=>{Ml=new Map});a(Ide,"bypassAuth");a(dV,"authentication");a(Cde,"start");a(Pde,"login");a(Dde,"logout")});var gV=w((wMe,EV)=>{"use strict";var Ne=require("joi"),fV=require("fs-extra"),_V=require("path"),ss=ot(),pV=ae(),hV=(H(),C(G)),mV=z(),{hdb_errors:Lde}=pe(),{HDB_ERROR_MSGS:tn}=Lde,Ho=/^[a-zA-Z0-9-_]+$/,Mde=/^[a-zA-Z0-9-_]+$/;EV.exports={getDropCustomFunctionValidator:Ude,setCustomFunctionValidator:xde,addComponentValidator:Fde,dropCustomFunctionProjectValidator:Gde,packageComponentValidator:qde,deployComponentValidator:$de,setComponentFileValidator:Bde,getComponentFileValidator:kde,dropComponentFileValidator:Hde,addSSHKeyValidator:Vde,updateSSHKeyValidator:Kde,deleteSSHKeyValidator:Yde,setSSHKnownHostsValidator:Wde};function US(e,t,r){try{let n=pV.get(hV.CONFIG_PARAMS.COMPONENTSROOT),s=_V.join(n,t);return fV.existsSync(s)?e?t:r.message(tn.PROJECT_EXISTS):e?r.message(tn.NO_PROJECT):t}catch(n){return mV.error(n),r.message(tn.VALIDATION_ERR)}}a(US,"checkProjectExists");function qp(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(qp,"checkFilePath");function vde(e,t,r,n){try{let s=pV.get(hV.CONFIG_PARAMS.COMPONENTSROOT),i=_V.join(s,e,t,r+".js");return fV.existsSync(i)?r:n.message(tn.NO_FILE)}catch(s){return mV.error(s),n.message(tn.VALIDATION_ERR)}}a(vde,"checkFileExists");function Ude(e){let t=Ne.object({project:Ne.string().pattern(Ho).custom(US.bind(null,!0)).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().pattern(Ho).custom(vde.bind(null,e.project,e.type)).custom(qp).required().messages({"string.pattern.base":tn.BAD_FILE_NAME})});return ss.validateBySchema(e,t)}a(Ude,"getDropCustomFunctionValidator");function xde(e){let t=Ne.object({project:Ne.string().pattern(Ho).custom(US.bind(null,!0)).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().custom(qp).required(),function_content:Ne.string().required()});return ss.validateBySchema(e,t)}a(xde,"setCustomFunctionValidator");function Bde(e){let t=Ne.object({project:Ne.string().pattern(Ho).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),file:Ne.string().custom(qp).required(),payload:Ne.string().allow("").optional(),encoding:Ne.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return ss.validateBySchema(e,t)}a(Bde,"setComponentFileValidator");function Hde(e){let t=Ne.object({project:Ne.string().pattern(Ho).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),file:Ne.string().custom(qp).optional()});return ss.validateBySchema(e,t)}a(Hde,"dropComponentFileValidator");function kde(e){let t=Ne.object({project:Ne.string().required(),file:Ne.string().custom(qp).required(),encoding:Ne.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return ss.validateBySchema(e,t)}a(kde,"getComponentFileValidator");function Fde(e){let t=Ne.object({project:Ne.string().pattern(Ho).custom(US.bind(null,!1)).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME})});return ss.validateBySchema(e,t)}a(Fde,"addComponentValidator");function Gde(e){let t=Ne.object({project:Ne.string().pattern(Ho).custom(US.bind(null,!0)).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME})});return ss.validateBySchema(e,t)}a(Gde,"dropCustomFunctionProjectValidator");function qde(e){let t=Ne.object({project:Ne.string().pattern(Ho).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),skip_node_modules:Ne.boolean(),skip_symlinks:Ne.boolean()});return ss.validateBySchema(e,t)}a(qde,"packageComponentValidator");function $de(e){let t=Ne.object({project:Ne.string().pattern(Ho).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),package:Ne.string().optional(),restart:Ne.alternatives().try(Ne.boolean(),Ne.string().valid("rolling")).optional()});return ss.validateBySchema(e,t)}a($de,"deployComponentValidator");function Vde(e){let t=Ne.object({name:Ne.string().pattern(Mde).required().messages({"string.pattern.base":tn.BAD_SSH_KEY_NAME}),key:Ne.string().required(),host:Ne.string().required(),hostname:Ne.string().required(),known_hosts:Ne.string().optional()});return ss.validateBySchema(e,t)}a(Vde,"addSSHKeyValidator");function Kde(e){let t=Ne.object({name:Ne.string().required(),key:Ne.string().required()});return ss.validateBySchema(e,t)}a(Kde,"updateSSHKeyValidator");function Yde(e){let t=Ne.object({name:Ne.string().required()});return ss.validateBySchema(e,t)}a(Yde,"deleteSSHKeyValidator");function Wde(e){let t=Ne.object({known_hosts:Ne.string().required()});return ss.validateBySchema(e,t)}a(Wde,"setSSHKnownHostsValidator")});var Kp=w((CMe,yV)=>{"use strict";var xS=require("joi"),ja=require("path"),vd=require("fs-extra"),{exec:zde,spawn:jde}=require("child_process"),Jde=require("util"),Qde=Jde.promisify(zde),Ud=(H(),C(G)),{PACKAGE_ROOT:Xde}=it(),{handleHDBError:$p,hdb_errors:Zde}=pe(),{HTTP_STATUS_CODES:Vp}=Zde,vl=ae(),efe=ot(),Ja=z(),{once:tfe}=require("events");vl.initSync();var Gw=vl.get(Ud.CONFIG_PARAMS.COMPONENTSROOT),SV="npm install --force --omit=dev --json",rfe=`${SV} --dry-run`,nfe=vl.get(Ud.CONFIG_PARAMS.ROOTPATH),BS=ja.join(nfe,"ssh");yV.exports={installModules:afe,auditModules:cfe,installAllRootModules:sfe,uninstallRootModule:ife,linkHarperdb:ofe,runCommand:xd};async function sfe(e=!1,t=vl.get(Ud.CONFIG_PARAMS.ROOTPATH)){await HS();let r=!1,n=process.env;vd.pathExistsSync(BS)&&vd.readdirSync(BS).forEach(s=>{s.includes(".key")&&!r&&(n={GIT_SSH_COMMAND:"ssh -F "+ja.join(BS,"config")+" -o UserKnownHostsFile="+ja.join(BS,"known_hosts"),...process.env},r=!0)});try{let s=vl.get(Ud.CONFIG_PARAMS.ROOTPATH),i=ja.join(s,"node_modules","harperdb");vd.lstatSync(i).isSymbolicLink()&&vd.unlinkSync(i)}catch(s){s.code!=="ENOENT"&&Ja.error("Error removing symlink:",s)}await xd(e?"npm install --force --ignore-scripts --no-bin-links":"npm install --force --no-bin-links",t,n)}a(sfe,"installAllRootModules");async function ife(e){await xd(`npm uninstall ${e}`,vl.get(Ud.CONFIG_PARAMS.ROOTPATH))}a(ife,"uninstallRootModule");async function ofe(){await HS(),await xd(`npm link ${Xde}`,vl.get(Ud.CONFIG_PARAMS.ROOTPATH))}a(ofe,"linkHarperdb");async function xd(e,t=void 0,r=process.env){Ja.debug({tagName:"npm_run_command"},`running command: \`${e}\``);let n=jde(e,{shell:!0,cwd:t,env:r,stdio:["ignore","pipe","pipe"]}),s="",i="";n.stdout.on("data",c=>{let l=c.toString();Ja.debug({tagName:"npm_run_command:stdout"},l),s+=l}),n.stderr.on("data",c=>{let l=c.toString();Ja.error({tagName:"npm_run_command:stderr"},l),i+=l});let[o]=await tfe(n,"close");if(o!==0)throw new Error(`Command \`${e}\` exited with code ${o}.${i===""?"":` Error: ${i}`}`);return s||void 0}a(xd,"runCommand");async function afe(e){let t="install_node_modules is deprecated. Dependencies are automatically installed on deploy, and install_node_modules can lead to inconsistent behavior";Ja.warn(t,e);let r=RV(e);if(r)throw $p(r,r.message,Vp.BAD_REQUEST);let{projects:n,dry_run:s}=e,i=s===!0?rfe:SV;await HS(),await AV(n);let o={};for(let c=0,l=n.length;c<l;c++){let u=n[c];o[u]={npm_output:null,npm_error:null};let f=ja.join(Gw,u),d,p=null;try{let{stdout:_,stderr:h}=await Qde(i,{cwd:f});d=_?_.replace(`
27
+ Database backup has not been removed and can be found here: ${s}`;za.error(l),console.error(l)}(0,Pw.get)(x.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||o===!1||(console.log("Removing backup",s),await(0,Ll.remove)(s))}}async function U$(e){let t=await(0,k$.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}async function F$(e,t){console.log("copyDb start");let r=Xe()[e],n;for(let d in r){n=r[d].primaryStore.rootStore;break}let s=n.dbisDb,i=n.auditStore,o=(0,x$.open)(new B$.default(t)),c=o.openDB(wS.INTERNAL_DBIS_NAME),l,u=0,f=s.useReadTransaction();try{for(let{key:p,value:_}of s.getRange({transaction:f})){let h=_.is_hash_attribute||_.isPrimaryKey,S,g;if(h&&(S=_.compression,g=PS(),g?_.compression=g:delete _.compression,S?.dictionary?.toString()===g?.dictionary?.toString()&&(S=null,g=null)),c.put(p,_),!(h||_.indexed))continue;let R=new H$.default(!h,h);R.encoding="binary",R.compression=S;let E=n.openDB(p,R);E.decoder=null,E.decoderCopies=!1,E.encoding="binary",R.compression=g;let A=o.openDB(p,R);A.encoder=null,console.log("copying",p,"from",e,"to",t),await d(E,A,h,f)}if(i){let p=n.openDB(wS.AUDIT_STORE_NAME,Bp);console.log("copying audit log for",e,"to",t),d(i,p,!1,f)}async function d(p,_,h,S){let g=0,R=0,E=1e7,A=null;for(;E-- >0;)try{for(let N of p.getKeys({start:A,transaction:S}))try{A=N;let{value:v,version:F}=p.getEntry(N,{transaction:S});l=_.put(N,v,h?F:void 0),g++,S.openTimer&&(S.openTimer=0),R+=(N?.length||10)+v.length,u++>5e3&&(await l,console.log("copied",g,"entries",R,"bytes"),u=0)}catch(v){console.error("Error copying record",typeof N=="symbol"?"symbol":N,"from",e,"to",t,v)}console.log("finish copying, copied",g,"entries",R,"bytes");return}catch{if(typeof A=="string"){if(A==="z")return console.error("Reached end of dbi",A,"for",e,"to",t);A=A.slice(0,-2)+"z"}else if(typeof A=="number")A++;else return console.error("Unknown key type",A,"for",e,"to",t)}}a(d,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{f.done(),o.close()}}var x$,NS,Ll,Pw,B$,H$,wS,k$,Dw,za,CS=be(()=>{De();x$=require("lmdb"),NS=require("path"),Ll=require("fs-extra"),Pw=M(ce()),B$=M(o_()),H$=M(i_()),wS=M(xt());H();_o();k$=M(So()),Dw=M(Rt()),za=M(W());a(Xue,"compactOnStart");a(U$,"getTotalDBRecordCount");a(F$,"copyDb")});var ja=I((_Me,W$)=>{"use strict";var Zue=require("minimist"),{isMainThread:Mw,parentPort:kp,threadId:uMe}=require("worker_threads"),ot=(H(),P(G)),Ki=W(),vw=ae(),LS=AS(),DS=ir(),dMe=St(),V$=Rt(),fi=Dd(),G$=Do(),{compactOnStart:ede}=(CS(),P(IS)),tde=da(),{restartWorkers:MS,onMessageByType:rde}=rt(),{handleHDBError:nde,hdb_errors:sde}=pe(),{HTTP_STATUS_CODES:ide}=sde,Fp=ce(),{sendOperationToNode:q$,getThisNodeName:ode,monitorNodeCAs:ade}=(Zn(),P(Io)),{getHDBNodeTable:fMe}=(hl(),P(JO));Fp.initSync();var Hp=`Restarting HarperDB. This may take up to ${ot.RESTART_TIMEOUT_MS/1e3} seconds.`,cde="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",$$="Clustering is not enabled so cannot be restarted",lde="Invalid service",Md,Cs;W$.exports={restart:K$,restartService:Uw};Mw&&rde(ot.ITC_EVENT_TYPES.RESTART,async(e,t)=>{e.workerType?await Uw({service:e.workerType}):K$({operation:"restart"}),t.postMessage({type:"restart-complete"})});async function K$(e){Cs=Object.keys(e).length===0,Md=await fi.isServiceRegistered(ot.PROCESS_DESCRIPTORS.HDB);let t=Zue(process.argv);if(t.service){await Uw(t);return}if(Cs&&!Md){console.error(cde);return}if(Cs&&console.log(Hp),Md){fi.enterPM2Mode(),Ki.notify(Hp);let r=tde(Object.keys(ot.CONFIG_PARAM_MAP),!0);return vw.isEmptyOrZeroLength(Object.keys(r))||V$.updateConfigValue(void 0,void 0,r,!0,!0),ude(),Hp}return Mw?(Ki.notify(Hp),Fp.get(ot.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await ede(),process.env.HARPER_EXIT_ON_RESTART&&process.exit(0),setTimeout(()=>{MS()},50)):kp.postMessage({type:ot.ITC_EVENT_TYPES.RESTART}),Hp}a(K$,"restart");async function Uw(e){let{service:t}=e;if(ot.HDB_PROCESS_SERVICES[t]===void 0)throw nde(new Error,lde,ide.BAD_REQUEST,void 0,void 0,!0);if(fi.expectedRestartOfChildren(),Md=await fi.isServiceRegistered(ot.PROCESS_DESCRIPTORS.HDB),!Mw){e.replicated&&ade(),kp.postMessage({type:ot.ITC_EVENT_TYPES.RESTART,workerType:t}),kp.ref(),await new Promise(s=>{kp.on("message",i=>{i.type==="restart-complete"&&(s(),kp.unref())})});let n;if(e.replicated){e.replicated=!1,n=[];for(let s of server.nodes){if(s.name===ode())continue;let i;try{({job_id:i}=await q$(s,e))}catch(o){n.push({node:s.name,message:o.message});continue}n.push(await new Promise((o,c)=>{let u=2400,f=setInterval(async()=>{if(u--<=0){clearInterval(f);let _=new Error("Timed out waiting for restart job to complete");_.replicated=n,c(_)}let p=(await q$(s,{operation:"get_job",id:i})).results[0];if(p.status==="COMPLETE"&&(clearInterval(f),o({node:s.name,message:p.message})),p.status==="ERROR"){clearInterval(f);let _=new Error(p.message);_.replicated=n,c(_)}},250)}))}return{replicated:n}}return}let r;switch(t){case ot.HDB_PROCESS_SERVICES.clustering:if(!Fp.get(ot.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=$$;break}Cs&&console.log("Restarting clustering"),Ki.notify("Restarting clustering"),await Y$();break;case ot.HDB_PROCESS_SERVICES.clustering_config:case ot.HDB_PROCESS_SERVICES["clustering config"]:if(!Fp.get(ot.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=$$;break}Cs&&console.log("Restarting clustering_config"),Ki.notify("Restarting clustering_config"),await fi.reloadClustering();break;case"custom_functions":case"custom functions":case ot.HDB_PROCESS_SERVICES.harperdb:case ot.HDB_PROCESS_SERVICES.http_workers:case ot.HDB_PROCESS_SERVICES.http:if(Cs&&!Md){r=`Restart ${t} is not available from the CLI when running in non-pm2 mode. Either call restart ${t} from the API or stop and start HarperDB.`;break}Cs&&console.log("Restarting http_workers"),Ki.notify("Restarting http_workers"),Cs?await fi.restart(ot.PROCESS_DESCRIPTORS.HDB):await MS("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(Ki.error(r),Cs&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(Uw,"restartService");async function ude(){await Y$(),await fi.restart(ot.PROCESS_DESCRIPTORS.HDB),await vw.async_set_timeout(2e3),Fp.get(ot.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await Lw(),Cs&&(await DS.closeConnection(),process.exit(0))}a(ude,"restartPM2Mode");async function Y$(){if(!V$.getConfigFromFile(ot.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await G$.getHDBProcessInfo()).clustering.length===0)Ki.trace("Clustering not running, restart will start clustering services"),await LS.generateNatsConfig(!0),await fi.startClusteringProcesses(),await fi.startClusteringThreads(),await Lw(),Cs&&await DS.closeConnection();else{await LS.generateNatsConfig(!0),Md?(Ki.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await fi.restart(ot.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await fi.restart(ot.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await G$.getHDBProcessInfo()).clustering.forEach(s=>{Ki.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await vw.async_set_timeout(3e3),await Lw(),await DS.updateLocalStreams(),Cs&&await DS.closeConnection(),Ki.trace("Restart clustering restarting ingest and reply service threads");let t=MS(ot.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=MS(ot.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(Y$,"restartClustering");async function Lw(){await LS.removeNatsConfig(ot.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await LS.removeNatsConfig(ot.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(Lw,"removeNatsConfig")});var sV=I((mMe,nV)=>{"use strict";var hMe=require("lodash"),Cn=(H(),P(G)),{handleHDBError:z$,hdb_errors:dde}=pe(),{HDB_ERROR_MSGS:fde,HTTP_STATUS_CODES:_de}=dde,xw=W();nV.exports={getRolePermissions:hde};var Ml=Object.create(null),pde=a(e=>({key:e,perms:{}}),"perms_template_obj"),X$=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),Z$=a((e=!1,t=!1,r=!1,n=!1)=>({[Cn.PERMS_CRUD_ENUM.READ]:e,[Cn.PERMS_CRUD_ENUM.INSERT]:t,[Cn.PERMS_CRUD_ENUM.UPDATE]:r,[Cn.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),Bw=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...Z$(t,r,n,s)}),"table_perms_template"),j$=a((e,t=Z$())=>({attribute_name:e,describe:rV(t),[Gp]:t[Gp],[Hw]:t[Hw],[kw]:t[kw]}),"attr_perms_template"),J$=a((e,t=!1)=>({attribute_name:e,describe:t,[Gp]:t}),"timestamp_attr_perms_template"),{READ:Gp,INSERT:Hw,UPDATE:kw}=Cn.PERMS_CRUD_ENUM,eV=Object.values(Cn.PERMS_CRUD_ENUM),tV=[Gp,Hw,kw];function hde(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r={...global.hdb_schema};delete r[Cn.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(Ml[t]&&Ml[t].key===n)return Ml[t].perms;let s=mde(e,r);return Ml[t]?Ml[t].key=n:Ml[t]=pde(n),Ml[t].perms=s,s}catch(r){if(!e[Cn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[Cn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<Cn.PERMS_UPDATE_RELEASE_TIMESTAMP){let n=`Role permissions for role '${t}' must be updated to align with new structure from the 2.2.0 release.`;throw xw.error(n),xw.debug(r),z$(new Error,fde.OUTDATED_PERMS_TRANSLATION_ERROR,_de.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
28
+ ${r.stack}`;throw xw.error(n),z$(new Error)}}}a(hde,"getRolePermissions");function mde(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[Cn.SYSTEM_SCHEMA_NAME]=n[Cn.SYSTEM_SCHEMA_NAME],r.structure_user=n.structure_user;let s=Array.isArray(e.permission.structure_user)||e.permission.structure_user===!0?e.permission.structure_user:[];return Object.keys(t).forEach(i=>{if(s===!0||s.indexOf(i)>-1){r[i]=Ede(t[i]);return}r[i]=X$(),n[i]?(n[i].describe&&(r[i].describe=!0),Object.keys(t[i]).forEach(o=>{if(n[i].tables[o]){let c=n[i].tables[o],l=t[i][o],u=gde(c,l);r[i].describe||eV.forEach(f=>{u[f]&&(r[i].describe=!0)}),r[i].tables[o]=u}else r[i].tables[o]=Bw()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=Bw()})}),r}a(mde,"translateRolePermissions");function Ede(e){let t=X$(!0);return Object.keys(e).forEach(r=>{t.tables[r]=Bw(!0,!0,!0,!0,!0)}),t}a(Ede,"createStructureUserPermissions");function gde(e,t){let{attribute_permissions:r}=e;if(r?.length>0){let s={...e};s.attribute_permissions=[];let i=r.reduce((u,f)=>{let{attribute_name:d}=f,p=f;return Cn.TIME_STAMP_NAMES.includes(d)&&(p=J$(d,f[Gp])),u[d]=p,u},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=j$(o);return t.attributes.forEach(({attribute:u})=>{if(i[u]){let f=i[u];f.describe=rV(f),s.attribute_permissions.push(f),c||Sde(f,l)}else if(u!==o){let f;Cn.TIME_STAMP_NAMES.includes(u)?f=J$(u):f=j$(u),s.attribute_permissions.push(f)}}),c||s.attribute_permissions.push(l),s.describe=Q$(s),s}else return e.describe=Q$(e),e}a(gde,"getTableAttrPerms");function Q$(e){return eV.filter(t=>e[t]).length>0}a(Q$,"getSchemaTableDescribePerm");function rV(e){return tV.filter(t=>e[t]).length>0}a(rV,"getAttributeDescribePerm");function Sde(e,t){tV.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(Sde,"checkForHashPerms")});var qp={};Ue(qp,{authentication:()=>dV,bypassAuth:()=>Nde,login:()=>Ide,logout:()=>Cde,start:()=>wde});function Nde(){uV=!0}async function dV(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let _=e.isOperationsServer?yde?Rde:[]:Ade?Tde:[];if(_.includes(i)||_.includes("*")){if(e.method==="OPTIONS"){let h=ss.get(x.HTTP_CORSACCESSCONTROLALLOWHEADERS)??"Accept, Content-Type, Authorization",S=new bo([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers",h],["Access-Control-Allow-Origin",i]]);return vS&&S.set("Access-Control-Allow-Credentials","true"),{status:200,headers:S}}o.push("Access-Control-Allow-Origin",i),vS&&o.push("Access-Control-Allow-Credentials","true")}}let l,u;if(vS){i||(i=r.host);let _=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.split(/;\s+/)||[];for(let S of h)if(S.startsWith(_)){let g=S.indexOf(";");l=S.slice(_.length,g===-1?S.length:g),u=await iV.get(l);break}e.session=u||(u={})}let f=a((_,h,S)=>{let g=new vd.AuthAuditLog(_,h,ua.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);g.auth_strategy=S,l&&(g.session_id=l),r.referer&&(g.referer=r.referer),r.origin&&(g.origin=r.origin),h===Ws.SUCCESS?Fw.notify(g):Fw.error(g)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&Fw.error("Authorization error:",e._nodeRequest.socket.authorizationError),e.mtlsConfig&&e.authorized&&e.peerCertificate.subject){let _=e.mtlsConfig.user;_!==null?((_===void 0||_==="Common Name"||_==="CN")&&(_=e.peerCertificate.subject.CN),e.user=await We.getUser(_,null,e),f(_,Ws.SUCCESS,"mTLS")):(0,vd.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let d;if(!e.user)if(n){if(d=vl.get(n),!d){let _=n.indexOf(" "),h=n.slice(0,_),S=n.slice(_+1),g,R;try{switch(h){case"Basic":let E=atob(S),A=E.indexOf(":");g=E.slice(0,A),R=E.slice(A+1),d=g||R?await We.getUser(g,R,e):null;break;case"Bearer":try{d=await wO(S)}catch(N){if(N.message==="invalid token")try{return await ug(S),c({status:-1})}catch{throw N}}break}}catch(E){return Ode&&(vl.get(S)||(vl.set(S,S),f(g,Ws.FAILURE,h))),c({status:401,body:Ra({error:E.message},e)})}vl.set(n,d),bde&&f(d.username,Ws.SUCCESS,h)}e.user=d}else u?.user?e.user=await We.getUser(u.user,null,e):(uV&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,aV.getSuperUser)());vS&&(e.session.update=function(_){if(!l){l=(0,cV.v4)();let S=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${l}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",S):p?.headers?.set&&p.headers.set("Set-Cookie",S)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):p?.headers?.set&&(i&&p.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),p.headers.set("X-Hdb-Session","Secure"))),_.id=l,iV.put(_)},e.login=async function(_,h){let S=e.user=await We.authenticateUser(_,h,e);e.session.update({user:S&&(S.getId?.()??S.username)})});let p=await t(e);return p&&(p.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&Ni.loginPath?(p.status=302,p.headers.set("Location",Ni.loginPath(e))):p.headers.set("WWW-Authenticate","Basic")),c(p))}catch(l){throw c(l)}function c(l){let u=o.length;if(u>0){let f=l.headers;f||(l.headers=f=new bo);for(let d=0;d<u;){let p=o[d++];f.set(p,o[d++])}}return o=null,l}a(c,"applyResponseHeaders")}function wde({server:e,port:t,securePort:r}){e.http(dV,t||r?{port:t,securePort:r}:{port:"all"}),oV||(oV=!0,setInterval(()=>{vl=new Map},ss.get(x.AUTHENTICATION_CACHETTL)).unref(),lV.user.addListener(()=>{vl=new Map}))}async function Ide(e){if(!e.baseRequest?.login)throw new Error("No session for login");return e.baseResponse.headers.set=(t,r)=>{e.fastifyResponse.header(t,r)},await e.baseRequest.login(e.username,e.password??""),"Login successful"}async function Cde(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var aV,cV,ss,vd,lV,Fw,Tde,Ade,Rde,yde,iV,vS,uV,bde,Ode,vl,oV,US=be(()=>{aV=M(yn());Kr();Au();Qu();De();cV=require("uuid"),ss=M(ce());H();vd=M(W()),lV=M(O_());j_();co();Fw=(0,vd.loggerWithTag)("auth-event");ss.initSync();Tde=ss.get(x.HTTP_CORSACCESSLIST),Ade=ss.get(x.HTTP_CORS),Rde=ss.get(x.OPERATIONSAPI_NETWORK_CORSACCESSLIST),yde=ss.get(x.OPERATIONSAPI_NETWORK_CORS),iV=dt({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),vS=ss.get(x.AUTHENTICATION_ENABLESESSIONS)??!0,uV=process.env.AUTHENTICATION_AUTHORIZELOCAL??ss.get(x.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,bde=ss.get(x.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,Ode=ss.get(x.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,vl=new Map;We.onInvalidatedUser(()=>{vl=new Map});a(Nde,"bypassAuth");a(dV,"authentication");a(wde,"start");a(Ide,"login");a(Cde,"logout")});var gV=I((NMe,EV)=>{"use strict";var Ne=require("joi"),fV=require("fs-extra"),_V=require("path"),is=it(),pV=ce(),hV=(H(),P(G)),mV=W(),{hdb_errors:Pde}=pe(),{HDB_ERROR_MSGS:rn}=Pde,ko=/^[a-zA-Z0-9-_]+$/,Dde=/^[a-zA-Z0-9-_]+$/;EV.exports={getDropCustomFunctionValidator:Mde,setCustomFunctionValidator:vde,addComponentValidator:Hde,dropCustomFunctionProjectValidator:kde,packageComponentValidator:Fde,deployComponentValidator:Gde,setComponentFileValidator:Ude,getComponentFileValidator:Bde,dropComponentFileValidator:xde,addSSHKeyValidator:qde,updateSSHKeyValidator:$de,deleteSSHKeyValidator:Vde,setSSHKnownHostsValidator:Kde};function xS(e,t,r){try{let n=pV.get(hV.CONFIG_PARAMS.COMPONENTSROOT),s=_V.join(n,t);return fV.existsSync(s)?e?t:r.message(rn.PROJECT_EXISTS):e?r.message(rn.NO_PROJECT):t}catch(n){return mV.error(n),r.message(rn.VALIDATION_ERR)}}a(xS,"checkProjectExists");function $p(e,t){return e.includes("..")?t.message("Invalid file path"):e}a($p,"checkFilePath");function Lde(e,t,r,n){try{let s=pV.get(hV.CONFIG_PARAMS.COMPONENTSROOT),i=_V.join(s,e,t,r+".js");return fV.existsSync(i)?r:n.message(rn.NO_FILE)}catch(s){return mV.error(s),n.message(rn.VALIDATION_ERR)}}a(Lde,"checkFileExists");function Mde(e){let t=Ne.object({project:Ne.string().pattern(ko).custom(xS.bind(null,!0)).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().pattern(ko).custom(Lde.bind(null,e.project,e.type)).custom($p).required().messages({"string.pattern.base":rn.BAD_FILE_NAME})});return is.validateBySchema(e,t)}a(Mde,"getDropCustomFunctionValidator");function vde(e){let t=Ne.object({project:Ne.string().pattern(ko).custom(xS.bind(null,!0)).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().custom($p).required(),function_content:Ne.string().required()});return is.validateBySchema(e,t)}a(vde,"setCustomFunctionValidator");function Ude(e){let t=Ne.object({project:Ne.string().pattern(ko).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),file:Ne.string().custom($p).required(),payload:Ne.string().allow("").optional(),encoding:Ne.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return is.validateBySchema(e,t)}a(Ude,"setComponentFileValidator");function xde(e){let t=Ne.object({project:Ne.string().pattern(ko).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),file:Ne.string().custom($p).optional()});return is.validateBySchema(e,t)}a(xde,"dropComponentFileValidator");function Bde(e){let t=Ne.object({project:Ne.string().required(),file:Ne.string().custom($p).required(),encoding:Ne.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return is.validateBySchema(e,t)}a(Bde,"getComponentFileValidator");function Hde(e){let t=Ne.object({project:Ne.string().pattern(ko).custom(xS.bind(null,!1)).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME})});return is.validateBySchema(e,t)}a(Hde,"addComponentValidator");function kde(e){let t=Ne.object({project:Ne.string().pattern(ko).custom(xS.bind(null,!0)).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME})});return is.validateBySchema(e,t)}a(kde,"dropCustomFunctionProjectValidator");function Fde(e){let t=Ne.object({project:Ne.string().pattern(ko).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),skip_node_modules:Ne.boolean(),skip_symlinks:Ne.boolean()});return is.validateBySchema(e,t)}a(Fde,"packageComponentValidator");function Gde(e){let t=Ne.object({project:Ne.string().pattern(ko).required().messages({"string.pattern.base":rn.BAD_PROJECT_NAME}),package:Ne.string().optional(),restart:Ne.alternatives().try(Ne.boolean(),Ne.string().valid("rolling")).optional()});return is.validateBySchema(e,t)}a(Gde,"deployComponentValidator");function qde(e){let t=Ne.object({name:Ne.string().pattern(Dde).required().messages({"string.pattern.base":rn.BAD_SSH_KEY_NAME}),key:Ne.string().required(),host:Ne.string().required(),hostname:Ne.string().required(),known_hosts:Ne.string().optional()});return is.validateBySchema(e,t)}a(qde,"addSSHKeyValidator");function $de(e){let t=Ne.object({name:Ne.string().required(),key:Ne.string().required()});return is.validateBySchema(e,t)}a($de,"updateSSHKeyValidator");function Vde(e){let t=Ne.object({name:Ne.string().required()});return is.validateBySchema(e,t)}a(Vde,"deleteSSHKeyValidator");function Kde(e){let t=Ne.object({known_hosts:Ne.string().required()});return is.validateBySchema(e,t)}a(Kde,"setSSHKnownHostsValidator")});var Yp=I((IMe,yV)=>{"use strict";var BS=require("joi"),Ja=require("path"),Ud=require("fs-extra"),{exec:Yde,spawn:Wde}=require("child_process"),zde=require("util"),jde=zde.promisify(Yde),xd=(H(),P(G)),{PACKAGE_ROOT:Jde}=st(),{handleHDBError:Vp,hdb_errors:Qde}=pe(),{HTTP_STATUS_CODES:Kp}=Qde,Ul=ce(),Xde=it(),Qa=W(),{once:Zde}=require("events");Ul.initSync();var Gw=Ul.get(xd.CONFIG_PARAMS.COMPONENTSROOT),SV="npm install --force --omit=dev --json",efe=`${SV} --dry-run`,tfe=Ul.get(xd.CONFIG_PARAMS.ROOTPATH),HS=Ja.join(tfe,"ssh");yV.exports={installModules:ife,auditModules:ofe,installAllRootModules:rfe,uninstallRootModule:nfe,linkHarperdb:sfe,runCommand:Bd};async function rfe(e=!1,t=Ul.get(xd.CONFIG_PARAMS.ROOTPATH)){await kS();let r=!1,n=process.env;Ud.pathExistsSync(HS)&&Ud.readdirSync(HS).forEach(s=>{s.includes(".key")&&!r&&(n={GIT_SSH_COMMAND:"ssh -F "+Ja.join(HS,"config")+" -o UserKnownHostsFile="+Ja.join(HS,"known_hosts"),...process.env},r=!0)});try{let s=Ul.get(xd.CONFIG_PARAMS.ROOTPATH),i=Ja.join(s,"node_modules","harperdb");Ud.lstatSync(i).isSymbolicLink()&&Ud.unlinkSync(i)}catch(s){s.code!=="ENOENT"&&Qa.error("Error removing symlink:",s)}await Bd(e?"npm install --force --ignore-scripts --no-bin-links":"npm install --force --no-bin-links",t,n)}a(rfe,"installAllRootModules");async function nfe(e){await Bd(`npm uninstall ${e}`,Ul.get(xd.CONFIG_PARAMS.ROOTPATH))}a(nfe,"uninstallRootModule");async function sfe(){await kS(),await Bd(`npm link ${Jde}`,Ul.get(xd.CONFIG_PARAMS.ROOTPATH))}a(sfe,"linkHarperdb");async function Bd(e,t=void 0,r=process.env){Qa.debug({tagName:"npm_run_command"},`running command: \`${e}\``);let n=Wde(e,{shell:!0,cwd:t,env:r,stdio:["ignore","pipe","pipe"]}),s="",i="";n.stdout.on("data",c=>{let l=c.toString();Qa.debug({tagName:"npm_run_command:stdout"},l),s+=l}),n.stderr.on("data",c=>{let l=c.toString();Qa.error({tagName:"npm_run_command:stderr"},l),i+=l});let[o]=await Zde(n,"close");if(o!==0)throw new Error(`Command \`${e}\` exited with code ${o}.${i===""?"":` Error: ${i}`}`);return s||void 0}a(Bd,"runCommand");async function ife(e){let t="install_node_modules is deprecated. Dependencies are automatically installed on deploy, and install_node_modules can lead to inconsistent behavior";Qa.warn(t,e.projects);let r=RV(e);if(r)throw Vp(r,r.message,Kp.BAD_REQUEST);let{projects:n,dry_run:s}=e,i=s===!0?efe:SV;await kS(),await AV(n);let o={};for(let c=0,l=n.length;c<l;c++){let u=n[c];o[u]={npm_output:null,npm_error:null};let f=Ja.join(Gw,u),d,p=null;try{let{stdout:_,stderr:h}=await jde(i,{cwd:f});d=_?_.replace(`
29
29
  `,""):null,p=h?h.replace(`
30
- `,""):null}catch(_){_.stderr?o[u].npm_error=TV(_.stderr):o[u].npm_error=_.message;continue}try{o[u].npm_output=JSON.parse(d)}catch{o[u].npm_output=d}try{o[u].npm_error=JSON.parse(p)}catch{o[u].npm_error=p}}return Ja.info(`finished installModules with response ${o}`),o.warning=t,o}a(afe,"installModules");function TV(e){let t='"error": {',r=e.indexOf('"error": {'),n=e.indexOf(`}
31
- `);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(TV,"parseNPMStdErr");async function cfe(e){Ja.info(`starting auditModules for request: ${e}`);let t=RV(e);if(t)throw $p(t,t.message,Vp.BAD_REQUEST);let{projects:r}=e;await HS(),await AV(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=ja.join(Gw,o);n[o]={npm_output:null,npm_error:null};try{let l=await xd("npm audit --json",c);n[o].npm_output=JSON.parse(l)}catch(l){n[o].npm_error=TV(l.stderr)}}return Ja.info(`finished auditModules with response ${n}`),n}a(cfe,"auditModules");async function HS(){return await xd("npm -v"),!0}a(HS,"checkNPMInstalled");async function AV(e){if(!Array.isArray(e)||e.length===0)throw $p(new Error,"projects argument must be an array with at least 1 element",Vp.BAD_REQUEST,void 0,void 0,!0);let t=[],r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n],o=ja.join(Gw,i.toString());if(!await vd.pathExists(o)){t.push(i);continue}let l=ja.join(o,"package.json");await vd.pathExists(l)||r.push(i)}if(t.length>0)throw $p(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,Vp.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw $p(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,Vp.BAD_REQUEST,void 0,void 0,!0)}a(AV,"checkProjectPaths");function RV(e){let t=xS.object({projects:xS.array().min(1).items(xS.string()).required(),dry_run:xS.boolean().default(!1)});return efe.validateBySchema(e,t)}a(RV,"modulesValidator")});var $w=w((DMe,CV)=>{"use strict";var Cs=require("fs-extra"),Wp=require("path"),Yp=z(),bV=ie(),{PACKAGE_ROOT:lfe}=it(),qw=(H(),C(G)),IV=ae(),ufe=yt();CV.exports=dfe;async function dfe(){let e=ffe(),t=IV.get(qw.CONFIG_PARAMS.ROOTPATH),r=Wp.join(t,"package.json"),n={dependencies:{harperdb:"file:"+lfe}},s=Wp.join(t,"node_modules");Cs.ensureDirSync(s);let i,o=!0,c=!1;try{i=Cs.readJsonSync(r)}catch(l){if(bV.isEmptyOrZeroLength(e))return;if(l.code!==qw.NODE_ERROR_CODES.ENOENT)throw l;o=!1}if(!bV.isEmptyOrZeroLength(e)){for(let{name:l,package:u}of e){let f=NV(u);n.dependencies[l]=f+u}if(!o){Yp.notify("Installing components"),await wV(r,n,null),await OV(t,e);return}for(let{name:l,package:u}of e){let f=i.dependencies[l],d=NV(u);if(f===void 0||f!==d+u){c=!0;break}if(u.startsWith("file:"))try{if(Cs.statSync(new URL(u+"/package.json")).mtimeMs>Cs.statSync(r).mtimeMs){c=!0;break}}catch(p){Yp.info(`Error checking ${u}/package.json modification time`,p);break}}}for(let l in i.dependencies)n.dependencies[l]===void 0&&(Yp.notify("Removing component",l),c=!0);c&&(Yp.notify("Updating components."),await wV(r,n,i),await OV(t,e))}a(dfe,"installComponents");function OV(e,t){return Promise.all(t.map(({name:r})=>{let n=Wp.join(e,"node_modules",r),s=Wp.join(e,"components",r);if(Cs.existsSync(n)&&Cs.lstatSync(n).isDirectory())return Cs.move(n,s,{overwrite:!0}).then(()=>{Cs.symlink(s,n)})}))}a(OV,"moveModuleToComponents");function ffe(){let e=ufe.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(ffe,"getComponentsConfig");function NV(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":Wp.extname(e)||Cs.existsSync(e)?"file:":"github:"}a(NV,"getPkgPrefix");async function wV(e,t,r){Yp.trace("npm installing components package.json",t),Cs.writeFileSync(e,JSON.stringify(t,null," "));try{await Kp().installAllRootModules(IV.get(qw.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?Cs.writeFileSync(e,JSON.stringify(r,null," ")):Cs.unlinkSync(e),n}}a(wV,"installPackages")});var Vw={};ve(Vw,{packageDirectory:()=>_fe});function _fe(e,t={skip_node_modules:!1,skip_symlinks:!1}){return new Promise((r,n)=>{let s=[];DV.default.pack(e,{dereference:!t.skip_symlinks,ignore:t.skip_node_modules?i=>i.includes("node_modules")||i.includes((0,PV.join)("cache","webpack")):void 0}).pipe((0,LV.createGzip)()).on("data",i=>s.push(i)).on("end",()=>{r(Buffer.concat(s))}).on("error",n)})}var PV,DV,LV,Kw=be(()=>{PV=require("path"),DV=M(require("tar-fs")),LV=require("node:zlib");a(_fe,"packageDirectory")});var zw=w(xV=>{"use strict";var Oe=require("fs-extra"),Yw=require("fast-glob"),we=require("path"),pfe=require("tar-fs"),hfe=require("gunzip-maybe"),Ww=require("normalize-path"),Cn=gV(),Bt=z(),lt=(H(),C(G)),Qt=ae(),kS=yt(),mfe=ie(),{PACKAGE_ROOT:Efe}=it(),{handleHDBError:Ht,hdb_errors:gfe}=pe(),{basename:Sfe}=require("path"),Tfe=$w(),vV=ae(),{Readable:Afe}=require("stream"),{isMainThread:Rfe}=require("worker_threads"),{HDB_ERROR_MSGS:Ul,HTTP_STATUS_CODES:kt}=gfe,UV=rt(),{replicateOperation:fi}=(Xn(),C(wo)),{packageDirectory:yfe}=(Kw(),C(Vw)),MV=Kp(),bfe=we.join(Efe,"application-template"),Ofe=Qt.get(lt.CONFIG_PARAMS.ROOTPATH),Qa=we.join(Ofe,"ssh"),ko=we.join(Qa,"known_hosts");function Nfe(){Bt.trace("getting custom api status");let e={};try{e={port:Qt.get(lt.CONFIG_PARAMS.HTTP_PORT),directory:Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw Ht(new Error,Ul.FUNCTION_STATUS,kt.INTERNAL_SERVER_ERROR,Bt.ERR,t)}return e}a(Nfe,"customFunctionsStatus");function wfe(){Bt.trace("getting custom api endpoints");let e={},t=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT);try{Yw.sync(Ww(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:Yw.sync(Ww(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:Yw.sync(Ww(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw Ht(new Error,Ul.GET_FUNCTIONS,kt.INTERNAL_SERVER_ERROR,Bt.ERR,r)}return e}a(wfe,"getCustomFunctions");function Ife(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Cn.getDropCustomFunctionValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("getting custom api endpoint file content");let r=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=we.join(r,n,s,i+".js");try{return Oe.readFileSync(o,{encoding:"utf8"})}catch(c){throw Ht(new Error,Ul.GET_FUNCTION,kt.INTERNAL_SERVER_ERROR,Bt.ERR,c)}}a(Ife,"getCustomFunction");async function Cfe(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Cn.setCustomFunctionValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("setting custom function file content");let r=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{Oe.outputFileSync(we.join(r,n,s,i+".js"),o);let c=await fi(e);return c.message=`Successfully updated custom function: ${i}.js`,c}catch(c){throw Ht(new Error,Ul.SET_FUNCTION,kt.INTERNAL_SERVER_ERROR,Bt.ERR,c)}}a(Cfe,"setCustomFunction");async function Pfe(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Cn.getDropCustomFunctionValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("dropping custom function file");let r=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{Oe.unlinkSync(we.join(r,n,s,i+".js"));let o=await fi(e);return o.message=`Successfully deleted custom function: ${i}.js`,o}catch(o){throw Ht(new Error,Ul.DROP_FUNCTION,kt.INTERNAL_SERVER_ERROR,Bt.ERR,o)}}a(Pfe,"dropCustomFunction");async function Dfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Cn.addComponentValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("adding component");let r=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=we.join(r,n);Oe.mkdirSync(s,{recursive:!0}),Oe.copySync(bfe,s);let i=await fi(e);return i.message=`Successfully added project: ${n}`,i}catch(s){throw Ht(new Error,Ul.ADD_FUNCTION,kt.INTERNAL_SERVER_ERROR,Bt.ERR,s)}}a(Dfe,"addComponent");async function Lfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Cn.dropCustomFunctionProjectValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("dropping custom function project");let r=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=Qt.get(lt.CONFIG_PARAMS.APPS);if(!mfe.isEmptyOrZeroLength(s)){let i=!1;for(let[o,c]of s.entries())if(c.name===n){s.splice(o,1),i=!0;break}if(i)return kS.updateConfigValue(lt.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=we.join(r,n);Oe.rmSync(i,{recursive:!0});let o=await fi(e);return o.message=`Successfully deleted project: ${n}`,o}catch(i){throw Ht(new Error,Ul.DROP_FUNCTION_PROJECT,kt.INTERNAL_SERVER_ERROR,Bt.ERR,i)}}a(Lfe,"dropCustomFunctionProject");async function Mfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Cn.packageComponentValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let r=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;Bt.trace("packaging component",n);let s;try{s=await Oe.realpath(we.join(r,n))}catch(o){if(o.code!==lt.NODE_ERROR_CODES.ENOENT)throw o;try{s=await Oe.realpath(we.join(Qt.get(lt.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(c){if(c.code===lt.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}let i=(await yfe(s,e)).toString("base64");return{project:n,payload:i}}a(Mfe,"packageComponent");async function vfe(e){e.project?e.project=we.parse(e.project).name:e.package&&(e.project=Ufe(e.package));let t=Cn.deployComponentValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let r=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i,install_command:o}=e;if(Bt.trace("deploying component",n),!s&&!i)throw new Error("'payload' or 'package' must be provided");let c;if(s){c=we.join(r,n),i="file:"+c,await Oe.emptyDir(c);let S=Afe.from(s instanceof Buffer?s:Buffer.from(s,"base64"));await new Promise((E,T)=>{S.pipe(hfe()).pipe(pfe.extract(c,{finish:E})).on("error",T)});let g=await Oe.readdir(c);g.length===1&&g[0]==="package"&&(await Oe.copy(we.join(c,"package"),c),await Oe.remove(we.join(c,"package")));let R=we.join(c,"node_modules");o?await MV.runCommand(o,c):Oe.existsSync(R)||await MV.installAllRootModules(!1,c)}else{await kS.addConfig(n,{package:i}),await Tfe();let S=vV.get(lt.CONFIG_PARAMS.ROOTPATH);c=we.join(S,"node_modules",n)}if(Rfe)return;let l=new Map;l.isWorker=!0;let u=(jp(),C(zp)),f;u.setErrorReporter(S=>f=S);let d=Sfe(c),p=u.component_errors.get(d);try{await u.loadComponent(c,l)}finally{u.component_errors.set(d,p)}if(f)throw f;Bt.info("Installed component");let _=e.restart==="rolling";e.restart=_?!1:e.restart;let h=await fi(e);if(e.restart===!0)UV.restartWorkers("http"),h.message=`Successfully deployed: ${n}, restarting HarperDB`;else if(_){let g=await jw().executeJob({operation:"restart_service",service:"http",replicated:!0});h.restartJobId=g.job_id,h.message=`Successfully deployed: ${n}, restarting HarperDB`}else h.message=`Successfully deployed: ${n}`;return h}a(vfe,"deployComponent");function Ufe(e){if(e.startsWith("git+ssh://"))return we.basename(e.split("#")[0].replace(/\.git$/,""));if(e.startsWith("http://")||e.startsWith("https://"))return we.basename(new URL(e.replace(/\.git$/,"")).pathname);if(e.startsWith("file://"))try{let{name:t}=JSON.parse(Oe.readFileSync(we.join(e,"package.json"),"utf8"));return we.basename(t)}catch{}return we.basename(e)}a(Ufe,"getProjectNameFromPackage");async function xfe(){let e=a(async(s,i)=>{try{let o=await Oe.readdir(s,{withFileTypes:!0});for(let c of o){let l=c.name;if(l.startsWith(".")||l==="node_modules")continue;let u=we.join(s,l);if(c.isDirectory()||c.isSymbolicLink()){let f={name:l,entries:[]};i.entries.push(f),await e(u,f)}else{let f=await Oe.stat(u),d={name:we.basename(l),mtime:f.mtime,size:f.size};i.entries.push(d)}}return i}catch(o){return Bt.warn("Error loading package",o),{error:o.toString(),entries:[]}}},"walkDir"),t=await e(Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{name:Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT).split(we.sep).slice(-1).pop(),entries:[]}),n=(jp(),C(zp)).component_errors;for(let s of t.entries){let i=n.get(s.name);i?s.error=n.get(s.name):i===void 0&&(s.error="The component has not been loaded yet (may need a restart)")}return t}a(xfe,"getComponents");async function Bfe(e){let t=Cn.getComponentFileValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let n=kS.getConfigObj()[e.project]||e.project==="harperdb"?we.join(vV.get(lt.CONFIG_PARAMS.ROOTPATH),"node_modules"):Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await Oe.stat(we.join(n,e.project,e.file));return{message:await Oe.readFile(we.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===lt.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${we.join(e.project,e.file)}'`):i}}a(Bfe,"getComponentFile");async function Hfe(e){let t=Cn.setComponentFileValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=we.join(Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);e.payload!==void 0?(await Oe.ensureFile(n),await Oe.outputFile(n,e.payload,r)):await Oe.ensureDir(n);let s=await fi(e);return s.message="Successfully set component: "+e.file,s}a(Hfe,"setComponentFile");async function kfe(e){let t=Cn.dropComponentFileValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let{project:r,file:n}=e,s=e.file?we.join(r,n):r,i=we.join(Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),s),o=we.join(Qt.get(lt.CONFIG_PARAMS.ROOTPATH),"node_modules",r);await Oe.pathExists(o)&&await Oe.unlink(o),await Oe.pathExists(i)&&await Oe.remove(i);let c=we.join(Qt.get(lt.CONFIG_PARAMS.ROOTPATH),"package.json");if(await Oe.pathExists(c)){let u=JSON.parse(await Oe.readFile(c,"utf8"));u?.dependencies?.[r]&&delete u.dependencies[r],await Oe.writeFile(c,JSON.stringify(u,null,2),"utf8")}kS.deleteConfigFromFile([r]);let l=await fi(e);return e.restart===!0?(UV.restartWorkers("http"),l.message=`Successfully dropped: ${s}, restarting HarperDB`):l.message=`Successfully dropped: ${s}`,l}a(kfe,"dropComponent");async function Ffe(e){let t=Cn.addSSHKeyValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let{name:r,key:n,host:s,hostname:i,known_hosts:o}=e;Bt.trace("adding ssh key",r);let c=we.join(Qa,r+".key"),l=we.join(Qa,"config");if(await Oe.pathExists(c))throw new Error("Key already exists. Use update_ssh_key or delete_ssh_key and then add_ssh_key");await Oe.outputFile(c,n),await Oe.chmod(c,"0600");let u=`#${r}
30
+ `,""):null}catch(_){_.stderr?o[u].npm_error=TV(_.stderr):o[u].npm_error=_.message;continue}try{o[u].npm_output=JSON.parse(d)}catch{o[u].npm_output=d}try{o[u].npm_error=JSON.parse(p)}catch{o[u].npm_error=p}}return Qa.info(`finished installModules with response ${o}`),o.warning=t,o}a(ife,"installModules");function TV(e){let t='"error": {',r=e.indexOf('"error": {'),n=e.indexOf(`}
31
+ `);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(TV,"parseNPMStdErr");async function ofe(e){Qa.info(`starting auditModules for request: ${e}`);let t=RV(e);if(t)throw Vp(t,t.message,Kp.BAD_REQUEST);let{projects:r}=e;await kS(),await AV(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=Ja.join(Gw,o);n[o]={npm_output:null,npm_error:null};try{let l=await Bd("npm audit --json",c);n[o].npm_output=JSON.parse(l)}catch(l){n[o].npm_error=TV(l.stderr)}}return Qa.info(`finished auditModules with response ${n}`),n}a(ofe,"auditModules");async function kS(){return await Bd("npm -v"),!0}a(kS,"checkNPMInstalled");async function AV(e){if(!Array.isArray(e)||e.length===0)throw Vp(new Error,"projects argument must be an array with at least 1 element",Kp.BAD_REQUEST,void 0,void 0,!0);let t=[],r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n],o=Ja.join(Gw,i.toString());if(!await Ud.pathExists(o)){t.push(i);continue}let l=Ja.join(o,"package.json");await Ud.pathExists(l)||r.push(i)}if(t.length>0)throw Vp(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,Kp.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw Vp(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,Kp.BAD_REQUEST,void 0,void 0,!0)}a(AV,"checkProjectPaths");function RV(e){let t=BS.object({projects:BS.array().min(1).items(BS.string()).required(),dry_run:BS.boolean().default(!1)});return Xde.validateBySchema(e,t)}a(RV,"modulesValidator")});var $w=I((PMe,CV)=>{"use strict";var Ps=require("fs-extra"),zp=require("path"),Wp=W(),bV=ae(),{PACKAGE_ROOT:afe}=st(),qw=(H(),P(G)),IV=ce(),cfe=Rt();CV.exports=lfe;async function lfe(){let e=ufe(),t=IV.get(qw.CONFIG_PARAMS.ROOTPATH),r=zp.join(t,"package.json"),n={dependencies:{harperdb:"file:"+afe}},s=zp.join(t,"node_modules");Ps.ensureDirSync(s);let i,o=!0,c=!1;try{i=Ps.readJsonSync(r)}catch(l){if(bV.isEmptyOrZeroLength(e))return;if(l.code!==qw.NODE_ERROR_CODES.ENOENT)throw l;o=!1}if(!bV.isEmptyOrZeroLength(e)){for(let{name:l,package:u}of e){let f=NV(u);n.dependencies[l]=f+u}if(!o){Wp.notify("Installing components"),await wV(r,n,null),await OV(t,e);return}for(let{name:l,package:u}of e){let f=i.dependencies[l],d=NV(u);if(f===void 0||f!==d+u){c=!0;break}if(u.startsWith("file:"))try{if(Ps.statSync(new URL(u+"/package.json")).mtimeMs>Ps.statSync(r).mtimeMs){c=!0;break}}catch(p){Wp.info(`Error checking ${u}/package.json modification time`,p);break}}}for(let l in i.dependencies)n.dependencies[l]===void 0&&(Wp.notify("Removing component",l),c=!0);c&&(Wp.notify("Updating components."),await wV(r,n,i),await OV(t,e))}a(lfe,"installComponents");function OV(e,t){return Promise.all(t.map(({name:r})=>{let n=zp.join(e,"node_modules",r),s=zp.join(e,"components",r);if(Ps.existsSync(n)&&Ps.lstatSync(n).isDirectory())return Ps.move(n,s,{overwrite:!0}).then(()=>{Ps.symlink(s,n)})}))}a(OV,"moveModuleToComponents");function ufe(){let e=cfe.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(ufe,"getComponentsConfig");function NV(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":zp.extname(e)||Ps.existsSync(e)?"file:":"github:"}a(NV,"getPkgPrefix");async function wV(e,t,r){Wp.trace("npm installing components package.json",t),Ps.writeFileSync(e,JSON.stringify(t,null," "));try{await Yp().installAllRootModules(IV.get(qw.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?Ps.writeFileSync(e,JSON.stringify(r,null," ")):Ps.unlinkSync(e),n}}a(wV,"installPackages")});var Vw={};Ue(Vw,{packageDirectory:()=>dfe});function dfe(e,t={skip_node_modules:!1,skip_symlinks:!1}){return new Promise((r,n)=>{let s=[];DV.default.pack(e,{dereference:!t.skip_symlinks,ignore:t.skip_node_modules?i=>i.includes("node_modules")||i.includes((0,PV.join)("cache","webpack")):void 0}).pipe((0,LV.createGzip)()).on("data",i=>s.push(i)).on("end",()=>{r(Buffer.concat(s))}).on("error",n)})}var PV,DV,LV,Kw=be(()=>{PV=require("path"),DV=M(require("tar-fs")),LV=require("node:zlib");a(dfe,"packageDirectory")});var zw=I(xV=>{"use strict";var Oe=require("fs-extra"),Yw=require("fast-glob"),we=require("path"),ffe=require("tar-fs"),_fe=require("gunzip-maybe"),Ww=require("normalize-path"),Pn=gV(),Bt=W(),ct=(H(),P(G)),Jt=ce(),FS=Rt(),pfe=ae(),{PACKAGE_ROOT:hfe}=st(),{handleHDBError:Ht,hdb_errors:mfe}=pe(),{basename:Efe}=require("path"),gfe=$w(),vV=ce(),{Readable:Sfe}=require("stream"),{isMainThread:Tfe}=require("worker_threads"),{HDB_ERROR_MSGS:xl,HTTP_STATUS_CODES:kt}=mfe,UV=rt(),{replicateOperation:_i}=(Zn(),P(Io)),{packageDirectory:Afe}=(Kw(),P(Vw)),MV=Yp(),Rfe=we.join(hfe,"application-template"),yfe=Jt.get(ct.CONFIG_PARAMS.ROOTPATH),Xa=we.join(yfe,"ssh"),Fo=we.join(Xa,"known_hosts");function bfe(){Bt.trace("getting custom api status");let e={};try{e={port:Jt.get(ct.CONFIG_PARAMS.HTTP_PORT),directory:Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw Ht(new Error,xl.FUNCTION_STATUS,kt.INTERNAL_SERVER_ERROR,Bt.ERR,t)}return e}a(bfe,"customFunctionsStatus");function Ofe(){Bt.trace("getting custom api endpoints");let e={},t=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT);try{Yw.sync(Ww(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:Yw.sync(Ww(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:Yw.sync(Ww(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw Ht(new Error,xl.GET_FUNCTIONS,kt.INTERNAL_SERVER_ERROR,Bt.ERR,r)}return e}a(Ofe,"getCustomFunctions");function Nfe(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Pn.getDropCustomFunctionValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("getting custom api endpoint file content");let r=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=we.join(r,n,s,i+".js");try{return Oe.readFileSync(o,{encoding:"utf8"})}catch(c){throw Ht(new Error,xl.GET_FUNCTION,kt.INTERNAL_SERVER_ERROR,Bt.ERR,c)}}a(Nfe,"getCustomFunction");async function wfe(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Pn.setCustomFunctionValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("setting custom function file content");let r=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{Oe.outputFileSync(we.join(r,n,s,i+".js"),o);let c=await _i(e);return c.message=`Successfully updated custom function: ${i}.js`,c}catch(c){throw Ht(new Error,xl.SET_FUNCTION,kt.INTERNAL_SERVER_ERROR,Bt.ERR,c)}}a(wfe,"setCustomFunction");async function Ife(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Pn.getDropCustomFunctionValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("dropping custom function file");let r=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{Oe.unlinkSync(we.join(r,n,s,i+".js"));let o=await _i(e);return o.message=`Successfully deleted custom function: ${i}.js`,o}catch(o){throw Ht(new Error,xl.DROP_FUNCTION,kt.INTERNAL_SERVER_ERROR,Bt.ERR,o)}}a(Ife,"dropCustomFunction");async function Cfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Pn.addComponentValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("adding component");let r=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=we.join(r,n);Oe.mkdirSync(s,{recursive:!0}),Oe.copySync(Rfe,s);let i=await _i(e);return i.message=`Successfully added project: ${n}`,i}catch(s){throw Ht(new Error,xl.ADD_FUNCTION,kt.INTERNAL_SERVER_ERROR,Bt.ERR,s)}}a(Cfe,"addComponent");async function Pfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Pn.dropCustomFunctionProjectValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("dropping custom function project");let r=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=Jt.get(ct.CONFIG_PARAMS.APPS);if(!pfe.isEmptyOrZeroLength(s)){let i=!1;for(let[o,c]of s.entries())if(c.name===n){s.splice(o,1),i=!0;break}if(i)return FS.updateConfigValue(ct.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=we.join(r,n);Oe.rmSync(i,{recursive:!0});let o=await _i(e);return o.message=`Successfully deleted project: ${n}`,o}catch(i){throw Ht(new Error,xl.DROP_FUNCTION_PROJECT,kt.INTERNAL_SERVER_ERROR,Bt.ERR,i)}}a(Pfe,"dropCustomFunctionProject");async function Dfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Pn.packageComponentValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let r=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;Bt.trace("packaging component",n);let s;try{s=await Oe.realpath(we.join(r,n))}catch(o){if(o.code!==ct.NODE_ERROR_CODES.ENOENT)throw o;try{s=await Oe.realpath(we.join(Jt.get(ct.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(c){if(c.code===ct.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}let i=(await Afe(s,e)).toString("base64");return{project:n,payload:i}}a(Dfe,"packageComponent");async function Lfe(e){e.project?e.project=we.parse(e.project).name:e.package&&(e.project=Mfe(e.package));let t=Pn.deployComponentValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let r=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i,install_command:o}=e;if(Bt.trace("deploying component",n),!s&&!i)throw new Error("'payload' or 'package' must be provided");let c;if(s){c=we.join(r,n),i="file:"+c,await Oe.emptyDir(c);let S=Sfe.from(s instanceof Buffer?s:Buffer.from(s,"base64"));await new Promise((E,A)=>{S.pipe(_fe()).pipe(ffe.extract(c,{finish:E})).on("error",A)});let g=await Oe.readdir(c);g.length===1&&g[0]==="package"&&(await Oe.copy(we.join(c,"package"),c),await Oe.remove(we.join(c,"package")));let R=we.join(c,"node_modules");o?await MV.runCommand(o,c):Oe.existsSync(R)||await MV.installAllRootModules(!1,c)}else{await FS.addConfig(n,{package:i}),await gfe();let S=vV.get(ct.CONFIG_PARAMS.ROOTPATH);c=we.join(S,"node_modules",n)}if(Tfe)return;let l=new Map;l.isWorker=!0;let u=(Jp(),P(jp)),f;u.setErrorReporter(S=>f=S);let d=Efe(c),p=u.component_errors.get(d);try{await u.loadComponent(c,l)}finally{u.component_errors.set(d,p)}if(f)throw f;Bt.info("Installed component");let _=e.restart==="rolling";e.restart=_?!1:e.restart;let h=await _i(e);if(e.restart===!0)UV.restartWorkers("http"),h.message=`Successfully deployed: ${n}, restarting HarperDB`;else if(_){let g=await jw().executeJob({operation:"restart_service",service:"http",replicated:!0});h.restartJobId=g.job_id,h.message=`Successfully deployed: ${n}, restarting HarperDB`}else h.message=`Successfully deployed: ${n}`;return h}a(Lfe,"deployComponent");function Mfe(e){if(e.startsWith("git+ssh://"))return we.basename(e.split("#")[0].replace(/\.git$/,""));if(e.startsWith("http://")||e.startsWith("https://"))return we.basename(new URL(e.replace(/\.git$/,"")).pathname);if(e.startsWith("file://"))try{let{name:t}=JSON.parse(Oe.readFileSync(we.join(e,"package.json"),"utf8"));return we.basename(t)}catch{}return we.basename(e)}a(Mfe,"getProjectNameFromPackage");async function vfe(){let e=a(async(s,i)=>{try{let o=await Oe.readdir(s,{withFileTypes:!0});for(let c of o){let l=c.name;if(l.startsWith(".")||l==="node_modules")continue;let u=we.join(s,l);if(c.isDirectory()||c.isSymbolicLink()){let f={name:l,entries:[]};i.entries.push(f),await e(u,f)}else{let f=await Oe.stat(u),d={name:we.basename(l),mtime:f.mtime,size:f.size};i.entries.push(d)}}return i}catch(o){return Bt.warn("Error loading package",o),{error:o.toString(),entries:[]}}},"walkDir"),t=await e(Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{name:Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT).split(we.sep).slice(-1).pop(),entries:[]}),n=(Jp(),P(jp)).component_errors;for(let s of t.entries){let i=n.get(s.name);i?s.error=n.get(s.name):i===void 0&&(s.error="The component has not been loaded yet (may need a restart)")}return t}a(vfe,"getComponents");async function Ufe(e){let t=Pn.getComponentFileValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let n=FS.getConfigObj()[e.project]||e.project==="harperdb"?we.join(vV.get(ct.CONFIG_PARAMS.ROOTPATH),"node_modules"):Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await Oe.stat(we.join(n,e.project,e.file));return{message:await Oe.readFile(we.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===ct.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${we.join(e.project,e.file)}'`):i}}a(Ufe,"getComponentFile");async function xfe(e){let t=Pn.setComponentFileValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=we.join(Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);e.payload!==void 0?(await Oe.ensureFile(n),await Oe.outputFile(n,e.payload,r)):await Oe.ensureDir(n);let s=await _i(e);return s.message="Successfully set component: "+e.file,s}a(xfe,"setComponentFile");async function Bfe(e){let t=Pn.dropComponentFileValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let{project:r,file:n}=e,s=e.file?we.join(r,n):r,i=we.join(Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),s),o=we.join(Jt.get(ct.CONFIG_PARAMS.ROOTPATH),"node_modules",r);await Oe.pathExists(o)&&await Oe.unlink(o),await Oe.pathExists(i)&&await Oe.remove(i);let c=we.join(Jt.get(ct.CONFIG_PARAMS.ROOTPATH),"package.json");if(await Oe.pathExists(c)){let u=JSON.parse(await Oe.readFile(c,"utf8"));u?.dependencies?.[r]&&delete u.dependencies[r],await Oe.writeFile(c,JSON.stringify(u,null,2),"utf8")}FS.deleteConfigFromFile([r]);let l=await _i(e);return e.restart===!0?(UV.restartWorkers("http"),l.message=`Successfully dropped: ${s}, restarting HarperDB`):l.message=`Successfully dropped: ${s}`,l}a(Bfe,"dropComponent");async function Hfe(e){let t=Pn.addSSHKeyValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let{name:r,key:n,host:s,hostname:i,known_hosts:o}=e;Bt.trace("adding ssh key",r);let c=we.join(Xa,r+".key"),l=we.join(Xa,"config");if(await Oe.pathExists(c))throw new Error("Key already exists. Use update_ssh_key or delete_ssh_key and then add_ssh_key");await Oe.outputFile(c,n),await Oe.chmod(c,"0600");let u=`#${r}
32
32
  Host ${s}
33
33
  HostName ${i}
34
34
  User git
35
35
  IdentityFile ${c}
36
36
  IdentitiesOnly yes`;await Oe.pathExists(l)?await Oe.appendFile(l,`
37
- `+u):await Oe.outputFile(l,u);let f="";if(await Oe.pathExists(ko)||(await Oe.writeFile(ko,""),await Oe.chmod(ko,"0600")),i=="github.com"&&!(await Oe.readFile(ko,"utf8")).includes("github.com"))try{let S=(await(await fetch("https://api.github.com/meta")).json()).ssh_keys;for(let g of S)Oe.appendFile(ko,"github.com "+g+`
38
- `)}catch{f=". Unable to get known hosts from github.com. Set your known hosts manually using set_ssh_known_hosts."}o&&await Oe.appendFile(ko,o);let d=await fi(e);return d.message=`Added ssh key: ${r}${f}`,d}a(Ffe,"addSSHKey");async function Gfe(e){let t=Cn.updateSSHKeyValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let{name:r,key:n}=e;Bt.trace("updating ssh key",r);let s=we.join(Qa,r+".key");if(!await Oe.pathExists(s))throw new Error("Key does not exist. Use add_ssh_key");await Oe.outputFile(s,n);let i=await fi(e);return i.message=`Updated ssh key: ${r}`,i}a(Gfe,"updateSSHKey");async function qfe(e){let t=Cn.deleteSSHKeyValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let{name:r}=e;Bt.trace("deleting ssh key",r);let n=we.join(Qa,r+".key"),s=we.join(Qa,"config");if(!await Oe.pathExists(n))throw new Error("Key does not exist");let i=await Oe.readFile(s,"utf8"),o=new RegExp(`#${r}[\\S\\s]*?IdentitiesOnly yes`,"g");i=i.replace(o,""),await Oe.outputFile(s,i),Oe.removeSync(n);let c=await fi(e);return c.message=`Deleted ssh key: ${r}`,c}a(qfe,"deleteSSHKey");async function $fe(e){let t=[];return await Oe.pathExists(Qa)&&(await Oe.readdir(Qa)).forEach(r=>{r!="known_hosts"&&r!="config"&&t.push({name:r.split(".")[0]})}),t}a($fe,"listSSHKeys");async function Vfe(e){let t=Cn.setSSHKnownHostsValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let{known_hosts:r}=e;await Oe.outputFile(ko,r);let n=await fi(e);return n.message="Known hosts successfully set",n}a(Vfe,"setSSHKnownHosts");async function Kfe(e){return await Oe.pathExists(ko)?{known_hosts:await Oe.readFile(ko,"utf8")}:{known_hosts:null}}a(Kfe,"getSSHKnownHosts");Object.assign(xV,{customFunctionsStatus:Nfe,getCustomFunctions:wfe,getCustomFunction:Ife,setCustomFunction:Cfe,dropCustomFunction:Pfe,addComponent:Dfe,dropCustomFunctionProject:Lfe,packageComponent:Mfe,deployComponent:vfe,getComponents:xfe,getComponentFile:Bfe,setComponentFile:Hfe,dropComponent:kfe,addSSHKey:Ffe,updateSSHKey:Gfe,deleteSSHKey:qfe,listSSHKeys:$fe,setSSHKnownHosts:Vfe,getSSHKnownHosts:Kfe})});var Jw=w((xMe,HV)=>{"use strict";var Ps=require("joi"),BV=ot();HV.exports={readTransactionLogValidator:Yfe,deleteTransactionLogsBeforeValidator:Wfe};function Yfe(e){let t=Ps.object({schema:Ps.string(),database:Ps.string(),table:Ps.string().required(),from:Ps.date().timestamp(),to:Ps.date().timestamp(),limit:Ps.number().min(1)});return BV.validateBySchema(e,t)}a(Yfe,"readTransactionLogValidator");function Wfe(e){let t=Ps.object({schema:Ps.string(),database:Ps.string(),table:Ps.string().required(),timestamp:Ps.date().timestamp().required()});return BV.validateBySchema(e,t)}a(Wfe,"deleteTransactionLogsBeforeValidator")});var qS=w((HMe,VV)=>{"use strict";var Qw=(H(),C(G)),Jp=ir(),kV=ie(),FV=ae(),GV=Eo(),qV=z(),{handleHDBError:FS,hdb_errors:zfe}=pe(),{HTTP_STATUS_CODES:GS}=zfe,{readTransactionLogValidator:jfe,deleteTransactionLogsBeforeValidator:Jfe}=Jw(),$V=Vn(),Qfe="Logs successfully deleted from transaction log.",Xfe="All logs successfully deleted from transaction log.";VV.exports={readTransactionLog:Zfe,deleteTransactionLogsBefore:t_e};async function Zfe(e){let t=jfe(e);if(t)throw FS(t,t.message,GS.BAD_REQUEST,void 0,void 0,!0);e.database=e.database??e.schema??"data";let r=kV.checkSchemaTableExist(e.database,e.table);if(r)throw FS(new Error,r,GS.NOT_FOUND,void 0,void 0,!0);return FV.get(Qw.CONFIG_PARAMS.CLUSTERING_ENABLED)?await e_e(e):(qV.info("Reading HarperDB logs used by Plexus"),(e.from||e.to)&&(e.search_type="timestamp",e.search_values=[e.from??0],e.to&&(e.search_values[1]=e.to)),$V.readAuditLog(e))}a(Zfe,"readTransactionLog");async function*e_e(e){let t=GV.createNatsTableStreamName(e.database,e.table),r=await Jp.viewStreamIterator(t,parseInt(e.from),e.limit);for await(let n of r){let s=Math.floor(n?.nats_timestamp/1e6);if(e.to&&s>e.to)break;let i={operation:n?.entry?.operation,user:n?.entry?.__origin?.user,timestamp:s,records:n?.entry?.records,attributes:n?.entry?.attributes};n?.entry?.operation===Qw.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(e_e,"readTransactionLogNats");async function t_e(e){let t=Jfe(e);if(t)throw FS(t,t.message,GS.BAD_REQUEST,void 0,void 0,!0);if(e.database=e.database??e.schema??"data",!FV.get(Qw.CONFIG_PARAMS.CLUSTERING_ENABLED))return qV.info("Delete transaction logs called for Plexus"),$V.deleteAuditLogsBefore(e);let{database:r,table:n,timestamp:s}=e,i=kV.checkSchemaTableExist(r,n);if(i)throw FS(new Error,i,GS.NOT_FOUND,void 0,void 0,!0);let o=GV.createNatsTableStreamName(r,n),{jsm:c}=await Jp.getNATSReferences(),l=await Jp.getStreamInfo(o),u=new Date(l.state.first_ts).getTime();if(s<=u)return`No transactions exist before: ${s}`;let f=Qfe,d,p=new Date(l.state.last_ts).getTime();return s>p?(d=l.state.last_seq+1,f=Xfe):d=(await Jp.viewStream(o,parseInt(s),1))[0].nats_sequence,await Jp.purgeTableStream(r,n,{seq:d}),f}a(t_e,"deleteTransactionLogsBefore")});var YV=w((FMe,KV)=>{"use strict";var Xw=class{static{a(this,"PermissionTableResponseObject")}constructor(t,r,n=[],s=[]){this.schema=t,this.table=r,this.required_table_permissions=n,this.required_attribute_permissions=s}};KV.exports=Xw});var zV=w((qMe,WV)=>{"use strict";var Zw=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};WV.exports=Zw});var tI=w((VMe,JV)=>{"use strict";var jV=YV(),r_e=zV(),{HDB_ERROR_MSGS:n_e}=xn(),eI=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=n_e.OP_AUTH_PERMS_ERROR,this.unauthorized_access={},this.invalid_schema_items=[]}handleUnauthorizedItem(t){return this.invalid_schema_items=[],this.unauthorized_access=[t],this}handleInvalidItem(t){return this.invalid_schema_items=[t],this.unauthorized_access=[],this}addInvalidItem(t,r,n){if(r&&n){let s=`${r}_${n}`;if(this.unauthorized_access[s])return}this.invalid_schema_items.push(t)}addUnauthorizedTable(t,r,n){let s=new jV(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let l=new r_e(c,s[c]);i.push(l)});let o=`${r}_${n}`;if(this.unauthorized_access[o])this.unauthorized_access[o].required_attribute_permissions=i;else{let c=new jV(r,n,[],i);this.unauthorized_access[o]=c}}getPermsResponse(){let t=Object.values(this.unauthorized_access);return t.length>0||this.invalid_schema_items.length>0?(this.unauthorized_access=t,this):null}};JV.exports=eI});var YS=w((zMe,_1)=>{"use strict";var rI=yn(),$S=Yr(),Ds=Kg(),Zp=go(),nI=zc(),s_e=ON(),i_e=fG(),eh=Rn(),VS=F_(),Tr=z(),o_e=PN(),a_e=Sd(),c_e=tw(),l_e=sS(),u_e=sw(),d_e=iw(),f_e=cS(),__e=uS(),sI=dS(),Fo=ie(),p_e=Vq(),iI=mS(),ZV=za(),rn=(H(),C(G)),e1=sV(),h_e=Po(),t1=(Ju(),C(X_)),r1=(vS(),C(Gp)),n1=yt(),ur=zw(),m_e=require("alasql"),s1=qS(),i1=Kp(),Bd=Zn(),o1=(bl(),C(yl)),a1=tI(),{handleHDBError:Pn,hdb_errors:c1}=pe(),{addNodeBack:YMe,removeNodeBack:WMe}=(bl(),C(yl)),{HDB_ERROR_MSGS:xr,HTTP_STATUS_CODES:Qp}=c1,X=new Map,l1="delete",Xa="insert",Go="read",xl="update",Xp="describe",QV=Zp.describeSchema.name,XV=Zp.describeTable.name,u1={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},E_e={insert:!0,delete:!0,deleteRecord:!0,update:!0,updateData:!0,upsert:!0,upsertData:!0},g_e="catchup",S_e="handleGetJob",T_e="handleGetJobsByStartDate",KS={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},A_e=[Ds.createTable.name,Ds.createAttribute.name,Ds.dropTable.name,Ds.dropAttribute.name],d1={EXPORT_TO_S3:"export_to_s3",EXPORT_LOCAL:"export_local"},re=class{static{a(this,"permission")}constructor(t,r){this.requires_su=t,this.perms=r}};X.set(rI.insert.name,new re(!1,[Xa]));X.set(rI.update.name,new re(!1,[xl]));X.set(rI.upsert.name,new re(!1,[Xa,xl]));X.set($S.searchByConditions.name,new re(!1,[Go]));X.set($S.searchByHash.name,new re(!1,[Go]));X.set($S.searchByValue.name,new re(!1,[Go]));X.set($S.search.name,new re(!1,[Go]));X.set(Ds.createSchema.name,new re(!0,[]));X.set(Ds.createTable.name,new re(!0,[]));X.set(Ds.createAttribute.name,new re(!1,[Xa]));X.set(Ds.dropSchema.name,new re(!0,[]));X.set(Ds.dropTable.name,new re(!0,[]));X.set(Ds.dropAttribute.name,new re(!0,[]));X.set(Zp.describeSchema.name,new re(!1,[Go]));X.set(Zp.describeTable.name,new re(!1,[Go]));X.set(nI.deleteRecord.name,new re(!1,[l1]));X.set(eh.addUser.name,new re(!0,[]));X.set(eh.alterUser.name,new re(!0,[]));X.set(eh.dropUser.name,new re(!0,[]));X.set(eh.listUsersExternal.name,new re(!0,[]));X.set(VS.listRoles.name,new re(!0,[]));X.set(VS.addRole.name,new re(!0,[]));X.set(VS.alterRole.name,new re(!0,[]));X.set(VS.dropRole.name,new re(!0,[]));X.set(o_e.name,new re(!0,[]));X.set(a_e.name,new re(!0,[]));X.set(c_e.name,new re(!0,[]));X.set(l_e.name,new re(!0,[]));X.set(u_e.name,new re(!0,[]));X.set(d_e.name,new re(!0,[]));X.set(sI.setRoutes.name,new re(!0,[]));X.set(sI.getRoutes.name,new re(!0,[]));X.set(sI.deleteRoutes.name,new re(!0,[]));X.set(n1.setConfiguration.name,new re(!0,[]));X.set(f_e.clusterStatus.name,new re(!0,[]));X.set(__e.name,new re(!0,[]));X.set(iI.getFingerprint.name,new re(!0,[]));X.set(iI.setLicense.name,new re(!0,[]));X.set(nI.deleteFilesBefore.name,new re(!0,[]));X.set(nI.deleteAuditLogsBefore.name,new re(!0,[]));X.set(ZV.restart.name,new re(!0,[]));X.set(ZV.restartService.name,new re(!0,[]));X.set(s_e.name,new re(!0,[]));X.set(i_e.name,new re(!0,[Go]));X.set(h_e.systemInformation.name,new re(!0,[]));X.set(n1.getConfiguration.name,new re(!0,[]));X.set(s1.readTransactionLog.name,new re(!0,[]));X.set(s1.deleteTransactionLogsBefore.name,new re(!0,[]));X.set(i1.installModules.name,new re(!0,[]));X.set(i1.auditModules.name,new re(!0,[]));X.set(Bd.createCsr.name,new re(!0,[]));X.set(Bd.signCertificate.name,new re(!0,[]));X.set(Bd.listCertificates.name,new re(!0,[]));X.set(Bd.addCertificate.name,new re(!0,[]));X.set(Bd.removeCertificate.name,new re(!0,[]));X.set(Bd.getKey.name,new re(!0,[]));X.set(o1.addNodeBack.name,new re(!0,[]));X.set(o1.removeNodeBack.name,new re(!0,[]));X.set(t1.createTokens.name,new re(!1,[]));X.set(t1.refreshOperationToken.name,new re(!1,[]));X.set(r1.login.name,new re(!1,[]));X.set(r1.logout.name,new re(!1,[]));X.set(ur.customFunctionsStatus.name,new re(!0,[]));X.set(ur.getCustomFunctions.name,new re(!0,[]));X.set(ur.getComponents.name,new re(!0,[]));X.set(ur.getComponentFile.name,new re(!0,[]));X.set(ur.setComponentFile.name,new re(!0,[]));X.set(ur.dropComponent.name,new re(!0,[]));X.set(ur.getCustomFunction.name,new re(!0,[]));X.set(ur.setCustomFunction.name,new re(!0,[]));X.set(ur.dropCustomFunction.name,new re(!0,[]));X.set(ur.addComponent.name,new re(!0,[]));X.set(ur.dropCustomFunctionProject.name,new re(!0,[]));X.set(ur.packageComponent.name,new re(!0,[]));X.set(ur.deployComponent.name,new re(!0,[]));X.set(ur.addSSHKey.name,new re(!0,[]));X.set(ur.updateSSHKey.name,new re(!0,[]));X.set(ur.deleteSSHKey.name,new re(!0,[]));X.set(ur.listSSHKeys.name,new re(!0,[]));X.set(ur.setSSHKnownHosts.name,new re(!0,[]));X.set(ur.getSSHKnownHosts.name,new re(!0,[]));X.set(iI.getRegistrationInfo.name,new re(!1,[]));X.set(eh.userInfo.name,new re(!1,[]));X.set(Zp.describeAll.name,new re(!1,[]));X.set(S_e,new re(!1,[]));X.set(T_e,new re(!0,[]));X.set(g_e,new re(!0,[]));X.set(KS.CSV_DATA_LOAD,new re(!1,[Xa,xl]));X.set(KS.CSV_URL_LOAD,new re(!1,[Xa,xl]));X.set(KS.CSV_FILE_LOAD,new re(!1,[Xa,xl]));X.set(KS.IMPORT_FROM_S3,new re(!1,[Xa,xl]));X.set(d1.EXPORT_TO_S3,new re(!0,[]));X.set(d1.EXPORT_LOCAL,new re(!0,[]));X.set(rn.VALID_SQL_OPS_ENUM.DELETE,new re(!1,[l1]));X.set(rn.VALID_SQL_OPS_ENUM.SELECT,new re(!1,[Go]));X.set(rn.VALID_SQL_OPS_ENUM.INSERT,new re(!1,[Xa]));X.set(rn.VALID_SQL_OPS_ENUM.UPDATE,new re(!1,[xl]));_1.exports={verifyPerms:y_e,verifyPermsAst:R_e,verifyBulkLoadAttributePerms:O_e};function R_e(e,t,r){if(Fo.isEmptyOrZeroLength(e))throw Tr.info("verify_perms_ast has an empty user parameter"),Pn(new Error);if(Fo.isEmptyOrZeroLength(t))throw Tr.info("verify_perms_ast has an empty user parameter"),Pn(new Error);if(Fo.isEmptyOrZeroLength(r))throw Tr.info("verify_perms_ast has a null operation parameter"),Pn(new Error);try{let n=new a1,s=new p_e(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw Tr.info("No schemas defined in verifyPermsAst(), will not continue."),Pn(new Error);let c=!!t.role.permission.super_user,l=i.includes("system");if(l&&u1[r])throw Pn(new Error,xr.DROP_SYSTEM,Qp.FORBIDDEN);if(c&&!l)return null;let u=e1.getRolePermissions(t.role);t.role.permission=u,!c&&e instanceof m_e.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(u));for(let d=0;d<i.length;d++){let p=s.getTablesBySchemaName(i[d]);p&&o.set(i[d],p)}let f=f1(t,r,o,n);return f||(o.forEach((d,p)=>{for(let _=0;_<d.length;_++){let h=s.getAttributesBySchemaTableName(p,d[_]),S=aI(t.role.permission,p,d[_]);oI(h,S,r,d[_],p,n)}}),n.getPermsResponse())}catch(n){throw Pn(n)}}a(R_e,"verifyPermsAst");function y_e(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw Tr.info("null required parameter in verifyPerms"),Pn(new Error,xr.DEFAULT_INVALID_REQUEST,Qp.BAD_REQUEST);let r;t instanceof Function?r=t.name:r=t;let n=e.action,s=e.schema??e.database,i=e.table,o=new Map;s&&i&&o.set(s,[i]);let c=new a1;if(Fo.isEmptyOrZeroLength(e.hdb_user?.role)||Fo.isEmptyOrZeroLength(e.hdb_user?.role?.permission))return Tr.info(`User ${e.hdb_user?.username} has no role or permissions. Please assign the user a valid role.`),c.handleUnauthorizedItem(xr.USER_HAS_NO_PERMS(e.hdb_user?.username));let l=!!e.hdb_user?.role?.permission?.super_user,u=e.hdb_user?.role?.permission?.structure_user,f=o.has(rn.SYSTEM_SCHEMA_NAME)||s===rn.SYSTEM_SCHEMA_NAME;if(l&&f&&E_e[e.operation]&&(i===rn.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME||i===rn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||i===rn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME))return null;if(f&&u1[r])throw Pn(new Error,xr.DROP_SYSTEM,Qp.FORBIDDEN);if(l&&!f||u===!0&&(r===Ds.createSchema.name||r===Ds.dropSchema.name))return null;if(A_e.indexOf(r)>=0&&(u===!0||Array.isArray(u)))return u===!0||u.indexOf(s)>=0?null:c.handleUnauthorizedItem(`User does not have access to perform '${e.operation}' against schema '${s}'`);let d=e1.getRolePermissions(e.hdb_user?.role);if(e.hdb_user?.role&&(e.hdb_user.role.permission=d),(r===QV||r===XV)&&!d.super_user){if(s===rn.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(xr.SCHEMA_PERM_ERROR(s));if(r===QV&&(!d[s]||!d[s][Xp]))return c.handleInvalidItem(xr.SCHEMA_NOT_FOUND(s));if(r===XV&&(!d[s]||!d[s].tables[i]||!d[s].tables[i][Xp]))return c.handleInvalidItem(xr.TABLE_NOT_FOUND(s,i))}let p=f1(e.hdb_user,r,o,c,n);if(p)return p;if(X.get(r)&&X.get(r).perms.length===0)return null;if(!l&&e.get_attributes&&rn.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let S=[],g=d[s].tables[i];g[rn.PERMS_CRUD_ENUM.READ]&&(g.attribute_permissions.length>0?g.attribute_permissions.filter(E=>E[rn.PERMS_CRUD_ENUM.READ]).forEach(E=>{S.push(E.attribute_name)}):S=global.hdb_schema[s][i].attributes.map(R=>R.attribute),e.get_attributes=S)}let _=b_e(e),h=aI(e.hdb_user?.role?.permission,s,i);return oI(_,h,r,i,s,c,n),c.getPermsResponse()}a(y_e,"verifyPerms");function f1(e,t,r,n,s){if(Fo.arrayHasEmptyValues([e,t,r]))throw Tr.info("hasPermissions has an invalid parameter"),Pn(new Error);let i=r.has("system"),o=e.role.permission;if(o.super_user&&(!i||X.get(t).requires_su))return null;if(!X.get(t))throw Tr.info(`operation ${t} not found.`),Pn(new Error,xr.OP_NOT_FOUND(t),Qp.BAD_REQUEST);if(X.get(t)&&X.get(t).requires_su)return Tr.info(`operation ${t} requires SU permissions.`),n.handleUnauthorizedItem(xr.OP_IS_SU_ONLY(t));let c=r.keys();for(let l of c){try{if(l&&!o[l]||o[l][Xp]===!1){n.addInvalidItem(xr.SCHEMA_NOT_FOUND(l));continue}}catch{n.addInvalidItem(xr.SCHEMA_NOT_FOUND(l));continue}let u=r.get(l);for(let f of u){let d=o[l].tables[f];if(!d||d[Xp]===!1)n.addInvalidItem(xr.TABLE_NOT_FOUND(l,f));else try{let p=[],_=X.get(t).perms;!Fo.isEmpty(s)&&_.includes(s)&&(_=[s]);for(let h=0;h<_.length;h++){let S=_[h],g=d[S];(g==null||g===!1)&&(Tr.info(`Required ${S} permission not found for ${t} ${s?`${s} `:""}operation in role ${e.role.id}`),p.push(S))}p.length>0&&n.addUnauthorizedTable(l,f,p)}catch(p){let _=xr.UNKNOWN_OP_AUTH_ERROR(t,l,f);throw Tr.error(_),Tr.error(p),Pn(c1.CHECK_LOGS_WRAPPER(_))}}}return r.size<2?n.getPermsResponse():null}a(f1,"hasPermissions");function oI(e,t,r,n,s,i,o){if(!e||!t)throw Tr.info("no attributes specified in checkAttributePerms."),Pn(new Error);let c=X.get(r).perms;if(!c||c==="")throw Tr.info(`no permissions found for ${r} in checkAttributePerms().`),Pn(new Error);if(Fo.isEmptyOrZeroLength(t))return Tr.info("No role permissions set (this is OK)."),null;o&&c.includes(o)&&(c=[o]);let l={};for(let f of e){let d=t.get(f);if(d){if(d[Xp]===!1){i.addInvalidItem(xr.ATTR_NOT_FOUND(s,n,f),s,n);continue}if(c)for(let p of c){if(rn.TIME_STAMP_NAMES.includes(d.attribute_name)&&p!==Go)throw Pn(new Error,xr.SYSTEM_TIMESTAMP_PERMS_ERR,Qp.FORBIDDEN);d[p]===!1&&(l[d.attribute_name]?l[d.attribute_name].push(p):l[d.attribute_name]=[p])}}else i.addInvalidItem(xr.ATTR_NOT_FOUND(s,n,f),s,n)}let u=Object.keys(l);u.length>0&&i.addUnauthorizedAttributes(u,s,n,l)}a(oI,"checkAttributePerms");function b_e(e){let t=new Set;try{if(e.action)return t;if(e.operation===rn.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS&&e.conditions.forEach(r=>{t.add(r.search_attribute)}),e&&e.search_attribute&&t.add(e.search_attribute),!e.records||e.records.length===0){if(!e.get_attributes||!e.get_attributes.length===0)return t;for(let r=0;r<e.get_attributes.length;r++)t.add(e.get_attributes[r])}else for(let r=0;r<e.records.length;r++){let n=Object.keys(e.records[r]);for(let s=0;s<n.length;s++)t.add(n[s])}}catch(r){Tr.info(r)}return t}a(b_e,"getRecordAttributes");function aI(e,t,r){let n=new Map;if(Fo.isEmpty(e))return Tr.info("no hdb_user specified in getAttributePermissions"),n;if(e.super_user||!t||!r)return n;try{e[t].tables[r].attribute_permissions.forEach(s=>{n.has(s.attribute_name)||n.set(s.attribute_name,s)})}catch{Tr.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(aI,"getAttributePermissions");function O_e(e,t,r,n,s,i,o){let c=new Set(i),l=aI(e,n,s);oI(c,l,t,s,n,o,r)}a(O_e,"verifyBulkLoadAttributePerms")});var zS=w((JMe,g1)=>{"use strict";g1.exports={evaluateSQL:H_e,processAST:E1,convertSQLToAST:m1,checkASTPermissions:h1};var N_e=yn(),p1=require("util"),w_e=p1.callbackify(N_e.insert),I_e=Yr().search,C_e=rk().update,P_e=p1.callbackify(C_e),D_e=sk().convertDelete,Za=require("alasql"),L_e=YS(),WS=z(),M_e=aE(),v_e=ie(),th=(H(),C(G)),{hdb_errors:U_e,handleHDBError:cI}=pe(),{HTTP_STATUS_CODES:lI}=U_e;M_e(Za);var x_e=403,B_e="There was a problem performing this insert. Please check the logs and try again.",uI=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function H_e(e,t){let r=e.parsed_sql_object;if(!r){r=m1(e.sql);let n,s=r.ast.statements[0];if(s instanceof Za.yy.Insert?n=s.into.databaseid:s instanceof Za.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof Za.yy.Update||s instanceof Za.yy.Delete?n=s.table.databaseid:WS.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof Za.yy.Select)&&v_e.isEmptyOrZeroLength(n))return t("No schema specified",null)}E1(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(H_e,"evaluateSQL");function h1(e,t){let r;try{r=L_e.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(h1,"checkASTPermissions");function m1(e){let t=new uI;if(!e)throw cI(new Error,"The 'sql' parameter is missing from the request body",lI.BAD_REQUEST);try{let r=e.trim(),n=Za.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
39
- `);throw n[1]?cI(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,lI.BAD_REQUEST):cI(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",lI.BAD_REQUEST)}return t}a(m1,"convertSQLToAST");function E1(e,t,r){try{let n=k_e;if(!e.bypass_auth&&!t.permissions_checked){let i=h1(e,t);if(i&&i.length>0)return r(x_e,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case th.VALID_SQL_OPS_ENUM.SELECT:n=I_e,s=t.ast.statements[0];break;case th.VALID_SQL_OPS_ENUM.INSERT:n=F_e;break;case th.VALID_SQL_OPS_ENUM.UPDATE:n=P_e;break;case th.VALID_SQL_OPS_ENUM.DELETE:n=D_e;break;default:throw new Error(`unsupported SQL type ${t.variant} in SQL: ${e}`)}n(s,(i,o)=>{if(i){r(i);return}r(null,o)})}catch(n){return r(n)}}a(E1,"processAST");function k_e(e,t){WS.info(e),t("unknown sql statement")}a(k_e,"nullFunction");function F_e({statement:e,hdb_user:t},r){let n=e.into,s={schema:n.databaseid,table:n.tableid,operation:"insert",hdb_user:t},i=e.columns.map(o=>o.columnid);try{s.records=G_e(i,e.values)}catch(o){return r(o)}w_e(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(l){WS.error(`Error delete new_attributes from insert response: ${l}`)}r(null,c)})}a(F_e,"convertInsert");function G_e(e,t){try{return t.map(r=>{if(e.length!==r.length)throw"number of values do not match number of columns in insert";let n={};return r.forEach((s,i)=>{if(s.columnid)throw"cannot use a column in insert value";"value"in s?n[e[i]]=s.value:n[e[i]]=Za.compile(`SELECT ${s.toString()} AS [${th.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw WS.error(r),new Error(B_e)}}a(G_e,"createDataObjects")});var mI=w((eve,R1)=>{var XS=require("clone"),ZS=ot(),q_e=ie(),JS=(H(),C(G)),XMe=z(),dI=require("fs"),_I=require("joi"),{string:QS}=_I.types(),{hdb_errors:$_e,handleHDBError:jS}=pe(),{HDB_ERROR_MSGS:ZMe,HTTP_STATUS_CODES:fI}=$_e,{common_validators:Hd}=Di(),S1=" is required",V_e=["insert","update","upsert"],pI={database:{presence:!1,format:Hd.schema_format,length:Hd.schema_length},schema:{presence:!1,format:Hd.schema_format,length:Hd.schema_length},table:{presence:!0,format:Hd.schema_format,length:Hd.schema_length},action:{inclusion:{within:V_e,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},K_e={schema:QS.required(),table:QS.required(),action:QS.valid("insert","update","upsert")},{AWS_ACCESS_KEY:Y_e,AWS_SECRET:W_e,AWS_BUCKET:z_e,AWS_FILE_KEY:j_e,REGION:J_e}=JS.S3_BUCKET_AUTH_KEYS,Q_e={s3:{presence:!0},[`s3.${Y_e}`]:{presence:!0,type:"String"},[`s3.${W_e}`]:{presence:!0,type:"String"},[`s3.${z_e}`]:{presence:!0,type:"String"},[`s3.${j_e}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${J_e}`]:{presence:!0,type:"String"}},T1=XS(pI);T1.data.presence={message:S1};var A1=XS(pI);A1.file_path.presence={message:S1};var X_e=Object.assign(XS(pI),Q_e),hI=XS(K_e);hI.csv_url=QS.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();hI.passthrough_headers=_I.object();function Z_e(e){let t=ZS.validateObject(e,T1);return eT(e,t)}a(Z_e,"dataObject");function epe(e){let t=ZS.validateBySchema(e,_I.object(hI));return eT(e,t)}a(epe,"urlObject");function tpe(e){let t=ZS.validateObject(e,A1);return eT(e,t)}a(tpe,"fileObject");function rpe(e){let t=ZS.validateObject(e,X_e);return eT(e,t)}a(rpe,"s3FileObject");function eT(e,t){if(!t){let r=q_e.checkGlobalSchemaTable(e.schema,e.table);if(r)return jS(new Error,r,fI.BAD_REQUEST);if(e.operation===JS.OPERATIONS_ENUM.CSV_FILE_LOAD)try{dI.accessSync(e.file_path,dI.constants.R_OK|dI.constants.F_OK)}catch(n){return n.code===JS.NODE_ERROR_CODES.ENOENT?jS(n,`No such file or directory ${n.path}`,fI.BAD_REQUEST):n.code===JS.NODE_ERROR_CODES.EACCES?jS(n,`Permission denied ${n.path}`,fI.BAD_REQUEST):jS(n)}}return t}a(eT,"postValidateChecks");R1.exports={dataObject:Z_e,urlObject:epe,fileObject:tpe,s3FileObject:rpe}});var EI=w((rve,y1)=>{"use strict";var rh=z(),tT=(H(),C(G));async function npe(e,t,r,n=void 0){if(!e||typeof e!="function")throw new Error("Invalid function parameter");let s;try{return s=await e(t),r&&await r(t,s,n),t.operation===tT.OPERATIONS_ENUM.INSERT||t.operation===tT.OPERATIONS_ENUM.UPDATE||t.operation===tT.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===tT.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(rh.info(i.message),i):i.http_resp_msg?(rh.error(`Error calling operation: ${e.name}`),rh.error(i.http_resp_msg),i):(rh.error(`Error calling operation: ${e.name}`),rh.error(i),i)}}a(npe,"callOperationFunctionAsAwait");y1.exports={callOperationFunctionAsAwait:npe}});var gI=w((sve,O1)=>{"use strict";var{S3:spe,GetObjectCommand:ipe}=require("@aws-sdk/client-s3");O1.exports={getFileStreamFromS3:ope,getS3AuthObj:b1};async function ope(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await b1(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new ipe(r))).Body}a(ope,"getFileStreamFromS3");function b1(e,t,r){return new spe({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(b1,"getS3AuthObj")});var w1=w((ove,N1)=>{"use strict";var SI=class{static{a(this,"BulkLoadFileObject")}constructor(t,r,n,s,i,o,c=null){this.op=t,this.action=r,this.schema=n,this.table=s,this.file_path=i,this.file_type=o,this.role_perms=c}},TI=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};N1.exports={BulkLoadFileObject:SI,BulkLoadDataObject:TI}});var C1=w((cve,I1)=>{"use strict";var AI=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};I1.exports=AI});var wI=w((pve,Y1)=>{"use strict";var rT=yn(),sT=mI(),ape=require("needle"),_i=(H(),C(G)),uve=Tt(),kd=ie(),{handleHDBError:Ft,hdb_errors:H1}=pe(),{HTTP_STATUS_CODES:Br,HDB_ERROR_MSGS:Ar,CHECK_LOGS_WRAPPER:Hl}=H1,Fd=z(),RI=require("papaparse");kd.promisifyPapaParse();var pi=require("fs-extra"),cpe=require("path"),{chain:P1}=require("stream-chain"),D1=require("stream-json/streamers/StreamArray"),L1=require("stream-json/utils/Batch"),M1=require("stream-chain/utils/comp"),{finished:v1}=require("stream"),lpe=ae(),k1=EI(),upe=gI(),{BulkLoadFileObject:bI,BulkLoadDataObject:dpe}=w1(),OI=tI(),{verifyBulkLoadAttributePerms:F1}=YS(),dve=C1(),fve=ir(),_ve=Eo(),{databases:fpe}=(De(),C(nt)),{coerceType:_pe}=(qf(),C(II)),U1="No records parsed from csv file.",Bl=`${lpe.get("HDB_ROOT")}/tmp`,{schema_regex:ppe}=Di(),x1=1024*1024*2,B1=5e3,hpe={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};Y1.exports={csvDataLoad:mpe,csvURLLoad:Epe,csvFileLoad:gpe,importFromS3:Spe};async function mpe(e,t){let r=sT.dataObject(e);if(r)throw Ft(r,r.message,Br.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=$1(e.schema,e.table),i=RI.parse(e.data,{header:!0,skipEmptyLines:!0,transform:yI.bind(null,s),dynamicTyping:!1}),o=new OI;e.hdb_user&&e.hdb_user?.role&&e.hdb_user?.role?.permission&&e.hdb_user?.role?.permission?.super_user!==!0&&F1(e.hdb_user?.role?.permission,this.job_operation_function.name,e.action,e.schema,e.table,i.meta.fields,o);let c=o.getPermsResponse();if(c)throw Ft(new Error,c,Br.BAD_REQUEST,void 0,void 0,!0);let l=new dpe(e.action,e.schema,e.table,i.data);return n=await k1.callOperationFunctionAsAwait(V1,l,null),n.message===U1?U1:K1(n.records,n.number_written)}catch(s){throw kl(s)}}a(mpe,"csvDataLoad");async function Epe(e){let t=sT.urlObject(e);if(t)throw Ft(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${Bl}/${r}`;try{await Tpe(e,r)}catch(s){throw Fd.error(Ar.DOWNLOAD_FILE_ERR(r)+" - "+s),Ft(s,Hl(Ar.DOWNLOAD_FILE_ERR(r)))}try{let s=new bI(this.job_operation_function.name,e.action,e.schema,e.table,n,_i.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission),i=await NI(s);return await nT(n),i}catch(s){throw await nT(n),kl(s)}}a(Epe,"csvURLLoad");async function gpe(e){let t=sT.fileObject(e);if(t)throw Ft(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r=new bI(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,_i.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission);try{return await NI(r)}catch(n){throw kl(n)}}a(gpe,"csvFileLoad");async function Spe(e){let t=sT.s3FileObject(e);if(t)throw Ft(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=cpe.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${Bl}/${s}`;let i=new bI(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user?.role?.permission);await Ape(s,e);let o=await NI(i);return await nT(r),o}catch(n){throw await nT(r),kl(n)}}a(Spe,"importFromS3");async function Tpe(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await ape("get",e.csv_url,n)}catch(n){let s=`Error downloading CSV file from ${e.csv_url}, status code: ${n.statusCode}. Check the log for more information.`;throw Ft(n,s,n.statusCode,_i.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}ype(r,e.csv_url),await Rpe(t,r.raw)}a(Tpe,"downloadCSVFile");async function Ape(e,t){try{let r=`${Bl}/${e}`;await pi.mkdirp(Bl),await pi.writeFile(`${Bl}/${e}`,"",{flag:"a+"});let n=await pi.createWriteStream(r),s=await upe.getFileStreamFromS3(t);await new Promise((i,o)=>{s.on("error",function(c){o(c)}),s.pipe(n).on("error",function(c){o(c)}).on("close",function(){Fd.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw Fd.error(Ar.S3_DOWNLOAD_ERR+" - "+r),Ft(r,Hl(Ar.S3_DOWNLOAD_ERR))}}a(Ape,"downloadFileFromS3");async function Rpe(e,t){try{await pi.mkdirp(Bl),await pi.writeFile(`${Bl}/${e}`,t)}catch(r){throw Fd.error(Ar.WRITE_TEMP_FILE_ERR),Ft(r,Hl(Ar.DEFAULT_BULK_LOAD_ERR))}}a(Rpe,"writeFileToTempFolder");async function nT(e){if(e)try{await pi.access(e),await pi.unlink(e)}catch{Fd.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(nT,"deleteTempFile");function ype(e,t){if(e.statusCode!==H1.HTTP_STATUS_CODES.OK)throw Ft(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,Br.BAD_REQUEST);if(!hpe[e.headers["content-type"]])throw Ft(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,Br.BAD_REQUEST);if(!e.raw)throw Ft(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,Br.BAD_REQUEST)}a(ype,"validateURLResponse");async function NI(e){try{let t;switch(e.file_type){case _i.VALID_S3_FILE_TYPES.CSV:t=await bpe(e);break;case _i.VALID_S3_FILE_TYPES.JSON:t=await Ope(e);break;default:throw Ft(new Error,Ar.DEFAULT_BULK_LOAD_ERR,Br.BAD_REQUEST,_i.LOG_LEVELS.ERROR,Ar.INVALID_FILE_EXT_ERR(e))}return K1(t.records,t.number_written)}catch(t){throw kl(t)}}a(NI,"fileLoad");async function G1(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;s&&s.pause();let o={operation:e.action,schema:e.schema,table:e.table,records:i};try{let{attributes:c}=await rT.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&F1(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let l=Ft(c);r(l)}}a(G1,"validateChunk");async function q1(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;kd.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!kd.isEmpty(c)&&!kd.isEmpty(c.__parsed_extra)&&delete c.__parsed_extra});else{let c=new Set;i.forEach(l=>{Object.keys(l).forEach(u=>c.add(u))}),o=[...c]}try{let c={schema:e.schema,table:e.table,action:e.action,data:i},l=await k1.callOperationFunctionAsAwait(V1,c,null);t.records+=l.records,t.number_written+=l.number_written,s&&s.resume()}catch(c){let l=Ft(c,Hl(Ar.INSERT_CSV_ERR),Br.INTERNAL_SERVER_ERROR,_i.LOG_LEVELS.ERROR,Ar.INSERT_CSV_ERR+" - "+c);r(l)}}a(q1,"insertChunk");async function bpe(e){let t={records:0,number_written:0},r=$1(e.schema,e.table);try{let n=new OI,s=pi.createReadStream(e.file_path,{highWaterMark:x1});s.setEncoding("utf8"),await RI.parsePromise(s,G1.bind(null,e,n),yI.bind(null,r));let i=n.getPermsResponse();if(i)throw Ft(new Error,i,Br.BAD_REQUEST);return s=pi.createReadStream(e.file_path,{highWaterMark:x1}),s.setEncoding("utf8"),await RI.parsePromise(s,q1.bind(null,e,t),yI.bind(null,r)),s.destroy(),t}catch(n){throw Ft(n,Hl(Ar.PAPA_PARSE_ERR),Br.INTERNAL_SERVER_ERROR,_i.LOG_LEVELS.ERROR,Ar.PAPA_PARSE_ERR+n)}}a(bpe,"callPapaParse");function $1(e,t){let r=fpe[e][t].attributes,n=new Map;for(let s of r)s.type&&!s.computed&&!s.relationship&&n.set(s.name,i=>_pe(i,s));return n}a($1,"createTransformMap");function yI(e,t,r){let n=e.get(r);return n?n(t):kd.autoCast(t)}a(yI,"typeFunction");async function Ope(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new OI,s=P1([pi.createReadStream(e.file_path,{encoding:"utf-8"}),D1.withParser(),c=>c.value,new L1({batchSize:B1}),M1(async c=>{await G1(e,n,r,c)})]);await new Promise((c,l)=>{v1(s,u=>{u?l(u):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw Ft(new Error,i,Br.BAD_REQUEST);let o=P1([pi.createReadStream(e.file_path,{encoding:"utf-8"}),D1.withParser(),c=>c.value,new L1({batchSize:B1}),M1(async c=>{await q1(e,t,r,c)})]);return await new Promise((c,l)=>{v1(o,u=>{u?l(u):c()}),o.resume()}),t}catch(n){throw Ft(n,Hl(Ar.INSERT_JSON_ERR),Br.INTERNAL_SERVER_ERROR,_i.LOG_LEVELS.ERROR,Ar.INSERT_JSON_ERR+n)}}a(Ope,"insertJson");async function V1(e){let t={};try{e.data&&e.data.length>0&&Npe(e.data[0])?t=await wpe(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",Fd.info(t.message))}catch(r){throw kl(r)}return t}a(V1,"callBulkFileLoad");function Npe(e){let t=Object.keys(e);for(let r of t)if(!ppe.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(Npe,"validateColumnNames");async function wpe(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=rT.insert;break;case"update":i=rT.update;break;case"upsert":i=rT.upsert;break;default:throw Ft(new Error,Ar.INVALID_ACTION_PARAM_ERR(n),Br.BAD_REQUEST,_i.LOG_LEVELS.ERROR,Ar.INVALID_ACTION_PARAM_ERR(n))}try{let o=await i(s),c;switch(n){case"insert":c=o.inserted_hashes;break;case"update":c=o.update_hashes;break;case"upsert":c=o.upserted_hashes;break;default:break}if(Array.isArray(o.skipped_hashes)&&o.skipped_hashes.length>0){let f=global.hdb_schema[t][r].hash_attribute,d=e.length;for(;d--;)o.skipped_hashes.indexOf(e[d][f])>=0&&e.splice(d,1)}let l=kd.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw kl(o)}}a(wpe,"bulkFileLoad");function K1(e,t){return`successfully loaded ${t} of ${e} records`}a(K1,"buildResponseMsg");function kl(e){return Ft(e,Hl(Ar.DEFAULT_BULK_LOAD_ERR),Br.INTERNAL_SERVER_ERROR,_i.LOG_LEVELS.ERROR,Ar.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(kl,"buildTopLevelErrMsg")});var DI=w((mve,eK)=>{"use strict";var PI=Yr(),Ipe=gI(),{AsyncParser:Cpe}=require("json2csv"),iT=require("stream"),is=ie(),CI=require("fs-extra"),Ppe=require("path"),Ls=z(),{promisify:j1}=require("util"),nh=ie(),{handleHDBError:dr,hdb_errors:Dpe}=pe(),{HDB_ERROR_MSGS:Dn,HTTP_STATUS_CODES:fr}=Dpe,{streamAsJSON:Lpe}=(OR(),C(KL)),{Upload:Mpe}=require("@aws-sdk/lib-storage"),{toCsvStream:vpe}=(ao(),C(dM)),W1=["search_by_value","search_by_hash","sql","search_by_conditions"],z1=["json","csv"],J1="json",Q1="csv",Upe="Successfully exported JSON locally.",xpe="Successfully exported CSV locally.",Bpe=1e3,Hpe=PI.searchByHash,kpe=PI.searchByValue,Fpe=j1(iT.finished);eK.exports={export_to_s3:Vpe,export_local:Gpe};async function Gpe(e){Ls.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=X1(e);if(!is.isEmpty(t))throw Ls.error(t),dr(new Error,t,fr.BAD_REQUEST,void 0,void 0,!0);if(is.isEmpty(e.path))throw Ls.error(Dn.MISSING_VALUE("path")),dr(new Error,Dn.MISSING_VALUE("path"),fr.BAD_REQUEST,void 0,void 0,!0);let r=(is.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(Ppe.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=is.buildFolderPath(e.path,r);await qpe(e.path);let s=await Z1(e);return await $pe(n,e.format,s)}a(Gpe,"export_local");async function qpe(e){if(Ls.trace("in confirmPath"),is.isEmptyOrZeroLength(e))throw dr(new Error,`Invalid path: ${e}`,fr.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await CI.stat(e)}catch(r){let n;throw r.code==="ENOENT"?n=`path '${e}' does not exist`:r.code==="EACCES"?n=`access to path '${e}' is denied`:n=r.message,Ls.error(n),dr(new Error,n,fr.BAD_REQUEST,void 0,void 0,!0)}if(!t.isDirectory()){let r=`path '${e}' is not a directory, please supply a valid folder path`;throw Ls.error(r),dr(new Error,r,fr.BAD_REQUEST,void 0,void 0,!0)}return!0}a(qpe,"confirmPath");async function $pe(e,t,r){if(Ls.trace("in saveToLocal"),nh.isEmptyOrZeroLength(e))throw dr(new Error,Dn.INVALID_VALUE("file_path"),fr.BAD_REQUEST,void 0,void 0,!0);if(nh.isEmptyOrZeroLength(t))throw dr(new Error,Dn.INVALID_VALUE("Source format"),fr.BAD_REQUEST,void 0,void 0,!0);if(nh.isEmpty(r))throw dr(new Error,Dn.NOT_FOUND("Data"),fr.BAD_REQUEST,void 0,void 0,!0);if(t===J1){let n=CI.createWriteStream(e);return Lpe(r).pipe(n),await Fpe(n),{message:Upe,path:e}}else if(t===Q1){let n=CI.createWriteStream(e),s=iT.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(f=>({label:f,value:f})));let c={objectMode:!0};return await new Cpe(i,c).fromInput(s).toOutput(n).promise(!1),{message:xpe,path:e}}throw dr(new Error,Dn.INVALID_VALUE("format"),fr.BAD_REQUEST)}a($pe,"saveToLocal");async function Vpe(e){if(!e.s3||Object.keys(e.s3).length===0)throw dr(new Error,Dn.MISSING_VALUE("S3 object"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw dr(new Error,Dn.MISSING_VALUE("aws_access_key_id"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw dr(new Error,Dn.MISSING_VALUE("aws_secret_access_key"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.bucket))throw dr(new Error,Dn.MISSING_VALUE("bucket"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.key))throw dr(new Error,Dn.MISSING_VALUE("key"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.region))throw dr(new Error,Dn.MISSING_VALUE("region"),fr.BAD_REQUEST);let t=X1(e);if(!is.isEmpty(t))throw dr(new Error,t,fr.BAD_REQUEST);Ls.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await Z1(e)}catch(l){throw Ls.error(l),l}let n,s=await Ipe.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new iT.PassThrough;if(e.format===Q1){i=e.s3.key+".csv";let l=vpe(r,r.getColumns?.());l.on("error",u=>{throw u}),l.pipe(o)}else if(e.format===J1){i=e.s3.key+".json";let l=new iT.Readable;l.pipe(o),l.on("error",d=>{throw d}),l.push("[");let u=r.length,f="";for(let[d,p]of r.entries()){let _=d===u-1?JSON.stringify(p):JSON.stringify(p)+",";f+=_,d!==0&&d%Bpe===0&&(l.push(f),f="")}f.length!==0&&l.push(f),l.push("]"),l.push(null)}else throw dr(new Error,Dn.INVALID_VALUE("format"),fr.BAD_REQUEST);return new Mpe({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(Vpe,"export_to_s3");function X1(e){if(Ls.trace("in exportCoreValidation"),is.isEmpty(e.format))return"format missing";if(z1.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${z1.join(", ")}`;let t=e.search_operation.operation;if(is.isEmpty(t))return"search_operation.operation missing";if(W1.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${W1.join(", ")}`}a(X1,"exportCoreValidation");async function Z1(e){Ls.trace("in getRecords");let t,r;if(nh.isEmpty(e.search_operation)||nh.isEmptyOrZeroLength(e.search_operation.operation))throw dr(new Error,Dn.INVALID_VALUE("Search operation"),fr.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=kpe;break;case"search_by_hash":t=Hpe;break;case"search_by_conditions":t=PI.searchByConditions;break;case"sql":{let n=zS();t=j1(n.evaluateSQL);break}default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,Ls.error(r),dr(new Error,r,fr.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(Z1,"getRecords")});var rK=w((gve,tK)=>{"use strict";var LI=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};tK.exports=LI});var iK=w((Tve,sK)=>{"use strict";var Kpe=(H(),C(G)),nK=require("moment"),Ype=require("uuid").v4,MI=class{static{a(this,"JobObject")}constructor(){this.id=Ype(),this.type=void 0,this.start_datetime=nK().valueOf(),this.created_datetime=nK().valueOf(),this.end_datetime=void 0,this.status=Kpe.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};sK.exports=MI});var vI=w((Rve,_K)=>{"use strict";var Wpe=require("uuid").v4,uK=yn(),dK=Yr(),zpe=ni(),jpe=Fu(),Jpe=rK(),Ot=(H(),C(G)),Qpe=iK(),Xpe=ng(),hi=z(),Zpe=Uf(),Gd=ie(),{promisify:ehe}=require("util"),Fl=require("moment"),the=zS(),oT=mI(),oK=Py(),{deleteTransactionLogsBeforeValidator:rhe}=Jw(),{handleHDBError:aK,hdb_errors:nhe,ClientError:she}=pe(),{HTTP_STATUS_CODES:cK}=nhe,lK=dK.searchByValue,ihe=dK.searchByHash,ohe=uK.insert,ahe=ehe(the.evaluateSQL),che=uK.update;_K.exports={addJob:dhe,updateJob:_he,handleGetJob:lhe,handleGetJobsByStartDate:uhe,getJobById:fK};async function lhe(e){if(e.id===void 0)throw new she("'id' is required");let t=await fK(e.id);return Gd.isEmptyOrZeroLength(t)||(t[0]={...t[0]},t[0].request!==void 0&&delete t[0].request,delete t[0].__createdtime__,delete t[0].__updatedtime__),t}a(lhe,"handleGetJob");async function uhe(e){try{let t=await fhe(e);if(hi.trace(`Searching for jobs from ${e.from_date} to ${e.to_date}`),t&&t.length>0)for(let r of t)r.start_datetime&&(r.start_datetime_converted=Fl(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=Fl(r.end_datetime)),r.request!==void 0&&delete r.request,delete r.__createdtime__,delete r.__updatedtime__;return t}catch(t){let r=`There was an error searching jobs by date: ${t}`;throw hi.error(r),new Error(r)}}a(uhe,"handleGetJobsByStartDate");async function dhe(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||Gd.isEmptyOrZeroLength(e.operation)){let f="job parameter is invalid";return hi.info(f),t.error=f,t}if(!Ot.JOB_TYPE_ENUM[e.operation])return hi.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case Ot.OPERATIONS_ENUM.CSV_FILE_LOAD:n=oT.fileObject(e);break;case Ot.OPERATIONS_ENUM.CSV_URL_LOAD:n=oT.urlObject(e);break;case Ot.OPERATIONS_ENUM.CSV_DATA_LOAD:n=oT.dataObject(e);break;case Ot.OPERATIONS_ENUM.IMPORT_FROM_S3:n=oT.s3FileObject(e);break;case Ot.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case Ot.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=oK(e,"date");break;case Ot.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=oK(e,"timestamp");break;case Ot.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=rhe(e);break;case Ot.OPERATIONS_ENUM.RESTART_SERVICE:if(Ot.HDB_PROCESS_SERVICES[e.service]===void 0)throw aK(new Error,"Invalid service",cK.BAD_REQUEST,void 0,void 0,!0);break;default:break}if(n)throw aK(n,n.message,cK.BAD_REQUEST,void 0,void 0,!0);let s=new Qpe;s.type=e.operation===Ot.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE?Ot.OPERATIONS_ENUM.DELETE_FILES_BEFORE:e.operation,s.type=e.operation,s.user=e.hdb_user?.username;let i=new zpe(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await lK(i))}catch(f){let d=`There was an error inserting a new job: ${f}`;return hi.error(d),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=Wpe();try{o=await lK(i)}catch(f){let d=`There was an error inserting a new job: ${f}`;return hi.error(d),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return hi.error("Error creating a job, could not find a unique job id."),t}s.request=e;let l=new Zpe(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),u;try{u=await ohe(l)}catch(f){return hi.error(`There was an error inserting a job for job type: ${e.operation} -- ${f}`),t.success=!1,t}if(u.inserted_hashes.length===0)t.message=`Had a problem creating a job with type ${s.operation} and id ${s.id}`;else{let f=`Created a job with type ${s.type} and id ${s.id}`;t.message=f,t.createdJob=s,t.success=!0,hi.trace(f)}return t}a(dhe,"addJob");async function fhe(e){let t=Fl(e.from_date,Fl.ISO_8601),r=Fl(e.to_date,Fl.ISO_8601);if(!t.isValid())throw new Error("Invalid 'from' date, must be in ISO-8601 format (YYYY-MM-DD).");if(!r.isValid())throw new Error("Invalid 'to' date, must be in ISO-8601 format (YYYY-MM-DD)");let n=`select * from system.hdb_job where start_datetime > '${t.valueOf()}' and start_datetime < '${r.valueOf()}'`,s=new Jpe(n,e.hdb_user);try{return await ahe(s)}catch(i){throw hi.error(`there was a problem searching for jobs from date ${e.from_date} to date ${e.to_date} ${i}`),new Error("there was an error searching for jobs. Please check the log for details.")}}a(fhe,"getJobsInDateRange");async function fK(e){if(Gd.isEmptyOrZeroLength(e))return Gd.errorizeMessage("Invalid job ID specified.");let t=new jpe(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await ihe(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return hi.error(n),Gd.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(fK,"getJobById");async function _he(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(Gd.isEmptyOrZeroLength(e.id))throw new Error("invalid ID passed to updateJob");(e.status===Ot.JOB_STATUS_ENUM.COMPLETE||e.status===Ot.JOB_STATUS_ENUM.ERROR)&&(e.end_datetime=Fl().valueOf());let t=new Xpe(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await che(t),r}a(_he,"updateJob")});var AK=w((bve,TK)=>{"use strict";var pK=ie(),Rr=(H(),C(G)),phe=require("moment"),aT=wI(),sh=z(),hK=vI(),mK=DI(),EK=zc(),gK=rt(),hhe=qS(),mhe=za(),{parentPort:Ehe,isMainThread:SK}=require("worker_threads"),{onMessageByType:ghe}=rt(),UI=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function She(e){if(!e||Object.keys(e).length===0)throw new Error("Empty runner passed to parseMessage");if(!e.json||Object.keys(e.json).length===0)throw new Error("Empty JSON passed to parseMessage");if(!e.job||Object.keys(e.job).length===0)throw new Error("Empty job passed to parseMessage");if(pK.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(pK.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case Rr.JOB_TYPE_ENUM.csv_file_load:await Ki(e,aT.csvFileLoad);break;case Rr.JOB_TYPE_ENUM.csv_url_load:await Ki(e,aT.csvURLLoad);break;case Rr.JOB_TYPE_ENUM.csv_data_load:await Ki(e,aT.csvDataLoad);break;case Rr.JOB_TYPE_ENUM.import_from_s3:await Ki(e,aT.importFromS3);break;case Rr.JOB_TYPE_ENUM.empty_trash:break;case Rr.JOB_TYPE_ENUM.export_local:await Ki(e,mK.export_local);break;case Rr.JOB_TYPE_ENUM.export_to_s3:await Ki(e,mK.export_to_s3);break;case Rr.JOB_TYPE_ENUM.delete_files_before:case Rr.JOB_TYPE_ENUM.delete_records_before:await Ki(e,EK.deleteFilesBefore);break;case Rr.JOB_TYPE_ENUM.delete_audit_logs_before:await Ki(e,EK.deleteAuditLogsBefore);break;case Rr.JOB_TYPE_ENUM.delete_transaction_logs_before:await Ki(e,hhe.deleteTransactionLogsBefore);break;case Rr.JOB_TYPE_ENUM.restart_service:return await Ki(e,mhe.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(She,"parseMessage");async function Ki(e,t){try{e.job.status=Rr.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=phe().valueOf(),await hK.updateJob(e.job),await The(e.job.id)}catch(r){let n=r.message!==void 0?r.message:r;typeof n=="string"?(n=`There was an error running ${t.name} job with id ${e.job.id} - ${n}`,r.message=n):sh.error(`There was an error running ${t.name} job with id ${e.job.id}`),sh.error(n),e.job.message=n,e.job.status=Rr.JOB_STATUS_ENUM.ERROR;try{await hK.updateJob(e.job)}catch(s){throw sh.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(Ki,"runJob");async function The(e){sh.trace("launching job thread:",e),SK?gK.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Rr.PROCESS_NAME_ENV_PROP]:`JOB-${e}`}}):Ehe.postMessage({type:Rr.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(The,"launchJobThread");SK&&ghe(Rr.ITC_EVENT_TYPES.START_JOB,async(e,t)=>{try{gK.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Rr.PROCESS_NAME_ENV_PROP]:`JOB-${e.jobId}`}})}catch(r){sh.error(r)}});TK.exports={parseMessage:She,RunnerMessage:UI}});var yK=w((Nve,RK)=>{"use strict";var xI=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};RK.exports=xI});var jw=w((Cve,qI)=>{"use strict";var fT=Yr(),kI=zS(),cT=wI(),qo=Kg(),lT=go(),oh=zc(),Ahe=ON(),ih=Rn(),uT=F_(),Pt=zw(),dT=z(),Rhe=PN(),yhe=Sd(),bK=tw(),bhe=sS(),Ohe=sw(),Nhe=iw(),whe=cS(),Ihe=uS(),BI=dS(),OK=DI(),Che=YS(),FI=vI(),K=(H(),C(G)),{hdb_errors:ch,handleHDBError:ah}=pe(),{HTTP_STATUS_CODES:NK}=ch,HI=mS(),wK=za(),BK=require("util"),$d=yn(),Phe=As(),Dhe=Po(),IK=AK(),CK=(Ju(),C(X_)),PK=(vS(),C(Gp)),DK=yt(),LK=qS(),MK=Kp(),{setServerUtilities:Lhe}=(qf(),C(II)),{CONTEXT:Ive}=(Ea(),C(gR)),{_assignPackageExport:Mhe}=Ti(),{transformReq:vhe}=ie(),{server:Uhe}=(Vr(),C(Au)),nn=dT.loggerWithTag("operation"),qd=Zn(),vK=(bl(),C(yl)),xhe=EI(),UK=fT.searchByHash,Bhe=fT.searchByValue,Hhe=BK.promisify(fT.search),khe=BK.promisify(kI.evaluateSQL),Fhe={[K.OPERATIONS_ENUM.CREATE_ATTRIBUTE]:!0,[K.OPERATIONS_ENUM.CREATE_TABLE]:!0,[K.OPERATIONS_ENUM.CREATE_SCHEMA]:!0,[K.OPERATIONS_ENUM.DROP_ATTRIBUTE]:!0,[K.OPERATIONS_ENUM.DROP_TABLE]:!0,[K.OPERATIONS_ENUM.DROP_SCHEMA]:!0},ee=yK();async function HK(e,t){try{if(e.body.operation!=="read_log"&&(dT.log_level===K.LOG_LEVELS.INFO||dT.log_level===K.LOG_LEVELS.DEBUG||dT.log_level===K.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,payload:o,...c}=e.body;nn.info(c)}}catch(n){nn.error(n)}let r=await xhe.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return Fhe[e.body.operation]&&Phe.setSchemaDataToGlobal(n=>{n&&nn.error(n)}),r}a(HK,"processLocalTransaction");var xK=qhe();qI.exports={chooseOperation:kK,getOperationFunction:FK,operation:GI,processLocalTransaction:HK,executeJob:Ms};Lhe(qI.exports);Uhe.operation=GI;function kK(e){let t;try{t=FK(e)}catch(s){throw nn.error(`Error when selecting operation function - ${s}`),s}let{operation_function:r,job_operation_function:n}=t;try{if(e.operation==="sql"||e.search_operation&&e.search_operation.operation==="sql"){let s=e.operation==="sql"?e.sql:e.search_operation.sql,i=kI.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=kI.checkASTPermissions(e,i);if(o)throw nn.error(`${NK.FORBIDDEN} from operation ${e.operation}`),nn.warn(`User '${e.hdb_user?.username}' is not permitted to ${e.operation}`),ah(new Error,o,ch.HTTP_STATUS_CODES.FORBIDDEN,void 0,void 0,!0)}}else if(!e.bypass_auth&&e.operation!==K.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.operation!==K.OPERATIONS_ENUM.LOGIN&&e.operation!==K.OPERATIONS_ENUM.LOGOUT){let s=n===void 0?r:n,i=e.search_operation?e.search_operation:e;i.hdb_user||(i.hdb_user=e.hdb_user);let o=Che.verifyPerms(i,s);if(o)throw nn.error(`${NK.FORBIDDEN} from operation ${e.operation}`),nn.warn(`User '${i.hdb_user?.username}' is not permitted to ${i.operation}`),ah(new Error,o,ch.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw ah(s,"There was an error when trying to choose an operation path")}return r}a(kK,"chooseOperation");function FK(e){if(nn.trace(`getOperationFunction with operation: ${e.operation}`),xK.has(e.operation))return xK.get(e.operation);throw ah(new Error,ch.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),ch.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(FK,"getOperationFunction");Mhe("operation",GI);function GI(e,t,r){e.hdb_user=t?.user,e.bypass_auth=!r;let n=kK(e);return HK({body:e},n)}a(GI,"operation");async function Ghe(e){nn.trace("In serverUtils.catchup");let t=e.transaction,r=t.channel.split(":"),n=r[0],s=r[1];for(let i of t.transactions)try{i.schema=n,i.table=s,i[K.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case K.OPERATIONS_ENUM.INSERT:o=await $d.insert(i);break;case K.OPERATIONS_ENUM.UPDATE:o=await $d.update(i);break;case K.OPERATIONS_ENUM.UPSERT:o=await $d.upsert(i);break;case K.OPERATIONS_ENUM.DELETE:o=await oh.deleteRecord(i);break;default:nn.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){nn.info("Invalid operation in transaction"),nn.error(o)}}a(Ghe,"catchup");async function Ms(e){vhe(e);let t,r;try{r=await FI.addJob(e),t=r.createdJob,nn.info("addJob result",r);let n=new IK.RunnerMessage(t,e);return{message:await IK.parseMessage(n)??`Starting job with id ${t.id}`,job_id:t.id}}catch(n){let s=`There was an error executing job: ${n.http_resp_msg?n.http_resp_msg:n}`;throw nn.error(s),ah(n,s)}}a(Ms,"executeJob");function qhe(){let e=new Map;return e.set(K.OPERATIONS_ENUM.INSERT,new ee($d.insert)),e.set(K.OPERATIONS_ENUM.UPDATE,new ee($d.update)),e.set(K.OPERATIONS_ENUM.UPSERT,new ee($d.upsert)),e.set(K.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new ee(fT.searchByConditions)),e.set(K.OPERATIONS_ENUM.SEARCH_BY_HASH,new ee(UK)),e.set(K.OPERATIONS_ENUM.SEARCH_BY_ID,new ee(UK)),e.set(K.OPERATIONS_ENUM.SEARCH_BY_VALUE,new ee(Bhe)),e.set(K.OPERATIONS_ENUM.SEARCH,new ee(Hhe)),e.set(K.OPERATIONS_ENUM.SQL,new ee(khe)),e.set(K.OPERATIONS_ENUM.CSV_DATA_LOAD,new ee(Ms,cT.csvDataLoad)),e.set(K.OPERATIONS_ENUM.CSV_FILE_LOAD,new ee(Ms,cT.csvFileLoad)),e.set(K.OPERATIONS_ENUM.CSV_URL_LOAD,new ee(Ms,cT.csvURLLoad)),e.set(K.OPERATIONS_ENUM.IMPORT_FROM_S3,new ee(Ms,cT.importFromS3)),e.set(K.OPERATIONS_ENUM.CREATE_SCHEMA,new ee(qo.createSchema)),e.set(K.OPERATIONS_ENUM.CREATE_DATABASE,new ee(qo.createSchema)),e.set(K.OPERATIONS_ENUM.CREATE_TABLE,new ee(qo.createTable)),e.set(K.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new ee(qo.createAttribute)),e.set(K.OPERATIONS_ENUM.DROP_SCHEMA,new ee(qo.dropSchema)),e.set(K.OPERATIONS_ENUM.DROP_DATABASE,new ee(qo.dropSchema)),e.set(K.OPERATIONS_ENUM.DROP_TABLE,new ee(qo.dropTable)),e.set(K.OPERATIONS_ENUM.DROP_ATTRIBUTE,new ee(qo.dropAttribute)),e.set(K.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new ee(lT.describeSchema)),e.set(K.OPERATIONS_ENUM.DESCRIBE_DATABASE,new ee(lT.describeSchema)),e.set(K.OPERATIONS_ENUM.DESCRIBE_TABLE,new ee(lT.describeTable)),e.set(K.OPERATIONS_ENUM.DESCRIBE_ALL,new ee(lT.describeAll)),e.set(K.OPERATIONS_ENUM.DELETE,new ee(oh.deleteRecord)),e.set(K.OPERATIONS_ENUM.ADD_USER,new ee(ih.addUser)),e.set(K.OPERATIONS_ENUM.ALTER_USER,new ee(ih.alterUser)),e.set(K.OPERATIONS_ENUM.DROP_USER,new ee(ih.dropUser)),e.set(K.OPERATIONS_ENUM.LIST_USERS,new ee(ih.listUsersExternal)),e.set(K.OPERATIONS_ENUM.LIST_ROLES,new ee(uT.listRoles)),e.set(K.OPERATIONS_ENUM.ADD_ROLE,new ee(uT.addRole)),e.set(K.OPERATIONS_ENUM.ALTER_ROLE,new ee(uT.alterRole)),e.set(K.OPERATIONS_ENUM.DROP_ROLE,new ee(uT.dropRole)),e.set(K.OPERATIONS_ENUM.USER_INFO,new ee(ih.userInfo)),e.set(K.OPERATIONS_ENUM.READ_LOG,new ee(Rhe)),e.set(K.OPERATIONS_ENUM.ADD_NODE,new ee(yhe)),e.set(K.OPERATIONS_ENUM.UPDATE_NODE,new ee(bK)),e.set(K.OPERATIONS_ENUM.SET_NODE_REPLICATION,new ee(bK)),e.set(K.OPERATIONS_ENUM.REMOVE_NODE,new ee(bhe)),e.set(K.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new ee(Ohe)),e.set(K.OPERATIONS_ENUM.PURGE_STREAM,new ee(Nhe)),e.set(K.OPERATIONS_ENUM.SET_CONFIGURATION,new ee(DK.setConfiguration)),e.set(K.OPERATIONS_ENUM.CLUSTER_STATUS,new ee(whe.clusterStatus)),e.set(K.OPERATIONS_ENUM.CLUSTER_NETWORK,new ee(Ihe)),e.set(K.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new ee(BI.setRoutes)),e.set(K.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new ee(BI.getRoutes)),e.set(K.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new ee(BI.deleteRoutes)),e.set(K.OPERATIONS_ENUM.EXPORT_TO_S3,new ee(Ms,OK.export_to_s3)),e.set(K.OPERATIONS_ENUM.CREATE_CSR,new ee(qd.createCsr)),e.set(K.OPERATIONS_ENUM.SIGN_CERTIFICATE,new ee(qd.signCertificate)),e.set(K.OPERATIONS_ENUM.LIST_CERTIFICATES,new ee(qd.listCertificates)),e.set(K.OPERATIONS_ENUM.ADD_CERTIFICATES,new ee(qd.addCertificate)),e.set(K.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new ee(qd.removeCertificate)),e.set(K.OPERATIONS_ENUM.GET_KEY,new ee(qd.getKey)),e.set(K.OPERATIONS_ENUM.ADD_NODE_BACK,new ee(vK.addNodeBack)),e.set(K.OPERATIONS_ENUM.REMOVE_NODE_BACK,new ee(vK.removeNodeBack)),e.set(K.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new ee(Ms,oh.deleteFilesBefore)),e.set(K.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new ee(Ms,oh.deleteFilesBefore)),e.set(K.OPERATIONS_ENUM.EXPORT_LOCAL,new ee(Ms,OK.export_local)),e.set(K.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new ee(FI.handleGetJobsByStartDate)),e.set(K.OPERATIONS_ENUM.GET_JOB,new ee(FI.handleGetJob)),e.set(K.OPERATIONS_ENUM.GET_FINGERPRINT,new ee(HI.getFingerprint)),e.set(K.OPERATIONS_ENUM.SET_LICENSE,new ee(HI.setLicense)),e.set(K.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new ee(HI.getRegistrationInfo)),e.set(K.OPERATIONS_ENUM.RESTART,new ee(wK.restart)),e.set(K.OPERATIONS_ENUM.RESTART_SERVICE,new ee(Ms,wK.restartService)),e.set(K.OPERATIONS_ENUM.CATCHUP,new ee(Ghe)),e.set(K.OPERATIONS_ENUM.SYSTEM_INFORMATION,new ee(Dhe.systemInformation)),e.set(K.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new ee(Ms,oh.deleteAuditLogsBefore)),e.set(K.OPERATIONS_ENUM.READ_AUDIT_LOG,new ee(Ahe)),e.set(K.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new ee(CK.createTokens)),e.set(K.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new ee(CK.refreshOperationToken)),e.set(K.OPERATIONS_ENUM.LOGIN,new ee(PK.login)),e.set(K.OPERATIONS_ENUM.LOGOUT,new ee(PK.logout)),e.set(K.OPERATIONS_ENUM.GET_CONFIGURATION,new ee(DK.getConfiguration)),e.set(K.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new ee(Pt.customFunctionsStatus)),e.set(K.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new ee(Pt.getCustomFunctions)),e.set(K.OPERATIONS_ENUM.GET_COMPONENT_FILE,new ee(Pt.getComponentFile)),e.set(K.OPERATIONS_ENUM.GET_COMPONENTS,new ee(Pt.getComponents)),e.set(K.OPERATIONS_ENUM.SET_COMPONENT_FILE,new ee(Pt.setComponentFile)),e.set(K.OPERATIONS_ENUM.DROP_COMPONENT,new ee(Pt.dropComponent)),e.set(K.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new ee(Pt.getCustomFunction)),e.set(K.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new ee(Pt.setCustomFunction)),e.set(K.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new ee(Pt.dropCustomFunction)),e.set(K.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new ee(Pt.addComponent)),e.set(K.OPERATIONS_ENUM.ADD_COMPONENT,new ee(Pt.addComponent)),e.set(K.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new ee(Pt.dropCustomFunctionProject)),e.set(K.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new ee(Pt.packageComponent)),e.set(K.OPERATIONS_ENUM.PACKAGE_COMPONENT,new ee(Pt.packageComponent)),e.set(K.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new ee(Pt.deployComponent)),e.set(K.OPERATIONS_ENUM.DEPLOY_COMPONENT,new ee(Pt.deployComponent)),e.set(K.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new ee(LK.readTransactionLog)),e.set(K.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new ee(Ms,LK.deleteTransactionLogsBefore)),e.set(K.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new ee(MK.installModules)),e.set(K.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new ee(MK.auditModules)),e.set(K.OPERATIONS_ENUM.GET_BACKUP,new ee(qo.getBackup)),e.set(K.OPERATIONS_ENUM.ADD_SSH_KEY,new ee(Pt.addSSHKey)),e.set(K.OPERATIONS_ENUM.UPDATE_SSH_KEY,new ee(Pt.updateSSHKey)),e.set(K.OPERATIONS_ENUM.DELETE_SSH_KEY,new ee(Pt.deleteSSHKey)),e.set(K.OPERATIONS_ENUM.LIST_SSH_KEYS,new ee(Pt.listSSHKeys)),e.set(K.OPERATIONS_ENUM.SET_SSH_KNOWN_HOSTS,new ee(Pt.setSSHKnownHosts)),e.set(K.OPERATIONS_ENUM.GET_SSH_KNOWN_HOSTS,new ee(Pt.getSSHKnownHosts)),e}a(qhe,"initializeOperationFunctionMap")});var hT=w((Dve,$K)=>{"use strict";var _T=(H(),C(G)),$he=ie(),lh=z(),{handleHDBError:$I,hdb_errors:pT}=pe(),{isMainThread:Vhe}=require("worker_threads"),{Readable:Khe}=require("stream"),GK=require("os"),Yhe=require("util"),Whe=wO(),zhe=Yhe.promisify(Whe.authorize),qK=jw(),{createGzip:jhe,constants:Jhe}=require("zlib"),Qhe=[_T.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,_T.OPERATIONS_ENUM.LOGIN,_T.OPERATIONS_ENUM.LOGOUT];function Xhe(e){let t=`Found an uncaught exception with message: ${e.message}. ${GK.EOL}Stack: ${e.stack} ${GK.EOL}Terminating ${Vhe?"HDB":"thread"}.`;console.error(t),lh.fatal(t),process.exit(1)}a(Xhe,"handleServerUncaughtException");function Zhe(e,t,r){if(lh[e.logLevel||"error"](e),e.statusCode)return typeof e.http_resp_msg!="object"?r.code(e.statusCode).send({error:e.http_resp_msg||e.message}):r.code(e.statusCode).send(e.http_resp_msg);let n=e.statusCode?e.statusCode:pT.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR;return typeof e=="string"?r.code(n).send({error:e}):r.code(n).send(e.message?{error:e.message}:e)}a(Zhe,"serverErrorHandler");function eme(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=$I(new Error,"Invalid JSON.",pT.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if($he.isEmpty(e.body.operation)){let n=$I(new Error,"Request body must include an 'operation' property.",pT.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(eme,"reqBodyValidationHandler");function tme(e,t,r){let n;!Qhe.includes(e.body.operation)||e.body.operation===_T.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&!e.body.username&&!e.body.password?zhe(e,t).then(i=>{n=i,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(i=>{lh.warn(i),lh.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${i.stack}"`);let o=typeof i=="string"?{error:i}:{error:i.message};r($I(i,o,pT.HTTP_STATUS_CODES.UNAUTHORIZED),null)}):(e.body.hdb_user=null,e.body.hdb_auth_header=e.headers.authorization,e.body.baseRequest=e.raw?.baseRequest,e.body.baseResponse=t.raw?.baseResponse,e.body.fastifyResponse=t,r())}a(tme,"authHandler");async function rme(e,t,r=!1){let n;try{e.body.bypass_auth&&delete e.body.bypass_auth,n=qK.chooseOperation(e.body);let s=await qK.processLocalTransaction(e,n);if(s instanceof Khe&&s.headers){for(let[i,o]of s.headers)t.header(i,o);e.headers["accept-encoding"]?.includes("gzip")&&(t.header("content-encoding","gzip"),s=s.pipe(jhe({level:Jhe.Z_BEST_SPEED})))}return s}catch(s){throw lh.error(s),s}}a(rme,"handlePostRequest");$K.exports={authHandler:tme,handlePostRequest:rme,handleServerUncaughtException:Xhe,serverErrorHandler:Zhe,reqBodyValidationHandler:eme}});var WK=w((Mve,YK)=>{"use strict";var nme=require("fastify-plugin"),{handlePostRequest:VK,authHandler:sme,reqBodyValidationHandler:ime}=hT();async function ome(e){e.decorate("hdbCore",{preValidation:[ime,sme],request:a(t=>KK(VK(t,response)),"request"),requestWithoutAuthentication:a((t,r)=>KK(VK(t,r,!0)),"requestWithoutAuthentication")})}a(ome,"hdbCore");async function KK(e){if(e=await e,e?.[Symbol.asyncIterator]&&!e[Symbol.iterator]){let t=[];for await(let r of e)t.push(r);return t}return e}a(KK,"convertAsyncIterators");YK.exports=nme(ome)});var jK=w((xve,zK)=>{"use strict";var Uve=require("fs"),mT=ae();mT.initSync();var{CONFIG_PARAMS:VI}=(H(),C(G)),ame=1024*1024*1024;function cme(e){let t=mT.get(VI.HTTP_TIMEOUT),r=mT.get(VI.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:ame,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,maxParamLength:mT.get(VI.HTTP_MAXPARAMLENGTH)??1e3,https:e}}a(cme,"getServerOptions");zK.exports=cme});var XK=w((Hve,QK)=>{"use strict";var KI=ae();KI.initSync();var{CONFIG_PARAMS:JK}=(H(),C(G));function lme(){let e=KI.get(JK.HTTP_CORSACCESSLIST),t=KI.get(JK.HTTP_CORS),r;return t&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},e&&e.length>0&&e[0]!==null&&e[0]!=="*"&&(r.origin=(n,s)=>s(null,e.indexOf(n)!==-1))),r}a(lme,"getCORSOptions");QK.exports=lme});var tY=w((Fve,eY)=>{"use strict";var ZK=ae();ZK.initSync();var ume=(H(),C(G));function dme(){return ZK.get(ume.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(dme,"getHeaderTimeoutConfig");eY.exports=dme});var WI={};ve(WI,{customFunctionsServer:()=>pme,ready:()=>hY,start:()=>_me});function _me(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){$o||($o=pY(t),We.http((await $o).server));let o=await $o,c=(0,YI.dirname)(s),l=(0,YI.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!rY.has(c)){rY.add(c);try{o.register(mme(c,l))}catch(u){if(u.message==="Root plugin has already booted")ht.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw u}}},ready:hY}}async function pme(){try{ht.info("In Custom Functions Fastify server"+process.cwd()),ht.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),ht.debug(`Custom Functions server process ${process.pid} starting up.`),await hme();let e=cY.get(x.HTTP_SECUREPORT)>0,t;try{t=$o=await pY(e)}catch(r){throw ht.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw ht.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){ht.error(`Custom Functions ${process.pid} Error: ${e}`),ht.error(e),process.exit(1)}}async function hme(){try{ht.info("Custom Functions starting configuration."),await lY.setUsersWithRolesCache(),ht.info("Custom Functions completed configuration.")}catch(e){ht.error(e)}}function mme(e,t){return async function(r){try{ht.info("Custom Functions starting buildRoutes"),ht.trace("Loading fastify routes folder "+e),(0,nY.existsSync)(e)&&r.register(aY.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:ht.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?ht.error(s.message):s&&ht.error(s),o()})}catch(n){ht.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function pY(e){ht.info("Custom Functions starting buildServer.");let t=(0,uY.default)(e),r=(0,sY.default)(t);r.server.headersTimeout=(0,fY.default)(),r.setErrorHandler(_Y.serverErrorHandler);let n=(0,dY.default)();return n&&r.register(iY.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,l){r.server.emit("unhandled",c.raw,l.raw)}),o()}),r.register(oY.default),await r.register(fme),await r.after(),jf(r),ht.info("Custom Functions completed buildServer."),r}function hY(){if($o)return $o.then?$o.then(e=>e.ready()):$o.ready()}var YI,nY,sY,iY,oY,aY,cY,ht,fme,lY,uY,dY,fY,_Y,$o,rY,mY=be(()=>{YI=require("path"),nY=require("fs"),sY=M(require("fastify")),iY=M(require("@fastify/cors")),oY=M(RO()),aY=M(require("@fastify/autoload")),cY=M(ae());H();ht=M(z()),fme=M(WK()),lY=M(Rn()),uY=M(jK()),dY=M(XK()),fY=M(tY()),_Y=M(hT());ao();Vr();rY=new Set;a(_me,"start");a(pme,"customFunctionsServer");a(hme,"setUp");a(mme,"buildRouteFolder");a(pY,"buildServer");a(hY,"ready")});var zI={};ve(zI,{start:()=>Eme});function Eme(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,AY.default)(r,e);return e.server.http(async(s,i)=>{if(!s.isWebSocket)return new Promise(o=>n(s._nodeRequest,s._nodeResponse,()=>{o(i(s))}))}),!0}},handleFile(t,r,n){gY||(gY=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=EY.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,SY.default)(s,(0,TY.realpathSync)(o))}}return i(s)},{runFirst:!0})),EY.set(r,n)}}}var SY,TY,AY,EY,gY,RY=be(()=>{SY=M(require("send")),TY=require("fs"),AY=M(require("serve-static")),EY=new Map;a(Eme,"start")});var jI={};ve(jI,{start:()=>gme});function gme({override:e}){return{handleFile:a((t,r,n)=>{ET.default.debug(`Loading env file: ${n}`);for(let[s,i]of Object.entries((0,yY.parse)(t))){if(process.env[s]!==void 0)if(ET.default.warn(`Environment variable conflict: ${s} from ${n} is already set on process.env`),e)ET.default.debug(`override option enabled. overriding environment variable: ${s}`);else continue;process.env[s]=i}},"handleFile")}}var yY,ET,bY=be(()=>{yY=require("dotenv"),ET=M(z());a(gme,"start")});var NY={};ve(NY,{Request:()=>JI,createReuseportFd:()=>gT});var OY,JI,QI,XI,gT,ZI=be(()=>{OY=require("os"),JI=class{static{a(this,"Request")}#e;constructor(t,r){this.method=t.method;let n=t.url;this._nodeRequest=t,this._nodeResponse=r,this.url=n,this.headers=new XI(t.headers)}get absoluteURL(){return this.protocol+"://"+this.host+this.url}get pathname(){let t=this.url.indexOf("?");return t>-1?this.url.slice(0,t):this.url}set pathname(t){let r=this.url.indexOf("?");r>-1?this.url=t+this.url.slice(r):this.url=t}get protocol(){return this._nodeRequest.socket.encrypted?"https":"http"}get ip(){return this._nodeRequest.socket.remoteAddress}get authorized(){return this._nodeRequest.socket.authorized}get peerCertificate(){return this._nodeRequest.socket.getPeerCertificate()}get mtlsConfig(){return this._nodeRequest.socket.server.mtlsConfig}get body(){return this.#e||(this.#e=new QI(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}sendEarlyHints(t,r={}){r.link=t,this._nodeResponse.writeEarlyHints(r)}},QI=class{static{a(this,"RequestBody")}#e;constructor(t){this.#e=t}on(t,r){return this.#e.on(t,r),this}pipe(t,r){return this.#e.pipe(t,r)}},XI=class{constructor(t){this.asObject=t}static{a(this,"Headers")}set(t,r){this.asObject[t.toLowerCase()]=r}get(t){return this.asObject[t.toLowerCase()]}has(t){return this.asObject.hasOwnProperty(t.toLowerCase())}[Symbol.iterator](){return Object.entries(this.asObject)[Symbol.iterator]()}keys(){return Object.keys(this.asObject)}values(){return Object.values(this.asObject)}delete(t){delete this.asObject[t.toLowerCase()]}forEach(t){for(let[r,n]of this)t(n,r,this)}};(0,OY.platform)()!="win32"&&(gT=require("node-unix-socket").createReuseportFd)});var tC=w((jve,wY)=>{"use strict";var uh=ae();uh.initSync();var Vd=require("fs-extra"),eC=require("path"),Kd=(H(),C(G)),Sme=require("crypto"),Tme=require("uuid").v4;wY.exports=Ame;function Ame(){if(uh.getHdbBasePath()!==void 0){let e=eC.join(uh.getHdbBasePath(),Kd.LICENSE_KEY_DIR_NAME,Kd.JWT_ENUM.JWT_PRIVATE_KEY_NAME),t=eC.join(uh.getHdbBasePath(),Kd.LICENSE_KEY_DIR_NAME,Kd.JWT_ENUM.JWT_PUBLIC_KEY_NAME),r=eC.join(uh.getHdbBasePath(),Kd.LICENSE_KEY_DIR_NAME,Kd.JWT_ENUM.JWT_PASSPHRASE_NAME);try{Vd.accessSync(r),Vd.accessSync(e),Vd.accessSync(t)}catch(n){if(n.code==="ENOENT"){let s=Tme(),i=Sme.generateKeyPairSync("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem",cipher:"aes-256-cbc",passphrase:s}});Vd.writeFileSync(r,s),Vd.writeFileSync(e,i.privateKey),Vd.writeFileSync(t,i.publicKey)}else throw n}}}a(Ame,"checkJWTTokenExist")});var CY=w((Qve,IY)=>{"use strict";var rC=class{static{a(this,"HdbInfoInsertObject")}constructor(t,r,n){this.info_id=t,this.data_version_num=r,this.hdb_version_num=n}};IY.exports={HdbInfoInsertObject:rC}});var LY=w((Zve,DY)=>{"use strict";var PY=(H(),C(G)),nC=class{static{a(this,"UpgradeObject")}constructor(t,r){this[PY.UPGRADE_JSON_FIELD_NAMES_ENUM.DATA_VERSION]=t,this[PY.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION]=r}};DY.exports={UpgradeObject:nC}});var ST=w((tUe,vY)=>{"use strict";var vs=require("prompt"),Yd=require("chalk"),MY=z(),mi=require("os"),sC=ua(),iC=["yes","y"];async function Rme(e){let t=`${mi.EOL}`+Yd.bold.green("Your current HarperDB version requires that we complete an update process.")+`${mi.EOL}If a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${mi.EOL}${mi.EOL}You can read more about the changes in this upgrade at https://harperdb.io/developers/release-notes/${mi.EOL}`;vs.override=sC(["CONFIRM_UPGRADE"]),vs.start(),vs.message=t;let r={properties:{CONFIRM_UPGRADE:{description:Yd.magenta(`${mi.EOL}[CONFIRM_UPGRADE] Do you want to upgrade your HDB instance now? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"no",required:!0}}},n;try{n=await vs.get([r])}catch(s){return MY.error("There was an error when prompting user about an upgrade."),MY.error(s),!1}return iC.includes(n.CONFIRM_UPGRADE)}a(Rme,"forceUpdatePrompt");async function yme(e){let t=`${mi.EOL}`+Yd.bold.green(`Your installed HarperDB version is older than the version used to create your data. Downgrading is not recommended as it is not tested and guaranteed to work. However, if you need to downgrade, and a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${mi.EOL}`);vs.override=sC(["CONFIRM_DOWNGRADE"]),vs.start(),vs.message=t;let r={properties:{CONFIRM_DOWNGRADE:{description:Yd.magenta(`${mi.EOL}[CONFIRM_DOWNGRADE] Do you want to proceed with using your downgraded HDB instance now? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"no",required:!0}}},n=await vs.get([r]);return iC.includes(n.CONFIRM_DOWNGRADE)}a(yme,"forceDowngradePrompt");async function bme(){let e=`${mi.EOL}`+Yd.bold.green("We now require a Certifacte Authority certificate. HarperDB can generate all new certificates for you (your existing certificates will be backed up) or you can keep any existing certificates and add your own CA certificate. To add your own CA certificate set the <certificateAuthority> parameter in harperdb-config.yaml");vs.override=sC(["GENERATE_CERTS"]),vs.start(),vs.message=e;let t={properties:{GENERATE_CERTS:{description:Yd.magenta(`${mi.EOL}[GENERATE_CERTS] Do you want HarperDB to generate all new certificates? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"yes",required:!0}}},r=await vs.get([t]);return iC.includes(r.GENERATE_CERTS)}a(bme,"upgradeCertsPrompt");vY.exports={forceUpdatePrompt:Rme,forceDowngradePrompt:yme,upgradeCertsPrompt:bme}});var aC=w((nUe,UY)=>{"use strict";var oC=class{static{a(this,"UpgradeDirective")}constructor(t){this.version=t,this.sync_functions=[],this.async_functions=[]}};UY.exports=oC});var BY=w((lUe,xY)=>{"use strict";var Ome=ie(),Nme=yt(),iUe=z(),oUe=require("path"),aUe=require("fs"),cUe=(H(),C(G));xY.exports={getOldPropsValue:wme};function wme(e,t,r=!1){let n=t.getRaw(e);return Ome.isNotEmptyAndHasValue(n)?n:r?Nme.getDefaultConfig(e):""}a(wme,"getOldPropsValue")});var GY=w((dUe,FY)=>{"use strict";var ec=require("path"),tc=require("fs-extra"),Ime=require("properties-reader"),Cme=aC(),_r=z(),{getOldPropsValue:mt}=BY(),{HDB_SETTINGS_NAMES:Te,CONFIG_PARAMS:Gl}=(H(),C(G)),ql=yt(),TT=ae(),HY=ie(),Yi=(H(),C(G)),cC=new Cme("3.1.0"),kY=[];function Pme(){let e=Ime(TT.get(Te.SETTINGS_PATH_KEY)),t="Updating settings file for version 3.1.0";console.log(t),_r.info(t);let r=` ;Settings for the HarperDB process.
37
+ `+u):await Oe.outputFile(l,u);let f="";if(await Oe.pathExists(Fo)||(await Oe.writeFile(Fo,""),await Oe.chmod(Fo,"0600")),i=="github.com"&&!(await Oe.readFile(Fo,"utf8")).includes("github.com"))try{let S=(await(await fetch("https://api.github.com/meta")).json()).ssh_keys;for(let g of S)Oe.appendFile(Fo,"github.com "+g+`
38
+ `)}catch{f=". Unable to get known hosts from github.com. Set your known hosts manually using set_ssh_known_hosts."}o&&await Oe.appendFile(Fo,o);let d=await _i(e);return d.message=`Added ssh key: ${r}${f}`,d}a(Hfe,"addSSHKey");async function kfe(e){let t=Pn.updateSSHKeyValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let{name:r,key:n}=e;Bt.trace("updating ssh key",r);let s=we.join(Xa,r+".key");if(!await Oe.pathExists(s))throw new Error("Key does not exist. Use add_ssh_key");await Oe.outputFile(s,n);let i=await _i(e);return i.message=`Updated ssh key: ${r}`,i}a(kfe,"updateSSHKey");async function Ffe(e){let t=Pn.deleteSSHKeyValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let{name:r}=e;Bt.trace("deleting ssh key",r);let n=we.join(Xa,r+".key"),s=we.join(Xa,"config");if(!await Oe.pathExists(n))throw new Error("Key does not exist");let i=await Oe.readFile(s,"utf8"),o=new RegExp(`#${r}[\\S\\s]*?IdentitiesOnly yes`,"g");i=i.replace(o,""),await Oe.outputFile(s,i),Oe.removeSync(n);let c=await _i(e);return c.message=`Deleted ssh key: ${r}`,c}a(Ffe,"deleteSSHKey");async function Gfe(e){let t=[];return await Oe.pathExists(Xa)&&(await Oe.readdir(Xa)).forEach(r=>{r!="known_hosts"&&r!="config"&&t.push({name:r.split(".")[0]})}),t}a(Gfe,"listSSHKeys");async function qfe(e){let t=Pn.setSSHKnownHostsValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let{known_hosts:r}=e;await Oe.outputFile(Fo,r);let n=await _i(e);return n.message="Known hosts successfully set",n}a(qfe,"setSSHKnownHosts");async function $fe(e){return await Oe.pathExists(Fo)?{known_hosts:await Oe.readFile(Fo,"utf8")}:{known_hosts:null}}a($fe,"getSSHKnownHosts");Object.assign(xV,{customFunctionsStatus:bfe,getCustomFunctions:Ofe,getCustomFunction:Nfe,setCustomFunction:wfe,dropCustomFunction:Ife,addComponent:Cfe,dropCustomFunctionProject:Pfe,packageComponent:Dfe,deployComponent:Lfe,getComponents:vfe,getComponentFile:Ufe,setComponentFile:xfe,dropComponent:Bfe,addSSHKey:Hfe,updateSSHKey:kfe,deleteSSHKey:Ffe,listSSHKeys:Gfe,setSSHKnownHosts:qfe,getSSHKnownHosts:$fe})});var Jw=I((UMe,HV)=>{"use strict";var Ds=require("joi"),BV=it();HV.exports={readTransactionLogValidator:Vfe,deleteTransactionLogsBeforeValidator:Kfe};function Vfe(e){let t=Ds.object({schema:Ds.string(),database:Ds.string(),table:Ds.string().required(),from:Ds.date().timestamp(),to:Ds.date().timestamp(),limit:Ds.number().min(1)});return BV.validateBySchema(e,t)}a(Vfe,"readTransactionLogValidator");function Kfe(e){let t=Ds.object({schema:Ds.string(),database:Ds.string(),table:Ds.string().required(),timestamp:Ds.date().timestamp().required()});return BV.validateBySchema(e,t)}a(Kfe,"deleteTransactionLogsBeforeValidator")});var $S=I((BMe,VV)=>{"use strict";var Qw=(H(),P(G)),Qp=ir(),kV=ae(),FV=ce(),GV=go(),qV=W(),{handleHDBError:GS,hdb_errors:Yfe}=pe(),{HTTP_STATUS_CODES:qS}=Yfe,{readTransactionLogValidator:Wfe,deleteTransactionLogsBeforeValidator:zfe}=Jw(),$V=Kn(),jfe="Logs successfully deleted from transaction log.",Jfe="All logs successfully deleted from transaction log.";VV.exports={readTransactionLog:Qfe,deleteTransactionLogsBefore:Zfe};async function Qfe(e){let t=Wfe(e);if(t)throw GS(t,t.message,qS.BAD_REQUEST,void 0,void 0,!0);e.database=e.database??e.schema??"data";let r=kV.checkSchemaTableExist(e.database,e.table);if(r)throw GS(new Error,r,qS.NOT_FOUND,void 0,void 0,!0);return FV.get(Qw.CONFIG_PARAMS.CLUSTERING_ENABLED)?await Xfe(e):(qV.info("Reading HarperDB logs used by Plexus"),(e.from||e.to)&&(e.search_type="timestamp",e.search_values=[e.from??0],e.to&&(e.search_values[1]=e.to)),$V.readAuditLog(e))}a(Qfe,"readTransactionLog");async function*Xfe(e){let t=GV.createNatsTableStreamName(e.database,e.table),r=await Qp.viewStreamIterator(t,parseInt(e.from),e.limit);for await(let n of r){let s=Math.floor(n?.nats_timestamp/1e6);if(e.to&&s>e.to)break;let i={operation:n?.entry?.operation,user:n?.entry?.__origin?.user,timestamp:s,records:n?.entry?.records,attributes:n?.entry?.attributes};n?.entry?.operation===Qw.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(Xfe,"readTransactionLogNats");async function Zfe(e){let t=zfe(e);if(t)throw GS(t,t.message,qS.BAD_REQUEST,void 0,void 0,!0);if(e.database=e.database??e.schema??"data",!FV.get(Qw.CONFIG_PARAMS.CLUSTERING_ENABLED))return qV.info("Delete transaction logs called for Plexus"),$V.deleteAuditLogsBefore(e);let{database:r,table:n,timestamp:s}=e,i=kV.checkSchemaTableExist(r,n);if(i)throw GS(new Error,i,qS.NOT_FOUND,void 0,void 0,!0);let o=GV.createNatsTableStreamName(r,n),{jsm:c}=await Qp.getNATSReferences(),l=await Qp.getStreamInfo(o),u=new Date(l.state.first_ts).getTime();if(s<=u)return`No transactions exist before: ${s}`;let f=jfe,d,p=new Date(l.state.last_ts).getTime();return s>p?(d=l.state.last_seq+1,f=Jfe):d=(await Qp.viewStream(o,parseInt(s),1))[0].nats_sequence,await Qp.purgeTableStream(r,n,{seq:d}),f}a(Zfe,"deleteTransactionLogsBefore")});var YV=I((kMe,KV)=>{"use strict";var Xw=class{static{a(this,"PermissionTableResponseObject")}constructor(t,r,n=[],s=[]){this.schema=t,this.table=r,this.required_table_permissions=n,this.required_attribute_permissions=s}};KV.exports=Xw});var zV=I((GMe,WV)=>{"use strict";var Zw=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};WV.exports=Zw});var tI=I(($Me,JV)=>{"use strict";var jV=YV(),e_e=zV(),{HDB_ERROR_MSGS:t_e}=Bn(),eI=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=t_e.OP_AUTH_PERMS_ERROR,this.unauthorized_access={},this.invalid_schema_items=[]}handleUnauthorizedItem(t){return this.invalid_schema_items=[],this.unauthorized_access=[t],this}handleInvalidItem(t){return this.invalid_schema_items=[t],this.unauthorized_access=[],this}addInvalidItem(t,r,n){if(r&&n){let s=`${r}_${n}`;if(this.unauthorized_access[s])return}this.invalid_schema_items.push(t)}addUnauthorizedTable(t,r,n){let s=new jV(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let l=new e_e(c,s[c]);i.push(l)});let o=`${r}_${n}`;if(this.unauthorized_access[o])this.unauthorized_access[o].required_attribute_permissions=i;else{let c=new jV(r,n,[],i);this.unauthorized_access[o]=c}}getPermsResponse(){let t=Object.values(this.unauthorized_access);return t.length>0||this.invalid_schema_items.length>0?(this.unauthorized_access=t,this):null}};JV.exports=eI});var WS=I((WMe,_1)=>{"use strict";var rI=bn(),VS=Wr(),Ls=Yg(),eh=So(),nI=jc(),r_e=ON(),n_e=fG(),th=yn(),KS=G_(),Tr=W(),s_e=PN(),i_e=Td(),o_e=tw(),a_e=iS(),c_e=sw(),l_e=iw(),u_e=lS(),d_e=dS(),sI=fS(),Go=ae(),f_e=Vq(),iI=ES(),ZV=ja(),nn=(H(),P(G)),e1=sV(),__e=Do(),t1=(Qu(),P(Z_)),r1=(US(),P(qp)),n1=Rt(),ur=zw(),p_e=require("alasql"),s1=$S(),i1=Yp(),Hd=es(),o1=(Ol(),P(bl)),a1=tI(),{handleHDBError:Dn,hdb_errors:c1}=pe(),{addNodeBack:KMe,removeNodeBack:YMe}=(Ol(),P(bl)),{HDB_ERROR_MSGS:xr,HTTP_STATUS_CODES:Xp}=c1,Z=new Map,l1="delete",Za="insert",qo="read",Bl="update",Zp="describe",QV=eh.describeSchema.name,XV=eh.describeTable.name,u1={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},h_e={insert:!0,delete:!0,deleteRecord:!0,update:!0,updateData:!0,upsert:!0,upsertData:!0},m_e="catchup",E_e="handleGetJob",g_e="handleGetJobsByStartDate",YS={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},S_e=[Ls.createTable.name,Ls.createAttribute.name,Ls.dropTable.name,Ls.dropAttribute.name],d1={EXPORT_TO_S3:"export_to_s3",EXPORT_LOCAL:"export_local"},ne=class{static{a(this,"permission")}constructor(t,r){this.requires_su=t,this.perms=r}};Z.set(rI.insert.name,new ne(!1,[Za]));Z.set(rI.update.name,new ne(!1,[Bl]));Z.set(rI.upsert.name,new ne(!1,[Za,Bl]));Z.set(VS.searchByConditions.name,new ne(!1,[qo]));Z.set(VS.searchByHash.name,new ne(!1,[qo]));Z.set(VS.searchByValue.name,new ne(!1,[qo]));Z.set(VS.search.name,new ne(!1,[qo]));Z.set(Ls.createSchema.name,new ne(!0,[]));Z.set(Ls.createTable.name,new ne(!0,[]));Z.set(Ls.createAttribute.name,new ne(!1,[Za]));Z.set(Ls.dropSchema.name,new ne(!0,[]));Z.set(Ls.dropTable.name,new ne(!0,[]));Z.set(Ls.dropAttribute.name,new ne(!0,[]));Z.set(eh.describeSchema.name,new ne(!1,[qo]));Z.set(eh.describeTable.name,new ne(!1,[qo]));Z.set(nI.deleteRecord.name,new ne(!1,[l1]));Z.set(th.addUser.name,new ne(!0,[]));Z.set(th.alterUser.name,new ne(!0,[]));Z.set(th.dropUser.name,new ne(!0,[]));Z.set(th.listUsersExternal.name,new ne(!0,[]));Z.set(KS.listRoles.name,new ne(!0,[]));Z.set(KS.addRole.name,new ne(!0,[]));Z.set(KS.alterRole.name,new ne(!0,[]));Z.set(KS.dropRole.name,new ne(!0,[]));Z.set(s_e.name,new ne(!0,[]));Z.set(i_e.name,new ne(!0,[]));Z.set(o_e.name,new ne(!0,[]));Z.set(a_e.name,new ne(!0,[]));Z.set(c_e.name,new ne(!0,[]));Z.set(l_e.name,new ne(!0,[]));Z.set(sI.setRoutes.name,new ne(!0,[]));Z.set(sI.getRoutes.name,new ne(!0,[]));Z.set(sI.deleteRoutes.name,new ne(!0,[]));Z.set(n1.setConfiguration.name,new ne(!0,[]));Z.set(u_e.clusterStatus.name,new ne(!0,[]));Z.set(d_e.name,new ne(!0,[]));Z.set(iI.getFingerprint.name,new ne(!0,[]));Z.set(iI.setLicense.name,new ne(!0,[]));Z.set(nI.deleteFilesBefore.name,new ne(!0,[]));Z.set(nI.deleteAuditLogsBefore.name,new ne(!0,[]));Z.set(ZV.restart.name,new ne(!0,[]));Z.set(ZV.restartService.name,new ne(!0,[]));Z.set(r_e.name,new ne(!0,[]));Z.set(n_e.name,new ne(!0,[qo]));Z.set(__e.systemInformation.name,new ne(!0,[]));Z.set(n1.getConfiguration.name,new ne(!0,[]));Z.set(s1.readTransactionLog.name,new ne(!0,[]));Z.set(s1.deleteTransactionLogsBefore.name,new ne(!0,[]));Z.set(i1.installModules.name,new ne(!0,[]));Z.set(i1.auditModules.name,new ne(!0,[]));Z.set(Hd.createCsr.name,new ne(!0,[]));Z.set(Hd.signCertificate.name,new ne(!0,[]));Z.set(Hd.listCertificates.name,new ne(!0,[]));Z.set(Hd.addCertificate.name,new ne(!0,[]));Z.set(Hd.removeCertificate.name,new ne(!0,[]));Z.set(Hd.getKey.name,new ne(!0,[]));Z.set(o1.addNodeBack.name,new ne(!0,[]));Z.set(o1.removeNodeBack.name,new ne(!0,[]));Z.set(t1.createTokens.name,new ne(!1,[]));Z.set(t1.refreshOperationToken.name,new ne(!1,[]));Z.set(r1.login.name,new ne(!1,[]));Z.set(r1.logout.name,new ne(!1,[]));Z.set(ur.customFunctionsStatus.name,new ne(!0,[]));Z.set(ur.getCustomFunctions.name,new ne(!0,[]));Z.set(ur.getComponents.name,new ne(!0,[]));Z.set(ur.getComponentFile.name,new ne(!0,[]));Z.set(ur.setComponentFile.name,new ne(!0,[]));Z.set(ur.dropComponent.name,new ne(!0,[]));Z.set(ur.getCustomFunction.name,new ne(!0,[]));Z.set(ur.setCustomFunction.name,new ne(!0,[]));Z.set(ur.dropCustomFunction.name,new ne(!0,[]));Z.set(ur.addComponent.name,new ne(!0,[]));Z.set(ur.dropCustomFunctionProject.name,new ne(!0,[]));Z.set(ur.packageComponent.name,new ne(!0,[]));Z.set(ur.deployComponent.name,new ne(!0,[]));Z.set(ur.addSSHKey.name,new ne(!0,[]));Z.set(ur.updateSSHKey.name,new ne(!0,[]));Z.set(ur.deleteSSHKey.name,new ne(!0,[]));Z.set(ur.listSSHKeys.name,new ne(!0,[]));Z.set(ur.setSSHKnownHosts.name,new ne(!0,[]));Z.set(ur.getSSHKnownHosts.name,new ne(!0,[]));Z.set(iI.getRegistrationInfo.name,new ne(!1,[]));Z.set(th.userInfo.name,new ne(!1,[]));Z.set(eh.describeAll.name,new ne(!1,[]));Z.set(E_e,new ne(!1,[]));Z.set(g_e,new ne(!0,[]));Z.set(m_e,new ne(!0,[]));Z.set(YS.CSV_DATA_LOAD,new ne(!1,[Za,Bl]));Z.set(YS.CSV_URL_LOAD,new ne(!1,[Za,Bl]));Z.set(YS.CSV_FILE_LOAD,new ne(!1,[Za,Bl]));Z.set(YS.IMPORT_FROM_S3,new ne(!1,[Za,Bl]));Z.set(d1.EXPORT_TO_S3,new ne(!0,[]));Z.set(d1.EXPORT_LOCAL,new ne(!0,[]));Z.set(nn.VALID_SQL_OPS_ENUM.DELETE,new ne(!1,[l1]));Z.set(nn.VALID_SQL_OPS_ENUM.SELECT,new ne(!1,[qo]));Z.set(nn.VALID_SQL_OPS_ENUM.INSERT,new ne(!1,[Za]));Z.set(nn.VALID_SQL_OPS_ENUM.UPDATE,new ne(!1,[Bl]));_1.exports={verifyPerms:A_e,verifyPermsAst:T_e,verifyBulkLoadAttributePerms:y_e};function T_e(e,t,r){if(Go.isEmptyOrZeroLength(e))throw Tr.info("verify_perms_ast has an empty user parameter"),Dn(new Error);if(Go.isEmptyOrZeroLength(t))throw Tr.info("verify_perms_ast has an empty user parameter"),Dn(new Error);if(Go.isEmptyOrZeroLength(r))throw Tr.info("verify_perms_ast has a null operation parameter"),Dn(new Error);try{let n=new a1,s=new f_e(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw Tr.info("No schemas defined in verifyPermsAst(), will not continue."),Dn(new Error);let c=!!t.role.permission.super_user,l=i.includes("system");if(l&&u1[r])throw Dn(new Error,xr.DROP_SYSTEM,Xp.FORBIDDEN);if(c&&!l)return null;let u=e1.getRolePermissions(t.role);t.role.permission=u,!c&&e instanceof p_e.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(u));for(let d=0;d<i.length;d++){let p=s.getTablesBySchemaName(i[d]);p&&o.set(i[d],p)}let f=f1(t,r,o,n);return f||(o.forEach((d,p)=>{for(let _=0;_<d.length;_++){let h=s.getAttributesBySchemaTableName(p,d[_]),S=aI(t.role.permission,p,d[_]);oI(h,S,r,d[_],p,n)}}),n.getPermsResponse())}catch(n){throw Dn(n)}}a(T_e,"verifyPermsAst");function A_e(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw Tr.info("null required parameter in verifyPerms"),Dn(new Error,xr.DEFAULT_INVALID_REQUEST,Xp.BAD_REQUEST);let r;t instanceof Function?r=t.name:r=t;let n=e.action,s=e.schema??e.database,i=e.table,o=new Map;s&&i&&o.set(s,[i]);let c=new a1;if(Go.isEmptyOrZeroLength(e.hdb_user?.role)||Go.isEmptyOrZeroLength(e.hdb_user?.role?.permission))return Tr.info(`User ${e.hdb_user?.username} has no role or permissions. Please assign the user a valid role.`),c.handleUnauthorizedItem(xr.USER_HAS_NO_PERMS(e.hdb_user?.username));let l=!!e.hdb_user?.role?.permission?.super_user,u=e.hdb_user?.role?.permission?.structure_user,f=o.has(nn.SYSTEM_SCHEMA_NAME)||s===nn.SYSTEM_SCHEMA_NAME;if(l&&f&&h_e[e.operation]&&(i===nn.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME||i===nn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||i===nn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME))return null;if(f&&u1[r])throw Dn(new Error,xr.DROP_SYSTEM,Xp.FORBIDDEN);if(l&&!f||u===!0&&(r===Ls.createSchema.name||r===Ls.dropSchema.name))return null;if(S_e.indexOf(r)>=0&&(u===!0||Array.isArray(u)))return u===!0||u.indexOf(s)>=0?null:c.handleUnauthorizedItem(`User does not have access to perform '${e.operation}' against schema '${s}'`);let d=e1.getRolePermissions(e.hdb_user?.role);if(e.hdb_user?.role&&(e.hdb_user.role.permission=d),(r===QV||r===XV)&&!d.super_user){if(s===nn.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(xr.SCHEMA_PERM_ERROR(s));if(r===QV&&(!d[s]||!d[s][Zp]))return c.handleInvalidItem(xr.SCHEMA_NOT_FOUND(s));if(r===XV&&(!d[s]||!d[s].tables[i]||!d[s].tables[i][Zp]))return c.handleInvalidItem(xr.TABLE_NOT_FOUND(s,i))}let p=f1(e.hdb_user,r,o,c,n);if(p)return p;if(Z.get(r)&&Z.get(r).perms.length===0)return null;if(!l&&e.get_attributes&&nn.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let S=[],g=d[s].tables[i];g[nn.PERMS_CRUD_ENUM.READ]&&(g.attribute_permissions.length>0?g.attribute_permissions.filter(E=>E[nn.PERMS_CRUD_ENUM.READ]).forEach(E=>{S.push(E.attribute_name)}):S=global.hdb_schema[s][i].attributes.map(R=>R.attribute),e.get_attributes=S)}let _=R_e(e),h=aI(e.hdb_user?.role?.permission,s,i);return oI(_,h,r,i,s,c,n),c.getPermsResponse()}a(A_e,"verifyPerms");function f1(e,t,r,n,s){if(Go.arrayHasEmptyValues([e,t,r]))throw Tr.info("hasPermissions has an invalid parameter"),Dn(new Error);let i=r.has("system"),o=e.role.permission;if(o.super_user&&(!i||Z.get(t).requires_su))return null;if(!Z.get(t))throw Tr.info(`operation ${t} not found.`),Dn(new Error,xr.OP_NOT_FOUND(t),Xp.BAD_REQUEST);if(Z.get(t)&&Z.get(t).requires_su)return Tr.info(`operation ${t} requires SU permissions.`),n.handleUnauthorizedItem(xr.OP_IS_SU_ONLY(t));let c=r.keys();for(let l of c){try{if(l&&!o[l]||o[l][Zp]===!1){n.addInvalidItem(xr.SCHEMA_NOT_FOUND(l));continue}}catch{n.addInvalidItem(xr.SCHEMA_NOT_FOUND(l));continue}let u=r.get(l);for(let f of u){let d=o[l].tables[f];if(!d||d[Zp]===!1)n.addInvalidItem(xr.TABLE_NOT_FOUND(l,f));else try{let p=[],_=Z.get(t).perms;!Go.isEmpty(s)&&_.includes(s)&&(_=[s]);for(let h=0;h<_.length;h++){let S=_[h],g=d[S];(g==null||g===!1)&&(Tr.info(`Required ${S} permission not found for ${t} ${s?`${s} `:""}operation in role ${e.role.id}`),p.push(S))}p.length>0&&n.addUnauthorizedTable(l,f,p)}catch(p){let _=xr.UNKNOWN_OP_AUTH_ERROR(t,l,f);throw Tr.error(_),Tr.error(p),Dn(c1.CHECK_LOGS_WRAPPER(_))}}}return r.size<2?n.getPermsResponse():null}a(f1,"hasPermissions");function oI(e,t,r,n,s,i,o){if(!e||!t)throw Tr.info("no attributes specified in checkAttributePerms."),Dn(new Error);let c=Z.get(r).perms;if(!c||c==="")throw Tr.info(`no permissions found for ${r} in checkAttributePerms().`),Dn(new Error);if(Go.isEmptyOrZeroLength(t))return Tr.info("No role permissions set (this is OK)."),null;o&&c.includes(o)&&(c=[o]);let l={};for(let f of e){let d=t.get(f);if(d){if(d[Zp]===!1){i.addInvalidItem(xr.ATTR_NOT_FOUND(s,n,f),s,n);continue}if(c)for(let p of c){if(nn.TIME_STAMP_NAMES.includes(d.attribute_name)&&p!==qo)throw Dn(new Error,xr.SYSTEM_TIMESTAMP_PERMS_ERR,Xp.FORBIDDEN);d[p]===!1&&(l[d.attribute_name]?l[d.attribute_name].push(p):l[d.attribute_name]=[p])}}else i.addInvalidItem(xr.ATTR_NOT_FOUND(s,n,f),s,n)}let u=Object.keys(l);u.length>0&&i.addUnauthorizedAttributes(u,s,n,l)}a(oI,"checkAttributePerms");function R_e(e){let t=new Set;try{if(e.action)return t;if(e.operation===nn.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS&&e.conditions.forEach(r=>{t.add(r.search_attribute)}),e&&e.search_attribute&&t.add(e.search_attribute),!e.records||e.records.length===0){if(!e.get_attributes||!e.get_attributes.length===0)return t;for(let r=0;r<e.get_attributes.length;r++)t.add(e.get_attributes[r])}else for(let r=0;r<e.records.length;r++){let n=Object.keys(e.records[r]);for(let s=0;s<n.length;s++)t.add(n[s])}}catch(r){Tr.info(r)}return t}a(R_e,"getRecordAttributes");function aI(e,t,r){let n=new Map;if(Go.isEmpty(e))return Tr.info("no hdb_user specified in getAttributePermissions"),n;if(e.super_user||!t||!r)return n;try{e[t].tables[r].attribute_permissions.forEach(s=>{n.has(s.attribute_name)||n.set(s.attribute_name,s)})}catch{Tr.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(aI,"getAttributePermissions");function y_e(e,t,r,n,s,i,o){let c=new Set(i),l=aI(e,n,s);oI(c,l,t,s,n,o,r)}a(y_e,"verifyBulkLoadAttributePerms")});var jS=I((jMe,g1)=>{"use strict";g1.exports={evaluateSQL:x_e,processAST:E1,convertSQLToAST:m1,checkASTPermissions:h1};var b_e=bn(),p1=require("util"),O_e=p1.callbackify(b_e.insert),N_e=Wr().search,w_e=rk().update,I_e=p1.callbackify(w_e),C_e=sk().convertDelete,ec=require("alasql"),P_e=WS(),zS=W(),D_e=cE(),L_e=ae(),rh=(H(),P(G)),{hdb_errors:M_e,handleHDBError:cI}=pe(),{HTTP_STATUS_CODES:lI}=M_e;D_e(ec);var v_e=403,U_e="There was a problem performing this insert. Please check the logs and try again.",uI=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function x_e(e,t){let r=e.parsed_sql_object;if(!r){r=m1(e.sql);let n,s=r.ast.statements[0];if(s instanceof ec.yy.Insert?n=s.into.databaseid:s instanceof ec.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof ec.yy.Update||s instanceof ec.yy.Delete?n=s.table.databaseid:zS.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof ec.yy.Select)&&L_e.isEmptyOrZeroLength(n))return t("No schema specified",null)}E1(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(x_e,"evaluateSQL");function h1(e,t){let r;try{r=P_e.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(h1,"checkASTPermissions");function m1(e){let t=new uI;if(!e)throw cI(new Error,"The 'sql' parameter is missing from the request body",lI.BAD_REQUEST);try{let r=e.trim(),n=ec.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
39
+ `);throw n[1]?cI(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,lI.BAD_REQUEST):cI(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",lI.BAD_REQUEST)}return t}a(m1,"convertSQLToAST");function E1(e,t,r){try{let n=B_e;if(!e.bypass_auth&&!t.permissions_checked){let i=h1(e,t);if(i&&i.length>0)return r(v_e,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case rh.VALID_SQL_OPS_ENUM.SELECT:n=N_e,s=t.ast.statements[0];break;case rh.VALID_SQL_OPS_ENUM.INSERT:n=H_e;break;case rh.VALID_SQL_OPS_ENUM.UPDATE:n=I_e;break;case rh.VALID_SQL_OPS_ENUM.DELETE:n=C_e;break;default:throw new Error(`unsupported SQL type ${t.variant} in SQL: ${e}`)}n(s,(i,o)=>{if(i){r(i);return}r(null,o)})}catch(n){return r(n)}}a(E1,"processAST");function B_e(e,t){zS.info(e),t("unknown sql statement")}a(B_e,"nullFunction");function H_e({statement:e,hdb_user:t},r){let n=e.into,s={schema:n.databaseid,table:n.tableid,operation:"insert",hdb_user:t},i=e.columns.map(o=>o.columnid);try{s.records=k_e(i,e.values)}catch(o){return r(o)}O_e(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(l){zS.error(`Error delete new_attributes from insert response: ${l}`)}r(null,c)})}a(H_e,"convertInsert");function k_e(e,t){try{return t.map(r=>{if(e.length!==r.length)throw"number of values do not match number of columns in insert";let n={};return r.forEach((s,i)=>{if(s.columnid)throw"cannot use a column in insert value";"value"in s?n[e[i]]=s.value:n[e[i]]=ec.compile(`SELECT ${s.toString()} AS [${rh.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw zS.error(r),new Error(U_e)}}a(k_e,"createDataObjects")});var mI=I((ZMe,R1)=>{var ZS=require("clone"),eT=it(),F_e=ae(),QS=(H(),P(G)),QMe=W(),dI=require("fs"),_I=require("joi"),{string:XS}=_I.types(),{hdb_errors:G_e,handleHDBError:JS}=pe(),{HDB_ERROR_MSGS:XMe,HTTP_STATUS_CODES:fI}=G_e,{common_validators:kd}=Li(),S1=" is required",q_e=["insert","update","upsert"],pI={database:{presence:!1,format:kd.schema_format,length:kd.schema_length},schema:{presence:!1,format:kd.schema_format,length:kd.schema_length},table:{presence:!0,format:kd.schema_format,length:kd.schema_length},action:{inclusion:{within:q_e,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},$_e={schema:XS.required(),table:XS.required(),action:XS.valid("insert","update","upsert")},{AWS_ACCESS_KEY:V_e,AWS_SECRET:K_e,AWS_BUCKET:Y_e,AWS_FILE_KEY:W_e,REGION:z_e}=QS.S3_BUCKET_AUTH_KEYS,j_e={s3:{presence:!0},[`s3.${V_e}`]:{presence:!0,type:"String"},[`s3.${K_e}`]:{presence:!0,type:"String"},[`s3.${Y_e}`]:{presence:!0,type:"String"},[`s3.${W_e}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${z_e}`]:{presence:!0,type:"String"}},T1=ZS(pI);T1.data.presence={message:S1};var A1=ZS(pI);A1.file_path.presence={message:S1};var J_e=Object.assign(ZS(pI),j_e),hI=ZS($_e);hI.csv_url=XS.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();hI.passthrough_headers=_I.object();function Q_e(e){let t=eT.validateObject(e,T1);return tT(e,t)}a(Q_e,"dataObject");function X_e(e){let t=eT.validateBySchema(e,_I.object(hI));return tT(e,t)}a(X_e,"urlObject");function Z_e(e){let t=eT.validateObject(e,A1);return tT(e,t)}a(Z_e,"fileObject");function epe(e){let t=eT.validateObject(e,J_e);return tT(e,t)}a(epe,"s3FileObject");function tT(e,t){if(!t){let r=F_e.checkGlobalSchemaTable(e.schema,e.table);if(r)return JS(new Error,r,fI.BAD_REQUEST);if(e.operation===QS.OPERATIONS_ENUM.CSV_FILE_LOAD)try{dI.accessSync(e.file_path,dI.constants.R_OK|dI.constants.F_OK)}catch(n){return n.code===QS.NODE_ERROR_CODES.ENOENT?JS(n,`No such file or directory ${n.path}`,fI.BAD_REQUEST):n.code===QS.NODE_ERROR_CODES.EACCES?JS(n,`Permission denied ${n.path}`,fI.BAD_REQUEST):JS(n)}}return t}a(tT,"postValidateChecks");R1.exports={dataObject:Q_e,urlObject:X_e,fileObject:Z_e,s3FileObject:epe}});var EI=I((tve,y1)=>{"use strict";var nh=W(),rT=(H(),P(G));async function tpe(e,t,r,n=void 0){if(!e||typeof e!="function")throw new Error("Invalid function parameter");let s;try{return s=await e(t),r&&await r(t,s,n),t.operation===rT.OPERATIONS_ENUM.INSERT||t.operation===rT.OPERATIONS_ENUM.UPDATE||t.operation===rT.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===rT.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(nh.info(i.message),i):i.http_resp_msg?(nh.error(`Error calling operation: ${e.name}`),nh.error(i.http_resp_msg),i):(nh.error(`Error calling operation: ${e.name}`),nh.error(i),i)}}a(tpe,"callOperationFunctionAsAwait");y1.exports={callOperationFunctionAsAwait:tpe}});var gI=I((nve,O1)=>{"use strict";var{S3:rpe,GetObjectCommand:npe}=require("@aws-sdk/client-s3");O1.exports={getFileStreamFromS3:spe,getS3AuthObj:b1};async function spe(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await b1(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new npe(r))).Body}a(spe,"getFileStreamFromS3");function b1(e,t,r){return new rpe({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(b1,"getS3AuthObj")});var w1=I((ive,N1)=>{"use strict";var SI=class{static{a(this,"BulkLoadFileObject")}constructor(t,r,n,s,i,o,c=null){this.op=t,this.action=r,this.schema=n,this.table=s,this.file_path=i,this.file_type=o,this.role_perms=c}},TI=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};N1.exports={BulkLoadFileObject:SI,BulkLoadDataObject:TI}});var C1=I((ave,I1)=>{"use strict";var AI=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};I1.exports=AI});var wI=I((_ve,Y1)=>{"use strict";var nT=bn(),iT=mI(),ipe=require("needle"),pi=(H(),P(G)),lve=St(),Fd=ae(),{handleHDBError:Ft,hdb_errors:H1}=pe(),{HTTP_STATUS_CODES:Br,HDB_ERROR_MSGS:Ar,CHECK_LOGS_WRAPPER:kl}=H1,Gd=W(),RI=require("papaparse");Fd.promisifyPapaParse();var hi=require("fs-extra"),ope=require("path"),{chain:P1}=require("stream-chain"),D1=require("stream-json/streamers/StreamArray"),L1=require("stream-json/utils/Batch"),M1=require("stream-chain/utils/comp"),{finished:v1}=require("stream"),ape=ce(),k1=EI(),cpe=gI(),{BulkLoadFileObject:bI,BulkLoadDataObject:lpe}=w1(),OI=tI(),{verifyBulkLoadAttributePerms:F1}=WS(),uve=C1(),dve=ir(),fve=go(),{databases:upe}=(De(),P(nt)),{coerceType:dpe}=($f(),P(II)),U1="No records parsed from csv file.",Hl=`${ape.get("HDB_ROOT")}/tmp`,{schema_regex:fpe}=Li(),x1=1024*1024*2,B1=5e3,_pe={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};Y1.exports={csvDataLoad:ppe,csvURLLoad:hpe,csvFileLoad:mpe,importFromS3:Epe};async function ppe(e,t){let r=iT.dataObject(e);if(r)throw Ft(r,r.message,Br.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=$1(e.schema,e.table),i=RI.parse(e.data,{header:!0,skipEmptyLines:!0,transform:yI.bind(null,s),dynamicTyping:!1}),o=new OI;e.hdb_user&&e.hdb_user?.role&&e.hdb_user?.role?.permission&&e.hdb_user?.role?.permission?.super_user!==!0&&F1(e.hdb_user?.role?.permission,this.job_operation_function.name,e.action,e.schema,e.table,i.meta.fields,o);let c=o.getPermsResponse();if(c)throw Ft(new Error,c,Br.BAD_REQUEST,void 0,void 0,!0);let l=new lpe(e.action,e.schema,e.table,i.data);return n=await k1.callOperationFunctionAsAwait(V1,l,null),n.message===U1?U1:K1(n.records,n.number_written)}catch(s){throw Fl(s)}}a(ppe,"csvDataLoad");async function hpe(e){let t=iT.urlObject(e);if(t)throw Ft(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${Hl}/${r}`;try{await gpe(e,r)}catch(s){throw Gd.error(Ar.DOWNLOAD_FILE_ERR(r)+" - "+s),Ft(s,kl(Ar.DOWNLOAD_FILE_ERR(r)))}try{let s=new bI(this.job_operation_function.name,e.action,e.schema,e.table,n,pi.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission),i=await NI(s);return await sT(n),i}catch(s){throw await sT(n),Fl(s)}}a(hpe,"csvURLLoad");async function mpe(e){let t=iT.fileObject(e);if(t)throw Ft(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r=new bI(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,pi.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission);try{return await NI(r)}catch(n){throw Fl(n)}}a(mpe,"csvFileLoad");async function Epe(e){let t=iT.s3FileObject(e);if(t)throw Ft(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=ope.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${Hl}/${s}`;let i=new bI(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user?.role?.permission);await Spe(s,e);let o=await NI(i);return await sT(r),o}catch(n){throw await sT(r),Fl(n)}}a(Epe,"importFromS3");async function gpe(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await ipe("get",e.csv_url,n)}catch(n){let s=`Error downloading CSV file from ${e.csv_url}, status code: ${n.statusCode}. Check the log for more information.`;throw Ft(n,s,n.statusCode,pi.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}Ape(r,e.csv_url),await Tpe(t,r.raw)}a(gpe,"downloadCSVFile");async function Spe(e,t){try{let r=`${Hl}/${e}`;await hi.mkdirp(Hl),await hi.writeFile(`${Hl}/${e}`,"",{flag:"a+"});let n=await hi.createWriteStream(r),s=await cpe.getFileStreamFromS3(t);await new Promise((i,o)=>{s.on("error",function(c){o(c)}),s.pipe(n).on("error",function(c){o(c)}).on("close",function(){Gd.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw Gd.error(Ar.S3_DOWNLOAD_ERR+" - "+r),Ft(r,kl(Ar.S3_DOWNLOAD_ERR))}}a(Spe,"downloadFileFromS3");async function Tpe(e,t){try{await hi.mkdirp(Hl),await hi.writeFile(`${Hl}/${e}`,t)}catch(r){throw Gd.error(Ar.WRITE_TEMP_FILE_ERR),Ft(r,kl(Ar.DEFAULT_BULK_LOAD_ERR))}}a(Tpe,"writeFileToTempFolder");async function sT(e){if(e)try{await hi.access(e),await hi.unlink(e)}catch{Gd.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(sT,"deleteTempFile");function Ape(e,t){if(e.statusCode!==H1.HTTP_STATUS_CODES.OK)throw Ft(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,Br.BAD_REQUEST);if(!_pe[e.headers["content-type"]])throw Ft(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,Br.BAD_REQUEST);if(!e.raw)throw Ft(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,Br.BAD_REQUEST)}a(Ape,"validateURLResponse");async function NI(e){try{let t;switch(e.file_type){case pi.VALID_S3_FILE_TYPES.CSV:t=await Rpe(e);break;case pi.VALID_S3_FILE_TYPES.JSON:t=await ype(e);break;default:throw Ft(new Error,Ar.DEFAULT_BULK_LOAD_ERR,Br.BAD_REQUEST,pi.LOG_LEVELS.ERROR,Ar.INVALID_FILE_EXT_ERR(e))}return K1(t.records,t.number_written)}catch(t){throw Fl(t)}}a(NI,"fileLoad");async function G1(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;s&&s.pause();let o={operation:e.action,schema:e.schema,table:e.table,records:i};try{let{attributes:c}=await nT.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&F1(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let l=Ft(c);r(l)}}a(G1,"validateChunk");async function q1(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;Fd.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Fd.isEmpty(c)&&!Fd.isEmpty(c.__parsed_extra)&&delete c.__parsed_extra});else{let c=new Set;i.forEach(l=>{Object.keys(l).forEach(u=>c.add(u))}),o=[...c]}try{let c={schema:e.schema,table:e.table,action:e.action,data:i},l=await k1.callOperationFunctionAsAwait(V1,c,null);t.records+=l.records,t.number_written+=l.number_written,s&&s.resume()}catch(c){let l=Ft(c,kl(Ar.INSERT_CSV_ERR),Br.INTERNAL_SERVER_ERROR,pi.LOG_LEVELS.ERROR,Ar.INSERT_CSV_ERR+" - "+c);r(l)}}a(q1,"insertChunk");async function Rpe(e){let t={records:0,number_written:0},r=$1(e.schema,e.table);try{let n=new OI,s=hi.createReadStream(e.file_path,{highWaterMark:x1});s.setEncoding("utf8"),await RI.parsePromise(s,G1.bind(null,e,n),yI.bind(null,r));let i=n.getPermsResponse();if(i)throw Ft(new Error,i,Br.BAD_REQUEST);return s=hi.createReadStream(e.file_path,{highWaterMark:x1}),s.setEncoding("utf8"),await RI.parsePromise(s,q1.bind(null,e,t),yI.bind(null,r)),s.destroy(),t}catch(n){throw Ft(n,kl(Ar.PAPA_PARSE_ERR),Br.INTERNAL_SERVER_ERROR,pi.LOG_LEVELS.ERROR,Ar.PAPA_PARSE_ERR+n)}}a(Rpe,"callPapaParse");function $1(e,t){let r=upe[e][t].attributes,n=new Map;for(let s of r)s.type&&!s.computed&&!s.relationship&&n.set(s.name,i=>dpe(i,s));return n}a($1,"createTransformMap");function yI(e,t,r){let n=e.get(r);return n?n(t):Fd.autoCast(t)}a(yI,"typeFunction");async function ype(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new OI,s=P1([hi.createReadStream(e.file_path,{encoding:"utf-8"}),D1.withParser(),c=>c.value,new L1({batchSize:B1}),M1(async c=>{await G1(e,n,r,c)})]);await new Promise((c,l)=>{v1(s,u=>{u?l(u):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw Ft(new Error,i,Br.BAD_REQUEST);let o=P1([hi.createReadStream(e.file_path,{encoding:"utf-8"}),D1.withParser(),c=>c.value,new L1({batchSize:B1}),M1(async c=>{await q1(e,t,r,c)})]);return await new Promise((c,l)=>{v1(o,u=>{u?l(u):c()}),o.resume()}),t}catch(n){throw Ft(n,kl(Ar.INSERT_JSON_ERR),Br.INTERNAL_SERVER_ERROR,pi.LOG_LEVELS.ERROR,Ar.INSERT_JSON_ERR+n)}}a(ype,"insertJson");async function V1(e){let t={};try{e.data&&e.data.length>0&&bpe(e.data[0])?t=await Ope(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",Gd.info(t.message))}catch(r){throw Fl(r)}return t}a(V1,"callBulkFileLoad");function bpe(e){let t=Object.keys(e);for(let r of t)if(!fpe.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(bpe,"validateColumnNames");async function Ope(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=nT.insert;break;case"update":i=nT.update;break;case"upsert":i=nT.upsert;break;default:throw Ft(new Error,Ar.INVALID_ACTION_PARAM_ERR(n),Br.BAD_REQUEST,pi.LOG_LEVELS.ERROR,Ar.INVALID_ACTION_PARAM_ERR(n))}try{let o=await i(s),c;switch(n){case"insert":c=o.inserted_hashes;break;case"update":c=o.update_hashes;break;case"upsert":c=o.upserted_hashes;break;default:break}if(Array.isArray(o.skipped_hashes)&&o.skipped_hashes.length>0){let f=global.hdb_schema[t][r].hash_attribute,d=e.length;for(;d--;)o.skipped_hashes.indexOf(e[d][f])>=0&&e.splice(d,1)}let l=Fd.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw Fl(o)}}a(Ope,"bulkFileLoad");function K1(e,t){return`successfully loaded ${t} of ${e} records`}a(K1,"buildResponseMsg");function Fl(e){return Ft(e,kl(Ar.DEFAULT_BULK_LOAD_ERR),Br.INTERNAL_SERVER_ERROR,pi.LOG_LEVELS.ERROR,Ar.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(Fl,"buildTopLevelErrMsg")});var DI=I((hve,eK)=>{"use strict";var PI=Wr(),Npe=gI(),{AsyncParser:wpe}=require("json2csv"),oT=require("stream"),os=ae(),CI=require("fs-extra"),Ipe=require("path"),Ms=W(),{promisify:j1}=require("util"),sh=ae(),{handleHDBError:dr,hdb_errors:Cpe}=pe(),{HDB_ERROR_MSGS:Ln,HTTP_STATUS_CODES:fr}=Cpe,{streamAsJSON:Ppe}=(NR(),P(KL)),{Upload:Dpe}=require("@aws-sdk/lib-storage"),{toCsvStream:Lpe}=(co(),P(dM)),W1=["search_by_value","search_by_hash","sql","search_by_conditions"],z1=["json","csv"],J1="json",Q1="csv",Mpe="Successfully exported JSON locally.",vpe="Successfully exported CSV locally.",Upe=1e3,xpe=PI.searchByHash,Bpe=PI.searchByValue,Hpe=j1(oT.finished);eK.exports={export_to_s3:qpe,export_local:kpe};async function kpe(e){Ms.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=X1(e);if(!os.isEmpty(t))throw Ms.error(t),dr(new Error,t,fr.BAD_REQUEST,void 0,void 0,!0);if(os.isEmpty(e.path))throw Ms.error(Ln.MISSING_VALUE("path")),dr(new Error,Ln.MISSING_VALUE("path"),fr.BAD_REQUEST,void 0,void 0,!0);let r=(os.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(Ipe.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=os.buildFolderPath(e.path,r);await Fpe(e.path);let s=await Z1(e);return await Gpe(n,e.format,s)}a(kpe,"export_local");async function Fpe(e){if(Ms.trace("in confirmPath"),os.isEmptyOrZeroLength(e))throw dr(new Error,`Invalid path: ${e}`,fr.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await CI.stat(e)}catch(r){let n;throw r.code==="ENOENT"?n=`path '${e}' does not exist`:r.code==="EACCES"?n=`access to path '${e}' is denied`:n=r.message,Ms.error(n),dr(new Error,n,fr.BAD_REQUEST,void 0,void 0,!0)}if(!t.isDirectory()){let r=`path '${e}' is not a directory, please supply a valid folder path`;throw Ms.error(r),dr(new Error,r,fr.BAD_REQUEST,void 0,void 0,!0)}return!0}a(Fpe,"confirmPath");async function Gpe(e,t,r){if(Ms.trace("in saveToLocal"),sh.isEmptyOrZeroLength(e))throw dr(new Error,Ln.INVALID_VALUE("file_path"),fr.BAD_REQUEST,void 0,void 0,!0);if(sh.isEmptyOrZeroLength(t))throw dr(new Error,Ln.INVALID_VALUE("Source format"),fr.BAD_REQUEST,void 0,void 0,!0);if(sh.isEmpty(r))throw dr(new Error,Ln.NOT_FOUND("Data"),fr.BAD_REQUEST,void 0,void 0,!0);if(t===J1){let n=CI.createWriteStream(e);return Ppe(r).pipe(n),await Hpe(n),{message:Mpe,path:e}}else if(t===Q1){let n=CI.createWriteStream(e),s=oT.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(f=>({label:f,value:f})));let c={objectMode:!0};return await new wpe(i,c).fromInput(s).toOutput(n).promise(!1),{message:vpe,path:e}}throw dr(new Error,Ln.INVALID_VALUE("format"),fr.BAD_REQUEST)}a(Gpe,"saveToLocal");async function qpe(e){if(!e.s3||Object.keys(e.s3).length===0)throw dr(new Error,Ln.MISSING_VALUE("S3 object"),fr.BAD_REQUEST);if(os.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw dr(new Error,Ln.MISSING_VALUE("aws_access_key_id"),fr.BAD_REQUEST);if(os.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw dr(new Error,Ln.MISSING_VALUE("aws_secret_access_key"),fr.BAD_REQUEST);if(os.isEmptyOrZeroLength(e.s3.bucket))throw dr(new Error,Ln.MISSING_VALUE("bucket"),fr.BAD_REQUEST);if(os.isEmptyOrZeroLength(e.s3.key))throw dr(new Error,Ln.MISSING_VALUE("key"),fr.BAD_REQUEST);if(os.isEmptyOrZeroLength(e.s3.region))throw dr(new Error,Ln.MISSING_VALUE("region"),fr.BAD_REQUEST);let t=X1(e);if(!os.isEmpty(t))throw dr(new Error,t,fr.BAD_REQUEST);Ms.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await Z1(e)}catch(l){throw Ms.error(l),l}let n,s=await Npe.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new oT.PassThrough;if(e.format===Q1){i=e.s3.key+".csv";let l=Lpe(r,r.getColumns?.());l.on("error",u=>{throw u}),l.pipe(o)}else if(e.format===J1){i=e.s3.key+".json";let l=new oT.Readable;l.pipe(o),l.on("error",d=>{throw d}),l.push("[");let u=r.length,f="";for(let[d,p]of r.entries()){let _=d===u-1?JSON.stringify(p):JSON.stringify(p)+",";f+=_,d!==0&&d%Upe===0&&(l.push(f),f="")}f.length!==0&&l.push(f),l.push("]"),l.push(null)}else throw dr(new Error,Ln.INVALID_VALUE("format"),fr.BAD_REQUEST);return new Dpe({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(qpe,"export_to_s3");function X1(e){if(Ms.trace("in exportCoreValidation"),os.isEmpty(e.format))return"format missing";if(z1.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${z1.join(", ")}`;let t=e.search_operation.operation;if(os.isEmpty(t))return"search_operation.operation missing";if(W1.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${W1.join(", ")}`}a(X1,"exportCoreValidation");async function Z1(e){Ms.trace("in getRecords");let t,r;if(sh.isEmpty(e.search_operation)||sh.isEmptyOrZeroLength(e.search_operation.operation))throw dr(new Error,Ln.INVALID_VALUE("Search operation"),fr.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=Bpe;break;case"search_by_hash":t=xpe;break;case"search_by_conditions":t=PI.searchByConditions;break;case"sql":{let n=jS();t=j1(n.evaluateSQL);break}default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,Ms.error(r),dr(new Error,r,fr.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(Z1,"getRecords")});var rK=I((Eve,tK)=>{"use strict";var LI=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};tK.exports=LI});var iK=I((Sve,sK)=>{"use strict";var $pe=(H(),P(G)),nK=require("moment"),Vpe=require("uuid").v4,MI=class{static{a(this,"JobObject")}constructor(){this.id=Vpe(),this.type=void 0,this.start_datetime=nK().valueOf(),this.created_datetime=nK().valueOf(),this.end_datetime=void 0,this.status=$pe.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};sK.exports=MI});var vI=I((Ave,_K)=>{"use strict";var Kpe=require("uuid").v4,uK=bn(),dK=Wr(),Ype=si(),Wpe=Gu(),zpe=rK(),bt=(H(),P(G)),jpe=iK(),Jpe=sg(),mi=W(),Qpe=xf(),qd=ae(),{promisify:Xpe}=require("util"),Gl=require("moment"),Zpe=jS(),aT=mI(),oK=Dy(),{deleteTransactionLogsBeforeValidator:ehe}=Jw(),{handleHDBError:aK,hdb_errors:the,ClientError:rhe}=pe(),{HTTP_STATUS_CODES:cK}=the,lK=dK.searchByValue,nhe=dK.searchByHash,she=uK.insert,ihe=Xpe(Zpe.evaluateSQL),ohe=uK.update;_K.exports={addJob:lhe,updateJob:dhe,handleGetJob:ahe,handleGetJobsByStartDate:che,getJobById:fK};async function ahe(e){if(e.id===void 0)throw new rhe("'id' is required");let t=await fK(e.id);return qd.isEmptyOrZeroLength(t)||(t[0]={...t[0]},t[0].request!==void 0&&delete t[0].request,delete t[0].__createdtime__,delete t[0].__updatedtime__),t}a(ahe,"handleGetJob");async function che(e){try{let t=await uhe(e);if(mi.trace(`Searching for jobs from ${e.from_date} to ${e.to_date}`),t&&t.length>0)for(let r of t)r.start_datetime&&(r.start_datetime_converted=Gl(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=Gl(r.end_datetime)),r.request!==void 0&&delete r.request,delete r.__createdtime__,delete r.__updatedtime__;return t}catch(t){let r=`There was an error searching jobs by date: ${t}`;throw mi.error(r),new Error(r)}}a(che,"handleGetJobsByStartDate");async function lhe(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||qd.isEmptyOrZeroLength(e.operation)){let f="job parameter is invalid";return mi.info(f),t.error=f,t}if(!bt.JOB_TYPE_ENUM[e.operation])return mi.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case bt.OPERATIONS_ENUM.CSV_FILE_LOAD:n=aT.fileObject(e);break;case bt.OPERATIONS_ENUM.CSV_URL_LOAD:n=aT.urlObject(e);break;case bt.OPERATIONS_ENUM.CSV_DATA_LOAD:n=aT.dataObject(e);break;case bt.OPERATIONS_ENUM.IMPORT_FROM_S3:n=aT.s3FileObject(e);break;case bt.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case bt.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=oK(e,"date");break;case bt.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=oK(e,"timestamp");break;case bt.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=ehe(e);break;case bt.OPERATIONS_ENUM.RESTART_SERVICE:if(bt.HDB_PROCESS_SERVICES[e.service]===void 0)throw aK(new Error,"Invalid service",cK.BAD_REQUEST,void 0,void 0,!0);break;default:break}if(n)throw aK(n,n.message,cK.BAD_REQUEST,void 0,void 0,!0);let s=new jpe;s.type=e.operation===bt.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE?bt.OPERATIONS_ENUM.DELETE_FILES_BEFORE:e.operation,s.type=e.operation,s.user=e.hdb_user?.username;let i=new Ype(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await lK(i))}catch(f){let d=`There was an error inserting a new job: ${f}`;return mi.error(d),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=Kpe();try{o=await lK(i)}catch(f){let d=`There was an error inserting a new job: ${f}`;return mi.error(d),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return mi.error("Error creating a job, could not find a unique job id."),t}s.request=e;let l=new Qpe(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),u;try{u=await she(l)}catch(f){return mi.error(`There was an error inserting a job for job type: ${e.operation} -- ${f}`),t.success=!1,t}if(u.inserted_hashes.length===0)t.message=`Had a problem creating a job with type ${s.operation} and id ${s.id}`;else{let f=`Created a job with type ${s.type} and id ${s.id}`;t.message=f,t.createdJob=s,t.success=!0,mi.trace(f)}return t}a(lhe,"addJob");async function uhe(e){let t=Gl(e.from_date,Gl.ISO_8601),r=Gl(e.to_date,Gl.ISO_8601);if(!t.isValid())throw new Error("Invalid 'from' date, must be in ISO-8601 format (YYYY-MM-DD).");if(!r.isValid())throw new Error("Invalid 'to' date, must be in ISO-8601 format (YYYY-MM-DD)");let n=`select * from system.hdb_job where start_datetime > '${t.valueOf()}' and start_datetime < '${r.valueOf()}'`,s=new zpe(n,e.hdb_user);try{return await ihe(s)}catch(i){throw mi.error(`there was a problem searching for jobs from date ${e.from_date} to date ${e.to_date} ${i}`),new Error("there was an error searching for jobs. Please check the log for details.")}}a(uhe,"getJobsInDateRange");async function fK(e){if(qd.isEmptyOrZeroLength(e))return qd.errorizeMessage("Invalid job ID specified.");let t=new Wpe(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await nhe(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return mi.error(n),qd.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(fK,"getJobById");async function dhe(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(qd.isEmptyOrZeroLength(e.id))throw new Error("invalid ID passed to updateJob");(e.status===bt.JOB_STATUS_ENUM.COMPLETE||e.status===bt.JOB_STATUS_ENUM.ERROR)&&(e.end_datetime=Gl().valueOf());let t=new Jpe(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await ohe(t),r}a(dhe,"updateJob")});var AK=I((yve,TK)=>{"use strict";var pK=ae(),Rr=(H(),P(G)),fhe=require("moment"),cT=wI(),ih=W(),hK=vI(),mK=DI(),EK=jc(),gK=rt(),_he=$S(),phe=ja(),{parentPort:hhe,isMainThread:SK}=require("worker_threads"),{onMessageByType:mhe}=rt(),UI=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function Ehe(e){if(!e||Object.keys(e).length===0)throw new Error("Empty runner passed to parseMessage");if(!e.json||Object.keys(e.json).length===0)throw new Error("Empty JSON passed to parseMessage");if(!e.job||Object.keys(e.job).length===0)throw new Error("Empty job passed to parseMessage");if(pK.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(pK.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case Rr.JOB_TYPE_ENUM.csv_file_load:await Yi(e,cT.csvFileLoad);break;case Rr.JOB_TYPE_ENUM.csv_url_load:await Yi(e,cT.csvURLLoad);break;case Rr.JOB_TYPE_ENUM.csv_data_load:await Yi(e,cT.csvDataLoad);break;case Rr.JOB_TYPE_ENUM.import_from_s3:await Yi(e,cT.importFromS3);break;case Rr.JOB_TYPE_ENUM.empty_trash:break;case Rr.JOB_TYPE_ENUM.export_local:await Yi(e,mK.export_local);break;case Rr.JOB_TYPE_ENUM.export_to_s3:await Yi(e,mK.export_to_s3);break;case Rr.JOB_TYPE_ENUM.delete_files_before:case Rr.JOB_TYPE_ENUM.delete_records_before:await Yi(e,EK.deleteFilesBefore);break;case Rr.JOB_TYPE_ENUM.delete_audit_logs_before:await Yi(e,EK.deleteAuditLogsBefore);break;case Rr.JOB_TYPE_ENUM.delete_transaction_logs_before:await Yi(e,_he.deleteTransactionLogsBefore);break;case Rr.JOB_TYPE_ENUM.restart_service:return await Yi(e,phe.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(Ehe,"parseMessage");async function Yi(e,t){try{e.job.status=Rr.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=fhe().valueOf(),await hK.updateJob(e.job),await ghe(e.job.id)}catch(r){let n=r.message!==void 0?r.message:r;typeof n=="string"?(n=`There was an error running ${t.name} job with id ${e.job.id} - ${n}`,r.message=n):ih.error(`There was an error running ${t.name} job with id ${e.job.id}`),ih.error(n),e.job.message=n,e.job.status=Rr.JOB_STATUS_ENUM.ERROR;try{await hK.updateJob(e.job)}catch(s){throw ih.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(Yi,"runJob");async function ghe(e){ih.trace("launching job thread:",e),SK?gK.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Rr.PROCESS_NAME_ENV_PROP]:`JOB-${e}`}}):hhe.postMessage({type:Rr.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(ghe,"launchJobThread");SK&&mhe(Rr.ITC_EVENT_TYPES.START_JOB,async(e,t)=>{try{gK.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Rr.PROCESS_NAME_ENV_PROP]:`JOB-${e.jobId}`}})}catch(r){ih.error(r)}});TK.exports={parseMessage:Ehe,RunnerMessage:UI}});var yK=I((Ove,RK)=>{"use strict";var xI=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};RK.exports=xI});var jw=I((Ive,qI)=>{"use strict";var _T=Wr(),kI=jS(),lT=wI(),$o=Yg(),uT=So(),ah=jc(),She=ON(),oh=yn(),dT=G_(),Ct=zw(),fT=W(),The=PN(),Ahe=Td(),bK=tw(),Rhe=iS(),yhe=sw(),bhe=iw(),Ohe=lS(),Nhe=dS(),BI=fS(),OK=DI(),whe=WS(),FI=vI(),K=(H(),P(G)),{hdb_errors:lh,handleHDBError:ch}=pe(),{HTTP_STATUS_CODES:NK}=lh,HI=ES(),wK=ja(),BK=require("util"),Vd=bn(),Ihe=Rs(),Che=Do(),IK=AK(),CK=(Qu(),P(Z_)),PK=(US(),P(qp)),DK=Rt(),LK=$S(),MK=Yp(),{setServerUtilities:Phe}=($f(),P(II)),{CONTEXT:wve}=(ga(),P(SR)),{_assignPackageExport:Dhe}=Ai(),{transformReq:Lhe}=ae(),{server:Mhe}=(Kr(),P(Ru)),sn=fT.loggerWithTag("operation"),$d=es(),vK=(Ol(),P(bl)),vhe=EI(),UK=_T.searchByHash,Uhe=_T.searchByValue,xhe=BK.promisify(_T.search),Bhe=BK.promisify(kI.evaluateSQL),Hhe={[K.OPERATIONS_ENUM.CREATE_ATTRIBUTE]:!0,[K.OPERATIONS_ENUM.CREATE_TABLE]:!0,[K.OPERATIONS_ENUM.CREATE_SCHEMA]:!0,[K.OPERATIONS_ENUM.DROP_ATTRIBUTE]:!0,[K.OPERATIONS_ENUM.DROP_TABLE]:!0,[K.OPERATIONS_ENUM.DROP_SCHEMA]:!0},te=yK();async function HK(e,t){try{if(e.body.operation!=="read_log"&&(fT.log_level===K.LOG_LEVELS.INFO||fT.log_level===K.LOG_LEVELS.DEBUG||fT.log_level===K.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,payload:o,...c}=e.body;sn.info(c)}}catch(n){sn.error(n)}let r=await vhe.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return Hhe[e.body.operation]&&Ihe.setSchemaDataToGlobal(n=>{n&&sn.error(n)}),r}a(HK,"processLocalTransaction");var xK=Fhe();qI.exports={chooseOperation:kK,getOperationFunction:FK,operation:GI,processLocalTransaction:HK,executeJob:vs};Phe(qI.exports);Mhe.operation=GI;function kK(e){let t;try{t=FK(e)}catch(s){throw sn.error(`Error when selecting operation function - ${s}`),s}let{operation_function:r,job_operation_function:n}=t;try{if(e.operation==="sql"||e.search_operation&&e.search_operation.operation==="sql"){let s=e.operation==="sql"?e.sql:e.search_operation.sql,i=kI.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=kI.checkASTPermissions(e,i);if(o)throw sn.error(`${NK.FORBIDDEN} from operation ${e.operation}`),sn.warn(`User '${e.hdb_user?.username}' is not permitted to ${e.operation}`),ch(new Error,o,lh.HTTP_STATUS_CODES.FORBIDDEN,void 0,void 0,!0)}}else if(!e.bypass_auth&&e.operation!==K.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.operation!==K.OPERATIONS_ENUM.LOGIN&&e.operation!==K.OPERATIONS_ENUM.LOGOUT){let s=n===void 0?r:n,i=e.search_operation?e.search_operation:e;i.hdb_user||(i.hdb_user=e.hdb_user);let o=whe.verifyPerms(i,s);if(o)throw sn.error(`${NK.FORBIDDEN} from operation ${e.operation}`),sn.warn(`User '${i.hdb_user?.username}' is not permitted to ${i.operation}`),ch(new Error,o,lh.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw ch(s,"There was an error when trying to choose an operation path")}return r}a(kK,"chooseOperation");function FK(e){if(sn.trace(`getOperationFunction with operation: ${e.operation}`),xK.has(e.operation))return xK.get(e.operation);throw ch(new Error,lh.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),lh.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(FK,"getOperationFunction");Dhe("operation",GI);function GI(e,t,r){e.hdb_user=t?.user,e.bypass_auth=!r;let n=kK(e);return HK({body:e},n)}a(GI,"operation");async function khe(e){sn.trace("In serverUtils.catchup");let t=e.transaction,r=t.channel.split(":"),n=r[0],s=r[1];for(let i of t.transactions)try{i.schema=n,i.table=s,i[K.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case K.OPERATIONS_ENUM.INSERT:o=await Vd.insert(i);break;case K.OPERATIONS_ENUM.UPDATE:o=await Vd.update(i);break;case K.OPERATIONS_ENUM.UPSERT:o=await Vd.upsert(i);break;case K.OPERATIONS_ENUM.DELETE:o=await ah.deleteRecord(i);break;default:sn.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){sn.info("Invalid operation in transaction"),sn.error(o)}}a(khe,"catchup");async function vs(e){Lhe(e);let t,r;try{r=await FI.addJob(e),t=r.createdJob,sn.info("addJob result",r);let n=new IK.RunnerMessage(t,e);return{message:await IK.parseMessage(n)??`Starting job with id ${t.id}`,job_id:t.id}}catch(n){let s=`There was an error executing job: ${n.http_resp_msg?n.http_resp_msg:n}`;throw sn.error(s),ch(n,s)}}a(vs,"executeJob");function Fhe(){let e=new Map;return e.set(K.OPERATIONS_ENUM.INSERT,new te(Vd.insert)),e.set(K.OPERATIONS_ENUM.UPDATE,new te(Vd.update)),e.set(K.OPERATIONS_ENUM.UPSERT,new te(Vd.upsert)),e.set(K.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new te(_T.searchByConditions)),e.set(K.OPERATIONS_ENUM.SEARCH_BY_HASH,new te(UK)),e.set(K.OPERATIONS_ENUM.SEARCH_BY_ID,new te(UK)),e.set(K.OPERATIONS_ENUM.SEARCH_BY_VALUE,new te(Uhe)),e.set(K.OPERATIONS_ENUM.SEARCH,new te(xhe)),e.set(K.OPERATIONS_ENUM.SQL,new te(Bhe)),e.set(K.OPERATIONS_ENUM.CSV_DATA_LOAD,new te(vs,lT.csvDataLoad)),e.set(K.OPERATIONS_ENUM.CSV_FILE_LOAD,new te(vs,lT.csvFileLoad)),e.set(K.OPERATIONS_ENUM.CSV_URL_LOAD,new te(vs,lT.csvURLLoad)),e.set(K.OPERATIONS_ENUM.IMPORT_FROM_S3,new te(vs,lT.importFromS3)),e.set(K.OPERATIONS_ENUM.CREATE_SCHEMA,new te($o.createSchema)),e.set(K.OPERATIONS_ENUM.CREATE_DATABASE,new te($o.createSchema)),e.set(K.OPERATIONS_ENUM.CREATE_TABLE,new te($o.createTable)),e.set(K.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new te($o.createAttribute)),e.set(K.OPERATIONS_ENUM.DROP_SCHEMA,new te($o.dropSchema)),e.set(K.OPERATIONS_ENUM.DROP_DATABASE,new te($o.dropSchema)),e.set(K.OPERATIONS_ENUM.DROP_TABLE,new te($o.dropTable)),e.set(K.OPERATIONS_ENUM.DROP_ATTRIBUTE,new te($o.dropAttribute)),e.set(K.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new te(uT.describeSchema)),e.set(K.OPERATIONS_ENUM.DESCRIBE_DATABASE,new te(uT.describeSchema)),e.set(K.OPERATIONS_ENUM.DESCRIBE_TABLE,new te(uT.describeTable)),e.set(K.OPERATIONS_ENUM.DESCRIBE_ALL,new te(uT.describeAll)),e.set(K.OPERATIONS_ENUM.DELETE,new te(ah.deleteRecord)),e.set(K.OPERATIONS_ENUM.ADD_USER,new te(oh.addUser)),e.set(K.OPERATIONS_ENUM.ALTER_USER,new te(oh.alterUser)),e.set(K.OPERATIONS_ENUM.DROP_USER,new te(oh.dropUser)),e.set(K.OPERATIONS_ENUM.LIST_USERS,new te(oh.listUsersExternal)),e.set(K.OPERATIONS_ENUM.LIST_ROLES,new te(dT.listRoles)),e.set(K.OPERATIONS_ENUM.ADD_ROLE,new te(dT.addRole)),e.set(K.OPERATIONS_ENUM.ALTER_ROLE,new te(dT.alterRole)),e.set(K.OPERATIONS_ENUM.DROP_ROLE,new te(dT.dropRole)),e.set(K.OPERATIONS_ENUM.USER_INFO,new te(oh.userInfo)),e.set(K.OPERATIONS_ENUM.READ_LOG,new te(The)),e.set(K.OPERATIONS_ENUM.ADD_NODE,new te(Ahe)),e.set(K.OPERATIONS_ENUM.UPDATE_NODE,new te(bK)),e.set(K.OPERATIONS_ENUM.SET_NODE_REPLICATION,new te(bK)),e.set(K.OPERATIONS_ENUM.REMOVE_NODE,new te(Rhe)),e.set(K.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new te(yhe)),e.set(K.OPERATIONS_ENUM.PURGE_STREAM,new te(bhe)),e.set(K.OPERATIONS_ENUM.SET_CONFIGURATION,new te(DK.setConfiguration)),e.set(K.OPERATIONS_ENUM.CLUSTER_STATUS,new te(Ohe.clusterStatus)),e.set(K.OPERATIONS_ENUM.CLUSTER_NETWORK,new te(Nhe)),e.set(K.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new te(BI.setRoutes)),e.set(K.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new te(BI.getRoutes)),e.set(K.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new te(BI.deleteRoutes)),e.set(K.OPERATIONS_ENUM.EXPORT_TO_S3,new te(vs,OK.export_to_s3)),e.set(K.OPERATIONS_ENUM.CREATE_CSR,new te($d.createCsr)),e.set(K.OPERATIONS_ENUM.SIGN_CERTIFICATE,new te($d.signCertificate)),e.set(K.OPERATIONS_ENUM.LIST_CERTIFICATES,new te($d.listCertificates)),e.set(K.OPERATIONS_ENUM.ADD_CERTIFICATES,new te($d.addCertificate)),e.set(K.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new te($d.removeCertificate)),e.set(K.OPERATIONS_ENUM.GET_KEY,new te($d.getKey)),e.set(K.OPERATIONS_ENUM.ADD_NODE_BACK,new te(vK.addNodeBack)),e.set(K.OPERATIONS_ENUM.REMOVE_NODE_BACK,new te(vK.removeNodeBack)),e.set(K.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new te(vs,ah.deleteFilesBefore)),e.set(K.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new te(vs,ah.deleteFilesBefore)),e.set(K.OPERATIONS_ENUM.EXPORT_LOCAL,new te(vs,OK.export_local)),e.set(K.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new te(FI.handleGetJobsByStartDate)),e.set(K.OPERATIONS_ENUM.GET_JOB,new te(FI.handleGetJob)),e.set(K.OPERATIONS_ENUM.GET_FINGERPRINT,new te(HI.getFingerprint)),e.set(K.OPERATIONS_ENUM.SET_LICENSE,new te(HI.setLicense)),e.set(K.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new te(HI.getRegistrationInfo)),e.set(K.OPERATIONS_ENUM.RESTART,new te(wK.restart)),e.set(K.OPERATIONS_ENUM.RESTART_SERVICE,new te(vs,wK.restartService)),e.set(K.OPERATIONS_ENUM.CATCHUP,new te(khe)),e.set(K.OPERATIONS_ENUM.SYSTEM_INFORMATION,new te(Che.systemInformation)),e.set(K.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new te(vs,ah.deleteAuditLogsBefore)),e.set(K.OPERATIONS_ENUM.READ_AUDIT_LOG,new te(She)),e.set(K.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new te(CK.createTokens)),e.set(K.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new te(CK.refreshOperationToken)),e.set(K.OPERATIONS_ENUM.LOGIN,new te(PK.login)),e.set(K.OPERATIONS_ENUM.LOGOUT,new te(PK.logout)),e.set(K.OPERATIONS_ENUM.GET_CONFIGURATION,new te(DK.getConfiguration)),e.set(K.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new te(Ct.customFunctionsStatus)),e.set(K.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new te(Ct.getCustomFunctions)),e.set(K.OPERATIONS_ENUM.GET_COMPONENT_FILE,new te(Ct.getComponentFile)),e.set(K.OPERATIONS_ENUM.GET_COMPONENTS,new te(Ct.getComponents)),e.set(K.OPERATIONS_ENUM.SET_COMPONENT_FILE,new te(Ct.setComponentFile)),e.set(K.OPERATIONS_ENUM.DROP_COMPONENT,new te(Ct.dropComponent)),e.set(K.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new te(Ct.getCustomFunction)),e.set(K.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new te(Ct.setCustomFunction)),e.set(K.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new te(Ct.dropCustomFunction)),e.set(K.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new te(Ct.addComponent)),e.set(K.OPERATIONS_ENUM.ADD_COMPONENT,new te(Ct.addComponent)),e.set(K.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new te(Ct.dropCustomFunctionProject)),e.set(K.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new te(Ct.packageComponent)),e.set(K.OPERATIONS_ENUM.PACKAGE_COMPONENT,new te(Ct.packageComponent)),e.set(K.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new te(Ct.deployComponent)),e.set(K.OPERATIONS_ENUM.DEPLOY_COMPONENT,new te(Ct.deployComponent)),e.set(K.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new te(LK.readTransactionLog)),e.set(K.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new te(vs,LK.deleteTransactionLogsBefore)),e.set(K.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new te(MK.installModules)),e.set(K.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new te(MK.auditModules)),e.set(K.OPERATIONS_ENUM.GET_BACKUP,new te($o.getBackup)),e.set(K.OPERATIONS_ENUM.ADD_SSH_KEY,new te(Ct.addSSHKey)),e.set(K.OPERATIONS_ENUM.UPDATE_SSH_KEY,new te(Ct.updateSSHKey)),e.set(K.OPERATIONS_ENUM.DELETE_SSH_KEY,new te(Ct.deleteSSHKey)),e.set(K.OPERATIONS_ENUM.LIST_SSH_KEYS,new te(Ct.listSSHKeys)),e.set(K.OPERATIONS_ENUM.SET_SSH_KNOWN_HOSTS,new te(Ct.setSSHKnownHosts)),e.set(K.OPERATIONS_ENUM.GET_SSH_KNOWN_HOSTS,new te(Ct.getSSHKnownHosts)),e}a(Fhe,"initializeOperationFunctionMap")});var mT=I((Pve,$K)=>{"use strict";var pT=(H(),P(G)),Ghe=ae(),uh=W(),{handleHDBError:$I,hdb_errors:hT}=pe(),{isMainThread:qhe}=require("worker_threads"),{Readable:$he}=require("stream"),GK=require("os"),Vhe=require("util"),Khe=IO(),Yhe=Vhe.promisify(Khe.authorize),qK=jw(),{createGzip:Whe,constants:zhe}=require("zlib"),jhe=[pT.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,pT.OPERATIONS_ENUM.LOGIN,pT.OPERATIONS_ENUM.LOGOUT];function Jhe(e){let t=`Found an uncaught exception with message: ${e.message}. ${GK.EOL}Stack: ${e.stack} ${GK.EOL}Terminating ${qhe?"HDB":"thread"}.`;console.error(t),uh.fatal(t),process.exit(1)}a(Jhe,"handleServerUncaughtException");function Qhe(e,t,r){if(uh[e.logLevel||"error"](e),e.statusCode)return typeof e.http_resp_msg!="object"?r.code(e.statusCode).send({error:e.http_resp_msg||e.message}):r.code(e.statusCode).send(e.http_resp_msg);let n=e.statusCode?e.statusCode:hT.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR;return typeof e=="string"?r.code(n).send({error:e}):r.code(n).send(e.message?{error:e.message}:e)}a(Qhe,"serverErrorHandler");function Xhe(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=$I(new Error,"Invalid JSON.",hT.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(Ghe.isEmpty(e.body.operation)){let n=$I(new Error,"Request body must include an 'operation' property.",hT.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(Xhe,"reqBodyValidationHandler");function Zhe(e,t,r){let n;!jhe.includes(e.body.operation)||e.body.operation===pT.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&!e.body.username&&!e.body.password?Yhe(e,t).then(i=>{n=i,e.body.hdb_user=n,r()}).catch(i=>{uh.warn(i),uh.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${i.stack}"`);let o=typeof i=="string"?{error:i}:{error:i.message};r($I(i,o,hT.HTTP_STATUS_CODES.UNAUTHORIZED),null)}):(e.body.hdb_user=null,e.body.baseRequest=e.raw?.baseRequest,e.body.baseResponse=t.raw?.baseResponse,e.body.fastifyResponse=t,r())}a(Zhe,"authHandler");async function eme(e,t,r=!1){let n;try{e.body.bypass_auth&&delete e.body.bypass_auth,n=qK.chooseOperation(e.body);let s=await qK.processLocalTransaction(e,n);if(s instanceof $he&&s.headers){for(let[i,o]of s.headers)t.header(i,o);e.headers["accept-encoding"]?.includes("gzip")&&(t.header("content-encoding","gzip"),s=s.pipe(Whe({level:zhe.Z_BEST_SPEED})))}return s}catch(s){throw uh.error(s),s}}a(eme,"handlePostRequest");$K.exports={authHandler:Zhe,handlePostRequest:eme,handleServerUncaughtException:Jhe,serverErrorHandler:Qhe,reqBodyValidationHandler:Xhe}});var WK=I((Lve,YK)=>{"use strict";var tme=require("fastify-plugin"),{handlePostRequest:VK,authHandler:rme,reqBodyValidationHandler:nme}=mT();async function sme(e){e.decorate("hdbCore",{preValidation:[nme,rme],request:a(t=>KK(VK(t,response)),"request"),requestWithoutAuthentication:a((t,r)=>KK(VK(t,r,!0)),"requestWithoutAuthentication")})}a(sme,"hdbCore");async function KK(e){if(e=await e,e?.[Symbol.asyncIterator]&&!e[Symbol.iterator]){let t=[];for await(let r of e)t.push(r);return t}return e}a(KK,"convertAsyncIterators");YK.exports=tme(sme)});var jK=I((Uve,zK)=>{"use strict";var vve=require("fs"),ET=ce();ET.initSync();var{CONFIG_PARAMS:VI}=(H(),P(G)),ime=1024*1024*1024;function ome(e){let t=ET.get(VI.HTTP_TIMEOUT),r=ET.get(VI.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:ime,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,maxParamLength:ET.get(VI.HTTP_MAXPARAMLENGTH)??1e3,https:e}}a(ome,"getServerOptions");zK.exports=ome});var XK=I((Bve,QK)=>{"use strict";var KI=ce();KI.initSync();var{CONFIG_PARAMS:JK}=(H(),P(G));function ame(){let e=KI.get(JK.HTTP_CORSACCESSLIST),t=KI.get(JK.HTTP_CORS),r;return t&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},e&&e.length>0&&e[0]!==null&&e[0]!=="*"&&(r.origin=(n,s)=>s(null,e.indexOf(n)!==-1))),r}a(ame,"getCORSOptions");QK.exports=ame});var tY=I((kve,eY)=>{"use strict";var ZK=ce();ZK.initSync();var cme=(H(),P(G));function lme(){return ZK.get(cme.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(lme,"getHeaderTimeoutConfig");eY.exports=lme});var WI={};Ue(WI,{customFunctionsServer:()=>fme,ready:()=>hY,start:()=>dme});function dme(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){Vo||(Vo=pY(t),We.http((await Vo).server));let o=await Vo,c=(0,YI.dirname)(s),l=(0,YI.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!rY.has(c)){rY.add(c);try{o.register(pme(c,l))}catch(u){if(u.message==="Root plugin has already booted")pt.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw u}}},ready:hY}}async function fme(){try{pt.info("In Custom Functions Fastify server"+process.cwd()),pt.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),pt.debug(`Custom Functions server process ${process.pid} starting up.`),await _me();let e=cY.get(x.HTTP_SECUREPORT)>0,t;try{t=Vo=await pY(e)}catch(r){throw pt.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw pt.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){pt.error(`Custom Functions ${process.pid} Error: ${e}`),pt.error(e),process.exit(1)}}async function _me(){try{pt.info("Custom Functions starting configuration."),await lY.setUsersWithRolesCache(),pt.info("Custom Functions completed configuration.")}catch(e){pt.error(e)}}function pme(e,t){return async function(r){try{pt.info("Custom Functions starting buildRoutes"),pt.trace("Loading fastify routes folder "+e),(0,nY.existsSync)(e)&&r.register(aY.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:pt.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?pt.error(s.message):s&&pt.error(s),o()})}catch(n){pt.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function pY(e){pt.info("Custom Functions starting buildServer.");let t=(0,uY.default)(e),r=(0,sY.default)(t);r.server.headersTimeout=(0,fY.default)(),r.setErrorHandler(_Y.serverErrorHandler);let n=(0,dY.default)();return n&&r.register(iY.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,l){r.server.emit("unhandled",c.raw,l.raw)}),o()}),r.register(oY.default),await r.register(ume),await r.after(),Jf(r),pt.info("Custom Functions completed buildServer."),r}function hY(){if(Vo)return Vo.then?Vo.then(e=>e.ready()):Vo.ready()}var YI,nY,sY,iY,oY,aY,cY,pt,ume,lY,uY,dY,fY,_Y,Vo,rY,mY=be(()=>{YI=require("path"),nY=require("fs"),sY=M(require("fastify")),iY=M(require("@fastify/cors")),oY=M(yO()),aY=M(require("@fastify/autoload")),cY=M(ce());H();pt=M(W()),ume=M(WK()),lY=M(yn()),uY=M(jK()),dY=M(XK()),fY=M(tY()),_Y=M(mT());co();Kr();rY=new Set;a(dme,"start");a(fme,"customFunctionsServer");a(_me,"setUp");a(pme,"buildRouteFolder");a(pY,"buildServer");a(hY,"ready")});var zI={};Ue(zI,{start:()=>hme});function hme(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,AY.default)(r,e);return e.server.http(async(s,i)=>{if(!s.isWebSocket)return new Promise(o=>n(s._nodeRequest,s._nodeResponse,()=>{o(i(s))}))}),!0}},handleFile(t,r,n){gY||(gY=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=EY.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,SY.default)(s,(0,TY.realpathSync)(o))}}return i(s)},{runFirst:!0})),EY.set(r,n)}}}var SY,TY,AY,EY,gY,RY=be(()=>{SY=M(require("send")),TY=require("fs"),AY=M(require("serve-static")),EY=new Map;a(hme,"start")});var jI={};Ue(jI,{start:()=>mme});function mme({override:e}){return{handleFile:a((t,r,n)=>{gT.default.debug(`Loading env file: ${n}`);for(let[s,i]of Object.entries((0,yY.parse)(t))){if(process.env[s]!==void 0)if(gT.default.warn(`Environment variable conflict: ${s} from ${n} is already set on process.env`),e)gT.default.debug(`override option enabled. overriding environment variable: ${s}`);else continue;process.env[s]=i}},"handleFile")}}var yY,gT,bY=be(()=>{yY=require("dotenv"),gT=M(W());a(mme,"start")});var NY={};Ue(NY,{Request:()=>JI,createReuseportFd:()=>ST});var OY,JI,QI,XI,ST,ZI=be(()=>{OY=require("os"),JI=class{static{a(this,"Request")}#e;constructor(t,r){this.method=t.method;let n=t.url;this._nodeRequest=t,this._nodeResponse=r,this.url=n,this.headers=new XI(t.headers)}get absoluteURL(){return this.protocol+"://"+this.host+this.url}get pathname(){let t=this.url.indexOf("?");return t>-1?this.url.slice(0,t):this.url}set pathname(t){let r=this.url.indexOf("?");r>-1?this.url=t+this.url.slice(r):this.url=t}get protocol(){return this._nodeRequest.socket.encrypted?"https":"http"}get ip(){return this._nodeRequest.socket.remoteAddress}get authorized(){return this._nodeRequest.socket.authorized}get peerCertificate(){return this._nodeRequest.socket.getPeerCertificate()}get mtlsConfig(){return this._nodeRequest.socket.server.mtlsConfig}get body(){return this.#e||(this.#e=new QI(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}sendEarlyHints(t,r={}){r.link=t,this._nodeResponse.writeEarlyHints(r)}},QI=class{static{a(this,"RequestBody")}#e;constructor(t){this.#e=t}on(t,r){return this.#e.on(t,r),this}pipe(t,r){return this.#e.pipe(t,r)}},XI=class{constructor(t){this.asObject=t}static{a(this,"Headers")}set(t,r){this.asObject[t.toLowerCase()]=r}get(t){return this.asObject[t.toLowerCase()]}has(t){return this.asObject.hasOwnProperty(t.toLowerCase())}[Symbol.iterator](){return Object.entries(this.asObject)[Symbol.iterator]()}keys(){return Object.keys(this.asObject)}values(){return Object.values(this.asObject)}delete(t){delete this.asObject[t.toLowerCase()]}forEach(t){for(let[r,n]of this)t(n,r,this)}};(0,OY.platform)()!="win32"&&(ST=require("node-unix-socket").createReuseportFd)});var tC=I((zve,wY)=>{"use strict";var dh=ce();dh.initSync();var Kd=require("fs-extra"),eC=require("path"),Yd=(H(),P(G)),Eme=require("crypto"),gme=require("uuid").v4;wY.exports=Sme;function Sme(){if(dh.getHdbBasePath()!==void 0){let e=eC.join(dh.getHdbBasePath(),Yd.LICENSE_KEY_DIR_NAME,Yd.JWT_ENUM.JWT_PRIVATE_KEY_NAME),t=eC.join(dh.getHdbBasePath(),Yd.LICENSE_KEY_DIR_NAME,Yd.JWT_ENUM.JWT_PUBLIC_KEY_NAME),r=eC.join(dh.getHdbBasePath(),Yd.LICENSE_KEY_DIR_NAME,Yd.JWT_ENUM.JWT_PASSPHRASE_NAME);try{Kd.accessSync(r),Kd.accessSync(e),Kd.accessSync(t)}catch(n){if(n.code==="ENOENT"){let s=gme(),i=Eme.generateKeyPairSync("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem",cipher:"aes-256-cbc",passphrase:s}});Kd.writeFileSync(r,s),Kd.writeFileSync(e,i.privateKey),Kd.writeFileSync(t,i.publicKey)}else throw n}}}a(Sme,"checkJWTTokenExist")});var CY=I((Jve,IY)=>{"use strict";var rC=class{static{a(this,"HdbInfoInsertObject")}constructor(t,r,n){this.info_id=t,this.data_version_num=r,this.hdb_version_num=n}};IY.exports={HdbInfoInsertObject:rC}});var LY=I((Xve,DY)=>{"use strict";var PY=(H(),P(G)),nC=class{static{a(this,"UpgradeObject")}constructor(t,r){this[PY.UPGRADE_JSON_FIELD_NAMES_ENUM.DATA_VERSION]=t,this[PY.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION]=r}};DY.exports={UpgradeObject:nC}});var TT=I((eUe,vY)=>{"use strict";var Us=require("prompt"),Wd=require("chalk"),MY=W(),Ei=require("os"),sC=da(),iC=["yes","y"];async function Tme(e){let t=`${Ei.EOL}`+Wd.bold.green("Your current HarperDB version requires that we complete an update process.")+`${Ei.EOL}If a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${Ei.EOL}${Ei.EOL}You can read more about the changes in this upgrade at https://harperdb.io/developers/release-notes/${Ei.EOL}`;Us.override=sC(["CONFIRM_UPGRADE"]),Us.start(),Us.message=t;let r={properties:{CONFIRM_UPGRADE:{description:Wd.magenta(`${Ei.EOL}[CONFIRM_UPGRADE] Do you want to upgrade your HDB instance now? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"no",required:!0}}},n;try{n=await Us.get([r])}catch(s){return MY.error("There was an error when prompting user about an upgrade."),MY.error(s),!1}return iC.includes(n.CONFIRM_UPGRADE)}a(Tme,"forceUpdatePrompt");async function Ame(e){let t=`${Ei.EOL}`+Wd.bold.green(`Your installed HarperDB version is older than the version used to create your data. Downgrading is not recommended as it is not tested and guaranteed to work. However, if you need to downgrade, and a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${Ei.EOL}`);Us.override=sC(["CONFIRM_DOWNGRADE"]),Us.start(),Us.message=t;let r={properties:{CONFIRM_DOWNGRADE:{description:Wd.magenta(`${Ei.EOL}[CONFIRM_DOWNGRADE] Do you want to proceed with using your downgraded HDB instance now? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"no",required:!0}}},n=await Us.get([r]);return iC.includes(n.CONFIRM_DOWNGRADE)}a(Ame,"forceDowngradePrompt");async function Rme(){let e=`${Ei.EOL}`+Wd.bold.green("We now require a Certifacte Authority certificate. HarperDB can generate all new certificates for you (your existing certificates will be backed up) or you can keep any existing certificates and add your own CA certificate. To add your own CA certificate set the <certificateAuthority> parameter in harperdb-config.yaml");Us.override=sC(["GENERATE_CERTS"]),Us.start(),Us.message=e;let t={properties:{GENERATE_CERTS:{description:Wd.magenta(`${Ei.EOL}[GENERATE_CERTS] Do you want HarperDB to generate all new certificates? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"yes",required:!0}}},r=await Us.get([t]);return iC.includes(r.GENERATE_CERTS)}a(Rme,"upgradeCertsPrompt");vY.exports={forceUpdatePrompt:Tme,forceDowngradePrompt:Ame,upgradeCertsPrompt:Rme}});var aC=I((rUe,UY)=>{"use strict";var oC=class{static{a(this,"UpgradeDirective")}constructor(t){this.version=t,this.sync_functions=[],this.async_functions=[]}};UY.exports=oC});var BY=I((cUe,xY)=>{"use strict";var yme=ae(),bme=Rt(),sUe=W(),iUe=require("path"),oUe=require("fs"),aUe=(H(),P(G));xY.exports={getOldPropsValue:Ome};function Ome(e,t,r=!1){let n=t.getRaw(e);return yme.isNotEmptyAndHasValue(n)?n:r?bme.getDefaultConfig(e):""}a(Ome,"getOldPropsValue")});var GY=I((uUe,FY)=>{"use strict";var tc=require("path"),rc=require("fs-extra"),Nme=require("properties-reader"),wme=aC(),_r=W(),{getOldPropsValue:ht}=BY(),{HDB_SETTINGS_NAMES:Ee,CONFIG_PARAMS:ql}=(H(),P(G)),$l=Rt(),AT=ce(),HY=ae(),Wi=(H(),P(G)),cC=new wme("3.1.0"),kY=[];function Ime(){let e=Nme(AT.get(Ee.SETTINGS_PATH_KEY)),t="Updating settings file for version 3.1.0";console.log(t),_r.info(t);let r=` ;Settings for the HarperDB process.
40
40
 
41
41
  ;The directory selected during install where the database files reside.
42
- ${Te.HDB_ROOT_KEY} = ${mt(Te.HDB_ROOT_KEY,e)}
42
+ ${Ee.HDB_ROOT_KEY} = ${ht(Ee.HDB_ROOT_KEY,e)}
43
43
  ;The port the HarperDB REST interface will listen on.
44
- ${Te.SERVER_PORT_KEY} = ${mt(Te.SERVER_PORT_KEY,e)}
44
+ ${Ee.SERVER_PORT_KEY} = ${ht(Ee.SERVER_PORT_KEY,e)}
45
45
  ;Set to true to enable HTTPS on the HarperDB REST endpoint. Requires a valid certificate and key.
46
- ${Te.HTTP_SECURE_ENABLED_KEY} = ${mt(Te.HTTP_SECURE_ENABLED_KEY,e)}
46
+ ${Ee.HTTP_SECURE_ENABLED_KEY} = ${ht(Ee.HTTP_SECURE_ENABLED_KEY,e)}
47
47
  ;The path to the SSL certificate used when running with HTTPS enabled.
48
- ${Te.CERT_KEY} = ${mt(Te.CERT_KEY,e)}
48
+ ${Ee.CERT_KEY} = ${ht(Ee.CERT_KEY,e)}
49
49
  ;The path to the SSL private key used when running with HTTPS enabled.
50
- ${Te.PRIVATE_KEY_KEY} = ${mt(Te.PRIVATE_KEY_KEY,e)}
50
+ ${Ee.PRIVATE_KEY_KEY} = ${ht(Ee.PRIVATE_KEY_KEY,e)}
51
51
  ;Set to true to enable Cross Origin Resource Sharing, which allows requests across a domain.
52
- ${Te.CORS_ENABLED_KEY} = ${mt(Te.CORS_ENABLED_KEY,e)}
52
+ ${Ee.CORS_ENABLED_KEY} = ${ht(Ee.CORS_ENABLED_KEY,e)}
53
53
  ;Allows for setting allowable domains with CORS. Comma separated list.
54
- ${Te.CORS_WHITELIST_KEY} = ${mt(Te.CORS_WHITELIST_KEY,e)}
54
+ ${Ee.CORS_WHITELIST_KEY} = ${ht(Ee.CORS_WHITELIST_KEY,e)}
55
55
  ;Length of time in milliseconds after which a request will timeout. Defaults to 120,000 ms (2 minutes).
56
- ${Te.SERVER_TIMEOUT_KEY} = ${mt(Te.SERVER_TIMEOUT_KEY,e,!0)}
56
+ ${Ee.SERVER_TIMEOUT_KEY} = ${ht(Ee.SERVER_TIMEOUT_KEY,e,!0)}
57
57
  ;The number of milliseconds of inactivity a server needs to wait for additional incoming data, after it has finished writing the last response. Defaults to 5,000 ms (5 seconds).
58
- ${Te.SERVER_KEEP_ALIVE_TIMEOUT_KEY} = ${mt(Te.SERVER_KEEP_ALIVE_TIMEOUT_KEY,e,!0)}
58
+ ${Ee.SERVER_KEEP_ALIVE_TIMEOUT_KEY} = ${ht(Ee.SERVER_KEEP_ALIVE_TIMEOUT_KEY,e,!0)}
59
59
  ;Limit the amount of time the parser will wait to receive the complete HTTP headers.. Defaults to 60,000 ms (1 minute).
60
- ${Te.SERVER_HEADERS_TIMEOUT_KEY} = ${mt(Te.SERVER_HEADERS_TIMEOUT_KEY,e,!0)}
60
+ ${Ee.SERVER_HEADERS_TIMEOUT_KEY} = ${ht(Ee.SERVER_HEADERS_TIMEOUT_KEY,e,!0)}
61
61
  ;Define whether to log to file or not.
62
- ${Te.LOG_TO_FILE} = ${ql.getDefaultConfig(Gl.LOGGING_FILE)}
62
+ ${Ee.LOG_TO_FILE} = ${$l.getDefaultConfig(ql.LOGGING_FILE)}
63
63
  ;Define whether to log to stdout/stderr or not. NOTE HarperDB must run in foreground in order to receive the std stream from HarperDB.
64
- ${Te.LOG_TO_STDSTREAMS} = ${ql.getDefaultConfig(Gl.LOGGING_STDSTREAMS)}
64
+ ${Ee.LOG_TO_STDSTREAMS} = ${$l.getDefaultConfig(ql.LOGGING_STDSTREAMS)}
65
65
  ;Set to control amount of logging generated. Accepted levels are trace, debug, warn, error, fatal.
66
- ${Te.LOG_LEVEL_KEY} = ${mt(Te.LOG_LEVEL_KEY,e)}
66
+ ${Ee.LOG_LEVEL_KEY} = ${ht(Ee.LOG_LEVEL_KEY,e)}
67
67
  ;The path where log files will be written. If there is no file name included in the path, the log file will be created by default as 'hdb_log.log'
68
- ${Te.LOG_PATH_KEY} = ${mt(Te.LOG_PATH_KEY,e)}
68
+ ${Ee.LOG_PATH_KEY} = ${ht(Ee.LOG_PATH_KEY,e)}
69
69
  ;Set to true to enable daily log file rotations - each log file name will be prepended with YYYY-MM-DD.
70
- ${Te.LOG_DAILY_ROTATE_KEY} = ${mt(Te.LOG_DAILY_ROTATE_KEY,e)}
70
+ ${Ee.LOG_DAILY_ROTATE_KEY} = ${ht(Ee.LOG_DAILY_ROTATE_KEY,e)}
71
71
  ;Set the number of daily log files to maintain when LOG_DAILY_ROTATE is enabled. If no integer value is set, no limit will be set for
72
72
  ;daily log files which may consume a large amount of storage depending on your log settings.
73
- ${Te.LOG_MAX_DAILY_FILES_KEY} = ${mt(Te.LOG_MAX_DAILY_FILES_KEY,e)}
73
+ ${Ee.LOG_MAX_DAILY_FILES_KEY} = ${ht(Ee.LOG_MAX_DAILY_FILES_KEY,e)}
74
74
  ;The environment used by NodeJS. Setting to production will be the most performant, settings to development will generate more logging.
75
- ${Te.PROPS_ENV_KEY} = ${mt(Te.PROPS_ENV_KEY,e)}
75
+ ${Ee.PROPS_ENV_KEY} = ${ht(Ee.PROPS_ENV_KEY,e)}
76
76
  ;This allows self signed certificates to be used in clustering. This is a security risk
77
77
  ;as clustering will not validate the cert, so should only be used internally.
78
78
  ;The HDB install creates a self signed certificate, if you use that cert this must be set to true.
79
- ${Te.ALLOW_SELF_SIGNED_SSL_CERTS} = ${mt(Te.ALLOW_SELF_SIGNED_SSL_CERTS,e,!0)}
79
+ ${Ee.ALLOW_SELF_SIGNED_SSL_CERTS} = ${ht(Ee.ALLOW_SELF_SIGNED_SSL_CERTS,e,!0)}
80
80
  ;Set the max number of processes HarperDB will start. This can also be limited by number of cores and licenses.
81
- ${Te.MAX_HDB_PROCESSES} = ${mt(Te.MAX_HDB_PROCESSES,e)}
81
+ ${Ee.MAX_HDB_PROCESSES} = ${ht(Ee.MAX_HDB_PROCESSES,e)}
82
82
  ;Set to true to enable clustering. Requires a valid enterprise license.
83
- ${Te.CLUSTERING_ENABLED_KEY} = ${mt(Te.CLUSTERING_ENABLED_KEY,e,!0)}
83
+ ${Ee.CLUSTERING_ENABLED_KEY} = ${ht(Ee.CLUSTERING_ENABLED_KEY,e,!0)}
84
84
  ;The port that will be used for HarperDB clustering.
85
- ${Te.CLUSTERING_PORT_KEY} = ${mt(Te.CLUSTERING_PORT_KEY,e)}
85
+ ${Ee.CLUSTERING_PORT_KEY} = ${ht(Ee.CLUSTERING_PORT_KEY,e)}
86
86
  ;The name of this node in your HarperDB cluster topology. This must be a value unique from the rest of your cluster node names.
87
- ${Te.CLUSTERING_NODE_NAME_KEY} = ${mt(Te.CLUSTERING_NODE_NAME_KEY,e)}
87
+ ${Ee.CLUSTERING_NODE_NAME_KEY} = ${ht(Ee.CLUSTERING_NODE_NAME_KEY,e)}
88
88
  ;The user used to connect to other instances of HarperDB, this user must have a role of cluster_user.
89
- ${Te.CLUSTERING_USER_KEY} = ${mt(Te.CLUSTERING_USER_KEY,e)}
89
+ ${Ee.CLUSTERING_USER_KEY} = ${ht(Ee.CLUSTERING_USER_KEY,e)}
90
90
  ;Defines if this instance does not record transactions. Note, if Clustering is enabled and Transaction Log is disabled your nodes will not catch up.
91
- ${Te.DISABLE_TRANSACTION_LOG_KEY} = ${mt(Te.DISABLE_TRANSACTION_LOG_KEY,e,!0)}
91
+ ${Ee.DISABLE_TRANSACTION_LOG_KEY} = ${ht(Ee.DISABLE_TRANSACTION_LOG_KEY,e,!0)}
92
92
  ;Defines the length of time an operation token will be valid until it expires. Example values: https://github.com/vercel/ms
93
- ${Te.OPERATION_TOKEN_TIMEOUT_KEY} = ${mt(Te.OPERATION_TOKEN_TIMEOUT_KEY,e,!0)}
93
+ ${Ee.OPERATION_TOKEN_TIMEOUT_KEY} = ${ht(Ee.OPERATION_TOKEN_TIMEOUT_KEY,e,!0)}
94
94
  ;Defines the length of time a refresh token will be valid until it expires. Example values: https://github.com/vercel/ms
95
- ${Te.REFRESH_TOKEN_TIMEOUT_KEY} = ${mt(Te.REFRESH_TOKEN_TIMEOUT_KEY,e,!0)}
95
+ ${Ee.REFRESH_TOKEN_TIMEOUT_KEY} = ${ht(Ee.REFRESH_TOKEN_TIMEOUT_KEY,e,!0)}
96
96
  ;The port the IPC server will run on.
97
- ${Te.IPC_SERVER_PORT} = ${ql.getDefaultConfig(Gl.IPC_NETWORK_PORT)}
97
+ ${Ee.IPC_SERVER_PORT} = ${$l.getDefaultConfig(ql.IPC_NETWORK_PORT)}
98
98
  ;Run HDB in the foreground.
99
- ${Te.RUN_IN_FOREGROUND} = ${ql.getDefaultConfig(Gl.OPERATIONSAPI_FOREGROUND)}
99
+ ${Ee.RUN_IN_FOREGROUND} = ${$l.getDefaultConfig(ql.OPERATIONSAPI_FOREGROUND)}
100
100
  ;Set to true to enable custom API endpoints. Requires a valid enterprise license.
101
- ${Te.CUSTOM_FUNCTIONS_ENABLED_KEY} = ${ql.getDefaultConfig(Gl.CUSTOMFUNCTIONS_ENABLED)}
101
+ ${Ee.CUSTOM_FUNCTIONS_ENABLED_KEY} = ${$l.getDefaultConfig(ql.CUSTOMFUNCTIONS_ENABLED)}
102
102
  ;The port used to access the custom functions server.
103
- ${Te.CUSTOM_FUNCTIONS_PORT_KEY} = ${ql.getDefaultConfig(Gl.HTTP_PORT)}
103
+ ${Ee.CUSTOM_FUNCTIONS_PORT_KEY} = ${$l.getDefaultConfig(ql.HTTP_PORT)}
104
104
  ;The path to the folder containing HarperDB custom function files.
105
- ${Te.CUSTOM_FUNCTIONS_DIRECTORY_KEY} = ${ec.join(mt(Te.HDB_ROOT_KEY,e),"custom_functions")}
105
+ ${Ee.CUSTOM_FUNCTIONS_DIRECTORY_KEY} = ${tc.join(ht(Ee.HDB_ROOT_KEY,e),"custom_functions")}
106
106
  ;Set the max number of processes HarperDB will start for the Custom Functions server
107
- ${Te.MAX_CUSTOM_FUNCTION_PROCESSES} = ${ql.getDefaultConfig(Gl.HTTP_THREADS)}
108
- `,n=TT.get("settings_path"),s=ec.dirname(n),i=ec.join(s,"3_1_0_upgrade_settings.bak");try{_r.info(`Backing up old settings file to: ${i}`),tc.copySync(n,i)}catch(c){throw _r.error(c),console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),c}try{_r.info("New settings file values for 3.1.0 upgrade:",r),_r.info(`Creating new/upgraded settings file at '${n}'`),tc.writeFileSync(n,r),_r.info("Updating env variables with new settings values")}catch(c){throw console.error("There was a problem writing the new settings file. Please check the log for details."),_r.error("Attempting to reset the settings file to its original state. Use the '.bak' file if this fails."),_r.error(c),tc.copySync(i,n),c}TT.initSync();let o="New settings file for 3.1.0 upgrade successfully created.";return console.log(o),_r.info(o),o}a(Pme,"updateSettingsFile_3_1_0");function Dme(){let e=ec.join(HY.getHomeDir(),Yi.HDB_HOME_DIR_NAME,Yi.LICENSE_KEY_DIR_NAME,Yi.LICENSE_FILE_NAME),t=ec.join(HY.getHomeDir(),Yi.HDB_HOME_DIR_NAME,Yi.LICENSE_KEY_DIR_NAME,Yi.REG_KEY_FILE_NAME),r=ec.join(TT.getHdbBasePath(),Yi.LICENSE_KEY_DIR_NAME,Yi.LICENSE_FILE_NAME),n=ec.join(r,Yi.LICENSE_FILE_NAME),s=ec.join(r,Yi.REG_KEY_FILE_NAME),i="Move license files for version 3.1.0";console.log(i),_r.info(i);let o="Creating .license directory";console.log(o),_r.info(o),tc.mkdirpSync(r);try{tc.accessSync(e);try{let c="Moving licence file";console.log(c),_r.info(c),tc.moveSync(e,n);let l="License file successfully moved.";console.log(l),_r.info(l)}catch{let l="moving license file failed";console.error(l),_r.error(l)}}catch{let l=`license file '${e}' does not exist.`;console.warn(l),_r.warn(l)}try{tc.accessSync(t);try{let c="Moving registration file";console.log(c),_r.info(c),tc.moveSync(t,s);let l="Registration file successfully moved.";console.log(l),_r.info(l)}catch{let l="moving registration file failed";console.error(l),_r.error(l)}}catch{let l=`registration file '${t}' does not exist.`;console.warn(l),_r.warn(l)}}a(Dme,"moveLicenseFiles");cC.sync_functions.push(Pme);cC.sync_functions.push(Dme);kY.push(cC);FY.exports=kY});var YY=w((_Ue,KY)=>{"use strict";var os=_t(),{insertRecords:Lme}=qc(),Mme=_n(),rc=xt(),vme=ie(),Vo=z(),Ume=ie(),Wi=require("fs-extra"),Ko=require("path"),xme=require("cli-progress"),dh=require("assert"),Bme=require("pino"),Hme=ae();KY.exports=kme;var AT,qY,RT,lC,sn,fh=!1;async function kme(e=!0){return AT=Hme.getHdbBasePath(),qY=Ko.join(AT,"schema"),RT=Ko.join(AT,"4_0_0_upgrade_tmp"),lC=Ko.join(AT,"transactions"),console.info("Reindexing upgrade started for schemas"),Vo.notify("Reindexing upgrade started for schemas"),await $Y(qY,!1,e),await Wi.pathExists(lC)&&(console.info(`
107
+ ${Ee.MAX_CUSTOM_FUNCTION_PROCESSES} = ${$l.getDefaultConfig(ql.HTTP_THREADS)}
108
+ `,n=AT.get("settings_path"),s=tc.dirname(n),i=tc.join(s,"3_1_0_upgrade_settings.bak");try{_r.info(`Backing up old settings file to: ${i}`),rc.copySync(n,i)}catch(c){throw _r.error(c),console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),c}try{_r.info("New settings file values for 3.1.0 upgrade:",r),_r.info(`Creating new/upgraded settings file at '${n}'`),rc.writeFileSync(n,r),_r.info("Updating env variables with new settings values")}catch(c){throw console.error("There was a problem writing the new settings file. Please check the log for details."),_r.error("Attempting to reset the settings file to its original state. Use the '.bak' file if this fails."),_r.error(c),rc.copySync(i,n),c}AT.initSync();let o="New settings file for 3.1.0 upgrade successfully created.";return console.log(o),_r.info(o),o}a(Ime,"updateSettingsFile_3_1_0");function Cme(){let e=tc.join(HY.getHomeDir(),Wi.HDB_HOME_DIR_NAME,Wi.LICENSE_KEY_DIR_NAME,Wi.LICENSE_FILE_NAME),t=tc.join(HY.getHomeDir(),Wi.HDB_HOME_DIR_NAME,Wi.LICENSE_KEY_DIR_NAME,Wi.REG_KEY_FILE_NAME),r=tc.join(AT.getHdbBasePath(),Wi.LICENSE_KEY_DIR_NAME,Wi.LICENSE_FILE_NAME),n=tc.join(r,Wi.LICENSE_FILE_NAME),s=tc.join(r,Wi.REG_KEY_FILE_NAME),i="Move license files for version 3.1.0";console.log(i),_r.info(i);let o="Creating .license directory";console.log(o),_r.info(o),rc.mkdirpSync(r);try{rc.accessSync(e);try{let c="Moving licence file";console.log(c),_r.info(c),rc.moveSync(e,n);let l="License file successfully moved.";console.log(l),_r.info(l)}catch{let l="moving license file failed";console.error(l),_r.error(l)}}catch{let l=`license file '${e}' does not exist.`;console.warn(l),_r.warn(l)}try{rc.accessSync(t);try{let c="Moving registration file";console.log(c),_r.info(c),rc.moveSync(t,s);let l="Registration file successfully moved.";console.log(l),_r.info(l)}catch{let l="moving registration file failed";console.error(l),_r.error(l)}}catch{let l=`registration file '${t}' does not exist.`;console.warn(l),_r.warn(l)}}a(Cme,"moveLicenseFiles");cC.sync_functions.push(Ime);cC.sync_functions.push(Cme);kY.push(cC);FY.exports=kY});var YY=I((fUe,KY)=>{"use strict";var as=ft(),{insertRecords:Pme}=$c(),Dme=pn(),nc=xt(),Lme=ae(),Ko=W(),Mme=ae(),zi=require("fs-extra"),Yo=require("path"),vme=require("cli-progress"),fh=require("assert"),Ume=require("pino"),xme=ce();KY.exports=Bme;var RT,qY,yT,lC,on,_h=!1;async function Bme(e=!0){return RT=xme.getHdbBasePath(),qY=Yo.join(RT,"schema"),yT=Yo.join(RT,"4_0_0_upgrade_tmp"),lC=Yo.join(RT,"transactions"),console.info("Reindexing upgrade started for schemas"),Ko.notify("Reindexing upgrade started for schemas"),await $Y(qY,!1,e),await zi.pathExists(lC)&&(console.info(`
109
109
 
110
- Reindexing upgrade started for transaction logs`),Vo.notify("Reindexing upgrade started for transaction logs"),await $Y(lC,!0,e)),Vo.notify("Reindexing upgrade complete"),"Reindexing for 4.0.0 upgrade complete"+(fh?", but errors occurred":"")}a(kme,"reindexUpgrade");async function $Y(e,t,r){let n=await Wi.readdir(e),s=n.length;for(let i=0;i<s;i++){let o=n[i],c=Ko.join(e,o.toString());if(o===".DS_Store")continue;let l=await Wi.readdir(c),u=l.length;for(let f=0;f<u;f++){let d=l[f];if(d!==".DS_Store"&&Wi.statSync(Ko.join(c,d)).isDirectory())try{await Fme(o,d,t),sn.info(`Reindexing started for ${o}.${d}`),Vo.notify(`${t?"Transaction":"Schema"} reindexing started for ${o}.${d}`),await qme(o,d,c,t,r),sn.info(`Reindexing completed for ${o}.${d}`),Vo.notify(`Reindexing completed for ${o}.${d}`)}catch(p){fh=!0,p.schema_path=c,p.table_name=d,Vo.error("There was an error with the reindex upgrade, check the logs in hdb/3_0_0_upgrade_tmp for more details"),Vo.error(p),sn.error(p),console.error(p)}}}if(!fh)try{await Wi.rm(RT,{recursive:!0})}catch{}}a($Y,"processTables");async function Fme(e,t,r){let s=`${e}_${t}_${r?"transaction_reindex":"schema_reindex"}.log`,i=Ko.join(RT,s);await Wi.ensureDir(RT),await Wi.writeFile(i,""),sn=Bme({level:"debug",formatters:{bindings(){}}},i)}a(Fme,"initPinoLogger");var Gme=20;async function qme(e,t,r,n,s){let i;try{i=await os.openEnvironment(r,t,n)}catch(E){if(E.message==="MDB_INVALID: File is not an LMDB file"){Vo.notify(`${e}.${t} file is not from the old environment and has been skipped`),console.info(`${e}.${t} file is not from the old environment and has been skipped`),sn.error(E);return}throw E}let o=Kme(i.dbis),c=os.openDBI(i,o),l=Object.keys(i.dbis),u=os.statDBI(i,o);sn.info(`Old environment stats: ${JSON.stringify(u)}`);let f=new xme.SingleBar({format:`${e}.${t} |{bar}| {percentage}% || {value}/{total} records`,barCompleteChar:"\u2588",barIncompleteChar:"\u2591",hideCursor:!0,clearOnComplete:!1});f.start(u.entryCount,0,{});let d=await os.createEnvironment(r,t,!1);os.createDBI(d,o,!1,!0);let p=[];try{for(let E of c.getRange({start:!1}))E.value={...E.value},p.push(E),n||e==="system"&&(t==="hdb_schema"&&(E.key=E.key.toString(),E.value.name=E.value.name.toString()),t==="hdb_table"&&(E.key=E.key.toString(),E.value.schema=E.value.schema.toString(),E.value.name=E.value.name.toString()),t==="hdb_attribute"&&(E.key=E.key.toString(),E.value.schema=E.value.schema.toString(),E.value.table=E.value.table.toString(),E.value.attribute=E.value.attribute.toString())),p.length>Gme&&await _();await _()}catch(E){throw fh=!0,sn.error(E),E}async function _(){let E,T=p.map(({value:v})=>v);n?E=await Promise.all(T.map(v=>$me(d,v))):E=await Lme(d,o,l.filter(v=>v!=="__blob__"),T,!1);for(let v=0,F=p.length;v<F;v++){let{key:q,value:Y}=p[v];sn.info(`Record hash value: ${q} hash: ${o}`);let Z;n?Z=E[v]:Z=E.written_hashes.indexOf(q)>-1,dh(Z,!0),Vme(d,o,Y[o],n),sn.info(`Insert success, written hashes: ${E.written_hashes}`),f.increment()}p=[],f.value/f.total*100%10===0&&Vo.notify(`${e}.${t} ${f.value}/${f.total} records inserted`),sn.info(`${f.value}/${f.total} records inserted`)}a(_,"finishOutstanding"),f.stop();let h=os.statDBI(i,o),S=os.statDBI(d,o);if(sn.info(`Old stats entry count: ${h.entryCount}. New stats entry count: ${S.entryCount}`),dh.deepStrictEqual(h.entryCount,S.entryCount),await os.closeEnvironment(i),await os.closeEnvironment(d),delete global.lmdb_map[`${e}.${t}`],s){let E=Ko.join(r,t),T=Ko.join(E,"data.mdb"),b=Ko.join(E,"lock.mdb");await Wi.unlink(T),await Wi.unlink(b),await Wi.rmdir(E),sn.info(`Deleted old environment files from schema folder: ${T}, ${b}`)}let g=await os.openEnvironment(r,t),R=os.statDBI(g,o);sn.info(`New stats: ${JSON.stringify(S)}. New stats after move: ${JSON.stringify(R)}`),dh.deepStrictEqual(R.entryCount,S.entryCount),await os.closeEnvironment(g),delete global.lmdb_map[`${e}.${t}`]}a(qme,"processTable");async function $me(e,t){os.initializeDBIs(e,rc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,rc.TRANSACTIONS_DBIS);let r=t.timestamp;return e.dbis[rc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(r,()=>{e.dbis[rc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(r,t),Ume.isEmpty(t.user_name)||e.dbis[rc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(t.user_name,r);for(let n of t.hash_values)e.dbis[rc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(n,r)})}a($me,"insertTransaction");function Vme(e,t,r,n){let i=e.dbis[t].get(r);dh.deepStrictEqual(typeof i,"object");let o;if(n){let c={[rc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME]:i.user_name,[rc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE]:i.hash_values};o=Object.entries(c)}else o=Object.entries(i);for(let[c,l]of o)if(c!==t&&e.dbis[c]!==void 0&&!vme.isEmptyOrZeroLength(l))if(n&&c==="hash_value")for(let u=0,f=l.length;u<f;u++){let d=l[u];VY(e,c,d,r)}else VY(e,c,l,r)}a(Vme,"validateIndices");function VY(e,t,r,n){try{let s=!1,i=Mme.getIndexedValues(r);if(!i)return;for(let o of i)s=e.dbis[t].doesExist(o,n),s||sn.info(`Validate indices did not find value in new DBI: ${o}. Hash: ${n}`),dh.deepStrictEqual(s,!0)}catch(s){fh=!0,sn.error(s),console.error(s)}}a(VY,"validateIndex");function Kme(e){let t;for(let[r,n]of Object.entries(e))if(n.__dbi_defintion__.is_hash_attribute===!0){t=r;break}return t}a(Kme,"getHashDBI")});var QY=w((mUe,JY)=>{"use strict";var yT=require("path"),nc=require("fs-extra"),Yme=aC(),$l=z(),WY=yt(),uC=ae(),Ei=(H(),C(G)),bT=ie(),Wme=require("properties-reader"),zme=ni(),jme=ng(),Jme=Yr(),hUe=require("util"),Qme=Jme.searchByValue,Xme=yn(),Zme=dS(),eEe=Tt(),tEe=YY(),zY=Zn(),rEe=ST(),hh=new Yme("4.0.0"),jY=[],_h,ph;async function nEe(){try{if(await rEe.upgradeCertsPrompt()){if(console.log("Generating new certificates."),_h){let t=bT.changeExtension(_h,".bak");await nc.move(_h,t)}if(ph){let t=bT.changeExtension(ph,".bak");await nc.move(ph,t)}await zY.generateKeys()}else console.log("Using existing certificates."),zY.updateConfigCert(_h,ph,void 0)}catch(e){throw console.error("There was a problem generating new keys. Please check the log for details."),e}}a(nEe,"generateNewKeys");async function sEe(){console.log("Updating HarperDB nodes."),$l.info("Updating HarperDB nodes.");let e=[];try{let t=new zme(Ei.SYSTEM_SCHEMA_NAME,Ei.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*","name",["*"]),r=Array.from(await Qme(t)),n=[];for(let i=0,o=r.length;i<o;i++){let c=r[i];if(!eEe.NATS_TERM_CONSTRAINTS_RX.test(c.name)){let f=`Node name '${c.name}' is invalid, must not contain ., * or >. Please change name and try again.`;throw console.error(f),f}let l={host:c.host,port:c.port};e.push(l);let u=[];for(let f=0,d=c.subscriptions.length;f<d;f++){let p=c.subscriptions[f],_=p.channel.split(":");u.push({schema:_[0],table:_[1],publish:p.publish,subscribe:p.subscribe})}n.push({name:c.name,subscriptions:u,system_info:{hdb_version:Ei.PRE_4_0_0_VERSION,node_version:void 0,platform:void 0}})}if(bT.isEmptyOrZeroLength(n))return;let s=new jme(Ei.SYSTEM_SCHEMA_NAME,Ei.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,n);await Xme.update(s)}catch(t){throw console.error("There was a problem updating the hdb_nodes table. Please check the log for details."),t}try{Zme.setRoutes({server:"hub",routes:e})}catch(t){throw console.error("There was a problem setting the clustering routes. Please check the log for details."),t}}a(sEe,"updateNodes");async function iEe(){let e=uC.get(Ei.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);if(!e.includes(yT.join("config","settings.js"))){$l.info("pre 4.0.0 settings.js file not found, skipping settings file update");return}let t="Updating settings file for version 4.0.0";console.log(t),$l.info(t);let r=yT.dirname(e),n=uC.get(Ei.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),s=yT.join(n,"backup","4_0_0_upgrade_settings.bak"),i=yT.join(n,Ei.HDB_CONFIG_FILE);try{$l.info(`Backing up old settings file to: ${s}`),console.log(`Backing up old settings file to: ${s}`),nc.copySync(e,s)}catch(d){throw console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),d}try{$l.info(`Creating new/upgraded settings file at '${i}'`),console.log(`Creating new/upgraded settings file at '${i}'`),$l.info("Updating env variables with new settings values");let d=WY.initOldConfig(e);_h=d[Ei.CONFIG_PARAMS.TLS_CERTIFICATE.toLowerCase()],ph=d[Ei.CONFIG_PARAMS.TLS_PRIVATEKEY.toLowerCase()],WY.createConfigFile(d)}catch(d){throw console.log("There was a problem creating the new HarperDB config file. Please check the log for details."),d}let o=bT.getPropsFilePath();nc.accessSync(o,nc.constants.F_OK|nc.constants.R_OK);let l=Wme(o).get(Ei.HDB_SETTINGS_NAMES.INSTALL_USER),u=`settings_path = ${i}
111
- install_user = ${l}`;try{nc.writeFileSync(o,u)}catch(d){throw console.log("There was a problem updating the HarperDB boot properties file. Please check the log for details."),d}try{uC.initSync(!0)}catch(d){throw console.error("Unable to initialize new properties. Please check the log for details."),d}let f="New settings file for 4.0.0 upgrade successfully created.";try{nc.removeSync(r),console.log(f),$l.info(f)}catch(d){throw console.error("There was a problem deleting the old settings file and directory. Please check the log for details."),d}}a(iEe,"updateSettingsFile_4_0_0");hh.async_functions.push(iEe);hh.async_functions.push(nEe);hh.async_functions.push(tEe);hh.async_functions.push(sEe);jY.push(hh);JY.exports=jY});var dC=w((gUe,tW)=>{"use strict";var Vl=ie(),oEe=(H(),C(G)),XY=z(),{DATA_VERSION:aEe,UPGRADE_VERSION:cEe}=oEe.UPGRADE_JSON_FIELD_NAMES_ENUM,ZY=GY(),OT=QY(),Kl=new Map;ZY&&ZY.forEach(e=>{Kl.set(e.version,e)});OT&&OT.forEach(e=>{Kl.set(e.version,e)});OT&&OT.forEach(e=>{Kl.set(e.version,e)});function lEe(){return[...Kl.keys()].sort(Vl.compareVersions)}a(lEe,"getSortedVersions");function eW(e){let t=e[aEe],r=e[cEe];return Vl.isEmptyOrZeroLength(t)||Vl.isEmptyOrZeroLength(r)?(XY.info(`There is an issue with the version data in your instance of HDB. Current version data: ${e}`),XY.error("There was an error when trying to evaluate the version information for your instance. Trying to start the server anyways but it may fail. If you continue to have this problem, please contact support@harperdb.io."),[]):[...Kl.keys()].sort(Vl.compareVersions).filter(function(n){return Vl.compareVersions(n,t)>0&&Vl.compareVersions(n,r)<=0})}a(eW,"getVersionsForUpgrade");function uEe(e){return eW(e).length>0}a(uEe,"hasUpgradesRequired");function dEe(e){return Vl.isEmptyOrZeroLength(e)?null:Kl.has(e)?Kl.get(e):null}a(dEe,"getDirectiveByVersion");tW.exports={getSortedVersions:lEe,getDirectiveByVersion:dEe,getVersionsForUpgrade:eW,hasUpgradesRequired:uEe}});var mh=w((TUe,oW)=>{"use strict";var fEe=require("util"),fC=require("chalk"),_Ee=require("os"),nW=yn(),pEe=Yr(),as=(H(),C(G)),sW=CY(),pC=Uy(),{UpgradeObject:rW}=LY(),{forceDowngradePrompt:hEe}=ST(),{packageJson:mEe}=it(),NT=z(),Wd=ie(),hC=As(),EEe=(De(),C(nt)),gEe=dC(),SEe=fEe.promisify(hC.setSchemaDataToGlobal),TEe=pEe.searchByValue,AEe="info_id",REe="2.9.9",yEe="3.0.0";async function bEe(e){let t=new sW.HdbInfoInsertObject(1,e,e),r=new pC.InsertObject(as.OPERATIONS_ENUM.INSERT,as.SYSTEM_SCHEMA_NAME,as.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,as.INFO_TABLE_HASH_ATTRIBUTE,[t]);return hC.setSchemaDataToGlobal(),nW.insert(r)}a(bEe,"insertHdbInstallInfo");async function _C(e){let t,r=await iW(),n=new Map([[0,{}]]);for(let c of r)n.set(c.info_id,c);let i=Math.max.apply(null,[...n.keys()])+1;t=new sW.HdbInfoInsertObject(i,e,e);let o=new pC.InsertObject(as.OPERATIONS_ENUM.INSERT,as.SYSTEM_SCHEMA_NAME,as.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,as.INFO_TABLE_HASH_ATTRIBUTE,[t]);return await SEe(),nW.insert(o)}a(_C,"insertHdbUpgradeInfo");async function iW(){let e=new pC.NoSQLSeachObject(as.SYSTEM_SCHEMA_NAME,as.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,AEe,as.INFO_TABLE_HASH_ATTRIBUTE,["*"],"*"),t=[];try{t=Array.from(await TEe(e))}catch(r){console.error(r)}return t}a(iW,"getAllHdbInfoRecords");async function OEe(){let e=await iW();if(e.length===0)return;let t,r=new Map;for(let s of e)r.set(s.info_id,s);let n=Math.max.apply(null,[...r.keys()]);return t=r.get(n),t}a(OEe,"getLatestHdbInfoRecord");async function NEe(){NT.info("Checking if HDB software has been updated");try{let e=mEe.version;if(!e)throw new Error("Could not find the version number in the package.json file");let t=await OEe(),r;if(Wd.isEmpty(t))r=REe;else if(r=t.data_version_num,Wd.compareVersions(r.toString(),e.toString())>0){if(!Wd.isCompatibleDataVersion(r.toString(),e.toString()))throw console.log(fC.yellow(`This instance's data was last run on version ${r}`)),console.error(fC.red(`You have installed a version lower than the version that your data was created on or was upgraded to. This may cause issues and is currently not supported.${_Ee.EOL}${as.SUPPORT_HELP_MSG}`)),new Error("Trying to downgrade major HDB versions is not supported.");Wd.isCompatibleDataVersion(r.toString(),e.toString(),!0)||(console.log(fC.yellow(`This instance's data was last run on version ${r}`)),await hEe(new rW(r,e))?await _C(e.toString()):(console.log("Cancelled downgrade, closing HarperDB"),process.exit(0)))}if(hC.setSchemaDataToGlobal(),wEe(r),e.toString()===r.toString())return;let n=new rW(r,e);if(gEe.hasUpgradesRequired(n))return n;Wd.compareVersions(n.data_version.toString(),n.upgrade_version.toString())<0&&(await _C(n.upgrade_version),NT.notify(`HarperDB running on upgraded version: ${n.upgrade_version}`))}catch(e){throw NT.fatal("Error while trying to evaluate the state of hdb data and the installed hdb version"),NT.fatal(e),e}}a(NEe,"getVersionUpdateInfo");function wEe(e){let t=`You are attempting to upgrade from an old instance of HarperDB that is no longer supported. In order to upgrade to this version, you must do a fresh install. If you need support, please contact ${as.HDB_SUPPORT_ADDRESS}`;if(!("hdb_info"in EEe.databases.system))throw console.log(t),new Error(t);if(!Wd.isEmpty(e)&&e<yEe)throw console.log(t),new Error(t)}a(wEe,"checkIfInstallIsSupported");oW.exports={insertHdbInstallInfo:bEe,insertHdbUpgradeInfo:_C,getVersionUpdateInfo:NEe}});var uW=w((RUe,lW)=>{"use strict";var wT=require("joi"),{boolean:IEe,string:mC,number:CEe}=wT.types(),aW=require("fs-extra"),Eh=(H(),C(G)),cW=require("path"),PEe=ot();lW.exports=DEe;function DEe(e){let t=mC.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),r=wT.object({[Eh.INSTALL_PROMPTS.ROOTPATH]:wT.custom(LEe),[Eh.INSTALL_PROMPTS.OPERATIONSAPI_NETWORK_PORT]:wT.alternatives([CEe.min(0),mC]).allow("null",null),[Eh.INSTALL_PROMPTS.TC_AGREEMENT]:mC.valid("yes","YES","Yes"),[Eh.INSTALL_PROMPTS.CLUSTERING_NODENAME]:t,[Eh.INSTALL_PROMPTS.CLUSTERING_ENABLED]:IEe});return PEe.validateBySchema(e,r)}a(DEe,"installValidator");function LEe(e,t){if(aW.existsSync(cW.join(e,"system/hdb_user/data.mdb"))||aW.existsSync(cW.join(e,"system/hdb_user.mdb")))return t.message(`'${e}' is already in use. Please enter a different path.`)}a(LEe,"validateRootAvailable")});var SC=w((bUe,dW)=>{"use strict";var{mkdirpSync:MEe,copySync:vEe}=require("fs-extra"),sc=require("path"),gh=(H(),C(G)),{PACKAGE_ROOT:UEe}=it(),gC=z(),xEe=Vn(),EC=po(),BEe=gt();dW.exports=HEe;async function HEe(e){gC.trace("Mounting HarperDB"),Yl(e),Yl(sc.join(e,"backup")),Yl(sc.join(e,"keys")),Yl(sc.join(e,"keys",gh.LICENSE_FILE_NAME)),Yl(sc.join(e,"log")),Yl(sc.join(e,"database")),Yl(sc.join(e,"components")),vEe(sc.resolve(UEe,"./utility/install/README.md"),sc.join(e,"README.md")),await kEe()}a(HEe,"mountHdb");async function kEe(){let e=v_(),t=Object.keys(EC);for(let r=0;r<t.length;r++){let n=t[r],s=EC[n].hash_attribute;try{BEe.initSystemSchemaPaths(gh.SYSTEM_SCHEMA_NAME,n);let i=new e(gh.SYSTEM_SCHEMA_NAME,n,s);i.attributes=EC[n].attributes;let o=i.attributes.find(({attribute:c})=>c===s);o.isPrimaryKey=!0,["hdb_user","hdb_role"].includes(n)&&(i.audit=!0),await xEe.createTable(n,i)}catch(i){throw gC.error(`issue creating environment for ${gh.SYSTEM_SCHEMA_NAME}.${n}: ${i}`),i}}}a(kEe,"createLMDBTables");function Yl(e){MEe(e,{mode:gh.HDB_FILE_PERMISSIONS}),gC.info(`Directory ${e} created`)}a(Yl,"makeDirectory")});var PT=w((IUe,bW)=>{"use strict";var AC=require("os"),mW=require("inquirer"),xs=require("fs-extra"),FEe=require("properties-reader"),zl=require("chalk"),ji=require("path"),GEe=require("human-readable-ids").hri,qEe=require("ora"),$Ee=require("yaml"),pr=z(),ic=ae(),Sh=ie(),CT=ua(),EW=mh(),{packageJson:gW}=it(),de=(H(),C(G)),{CONFIG_PARAM_MAP:NUe,CONFIG_PARAMS:Dt}=de,VEe=uW(),KEe=SC(),RC=yt(),YEe=Rn(),WEe=F_(),zEe=tC(),jEe=As(),JEe=require("util").promisify,QEe=JEe(jEe.setSchemaDataToGlobal),fW=Zn(),Wl=a(e=>e,"PROMPT_ANSWER_TRANSFORMER"),kr=a(e=>zl.magenta.bold(e),"HDB_PROMPT_MSG"),XEe="https://harperdb.io/legal/end-user-license-agreement",oc=AC.EOL,Yo="",ZEe="yes",_W="Starting HarperDB install...",pW="HarperDB installation was successful.",hW="Terms & Conditions acceptance is required to proceed with installation. Exiting install...",ege="An out of date version of HarperDB is already installed.",TC="It appears that HarperDB is already installed. Exiting install...",tge="Aborting install",wUe=new RegExp(/^([0-9]{1,4}|[1-5][0-9]{4}|6[0-4][0-9]{3}|65[0-4][0-9]{2}|655[0-2][0-9]|6553[0-5])$/),rge=new RegExp(/^[^\s.,*>]+$/),nge=AC.homedir(),sge=ji.join(nge,de.HDB_ROOT_DIR_NAME),ige="HDB_ADMIN",oge="CLUSTER_USER",age="dev",cge="localhost",IT={[Dt.HTTP_CORS]:!0,[Dt.HTTP_CORSACCESSLIST]:["*"],[Dt.HTTP_PORT]:9926,[Dt.AUTHENTICATION_AUTHORIZELOCAL]:!0,[Dt.THREADS_COUNT]:1,[Dt.THREADS_DEBUG]:!0,[Dt.LOGGING_STDSTREAMS]:!0,[Dt.LOGGING_LEVEL]:"info",[Dt.OPERATIONSAPI_NETWORK_PORT]:9925,[Dt.LOCALSTUDIO_ENABLED]:!0},Hr={DESTINATION:"Please enter a destination for HarperDB:",HDB_USERNAME:"Please enter a username for the administrative user:",HDB_PASS:"Please enter a password for the administrative user:",NODE_NAME:"Please enter a unique name for this node:",CLUSTER_USERNAME:"Please enter a username for the CLUSTER_USER:",CLUSTER_PASS:"Please enter a password for the CLUSTER_USER:",DEFAULTS_MODE:"Default Config - dev (easy access/debugging) or prod (security/performance): (dev/prod)",REPLICATION_HOSTNAME:"Please enter the hostname for this server:"},ac=CT([de.INSTALL_PROMPTS.HDB_CONFIG]),zi,SW=!1,yC=!1,TW=!1;bW.exports={install:AW,updateConfigEnv:Sge,setIgnoreExisting:Tge};AW.createSuperUser=yW;async function AW(){console.log(kr(oc+_W+oc)),pr.notify(_W);let e;ac[de.INSTALL_PROMPTS.HDB_CONFIG]&&(e=lge());let t=dge();Object.assign(t,e),t[de.INSTALL_PROMPTS.TC_AGREEMENT]&&t[de.INSTALL_PROMPTS.ROOTPATH]&&t[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME]&&t[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]&&t[de.INSTALL_PROMPTS.DEFAULTS_MODE]===void 0&&(TW=!0,t[de.INSTALL_PROMPTS.DEFAULTS_MODE]="prod");let r=VEe(t);if(r)throw r.message;await fge(),await _ge(t);let n=await uge(t);zi=n[de.INSTALL_PROMPTS.ROOTPATH],ac[de.INSTALL_PROMPTS.HDB_CONFIG]&&ji.dirname(ac[de.INSTALL_PROMPTS.HDB_CONFIG])===zi&&(SW=!0),!yC&&!ac[de.INSTALL_PROMPTS.HDB_CONFIG]&&await xs.pathExists(ji.join(zi,de.HDB_CONFIG_FILE))&&(console.error(TC),process.exit());let s=qEe({prefixText:kr("Installing"),color:"magenta",spinner:"simpleDots"});if(s.start(),Sh.isEmpty(zi))throw new Error("Installer should have the HDB root param at the stage it is in but it does not.");ic.setHdbBasePath(zi),await KEe(zi),await pge(),await hge(n),pr.initLogSettings(!0),await yW(n),await Ege(n),await fW.updateConfigCert(),await fW.generateCertsKeys(),await gge(),zEe(),s.stop(),console.log(kr(oc+pW+oc)),pr.notify(pW)}a(AW,"install");function lge(){let e=$Ee.parseDocument(xs.readFileSync(ac[de.INSTALL_PROMPTS.HDB_CONFIG],"utf8"),{simpleKeys:!0}),t=RC.flattenConfig(e.toJSON());return t[de.CONFIG_PARAMS.ROOTPATH.toLowerCase()]&&(t.ROOTPATH=t[de.CONFIG_PARAMS.ROOTPATH.toLowerCase()]),t}a(lge,"getConfigFromFile");async function uge(e){pr.trace("Getting install prompts and params.");let t,r=[{type:"input",transformer:Wl,when:Wo(e[de.INSTALL_PROMPTS.ROOTPATH],Hr.DESTINATION),name:de.INSTALL_PROMPTS.ROOTPATH,prefix:Yo,default:sge,validate:a(async s=>Us(s)?Us(s):await xs.pathExists(ji.join(s,"system","hdb_user.mdb"))?`'${s}' is already in use. Please enter a different path.`:!0,"validate"),message:kr(Hr.DESTINATION)},{type:"input",transformer:Wl,when:Wo(e[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],Hr.HDB_USERNAME),name:de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME,prefix:Yo,default:ige,validate:a(s=>Us(s)?Us(s):(t=s,!0),"validate"),message:kr(Hr.HDB_USERNAME)},{type:"password",when:Wo(e[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD],Hr.HDB_PASS),name:de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD,prefix:Yo,validate:a(s=>Us(s)?Us(s):!0,"validate"),message:kr(Hr.HDB_PASS)},{type:"input",transformer:Wl,when:Wo(e[de.INSTALL_PROMPTS.DEFAULTS_MODE],Hr.DEFAULTS_MODE),name:de.INSTALL_PROMPTS.DEFAULTS_MODE,prefix:Yo,default:age,validate:a(s=>Us(s)?Us(s):s!=="dev"&&s!=="prod"?`Invalid response '${s}', options are 'dev' or 'prod'.`:!0,"validate"),message:kr(Hr.DEFAULTS_MODE)}];if(TW||r.push({type:"input",name:de.INSTALL_PROMPTS.REPLICATION_HOSTNAME,transformer:Wl,when:Wo(e[de.INSTALL_PROMPTS.REPLICATION_HOSTNAME],Hr.REPLICATION_HOSTNAME),prefix:Yo,default:cge,message:kr(Hr.REPLICATION_HOSTNAME)}),Sh.autoCastBoolean(e[de.INSTALL_PROMPTS.CLUSTERING_ENABLED])===!0){let s=[{type:"input",transformer:Wl,when:Wo(e[de.INSTALL_PROMPTS.CLUSTERING_NODENAME],Hr.NODE_NAME),name:de.INSTALL_PROMPTS.CLUSTERING_NODENAME,prefix:Yo,default:GEe.random(),validate:a(i=>rge.test(i)?!0:"Invalid node name, must not contain ., * or >","validate"),message:kr(Hr.NODE_NAME)},{type:"input",transformer:Wl,when:Wo(e[de.INSTALL_PROMPTS.CLUSTERING_USER],Hr.CLUSTER_USERNAME),name:de.INSTALL_PROMPTS.CLUSTERING_USER,prefix:Yo,default:oge,validate:a(i=>Us(i)?Us(i):i.toLowerCase()===t.toLowerCase()?"Username is already in use.":!0,"validate"),message:kr(Hr.CLUSTER_USERNAME)},{type:"password",when:Wo(e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD],Hr.CLUSTER_PASS),name:de.INSTALL_PROMPTS.CLUSTERING_PASSWORD,prefix:Yo,validate:a(i=>Us(i)?Us(i):!0,"validate"),message:kr(Hr.CLUSTER_PASS)}];r.push(...s)}let n=await mW.prompt(r);if(Object.keys(n).length===0)return e;for(let s in n)e[s]===void 0&&(e[s]=n[s]);return e}a(uge,"installPrompts");function Wo(e,t){return e!==void 0?(t.includes("password")?(console.log(`${kr(t)} ${zl.gray("[hidden]")}`),pr.trace(`${kr(t)} [hidden]`)):(console.log(`${kr(t)} ${e}`),pr.trace(`${kr(t)} ${e}`)),!1):!0}a(Wo,"displayCmdEnvVar");function Us(e){let t=e.replace(/ /g,"");if(t===""||t==="''"||t==='""')return"Value cannot be empty."}a(Us,"checkForEmptyValue");function dge(){let e=Object.keys(de.INSTALL_PROMPTS),t=CT(e),r=CT(Object.keys(de.CONFIG_PARAM_MAP),!0),n={};for(let s of e){let i=de.CONFIG_PARAM_MAP[s.toLowerCase()];t[s]?i===void 0?n[s]=t[s]:n[i.toUpperCase()]=t[s]:i!==void 0&&r[i.toLowerCase()]&&(n[s]=r[i.toLowerCase()])}return n}a(dge,"checkForPromptOverride");async function fge(){pr.trace("Checking for existing install.");let e=Sh.getPropsFilePath(),t=await xs.pathExists(e),r;if(t){pr.trace(`Install found an existing boot prop file at:${e}`);let n=FEe(e),s=RC.getConfigValue(de.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)||n.get(de.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY);r=await xs.pathExists(s)}if(!t&&Sh.noBootFile()&&(r=!0),r&&!yC){if(pr.trace(`Install found existing HDB config at:${e}`),await EW.getVersionUpdateInfo()){let s=`Please use \`harperdb upgrade\` to update to ${gW.version}. Exiting install...`;console.log(oc+zl.magenta.bold(ege)),console.log(zl.magenta.bold(s)),pr.error(s)}else console.log(oc+zl.magenta.bold(TC)),pr.error(TC);process.exit(0)}}a(fge,"checkForExistingInstall");async function _ge(e){pr.info("Asking for terms agreement.");let t=`Terms & Conditions can be found at ${XEe}${oc}and can be viewed by typing or copying and pasting the URL into your web browser.${oc}I agree to the HarperDB Terms and Conditions: (yes/no)`,r={prefix:Yo,transformer:Wl,when:Wo(e[de.INSTALL_PROMPTS.TC_AGREEMENT],t),name:de.INSTALL_PROMPTS.TC_AGREEMENT,message:kr(t),validate:a(s=>s.toLowerCase()==="yes"||s.toLowerCase()==="no"?!0:zl.yellow("Please enter 'yes' or 'no'"),"validate")},n=await mW.prompt([r]);n[de.INSTALL_PROMPTS.TC_AGREEMENT]&&n[de.INSTALL_PROMPTS.TC_AGREEMENT].toLowerCase()!==ZEe&&(console.log(zl.yellow(hW)),pr.error(hW),process.exit(0))}a(_ge,"termsAgreement");async function pge(){let e=ji.join(zi,de.HDB_CONFIG_FILE),t;try{t=AC.userInfo().username}catch{t=process.env.USERNAME||process.env.USER||process.env.LOGNAME||process.env.LNAME||process.env.SUDO_USER}if(t){let r=`settings_path = ${e}
112
- install_user = ${t}`,n=Sh.getHomeDir(),s=ji.join(n,de.HDB_HOME_DIR_NAME),i=ji.join(s,de.LICENSE_KEY_DIR_NAME);try{xs.mkdirpSync(s,{mode:de.HDB_FILE_PERMISSIONS}),xs.mkdirpSync(i,{mode:de.HDB_FILE_PERMISSIONS})}catch{console.error(`Could not make settings directory ${de.HDB_HOME_DIR_NAME} in home directory. Please check your permissions and try again.`)}let o=ji.join(s,de.BOOT_PROPS_FILE_NAME);try{await xs.writeFile(o,r)}catch(c){throw pr.error(`There was an error creating the boot file at path: ${o}`),c}ic.setProperty(de.HDB_SETTINGS_NAMES.INSTALL_USER,`${t}`),ic.setProperty(de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,e),ic.setProperty(ic.BOOT_PROPS_FILE_PATH,o)}}a(pge,"createBootPropertiesFile");async function hge(e){pr.trace("Creating HarperDB config file");let t=CT(Object.keys(de.CONFIG_PARAM_MAP),!0);if(Object.assign(t,e),e[de.INSTALL_PROMPTS.DEFAULTS_MODE]==="dev"){process.env.DEV_MODE="true";for(let r in IT){if(r===Dt.HTTP_PORT&&t[Dt.HTTP_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??IT[r],t[Dt.HTTP_SECUREPORT]=null;continue}else if(r===Dt.HTTP_PORT)continue;if(r===Dt.OPERATIONSAPI_NETWORK_PORT&&t[Dt.OPERATIONSAPI_NETWORK_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??IT[r],t[Dt.OPERATIONSAPI_NETWORK_SECUREPORT]=null;continue}else if(r===Dt.OPERATIONSAPI_NETWORK_PORT)continue;t[r.toLowerCase()]===void 0&&(t[r]=IT[r])}}else t[Dt.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]&&(t[Dt.OPERATIONSAPI_NETWORK_SECUREPORT]=null),t[Dt.HTTP_PORT.toLowerCase()]&&(t[Dt.HTTP_SECUREPORT]=null);try{ac[de.INSTALL_PROMPTS.HDB_CONFIG]||RC.createConfigFile(t),ic.initSync()}catch(r){mge(r)}}a(hge,"createConfigFile");function mge(e){pr.error(`Error creating HarperDB config file. Rolling back install - ${e}`),console.error(e),console.error(tge);let t=ji.resolve(ic.get(ic.BOOT_PROPS_FILE_PATH),"../");t&&xs.removeSync(t),zi&&(SW?xs.readdirSync(zi,{withFileTypes:!0}).forEach(n=>{let s=ji.join(n.path,n.name);s!==ac[de.INSTALL_PROMPTS.HDB_CONFIG]&&xs.removeSync(s)}):xs.removeSync(zi)),process.exit(1)}a(mge,"rollbackInstall");async function RW(e,t){pr.trace("Creating admin user"),await QEe();let r;try{r=await WEe.addRole(e)}catch(n){if(n.message.includes("already exists"))t=void 0;else throw n.message+="Error creating role",n}if(t)try{t.role=r.role,await YEe.addUser(t)}catch(n){throw n.message=`Error creating user - ${n}`,n}}a(RW,"createAdminUser");async function yW(e){pr.trace("Creating Super user.");let t={role:"super_user",permission:{super_user:!0}},r={username:e[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME].toString(),password:e[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD].toString(),active:!0};await RW(t,r),delete e[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],delete e[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]}a(yW,"createSuperUser");async function Ege(e){pr.trace("Creating Cluster user.");let t;e[de.INSTALL_PROMPTS.CLUSTERING_USER]&&e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD]&&(t={username:e[de.INSTALL_PROMPTS.CLUSTERING_USER].toString(),password:e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD].toString(),active:!0}),await RW({role:"cluster_user",permission:{cluster_user:!0}},t),delete e[de.INSTALL_PROMPTS.CLUSTERING_USER],delete e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD]}a(Ege,"createClusterUser");async function gge(){let e=gW.version;if(e)await EW.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(gge,"insertHdbVersionInfo");function Sge(e){ac[de.INSTALL_PROMPTS.HDB_CONFIG]=e}a(Sge,"updateConfigEnv");function Tge(e){yC=e}a(Tge,"setIgnoreExisting")});var wW=w((PUe,NW)=>{"use strict";var bC=ie(),cs=z(),OW=dC();NW.exports={processDirectives:Age};async function Age(e){console.log("Starting upgrade process...");let t=OW.getVersionsForUpgrade(e),r=bge(t),n=[],s=r.length;for(let i=0;i<s;i++){let o=r[i],c=`Running upgrade for version ${o.version}`;cs.notify(c),console.log(c);let l=[],u=[];try{l=Rge(o.sync_functions)}catch(f){throw cs.error(`Error while running an upgrade script for ${o.version}`),f}try{u=await yge(o.async_functions)}catch(f){throw cs.error(`Error while running an upgrade script for ${o.version}`),f}n.push(...l,...u)}return n}a(Age,"processDirectives");function Rge(e){if(bC.isEmptyOrZeroLength(e))return cs.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return cs.info("Passed parameter is not an array"),[];let t=[];for(let r of e){if(cs.info(`Running function ${r.name}`),!(r instanceof Function)){cs.info("Variable being processed is not a function");continue}let n=r();cs.info(n),t.push(n)}return t}a(Rge,"runSyncFunctions");async function yge(e){if(bC.isEmptyOrZeroLength(e))return cs.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return cs.info("Passed parameter is not an array"),[];let t=[],r=e.length;for(let n=0;n<r;n++){let s=e[n];if(cs.info(`Running function ${s.name}`),!(s instanceof Function)){cs.info("Variable being processed is not a function");continue}let i=await s();cs.info(i),t.push(i)}return t}a(yge,"runAsyncFunctions");function bge(e){if(bC.isEmptyOrZeroLength(e))return[];let t=[];for(let r of e){let n=OW.getDirectiveByVersion(r);n&&t.push(n)}return t}a(bge,"getUpgradeDirectivesToInstall")});var IC=w((LUe,MW)=>{"use strict";var DT=ae();DT.initSync();var DW=require("chalk"),IW=require("fs-extra"),jo=z(),zo=(H(),C(G)),Oge=wW(),OC=ie(),LW=mh(),Nge=ST(),CW=iR(),wge=As(),{packageJson:PW}=it(),Ige=require("util").promisify,Cge=Ige(wge.setSchemaDataToGlobal),NC,{UPGRADE_VERSION:wC}=zo.UPGRADE_JSON_FIELD_NAMES_ENUM;MW.exports={upgrade:Pge};async function Pge(e){await Cge(),NC===void 0&&(NC=Pd()),IW.existsSync(DT.get(DT.BOOT_PROPS_FILE_PATH))||(Th("The hdb_boot_properties file was not found. Please install HDB.",zo.LOG_LEVELS.ERROR),process.exit(1)),IW.existsSync(DT.get(zo.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))||(Th("The hdb settings file was not found. Please make sure HDB is installed.",zo.LOG_LEVELS.ERROR),process.exit(1));let t=e;t||(t=await LW.getVersionUpdateInfo(),t||(console.log("HarperDB version is current"),process.exit(0))),Th(`This version of HarperDB is ${PW.version}`,zo.LOG_LEVELS.INFO);let r=t[wC]??PW.version;r||(console.log(`Current Version field missing from the package.json file. Cannot continue with upgrade. If you need support, please contact ${zo.HDB_SUPPORT_ADDRESS}`),jo.notify("Missing new version field from upgrade info object"),process.exit(1)),await Dge();let n,s=0;try{n=await Nge.forceUpdatePrompt(t)}catch(i){jo.error("There was an error when prompting user about upgrade."),jo.error(i),n=!1,s=1}n||(console.log("Cancelled upgrade, closing HarperDB"),process.exit(s)),jo.info(`Starting upgrade to version ${r}`),await Lge(t),Th(`HarperDB was successfully upgraded to version ${t[wC]}`,zo.LOG_LEVELS.INFO)}a(Pge,"upgrade");async function Dge(){let e=!1,t=await CW.findPs(zo.HDB_PROC_NAME);if(OC.isEmptyOrZeroLength(t)||(e=!0),!e){let r=await CW.findPs("hdb_express");OC.isEmptyOrZeroLength(r)||(e=!0)}if(!e){let r=await NC.list();OC.isEmptyOrZeroLength(r)||(e=!0)}if(e){let r="HarperDB is running, please stop all HarperDB services with 'harperdb stop' and run the upgrade command again.";console.log(DW.red(r)),jo.error(r),process.exit(1)}}a(Dge,"checkIfRunning");async function Lge(e){try{await Oge.processDirectives(e)}catch(t){throw Th("There was an error during the data upgrade. Please check the logs.",zo.LOG_LEVELS.ERROR),t}try{await LW.insertHdbUpgradeInfo(e[wC])}catch(t){jo.error("Error updating the 'hdb_info' system table."),jo.error(t)}}a(Lge,"runUpgrade");function Th(e,t=void 0){t||(t=jo.info),jo[t](e),console.log(DW.magenta(e))}a(Th,"printToLogAndConsole")});var HW={};ve(HW,{onStorageReclamation:()=>Ah,runReclamationHandlers:()=>LC,setAvailableSpaceRatioGetter:()=>vge});function Ah(e,t,r){(r||(0,MT.getWorkerIndex)()===(0,MT.getWorkerCount)()-1)&&(LT.has(e)||LT.set(e,[]),LT.get(e).push({priority:0,handler:t}),DC||(DC=setTimeout(LC,UW).unref()))}async function LC(){for(let[e,t]of LT)try{let r=await BW(e),n=Mge/r;for(let s of t){let{priority:i,handler:o}=s;if(s.priority=n,n>1||i>1){let c=o(n>1?n:0);c&&(PC.default.info?.(`Running storage reclamation handler for ${e} with priority ${n}`),await c)}}}catch(r){PC.default.error?.("Error running storage reclamation handlers",r)}DC=setTimeout(LC,UW).unref()}function vge(e){BW=e??xW}var CC,MT,PC,vT,vW,LT,Mge,UW,DC,xW,BW,UT=be(()=>{CC=require("node:fs/promises"),MT=M(rt()),PC=M(Ni());H();vT=M(ae()),vW=M(ie());vT.default.initSync();LT=new Map,Mge=vT.default.get(x.STORAGE_RECLAMATION_THRESHOLD)??.4,UW=(0,vW.convertToMS)(vT.default.get(x.STORAGE_RECLAMATION_INTERVAL))||36e5;a(Ah,"onStorageReclamation");xW=a(async e=>{if(CC.statfs){let t=await(0,CC.statfs)(e);return t.bavail/t.blocks}else return new Promise((t,r)=>{import("hdd-space").then(n=>{n.default(s=>{for(let i of s.parts)if(e.startsWith(i.place))return t(i.free/i.size);return t(1)})})})},"defaultGetAvailableSpaceRatio"),BW=xW;a(LC,"runReclamationHandlers");a(vge,"setAvailableSpaceRatioGetter")});var $W=w((xUe,qW)=>{"use strict";var{promises:zd,createReadStream:Uge,createWriteStream:xge}=require("fs"),{createGzip:Bge}=require("zlib"),{promisify:Hge}=require("util"),{pipeline:kge}=require("stream"),Fge=Hge(kge),vC=require("path"),lc=ae();lc.initSync();var cc=z(),{CONFIG_PARAMS:jd,ITC_EVENT_TYPES:Gge}=(H(),C(G)),{onMessageFromWorkers:qge}=rt(),{convertToMS:$ge}=ie(),{onStorageReclamation:Vge}=(UT(),C(HW)),Kge=6e4,Yge="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",Wge="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",MC,FW;qW.exports=GW;qge(e=>{e.type===Gge.RESTART&&(lc.initSync(!0),clearInterval(FW),lc.get(jd.LOGGING_ROTATION_ENABLED)&&GW())});async function GW(){try{let e=cc.getLogFilePath(),t=lc.get(jd.LOGGING_ROTATION_MAXSIZE),r=lc.get(jd.LOGGING_ROTATION_INTERVAL),n=lc.get(jd.LOGGING_ROTATION_RETENTION),s=0;if(Vge(e,l=>{s=l},!0),!t&&!r){cc.error(Yge);return}let i=lc.get(jd.LOGGING_ROTATION_PATH);if(!i){cc.error(Wge);return}let o;if(t){let l=t.slice(-1),u=t.slice(0,-1);l==="G"?o=u*1e9:l==="M"?o=u*1e6:o=u*1e3}let c;if(r){let l=r.slice(-1),u=r.slice(0,-1);l==="D"?c=u*1440:l==="H"?c=u*60:c=u}MC=Date.now()/6e4,cc.trace("Log rotate enabled, maxSize:",t,"interval:",r),FW=setInterval(async()=>{if(o){let l;l=await zd.stat(e),l.size>=o&&await kW(e,i)}if(c&&Date.now()/6e4-MC>=c&&(await kW(e,i),MC=Date.now()/6e4),n||s){let l=$ge(n??"1M")/(1+s);s=0;let u=await zd.readdir(i);for(let f of u)try{let d=await zd.stat(vC.join(i,f));Date.now()-d.mtimeMs>l&&await zd.unlink(vC.join(i,f))}catch(d){cc.error("Error trying to remove log",f,d)}}},Kge).unref()}catch(e){cc.error(e)}}a(GW,"logRotator");async function kW(e,t){let r=lc.get(jd.LOGGING_ROTATION_COMPRESS),n=vC.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.log`);await zd.rename(e,n),r&&(e=n,n+=".gz",await Fge(Uge(e),Bge(),xge(n)),await zd.unlink(e)),cc.closeLogFile(),cc.notify(`hdb.log rotated, old log moved to ${n}`)}a(kW,"moveLogFile")});var Qd=w(JW=>{"use strict";var Ae=ae();Ae.initSync();za();var Gt=(H(),C(G)),{CONFIG_PARAMS:Ce}=Gt,ls=z(),Jo=require("fs-extra"),Qo=require("path"),zge=tC(),{install:jge}=PT(),UC=require("chalk"),{packageJson:Jge,PACKAGE_ROOT:Qge}=it(),Xo=ie(),xC=yt(),KW=ua(),VW=TS(),Xge=IC(),Zge=$W(),{compactOnStart:eSe}=(IS(),C(wS)),tSe=require("minimist"),rSe=Zn(),{startHTTPThreads:nSe}=(BC(),C(QW)),sSe=mh(),{isMainThread:iSe}=require("worker_threads"),HUe=po(),kUe=go(),FUe=Pb(),GUe=v_(),xT=(H(),C(G)),Ji,Jd,YW=!1,oSe="Upgrade complete. Starting HarperDB.",aSe="Got an error while trying to upgrade your HarperDB instance. Exiting HarperDB.",cSe="HarperDB not found, starting install process.",lSe="There was an error during install, check install_log.log for more details. Exiting.",uSe="HarperDB successfully started.";function dSe(){if(!YW){let e=a(()=>{Jo.removeSync(Qo.join(Ae.get(Gt.CONFIG_PARAMS.ROOTPATH),Gt.HDB_PID_FILE)),process.exit(0)},"remove_hdb_pid");process.on("exit",()=>{e()}),process.on("SIGINT",()=>{e()}),process.on("SIGQUIT",()=>{e()}),process.on("SIGTERM",()=>{e()})}}a(dSe,"addExitListeners");async function WW(e=!1,t=!1){if(console.log(UC.magenta("Starting HarperDB...")),ls.suppressLogging?.(()=>{console.log(UC.magenta(""+Jo.readFileSync(Qo.join(Qge,"utility/install/ascii_logo.txt"))))}),await jW()===!1){console.log(cSe);try{await jge()}catch(l){console.error(lSe,l),ls.error(l),process.exit(1)}}if(!e){let l=KW(Object.keys(Gt.CONFIG_PARAM_MAP),!0);!Xo.isEmpty(l)&&!Xo.isEmptyOrZeroLength(Object.keys(l))&&xC.updateConfigValue(void 0,void 0,l,!0,!0)}let r,n=Jd?.service==="clustering";Jd?.service&&!n&&(console.error("Unrecognized service argument"),process.exit(1));let s=Qo.join(Ae.get(Gt.CONFIG_PARAMS.ROOTPATH),Gt.HDB_PID_FILE),i=mSe(s);i&&i!==1&&ESe(i)&&(n?r=!0:(console.error(`Error: HarperDB is already running (pid: ${i})`),process.exit(4))),Ji===void 0&&(Ji=Pd()),n&&(r||(console.error("HarperDB must be running to start clustering."),process.exit()),Ae.get(Gt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY)||(console.error("Clustering must be setup and enabled in harperdb-config."),process.exit()),console.log("Starting clustering."),await VW.generateNatsConfig(),await Ji.startClusteringProcesses(!0),process.exit()),dSe(),await Jo.writeFile(Qo.join(Ae.get(xT.CONFIG_PARAMS.ROOTPATH),xT.HDB_PID_FILE),`${process.pid}`),ls.info("HarperDB PID",process.pid);let o;try{let l=await sSe.getVersionUpdateInfo();l!==void 0&&(o=l[Gt.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION],await Xge.upgrade(l),console.log(oSe))}catch(l){o?(console.error(`Got an error while trying to upgrade your HarperDB instance to version ${o}. Exiting HarperDB.`,l),ls.error(l)):(console.error(aSe,l),ls.error(l)),process.exit(1)}zge(),pSe(),await rSe.reviewSelfSignedCert(),Xo.autoCastBoolean(Ae.get(Gt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&iSe&&await VW.generateNatsConfig(t)}a(WW,"initialize");async function fSe(e=!1){try{Jd=tSe(process.argv),Jd.ROOTPATH&&xC.updateConfigObject("settings_path",Qo.join(Jd.ROOTPATH,Gt.HDB_CONFIG_FILE)),await WW(e,!0),Ae.get(Gt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await eSe();let t=process.env.IS_SCRIPTED_SERVICE&&!Jd.service;Xo.autoCastBoolean(Ae.get(Gt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&(t||await Ji.startClusteringProcesses(),await Ji.startClusteringThreads()),await nSe(process.env.DEV_MODE?1:Ae.get(xT.CONFIG_PARAMS.THREADS_COUNT)??Ae.get(xT.CONFIG_PARAMS.THREADS)),Ae.get(Gt.CONFIG_PARAMS.LOGGING_ROTATION_ENABLED)&&await Zge(),t||zW()}catch(t){console.error(t),ls.error(t),process.exit(1)}}a(fSe,"main");function zW(){ls.suppressLogging(()=>{console.log(UC.magenta(`HarperDB ${Jge.version} successfully started`))}),ls.notify(uSe)}a(zW,"started");async function _Se(e=!0){YW=!e;try{Ji===void 0&&(Ji=Pd()),Ji.enterPM2Mode(),await WW(),Xo.autoCastBoolean(Ae.get(Gt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&await Ji.startClusteringProcesses(),await Ji.startService(Gt.PROCESS_DESCRIPTORS.HDB),zW(),e&&process.exit(0)}catch(t){console.error(t),ls.error(t),process.exit(1)}}a(_Se,"launch");function pSe(){let e=Qo.join(Ae.get(Gt.CONFIG_PARAMS.ROOTPATH),Gt.LICENSE_KEY_DIR_NAME,Gt.LICENSE_FILE_NAME),t=Qo.join(e,Gt.LICENSE_FILE_NAME),r=Qo.join(e,Gt.REG_KEY_FILE_NAME);try{let{HARPERDB_FINGERPRINT:n,HARPERDB_LICENSE:s}=KW(["HARPERDB_FINGERPRINT","HARPERDB_LICENSE"]);if(Xo.isEmpty(n)||Xo.isEmpty(s))return;Jo.mkdirpSync(e),Jo.writeFileSync(r,n),Jo.writeFileSync(t,s)}catch(n){let s=`Failed to write license & fingerprint due to: ${n.message}`;console.error(s),ls.error(s)}}a(pSe,"writeLicenseFromVars");Object.assign(JW,{launch:_Se,main:fSe,isHdbInstalled:jW,startupLog:hSe});async function jW(){try{await Jo.stat(Xo.getPropsFilePath()),await Jo.stat(Ae.get(Gt.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}catch(e){if(Xo.noBootFile())return!0;if(e.code==="ENOENT")return!1;throw ls.error(`Error checking for HDB install - ${e}`),e}return!0}a(jW,"isHdbInstalled");function hSe(e){let r=a(_=>_.padEnd(20),"pad"),n=`
113
- `;Ae.get(Ce.REPLICATION_HOSTNAME)&&(n+=`${r("Hostname:")}${Ae.get(Ce.REPLICATION_HOSTNAME)}
114
- `),Ae.get(Ce.REPLICATION_URL)&&(n+=`${r("Replication Url:")}${Ae.get(Ce.REPLICATION_URL)}
115
- `),n+=`${r("Worker Threads:")}${Ae.get(Ce.THREADS_COUNT)}
116
- `,n+=`${r("Root Path:")}${Ae.get(Ce.ROOTPATH)}
117
- `,Ae.get(Ce.THREADS_DEBUG)!==!1&&(n+=`${r("Debugging:")}enabled: true`,n+=Ae.get(Ce.THREADS_DEBUG_PORT)?`, TCP: ${Ae.get(Ce.THREADS_DEBUG_PORT)}
110
+ Reindexing upgrade started for transaction logs`),Ko.notify("Reindexing upgrade started for transaction logs"),await $Y(lC,!0,e)),Ko.notify("Reindexing upgrade complete"),"Reindexing for 4.0.0 upgrade complete"+(_h?", but errors occurred":"")}a(Bme,"reindexUpgrade");async function $Y(e,t,r){let n=await zi.readdir(e),s=n.length;for(let i=0;i<s;i++){let o=n[i],c=Yo.join(e,o.toString());if(o===".DS_Store")continue;let l=await zi.readdir(c),u=l.length;for(let f=0;f<u;f++){let d=l[f];if(d!==".DS_Store"&&zi.statSync(Yo.join(c,d)).isDirectory())try{await Hme(o,d,t),on.info(`Reindexing started for ${o}.${d}`),Ko.notify(`${t?"Transaction":"Schema"} reindexing started for ${o}.${d}`),await Fme(o,d,c,t,r),on.info(`Reindexing completed for ${o}.${d}`),Ko.notify(`Reindexing completed for ${o}.${d}`)}catch(p){_h=!0,p.schema_path=c,p.table_name=d,Ko.error("There was an error with the reindex upgrade, check the logs in hdb/3_0_0_upgrade_tmp for more details"),Ko.error(p),on.error(p),console.error(p)}}}if(!_h)try{await zi.rm(yT,{recursive:!0})}catch{}}a($Y,"processTables");async function Hme(e,t,r){let s=`${e}_${t}_${r?"transaction_reindex":"schema_reindex"}.log`,i=Yo.join(yT,s);await zi.ensureDir(yT),await zi.writeFile(i,""),on=Ume({level:"debug",formatters:{bindings(){}}},i)}a(Hme,"initPinoLogger");var kme=20;async function Fme(e,t,r,n,s){let i;try{i=await as.openEnvironment(r,t,n)}catch(E){if(E.message==="MDB_INVALID: File is not an LMDB file"){Ko.notify(`${e}.${t} file is not from the old environment and has been skipped`),console.info(`${e}.${t} file is not from the old environment and has been skipped`),on.error(E);return}throw E}let o=$me(i.dbis),c=as.openDBI(i,o),l=Object.keys(i.dbis),u=as.statDBI(i,o);on.info(`Old environment stats: ${JSON.stringify(u)}`);let f=new vme.SingleBar({format:`${e}.${t} |{bar}| {percentage}% || {value}/{total} records`,barCompleteChar:"\u2588",barIncompleteChar:"\u2591",hideCursor:!0,clearOnComplete:!1});f.start(u.entryCount,0,{});let d=await as.createEnvironment(r,t,!1);as.createDBI(d,o,!1,!0);let p=[];try{for(let E of c.getRange({start:!1}))E.value={...E.value},p.push(E),n||e==="system"&&(t==="hdb_schema"&&(E.key=E.key.toString(),E.value.name=E.value.name.toString()),t==="hdb_table"&&(E.key=E.key.toString(),E.value.schema=E.value.schema.toString(),E.value.name=E.value.name.toString()),t==="hdb_attribute"&&(E.key=E.key.toString(),E.value.schema=E.value.schema.toString(),E.value.table=E.value.table.toString(),E.value.attribute=E.value.attribute.toString())),p.length>kme&&await _();await _()}catch(E){throw _h=!0,on.error(E),E}async function _(){let E,A=p.map(({value:v})=>v);n?E=await Promise.all(A.map(v=>Gme(d,v))):E=await Pme(d,o,l.filter(v=>v!=="__blob__"),A,!1);for(let v=0,F=p.length;v<F;v++){let{key:$,value:Y}=p[v];on.info(`Record hash value: ${$} hash: ${o}`);let ee;n?ee=E[v]:ee=E.written_hashes.indexOf($)>-1,fh(ee,!0),qme(d,o,Y[o],n),on.info(`Insert success, written hashes: ${E.written_hashes}`),f.increment()}p=[],f.value/f.total*100%10===0&&Ko.notify(`${e}.${t} ${f.value}/${f.total} records inserted`),on.info(`${f.value}/${f.total} records inserted`)}a(_,"finishOutstanding"),f.stop();let h=as.statDBI(i,o),S=as.statDBI(d,o);if(on.info(`Old stats entry count: ${h.entryCount}. New stats entry count: ${S.entryCount}`),fh.deepStrictEqual(h.entryCount,S.entryCount),await as.closeEnvironment(i),await as.closeEnvironment(d),delete global.lmdb_map[`${e}.${t}`],s){let E=Yo.join(r,t),A=Yo.join(E,"data.mdb"),N=Yo.join(E,"lock.mdb");await zi.unlink(A),await zi.unlink(N),await zi.rmdir(E),on.info(`Deleted old environment files from schema folder: ${A}, ${N}`)}let g=await as.openEnvironment(r,t),R=as.statDBI(g,o);on.info(`New stats: ${JSON.stringify(S)}. New stats after move: ${JSON.stringify(R)}`),fh.deepStrictEqual(R.entryCount,S.entryCount),await as.closeEnvironment(g),delete global.lmdb_map[`${e}.${t}`]}a(Fme,"processTable");async function Gme(e,t){as.initializeDBIs(e,nc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,nc.TRANSACTIONS_DBIS);let r=t.timestamp;return e.dbis[nc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(r,()=>{e.dbis[nc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(r,t),Mme.isEmpty(t.user_name)||e.dbis[nc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(t.user_name,r);for(let n of t.hash_values)e.dbis[nc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(n,r)})}a(Gme,"insertTransaction");function qme(e,t,r,n){let i=e.dbis[t].get(r);fh.deepStrictEqual(typeof i,"object");let o;if(n){let c={[nc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME]:i.user_name,[nc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE]:i.hash_values};o=Object.entries(c)}else o=Object.entries(i);for(let[c,l]of o)if(c!==t&&e.dbis[c]!==void 0&&!Lme.isEmptyOrZeroLength(l))if(n&&c==="hash_value")for(let u=0,f=l.length;u<f;u++){let d=l[u];VY(e,c,d,r)}else VY(e,c,l,r)}a(qme,"validateIndices");function VY(e,t,r,n){try{let s=!1,i=Dme.getIndexedValues(r);if(!i)return;for(let o of i)s=e.dbis[t].doesExist(o,n),s||on.info(`Validate indices did not find value in new DBI: ${o}. Hash: ${n}`),fh.deepStrictEqual(s,!0)}catch(s){_h=!0,on.error(s),console.error(s)}}a(VY,"validateIndex");function $me(e){let t;for(let[r,n]of Object.entries(e))if(n.__dbi_defintion__.is_hash_attribute===!0){t=r;break}return t}a($me,"getHashDBI")});var QY=I((hUe,JY)=>{"use strict";var bT=require("path"),sc=require("fs-extra"),Vme=aC(),Vl=W(),WY=Rt(),uC=ce(),gi=(H(),P(G)),OT=ae(),Kme=require("properties-reader"),Yme=si(),Wme=sg(),zme=Wr(),pUe=require("util"),jme=zme.searchByValue,Jme=bn(),Qme=fS(),Xme=St(),Zme=YY(),zY=es(),eEe=TT(),mh=new Vme("4.0.0"),jY=[],ph,hh;async function tEe(){try{if(await eEe.upgradeCertsPrompt()){if(console.log("Generating new certificates."),ph){let t=OT.changeExtension(ph,".bak");await sc.move(ph,t)}if(hh){let t=OT.changeExtension(hh,".bak");await sc.move(hh,t)}await zY.generateKeys()}else console.log("Using existing certificates."),zY.updateConfigCert(ph,hh,void 0)}catch(e){throw console.error("There was a problem generating new keys. Please check the log for details."),e}}a(tEe,"generateNewKeys");async function rEe(){console.log("Updating HarperDB nodes."),Vl.info("Updating HarperDB nodes.");let e=[];try{let t=new Yme(gi.SYSTEM_SCHEMA_NAME,gi.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*","name",["*"]),r=Array.from(await jme(t)),n=[];for(let i=0,o=r.length;i<o;i++){let c=r[i];if(!Xme.NATS_TERM_CONSTRAINTS_RX.test(c.name)){let f=`Node name '${c.name}' is invalid, must not contain ., * or >. Please change name and try again.`;throw console.error(f),f}let l={host:c.host,port:c.port};e.push(l);let u=[];for(let f=0,d=c.subscriptions.length;f<d;f++){let p=c.subscriptions[f],_=p.channel.split(":");u.push({schema:_[0],table:_[1],publish:p.publish,subscribe:p.subscribe})}n.push({name:c.name,subscriptions:u,system_info:{hdb_version:gi.PRE_4_0_0_VERSION,node_version:void 0,platform:void 0}})}if(OT.isEmptyOrZeroLength(n))return;let s=new Wme(gi.SYSTEM_SCHEMA_NAME,gi.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,n);await Jme.update(s)}catch(t){throw console.error("There was a problem updating the hdb_nodes table. Please check the log for details."),t}try{Qme.setRoutes({server:"hub",routes:e})}catch(t){throw console.error("There was a problem setting the clustering routes. Please check the log for details."),t}}a(rEe,"updateNodes");async function nEe(){let e=uC.get(gi.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);if(!e.includes(bT.join("config","settings.js"))){Vl.info("pre 4.0.0 settings.js file not found, skipping settings file update");return}let t="Updating settings file for version 4.0.0";console.log(t),Vl.info(t);let r=bT.dirname(e),n=uC.get(gi.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),s=bT.join(n,"backup","4_0_0_upgrade_settings.bak"),i=bT.join(n,gi.HDB_CONFIG_FILE);try{Vl.info(`Backing up old settings file to: ${s}`),console.log(`Backing up old settings file to: ${s}`),sc.copySync(e,s)}catch(d){throw console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),d}try{Vl.info(`Creating new/upgraded settings file at '${i}'`),console.log(`Creating new/upgraded settings file at '${i}'`),Vl.info("Updating env variables with new settings values");let d=WY.initOldConfig(e);ph=d[gi.CONFIG_PARAMS.TLS_CERTIFICATE.toLowerCase()],hh=d[gi.CONFIG_PARAMS.TLS_PRIVATEKEY.toLowerCase()],WY.createConfigFile(d)}catch(d){throw console.log("There was a problem creating the new HarperDB config file. Please check the log for details."),d}let o=OT.getPropsFilePath();sc.accessSync(o,sc.constants.F_OK|sc.constants.R_OK);let l=Kme(o).get(gi.HDB_SETTINGS_NAMES.INSTALL_USER),u=`settings_path = ${i}
111
+ install_user = ${l}`;try{sc.writeFileSync(o,u)}catch(d){throw console.log("There was a problem updating the HarperDB boot properties file. Please check the log for details."),d}try{uC.initSync(!0)}catch(d){throw console.error("Unable to initialize new properties. Please check the log for details."),d}let f="New settings file for 4.0.0 upgrade successfully created.";try{sc.removeSync(r),console.log(f),Vl.info(f)}catch(d){throw console.error("There was a problem deleting the old settings file and directory. Please check the log for details."),d}}a(nEe,"updateSettingsFile_4_0_0");mh.async_functions.push(nEe);mh.async_functions.push(tEe);mh.async_functions.push(Zme);mh.async_functions.push(rEe);jY.push(mh);JY.exports=jY});var dC=I((EUe,tW)=>{"use strict";var Kl=ae(),sEe=(H(),P(G)),XY=W(),{DATA_VERSION:iEe,UPGRADE_VERSION:oEe}=sEe.UPGRADE_JSON_FIELD_NAMES_ENUM,ZY=GY(),NT=QY(),Yl=new Map;ZY&&ZY.forEach(e=>{Yl.set(e.version,e)});NT&&NT.forEach(e=>{Yl.set(e.version,e)});NT&&NT.forEach(e=>{Yl.set(e.version,e)});function aEe(){return[...Yl.keys()].sort(Kl.compareVersions)}a(aEe,"getSortedVersions");function eW(e){let t=e[iEe],r=e[oEe];return Kl.isEmptyOrZeroLength(t)||Kl.isEmptyOrZeroLength(r)?(XY.info(`There is an issue with the version data in your instance of HDB. Current version data: ${e}`),XY.error("There was an error when trying to evaluate the version information for your instance. Trying to start the server anyways but it may fail. If you continue to have this problem, please contact support@harperdb.io."),[]):[...Yl.keys()].sort(Kl.compareVersions).filter(function(n){return Kl.compareVersions(n,t)>0&&Kl.compareVersions(n,r)<=0})}a(eW,"getVersionsForUpgrade");function cEe(e){return eW(e).length>0}a(cEe,"hasUpgradesRequired");function lEe(e){return Kl.isEmptyOrZeroLength(e)?null:Yl.has(e)?Yl.get(e):null}a(lEe,"getDirectiveByVersion");tW.exports={getSortedVersions:aEe,getDirectiveByVersion:lEe,getVersionsForUpgrade:eW,hasUpgradesRequired:cEe}});var Eh=I((SUe,oW)=>{"use strict";var uEe=require("util"),fC=require("chalk"),dEe=require("os"),nW=bn(),fEe=Wr(),cs=(H(),P(G)),sW=CY(),pC=xy(),{UpgradeObject:rW}=LY(),{forceDowngradePrompt:_Ee}=TT(),{packageJson:pEe}=st(),wT=W(),zd=ae(),hC=Rs(),hEe=(De(),P(nt)),mEe=dC(),EEe=uEe.promisify(hC.setSchemaDataToGlobal),gEe=fEe.searchByValue,SEe="info_id",TEe="2.9.9",AEe="3.0.0";async function REe(e){let t=new sW.HdbInfoInsertObject(1,e,e),r=new pC.InsertObject(cs.OPERATIONS_ENUM.INSERT,cs.SYSTEM_SCHEMA_NAME,cs.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,cs.INFO_TABLE_HASH_ATTRIBUTE,[t]);return hC.setSchemaDataToGlobal(),nW.insert(r)}a(REe,"insertHdbInstallInfo");async function _C(e){let t,r=await iW(),n=new Map([[0,{}]]);for(let c of r)n.set(c.info_id,c);let i=Math.max.apply(null,[...n.keys()])+1;t=new sW.HdbInfoInsertObject(i,e,e);let o=new pC.InsertObject(cs.OPERATIONS_ENUM.INSERT,cs.SYSTEM_SCHEMA_NAME,cs.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,cs.INFO_TABLE_HASH_ATTRIBUTE,[t]);return await EEe(),nW.insert(o)}a(_C,"insertHdbUpgradeInfo");async function iW(){let e=new pC.NoSQLSeachObject(cs.SYSTEM_SCHEMA_NAME,cs.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,SEe,cs.INFO_TABLE_HASH_ATTRIBUTE,["*"],"*"),t=[];try{t=Array.from(await gEe(e))}catch(r){console.error(r)}return t}a(iW,"getAllHdbInfoRecords");async function yEe(){let e=await iW();if(e.length===0)return;let t,r=new Map;for(let s of e)r.set(s.info_id,s);let n=Math.max.apply(null,[...r.keys()]);return t=r.get(n),t}a(yEe,"getLatestHdbInfoRecord");async function bEe(){wT.info("Checking if HDB software has been updated");try{let e=pEe.version;if(!e)throw new Error("Could not find the version number in the package.json file");let t=await yEe(),r;if(zd.isEmpty(t))r=TEe;else if(r=t.data_version_num,zd.compareVersions(r.toString(),e.toString())>0){if(!zd.isCompatibleDataVersion(r.toString(),e.toString()))throw console.log(fC.yellow(`This instance's data was last run on version ${r}`)),console.error(fC.red(`You have installed a version lower than the version that your data was created on or was upgraded to. This may cause issues and is currently not supported.${dEe.EOL}${cs.SUPPORT_HELP_MSG}`)),new Error("Trying to downgrade major HDB versions is not supported.");zd.isCompatibleDataVersion(r.toString(),e.toString(),!0)||(console.log(fC.yellow(`This instance's data was last run on version ${r}`)),await _Ee(new rW(r,e))?await _C(e.toString()):(console.log("Cancelled downgrade, closing HarperDB"),process.exit(0)))}if(hC.setSchemaDataToGlobal(),OEe(r),e.toString()===r.toString())return;let n=new rW(r,e);if(mEe.hasUpgradesRequired(n))return n;zd.compareVersions(n.data_version.toString(),n.upgrade_version.toString())<0&&(await _C(n.upgrade_version),wT.notify(`HarperDB running on upgraded version: ${n.upgrade_version}`))}catch(e){throw wT.fatal("Error while trying to evaluate the state of hdb data and the installed hdb version"),wT.fatal(e),e}}a(bEe,"getVersionUpdateInfo");function OEe(e){let t=`You are attempting to upgrade from an old instance of HarperDB that is no longer supported. In order to upgrade to this version, you must do a fresh install. If you need support, please contact ${cs.HDB_SUPPORT_ADDRESS}`;if(!("hdb_info"in hEe.databases.system))throw console.log(t),new Error(t);if(!zd.isEmpty(e)&&e<AEe)throw console.log(t),new Error(t)}a(OEe,"checkIfInstallIsSupported");oW.exports={insertHdbInstallInfo:REe,insertHdbUpgradeInfo:_C,getVersionUpdateInfo:bEe}});var uW=I((AUe,lW)=>{"use strict";var IT=require("joi"),{boolean:NEe,string:mC,number:wEe}=IT.types(),aW=require("fs-extra"),gh=(H(),P(G)),cW=require("path"),IEe=it();lW.exports=CEe;function CEe(e){let t=mC.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),r=IT.object({[gh.INSTALL_PROMPTS.ROOTPATH]:IT.custom(PEe),[gh.INSTALL_PROMPTS.OPERATIONSAPI_NETWORK_PORT]:IT.alternatives([wEe.min(0),mC]).allow("null",null),[gh.INSTALL_PROMPTS.TC_AGREEMENT]:mC.valid("yes","YES","Yes"),[gh.INSTALL_PROMPTS.CLUSTERING_NODENAME]:t,[gh.INSTALL_PROMPTS.CLUSTERING_ENABLED]:NEe});return IEe.validateBySchema(e,r)}a(CEe,"installValidator");function PEe(e,t){if(aW.existsSync(cW.join(e,"system/hdb_user/data.mdb"))||aW.existsSync(cW.join(e,"system/hdb_user.mdb")))return t.message(`'${e}' is already in use. Please enter a different path.`)}a(PEe,"validateRootAvailable")});var SC=I((yUe,dW)=>{"use strict";var{mkdirpSync:DEe,copySync:LEe}=require("fs-extra"),ic=require("path"),Sh=(H(),P(G)),{PACKAGE_ROOT:MEe}=st(),gC=W(),vEe=Kn(),EC=ho(),UEe=Et();dW.exports=xEe;async function xEe(e){gC.trace("Mounting HarperDB"),Wl(e),Wl(ic.join(e,"backup")),Wl(ic.join(e,"keys")),Wl(ic.join(e,"keys",Sh.LICENSE_FILE_NAME)),Wl(ic.join(e,"log")),Wl(ic.join(e,"database")),Wl(ic.join(e,"components")),LEe(ic.resolve(MEe,"./utility/install/README.md"),ic.join(e,"README.md")),await BEe()}a(xEe,"mountHdb");async function BEe(){let e=U_(),t=Object.keys(EC);for(let r=0;r<t.length;r++){let n=t[r],s=EC[n].hash_attribute;try{UEe.initSystemSchemaPaths(Sh.SYSTEM_SCHEMA_NAME,n);let i=new e(Sh.SYSTEM_SCHEMA_NAME,n,s);i.attributes=EC[n].attributes;let o=i.attributes.find(({attribute:c})=>c===s);o.isPrimaryKey=!0,["hdb_user","hdb_role"].includes(n)&&(i.audit=!0),await vEe.createTable(n,i)}catch(i){throw gC.error(`issue creating environment for ${Sh.SYSTEM_SCHEMA_NAME}.${n}: ${i}`),i}}}a(BEe,"createLMDBTables");function Wl(e){DEe(e,{mode:Sh.HDB_FILE_PERMISSIONS}),gC.info(`Directory ${e} created`)}a(Wl,"makeDirectory")});var DT=I((wUe,bW)=>{"use strict";var AC=require("os"),mW=require("inquirer"),Bs=require("fs-extra"),HEe=require("properties-reader"),jl=require("chalk"),Ji=require("path"),kEe=require("human-readable-ids").hri,FEe=require("ora"),GEe=require("yaml"),pr=W(),oc=ce(),Th=ae(),PT=da(),EW=Eh(),{packageJson:gW}=st(),_e=(H(),P(G)),{CONFIG_PARAM_MAP:OUe,CONFIG_PARAMS:Pt}=_e,qEe=uW(),$Ee=SC(),RC=Rt(),VEe=yn(),KEe=G_(),YEe=tC(),WEe=Rs(),zEe=require("util").promisify,jEe=zEe(WEe.setSchemaDataToGlobal),fW=es(),zl=a(e=>e,"PROMPT_ANSWER_TRANSFORMER"),kr=a(e=>jl.magenta.bold(e),"HDB_PROMPT_MSG"),JEe="https://harperdb.io/legal/end-user-license-agreement",ac=AC.EOL,Wo="",QEe="yes",_W="Starting HarperDB install...",pW="HarperDB installation was successful.",hW="Terms & Conditions acceptance is required to proceed with installation. Exiting install...",XEe="An out of date version of HarperDB is already installed.",TC="It appears that HarperDB is already installed. Exiting install...",ZEe="Aborting install",NUe=new RegExp(/^([0-9]{1,4}|[1-5][0-9]{4}|6[0-4][0-9]{3}|65[0-4][0-9]{2}|655[0-2][0-9]|6553[0-5])$/),ege=new RegExp(/^[^\s.,*>]+$/),tge=AC.homedir(),rge=Ji.join(tge,_e.HDB_ROOT_DIR_NAME),nge="HDB_ADMIN",sge="CLUSTER_USER",ige="dev",oge="localhost",CT={[Pt.HTTP_CORS]:!0,[Pt.HTTP_CORSACCESSLIST]:["*"],[Pt.HTTP_PORT]:9926,[Pt.AUTHENTICATION_AUTHORIZELOCAL]:!0,[Pt.THREADS_COUNT]:1,[Pt.THREADS_DEBUG]:!0,[Pt.LOGGING_STDSTREAMS]:!0,[Pt.LOGGING_LEVEL]:"info",[Pt.OPERATIONSAPI_NETWORK_PORT]:9925,[Pt.LOCALSTUDIO_ENABLED]:!0},Hr={DESTINATION:"Please enter a destination for HarperDB:",HDB_USERNAME:"Please enter a username for the administrative user:",HDB_PASS:"Please enter a password for the administrative user:",NODE_NAME:"Please enter a unique name for this node:",CLUSTER_USERNAME:"Please enter a username for the CLUSTER_USER:",CLUSTER_PASS:"Please enter a password for the CLUSTER_USER:",DEFAULTS_MODE:"Default Config - dev (easy access/debugging) or prod (security/performance): (dev/prod)",REPLICATION_HOSTNAME:"Please enter the hostname for this server:"},cc=PT([_e.INSTALL_PROMPTS.HDB_CONFIG]),ji,SW=!1,yC=!1,TW=!1;bW.exports={install:AW,updateConfigEnv:Ege,setIgnoreExisting:gge};AW.createSuperUser=yW;async function AW(){console.log(kr(ac+_W+ac)),pr.notify(_W);let e;cc[_e.INSTALL_PROMPTS.HDB_CONFIG]&&(e=age());let t=lge();Object.assign(t,e),t[_e.INSTALL_PROMPTS.TC_AGREEMENT]&&t[_e.INSTALL_PROMPTS.ROOTPATH]&&t[_e.INSTALL_PROMPTS.HDB_ADMIN_USERNAME]&&t[_e.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]&&t[_e.INSTALL_PROMPTS.DEFAULTS_MODE]===void 0&&(TW=!0,t[_e.INSTALL_PROMPTS.DEFAULTS_MODE]="prod");let r=qEe(t);if(r)throw r.message;await uge(),await dge(t);let n=await cge(t);ji=n[_e.INSTALL_PROMPTS.ROOTPATH],cc[_e.INSTALL_PROMPTS.HDB_CONFIG]&&Ji.dirname(cc[_e.INSTALL_PROMPTS.HDB_CONFIG])===ji&&(SW=!0),!yC&&!cc[_e.INSTALL_PROMPTS.HDB_CONFIG]&&await Bs.pathExists(Ji.join(ji,_e.HDB_CONFIG_FILE))&&(console.error(TC),process.exit());let s=FEe({prefixText:kr("Installing"),color:"magenta",spinner:"simpleDots"});if(s.start(),Th.isEmpty(ji))throw new Error("Installer should have the HDB root param at the stage it is in but it does not.");oc.setHdbBasePath(ji),await $Ee(ji),await fge(),await _ge(n),pr.initLogSettings(!0),await yW(n),await hge(n),await fW.updateConfigCert(),await fW.generateCertsKeys(),await mge(),YEe(),s.stop(),console.log(kr(ac+pW+ac)),pr.notify(pW)}a(AW,"install");function age(){let e=GEe.parseDocument(Bs.readFileSync(cc[_e.INSTALL_PROMPTS.HDB_CONFIG],"utf8"),{simpleKeys:!0}),t=RC.flattenConfig(e.toJSON());return t[_e.CONFIG_PARAMS.ROOTPATH.toLowerCase()]&&(t.ROOTPATH=t[_e.CONFIG_PARAMS.ROOTPATH.toLowerCase()]),t}a(age,"getConfigFromFile");async function cge(e){pr.trace("Getting install prompts and params.");let t,r=[{type:"input",transformer:zl,when:zo(e[_e.INSTALL_PROMPTS.ROOTPATH],Hr.DESTINATION),name:_e.INSTALL_PROMPTS.ROOTPATH,prefix:Wo,default:rge,validate:a(async s=>xs(s)?xs(s):await Bs.pathExists(Ji.join(s,"system","hdb_user.mdb"))?`'${s}' is already in use. Please enter a different path.`:!0,"validate"),message:kr(Hr.DESTINATION)},{type:"input",transformer:zl,when:zo(e[_e.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],Hr.HDB_USERNAME),name:_e.INSTALL_PROMPTS.HDB_ADMIN_USERNAME,prefix:Wo,default:nge,validate:a(s=>xs(s)?xs(s):(t=s,!0),"validate"),message:kr(Hr.HDB_USERNAME)},{type:"password",when:zo(e[_e.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD],Hr.HDB_PASS),name:_e.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD,prefix:Wo,validate:a(s=>xs(s)?xs(s):!0,"validate"),message:kr(Hr.HDB_PASS)},{type:"input",transformer:zl,when:zo(e[_e.INSTALL_PROMPTS.DEFAULTS_MODE],Hr.DEFAULTS_MODE),name:_e.INSTALL_PROMPTS.DEFAULTS_MODE,prefix:Wo,default:ige,validate:a(s=>xs(s)?xs(s):s!=="dev"&&s!=="prod"?`Invalid response '${s}', options are 'dev' or 'prod'.`:!0,"validate"),message:kr(Hr.DEFAULTS_MODE)}];if(TW||r.push({type:"input",name:_e.INSTALL_PROMPTS.REPLICATION_HOSTNAME,transformer:zl,when:zo(e[_e.INSTALL_PROMPTS.REPLICATION_HOSTNAME],Hr.REPLICATION_HOSTNAME),prefix:Wo,default:oge,message:kr(Hr.REPLICATION_HOSTNAME)}),Th.autoCastBoolean(e[_e.INSTALL_PROMPTS.CLUSTERING_ENABLED])===!0){let s=[{type:"input",transformer:zl,when:zo(e[_e.INSTALL_PROMPTS.CLUSTERING_NODENAME],Hr.NODE_NAME),name:_e.INSTALL_PROMPTS.CLUSTERING_NODENAME,prefix:Wo,default:kEe.random(),validate:a(i=>ege.test(i)?!0:"Invalid node name, must not contain ., * or >","validate"),message:kr(Hr.NODE_NAME)},{type:"input",transformer:zl,when:zo(e[_e.INSTALL_PROMPTS.CLUSTERING_USER],Hr.CLUSTER_USERNAME),name:_e.INSTALL_PROMPTS.CLUSTERING_USER,prefix:Wo,default:sge,validate:a(i=>xs(i)?xs(i):i.toLowerCase()===t.toLowerCase()?"Username is already in use.":!0,"validate"),message:kr(Hr.CLUSTER_USERNAME)},{type:"password",when:zo(e[_e.INSTALL_PROMPTS.CLUSTERING_PASSWORD],Hr.CLUSTER_PASS),name:_e.INSTALL_PROMPTS.CLUSTERING_PASSWORD,prefix:Wo,validate:a(i=>xs(i)?xs(i):!0,"validate"),message:kr(Hr.CLUSTER_PASS)}];r.push(...s)}let n=await mW.prompt(r);if(Object.keys(n).length===0)return e;for(let s in n)e[s]===void 0&&(e[s]=n[s]);return e}a(cge,"installPrompts");function zo(e,t){return e!==void 0?(t.includes("password")?(console.log(`${kr(t)} ${jl.gray("[hidden]")}`),pr.trace(`${kr(t)} [hidden]`)):(console.log(`${kr(t)} ${e}`),pr.trace(`${kr(t)} ${e}`)),!1):!0}a(zo,"displayCmdEnvVar");function xs(e){let t=e.replace(/ /g,"");if(t===""||t==="''"||t==='""')return"Value cannot be empty."}a(xs,"checkForEmptyValue");function lge(){let e=Object.keys(_e.INSTALL_PROMPTS),t=PT(e),r=PT(Object.keys(_e.CONFIG_PARAM_MAP),!0),n={};for(let s of e){let i=_e.CONFIG_PARAM_MAP[s.toLowerCase()];t[s]?i===void 0?n[s]=t[s]:n[i.toUpperCase()]=t[s]:i!==void 0&&r[i.toLowerCase()]&&(n[s]=r[i.toLowerCase()])}return n}a(lge,"checkForPromptOverride");async function uge(){pr.trace("Checking for existing install.");let e=Th.getPropsFilePath(),t=await Bs.pathExists(e),r;if(t){pr.trace(`Install found an existing boot prop file at:${e}`);let n=HEe(e),s=RC.getConfigValue(_e.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)||n.get(_e.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY);r=await Bs.pathExists(s)}if(!t&&Th.noBootFile()&&(r=!0),r&&!yC){if(pr.trace(`Install found existing HDB config at:${e}`),await EW.getVersionUpdateInfo()){let s=`Please use \`harperdb upgrade\` to update to ${gW.version}. Exiting install...`;console.log(ac+jl.magenta.bold(XEe)),console.log(jl.magenta.bold(s)),pr.error(s)}else console.log(ac+jl.magenta.bold(TC)),pr.error(TC);process.exit(0)}}a(uge,"checkForExistingInstall");async function dge(e){pr.info("Asking for terms agreement.");let t=`Terms & Conditions can be found at ${JEe}${ac}and can be viewed by typing or copying and pasting the URL into your web browser.${ac}I agree to the HarperDB Terms and Conditions: (yes/no)`,r={prefix:Wo,transformer:zl,when:zo(e[_e.INSTALL_PROMPTS.TC_AGREEMENT],t),name:_e.INSTALL_PROMPTS.TC_AGREEMENT,message:kr(t),validate:a(s=>s.toLowerCase()==="yes"||s.toLowerCase()==="no"?!0:jl.yellow("Please enter 'yes' or 'no'"),"validate")},n=await mW.prompt([r]);n[_e.INSTALL_PROMPTS.TC_AGREEMENT]&&n[_e.INSTALL_PROMPTS.TC_AGREEMENT].toLowerCase()!==QEe&&(console.log(jl.yellow(hW)),pr.error(hW),process.exit(0))}a(dge,"termsAgreement");async function fge(){let e=Ji.join(ji,_e.HDB_CONFIG_FILE),t;try{t=AC.userInfo().username}catch{t=process.env.USERNAME||process.env.USER||process.env.LOGNAME||process.env.LNAME||process.env.SUDO_USER}if(t){let r=`settings_path = ${e}
112
+ install_user = ${t}`,n=Th.getHomeDir(),s=Ji.join(n,_e.HDB_HOME_DIR_NAME),i=Ji.join(s,_e.LICENSE_KEY_DIR_NAME);try{Bs.mkdirpSync(s,{mode:_e.HDB_FILE_PERMISSIONS}),Bs.mkdirpSync(i,{mode:_e.HDB_FILE_PERMISSIONS})}catch{console.error(`Could not make settings directory ${_e.HDB_HOME_DIR_NAME} in home directory. Please check your permissions and try again.`)}let o=Ji.join(s,_e.BOOT_PROPS_FILE_NAME);try{await Bs.writeFile(o,r)}catch(c){throw pr.error(`There was an error creating the boot file at path: ${o}`),c}oc.setProperty(_e.HDB_SETTINGS_NAMES.INSTALL_USER,`${t}`),oc.setProperty(_e.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,e),oc.setProperty(oc.BOOT_PROPS_FILE_PATH,o)}}a(fge,"createBootPropertiesFile");async function _ge(e){pr.trace("Creating HarperDB config file");let t=PT(Object.keys(_e.CONFIG_PARAM_MAP),!0);if(Object.assign(t,e),e[_e.INSTALL_PROMPTS.DEFAULTS_MODE]==="dev"){process.env.DEV_MODE="true";for(let r in CT){if(r===Pt.HTTP_PORT&&t[Pt.HTTP_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??CT[r],t[Pt.HTTP_SECUREPORT]=null;continue}else if(r===Pt.HTTP_PORT)continue;if(r===Pt.OPERATIONSAPI_NETWORK_PORT&&t[Pt.OPERATIONSAPI_NETWORK_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??CT[r],t[Pt.OPERATIONSAPI_NETWORK_SECUREPORT]=null;continue}else if(r===Pt.OPERATIONSAPI_NETWORK_PORT)continue;t[r.toLowerCase()]===void 0&&(t[r]=CT[r])}}else t[Pt.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]&&(t[Pt.OPERATIONSAPI_NETWORK_SECUREPORT]=null),t[Pt.HTTP_PORT.toLowerCase()]&&(t[Pt.HTTP_SECUREPORT]=null);try{cc[_e.INSTALL_PROMPTS.HDB_CONFIG]||RC.createConfigFile(t),oc.initSync()}catch(r){pge(r)}}a(_ge,"createConfigFile");function pge(e){pr.error(`Error creating HarperDB config file. Rolling back install - ${e}`),console.error(e),console.error(ZEe);let t=Ji.resolve(oc.get(oc.BOOT_PROPS_FILE_PATH),"../");t&&Bs.removeSync(t),ji&&(SW?Bs.readdirSync(ji,{withFileTypes:!0}).forEach(n=>{let s=Ji.join(n.path,n.name);s!==cc[_e.INSTALL_PROMPTS.HDB_CONFIG]&&Bs.removeSync(s)}):Bs.removeSync(ji)),process.exit(1)}a(pge,"rollbackInstall");async function RW(e,t){pr.trace("Creating admin user"),await jEe();let r;try{r=await KEe.addRole(e)}catch(n){if(n.message.includes("already exists"))t=void 0;else throw n.message+="Error creating role",n}if(t)try{t.role=r.role,await VEe.addUser(t)}catch(n){throw n.message=`Error creating user - ${n}`,n}}a(RW,"createAdminUser");async function yW(e){pr.trace("Creating Super user.");let t={role:"super_user",permission:{super_user:!0}},r={username:e[_e.INSTALL_PROMPTS.HDB_ADMIN_USERNAME].toString(),password:e[_e.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD].toString(),active:!0};await RW(t,r),delete e[_e.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],delete e[_e.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]}a(yW,"createSuperUser");async function hge(e){pr.trace("Creating Cluster user.");let t;e[_e.INSTALL_PROMPTS.CLUSTERING_USER]&&e[_e.INSTALL_PROMPTS.CLUSTERING_PASSWORD]&&(t={username:e[_e.INSTALL_PROMPTS.CLUSTERING_USER].toString(),password:e[_e.INSTALL_PROMPTS.CLUSTERING_PASSWORD].toString(),active:!0}),await RW({role:"cluster_user",permission:{cluster_user:!0}},t),delete e[_e.INSTALL_PROMPTS.CLUSTERING_USER],delete e[_e.INSTALL_PROMPTS.CLUSTERING_PASSWORD]}a(hge,"createClusterUser");async function mge(){let e=gW.version;if(e)await EW.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(mge,"insertHdbVersionInfo");function Ege(e){cc[_e.INSTALL_PROMPTS.HDB_CONFIG]=e}a(Ege,"updateConfigEnv");function gge(e){yC=e}a(gge,"setIgnoreExisting")});var wW=I((CUe,NW)=>{"use strict";var bC=ae(),ls=W(),OW=dC();NW.exports={processDirectives:Sge};async function Sge(e){console.log("Starting upgrade process...");let t=OW.getVersionsForUpgrade(e),r=Rge(t),n=[],s=r.length;for(let i=0;i<s;i++){let o=r[i],c=`Running upgrade for version ${o.version}`;ls.notify(c),console.log(c);let l=[],u=[];try{l=Tge(o.sync_functions)}catch(f){throw ls.error(`Error while running an upgrade script for ${o.version}`),f}try{u=await Age(o.async_functions)}catch(f){throw ls.error(`Error while running an upgrade script for ${o.version}`),f}n.push(...l,...u)}return n}a(Sge,"processDirectives");function Tge(e){if(bC.isEmptyOrZeroLength(e))return ls.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return ls.info("Passed parameter is not an array"),[];let t=[];for(let r of e){if(ls.info(`Running function ${r.name}`),!(r instanceof Function)){ls.info("Variable being processed is not a function");continue}let n=r();ls.info(n),t.push(n)}return t}a(Tge,"runSyncFunctions");async function Age(e){if(bC.isEmptyOrZeroLength(e))return ls.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return ls.info("Passed parameter is not an array"),[];let t=[],r=e.length;for(let n=0;n<r;n++){let s=e[n];if(ls.info(`Running function ${s.name}`),!(s instanceof Function)){ls.info("Variable being processed is not a function");continue}let i=await s();ls.info(i),t.push(i)}return t}a(Age,"runAsyncFunctions");function Rge(e){if(bC.isEmptyOrZeroLength(e))return[];let t=[];for(let r of e){let n=OW.getDirectiveByVersion(r);n&&t.push(n)}return t}a(Rge,"getUpgradeDirectivesToInstall")});var IC=I((DUe,MW)=>{"use strict";var LT=ce();LT.initSync();var DW=require("chalk"),IW=require("fs-extra"),Jo=W(),jo=(H(),P(G)),yge=wW(),OC=ae(),LW=Eh(),bge=TT(),CW=oR(),Oge=Rs(),{packageJson:PW}=st(),Nge=require("util").promisify,wge=Nge(Oge.setSchemaDataToGlobal),NC,{UPGRADE_VERSION:wC}=jo.UPGRADE_JSON_FIELD_NAMES_ENUM;MW.exports={upgrade:Ige};async function Ige(e){await wge(),NC===void 0&&(NC=Dd()),IW.existsSync(LT.get(LT.BOOT_PROPS_FILE_PATH))||(Ah("The hdb_boot_properties file was not found. Please install HDB.",jo.LOG_LEVELS.ERROR),process.exit(1)),IW.existsSync(LT.get(jo.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))||(Ah("The hdb settings file was not found. Please make sure HDB is installed.",jo.LOG_LEVELS.ERROR),process.exit(1));let t=e;t||(t=await LW.getVersionUpdateInfo(),t||(console.log("HarperDB version is current"),process.exit(0))),Ah(`This version of HarperDB is ${PW.version}`,jo.LOG_LEVELS.INFO);let r=t[wC]??PW.version;r||(console.log(`Current Version field missing from the package.json file. Cannot continue with upgrade. If you need support, please contact ${jo.HDB_SUPPORT_ADDRESS}`),Jo.notify("Missing new version field from upgrade info object"),process.exit(1)),await Cge();let n,s=0;try{n=await bge.forceUpdatePrompt(t)}catch(i){Jo.error("There was an error when prompting user about upgrade."),Jo.error(i),n=!1,s=1}n||(console.log("Cancelled upgrade, closing HarperDB"),process.exit(s)),Jo.info(`Starting upgrade to version ${r}`),await Pge(t),Ah(`HarperDB was successfully upgraded to version ${t[wC]}`,jo.LOG_LEVELS.INFO)}a(Ige,"upgrade");async function Cge(){let e=!1,t=await CW.findPs(jo.HDB_PROC_NAME);if(OC.isEmptyOrZeroLength(t)||(e=!0),!e){let r=await CW.findPs("hdb_express");OC.isEmptyOrZeroLength(r)||(e=!0)}if(!e){let r=await NC.list();OC.isEmptyOrZeroLength(r)||(e=!0)}if(e){let r="HarperDB is running, please stop all HarperDB services with 'harperdb stop' and run the upgrade command again.";console.log(DW.red(r)),Jo.error(r),process.exit(1)}}a(Cge,"checkIfRunning");async function Pge(e){try{await yge.processDirectives(e)}catch(t){throw Ah("There was an error during the data upgrade. Please check the logs.",jo.LOG_LEVELS.ERROR),t}try{await LW.insertHdbUpgradeInfo(e[wC])}catch(t){Jo.error("Error updating the 'hdb_info' system table."),Jo.error(t)}}a(Pge,"runUpgrade");function Ah(e,t=void 0){t||(t=Jo.info),Jo[t](e),console.log(DW.magenta(e))}a(Ah,"printToLogAndConsole")});var HW={};Ue(HW,{onStorageReclamation:()=>Rh,runReclamationHandlers:()=>LC,setAvailableSpaceRatioGetter:()=>Lge});function Rh(e,t,r){(r||(0,vT.getWorkerIndex)()===(0,vT.getWorkerCount)()-1)&&(MT.has(e)||MT.set(e,[]),MT.get(e).push({priority:0,handler:t}),DC||(DC=setTimeout(LC,UW).unref()))}async function LC(){for(let[e,t]of MT)try{let r=await BW(e),n=Dge/r;for(let s of t){let{priority:i,handler:o}=s;if(s.priority=n,n>1||i>1){let c=o(n>1?n:0);c&&(PC.default.info?.(`Running storage reclamation handler for ${e} with priority ${n}`),await c)}}}catch(r){PC.default.error?.("Error running storage reclamation handlers",r)}DC=setTimeout(LC,UW).unref()}function Lge(e){BW=e??xW}var CC,vT,PC,UT,vW,MT,Dge,UW,DC,xW,BW,xT=be(()=>{CC=require("node:fs/promises"),vT=M(rt()),PC=M(wi());H();UT=M(ce()),vW=M(ae());UT.default.initSync();MT=new Map,Dge=UT.default.get(x.STORAGE_RECLAMATION_THRESHOLD)??.4,UW=(0,vW.convertToMS)(UT.default.get(x.STORAGE_RECLAMATION_INTERVAL))||36e5;a(Rh,"onStorageReclamation");xW=a(async e=>{if(CC.statfs){let t=await(0,CC.statfs)(e);return t.bavail/t.blocks}else return new Promise((t,r)=>{import("hdd-space").then(n=>{n.default(s=>{for(let i of s.parts)if(e.startsWith(i.place))return t(i.free/i.size);return t(1)})})})},"defaultGetAvailableSpaceRatio"),BW=xW;a(LC,"runReclamationHandlers");a(Lge,"setAvailableSpaceRatioGetter")});var $W=I((UUe,qW)=>{"use strict";var{promises:jd,createReadStream:Mge,createWriteStream:vge}=require("fs"),{createGzip:Uge}=require("zlib"),{promisify:xge}=require("util"),{pipeline:Bge}=require("stream"),Hge=xge(Bge),vC=require("path"),uc=ce();uc.initSync();var lc=W(),{CONFIG_PARAMS:Jd,ITC_EVENT_TYPES:kge}=(H(),P(G)),{onMessageFromWorkers:Fge}=rt(),{convertToMS:Gge}=ae(),{onStorageReclamation:qge}=(xT(),P(HW)),$ge=6e4,Vge="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",Kge="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",MC,FW;qW.exports=GW;Fge(e=>{e.type===kge.RESTART&&(uc.initSync(!0),clearInterval(FW),uc.get(Jd.LOGGING_ROTATION_ENABLED)&&GW())});async function GW(){try{let e=lc.getLogFilePath(),t=uc.get(Jd.LOGGING_ROTATION_MAXSIZE),r=uc.get(Jd.LOGGING_ROTATION_INTERVAL),n=uc.get(Jd.LOGGING_ROTATION_RETENTION),s=0;if(qge(e,l=>{s=l},!0),!t&&!r){lc.error(Vge);return}let i=uc.get(Jd.LOGGING_ROTATION_PATH);if(!i){lc.error(Kge);return}let o;if(t){let l=t.slice(-1),u=t.slice(0,-1);l==="G"?o=u*1e9:l==="M"?o=u*1e6:o=u*1e3}let c;if(r){let l=r.slice(-1),u=r.slice(0,-1);l==="D"?c=u*1440:l==="H"?c=u*60:c=u}MC=Date.now()/6e4,lc.trace("Log rotate enabled, maxSize:",t,"interval:",r),FW=setInterval(async()=>{if(o){let l;l=await jd.stat(e),l.size>=o&&await kW(e,i)}if(c&&Date.now()/6e4-MC>=c&&(await kW(e,i),MC=Date.now()/6e4),n||s){let l=Gge(n??"1M")/(1+s);s=0;let u=await jd.readdir(i);for(let f of u)try{let d=await jd.stat(vC.join(i,f));Date.now()-d.mtimeMs>l&&await jd.unlink(vC.join(i,f))}catch(d){lc.error("Error trying to remove log",f,d)}}},$ge).unref()}catch(e){lc.error(e)}}a(GW,"logRotator");async function kW(e,t){let r=uc.get(Jd.LOGGING_ROTATION_COMPRESS),n=vC.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.log`);await jd.rename(e,n),r&&(e=n,n+=".gz",await Hge(Mge(e),Uge(),vge(n)),await jd.unlink(e)),lc.closeLogFile(),lc.notify(`hdb.log rotated, old log moved to ${n}`)}a(kW,"moveLogFile")});var Xd=I(JW=>{"use strict";var ge=ce();ge.initSync();ja();var Gt=(H(),P(G)),{CONFIG_PARAMS:Ce}=Gt,us=W(),Qo=require("fs-extra"),Xo=require("path"),Yge=tC(),{install:Wge}=DT(),UC=require("chalk"),{packageJson:zge,PACKAGE_ROOT:jge}=st(),Zo=ae(),xC=Rt(),KW=da(),VW=AS(),Jge=IC(),Qge=$W(),{compactOnStart:Xge}=(CS(),P(IS)),Zge=require("minimist"),eSe=es(),{startHTTPThreads:tSe}=(BC(),P(QW)),rSe=Eh(),{isMainThread:nSe}=require("worker_threads"),BUe=ho(),HUe=So(),kUe=Db(),FUe=U_(),BT=(H(),P(G)),Qi,Qd,YW=!1,sSe="Upgrade complete. Starting HarperDB.",iSe="Got an error while trying to upgrade your HarperDB instance. Exiting HarperDB.",oSe="HarperDB not found, starting install process.",aSe="There was an error during install, check install_log.log for more details. Exiting.",cSe="HarperDB successfully started.";function lSe(){if(!YW){let e=a(()=>{Qo.removeSync(Xo.join(ge.get(Gt.CONFIG_PARAMS.ROOTPATH),Gt.HDB_PID_FILE)),process.exit(0)},"remove_hdb_pid");process.on("exit",()=>{e()}),process.on("SIGINT",()=>{e()}),process.on("SIGQUIT",()=>{e()}),process.on("SIGTERM",()=>{e()})}}a(lSe,"addExitListeners");async function WW(e=!1,t=!1){if(console.log(UC.magenta("Starting HarperDB...")),us.suppressLogging?.(()=>{console.log(UC.magenta(""+Qo.readFileSync(Xo.join(jge,"utility/install/ascii_logo.txt"))))}),await jW()===!1){console.log(oSe);try{await Wge()}catch(l){console.error(aSe,l),us.error(l),process.exit(1)}}if(!e){let l=KW(Object.keys(Gt.CONFIG_PARAM_MAP),!0);!Zo.isEmpty(l)&&!Zo.isEmptyOrZeroLength(Object.keys(l))&&xC.updateConfigValue(void 0,void 0,l,!0,!0)}let r,n=Qd?.service==="clustering";Qd?.service&&!n&&(console.error("Unrecognized service argument"),process.exit(1));let s=Xo.join(ge.get(Gt.CONFIG_PARAMS.ROOTPATH),Gt.HDB_PID_FILE),i=pSe(s);i&&i!==1&&hSe(i)&&(n?r=!0:(console.error(`Error: HarperDB is already running (pid: ${i})`),process.exit(4))),Qi===void 0&&(Qi=Dd()),n&&(r||(console.error("HarperDB must be running to start clustering."),process.exit()),ge.get(Gt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY)||(console.error("Clustering must be setup and enabled in harperdb-config."),process.exit()),console.log("Starting clustering."),await VW.generateNatsConfig(),await Qi.startClusteringProcesses(!0),process.exit()),lSe(),await Qo.writeFile(Xo.join(ge.get(BT.CONFIG_PARAMS.ROOTPATH),BT.HDB_PID_FILE),`${process.pid}`),us.info("HarperDB PID",process.pid);let o;try{let l=await rSe.getVersionUpdateInfo();l!==void 0&&(o=l[Gt.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION],await Jge.upgrade(l),console.log(sSe))}catch(l){o?(console.error(`Got an error while trying to upgrade your HarperDB instance to version ${o}. Exiting HarperDB.`,l),us.error(l)):(console.error(iSe,l),us.error(l)),process.exit(1)}Yge(),fSe(),await eSe.reviewSelfSignedCert(),Zo.autoCastBoolean(ge.get(Gt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&nSe&&await VW.generateNatsConfig(t)}a(WW,"initialize");async function uSe(e=!1){try{Qd=Zge(process.argv),Qd.ROOTPATH&&xC.updateConfigObject("settings_path",Xo.join(Qd.ROOTPATH,Gt.HDB_CONFIG_FILE)),await WW(e,!0),ge.get(Gt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await Xge();let t=process.env.IS_SCRIPTED_SERVICE&&!Qd.service;Zo.autoCastBoolean(ge.get(Gt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&(t||await Qi.startClusteringProcesses(),await Qi.startClusteringThreads()),await tSe(process.env.DEV_MODE?1:ge.get(BT.CONFIG_PARAMS.THREADS_COUNT)??ge.get(BT.CONFIG_PARAMS.THREADS)),ge.get(Gt.CONFIG_PARAMS.LOGGING_ROTATION_ENABLED)&&await Qge(),t||zW()}catch(t){console.error(t),us.error(t),process.exit(1)}}a(uSe,"main");function zW(){us.suppressLogging(()=>{console.log(UC.magenta(`HarperDB ${zge.version} successfully started`))}),us.notify(cSe)}a(zW,"started");async function dSe(e=!0){YW=!e;try{Qi===void 0&&(Qi=Dd()),Qi.enterPM2Mode(),await WW(),Zo.autoCastBoolean(ge.get(Gt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&await Qi.startClusteringProcesses(),await Qi.startService(Gt.PROCESS_DESCRIPTORS.HDB),zW(),e&&process.exit(0)}catch(t){console.error(t),us.error(t),process.exit(1)}}a(dSe,"launch");function fSe(){let e=Xo.join(ge.get(Gt.CONFIG_PARAMS.ROOTPATH),Gt.LICENSE_KEY_DIR_NAME,Gt.LICENSE_FILE_NAME),t=Xo.join(e,Gt.LICENSE_FILE_NAME),r=Xo.join(e,Gt.REG_KEY_FILE_NAME);try{let{HARPERDB_FINGERPRINT:n,HARPERDB_LICENSE:s}=KW(["HARPERDB_FINGERPRINT","HARPERDB_LICENSE"]);if(Zo.isEmpty(n)||Zo.isEmpty(s))return;Qo.mkdirpSync(e),Qo.writeFileSync(r,n),Qo.writeFileSync(t,s)}catch(n){let s=`Failed to write license & fingerprint due to: ${n.message}`;console.error(s),us.error(s)}}a(fSe,"writeLicenseFromVars");Object.assign(JW,{launch:dSe,main:uSe,isHdbInstalled:jW,startupLog:_Se});async function jW(){try{await Qo.stat(Zo.getPropsFilePath()),await Qo.stat(ge.get(Gt.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}catch(e){if(Zo.noBootFile())return!0;if(e.code==="ENOENT")return!1;throw us.error(`Error checking for HDB install - ${e}`),e}return!0}a(jW,"isHdbInstalled");function _Se(e){let r=a(_=>_.padEnd(20),"pad"),n=`
113
+ `;ge.get(Ce.REPLICATION_HOSTNAME)&&(n+=`${r("Hostname:")}${ge.get(Ce.REPLICATION_HOSTNAME)}
114
+ `),ge.get(Ce.REPLICATION_URL)&&(n+=`${r("Replication Url:")}${ge.get(Ce.REPLICATION_URL)}
115
+ `),n+=`${r("Worker Threads:")}${ge.get(Ce.THREADS_COUNT)}
116
+ `,n+=`${r("Root Path:")}${ge.get(Ce.ROOTPATH)}
117
+ `,ge.get(Ce.THREADS_DEBUG)!==!1&&(n+=`${r("Debugging:")}enabled: true`,n+=ge.get(Ce.THREADS_DEBUG_PORT)?`, TCP: ${ge.get(Ce.THREADS_DEBUG_PORT)}
118
118
  `:`
119
- `);let s=Qo.join(Ae.get(Ce.LOGGING_ROOT),"hdb.log");n+=`${r("Logging:")}level: ${Ae.get(Ce.LOGGING_LEVEL)}, location: ${s+(Ae.get(Ce.LOGGING_STDSTREAMS)?", stdout/err":"")}
120
- `,n+=r("Default:"),n+=Ae.get(Ce.HTTP_PORT)?`HTTP (and WS): ${Ae.get(Ce.HTTP_PORT)}, `:"",n+=Ae.get(Ce.HTTP_SECUREPORT)?`HTTPS (and WS): ${Ae.get(Ce.HTTP_SECUREPORT)}, `:"",n+=`CORS: ${Ae.get(Ce.HTTP_CORS)?`enabled for ${Ae.get(Ce.HTTP_CORSACCESSLIST)}`:"disabled"}
121
- `,n+=r("Operations API:"),n+=Ae.get(Ce.OPERATIONSAPI_NETWORK_PORT)?`HTTP: ${Ae.get(Ce.OPERATIONSAPI_NETWORK_PORT)}, `:"",n+=Ae.get(Ce.OPERATIONSAPI_NETWORK_SECUREPORT)?`HTTPS: ${Ae.get(Ce.OPERATIONSAPI_NETWORK_SECUREPORT)}, `:"",n+=`CORS: ${Ae.get(Ce.OPERATIONSAPI_NETWORK_CORS)?`enabled for ${Ae.get(Ce.OPERATIONSAPI_NETWORK_CORSACCESSLIST)}`:"disabled"}`,n+=`, unix socket: ${Ae.get(Ce.OPERATIONSAPI_NETWORK_DOMAINSOCKET)}
122
- `,n+=r("MQTT:"),n+=Ae.get(Ce.MQTT_NETWORK_PORT)?`TCP: ${Ae.get(Ce.MQTT_NETWORK_PORT)}, `:"",n+=Ae.get(Ce.MQTT_NETWORK_SECUREPORT)?`TLS: ${Ae.get(Ce.MQTT_NETWORK_SECUREPORT)}`:"",n+=Ae.get(Ce.MQTT_WEBSOCKET)&&Ae.get(Ce.HTTP_PORT)?`, WS: ${Ae.get(Ce.HTTP_PORT)}`:"",n+=Ae.get(Ce.MQTT_WEBSOCKET)&&Ae.get(Ce.HTTP_SECUREPORT)?`, WSS: ${Ae.get(Ce.HTTP_SECUREPORT)}
119
+ `);let s=Xo.join(ge.get(Ce.LOGGING_ROOT),"hdb.log");n+=`${r("Logging:")}level: ${ge.get(Ce.LOGGING_LEVEL)}, location: ${s+(ge.get(Ce.LOGGING_STDSTREAMS)?", stdout/err":"")}
120
+ `,n+=r("Default:"),n+=ge.get(Ce.HTTP_PORT)?`HTTP (and WS): ${ge.get(Ce.HTTP_PORT)}, `:"",n+=ge.get(Ce.HTTP_SECUREPORT)?`HTTPS (and WS): ${ge.get(Ce.HTTP_SECUREPORT)}, `:"",n+=`CORS: ${ge.get(Ce.HTTP_CORS)?`enabled for ${ge.get(Ce.HTTP_CORSACCESSLIST)}`:"disabled"}
121
+ `,n+=r("Operations API:"),n+=ge.get(Ce.OPERATIONSAPI_NETWORK_PORT)?`HTTP: ${ge.get(Ce.OPERATIONSAPI_NETWORK_PORT)}, `:"",n+=ge.get(Ce.OPERATIONSAPI_NETWORK_SECUREPORT)?`HTTPS: ${ge.get(Ce.OPERATIONSAPI_NETWORK_SECUREPORT)}, `:"",n+=`CORS: ${ge.get(Ce.OPERATIONSAPI_NETWORK_CORS)?`enabled for ${ge.get(Ce.OPERATIONSAPI_NETWORK_CORSACCESSLIST)}`:"disabled"}`,n+=`, unix socket: ${ge.get(Ce.OPERATIONSAPI_NETWORK_DOMAINSOCKET)}
122
+ `,n+=r("MQTT:"),n+=ge.get(Ce.MQTT_NETWORK_PORT)?`TCP: ${ge.get(Ce.MQTT_NETWORK_PORT)}, `:"",n+=ge.get(Ce.MQTT_NETWORK_SECUREPORT)?`TLS: ${ge.get(Ce.MQTT_NETWORK_SECUREPORT)}`:"",n+=ge.get(Ce.MQTT_WEBSOCKET)&&ge.get(Ce.HTTP_PORT)?`, WS: ${ge.get(Ce.HTTP_PORT)}`:"",n+=ge.get(Ce.MQTT_WEBSOCKET)&&ge.get(Ce.HTTP_SECUREPORT)?`, WSS: ${ge.get(Ce.HTTP_SECUREPORT)}
123
123
  `:`
124
- `;let i=Ae.get(Ce.REPLICATION_PORT)??Ae.get(Ce.OPERATIONSAPI_NETWORK_PORT),o=Ae.get(Ce.REPLICATION_SECUREPORT)??Ae.get(Ce.OPERATIONSAPI_NETWORK_SECUREPORT),c=r("Replication:");c+=i?`WS: ${i}, `:"",c+=o?`WSS: ${o} `:"",n+=`${c.slice(0,-2)}
124
+ `;let i=ge.get(Ce.REPLICATION_PORT)??ge.get(Ce.OPERATIONSAPI_NETWORK_PORT),o=ge.get(Ce.REPLICATION_SECUREPORT)??ge.get(Ce.OPERATIONSAPI_NETWORK_SECUREPORT),c=r("Replication:");c+=i?`WS: ${i}, `:"",c+=o?`WSS: ${o} `:"",n+=`${c.slice(0,-2)}
125
125
  `;let l=[],u=xC.getConfigObj();for(let _ in u)u[_].package&&l.push(_);let f={},d=`${r("REST:")}`;for(let[_,h]of e)for(let S of h){let g=S.name;g==="rest"&&(d+=`${S.protocol_name}: ${_}, `),l.includes(g)&&(f[g]?f[g]+=`${S.protocol_name}: ${_}, `:f[g]=`${S.protocol_name}: ${_}, `)}d.length>21&&(d=d.slice(0,-2),n+=`${d}
126
- `);let p=Ae.get(Ce.HTTP_PORT)?`HTTP: ${Ae.get(Ce.HTTP_PORT)}, `:"";p+=Ae.get(Ce.HTTP_SECUREPORT)?`HTTPS: ${Ae.get(Ce.HTTP_SECUREPORT)}, `:"",p.length>21&&(p=p.slice(0,-2));for(let _ of l)f[_]?n+=`${r(_+": ")}${f[_].slice(0,-2)}
126
+ `);let p=ge.get(Ce.HTTP_PORT)?`HTTP: ${ge.get(Ce.HTTP_PORT)}, `:"";p+=ge.get(Ce.HTTP_SECUREPORT)?`HTTPS: ${ge.get(Ce.HTTP_SECUREPORT)}, `:"",p.length>21&&(p=p.slice(0,-2));for(let _ of l)f[_]?n+=`${r(_+": ")}${f[_].slice(0,-2)}
127
127
  `:n+=`${r(_+": ")}${p}
128
- `;console.log(n),Ae.get(Ce.LOGGING_STDSTREAMS)&&ls.logsAtLevel("info")&&ls.suppressLogging(()=>{console.log(`Note that log messages are being sent to the console (stdout and stderr) in addition to the log file ${s}. This can be disabled by setting logging.stdStreams to false, and the log file can be directly monitored/tailed.`)})}a(hSe,"startupLog");function mSe(e){try{return Number.parseInt(Jo.readFileSync(e,"utf8"),10)}catch{return null}}a(mSe,"readPidFile");function ESe(e){try{return process.kill(e,0),!0}catch(t){return t.code==="EPERM"}}a(ESe,"isProcessRunning")});var WC=w(Zo=>{"use strict";nm();var{isMainThread:HC,parentPort:Oh,threadId:HT,workerData:gSe}=require("node:worker_threads"),{Socket:SSe,createServer:TSe}=require("node:net"),{createServer:ASe,IncomingMessage:RSe}=require("node:http"),{createServer:ySe}=require("node:https"),{createSecureServer:bSe}=require("node:http2"),{Blob:OSe}=(gs(),C(Gm)),{unlinkSync:iz,existsSync:NSe}=require("fs"),Ln=z(),Et=ae(),Xt=(H(),C(G)),{server:Nh}=(Vr(),C(Au)),{WebSocketServer:wSe}=require("ws"),{createServer:ISe}=require("node:tls"),{getTicketKeys:CSe,restartNumber:PSe,getWorkerIndex:Xd}=rt(),{Headers:kC,appendHeader:DSe}=(z_(),C(wH)),{recordAction:Rh,recordActionBinary:XW}=(ki(),C(W_)),{Request:oz,createReuseportFd:bh}=(ZI(),C(NY)),{checkMemoryLimit:LSe}=Od(),{createTLSSelector:az}=Zn(),{resolvePath:cz}=yt(),{startupLog:MSe}=Qd(),{Readable:ZW}=require("node:stream"),vSe=Ti(),lz=Et.get(Xt.CONFIG_PARAMS.THREADS_DEBUG);if(lz){let e;if(HC)e=Et.get(Xt.CONFIG_PARAMS.THREADS_DEBUG_PORT)??9229,process.on(["SIGINT","SIGTERM","SIGQUIT","exit"],()=>{try{require("inspector").close()}catch(t){Ln.info("Could not close debugger",t)}});else{let t=Et.get(Xt.CONFIG_PARAMS.THREADS_DEBUG_STARTINGPORT);t&&Xd()>=0&&(e=t+Xd())}if(e){let t=Et.get(Xt.CONFIG_PARAMS.THREADS_DEBUG_HOST),r=Et.get(Xt.CONFIG_PARAMS.THREADS_DEBUG_WAITFORDEBUGGER);try{require("inspector").open(e,t,r)}catch(n){Ln.trace(`Could not start debugging on port ${e}, you may already be debugging:`,n.message)}}}else if(process.env.DEV_MODE&&HC)try{require("inspector").open(9229)}catch(e){PSe<=1&&Ln.trace("Could not start debugging on port 9229, you may already be debugging:",e.message)}process.on("uncaughtException",e=>{e.isHandled||e.code==="ECONNRESET"||e.code==="ECONNREFUSED"||e.message!=="write EIO"&&console.error("uncaughtException",e)});var{HDB_SETTINGS_NAMES:VUe,CONFIG_PARAMS:USe}=Xt;Et.initSync();var xSe=Et.get(USe.HTTP_SESSIONAFFINITY),Qi={},FC=new Map;Zo.registerServer=VC;Zo.httpServer=YC;Zo.deliverSocket=$C;Zo.startServers=uz;Zo.listenOnPorts=dz;Zo.globals=vSe;Zo.when_components_loaded=null;Nh.http=YC;Nh.request=HSe;Nh.socket=kSe;Nh.ws=FSe;Nh.upgrade=pz;var yh={},BT={},kT={},GC=[];function uz(){return Zo.when_components_loaded=$T().loadRootComponents(!0).then(()=>{Oh?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)$C(n,r,s);else if(t.requestId)BSe(t);else if(t.type===Xt.ITC_EVENT_TYPES.SHUTDOWN){Ln.trace("received shutdown request",HT);for(let i in Qi){let o=Qi[i],c;if(o.closeIdleConnections){let u=Object.getOwnPropertySymbols(o).find(p=>p.description.includes("connections")),f=0,d=setInterval(()=>{f++;let p=f>=100,_=o[u][p?"all":"idle"]();if(_.length===0){p&&clearInterval(d);return}f===1?Ln.info(`Closing ${_.length} idle connections`):p&&Ln.warn(`Forcefully closing ${_.length} active connections`);for(let h=0,S=_.length;h<S;h++){let g=_[h].socket;g._httpMessage&&!g._httpMessage.finished&&!p||(p?g.destroySoon():g.end(`HTTP/1.1 408 Request Timeout\r
128
+ `;console.log(n),ge.get(Ce.LOGGING_STDSTREAMS)&&us.logsAtLevel("info")&&us.suppressLogging(()=>{console.log(`Note that log messages are being sent to the console (stdout and stderr) in addition to the log file ${s}. This can be disabled by setting logging.stdStreams to false, and the log file can be directly monitored/tailed.`)})}a(_Se,"startupLog");function pSe(e){try{return Number.parseInt(Qo.readFileSync(e,"utf8"),10)}catch{return null}}a(pSe,"readPidFile");function hSe(e){try{return process.kill(e,0),!0}catch(t){return t.code==="EPERM"}}a(hSe,"isProcessRunning")});var WC=I(ea=>{"use strict";sm();var{isMainThread:HC,parentPort:Nh,threadId:kT,workerData:mSe}=require("node:worker_threads"),{Socket:ESe,createServer:gSe}=require("node:net"),{createServer:SSe,IncomingMessage:TSe}=require("node:http"),{createServer:ASe}=require("node:https"),{createSecureServer:RSe}=require("node:http2"),{Blob:ySe}=(Ss(),P(qm)),{unlinkSync:iz,existsSync:bSe}=require("fs"),Mn=W(),mt=ce(),Qt=(H(),P(G)),{server:wh}=(Kr(),P(Ru)),{WebSocketServer:OSe}=require("ws"),{createServer:NSe}=require("node:tls"),{getTicketKeys:wSe,restartNumber:ISe,getWorkerIndex:Zd}=rt(),{Headers:kC,appendHeader:CSe}=(j_(),P(wH)),{recordAction:yh,recordActionBinary:XW}=(Fi(),P(z_)),{Request:oz,createReuseportFd:Oh}=(ZI(),P(NY)),{checkMemoryLimit:PSe}=Nd(),{createTLSSelector:az}=es(),{resolvePath:cz}=Rt(),{startupLog:DSe}=Xd(),{Readable:ZW}=require("node:stream"),LSe=Ai(),lz=mt.get(Qt.CONFIG_PARAMS.THREADS_DEBUG);if(lz){let e;if(HC)e=mt.get(Qt.CONFIG_PARAMS.THREADS_DEBUG_PORT)??9229,process.on(["SIGINT","SIGTERM","SIGQUIT","exit"],()=>{try{require("inspector").close()}catch(t){Mn.info("Could not close debugger",t)}});else{let t=mt.get(Qt.CONFIG_PARAMS.THREADS_DEBUG_STARTINGPORT);t&&Zd()>=0&&(e=t+Zd())}if(e){let t=mt.get(Qt.CONFIG_PARAMS.THREADS_DEBUG_HOST),r=mt.get(Qt.CONFIG_PARAMS.THREADS_DEBUG_WAITFORDEBUGGER);try{require("inspector").open(e,t,r)}catch(n){Mn.trace(`Could not start debugging on port ${e}, you may already be debugging:`,n.message)}}}else if(process.env.DEV_MODE&&HC)try{require("inspector").open(9229)}catch(e){ISe<=1&&Mn.trace("Could not start debugging on port 9229, you may already be debugging:",e.message)}process.on("uncaughtException",e=>{e.isHandled||e.code==="ECONNRESET"||e.code==="ECONNREFUSED"||e.message!=="write EIO"&&console.error("uncaughtException",e)});var{HDB_SETTINGS_NAMES:$Ue,CONFIG_PARAMS:MSe}=Qt;mt.initSync();var vSe=mt.get(MSe.HTTP_SESSIONAFFINITY),Xi={},FC=new Map;ea.registerServer=VC;ea.httpServer=YC;ea.deliverSocket=$C;ea.startServers=uz;ea.listenOnPorts=dz;ea.globals=LSe;ea.when_components_loaded=null;wh.http=YC;wh.request=xSe;wh.socket=BSe;wh.ws=HSe;wh.upgrade=pz;var bh={},HT={},FT={},GC=[];function uz(){return ea.when_components_loaded=VT().loadRootComponents(!0).then(()=>{Nh?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)$C(n,r,s);else if(t.requestId)USe(t);else if(t.type===Qt.ITC_EVENT_TYPES.SHUTDOWN){Mn.trace("received shutdown request",kT);for(let i in Xi){let o=Xi[i],c;if(o.closeIdleConnections){let u=Object.getOwnPropertySymbols(o).find(p=>p.description.includes("connections")),f=0,d=setInterval(()=>{f++;let p=f>=100,_=o[u][p?"all":"idle"]();if(_.length===0){p&&clearInterval(d);return}f===1?Mn.info(`Closing ${_.length} idle connections`):p&&Mn.warn(`Forcefully closing ${_.length} active connections`);for(let h=0,S=_.length;h<S;h++){let g=_[h].socket;g._httpMessage&&!g._httpMessage.finished&&!p||(p?g.destroySoon():g.end(`HTTP/1.1 408 Request Timeout\r
129
129
  Connection: close\r
130
130
  \r
131
- `))}},25).unref()}o.close?.(()=>{if(Et.get(Xt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&Xd()==0)try{iz(cz(Et.get(Xt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,HT),o.cantCleanupProperly||Ln.warn("Had to forcefully exit the thread",HT),process.exit(0)},5e3).unref()})}if(lz||process.env.DEV_MODE)try{require("inspector").close()}catch(i){Ln.info("Could not close debugger",i)}}}).ref();let e;bh&&!xSe&&(e=dz()),Promise.resolve(e).then(()=>{if(Xd()===0)try{MSe(FC)}catch(t){console.error("Error displaying start-up log",t)}Oh?.postMessage({type:Xt.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(uz,"startServers");function dz(){let e=[];for(let t in Qi){let r=Qi[t];if(t.includes?.("/")&&Xd()==0){NSe(t)&&iz(t),e.push(new Promise((o,c)=>{r.listen({path:t},()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),Ln.info("Domain socket listening on "+t)}).on("error",c)}));continue}let n,s=Et.get(Xt.CONFIG_PARAMS.HTTP_THREADRANGE);if(s){let o=typeof s=="string"?s.split("-"):s,c=Xd();if(c<o[0]||c>o[1])continue}let i;try{let o=t.lastIndexOf(":");o>0?bh?n={fd:bh(+t.slice(o+1).replace(/[\[\]]/g,""),t.slice(0,o))}:n={host:+t.slice(o+1).replace(/[\[\]]/g,""),port:t.slice(0,o)}:bh?n={fd:bh(+t,"::")}:n={port:t}}catch(o){console.error(`Unable to bind to port ${t}`,o);continue}e.push(new Promise((o,c)=>{r.listen(n,()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),Ln.trace("Listening on port "+t,HT)}).on("error",c)}))}return Promise.all(e)}a(dz,"listenOnPorts");!HC&&!gSe?.noServerStart&&uz();function $C(e,t,r){let n=e?.read?e:new SSe({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=Qi[t];if(s.isSecure&&(n.startTime=performance.now()),s)typeof s=="function"?s(n):s.emit("connection",n),r&&n.emit("data",r);else{let i=a(o=>{setTimeout(()=>{let c=Qi[t];c?(typeof c=="function"?c(n):c.emit("connection",n),r&&n.emit("data",r)):o<5?i(o+1):(Ln.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a($C,"deliverSocket");var ez=new Map;function BSe(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=ez.get(s),r){case"connection":i=$C(void 0,t),ez.set(s,i),i.write=(c,l,u)=>(Oh.postMessage({requestId:s,event:"data",data:c.toString("latin1")}),u&&u(),!0),i.end=(c,l,u)=>(Oh.postMessage({requestId:s,event:"end",data:c?.toString("latin1")}),u&&u(),!0);let o=i.destroy;i.destroy=()=>{o.call(i),Oh.postMessage({requestId:s,event:"destroy"})};break;case"data":i._readableState.destroyed||i.emit("data",Buffer.from(n,"latin1"));break;case"drain":i._readableState.destroyed||i.emit("drain",{});break;case"end":i._readableState.destroyed||i.emit("end",{});break;case"error":i._readableState.destroyed||i.emit("error",{});break}}a(BSe,"proxyRequest");var{getComponentName:FT}=(jp(),C(zp));function VC(e,t,r=!0){t||(t=Et.get(Xt.CONFIG_PARAMS.HTTP_PORT));let n=Qi[t];if(n){let s=n.lastServer||n;if(s===e)throw new Error(`Can not register the same server twice for the same port ${t}`);if(r&&!!s.sessionIdContext!=!!e.sessionIdContext&&+t)throw new Error(`Can not mix secure HTTPS and insecure HTTP on the same port ${t}`);s.off("unhandled",sz),s.on("unhandled",(i,o)=>{e.cantCleanupProperly&&(n.cantCleanupProperly=!0),e.emit("request",i,o)}),n.lastServer=e}else Qi[t]=e;e.on("unhandled",sz)}a(VC,"registerServer");function KC(e){let t=[],r=e?.securePort;return r&&t.push({port:r,secure:!0}),r=e?.port,r&&t.push({port:r,secure:!1}),t.length===0&&(t=[],Et.get(Xt.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:Et.get(Xt.CONFIG_PARAMS.HTTP_PORT),secure:Et.get(Xt.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),Et.get(Xt.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:Et.get(Xt.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&Et.get(Xt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:cz(Et.get(Xt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)),secure:!1}),t}a(KC,"getPorts");function YC(e,t){let r=[];for(let{port:n,secure:s}of KC(t))r.push(fz(n,s,t?.isOperationsServer,t?.mtls)),typeof e=="function"?GC[t?.runFirst?"unshift":"push"]({listener:e,port:t?.port||n}):(e.isSecure=s,VC(e,n,!1)),kT[n]=qT(GC,n);return r}a(YC,"httpServer");function GT(e,t){let r=FC.get(e)??[];FC.set(e,[...r,t])}a(GT,"setPortServerMap");function fz(e,t,r,n){if(GT(e,{protocol_name:t?"HTTPS":"HTTP",name:FT()}),!BT[e]){let s=r?"operationsApi_network":"http",i=Et.get(s+"_keepAliveTimeout"),o=Et.get(s+"_timeout"),c=Et.get(s+"_headersTimeout"),l={keepAliveTimeout:i,headersTimeout:c,requestTimeout:o,highWaterMark:128*1024,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,maxHeaderSize:Et.get(Xt.CONFIG_PARAMS.HTTP_MAXHEADERSIZE)},u=Et.get(s+"_mtls"),f=Et.get(s+"_mtls_required"),d;t&&(d=Et.get(s+"_http2"),Object.assign(l,{allowHTTP1:!0,rejectUnauthorized:!!f,requestCert:!!(u||n),ticketKeys:CSe(),SNICallback:az(r?"operations-api":"server",u)}));let p=LSe(),_=BT[e]=(t?d?bSe:ySe:ASe)(l,async(h,S)=>{try{let R=performance.now(),E=new oz(h,S);r&&(E.isOperationsServer=!0);let T=await kT[e](E);if(!T){if(E._nodeResponse.statusCode)return;T=_z(E)}if(T.headers?.set||(T.headers=new kC(T.headers)),p?T.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):T.headers?.set?.("Server","HarperDB"),T.status===-1){for(let ne of T.headers||[])S.setHeader(ne[0],ne[1]);return h.baseRequest=E,S.baseResponse=T,BT[e].emit("unhandled",h,S)}let b=T.status||200,v=performance.now(),F=v-R,q=T.body,Y,Z=!1;if(!T.handlesHeaders){let ne=T.headers||new kC;q?q.length>=0?(typeof q=="string"?ne.set("Content-Length",Buffer.byteLength(q)):ne.set("Content-Length",q.length),Y=!0):q instanceof OSe&&(q.size?ne.set("Content-Length",q.size):q.on&&(Z=!0,q.on("size",me=>{S.headersSent||S.setHeader("Content-Length",me)})),q=q.stream()):(ne.set("Content-Length","0"),Y=!0);let J=`hdb;dur=${F.toFixed(2)}`;if(T.wasCacheMiss&&(J+=", miss"),DSe(ne,"Server-Timing",J,!0),!S.headersSent)if(Z){if(S.statusCode=b,ne)if(ne[Symbol.iterator])for(let[me,ye]of ne)S.setHeader(me,ye);else for(let me in ne)S.setHeader(me,ne[me])}else S.writeHead(b,ne&&(ne[Symbol.iterator]?Array.from(ne):ne));Y&&S.end(q)}let se=E.handlerPath,Q=E.method;if(Rh(F,"duration",se,Q,T.wasCacheMiss==null?void 0:T.wasCacheMiss?"cache-miss":"cache-hit"),XW(b<400,"success",se,Q),XW(1,"response_"+b,se,Q),!Y)if(q instanceof ReadableStream&&(q=ZW.fromWeb(q)),(q[Symbol.iterator]||q[Symbol.asyncIterator])&&(q=ZW.from(q)),q?.pipe){q.pipe(S),q.destroy&&S.on("close",()=>{q.destroy()});let ne=0;q.on("data",J=>{ne+=J.length}),q.on("end",()=>{Rh(performance.now()-v,"transfer",se,Q),Rh(ne,"bytes-sent",se,Q)})}else q?.then?q.then(ne=>{S.end(ne)},g):S.end(q)}catch(R){g(R)}function g(R){let E=R.headers;S.writeHead(R.statusCode||500,E&&(E[Symbol.iterator]?Array.from(E):E)),S.end(R.toString()),R.statusCode?R.statusCode===500?Ln.warn(R):Ln.info(R):Ln.error(R)}a(g,"onError")});i>=0&&(_.keepAliveTimeout=i),c>=0&&(_.headersTimeout=c),t&&(_.ports||(_.ports=[]),_.ports.push(e),l.SNICallback.initialize(_),u&&(_.mtlsConfig=u),_.on("secureConnection",h=>{h._parent.startTime&&Rh(performance.now()-h._parent.startTime,"tls-handshake",e),Rh(h.isSessionReused(),"tls-reused",e)}),_.isSecure=!0),VC(_,e)}return BT[e]}a(fz,"getHTTPServer");function qT(e,t){let r=_z;for(let n=e.length;n>0;){let{listener:s,port:i}=e[--n];if(i===t||i==="all"){let o=r;r=a((...c)=>s(...c,o),"next_callback")}}return r}a(qT,"makeCallbackChain");function _z(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new kC}}a(_z,"unhandled");function HSe(e,t){YC(e,{requestOnly:!0,...t})}a(HSe,"onRequest");function kSe(e,t){let r;if(t.securePort){GT(t.securePort,{protocol_name:"TLS",name:FT()});let n=az("server",t.mtls);r=ISe({rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,SNICallback:n},e),n.initialize(r),Qi[t.securePort]=r}return t.port&&(GT(t.port,{protocol_name:"TCP",name:FT()}),r=TSe(e,{noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600}),Qi[t.port]=r),r}a(kSe,"onSocket");Object.defineProperty(RSe.prototype,"upgrade",{get(){return"connection"in this.headers&&"upgrade"in this.headers&&this.headers.connection.toLowerCase().includes("upgrade")&&this.headers.upgrade.toLowerCase()=="websocket"},set(e){}});var tz=[],qC={};function pz(e,t){for(let{port:r}of KC(t))tz[t?.runFirst?"unshift":"push"]({listener:e,port:r}),qC[r]=qT(tz,r)}a(pz,"onUpgrade");var rz=[],nz={};function FSe(e,t){let r=[];for(let{port:n,secure:s}of KC(t)){GT(n,{protocol_name:s?"WSS":"WS",name:FT()});let i=fz(n,s,t?.isOperationsServer,t?.mtls);yh[n]||(yh[n]=new wSe({noServer:!0,maxPayload:t.maxPayload??100*1024*1024}),yh[n].on("connection",(o,c)=>{let l=new oz(c);l.isWebSocket=!0;let u=kT[n](l);nz[n](o,l,u)}),pz((o,c,l,u)=>o.__harperdb_request_upgraded?u(o,c,l):yh[n].handleUpgrade(o,c,l,f=>{o.__harperdb_request_upgraded=!0,u(o,c,l),yh[n].emit("connection",f,o)}),{port:n}),i.on("upgrade",(o,c,l)=>{qC[n]&&qC[n](o,c,l)})),r.push(i),rz[t?.runFirst?"unshift":"push"]({listener:e,port:n}),nz[n]=qT(rz,n),kT[n]=qT(GC,n)}return r}a(FSe,"onWebSocket");function sz(e,t){t.writeHead(404),t.end(`Not found
132
- `)}a(sz,"defaultNotFound")});var QW={};ve(QW,{startHTTPThreads:()=>qSe,startSocketServer:()=>XC,updateWorkerIdleness:()=>yz});async function qSe(e=2,t){try{if(t)JC(0,1,!0);else{let{loadRootComponents:r}=$T();if(e===0)return(0,Bs.setMainIsWorker)(!0),await WC().startServers(),Promise.resolve([]);await r()}Rz();for(let r=0;r<e;r++)JC(r,e);return Promise.all(Az)}finally{(0,Bs.threadsHaveStarted)()}}function Rz(){let e=(0,gz.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),jC=setInterval(()=>{YT.notify(e)},GSe).unref())}function JC(e,t=1,r){if(zC++,(0,Bs.startWorker)("server/threads/threadServer.js",{name:ZA.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(u){u.type===JA.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});Az.push(s),await s,Zd.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=KT.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=Zd.indexOf(n);o>-1&&Zd.splice(o,1)}if(a(i,"removeWorker"),ef){let o=ef;ef=[];for(let c of o)Tz[c.localPort](null,c)}}}),r){let n=setInterval(()=>{QC?QC=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,Bs.shutdownWorkers)(),zC=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function XC(e=0,t){if(typeof e=="string")try{(0,WT.existsSync)(e)&&(0,WT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=$Se:r=VSe(t):r=ZC;let n=(0,tf.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);return n._handle&&(n._handle.onconnection=Tz[e]=function(s,i){r.readsData||(i.reading=!1,i.readStop()),QC=!0,r(i,(o,c)=>{if(!o){if(hz){let u=i._socket||new tf.Socket({handle:i,writable:!0,readable:!0});hz.deliverSocket(u,e,c),u.resume()}else zC>0?(ef.length===0&&setTimeout(()=>{ef.length>0&&console.warn("Incoming sockets/requests have been queued for workers to start, and no workers have handled them. Check to make sure an error is not preventing workers from starting")},1e4).unref(),i.localPort=e,ef.push(i)):(console.log("start up a dynamic thread to handle request"),JC(0));sr(!1,"socket-routed");return}o.requests++;let l=i.fd;if(l>=0)o.postMessage({port:e,fd:l,data:c});else{let u=i._socket||new tf.Socket({handle:i,writable:!0,readable:!0});WSe(u,o,e)}sr(!0,"socket-routed")})},YT.info(`HarperDB ${Sz.packageJson.version} Server running on port ${e}`)),n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function ZC(e,t){let r,n=0;for(let s of Zd){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=VT)return VT=i,t(r);n=i}VT=0,t(r)}function $Se(e,t){let r={};e.getpeername(r);let n=r.address,s=rf.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);ZC(e,o=>{rf.set(n,{worker:o,lastUsed:i}),t(o)})}function VSe(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new tf.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let l=o.toString("latin1").match(t)?.[1],u=rf.get(l),f=Date.now();if(u&&u.worker.threadId!==-1)return u.lastUsed=f,s(u.worker);ZC(n,d=>{rf.set(l,{worker:d,lastUsed:f}),s(d,o)})})}a(r,"findByHeaderAffinity")}function yz(){VT=0;for(let e of Zd)e.expectedIdle=e.recentELU.idle+KSe,e.requests=1;Zd.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function WSe(e,t,r){let n=YSe++;t.postMessage({port:r,requestId:n,event:"connection"}),e.on("data",s=>{let i=s.toString("latin1");t.postMessage({port:r,requestId:n,data:i,event:"data"})}).on("close",s=>{t.postMessage({port:r,requestId:n,event:"close",hadError:s})}).on("error",s=>{t.postMessage({port:r,requestId:n,event:"error",error:s})}).on("drain",s=>{t.postMessage({port:r,requestId:n,event:"drain",error:s})}).on("end",()=>{t.postMessage({port:r,requestId:n,event:"end"})}).resume(),KT.set(n,s=>{s.event=="data"&&e.write(Buffer.from(s.data,"latin1")),s.event=="end"&&(e.end(s.data&&Buffer.from(s.data,"latin1")),KT.delete(n)),s.event=="destroy"&&(e.destroy(),KT.delete(n))})}var Bs,tf,YT,WT,Ez,gz,Sz,Zd,ef,Tz,hz,zC,Az,jC,GSe,QC,VT,mz,rf,KSe,KT,YSe,BC=be(()=>{Bs=M(rt()),tf=require("net");H();YT=M(z()),WT=require("fs");ki();Ez=require("worker_threads"),gz=M(Od()),Sz=M(it()),Zd=[],ef=[],Tz=[],zC=0,Az=[];Ez.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,Bs.onMessageFromWorkers)(e=>{e.type===XA.RESTART&&jC&&(clearInterval(jC),Rz())}));GSe=6e5;a(qSe,"startHTTPThreads");a(Rz,"licenseWarning");a(JC,"startHTTPWorker");a(XC,"startSocketServer");VT=0;a(ZC,"findMostIdleWorker");mz=36e5,rf=new Map;a($Se,"findByRemoteAddressAffinity");a(VSe,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of rf)r.lastUsed+mz<e&&rf.delete(t)},mz).unref();KSe=1e3;a(yz,"updateWorkerIdleness");(0,Bs.setMonitorListener)(yz);KT=new Map,YSe=1;a(WSe,"proxySocket")});var Hz=w((XUe,Bz)=>{var Oz=M(require("cluster")),uc=M(ae());H();var Xi=M(z()),Nz=M(require("fastify")),wz=M(require("@fastify/cors")),Iz=M(require("@fastify/compress")),Cz=M(require("@fastify/static")),Pz=M(RO()),Dz=M(require("path")),Lz=M(it()),Mz=M(As()),vz=M(ie()),Uz=M(Rn()),xz=M(Od());Vr();var dc=M(hT());ao();uc.default.initSync();var zSe=6e4,jSe=1024*1024*1024,JSe="TRUE",{CONFIG_PARAMS:wh}=G,nf;Bz.exports={hdbServer:bz,start:bz};async function bz(e){try{Xi.default.debug("In Fastify server"+process.cwd()),Xi.default.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Xi.default.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=Oz.default.isMaster,await QSe();let t=e.securePort>0;nf=XSe(t),await nf.ready(),e||(e={}),e.isOperationsServer=!0;try{We.http(nf.server,e),nf.server.closeIdleConnections||await nf.listen({port:0,host:"::"})}catch(r){throw nf.close(),Xi.default.error(r),Xi.default.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),Xi.default.fatal(t),process.exit(1)}}a(bz,"operationsServer");async function QSe(){Xi.default.trace("Configuring HarperDB process."),Mz.default.setSchemaDataToGlobal(),await Uz.default.setUsersWithRolesCache(),await xz.default.getLicense()}a(QSe,"setUp");function XSe(e){Xi.default.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=ZSe(e),r=(0,Nz.default)(t);r.server.headersTimeout=tTe(),r.setErrorHandler(dc.serverErrorHandler);let n=eTe();n&&r.register(wz.default,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,u){r.server.emit("unhandled",l.raw,u.raw)}),c()}),r.register(Pz.default),r.register(Iz.default),r.register(Cz.default,{root:Dz.default.join(Lz.PACKAGE_ROOT,"studio/build-local")}),jf(r);let s=uc.default.get(jA.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!vz.default.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[dc.reqBodyValidationHandler,dc.authHandler],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),(0,dc.handlePostRequest)(i,o)}),r.get("/health",()=>"HarperDB is running."),Xi.default.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(XSe,"buildServer");function ZSe(e){let t=uc.default.get(wh.OPERATIONSAPI_NETWORK_TIMEOUT),r=uc.default.get(wh.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:jSe,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(ZSe,"getServerOptions");function eTe(){let e=uc.default.get(wh.OPERATIONSAPI_NETWORK_CORS),t=uc.default.get(wh.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===JSe)&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},t&&t.length>0&&t[0]!==null&&t[0]!=="*"&&(r.origin=(n,s)=>s(null,t.indexOf(n)!==-1))),r}a(eTe,"getCORSOpts");function tTe(){return uc.default.get(wh.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??zSe}a(tTe,"getHeaderTimeoutConfig")});var iP={};ve(iP,{disableNATS:()=>nTe,publishToStream:()=>JT,setNATSReplicator:()=>eP,setPublishToStream:()=>sTe,setSubscription:()=>sP,start:()=>rTe});function rTe(){Ih.default.get(x.CLUSTERING_ENABLED)&&oTe()}function nTe(e=!0){$z=e}function sTe(e,t){JT=e,sP=t}function oTe(){if($z||process.env._DISABLE_NATS)return;let e=Xe(),t=Object.keys(e);t.push("system");for(let r of t){let n=e[r];for(let s in n){let i=n[s];eP(s,r,i)}}Tl((r,n)=>{eP(r.tableName,r.databaseName,r),n&&Kz(r)}),!kz&&(kz=!0)}function eP(e,t,r){if(t==="system"&&aTe.includes(e))return;if(!r)return console.error(`Attempt to replicate non-existent table ${e} from database ${t}`);if(r.sources.some(s=>s?.isNATSReplicator))return;r.sourcedFrom(class extends $r{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this.getId(),record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this.getId()})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this.getId(),record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this.getId(),record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this.getId()})}static defineSchema(i){Kz(i)}static subscribe(){let i=new Bn;return sP(t,e,i),i}static subscribeOnThisThread(i){return i<(Ih.default.get(x.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??iTe)}static isEqual(i){return i.isNATSReplicator}static isNATSReplicator=!0;static shouldReceiveInvalidations=!0},{intermediateSource:!0});function n(s){let i=s?.transaction?.nats;if(!i)if(s?.transaction){s.transaction.nats=i=new zT(s.transaction,s);let o=s.transaction;for(;o.next;)o=o.next;o.next=s.transaction.nats,i.user=s.user,i.context=s}else i=Vz;return i}a(n,"getNATSTransaction")}function Kz(e){let t=Ih.default.get(x.CLUSTERING_NODENAME);JT(`${rP.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,nP.createNatsTableStreamName)(e.databaseName,e.tableName),void 0,{operation:"define_schema",schema:e.databaseName,table:e.tableName,attributes:e.attributes,__origin:{timestamp:Date.now(),node_name:t}})}var Fz,rP,nP,Gz,qz,Ih,jT,$z,JT,sP,iTe,Vz,kz,aTe,zT,tP,Yz=be(()=>{De();Ea();Fz=M(ir()),rP=M(Tt()),nP=M(Eo());pu();Gz=M(xO()),qz=M(_n()),Ih=M(ae());H();jT=M(z());a(rTe,"start");a(nTe,"disableNATS");JT=Fz.publishToStream,sP=Gz.setSubscription;a(sTe,"setPublishToStream");iTe=2;a(oTe,"assignReplicationSource");aTe=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(eP,"setNATSReplicator");a(Kz,"publishSchema");zT=class{constructor(t,r){this.transaction=t;this.options=r}static{a(this,"NATSTransaction")}user;writes_by_db=new Map;addWrite(t,r){r.expiresAt=this.context?.expiresAt;let n=this.writes_by_db.get(t);n||this.writes_by_db.set(t,n=[]),n.push(r)}commit({timestamp:t}){let r=Ih.default.get(x.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],l,u;for(let f of i){let d=f.table,p=f.operation=="put"?"upsert":f.operation;l||(jT.trace(`Sending transaction event ${p}`),u=l={operation:p,schema:s,table:d,__origin:{user:this.user?.username,timestamp:t,node_name:r}},l.hash_values=c,p!=="delete"&&p!=="invalidate"&&(l.records=o)),l.table===d&&l.operation===p?(o.push(f.record),c.push(f.id)):u=u.next={operation:p,table:d,id:f.id,record:f.record},f.expiresAt&&(u.expiresAt=f.expiresAt)}l&&n.push(JT(`${rP.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,nP.createNatsTableStreamName)(s,l.table),void 0,l)?.catch(f=>{throw jT.error("An error has occurred trying to replicate transaction",l,f),f.statusCode=504,f}))}return Promise.all(n)}},tP=class extends zT{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,qz.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};Vz=new tP});async function Qz({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await oP.get(e,{returnNonexistent:!0});i=new lP(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await oP.get(e);o&&o.delete()}i=new XT(e,t)}return n&&(n.id=e,n.user={username:t?.username},Ch.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function aP(){return QT++,QT>65500&&(QT=1),QT}function cP(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=Oi.getMatch(n,"mqtt");if(!i)throw new Error(`Can not publish to topic ${n} as it does not exist, no resource has been defined to handle this topic`);e.url=i.relativeURL;let o=i.Resource;return wt(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var zz,fc,jz,Jz,Wz,oP,Ch,QT,XT,lP,Xz=be(()=>{De();Tu();zz=M(_n()),fc=M(z());Ic();jz=M(rt()),Jz=M(WC());Vr();Wz=100,oP=ft({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),Ch=ft({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,jz.getWorkerIndex)()===0&&(async()=>{await Jz.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of Ch.search({})){let t=e.data,r={...e};r.user?.username&&(r.user=await We.getUser(r.user.username));try{await cP(r,t,r)}catch{(0,fc.warn)("Failed to publish will",t)}Ch.delete(e.id)}})();a(Qz,"getSession");QT=1;a(aP,"getNextMessageId");XT=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;request;socket;subscriptions=[];awaitingAcks;sessionWasPresent;keepalive;keepaliveTimer;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),l,u;if(c>-1?(l=s.slice(c),u=s.slice(0,c)):u=s,!u)throw new Error("No topic provided");if(u.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let f=this.subscriptions.find(R=>R.topic===s),d;f?(d=i>0,f.end(),this.subscriptions.splice(this.subscriptions.indexOf(f),1)):d=i===2;let p={search:l,async:!0,user:this.user,startTime:o,omitCurrent:d,url:""};o&&(0,fc.trace)("Resuming subscription from",s,"from",o);let _=Oi.getMatch(u,"mqtt");if(!_){let R=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw R.statusCode=404,R}if(p.url=_.relativeURL,p.url.indexOf("+")>-1||p.url.indexOf("#")>-1){let R=p.url.slice(1);if(R.indexOf("#")>-1&&R.indexOf("#")!==R.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(p.isCollection=!0,R.indexOf("+")===R.length-1)p.onlyChildren=!0,p.url="/"+R.slice(0,R.length-1);else{let E=R.split("/"),T;for(let F=0;F<E.length;F++)if(E[F].indexOf("+")>-1)if(E[F]==="+")T=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&T)throw new Error("Filters can not be combined");let b=!0;E[E.length-1]==="#"&&(E.length--,b=!1),T&&(n=a(F=>{let q=F.id;if(!Array.isArray(q))if(q?.indexOf?.("/")>-1)q=q.split("/");else return!1;if(b&&q.length!==E.length)return!1;for(let Y=0;Y<E.length;Y++)if(E[Y]!=="+"&&E[Y]!==q[Y])return!1;return!0},"filter"));let v=E.indexOf("+");p.url="/"+(v>-1?E.slice(0,v):E).concat("").join("/")}}let h=_.path,S=_.Resource,g=await wt(p,async()=>{let R=this.createContext();R.topic=s,R.retainHandling=i;let E=await S.subscribe(p,R);if(!E)return;if(!E[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let T=(async()=>{for await(let b of E)try{let v;if(b.type&&b.type!=="put"&&b.type!=="delete"&&b.type!=="message"&&b.type!=="patch"||n&&!n(b))continue;r?(b.topic=s,v=this.needsAcknowledge(b)):(b.acknowledge?.(),v=aP());let F=b.id;if(Array.isArray(F)&&(F=Su(F)),F==null&&(F=""),await this.listener(h+"/"+F,b.value,v,t)===!1)break;this.awaitingAcks?.size>Wz?await new Promise(Y=>setTimeout(Y,this.awaitingAcks.size-Wz)):await new Promise(setImmediate)}catch(v){(0,fc.warn)(v)}})();return E});if(g)return g.topic=s,g.qos=t.qos,this.subscriptions.push(g),g}resume(){}needsAcknowledge(t){let r=aP();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,{acknowledge:t.acknowledge})),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r.acknowledge())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),this.subscriptions.splice(this.subscriptions.indexOf(r),1),!0}async publish(t,r){return cP(t,r,this.createContext())}createContext(){let t={session:this,socket:this.socket,user:this.user,authorize:!0};return this.request&&(t.request=this.request,t.url=this.request.url,t.headers=this.request.headers),t}setListener(t){this.listener=t}disconnect(t){this.keepaliveTimer&&clearTimeout(this.keepaliveTimer);let r=this.createContext();wt(r,async()=>{try{if(!t){let n=await Ch.get(this.sessionId);n?.doesExist()&&await cP(n,n.data,r)}}finally{await Ch.delete(this.sessionId)}}).catch(n=>{(0,fc.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}receivedPacket(){this.keepalive&&(clearTimeout(this.keepaliveTimer),this.keepaliveTimer=setTimeout(()=>{this.socket?.destroy?this.socket.destroy(new Error("Keepalive timeout")):this.socket?.terminate()},this.keepalive*1500))}};a(cP,"publish");lP=class extends XT{static{a(this,"DurableSubscriptionsSession")}sessionRecord;constructor(t,r,n){super(t,r),this.sessionRecord=n||{id:t,subscriptions:[]}}async resume(){for(let t of this.sessionRecord.subscriptions||[])await this.resumeSubscription({omitCurrent:!0,topic:t.topic,qos:t.qos,startTime:t.startTime},!0,t.acks?r=>!t.acks.includes(r.localTime):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=aP(),n={topic:t.topic,timestamp:t.localTime};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks?.get(t);if(!r)return;this.awaitingAcks?.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,fc.trace)("Received ack",n,r.timestamp),this.sessionRecord.update();return}}for(let s of this.sessionRecord.subscriptions)s.topic===n&&(s.startTime=r.timestamp);this.sessionRecord.update()}async addSubscription(t,r){await this.resumeSubscription(t,r);let{qos:n,startTime:s}=t;return n>0&&!s&&this.saveSubscriptions(),t.qos}removeSubscription(t){let r=this.subscriptions.find(s=>s.topic===t),n=super.removeSubscription(t);return r.qos>0&&this.saveSubscriptions(),n}saveSubscriptions(){this.sessionRecord.subscriptions=this.subscriptions.map(t=>{let r=t.startTime;return r||(r=t.startTime=(0,zz.getNextMonotonicTime)()),(0,fc.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),oP.put(this.sessionRecord)}}});var dP={};ve(dP,{bypassAuth:()=>cTe,start:()=>lTe});function cTe(){nj=!0}function lTe({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new rj.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c=[],l=r?.mtls;return n&&(c=e.ws((u,f,d,p)=>{if(f.headers.get("sec-websocket-protocol")!=="mqtt")return p(u,f,d);o.events.emit("connection",u),hr.debug?.("Received WebSocket connection for MQTT from",u._socket.remoteAddress);let{onMessage:_,onClose:h}=ej(u,S=>{u.send(S)},f,Promise.resolve(d).then(()=>f?.user),o);u.on("message",_),u.on("close",h),u.on("error",S=>{hr.info?.("WebSocket error",S)})},{...n})),(t||s)&&c.push(e.socket(async u=>{let f;if(o.events.emit("connection",u),hr.debug?.(`Received ${u.getCertificate?"SSL":"TCP"} connection for MQTT from ${u.remoteAddress}`),l){if(u.authorized)try{let _=l.user;if(_!==null){(_===void 0||_==="Common Name"||_==="CN")&&(_=u.getPeerCertificate().subject.CN);try{f=await e.getUser(_,null,null),(0,sf.get)(x.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&eA.notify?.({username:f?.username,status:Ys.SUCCESS,type:la.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:u.remoteAddress})}catch(h){throw(0,sf.get)(x.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&eA.error?.({username:_,status:Ys.FAILURE,type:la.AUTHENTICATION,auth_strategy:"mqtt",remote_address:u.remoteAddress}),h}}else hr.debug?.("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",u.remoteAddress)}catch(_){o.events.emit("error",_,u),hr.error?.(_)}else if(l.required)return hr.info?.(`Unauthorized connection attempt, no authorized client certificate provided, error: ${u.authorizationError}`),u.end()}!f&&nj&&u.remoteAddress.includes("127.0.0.1")&&(f=await(0,tj.getSuperUser)(),hr.debug?.("Auto-authorizing local connection",f?.username));let{onMessage:d,onClose:p}=ej(u,_=>u.write(_),null,f,o);u.on("data",d),u.on("close",p),u.on("error",_=>{hr.info?.("Socket error",_)})},{port:t,securePort:s,mtls:l})),c}function ej(e,t,r,n,s){Zz||(Zz=!0,Y_(d=>{ZT>0&&d.push({metric:"mqtt-connections",connections:ZT,byThread:!0})}));let i;ZT++;let o,c={protocolVersion:4},l=(0,tA.parser)({protocolVersion:5});function u(d){l.parse(d)}a(u,"onMessage");function f(){ZT--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),Qn(!1,"connection","mqtt","disconnect"),hr.debug?.("MQTT connection was closed",e.remoteAddress))}return a(f,"onClose"),l.on("packet",async d=>{n?.then&&(n=await n);let p=d.cmd;if(o)o.then&&await o;else if(p!=="connect"){hr.info?.("Received packet before connection was established, closing connection"),e?.destroy?e.destroy():e?.terminate();return}let _=d.topic,h=_?.indexOf("/",1),S=h>0?_.slice(0,h):_;sr(d.length,"bytes-received",S,R(d),"mqtt");try{switch(o?.receivedPacket?.(),p){case"connect":if(c.protocolVersion=d.protocolVersion,d.username)try{n=await We.getUser(d.username,d.password.toString(),r),(0,sf.get)(x.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&eA.notify?.({username:n?.username,status:Ys.SUCCESS,type:la.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(se){return(0,sf.get)(x.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&eA.error?.({username:d.username,status:Ys.FAILURE,type:la.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",d,e,se),Qn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",d,e),Qn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(d,n),d.will){let se=e.deserialize||(e.deserialize=uo(r?.headers.get?.("content-type")));d.will.data=d.will.payload?.length>0?se(d.will.payload):void 0,delete d.will.payload}o=Qz({user:n,...d}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(se){return hr.error?.(se),s.events.emit("auth-failed",d,e,se),Qn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:se.code||5,returnCode:se.code||128})}s.events.emit("connected",o,e),Qn(!0,"connection","mqtt","connect"),g({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0});let T=a(async(se,Q,ne,J)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",se);let me=se.indexOf("/",1),ye=me>0?se.slice(0,me):se;g({cmd:"publish",topic:se,payload:await E(Q),messageId:ne||Math.floor(Math.random()*1e8),qos:J.qos},ye);let Pe=e._socket??e;return Pe.writableNeedDrain?new Promise(he=>Pe.once("drain",he)):!Pe.closed}catch(me){return hr.error?.(me),o?.disconnect(),s.sessions.delete(o),!1}},"listener");o.setListener(T),o.sessionWasPresent&&await o.resume();break;case"subscribe":let b=[];for(let se of d.subscriptions){let Q;try{let ne=await o.addSubscription(se,se.qos>=1);Q=ne?ne.qos||0:c.protocolVersion<5?128:143}catch(ne){s.events.emit("error",ne,e,se,o),ne.statusCode?ne.statusCode===500?hr.warn?.(ne):hr.info?.(ne):hr.error?.(ne),Q=c.protocolVersion<5?128:ne.statusCode===403?135:ne.statusCode===404?143:128}b.push(Q)}await o.committed,g({cmd:"suback",granted:b,messageId:d.messageId});break;case"unsubscribe":{let se=[];for(let Q of d.unsubscriptions)se.push(o.removeSubscription(Q)?0:17);g({cmd:"unsuback",granted:se,messageId:d.messageId});break}case"pubrel":g({cmd:"pubcomp",messageId:d.messageId,reasonCode:0});return;case"publish":let v=d.qos===2?"pubrec":"puback",F=e.deserialize||(e.deserialize=uo(r?.headers.get?.("content-type"))),Y=(d.payload?.length||0)>0?F(d.payload):void 0,Z;try{Z=await o.publish(d,Y)}catch(se){s.events.emit("error",se,e,d,o),hr.warn?.(se),d.qos>0&&g({cmd:v,messageId:d.messageId,reasonCode:128},d.topic);break}d.qos>0&&g({cmd:v,messageId:d.messageId,reasonCode:Z===!1?144:0},d.topic);break;case"pubrec":g({cmd:"pubrel",messageId:d.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(d.messageId);break;case"pingreq":g({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),Qn(!0,"connection","mqtt","disconnect"),hr.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(T){s.events.emit("error",T,e,d,o),hr.error?.(T),g({cmd:"disconnect"})}function g(T,b){let v=(0,tA.generate)(T,c);t(v),sr(v.length,"bytes-sent",b,R(T),"mqtt")}a(g,"sendPacket");function R(T){return T.qos>0?T.cmd+",qos="+T.qos:T.cmd}a(R,"packetMethodName");function E(T){return Aa(T,r)}a(E,"serialize")}),l.on("error",d=>{hr.warn("MQTT parsing error, closing connection:",d.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:u,onClose:f}}var tA,tj,sf,uP,rj,eA,hr,nj,Zz,ZT,sj=be(()=>{tA=require("mqtt-packet");Xz();tj=M(Rn());ao();ki();Vr();sf=M(ae());H();uP=M(Ni()),rj=require("events"),eA=(0,uP.loggerWithTag)("auth-event"),hr=(0,uP.loggerWithTag)("mqtt"),nj=(0,sf.get)(x.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(cTe,"bypassAuth");a(lTe,"start");ZT=0;a(ej,"onSocket")});var zp={};ve(zp,{component_errors:()=>af,getComponentName:()=>pTe,loadComponent:()=>sA,loadComponentDirectories:()=>lj,setErrorReporter:()=>_Te});function lj(e,t){t&&(_P=t),e&&(EP=e);let r=[];if((0,ut.existsSync)(fP)){let s=(0,ut.readdirSync)(fP,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,St.join)(fP,o);r.push(sA(c,_P,KA,!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(sA(n,_P,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{cj=!0})}function _Te(e){Ph=e}async function sA(e,t,r,n,s,i){let o=(0,ut.realpathSync)(e);if(rA.has(o))return rA.get(o);rA.set(o,!0),s&&(EP=s);try{let c;n&&(af=new Map);let l=(0,St.join)(e,"harperdb-config.yaml");(0,ut.existsSync)(l)?c=n?(0,iA.getConfigObj)():(0,pP.parseDocument)((0,ut.readFileSync)(l,"utf8")).toJSON():!n&&(0,ut.existsSync)(l=(0,St.join)(e,"config.yaml"))?c=(0,pP.parseDocument)((0,ut.readFileSync)(l,"utf8")).toJSON():c=gP;let u=(0,St.join)(e,"node_modules","harperdb");try{jl.isMainThread&&(n||((0,ut.existsSync)(u)||!e.startsWith((0,mP.getHdbBasePath)()))&&(!(0,ut.existsSync)(u)||(0,ut.realpathSync)(hP.PACKAGE_ROOT)!==(0,ut.realpathSync)(u)))&&((0,ut.rmSync)(u,{recursive:!0,force:!0}),(0,ut.existsSync)((0,St.join)(e,"node_modules"))||(0,ut.mkdirSync)((0,St.join)(e,"node_modules")),(0,ut.symlinkSync)(hP.PACKAGE_ROOT,u,"dir"))}catch(p){of.default.error("Error symlinking harperdb module",p)}let f=nA,d=n;for(let p in c){nA=p;let _=c[p];if(af.set(n?p:(0,St.basename)(e),!1),!_)continue;let h,S=_.package;try{if(S){let b=e,v;for(;!(0,ut.existsSync)(v=(0,St.join)(b,"node_modules",p));)if(b=(0,St.dirname)(b),b.length<(0,mP.getHdbBasePath)().length){v=null;break}if(v)h=await sA(v,t,r,!1),d=!0;else throw new Error(`Unable to find package ${p}:${S}`)}else h=fTe[p];if(!h)continue;let g=a(b=>(b.origin=r,ft(b)),"ensureTable"),R=_.network||(_.port||_.securePort)&&_,E=R?.securePort||R?.https&&R.port,T=!R?.https&&R?.port;if(jl.isMainThread&&(h=await h.startOnMainThread?.({server:We,ensureTable:g,port:T,securePort:E,resources:t,..._})||h,n&&R))for(let b of[T,E])try{if(+b&&!ij.includes(b)){let v=SP.get(x.HTTP_SESSIONAFFINITY);v&&of.default.warn("Session affinity is not recommended and may cause memory leaks"),(v||!gT)&&(ij.push(b),XC(b,v))}}catch(v){console.error("Error listening on socket",b,v,p)}if(t.isWorker&&(h=await h.start?.({server:We,ensureTable:g,port:T,securePort:E,resources:t,..._})||h),EP.set(h,!0),(h.handleFile||h.handleDirectory||h.setupFile||h.setupDirectory)&&_.files!=null){if(_.files.includes(".."))throw(0,aj.handleHDBError)("Can not reference parent directories");let b=(0,St.join)(e,_.files).replace(/\\/g,"/"),v=b.indexOf("/*");if(v>-1&&_.files!==gP[p]?.files&&!(0,ut.existsSync)(b.slice(0,v)))throw new Error(`The path '${b.slice(0,v)}' does not exist and cannot be used as the base of the resolved 'files' path value '${_.files}'`);let F=(0,St.basename)(e),q=_.path||"/";q=q.startsWith("/")?q:q.startsWith("./")?"/"+F+q.slice(2):q==="."?"/"+F:"/"+F+"/"+q;let Y,Z,se;if(_.root){let ne=_.root;ne.startsWith("/")&&(ne=ne.slice(1)),ne.endsWith("/")&&(ne=ne.slice(0,-1)),ne+="/",Z=(0,St.join)(e,ne)}else(se=b.indexOf("/*"))>-1?(Z=b.slice(0,se+1),Y=(0,St.relative)(e,Z)):_.files.indexOf("/")>-1&&(Z=b.slice(0,b.lastIndexOf("/")+1),Y=(0,St.relative)(e,Z));let Q=!1;if(jl.isMainThread&&h.setupDirectory&&(Q=await h.setupDirectory?.(q,Z,t)),t.isWorker&&h.handleDirectory&&(Q=await h.handleDirectory?.(q,Z,t)),Q){d=!0;continue}for(let ne of await(0,oj.default)(b,{onlyFiles:!1,objectMode:!0})){let{path:J,dirent:me}=ne;d=!0;let ye=(0,St.relative)(e,J).replace(/\\/g,"/");if(Y)if(ye.startsWith(Y))ye=ye.slice(Y.length+1);else throw new Error(`The root path '${_.root}' does not reference a valid part of the file path '${ye}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let Pe=q+(q.endsWith("/")?"":"/")+ye;try{if(me.isFile()){let he=await dTe(J);jl.isMainThread&&await h.setupFile?.(he,Pe,J,t),t.isWorker&&await h.handleFile?.(he,Pe,J,t)}else jl.isMainThread&&await h.setupDirectory?.(Pe,J,t),t.isWorker&&await h.handleDirectory?.(Pe,J,t)}catch(he){let Nt=`Could not load ${me.isFile()?"file":"directory"} '${J}'${_.module?` using '${_.module}'`:""} for application '${e}' due to:
133
- `;he.message=`${Nt}${he.message}`,he.stack=`${Nt}${he.stack}`,Ph?.(he),of.default.error(he),t.set(_.path||"/",new ga(he)),af.set(n?p:(0,St.basename)(e),he.message)}}}}catch(g){g.message=`Could not load component '${p}' for application '${(0,St.basename)(e)}' due to: ${g.message}`,Ph?.(g),((0,Dh.getWorkerIndex)()===0?console:of.default).error(g),t.set(_.path||"/",new ga(g),null,!0),af.set(n?p:(0,St.basename)(e),g.message)}}if(nA=f,jl.isMainThread&&!cj&&i&&(0,Dh.watchDir)(e,async()=>lj()),c.extensionModule){let p=await jE((0,St.join)(e,c.extensionModule));return rA.set(o,p),p}if(!d&&t.isWorker){let p=`${e} did not load any modules, resources, or files, is this a valid component?`;Ph?.(new Error(p)),((0,Dh.getWorkerIndex)()===0?console:of.default).error(p),af.set((0,St.basename)(e),p)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,Ph?.(c),t.set("",new ga(c))}}var ut,St,jl,pP,SP,hP,oj,Dh,of,aj,mP,uTe,iA,dTe,fP,EP,cj,_P,af,fTe,gP,ij,rA,Ph,nA,pTe,jp=be(()=>{ut=require("fs"),St=require("path"),jl=require("worker_threads"),pP=require("yaml"),SP=M(ae()),hP=M(it());H();HL();AM();JB();eH();tH();BH();mY();RY();bY();oj=M(require("fast-glob")),Dh=M(rt()),of=M(z());oO();Vr();aj=M(pe());De();BC();mP=M(ae()),uTe=M(Hz());vS();Yz();Xn();sj();iA=M(yt());ZI();SR();({readFile:dTe}=ut.promises),fP=(0,iA.resolvePath)(SP.get(x.COMPONENTSROOT)),EP=new Map,af=new Map;a(lj,"loadComponentDirectories");fTe={REST:tg,rest:tg,graphql:HR,graphqlSchema:RR,roles:iO,jsResource:cO,fastifyRoutes:WI,login:uO,static:zI,operationsApi:uTe,customFunctions:{},http:{},clustering:iP,replication:wo,authentication:Gp,mqtt:dP,loadEnv:jI},gP={rest:!0,graphqlSchema:{files:"*.graphql"},roles:{files:"roles.yaml"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(gP,"static",{value:{files:"web/**"}});ij=[],rA=new Map;a(_Te,"setErrorReporter");pTe=a(()=>nA,"getComponentName");a(sA,"loadComponent")});var $T=w((I0e,dj)=>{var{isMainThread:uj}=require("worker_threads"),{getTables:hTe,getDatabases:N0e,table:w0e}=(De(),C(nt)),{loadComponentDirectories:mTe,loadComponent:ETe}=(jp(),C(zp)),{resetResources:gTe}=(Tu(),C(vL)),STe=$w(),TTe=yt(),{dirname:ATe}=require("path"),{getConnection:RTe}=ir(),yTe=ae(),{CONFIG_PARAMS:bTe}=(H(),C(G)),{loadCertificates:OTe}=Zn(),TP=new Map;async function NTe(e=!1){!uj&&yTe.get(bTe.CLUSTERING_ENABLED)&&RTe();try{uj&&await STe()}catch(n){console.error(n)}let t=gTe();hTe(),t.isWorker=e,await OTe(),await ETe(ATe(TTe.getConfigFilePath()),t,"hdb",!0,TP),await mTe(TP,t);let r=[];for(let[n]of TP)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(NTe,"loadRootComponents");dj.exports.loadRootComponents=NTe});var rt=w((P0e,Si)=>{"use strict";nm();var{Worker:wTe,MessageChannel:ITe,parentPort:Zi,isMainThread:OP,threadId:CTe,workerData:eo}=require("worker_threads"),{PACKAGE_ROOT:PTe}=it(),{join:hj,isAbsolute:DTe,extname:LTe}=require("path"),{server:mj}=(Vr(),C(Au)),{watch:MTe,readdir:vTe}=require("fs/promises"),{totalmem:fj}=require("os"),cf=(H(),C(G)),Ej=ae(),gi=z(),{randomBytes:UTe}=require("crypto"),{_assignPackageExport:xTe}=Ti(),_j=1024*1024,_c=[],Hs=[],BTe=50,NP=1e4,HTe="restart",gj="request_thread_info",Sj="resource_report",Tj="thread_info",Aj="added-port",kTe="ack",AP;xTe("threads",Hs);Si.exports={startWorker:RP,restartWorkers:IP,shutdownWorkers:VTe,workers:_c,setMonitorListener:XTe,onMessageFromWorkers:KTe,onMessageByType:Ij,broadcast:WTe,broadcastWithAcknowledgement:jTe,setChildListenerByType:$Te,getWorkerIndex:Rj,getWorkerCount:yj,getTicketKeys:Oj,setMainIsWorker:GTe,setTerminateTimeout:FTe,restartNumber:eo?.restartNumber||1};Hs.onMessageByType=Ij;Hs.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=Hs.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};Si.exports.whenThreadsStarted=new Promise(e=>{Si.exports.threadsHaveStarted=e});var wP;function FTe(e){NP=e}a(FTe,"setTerminateTimeout");function Rj(){return eo?eo.workerIndex:wP?0:void 0}a(Rj,"getWorkerIndex");function yj(){return eo?eo.workerCount:wP?1:void 0}a(yj,"getWorkerCount");function GTe(e){wP=e,Si.exports.threadsHaveStarted()}a(GTe,"setMainIsWorker");var bj=1,oA;function Oj(){return oA||(oA=OP?UTe(48):eo.ticketKeys,oA)}a(Oj,"getTicketKeys");Object.defineProperty(mj,"workerIndex",{get(){return Rj()}});Object.defineProperty(mj,"workerCount",{get(){return yj()}});var Nj={[gj](e,t){JTe(t)},[Sj](e,t){QTe(t,e)}};function RP(e,t={}){let r=process.constrainedMemory?.()||fj();r=Math.min(r,fj(),2e4*_j);let n=Ej.get(cf.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/_j/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let l of Hs){let u=new ITe;u.existingPort=l,i.push(u),o.push(u.port2)}LTe(e)||(e+=".js");let c=new wTe(DTe(e)?e:hj(PTe,e),{resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps","--expose-internals"],argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(l=>l.existingPort.threadId),workerIndex:t.workerIndex,workerCount:bj=t.threadCount,name:t.name,restartNumber:Si.exports.restartNumber,ticketKeys:Oj()},transferList:o,...t});for(let{port1:l,existingPort:u}of i)u.postMessage({type:Aj,port:l,threadId:c.threadId},[l]);return cA(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>RP(e,t),c.on("error",l=>{gi.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{_c.splice(_c.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<BTe?(t.unexpectedRestarts=c.unexpectedRestarts+1,RP(e,t)):gi.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{Nj[l.type]?.(l,c)}),_c.push(c),eAe(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(RP,"startWorker");var qTe=[cf.THREAD_TYPES.HTTP];async function IP(e=null,t=Math.max(bj>3,1),r=!0){if(OP){try{process.chdir(process.cwd())}catch(o){gi.error("Unable to reestablish current working directory",o)}if(r){let{loadRootComponents:o}=$T();await o()}Si.exports.restartNumber++,t<1&&(t=t*_c.length);let n=[],s=[];for(let o of _c.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;gi.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:Si.exports.restartNumber,type:cf.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=qTe.indexOf(o.name)>-1,l=new Promise(u=>{let f=setTimeout(()=>{gi.warn("Thread did not voluntarily terminate, terminating from the outside",o.threadId),o.terminate()},NP*2).unref();o.on("exit",()=>{clearTimeout(f),n.splice(n.indexOf(l)),!c&&r&&o.startCopy(),u()})});if(n.push(l),c&&r){let u=o.startCopy(),f=new Promise(d=>{let p=a(_=>{_.type===cf.ITC_EVENT_TYPES.CHILD_STARTED&&(gi.trace("Worker has started",u.threadId),d(),s.splice(s.indexOf(f)),u.off("message",p))},"startListener");gi.trace("Waiting for worker to start",u.threadId),u.on("message",p)});s.push(f),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=za();r&&(e==="http"||!e)&&Ej.get(cf.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else Zi.postMessage({type:HTe,workerType:e})}a(IP,"restartWorkers");function $Te(e,t){Nj[e]=t}a($Te,"setChildListenerByType");function VTe(e){return IP(e,1/0,!1)}a(VTe,"shutdownWorkers");var wj=[];function KTe(e){wj.push(e)}a(KTe,"onMessageFromWorkers");var yP=new Map;function Ij(e,t){let r=yP.get(e);r||yP.set(e,r=[]),r.push(t)}a(Ij,"onMessageByType");var YTe=10;async function WTe(e,t){let r=0;for(let n of Hs)try{n.postMessage(e),r++>YTe&&(r=0,await new Promise(setImmediate))}catch(s){gi.error("Unable to send message to worker",s)}t&&Pj(e,null)}a(WTe,"broadcast");var aA=new Map,zTe=1;function jTe(e){return new Promise(t=>{let r=0;for(let n of Hs)try{let s=zTe++,i=a(()=>{aA.delete(s),--r===0&&t(),n!==Zi&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,aA.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of aA)o.port===n&&o()})),n.postMessage(e),r++}catch(s){gi.error("Unable to send message to worker",s)}r===0&&t()})}a(jTe,"broadcastWithAcknowledgement");function JTe(e){e.postMessage({type:Tj,workers:Cj()})}a(JTe,"sendThreadInfo");function Cj(){let e=Date.now();return _c.map(t=>({threadId:t.threadId,name:t.name,heapTotal:t.resources?.heapTotal,heapUsed:t.resources?.heapUsed,externalMemory:t.resources?.external,arrayBuffers:t.resources?.arrayBuffers,sinceLastUpdate:e-t.resources?.updated,...t.recentELU}))}a(Cj,"getChildWorkerInfo");function QTe(e,t){e.resources=t,e.resources.updated=Date.now()}a(QTe,"recordResourceReport");var bP;function XTe(e){bP=e}a(XTe,"setMonitorListener");var ZTe=1e3,pj=!1;function eAe(){pj||(pj=!0,setInterval(()=>{for(let e of _c){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}bP&&bP()},ZTe).unref())}a(eAe,"startMonitoring");var tAe=1e3;if(Zi&&eo?.addPorts){cA(Zi);for(let e=0,t=eo.addPorts.length;e<t;e++){let r=eo.addPorts[e];r.threadId=eo.addThreadIds[e],cA(r)}setInterval(()=>{let e=process.memoryUsage();Zi.postMessage({type:Sj,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},tAe).unref(),AP=a(()=>new Promise((e,t)=>{Zi.on("message",r),Zi.postMessage({type:gj});function r(n){n.type===Tj&&(Zi.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else AP=Cj;Si.exports.getThreadInfo=AP;function cA(e,t){Hs.push(e),e.on("message",r=>{if(r.type===Aj)r.port.threadId=r.threadId,cA(r.port);else if(r.type===kTe){let n=aA.get(r.id);n&&n()}else Pj(r,e)}).on("close",()=>{Hs.splice(Hs.indexOf(e),1)}).on("exit",()=>{Hs.splice(Hs.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(cA,"addPort");function Pj(e,t){for(let n of wj)n(e,t);let r=yP.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){gi.error(s)}}a(Pj,"notifyMessageListeners");if(OP){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await vTe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(hj(s,o.name));try{for await(let{filename:o}of MTe(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await IP(),console.log("Reloaded HarperDB components, changed files:",Array.from(r)),r.clear()},100)}catch(o){console.warn("Error trying to watch component directory",s,o)}},"watch_dir");Si.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else Zi.on("message",async e=>{let{type:t}=e;t===cf.ITC_EVENT_TYPES.SHUTDOWN&&(Si.exports.restartNumber=e.restartNumber,Zi.unref(),setTimeout(()=>{gi.warn("Thread did not voluntarily terminate",CTe),process.exit(0)},NP).unref())})});var hB={};ve(hB,{ACTION_32_BIT:()=>zm,ACTION_64_BIT:()=>sAe,AUDIT_STORE_OPTIONS:()=>xp,Decoder:()=>Sl,HAS_BLOBS:()=>Fn,HAS_CURRENT_RESIDENCY_ID:()=>kc,HAS_EXPIRATION_EXTENDED_TYPE:()=>n_,HAS_ORIGINATING_OPERATION:()=>r_,HAS_PREVIOUS_RESIDENCY_ID:()=>Fc,REMOTE_SEQUENCE_UPDATE:()=>vg,createAuditEntry:()=>Nu,getLastRemoved:()=>TN,openAuditStore:()=>dA,readAuditEntry:()=>It,removeAuditEntry:()=>fA,setAuditRetention:()=>nAe,transactionKeyEncoder:()=>kj});function dA(e){let t=e.auditStore=e.openDB(CP.AUDIT_STORE_NAME,{create:!1,...xp});t||(t=e.auditStore=e.openDB(CP.AUDIT_STORE_NAME,xp),Lj(t,1)),t.rootStore=e,t.tableStores=[];let r=[];t.addDeleteRemovalCallback=function(l,u,f){return r[l]=f,t.tableStores[l]=u,t.deleteCallbacks=r,{remove(){delete r[l]}}};let n=null,s,i=0,o=DP;Ah(t.env.path,l=>{if(i=l,l)return c(100)});function c(l){l&&(o=l),clearTimeout(n);let u=new Promise(f=>{n=setTimeout(async()=>{if(await s,s=u,t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let d=0,p,_;try{for(let{key:h,value:S}of t.getRange({start:1,snapshot:!1,end:Date.now()-PP/(1+i*i)})){try{p=fA(t,h,S)}catch(g){lf.warn("Error removing audit entry",g)}if(_=h,await new Promise(setImmediate),++d>=rAe){o=10;break}}await p}finally{d===0?o=Math.min(o<<1,PP/10):(Lj(t,_),o>100&&(o=o>>1)),f(void 0),c()}},o).unref()});return u}if(a(c,"scheduleAuditCleanup"),t.scheduleAuditCleanup=c,(0,Mh.getWorkerIndex)()===(0,Mh.getWorkerCount)()-1&&c(),(0,Mh.getWorkerIndex)()===0&&!Dj)for(let l of t.getKeys({reverse:!0,limit:1}))l>Date.now()&&(Dj=!0,lf.error("The current time is before the last recorded entry in the audit log. Time reversal can undermine the integrity of data tracking and certificate validation and the time must be corrected."));return t}function fA(e,t,r){let n=iAe(r),s;if(n&Fn){s=It(r);let i=e.tableStores[s.tableId],o=i?.getEntry(s.recordId);(!o||o.version!==s.version||!o.value)&&vc(()=>Ta(s.getValue(i)),i.rootStore)}if((n&15)===LP){s=s||It(r);let i=s.tableId;e.tableStores[s.tableId]?.getEntry(s.recordId).version===s.version&&e.deleteCallbacks?.[i]?.(s.recordId,s.version)}return e.remove(t)}function Lj(e,t){MP[0]=t,e.put(Symbol.for("last-removed"),Fj)}function TN(e){let t=e.get(Symbol.for("last-removed"));if(t)return Fj.set(t),MP[0]}function nAe(e,t=DP){PP=e,DP=t}function Nu(e,t,r,n,s,i,o,c,l,u,f,d,p){let _=Gj[o];if(!_)throw new Error(`Invalid audit entry type ${o}`);let h=1;if(n&&(n>1?pc.setFloat64(0,n):ks.set(zR),h=9),l){if(l&255)throw new Error("Illegal extended type");h+=3}R(s),R(t),g(r),pc.setFloat64(h,e),h+=8,l&kc&&R(u),l&Fc&&R(f),l&n_&&(pc.setFloat64(h,d),h+=8),l&r_&&R(qj[p]),i?g(i):ks[h++]=0,l?pc.setUint32(n?8:0,_|l|3221225472):ks[n?8:0]=_;let S=ks.subarray(0,h);if(c)return Buffer.concat([S,c]);return S;function g(E){let T=h;h+=1,h=(0,Jl.writeKey)(E,ks,h);let b=h-T-1;b>127?b>16383?(lf.error("Key or username was too large for audit entry",E),h=T+1,ks[T]=0):(ks.copyWithin(T+2,T+1,h),pc.setUint16(T,b|32768),h++):ks[T]=b}function R(E){E<128?ks[h++]=E:E<16384?(pc.setUint16(h,E|32768),h+=2):E<1056964608?(pc.setUint32(h,E|3221225472),h+=4):(ks[h]=255,pc.setUint32(h+1,E),h+=5)}}function iAe(e){let t=0;e[0]==66&&(t=8);let r=e[t];if(r<128)return r;let n=e.dataView||(e.dataView=new Sl(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function It(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new Sl(e.buffer,e.byteOffset,e.byteLength));n.position=t;let s;e[n.position]==66&&(s=n.readFloat64());let i=n.readInt(),o=n.readInt(),c=n.readInt(),l=n.readInt(),u=n.position,f=n.position+=l,d=n.readFloat64(),p,_,h,S;if(i&kc&&(p=n.readInt()),i&Fc&&(_=n.readInt()),i&n_&&(h=n.readFloat64()),i&r_){let T=n.readInt();S=qj[T]}l=n.readInt();let g=n.position,R=n.position+=l,E;return{type:Gj[i&7],tableId:c,nodeId:o,get recordId(){return(0,Jl.readKey)(e,u,f)},getBinaryRecordId(){return e.subarray(u,f)},version:d,previousLocalTime:s,get user(){return R>g?(0,Jl.readKey)(e,g,R):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(T,b,v){if(i&lA||i&Lh&&!b)return E||(E=vc(()=>T.decoder.decode(e.subarray(n.position,r)),T.rootStore)),E;if(i&Lh&&v)return Vb(T.getEntry(this.recordId),v,T)},getBinaryValue(){return i&(lA|Lh)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:p,previousResidencyId:_,expiresAt:h,originatingOperation:S}}catch(n){return lf.error("Reading audit entry error",n,e),{}}}var Jl,uA,CP,Mh,Hj,lf,ks,pc,kj,xp,PP,rAe,MP,Fj,DP,Dj,lA,Lh,Mj,LP,vj,Uj,xj,Bj,zm,sAe,vg,kc,Fc,r_,n_,Fn,Gj,qj,Sl,fo=be(()=>{Jl=require("ordered-binary"),uA=M(ae()),CP=M(xt());H();Mh=M(rt()),Hj=M(ie());wu();lf=M(z());xE();gs();UT();(0,uA.initSync)();ks=Buffer.alloc(2816),pc=new DataView(ks.buffer,ks.byteOffset,2816),kj={writeKey(e,t,r){return e===t_?(t.set(t_,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,Jl.writeKey)(e,t,r)},readKey(e,t,r){return e[t]===66?(e.dataView||(e.dataView=new DataView(e.buffer,e.byteOffset,e.byteLength))).getFloat64(t):(0,Jl.readKey)(e,t,r)}},xp={encoding:"binary",keyEncoder:kj},PP=(0,Hj.convertToMS)((0,uA.get)(x.LOGGING_AUDITRETENTION))||86400*3,rAe=1e3,MP=new Float64Array(1),Fj=new Uint8Array(MP.buffer),DP=1e4,Dj=!1;a(dA,"openAuditStore");a(fA,"removeAuditEntry");a(Lj,"updateLastRemoved");a(TN,"getLastRemoved");a(nAe,"setAuditRetention");lA=16,Lh=32,Mj=1,LP=2,vj=3,Uj=4,xj=5,Bj=6,zm=14,sAe=15,vg=11,kc=512,Fc=1024,r_=2048,n_=4096,Fn=8192,Gj={put:Mj|lA,[Mj]:"put",delete:LP,[LP]:"delete",message:vj|lA,[vj]:"message",invalidate:Uj|Lh,[Uj]:"invalidate",patch:xj|Lh,[xj]:"patch",relocate:Bj,[Bj]:"relocate"},qj={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};a(Nu,"createAuditEntry");a(iAe,"readAction");a(It,"readAuditEntry");Sl=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t;return t=this.getUint8(this.position++),t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch(t){throw t.message=`Error reading float64: ${t.message} at position ${this.position}`,t}}}});function xP(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=Vj,oAe(e.primaryStore,e.auditStore)):(c=$j,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{Kj($j[i])})));let l=c[i]||(c[i]=[]);if(l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now()),s?.scope==="full-database")return;let u=l[o];u||(u=l[o]=new Map,u.envs=l,u.tableId=o,u.store=e.primaryStore),t=Su(t);let f=new UP(r);f.startTime=n;let d=u.get(t);return d?d.push(f):(u.set(t,d=[f]),d.tables=u,d.key=t),f.subscriptions=d,f}function Kj(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),Yj(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=It(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,l=Su(c),u=0;do{let f=o.get(l);if(f){for(let p of f)if(!(u>0&&!(p.includeDescendants&&!(p.onlyChildren&&u>1)))){if(p.startTime>=n){(0,vP.info)("omitting",c,p.startTime,n);continue}try{let _;p.supportsTransactions&&p.txnInProgress!==i.version&&(_=!0,p.txnInProgress||(r?r.push(p):r=[p]),p.txnInProgress=i.version),p.listener(c,i,n,_)}catch(_){console.error(_),(0,vP.info)(_)}}}if(l==null)break;let d=l.lastIndexOf?.("/",l.length-2);d!==l.length-1&&u++,d>-1?l=l.slice(0,d+1):l=null}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function oAe(e,t){let r=t||e,n=r.env;if(!n.hasAfterCommitListener){n.hasAfterCommitListener=!0;let s=n.path;r.on("aftercommit",({next:i,last:o,txnId:c})=>{let l=Vj[s];if(!l)return;let u=a(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),l.txnTime=r.threadLocalWrites[0]||Date.now();try{Kj(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function Yj(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function HF(e){return e.nextTransaction||(xP({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),Yj(e)),e.nextTransaction}var vP,$j,Vj,UP,AN=be(()=>{vP=M(z());pu();Tu();fo();$j=Object.create(null),Vj=Object.create(null);a(xP,"addSubscription");UP=class extends Bn{static{a(this,"Subscription")}listener;subscriptions;startTime;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;if(t){let r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};a(Kj,"notifyFromTransactionData");a(oAe,"listenToCommits");a(Yj,"nextTransaction");a(HF,"whenNextTransaction")});var II={};ve(II,{EVICTED:()=>ma,INVALIDATED:()=>mn,coerceType:()=>hA,makeTable:()=>EA,setServerUtilities:()=>pAe});function EA(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:l,schemaDefined:u,dbisDB:f,sealed:d,splitSegments:p,replicate:_}=e,{expirationMS:h,evictionMS:S,audit:g,trackDeletes:R}=e;S??=0;let{attributes:E}=e;E||(E=[]);let T=QR(i,n,l),b,v,F={},q=Promise.resolve(),Y,Z,se;for(let V of E)(V.assignCreatedTime||V.name==="__createdtime__")&&(Y=V),(V.assignUpdatedTime||V.name==="__updatedtime__")&&(Z=V),V.expiresAt&&(se=V),V.isPrimaryKey&&(F=V);let Q,ne=[],J=[],me=1,ye=2,Pe={},he={},Nt=864e5,dt=0,br,hs,Un,ou=!1,au,HA=new Map,kA=new Map,vt,Ef,Jh=Xl.get(x.REPLICATION_DATABASES);if(Array.isArray(Jh)){for(let V of Jh)if(V.name===c&&V.replicateTo>=0){Ef=V.replicateTo;break}}let Qh=i.getRange({start:!1,end:!1}).constructor,gf=10,Xh=6;g&&Af(),Ah(i.env.path,V=>{if(v)return aa(V)});class Ie extends $r{#e;#t;#n;#r;#s;#i;static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=g;static databasePath=o;static databaseName=c;static attributes=E;static replicate=_;static sealed=d;static splitSegments=p??!0;static createdTimeProperty=Y;static updatedTimeProperty=Z;static propertyResolvers;static userResolvers={};static sources=[];static getResidencyById;static get expirationMS(){return h}static dbisDB=f;static schemaDefined=u;static sourcedFrom(m,A){if(A&&(this.sourceOptions=A,(A.expiration||A.eviction||A.scanInterval)&&this.setTTLExpiration(A)),A?.intermediateSource)m.intermediateSource=!0,this.sources.unshift(m);else{if(this.sources.some(N=>!N.intermediateSource)){if(this.sources.some(N=>N.name===m.name))return;throw new Error("Can not have multiple canonical (non-intermediate) sources")}this.sources.push(m)}v=v||m.get&&(!m.get.reliesOnPrototype||m.prototype.get),b=b||m.load;let I=a(N=>{let L=this.sources;if(L=L.filter(k=>k.intermediateSource&&k[N]&&(!k[N].reliesOnPrototype||k.prototype[N])),L.length>0)if(L.length===1){let k=L[0];return(D,B,$)=>{if(D?.source!==k)return k[N](B,$,D)}}else return(k,D,B)=>{let $=[];for(let j of L){if(k?.source===j)break;$.push(j[N](D,B,k))}return Promise.all($)}},"getApplyToIntermediateSource"),y=this.sources[this.sources.length-1];y.intermediateSource&&(y={});let O=a(N=>{if(y[N]&&(!y[N].reliesOnPrototype||y.prototype[N]))return(L,k,D)=>{if(!L?.source)return y[N](k,D,L)}},"getApplyToCanonicalSource");Pe={put:O("put"),patch:O("patch"),delete:O("delete"),publish:O("publish")},he={put:I("put"),patch:I("patch"),delete:I("delete"),publish:I("publish"),invalidate:I("invalidate")};let P=y.shouldRevalidateEvents;return(async()=>{let N=!1,L,k=a(async(D,B)=>{let $=D.value,j=D.table?qe[c][D.table]:Ie;if(c===bf&&(D.table===fu.ROLE_TABLE_NAME||D.table===fu.USER_TABLE_NAME)&&(N=!0),D.id===void 0&&(D.id=$[j.primaryKey],D.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(D));D.source=m;let oe={residencyId:Rc(D.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:D.nodeId},U=await j.getResource(D.id,B,oe);switch(D.finished&&await D.finished,D.type){case"put":return P?U._writeInvalidate($,oe):U._writeUpdate($,!0,oe);case"patch":return P?U._writeInvalidate($,oe):U._writeUpdate($,!1,oe);case"delete":return U._writeDelete(oe);case"publish":return U._writePublish($,oe);case"invalidate":return U._writeInvalidate($,oe);case"relocate":return U._writeRelocate(oe);default:Ue.default.error?.("Unknown operation",D.type,D.id)}},"writeUpdate");try{let D=m.subscribe;D&&R==null&&(R=!0);let B={crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0},$=m.subscribeOnThisThread?m.subscribeOnThisThread((0,Ql.getWorkerIndex)(),B):(0,Ql.getWorkerIndex)()===0,j=D&&$&&await m.subscribe?.(B);if(j){let oe;for await(let U of j)try{if(!(U.type==="transaction"?U.writes[0]:U)){Ue.default.error?.("Bad subscription event",U);continue}if(U.source=m,U.type==="end_txn"){if(oe?.resolve(),U.localTime&&L!==U.localTime){if(U.remoteNodeIds?.length>0){let fe=[Symbol.for("seq"),U.remoteNodeIds[0]],te=f.get(fe),W=te?.nodes;W||(W=[]);for(let Ee of U.remoteNodeIds.slice(1)){let Se=W.find(tt=>tt.id===Ee);W=W.filter(tt=>tt.id!==Ee||tt===Se),Se||(Se={id:Ee,seqId:0},W.push(Se)),Se.seqId=Math.max(te?.seqId??1,U.localTime),Ee===oe?.nodeId&&(Se.lastTxnTime=U.timestamp)}let _e=Math.max(te?.seqId??1,U.localTime);Ue.default.trace?.("Received txn",c,new Date(_e),new Date(U.localTime),U.remoteNodeIds),f.put(fe,{seqId:_e,nodes:W})}L=U.localTime}U.onCommit&&oe?.committed.then(U.onCommit);continue}if(oe)if(U.beginTxn)oe.resolve();else{oe.write_promises.push(k(U,oe));continue}!U.timestamp&&U.version&&(U.timestamp=U.version);let ce=wt(U,()=>{if(U.type==="transaction"){let fe=[];for(let te of U.writes)try{fe.push(k(te,U))}catch(W){throw W.message+=" writing "+JSON.stringify(te)+" of event "+JSON.stringify(U),W}return Promise.all(fe)}else if(U.type==="define_schema"){let fe=this.attributes.slice(0),te;for(let W of U.attributes)fe.find(_e=>_e.name===W.name)||(fe.push(W),te=!0);te&&(ft({table:s,database:c,attributes:fe,origin:"cluster"}),Uh.signalSchemaChange(new xh.SchemaEventMsg(process.pid,Yt.CREATE_TABLE,c,s)))}else return U.beginTxn?(oe=U,oe.write_promises=[k(U,U)],new Promise(fe=>{oe.resolve=()=>fe(Promise.all(oe.write_promises))})):k(U,U)});oe&&(oe.committed=ce),N&&ce&&!ce?.waitingForUserChange&&(ce.then(()=>Uh.signalUserChange(new xh.UserEventMsg(process.pid))),ce.waitingForUserChange=!0),U.onCommit&&(ce?ce.then(U.onCommit):U.onCommit())}catch(ue){Ue.default.error?.("error in subscription handler",ue)}}}catch(D){Ue.default.error?.(D)}})(),this}static get isCaching(){return v}static get shouldRevalidateEvents(){return this.prototype.get!==Ie.prototype.get}static getResource(m,A,I){let y=super.getResource(m,A,I);if(m!=null){Cr(m);try{if(y.getRecord?.())return y;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let O=!I?.async||i.cache?.get?.(m),P=Gr(A),N=P.getReadTxn();if(N?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return cu(m,A,{transaction:N,ensureLoaded:I?.ensureLoaded},O,L=>{if(L?Ie._updateResource(y,L):y.#e=null,A.onlyIfCached&&A.noCacheStore){if(!y.doesExist())throw new Ir.ServerError("Entry is not cached",504)}else if(I?.ensureLoaded){let k=un(m,L,A,y);if(k)return P?.disregardReadTxn(),y.#i=!0,HP(k,D=>(Ie._updateResource(y,D),y))}return y})}catch(O){throw O.message.includes("Unable to serialize object")&&(O.message+=": "+JSON.stringify(m)),O}}return y}static _updateResource(m,A){m.#r=A,m.#e=A?.value??null,m.#n=A?.version}ensureLoaded(){let m=un(this.getId(),this.#r,this.getContext());if(m)return this.#i=!0,HP(m,A=>{this.#r=A,this.#e=A.value,this.#n=A.version})}static getNewId(){let m=F?.type;if(m==="String"||m==="ID")return super.getNewId();if(!vt){let O=i.getEntry(Symbol.for("id_allocation")),P=O?.value,N;if(P&&P.nodeName===server.hostname&&(!mAe(i)||P.pid===process.pid)){let L=P.start,k=P.end;N=L;for(let D of i.getKeys({start:k,end:L,limit:1,reverse:!0}))N=D}else P=y(O?.version??null),N=P.start;vt=new BigInt64Array([BigInt(N)+1n]),vt=new BigInt64Array(i.getUserSharedBuffer("id",vt.buffer)),vt.maxSafeId=P.end}let A=Number(Atomics.add(vt,0,1n)),I=m==="Int"?512:1048576;if(A+I>=vt.maxSafeId){let O=a(P=>{vt.maxSafeId=A+(m==="Int"?1023:4194303);let N=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,L=P?void 0:i.useReadTransaction(),k=Number(vt[0]);for(let $ of i.getKeys({start:k+1,end:N,limit:1,transaction:L}))N=$;L?.done();let{value:D,version:B}=i.getEntry(Symbol.for("id_allocation"));if(vt.maxSafeId<N){if(D.end>vt.maxSafeId-100)return;Ue.default.info?.("New id allocation",A,vt.maxSafeId,B),i.put(Symbol.for("id_allocation"),{start:D.start,end:vt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),B)}else{Ue.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${vt.maxSafeId}, but id of ${N} detected`);let $=y(B);$.alreadyUpdated||Atomics.store(vt,0,BigInt($.start+1)),vt.maxSafeId=$.end}},"updateEnd");A+I===vt.maxSafeId?setImmediate(O):A+100>=vt.maxSafeId&&(Ue.default.warn?.(`Synchronous id allocation required on table ${s}${m=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>O(!0)))}return A;function y(O){let P=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,N=P/4,L,k,D=!1,B,$;do{B=Math.floor(Math.random()*P),$={start:B,end:B+(m==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},L=0;for(let j of i.getKeys({start:B,limit:1,reverse:!0}))L=j;k=P;for(let j of i.getKeys({start:B+1,end:P,limit:1}))k=j;N*=.875,N<1e3&&!D&&(D=!0,Ue.default.error?.(`Id allocation in table ${s} is very dense, limited safe range of numbers to allocate ids in${m==="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`,B,L,k,N))}while(!(N<k-B&&(N<B-L||L===0)));return i.transactionSync(()=>{let j=i.getEntry(Symbol.for("id_allocation"));return(j?.version??null)==O?(Ue.default.info?.("Allocated new id range",$),i.put(Symbol.for("id_allocation"),$,Date.now()),$):(Ue.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...j.value})})}}static setTTLExpiration(m){if(typeof m=="number")h=m*1e3,S||(S=0);else if(m&&typeof m=="object")h=m.expiration*1e3,S=(m.eviction||0)*1e3,Nt=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(h<0)throw new Error("Expiration can not be negative");Nt=Nt||(h+S)/4,aa()}static getResidencyRecord(m){return f.get([Symbol.for("residency_by_id"),m])}static setResidency(m){Ie.getResidency=m}static setResidencyById(m){Ie.getResidencyById=m}static getResidency(m,A){if(Ie.getResidencyById)return Ie.getResidencyById(m[t]);let I=Ef;if(A.replicateTo!=null){if(Array.isArray(A.replicateTo))return A.replicateTo.includes(server.hostname)?A.replicateTo:[server.hostname,...A.replicateTo];A.replicateTo>=0&&(I=A.replicateTo)}if(I>=0&&server.nodes){let y=[server.hostname];if(A.previousResidency)y.push(...A.previousResidency.slice(0,I));else{let O=server.nodes.map(L=>L.name),P=Math.floor(O.length*Math.random());y.push(...O.slice(P,P+I));let N=P+I-O.length;N>0&&y.push(...O.slice(0,N))}return y}}static enableAuditing(m=!0){g=m,m&&Af(),Ie.audit=m}static coerceId(m){return m===""?null:hA(m,F)}static async dropTable(){delete qe[c][s];for(let m of i.getRange({versions:!0,snapshot:!1,lazy:!0}))m.metadataFlags&Fn&&m.value&&Ta(m.value);if(c===o){for(let m of E)f.remove(Ie.tableName+"/"+m.name),r[m.name]?.drop();f.remove(Ie.tableName+"/"),i.drop(),await f.committed}else console.log("legacy dropTable"),await i.close(),await pA.default.remove(data_path),await pA.default.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));Uh.signalSchemaChange(new xh.SchemaEventMsg(process.pid,Yt.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this.isCollection)return this.search(m);if(this.getId()===null)return m?.conditions?this.search(m):{records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:E};if(m?.property)return this.getProperty(m.property);if(this.doesExist()||m?.ensureLoaded===!1||this.getContext()?.returnNonexistent)return this}allowRead(m,A){let I=Tf(m);if(I?.read){if(I.isSuperUser)return!0;let y=I.attribute_permissions,O=A?.select;if(y?.length>0||ou&&O){if(A||(A={}),O){let P=y?.length>0&&BP(y,"read");A.select=O.map(N=>{let L=N.name||N;if(!P||P[L]){let k=Un[L]?.definition?.tableClass;if(k){if(N.name||(N={name:N}),!k.prototype.allowRead.call(null,m,N))return!1;if(!N.select)return N.name}return N}}).filter(Boolean)}else A.select=y.filter(P=>P.read&&!Un[P.attribute_name]).map(P=>P.attribute_name);return A}else return!0}}allowUpdate(m,A){let I=Tf(m);if(I?.update){let y=I.attribute_permissions;if(y?.length>0){let O=BP(y,"update");for(let P in A)if(!O[P])return!1;for(let P of y){let N=P.attribute_name;!P.update&&!(N in A)&&(A[N]=this.getProperty(N))}}return oa(this.getContext())}}allowCreate(m,A){if(this.isCollection){let I=Tf(m);if(I?.insert){let y=I.attribute_permissions;if(y?.length>0){let O=BP(y,"insert");for(let P in A)if(!O[P])return!1;return oa(this.getContext())}else return oa(this.getContext())}}else return this.allowUpdate(m,{})}allowDelete(m){return Tf(m)?.delete&&oa(this.getContext())}update(m,A){if(!Gr(this.getContext()))throw new Error("Can not update a table resource outside of a transaction");if(m===!1)return this;let y;return typeof m=="object"&&m&&(A?(Object.isFrozen(m)&&(m={...m}),this.#e={},this.#t=m):(y=this.#t,y&&(m=Object.assign(y,m)),this.#t=m)),this._writeUpdate(this.#t,A),this}addTo(m,A){if(typeof A=="number"||typeof A=="bigint")this.#s===zj?this.set(m,(+this.getProperty(m)||0)+A):(this.#s||this.update(),this.set(m,new kE(A)));else throw new Error("Can not add a non-numeric value")}subtractFrom(m,A){if(typeof A=="number")return this.addTo(m,-A);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this.#r}getRecord(){return this.#e}getChanges(){return this.#t}_setChanges(m){this.#t=m}setRecord(m){this.#e=m}invalidate(){this._writeInvalidate()}_writeInvalidate(m,A){let I=this.getContext(),y=this.getId();Cr(y),Gr(this.getContext()).addWrite({key:y,store:i,invalidated:!0,entry:this.#r,before:Pe.invalidate?.bind(this,I,y),beforeIntermediate:he.invalidate?.bind(this,I,y),commit:a((P,N)=>{if(!(ia(P,N,A?.nodeId)<=0)){m??=null;for(let L in r)m||(m={}),m[L]===void 0&&(m[L]=this.getProperty(L));Ue.default.trace?.(`Invalidating entry id: ${y}, timestamp: ${new Date(P).toISOString()}`),T(y,m,this.#r,P,mn,g,{user:I?.user,residencyId:A?.residencyId,nodeId:A?.nodeId},"invalidate")}},"commit")})}_writeRelocate(m){let A=this.getContext(),I=this.getId();Cr(I),Gr(this.getContext()).addWrite({key:I,store:i,invalidated:!0,entry:this.#r,before:Pe.relocate?.bind(this,A,I),beforeIntermediate:he.relocate?.bind(this,A,I),commit:a((O,P)=>{if(ia(O,P,m?.nodeId)<=0)return;let N=Ie.getResidencyRecord(m.residencyId),L=0,k=null,D=P?.value;if(N&&!N.includes(server.hostname)){for(let B in r)k||(k={}),k[B]=D(B);L=mn}else k=D;Ue.default.trace?.(`Relocating entry id: ${I}, timestamp: ${new Date(O).toISOString()}`),T(I,k,this.#r,O,L,g,{user:A.user,residencyId:m.residencyId,nodeId:m.nodeId,expiresAt:m.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(m,A){let I={previousResidency:this.getResidencyRecord(m.residencyId),isRelocation:!0},y=Ac(this.getResidency(A.value,I)),O;if(y){if(!y.includes(server.hostname))return;O=Rc(y)}let N=T(m.key,A.value,m,m.version,0,!0,{residencyId:O,expiresAt:A.expiresAt},"relocate",!1,null)}static evict(m,A,I){let y=this.Source,O;if(!((v||g)&&(!A||(O=i.getEntry(m),!O||!A)||O.version!==I))){if(v){if(i.hasLock(m,O.version))return;let P;for(let N in r)P||(P={}),P[N]=A[N];if(P)return T(m,P,O,I,ma,null,null,null,!0)}if(i.ifVersion(m,I,()=>{ln(m,A,null)}),g)return T(m,null,O,I,ma,null,null,null,!0);Hc(i,O??i.getEntry(m),I)}}lock(){throw new Error("Not yet implemented")}static operation(m,A){return m.table||=s,m.schema||=c,rJ.operation(m,A)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,A,I){let y=this.getContext(),O=Gr(y),P=this.getId();Cr(P);let N=this.#r;this.#s=A?zj:dAe;let L={key:P,store:i,entry:N,nodeName:y?.nodeName,validate:a(k=>{m||(m=this.#t),A||m&&BE(this.#t===m?this:m)?y?.source||(O.checkOverloaded(),this.validate(m,!A),Z&&(m[Z.name]=Z.type==="Date"?new Date(k):Z.type==="String"?new Date(k).toISOString():k),A&&(t&&m[t]!==P&&(m[t]=P),Y&&(N?.value?m[Y.name]=N?.value[Y.name]:m[Y.name]=Y.type==="Date"?new Date(k):Y.type==="String"?new Date(k).toISOString():k),m=sl(m))):O.removeWrite(L)},"validate"),before:A?Pe.put?()=>Pe.put(y,P,m):null:Pe.patch?()=>Pe.patch(y,P,m):Pe.put?()=>Pe.put(y,P,sl(this)):null,beforeIntermediate:A?he.put?()=>he.put(y,P,m):null:he.patch?()=>he.patch(y,P,m):he.put?()=>he.put(y,P,sl(this)):null,commit:a((k,D,B)=>{if(B){if(y&&D?.version>(y.lastModified||0)&&(y.lastModified=D.version),this.#r=D,D?.value&&D.value.getRecord)throw new Error("Can not assign a record to a record, check for circular references");A||(this.#e=D?.value??null)}this.#t=void 0,this.#n=k;let $=D?.value,j=m;this.#s=0;let oe=!1,U=ia(k,D,I?.nodeId),ue;if(U<=0)if(g){let _e=D.localTime,Ee=D.version;Ue.default.trace?.("Applying CRDT update to record with id: ",P,"applying later update:",Ee);let Se=[];for(;_e>k||Ee>=k&&_e>0;){let tt=l.get(_e);if(!tt)break;let Ye=It(tt);if(Ee=Ye.version,Ee>=k){if(Ee===k){if(U=ia(k,{version:Ee,localTime:_e},I?.nodeId),U===0)return;if(U>0)continue}if(Ye.type==="patch")Se.push(Ye),ue=m;else if(Ye.type==="put"||Ye.type==="delete")return}_e=Ye.previousLocalTime}Se.sort((tt,Ye)=>tt.version-Ye.version);for(let tt of Se){let Ye=tt.getValue(i);if(j=UE(j,Ye,A),Ue.default.debug?.("Rebuilding update with future patch:",j),!j)return}}else{if(A)return;j=UE(j,$,A),Ue.default.debug?.("Rebuilding update without audit:",j)}let ce;if(A?ce=j:(this.#e=$,ce=sl(this,j)),this.#e=ce,ce&&ce.getRecord)throw new Error("Can not assign a record to a record, check for circular references");let fe;if(I?.residencyId!=null)fe=I.residencyId;else{N?.residencyId&&(y.previousResidency=Ie.getResidencyRecord(N.residencyId));let _e=Ac(Ie.getResidency(ce,y));if(_e&&!_e.includes(server.hostname))if(ue??=ce,oe=!0,Ie.getResidencyById)ce=void 0;else{ce=null;for(let Ee in r)ce||(ce={}),ce[Ee]=ue[Ee]}fe=Rc(_e)}A||(ue=m);let te=y?.expiresAt??(h?h+Date.now():-1);Ue.default.trace?.(`Saving record with id: ${P}, timestamp: ${new Date(k).toISOString()}${te?", expires at: "+new Date(te).toISOString():""}${D?", replaces entry from: "+new Date(D.version).toISOString():", new entry"}`,(()=>{try{return JSON.stringify(ce).slice(0,100)}catch{return""}})()),ln(P,$,ce);let W=A?"put":"patch";T(P,ce,D,k,oe?mn:0,g,{omitLocalRecord:oe,user:y?.user,residencyId:fe,expiresAt:te,nodeId:I?.nodeId,originatingOperation:y?.originatingOperation},W,!1,ue),y.expiresAt&&aa()},"commit")};O.addWrite(L)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this.isCollection){for await(let A of this.search(m))(await Ie.getResource(A[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this.#e?this._writeDelete(m):!1}_writeDelete(m){let A=Gr(this.getContext()),I=this.getId();Cr(I);let y=this.getContext();return A.addWrite({key:I,store:i,entry:this.#r,nodeName:y?.nodeName,before:Pe.delete?.bind(this,y,I),beforeIntermediate:he.delete?.bind(this,y,I),commit:a((O,P,N)=>{let L=P?.value;N&&(y&&P?.version>(y.lastModified||0)&&(y.lastModified=P.version),Ie._updateResource(this,P)),!(ia(O,P,m?.nodeId)<=0)&&(ln(this.getId(),L),Ue.default.trace?.(`Deleting record with id: ${I}, txn timestamp: ${new Date(O).toISOString()}`),g||R?(T(I,null,this.#r,O,0,g,{user:y?.user,nodeId:m?.nodeId},"delete"),g||aa()):Hc(i,P))},"commit")}),!0}search(m){let A=this.getContext(),I=Gr(A);if(!m)throw new Error("No query provided");let y=m.conditions;y?y.length===void 0&&(y=y[Symbol.iterator]?Array.from(y):[y]):y=Array.isArray(m)?m:m[Symbol.iterator]?Array.from(m):[],this.getId()&&(y=[{attribute:null,comparator:Array.isArray(this.getId())?"prefix":"starts_with",value:this.getId()}].concat(y));let O,P={};function N(W,_e){let Ee;switch(_e){case"and":case void 0:if(W.length<1)throw new Error('An "and" operator requires at least one condition');Ee=!0;break;case"or":if(W.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+_e)}for(let Se of W){if(Se.conditions){Se.conditions=N(Se.conditions,Se.operator);continue}let tt=Se[0]??Se.attribute,Ye=tt==null?F:bi(E,tt);if(Ye)(Ye.type||pR[Se.comparator])&&(Se[1]===void 0?Se.value=k(Se.value,Ye):Se[1]=k(Se[1],Ye));else if(tt!=null)throw(0,Ir.handleHDBError)(new Error,`${tt} is not a defined attribute`,404);if(Se.chainedConditions)if(Se.chainedConditions.length===1&&(!Se.operator||Se.operator=="and")){let mr=Se.chainedConditions[0],ge,Qe;if(mr.comparator==="gt"||mr.comparator==="greater_than"||mr.comparator==="ge"||mr.comparator==="greater_than_equal"?(ge=Se,Qe=mr):(ge=mr,Qe=Se),ge.comparator!=="lt"&&ge.comparator!=="less_than"&&ge.comparator!=="le"&&ge.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let st=Qe.comparator==="ge"||Qe.comparator==="greater_than_equal",Vt=ge.comparator==="le"||ge.comparator==="less_than_equal";Se.comparator=(st?"ge":"gt")+(Vt?"le":"lt"),Se.value=[Qe.value,ge.value]}else throw new Error("Multiple chained conditions are not currently supported")}return W}a(N,"prepareConditions");function L(W,_e){if(m.enforceExecutionOrder)return W;for(let Ee of W)Ee.conditions&&(Ee.conditions=L(Ee.conditions,Ee.operator));return W.length>1&&_e!=="or"?(0,eJ.sortBy)(W,bm(Ie)):W}a(L,"orderConditions");function k(W,_e){return Array.isArray(W)?W.map(Ee=>hA(Ee,_e)):hA(W,_e)}a(k,"coerceTypedValues");let D=m.operator;(y.length>0||D)&&(y=N(y,D));let B=typeof m.sort=="object"&&m.sort,$;if(B&&D!=="or"){let W=B.attribute;if(W==null)throw new Ir.ClientError("Sort requires an attribute");if(O=y.find(_e=>gu(_e.attribute)===gu(W)),!O){let _e=bi(E,W);if(!_e)throw(0,Ir.handleHDBError)(new Error,`${Array.isArray(W)?W.join("."):W} is not a defined attribute`,404);if(_e.indexed)O={attribute:W,comparator:"sort"},y.push(O);else if(y.length===0&&!m.allowFullScan)throw(0,Ir.handleHDBError)(new Error,`${Array.isArray(W)?W.join("."):W} is not indexed and not combined with any other conditions`,404)}O&&(O.descending=!!B.descending)}y=L(y,D),B&&(O&&y[0]===O?B.next&&($={dbOrderedAttribute:B.attribute,attribute:B.next.attribute,descending:B.next.descending,next:B.next.next}):(O&&y.splice(y.indexOf(O),1),$=B));let j=m.select;if(y.length===0&&(y=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:y,operator:D,postOrdering:$,selectApplied:!!j};let oe=I.useReadTxn(),U=hR(y,D,Ie,oe,m,A,(W,_e)=>uu(W,j,A,oe,_e),P),ue=m.ensureLoaded!==!1;$||(U=te(U));let ce=Ie.transformEntryForSelect(j,A,oe,P,ue,!0),fe=Ie.transformToOrderedSelect(U,j,$,oe,A,ce);function te(W){return m.offset||m.limit!==void 0?W.slice(m.offset,m.limit!==void 0?(m.offset||0)+m.limit:void 0):W}return a(te,"applyOffset"),$&&(fe=te(fe)),fe.onDone=()=>{fe.onDone=null,I.doneReadTxn()},fe.selectApplied=!0,fe.getColumns=()=>{if(j){let W=[];for(let _e of j)_e==="*"?W.push(...E.map(Ee=>Ee.name)):W.push(_e.name||_e);return W}return E.filter(W=>!W.computed&&!W.relationship).map(W=>W.name)},fe}static transformToOrderedSelect(m,A,I,y,O,P){let N=new Qh;if(I){m=uu(m,A,y,O,null);let L;N.iterate=function(){let D,B=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),$,j=I.dbOrderedAttribute,oe,U,ue=!0;function ce(te){let W=te.next&&ce(te.next),_e=te.descending;return(Ee,Se)=>{let tt=lu(Ee,te.attribute,y),Ye=lu(Se,te.attribute,y),mr=_e?(0,Zl.compareKeys)(Ye,tt):(0,Zl.compareKeys)(tt,Ye);return mr===0?W?.(Ee,Se)||0:mr}}a(ce,"createComparator");let fe=ce(I);return{async next(){let te;if(D)if(te=D.next(),te.done){if($)return N.onDone&&N.onDone(),te}else return{value:await P.call(this,te.value)};L=[],oe&&L.push(oe);do if(te=await B.next(),te.done){if($=!0,L.length)break;return N.onDone&&N.onDone(),te}else{let W=te.value;if(W?.then&&(W=await W),j){let _e=lu(W,j,y);if(ue)ue=!1,U=_e;else if(_e!==U){U=_e,oe=W;break}}L.push(W)}while(!0);return I.isGrouped,L.sort(fe),D=L[Symbol.iterator](),te=D.next(),te.done?(N.onDone&&N.onDone(),te):{value:await P.call(this,te.value)}},return(){N.onDone&&N.onDone(),B.return()},throw(){N.onDone&&N.onDone(),B.throw()}}};let k=a(D=>{if(typeof A=="object"&&Array.isArray(D.attribute))for(let B=0;B<A.length;B++){let $=A[B],j;if($.name===D.attribute[0]){for(j=$.sort||($.sort={});j.next;)j=j.next;j.attribute=D.attribute.slice(1),j.descending=D.descending}else $===D.attribute[0]&&(A[B]=j={name:$,sort:{attribute:D.attribute.slice(1),descending:D.descending}})}D.next&&k(D.next)},"applySortingOnSelect");k(I)}else N.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),N=N.map(function(L){try{let k=P.call(this,L);return typeof k?.catch=="function"?k.catch(D=>{throw D.partialObject={[t]:L.key},D}):k}catch(k){throw k.partialObject={[t]:L.key},k}});return N}static transformEntryForSelect(m,A,I,y,O,P){if(m&&(m===t||m?.length===1&&m[0]===t&&Array.isArray(m))){let D=a(B=>(A?.transaction?.stale&&(A.transaction.stale=!1),B?.key??B),"transform");return m===t?D:m.asArray?B=>[D(B)]:B=>({[t]:D(B)})}let N;O&&v&&!(typeof m=="string"?[m]:m)?.every(D=>{let B;return typeof D=="object"?B=D.name:B=D,r[B]||B===t})&&(N=!0);let L,k=a(function(D){let B;if(A?.transaction?.stale&&(A.transaction.stale=!1),D!=null){if(B=D.value||D.deref?.()?.value,!B&&(D.key===void 0||D.deref)||D.metadataFlags&mn){if(D.metadataFlags&mn&&A.replicateFrom===!1&&P&&D.residencyId)return mc.SKIP;if(D=cu(D.key??D,A,{transaction:I,lazy:m?.length<4,ensureLoaded:O},this?.isSync,$=>$),D?.then)return D.then(k.bind(this));B=D?.value}if(N&&D?.metadataFlags&(mn|ma)||D?.expiresAt!=null&&D?.expiresAt<Date.now()){if(A.onlyIfCached&&A.noCacheStore)return{[t]:D.key,message:"This entry has expired"};let $=un(D.key??D,D,A);if($?.then)return $.then(k)}}if(B==null)return P?mc.SKIP:B;if(m&&!(m[0]==="*"&&m.length===1)){let $,j=a((U,ue)=>{let ce;typeof U=="object"?ce=U.name:ce=U;let fe=Un?.[ce],te;if(fe){let W=y?.[ce];if(W)if(W.hasMappings){let Ee=fe.from?B[fe.from]:gu(D.key);te=W.get(Ee),te||(te=[])}else te=W.fromRecord?.(B);else te=fe(B,A,D);let _e=a(Ee=>{if(Ee&&typeof Ee=="object"){let Se=fe.definition?.tableClass||Ie;L||(L={});let tt=L[ce]||(L[ce]=Se.transformEntryForSelect(ce===U?null:U.select||(Array.isArray(U)?U:null),A,I,W,O));if(Array.isArray(Ee)){let Ye=[],mr=Se.transformToOrderedSelect(Ee,U.select,typeof U.sort=="object"&&U.sort,A,I,tt)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),ge=a(st=>{for(;!st.done;){if(st?.then)return st.then(ge);Ye.push(st.value),st=mr.next()}ue(Ye,ce)},"nextValue"),Qe=ge(mr.next());Qe&&($||($=[]),$.push(Qe));return}else if(Ee=tt.call(this,Ee),Ee?.then){$||($=[]),$.push(Ee.then(Ye=>ue(Ye,ce)));return}}ue(Ee,ce)},"handleResolvedValue");te?.then?($||($=[]),$.push(te.then(_e))):_e(te);return}else te=B[ce],te&&typeof te=="object"&&ce!==U&&(te=Ie.transformEntryForSelect(U.select||U,A,I,null)({value:te}));ue(te,ce)},"selectAttribute"),oe;if(typeof m=="string")j(m,U=>{oe=U});else if(Array.isArray(m))if(m.asArray)oe=[],m.forEach((U,ue)=>{U==="*"?m[ue]=B:j(U,ce=>oe[ue]=ce)});else{oe={};let U=m.forceNulls;for(let ue of m)if(ue==="*")for(let ce in B)oe[ce]=B[ce];else j(ue,(ce,fe)=>{ce===void 0&&U&&(ce=null),oe[fe]=ce})}else throw new Ir.ClientError("Invalid select"+m);return $?Promise.all($).then(()=>oe):oe}return B},"transform");return k}async subscribe(m){if(!l)throw new Error("Can not subscribe to a table without an audit log");g||ft({table:s,database:c,schemaDefined:u,attributes:E,audit:!0}),m||(m={});let A=!m.rawEvents,I=[],y=this,O=xP(Ie,this.getId()??null,function(N,L,k,D){try{let B=L.getValue?.(i,A),$=L.type;if(!B&&$==="patch"&&A){let oe=i.getEntry(N);oe?.version===L.version?B=oe.value:B=L.getValue?.(i,!0,k),$="put"}let j={id:N,localTime:k,value:B,version:L.version,type:$,beginTxn:D};I?I.push(j):this.send(j)}catch(B){Ue.default.error?.(B)}},m.startTime||0,m),P=(async()=>{this.isCollection&&(O.includeDescendants=!0,m.onlyChildren&&(O.onlyChildren=!0)),m.supportsTransactions&&(O.supportsTransactions=!0);let N=this.getId(),L=m.previousCount;L>1e3&&(L=1e3);let k=m.startTime;if(this.isCollection){if(k){if(L)throw new Ir.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:D,value:B}of l.getRange({start:k,exclusiveStart:!0,snapshot:!1})){let $=It(B);if($.tableId!==n)continue;let j=$.recordId;if(N==null||Xj(N,j)){let oe=$.getValue(i,A,D);if(O.send({id:j,localTime:D,value:oe,version:$.version,type:$.type}),O.queue?.length>Jj&&await O.waitForDrain()===!1)return}O.startTime=D}}else if(L){let D=[];for(let{key:B,value:$}of l.getRange({start:"z",end:!1,reverse:!0}))try{let j=It($);if(j.tableId!==n)continue;let oe=j.recordId;if(N==null||Xj(N,oe)){let U=j.getValue(i,A,B);if(D.push({id:oe,localTime:B,value:U,version:j.version,type:j.type}),--L<=0)break}}catch(j){Ue.default.error("Error getting history entry",B,j)}for(let B=D.length;B>0;)O.send(D[--B]);D[0]&&(O.startTime=D[0].localTime)}else if(!m.omitCurrent){for(let{key:D,value:B,version:$,localTime:j}of i.getRange({start:N??!1,end:N==null?void 0:[N,Zl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(B&&(O.send({id:D,localTime:j,value:B,version:$,type:"put"}),O.queue?.length>Jj&&await O.waitForDrain()===!1))return}}else{L&&!k&&(k=0);let D=this.#r?.localTime;if(D===JR&&(i.cache?.delete(N),this.#r=i.getEntry(N),Ue.default.trace?.("re-retrieved record",D,this.#r?.localTime),D=this.#r?.localTime),Ue.default.trace?.("Subscription from",k,"from",N,D),k<D){let B=[],$=D;do{let j=l.get($);if(j){m.omitCurrent=!0;let oe=It(j),U=oe.getValue(i,A,$);A&&(oe.type="put"),B.push({id:N,value:U,localTime:$,...oe}),$=oe.previousLocalTime}else break;L&&L--}while($>k&&L!==0);for(let j=B.length;j>0;)O.send(B[--j]);O.startTime=D}!m.omitCurrent&&this.doesExist()&&O.send({id:N,localTime:D,value:this.#e,version:this.#n,type:"put"})}for(let D of I)O.send(D);I=null})();return m.listener&&O.on("data",m.listener),O}static subscribeOnThisThread(m,A){return m===0||A?.crossThreads===!1}doesExist(){return!!(this.#e||this.#s)}publish(m,A){this._writePublish(m,A)}_writePublish(m,A){let I=Gr(this.getContext()),y=this.getId()||null;y!=null&&Cr(y);let O=this.getContext();I.addWrite({key:y,store:i,entry:this.#r,nodeName:O?.nodeName,validate:a(()=>{O?.source||(I.checkOverloaded(),this.validate(m))},"validate"),before:Pe.publish?.bind(this,O,y,m),beforeIntermediate:he.publish?.bind(this,O,y,m),commit:a((P,N,L)=>{N===void 0&&R&&!g&&aa(),Ue.default.trace?.(`Publishing message to id: ${y}, timestamp: ${new Date(P).toISOString()}`),T(y,N?.value??null,N,N?.version||P,0,!0,{user:O?.user,residencyId:A?.residencyId,expiresAt:O?.expiresAt,nodeId:A?.nodeId},"message",!1,m)},"commit")})}validate(m,A){let I,y=a((O,P,N)=>{if(P.type&&O!=null)if(A&&O.__op__&&(O=O.value),P.properties){typeof O!="object"&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be an object${P.type?" ("+P.type+")":""}`);let L=P.properties;for(let k=0,D=L.length;k<D;k++){let B=L[k],$=y(O[B.name],B,N+"."+B.name);$&&(O[B.name]=$)}if(P.sealed&&O!=null&&typeof O=="object")for(let k in O)L.find(D=>D.name===k)||(I||(I=[])).push(`Property ${k} is not allowed within object in property ${N}`)}else switch(P.type){case"Int":(typeof O!="number"||O>>0!==O)&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof O!="number"||!(Math.floor(O)===O&&Math.abs(O)<=9007199254740992))&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof O!="number"&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a number`);break;case"ID":typeof O=="string"||O?.length>0&&O.every?.(L=>typeof L=="string")||(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a string, or an array of strings`);break;case"String":typeof O!="string"&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a string`);break;case"Boolean":typeof O!="boolean"&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a boolean`);break;case"Date":if(!(O instanceof Date)){if(typeof O=="string"||typeof O=="number")return new Date(O);(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a Date`)}break;case"BigInt":if(typeof O!="bigint"){if(typeof O=="string"||typeof O=="number")return BigInt(O);(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a bigint`)}break;case"Bytes":if(!(O instanceof Uint8Array)){if(typeof O=="string")return Buffer.from(O);(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a Buffer or Uint8Array`)}break;case"Blob":if(!(O instanceof wi)){if(typeof O=="string"&&(O=Buffer.from(O)),O instanceof Buffer)return createBlob(O,{type:"text/plain"});(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a Blob`)}break;case"array":if(Array.isArray(O)){if(P.elements)for(let L=0,k=O.length;L<k;L++){let D=O[L],B=y(D,P.elements,N+"[*]");B&&(O[L]=B)}}else(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be an Array`);break}P.nullable===!1&&O==null&&(I||(I=[])).push(`Property ${N} is required (and not does not allow null values)`)},"validateValue");for(let O=0,P=E.length;O<P;O++){let N=E[O];if(!(N.relationship||N.computed)&&(!A||N.name in m)){let L=y(m[N.name],N,N.name);L&&(m[N.name]=L)}}if(d)for(let O in m)E.find(P=>P.name===O)||(I||(I=[])).push(`Property ${O} is not allowed`);if(I)throw new Ir.ClientError(I.join(". "))}getUpdatedTime(){return this.#n}wasLoadedFromSource(){return v?!!this.#i:void 0}static async addAttributes(m){let A=E.slice(0);for(let I of m){if(!I.name)throw new Ir.ClientError("Attribute name is required");if(I.name.match(/[`/]/))throw new Ir.ClientError("Attribute names cannot include backticks or forward slashes");(0,tJ.validateAttribute)(I.name),A.push(I)}return ft({table:s,database:c,schemaDefined:u,attributes:A}),Ie.indexingOperation}static async removeAttributes(m){let A=E.filter(I=>!m.includes(I.name));return ft({table:s,database:c,schemaDefined:u,attributes:A}),Ie.indexingOperation}static getSize(){let m=i.getStats();return(m.treeBranchPageCount+m.treeLeafPageCount+m.overflowPages)*m.pageSize}static getAuditSize(){let m=l?.getStats();return m&&(m.treeBranchPageCount+m.treeLeafPageCount+m.overflowPages)*m.pageSize}static getStorageStats(){let m=i.env.path,A=pA.default.statfsSync?.(m)??{};return{available:A.bavail*A.bsize,free:A.bfree*A.bsize,size:A.blocks*A.bsize}}static async getRecordCount(m){let A=i.getStats().entryCount,I=1e3/2,y=performance.now(),O=Math.floor(A/2),P=m?.exactCount,N=0,L=0,k;for(let{value:D}of i.getRange({start:!0,lazy:!0,snapshot:!1}))if(D!=null&&N++,L++,await hc(),!P&&L<O&&performance.now()-y>I){k=L;break}if(k){let D=N;N=0;for(let{value:te}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:k,snapshot:!1}))te!=null&&N++,await hc();let B=k*2,$=(N+D)/B,j=Math.pow((N-D+1)/k/2,2)+$*(1-$)/B,oe=Math.max(Math.sqrt(j)*A,1),U=Math.round($*A),ue=Math.max(U-1.96*oe,N+D),ce=Math.min(U+1.96*oe,A),fe=Math.pow(10,Math.round(Math.log10(oe)));return fe>U&&(fe=fe/10),N=Math.round(U/fe)*fe,{recordCount:N,estimatedRange:[Math.round(ue),Math.round(ce)]}}return{recordCount:N}}static updatedAttributes(){Un=this.propertyResolvers={$id:a((m,A,I)=>({value:I.key}),"$id"),$updatedtime:a((m,A,I)=>I.version,"$updatedtime"),$record:a((m,A,I)=>I?{value:m}:m,"$record")};for(let m of this.attributes){m.resolve=null;let A=m.relationship,I=m.computed;if(A)if(m.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),I&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),ou=!0,A.to)m.elements?.definition?(Un[m.name]=m.resolve=(y,O,P)=>{let N=y[A.from?A.from:t],L=m.elements.definition.tableClass;return P?Eu({attribute:A.to,value:N},Gr(O).getReadTxn(),!1,L,!1).asArray:L.search([{attribute:A.to,value:N}],O).asArray},m.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},m.resolve.definition=m.elements.definition,A.from&&(m.resolve.from=A.from)):console.error(`The one-to-many/many-to-many relationship property "${m.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(A.from){let y=m.definition||m.elements?.definition;y?(Un[m.name]=m.resolve=(O,P,N)=>{let L=O[A.from];if(L!==void 0){if(m.elements){let k,D=L?.map(B=>{let $=N?y.tableClass.primaryStore.getEntry(B,{transaction:Gr(P).getReadTxn()}):y.tableClass.get(B,P);return $?.then&&(k=!0),$});return A.filterMissing?k?Promise.all(D).then(B=>B.filter(Zj)):D.filter(Zj):k?Promise.all(D):D}return N?y.tableClass.primaryStore.getEntry(L,{transaction:Gr(P).getReadTxn()}):y.tableClass.get(L,P)}},m.set=(O,P)=>{if(Array.isArray(P)){let N=P.map(L=>L.getId?.()||L[y.tableClass.primaryKey]);O[A.from]=N}else{let N=P.getId?.()||P[y.tableClass.primaryKey];O[A.from]=N}},m.resolve.definition=m.definition||m.elements?.definition,m.resolve.from=A.from):console.error(`The relationship property "${m.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${m.name}" in table "${s}" must use either "from" or "to" arguments`);else I&&(typeof I.from=="function"&&this.setComputedAttribute(m.name,I.from),Un[m.name]=m.resolve=(y,O,P)=>{let N=typeof I.from=="string"?y[I.from]:y,L=this.userResolvers[m.name];if(L)return L(N,O,P);Ue.default.warn(`Computed attribute "${m.name}" does not have a function assigned to it. Please use setComputedAttribute('${m.name}', resolver) to assign a resolver function.`),this.userResolvers[m.name]=()=>{}})}FE(this,this)}static setComputedAttribute(m,A){let I=bi(E,m);if(!I){console.error(`The attribute "${m}" does not exist in the table "${s}"`);return}if(!I.computed){console.error(`The attribute "${m}" is not defined as computed in the table "${s}"`);return}this.userResolvers[m]=A}static async deleteHistory(m=0,A=!1){let I;for(let{key:y,value:O}of l.getRange({start:0,end:m}))await hc(),It(O).tableId===n&&(I=fA(l,y,O));if(A)for(let y of i.getRange({start:0,versions:!0})){let{key:O,value:P,localTime:N}=y;await hc(),P===null&&N<m&&(I=Hc(i,y))}await I}static async*getHistory(m=0,A=1/0){for(let{key:I,value:y}of l.getRange({start:m||1,end:A})){await hc();let O=It(y);O.tableId===n&&(yield{id:O.recordId,localTime:I,version:O.version,type:O.type,value:O.getValue(i,!0,I),user:O.user,operation:O.originatingOperation})}}static async getHistoryOfRecord(m){let A=[];if(m==null)throw new Error("An id is required");let I=i.getEntry(m);if(!I)return A;let y=I.localTime;if(!y)throw new Error("The entry does not have a local audit time");let O=0;do{await hc();let P=l.get(y);if(P){let N=It(P);A.push({id:N.recordId,localTime:y,version:N.version,type:N.type,value:N.getValue(i,!0,y),user:N.user}),y=N.previousLocalTime}else break}while(O<1e3&&y);return A.reverse()}static cleanup(){Q?.remove()}}Ie.updatedAttributes();let Sf=Ie.prototype;return h&&Ie.setTTLExpiration(h/1e3),se&&du(),Ie;function ln(V,m,A){let I;for(let y in r){let O=r[y],P=O.isIndexing,N=Un[y],L=A&&(N?N(A):A[y]),k=m&&(N?N(m):m[y]);if(L===k&&!P)continue;I=!0;let D=O.indexNulls,B=(0,vh.getIndexedValues)(L,D),$=(0,vh.getIndexedValues)(k,D);if($?.length>0){let j=new Set($);if(B=B?B.filter(oe=>{if(j.has(oe))j.delete(oe);else return!0}):[],$=Array.from(j),($.length>0||B.length>0)&&Wj){let oe=$.concat(B).map(U=>({key:U,value:V}));O.prefetch(oe,Qj)}for(let oe=0,U=$.length;oe<U;oe++)O.remove($[oe],V)}else B?.length>0&&Wj&&O.prefetch(B.map(j=>({key:j,value:V})),Qj);if(B)for(let j=0,oe=B.length;j<oe;j++)O.put(B[j],V)}return I}a(ln,"updateIndices");function Cr(V){switch(typeof V){case"number":return!0;case"string":if(V.length<659)return!0;if(V.length>jj)throw new Error("Primary key size is too large: "+V.length);break;case"object":if(V===null)throw new Error("Invalid primary key of null");break;case"bigint":if(V<2n**64n&&V>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof V)}if((0,Zl.writeKey)(V,fAe,0)>jj)throw new Error("Primary key size is too large: "+V.length);return!0}a(Cr,"checkValidId");function cu(V,m,A,I,y){if(Ie.getResidencyById&&A.ensureLoaded&&m?.replicateFrom!==!1){let P=Ac(Ie.getResidencyById(V));if(P&&!P.includes(server.hostname)&&b)return b({key:V,residency:P}).then(y)}let O=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),A.transaction?.isDone)return y(null,V);let P=i.getEntry(V,A);return P?.residencyId&&P.metadataFlags&mn&&b&&A.ensureLoaded&&m?.replicateFrom!==!1?b(P).then(N=>y(N,V),N=>(Ue.default.error?.("Error loading remote record",V,P,A,N),y(null,V))):(P&&m&&(P?.version>(m.lastModified||0)&&(m.lastModified=P.version),P?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=P.localTime)),y(P,V))},"whenPrefetched");return I?O():me>0?(me--,O()):new Promise((P,N)=>{me===0?(me--,i.prefetch([V],()=>{L(),k()})):(ne.push(V),J.push(k),ne.length>Xh&&(me--,L()));function L(){if(ne.length>0){let D=J;i.prefetch(ne,()=>{me===-1?L():me++;for(let B of D)B()}),ne=[],J=[],ye>2&&ye--}else me=ye,ye<gf&&ye++}a(L,"prefetch");function k(){try{P(O())}catch(D){N(D)}}a(k,"load")})}a(cu,"loadLocalRecord");function Tf(V){if(!V?.role)return;let m=V.role.permission;if(m.super_user)return _Ae;let A=m[c],I,y=A?.tables;if(y)return y[s];if(c==="data"&&(I=m[s])&&!I.tables)return I}a(Tf,"getTablePermissions");function un(V,m,A,I){if(v){let y=!1;if(A.noCache?y=!0:(m?(!m.value||m.metadataFlags&(mn|ma)||m.expiresAt!=null&&m.expiresAt<Date.now())&&(y=!0):y=!0,Qn(!y,"cache-hit",s)),y){let O=Zh(V,m,A).then(P=>(P?.value&&P?.value.getRecord?.()&&Ue.default.error?.("Can not assign a record that is already a resource"),A&&(P?.version>(A.lastModified||0)&&(A.lastModified=P.version),A.lastRefreshed=Date.now()),P));if(A?.onlyIfCached||m?.value&&I?.allowStaleWhileRevalidate?.(m,V)){if(O.catch(P=>Ue.default.warn?.(P)),A?.onlyIfCached&&!I.doesExist())throw new Ir.ServerError("Entry is not cached",504);return}else return O}}else if(m?.value&&m.expiresAt!=null&&m.expiresAt<Date.now())return Ie.evict(m.key,m.value,m.version),m.value=null,{then(y){return y(m)}}}a(un,"ensureLoadedFromSource");function Gr(V){let m=V?.transaction;if(m){if(!m.lmdbDb)return m.lmdbDb=i,m;do{if(m.lmdbDb?.path===i.path)return m;let A=m.next;if(!A)return m=m.next=new wc,m.lmdbDb=i,m;m=A}while(!0)}else return new Am}a(Gr,"txnForContext");function lu(V,m,A){if(!V)return;let I=V.value||i.getEntry(V.key)?.value;if(typeof m=="object"){let O=Un,P=I;for(let N=0,L=m.length;N<L;N++){let k=m[N],D=O?.[k];P=D&&P?D(P,A,!0)?.value:P?.[k],O=D?.definition?.tableClass?.propertyResolvers}return P}let y=Un[m];return y?y(I,A):I[m]}a(lu,"getAttributeValue");function uu(V,m,A,I,y){let O=y?.length,P={transaction:I,lazy:O>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},N;function L(k,D){let B=k?.value;if(!B)return mc.SKIP;for(let $=0;$<O;$++)if(!N?.includes($)&&!y[$](B,k))return mc.SKIP;return D!==void 0&&(k.key=D),k}if(a(L,"processEntry"),O>0||!V.hasEntries){let k=V.map(D=>{if(N=null,typeof D=="object"&&D?.key!==void 0)return O>0?L(D):D;if(D==null)return mc.SKIP;for(let B=0;B<O;B++){let j=y[B].idFilter;if(j){if(!j(D))return mc.SKIP;N||(N=[]),N.push(B)}}return cu(D,A,P,!1,L)});return Array.isArray(V)&&(k=k.filter(D=>D!==mc.SKIP)),k.hasEntries=!0,k}return V}a(uu,"transformToEntries");function ia(V,m,A=server.replication?.getThisNodeId(l)){if(V<=m?.version){if(m?.version===V&&A!==void 0){let I=server.replication?.exportIdMapping(l),y=m.localTime,O=y&&l.get(y);if(O){let P,N,L=It(O);for(let k in I)I[k]===A&&(P=k),I[k]===L.nodeId&&(N=k);if(P>N)return 1;if(P===N)return 0}}return-1}return 1}a(ia,"precedesExistingVersion");async function Zh(V,m,A){let I=m?.metadataFlags,y=m?.version,O,P;if(!i.attemptLock(V,y,()=>{clearTimeout(P);let D=i.getEntry(V);!D||!D.value||D.metadataFlags&(mn|ma)?O(Zh(V,i.getEntry(V),A)):O(D)}))return new Promise(D=>{O=D,P=setTimeout(()=>{i.unlock(V,y)},uAe)});let N=m?.value,L={requestContext:A,replacingRecord:N,replacingEntry:m,replacingVersion:y,noCacheStore:!1,source:null,resourceCache:A?.resourceCache},k=A?.responseHeaders;return new Promise((D,B)=>{let $;HP(wt(L,async j=>{let oe=performance.now(),U,ue,ce;try{for(let _e of Ie.sources)if(_e.get&&(!_e.get.reliesOnPrototype||_e.prototype.get)){if(_e.available?.(m)===!1)continue;if(L.source=_e,U=await _e.get(V,L),U)break}ce=I&mn;let te=L.lastModified||ce&&y;ue=ce||te>y||!N,te||(te=(0,vh.getNextMonotonicTime)());let W=performance.now()-oe;if(sr(W,"cache-resolution",s,null,"success"),k&&ZE(k,"Server-Timing",`cache-resolve;dur=${W.toFixed(2)}`,!0),j.timestamp=te,h&&L.expiresAt==null&&(L.expiresAt=Date.now()+h),U){if(typeof U!="object")throw new Error("Only objects can be cached and stored in tables");if(U.status>0&&U.headers)if(U.status>=300)if(U.status===304)U=N,te=y;else throw new Ir.ServerError(U.body||"Error from source",U.status);else U=U.body;typeof U.toJSON=="function"&&(U=U.toJSON()),t&&U[t]!==V&&(U[t]=V)}$=!0,D({key:V,version:te,value:U})}catch(te){te.message+=` while resolving record ${V} for ${s}`,N&&((te.code==="ECONNRESET"||te.code==="ECONNREFUSED"||te.code==="EAI_AGAIN")&&!A?.mustRevalidate||A?.staleIfError&&(te.statusCode===500||te.statusCode===502||te.statusCode===503||te.statusCode===504))?(D({key:V,version:y,value:N}),Ue.default.trace?.(te.message,"(returned stale record)")):B(te);let W=performance.now()-oe;sr(W,"cache-resolution",s,null,"fail"),k&&ZE(k,"Server-Timing",`cache-resolve;dur=${W.toFixed(2)}`,!0),L.transaction.abort();return}if(A?.noCacheStore||L.noCacheStore){L.transaction.abort();return}Gr(L).addWrite({key:V,store:i,entry:m,nodeName:"source",commit:a((te,W)=>{if(W?.version!==y)return;let _e=ln(V,N,U);if(U){he.put?.(L,V,U),W&&(A.previousResidency=Ie.getResidencyRecord(W.residencyId));let Ee,Se=!1,tt,Ye=Ac(Ie.getResidency(U,A));if(Ye){if(!Ye.includes(server.hostname))if(Ee=U,Se=!0,Ie.getResidencyById)U=void 0;else{U=null;for(let mr in r)U||(U={}),U[mr]=Ee[mr]}tt=Rc(Ye)}Ue.default.trace?.(`Writing resolved record from source with id: ${V}, timestamp: ${new Date(te).toISOString()}`),T(V,U,W,te,Se?mn:0,g&&(ue||Se)||null,{user:L?.user,expiresAt:L.expiresAt,residencyId:tt},"put",!!ce,Ee)}else W&&(he.delete?.(L,V),Ue.default.trace?.(`Deleting resolved record from source with id: ${V}, timestamp: ${new Date(te).toISOString()}`),g||R?T(V,null,W,te,0,g&&ue||null,{user:L?.user},"delete",!!ce):Hc(i,W,y))},"commit")})}),()=>{i.unlock(V,y)},j=>{i.unlock(V,y),$&&Ue.default.error?.("Error committing cache update",j)})})}a(Zh,"getFromSource");function oa(V){if(!V||V.user?.role?.permission?.super_user)return!0;if(V.replicateTo)throw new Ir.ClientError("Can not specify replication parameters without super user permissions",403);if(V.replicatedConfirmation)throw new Ir.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}a(oa,"checkContextPermissions");function aa(V){let m=!1;if(V&&(V-dt>1&&(m=!0),dt=V),!(Nt===br&&!m)&&(br=Nt,(0,Ql.getWorkerIndex)()===(0,Ql.getWorkerCount)()-1))return hs&&clearTimeout(hs),Nt?new Promise(A=>{let I=new Date;I.setMonth(0),I.setDate(1),I.setHours(0),I.setMinutes(0),I.setSeconds(0);let y=Nt/(1+dt),O=m?Date.now():Math.ceil((Date.now()-I.getTime())/y)*y+I.getTime(),P=a(N=>{Ue.default.trace?.(`Scheduled next cleanup scan at ${new Date(N)}`),hs=setTimeout(()=>q=q.then(async()=>{if(P(Math.max(N+Nt,Date.now())),i.rootStore.status!=="open"){clearTimeout(hs);return}let L=50,k=new Array(L),D=0,B=Math.pow(dt,8)*(Xl.get(x.STORAGE_RECLAMATION_EVICTIONFACTOR)??1e5),$=S/Math.pow(Math.max(dt,1),4);Ue.default.info?.(`Starting cleanup scan for ${s}, evict threshold ${B}, adjusted eviction ${$}ms`);function j(oe,U,ue,ce){let fe=oe+$-Date.now();if(fe<0)return!0;if(dt){let te=i.lastSize;return ue&Fn&&yu(ce,W=>{W.size&&(te+=W.size)}),Ue.default.trace?.(`shouldEvict adjusted ${fe} ${te}, ${fe*(oe-U)/te} < ${B}`),fe*(oe-U)/te<B}return!1}a(j,"shouldEvict");try{let oe=0;for(let U of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let{key:ue,value:ce,version:fe,expiresAt:te,metadataFlags:W}=U,_e;ce===null&&!g&&fe+lAe<Date.now()?_e=Hc(i,U,fe):te!=null&&j(te,fe,W,ce)&&(_e=Ie.evict(ue,ce,fe),oe++),_e&&(await k[D],k[D]=_e.catch(Ee=>{Ue.default.error?.("Cleanup error",Ee)}),++D>=L&&(D=0)),await hc()}Ue.default.info?.(`Finished cleanup scan for ${s}, evicted ${oe} entries`)}catch(oe){Ue.default.warn?.(`Error in cleanup scan for ${s}:`,oe)}A(void 0),dt=0}),Math.min(N-Date.now(),2147483647)).unref()},"startNextTimer");P(O)}):void 0}a(aa,"scheduleCleanup");function Af(){Q=l?.addDeleteRemovalCallback(n,i,(V,m)=>{i.remove(V,m)})}a(Af,"addDeleteRemoval");function du(){(0,Ql.getWorkerIndex)()===0&&setInterval(async()=>{if(!au){au=!0;try{let V=se.name,m=r[V];if(!m)throw new Error(`expiresAt attribute ${se} must be indexed`);for(let A of m.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let I of m.getValues(A)){let y=i.getEntry(I);y?.value?y.value[V]<Date.now()&&Ie.evict(I,y.value,y.version):i.ifVersion(I,y?.version,()=>m.remove(A,I))}await hc()}}catch(V){Ue.default.error?.("Error in evicting old records",V)}finally{au=!1}}},cAe).unref()}a(du,"runRecordExpirationEviction");function Ac(V){if(V!=null){if(Array.isArray(V))return V;if(typeof V=="number"){if(V>=65536)throw new Error(`Shard id ${V} must be below 65536`);let m=server.shards?.get?.(V);if(m)return Ue.default.trace?.(`Shard ${V} mapped to ${m.map(A=>A.name).join(", ")}`),m.map(A=>A.name);throw new Error(`Shard ${V} is not defined`)}throw new Error(`Shard or residency list ${V} is not a valid type, must be a shard number or residency list of node hostnames`)}}a(Ac,"residencyFromFunction");function Rc(V){if(V){let m=V.join(","),A=f.get([Symbol.for("residency_by_set"),m]);return A||(f.put([Symbol.for("residency_by_set"),m],A=Math.floor(Math.random()*2147418112)+65535),f.put([Symbol.for("residency_by_id"),A],V),A)}}a(Rc,"getResidencyId")}function BP(e,t){let r=e.attr_object||(e.attr_object={}),n=r[t];if(n)return n;n=r[t]=Object.create(null);for(let s of e)n[s.attribute_name]=s[t];return n}function Qj(){}function pAe(e){rJ=e}function hA(e,t){let r=t?.type;if(e===null)return e;if(e===""&&r&&r!=="String"&&r!=="Any")return null;try{switch(r){case"Int":case"Long":if(e[0]==="$")return _A(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return _A(+e);case"Float":return e==="null"?null:_A(+e);case"BigInt":return e==="null"?null:BigInt(e);case"Boolean":return e==="true"?!0:e==="false"?!1:e;case"Date":if(isNaN(e)){if(e==="null")return null;hAe.test(e)||(e+="Z");let n=new Date(e);return _A(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,mA.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function _A(e){if(isNaN(e))throw new SyntaxError;return e}function Xj(e,t){if(e==null)return!0;if(!Array.isArray(t))return e===t||t.startsWith?.(e);if(Array.isArray(e)){let r=e.length;if(e[r-1]===null&&r--,t.length>=r){for(let n=0;n<r;n++)if(t[n]!==e[n])return!1;return!0}return!1}else if(t[0]===e)return!0}function HP(e,t,r){return e?.then?e.then(t,r):t(e)}function Zj(e){return e!=null}function Fs(e){try{return JSON.stringify(e)}catch{return e}}function mAe(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var mc,vh,eJ,tJ,Xl,Ir,Uh,xh,Ue,Zl,Ql,mA,pA,aAe,rJ,cAe,lAe,Wj,uAe,zj,dAe,mn,ma,fAe,jj,Jj,_Ae,axe,hAe,hc,qf=be(()=>{H();mc=require("lmdb"),vh=M(_n()),eJ=require("lodash"),tJ=M(xf());Ea();Rm();Xl=M(ae());AN();Ir=M(pe()),Uh=M(To()),xh=M(ri());De();Gf();Ue=M(Ni());Wb();Ic();Zl=require("ordered-binary"),Ql=M(rt());fo();mA=M(ie());wu();ki();xE();z_();pA=M(require("node:fs"));gs();UT();aAe=new Uint8Array(9);aAe[8]=192;cAe=6e4,lAe=864e5;Xl.initSync();Wj=Xl.get(x.STORAGE_PREFETCHWRITES),uAe=1e4,zj=1,dAe=2,mn=1,ma=8,fAe=Buffer.allocUnsafeSlow(8192),jj=1978,Jj=100,_Ae={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},axe=(0,mA.convertToMS)(Xl.get(x.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(EA,"makeTable");a(BP,"attributesAsObject");a(Qj,"noop");a(pAe,"setServerUtilities");hAe=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(hA,"coerceType");a(_A,"rejectNaN");a(Xj,"isDescendantId");hc=a(()=>new Promise(setImmediate),"rest");a(HP,"when");a(Zj,"exists");a(Fs,"stringify");a(mAe,"hasOtherProcesses")});var nt={};ve(nt,{database:()=>qu,database_envs:()=>ea,databases:()=>qe,dropDatabase:()=>Xb,dropTableMeta:()=>AAe,getDatabases:()=>Xe,getDefaultCompression:()=>CS,getTables:()=>EAe,onRemovedDB:()=>pp,onUpdatedTable:()=>Tl,readMetaDb:()=>Bh,resetDatabases:()=>Dd,table:()=>ft,tables:()=>Jn});function EAe(){return AA||Xe(),Jn||{}}function Xe(){if(AA)return qe;AA=!0,ff=new Map;let e=(0,Zt.getHdbBasePath)()&&(0,Lt.join)((0,Zt.getHdbBasePath)(),Nc),t=(0,Zt.get)(x.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,Zt.get)(x.STORAGE_PATH)||e&&((0,us.existsSync)(e)?e:(0,Lt.join)((0,Zt.getHdbBasePath)(),om)),!e)return;if((0,us.existsSync)(e))for(let n of(0,us.readdirSync)(e,{withFileTypes:!0})){let s=(0,Lt.basename)(n.name,".mdb");n.isFile()&&(0,Lt.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&Bh((0,Lt.join)(e,n.name),null,s)}if((0,us.existsSync)((0,df.getBaseSchemaPath)())){for(let n of(0,us.readdirSync)((0,df.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,Lt.join)((0,df.getBaseSchemaPath)(),n.name),i=(0,Lt.join)((0,df.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,us.readdirSync)(s,{withFileTypes:!0}))if(o.isFile()&&(0,Lt.extname)(o.name).toLowerCase()===".mdb"){let c=(0,Lt.join)(i,o.name);Bh((0,Lt.join)(s,o.name),(0,Lt.basename)(o.name,".mdb"),n.name,c,!0)}}}if(t)for(let n in t){let s=t[n],i=s.path;if((0,us.existsSync)(i))for(let c of(0,us.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,Lt.extname)(c.name).toLowerCase()===".mdb"&&Bh((0,Lt.join)(i,c.name),(0,Lt.basename)(c.name,".mdb"),n);let o=s.tables;if(o)for(let c in o){let l=o[c],u=(0,Lt.join)(l.path,(0,Lt.basename)(c+".mdb"));(0,us.existsSync)(u)&&Bh(u,c,n,null,!0)}}for(let n in qe){let s=ff.get(n);if(s){let i=qe[n];n.includes("delete")&&qt.trace(`defined tables ${Array.from(s.keys())}`);for(let o in i)s.has(o)||(qt.trace(`delete table class ${o}`),delete i[o])}else if(delete qe[n],n==="data"){for(let i in Jn)delete Jn[i];delete Jn[RA]}}let r=["hdb_temp","hdb_certificate","hdb_analytics","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if(qe.system)for(let n of r)qe.system[n]&&(qe.system[n].replicate=!1);return ff=null,qe}function Dd(){AA=!1;for(let[,e]of ea)e.needsDeletion=!0;Xe();for(let[e,t]of ea)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),ea.delete(e),delete qe[t.databaseName],kh.forEach(r=>r(t.databaseName)));return qe}function Bh(e,t,r=GP,n,s){let i=new kP.default(e,!1);try{let o=ea.get(e);o?o.needsDeletion=!1:(o=(0,_f.open)(i),ea.set(e,o));let c=new eu.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(gA.INTERNAL_DBIS_NAME,c)),u=o.auditStore;u||(n?(0,us.existsSync)(n)&&(i.path=n,u=(0,_f.open)(i),u.isLegacy=!0):u=dA(o));let f=oJ(r),d=f[RA],p=new Map;for(let{key:_,value:h}of l.getRange({start:!1})){let[S,g]=_.toString().split("/");g===""?g=h.name:g||(g=S,S=t,h.name||(h.name=g,h.indexed=!h.is_hash_attribute)),d?.add(S);let R=p.get(S);R||p.set(S,R={attributes:[]}),(g==null||h.is_hash_attribute)&&(R.primary=h),g!=null&&R.attributes.push(h),Object.defineProperty(h,"key",{value:_,configurable:!0})}for(let[_,h]of p){let{attributes:S,primary:g}=h;if(!g){for(let J of S)if(J.is_hash_attribute||J.isPrimaryKey){g=J;break}if(!g){qt.warn(`Unable to find a primary key attribute on table ${_}, with attributes: ${JSON.stringify(S)}`);continue}}let R=f[_],E={},T=[],b,v,F=typeof g.audit=="boolean"?g.audit:(0,Zt.get)(x.LOGGING_AUDITLOG),q=g.trackDeletes,Y=g.expiration,Z=g.eviction,se=g.sealed,Q=g.splitSegments,ne=g.replicate;if(R)E=R.indices,T=R.attributes,R.schemaVersion++;else{b=g.tableId,b?b>=(l.get(uf)||0)&&(l.putSync(uf,b+1),qt.info(`Updating next table id (it was out of sync) to ${b+1} for ${_}`)):(g.tableId=b=l.get(uf),b||(b=1),qt.debug("Table {table_name} missing an id, assigning {table_id}"),l.putSync(uf,b+1),l.putSync(g.key,g));let J=new eu.default(!g.is_hash_attribute,g.is_hash_attribute);if(J.compression=g.compression,J.compression){let me=(0,Zt.get)(x.STORAGE_COMPRESSION_THRESHOLD)||iJ;J.compression.threshold=me}v=Jm(o.openDB(g.key,J),o),o.databaseName=r,v.tableId=b}for(let J of S){J.attribute=J.name;try{if(!J.is_hash_attribute&&(J.indexed||J.attribute&&!J.name)){if(!E[J.name]){let ye=new eu.default(!J.is_hash_attribute,J.is_hash_attribute);E[J.name]=o.openDB(J.key,ye),E[J.name].indexNulls=J.indexNulls}let me=T.find(ye=>ye.name===J.name);me?T.splice(T.indexOf(me),1,J):T.push(J)}}catch(me){qt.error("Error trying to update attribute",J,T,E,me)}}if(!R){R=aJ(f,_,EA({primaryStore:v,auditStore:u,audit:F,sealed:se,splitSegments:Q,replicate:ne,expirationMS:Y&&Y*1e3,evictionMS:Z&&Z*1e3,trackDeletes:q,tableName:_,tableId:b,primaryKey:g.name,databasePath:s?r+"/"+_:r,databaseName:r,indices:E,attributes:S,schemaDefined:g.schemaDefined,dbisDB:l})),R.schemaVersion=1;for(let J of Hh)J(R)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function oJ(e){let t=qe[e];if(t||(e==="data"?t=qe[e]=Jn:e==="system"?Object.defineProperty(qe,"system",{value:t=Object.create(null),configurable:!0}):t=qe[e]=Object.create(null)),ff&&!ff.has(e)){let r=new Set;t[RA]=r,ff.set(e,r)}return t}function aJ(e,t,r){return e[t]=r,r}function qu({database:e,table:t}){e||(e=GP),Xe();let r=oJ(e),n=(0,Lt.join)((0,Zt.getHdbBasePath)(),Nc),s=(0,Zt.get)(x.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,Zt.get)(x.STORAGE_PATH)||((0,us.existsSync)(n)?n:(0,Lt.join)((0,Zt.getHdbBasePath)(),om));let o=(0,Lt.join)(n,(i?t:e)+".mdb"),c=ea.get(o);if(!c||c.status==="closed"){let l=new kP.default(o,!1);c=(0,_f.open)(l),ea.set(o,c)}return c.auditStore||(c.auditStore=dA(c)),c}async function Xb(e){if(!qe[e])throw new Error("Schema does not exist");let t=qe[e],r;for(let n in t)r=t[n].primaryStore.rootStore,ea.delete(r.path),r.status==="open"&&(await r.close(),await Fh.remove(r.path));if(r||(r=qu({database:e,table:null}),r.status==="open"&&(await r.close(),await Fh.remove(r.path))),e==="data"){for(let n in Jn)delete Jn[n];delete Jn[RA]}delete qe[e],kh.forEach(n=>n(e)),await IR(r)}function ft(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:o,audit:c,sealed:l,splitSegments:u,replicate:f,trackDeletes:d,schemaDefined:p,origin:_}=e;r||(r=GP);let h=qu({database:r,table:t}),S=qe[r];qt.trace(`Defining ${t} in ${r}`);let g=S?.[t];if(h.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let R,E,T;p==null&&(p=!0);let b=new eu.default(!1);for(let Q of o)Q.attribute&&!Q.name?(Q.name=Q.attribute,Q.indexed=!0):Q.attribute=Q.name,Q.expiresAt&&(Q.indexed=!0);let v,F;if(g){if(R=g.primaryKey,g.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);u==null&&(u=g.splitSegments),g.attributes.splice(0,g.attributes.length,...o)}else{let Q=h.auditStore;E=o.find(ye=>ye.isPrimaryKey)||{},R=E.name,E.is_hash_attribute=E.isPrimaryKey=!0,E.schemaDefined=p,E.compression=CS(),d&&(E.trackDeletes=!0),c=E.audit=typeof c=="boolean"?c:(0,Zt.get)(x.LOGGING_AUDITLOG),n&&(E.expiration=n),s&&(E.eviction=s),u??=!1,E.splitSegments=u,typeof l=="boolean"&&(E.sealed=l),typeof f=="boolean"&&(E.replicate=f),_&&(E.origins?E.origins.includes(_)||E.origins.push(_):E.origins=[_]),qt.trace(`${t} table loading, opening primary store`);let ne=new eu.default(!1,!0);ne.compression=E.compression;let J=t+"/";if(T=h.dbisDb=h.openDB(gA.INTERNAL_DBIS_NAME,b),se(),T.get(J))return F&&F(),Dd(),ft(e);let me=Jm(h.openDB(J,ne),h);h.databaseName=r,me.tableId=T.get(uf),qt.trace(`Assigning new table id ${me.tableId} for ${t}`),me.tableId||(me.tableId=1),T.put(uf,me.tableId+1),E.tableId=me.tableId,g=aJ(S,t,EA({primaryStore:me,auditStore:Q,audit:c,sealed:l,splitSegments:u,replicate:f,trackDeletes:d,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:R,tableName:t,tableId:me.tableId,databasePath:r,databaseName:r,indices:{},attributes:o,schemaDefined:p,dbisDB:T})),g.schemaVersion=1,v=!0,T.put(J,E)}let q=g.indices;T=T||(h.dbisDb=h.openDB(gA.INTERNAL_DBIS_NAME,b)),g.dbisDB=T;let Y=[];for(let{key:Q,value:ne}of T.getRange({start:!0})){let[J,me]=Q.toString().split("/");if(me===""&&(me=ne.name),me){if(J!==t)continue}else continue;let ye=o.find(he=>he.name===me),Pe=!ye?.indexed&&ne.indexed&&!ne.isPrimaryKey;if((!ye||Pe)&&(se(),v=!0,ye||T.remove(Q),Pe)){let he=g.indices[J];he&&Y.push(he)}}let Z=[];try{for(let Q of o||[]){if((Q.relationship||Q.computed)&&(v=!0,Q.relationship))continue;let ne=t+"/"+(Q.name||"");Object.defineProperty(Q,"key",{value:ne,configurable:!0});let J=T.get(ne);if(Q.isPrimaryKey){if(J=J||T.get(ne=t+"/")||{},c!==void 0&&c!==g.audit||l!==void 0&&l!==g.sealed||f!==void 0&&f!==g.replicate||(+n||void 0)!==(+J.expiration||void 0)||(+s||void 0)!==(+J.eviction||void 0)){let ye={...J};typeof c=="boolean"&&(c&&g.enableAuditing(c),ye.audit=c),n&&(ye.expiration=+n),s&&(ye.eviction=+s),l!==void 0&&(ye.sealed=l),f!==void 0&&(ye.replicate=f),v=!0,se(),T.put(ne,ye)}continue}J?.attribute&&!J.name&&(J.indexed=!0);let me=!J||J.type!==Q.type||J.indexed!==Q.indexed||J.nullable!==Q.nullable||J.version!==Q.version||JSON.stringify(J.properties)!==JSON.stringify(Q.properties)||JSON.stringify(J.elements)!==JSON.stringify(Q.elements);if(Q.indexed){let ye=new eu.default(!0,!1),Pe=h.openDB(ne,ye);(me||J.indexingPID&&J.indexingPID!==process.pid||J.restartNumber<Gh.workerData?.restartNumber)&&(v=!0,se(),J=T.get(ne),(me||J.indexingPID&&J.indexingPID!==process.pid||J.restartNumber<Gh.workerData?.restartNumber)&&(v=!0,Q.indexNulls===void 0&&(Q.indexNulls=!0),g.primaryStore.getStats().entryCount>0&&(Q.lastIndexedKey=J?.lastIndexedKey??void 0,Q.indexingPID=process.pid,Pe.isIndexing=!0,Object.defineProperty(Q,"dbi",{value:Pe}),Z.push(Q))),T.put(ne,Q)),J?.indexNulls&&Q.indexNulls===void 0&&(Q.indexNulls=!0),Pe.indexNulls=Q.indexNulls,q[Q.name]=Pe}else me&&(v=!0,se(),T.put(ne,Q))}}finally{F&&F()}if(v&&(g.schemaVersion++,g.updatedAttributes()),qt.trace(`${t} table loading, running index`),Z.length>0||Y.length>0?g.indexingOperation=TAe(g,Z,Y):v&&SA.signalSchemaChange(new TA.SchemaEventMsg(process.pid,"schema-change",g.databaseName,g.tableName)),g.origin=_,v)for(let Q of Hh)Q(g,_!=="cluster");return(n||s||i)&&g.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),qt.trace(`${t} table loaded`),g;function se(){F||h.transactionSync(()=>({then(Q){F=Q}}))}a(se,"startTxn")}async function TAe(e,t,r){try{qt.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await SA.signalSchemaChange(new TA.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o={},c=0,l=t.length;if(await new Promise(u=>setImmediate(u)),l>0){let u;for(let d of t)(0,_f.compareKeys)(d.lastIndexedKey,u)<0&&(u=d.lastIndexedKey),d.lastIndexedKey==null&&d.dbi.clearAsync();let f=0;for(let{key:d,value:p,version:_}of e.primaryStore.getRange({start:u,lazy:l<4,versions:!0,snapshot:!1}))if(p){if(f++,s=e.primaryStore.ifVersion(d,_,()=>{for(let h=0;h<l;h++){let S=t[h],g=S.name;try{let R=S.resolve,E=p&&(R?R(p):p[g]),T=(0,nJ.getIndexedValues)(E);if(T)for(let b=0,v=T.length;b<v;b++)S.dbi.put(T[b],d)}catch(R){o[g]||(o[g]=!0,qt.error(`Error indexing attribute ${g}`,R))}}}),s.then(()=>f--,h=>{f--,qt.error(h)}),Gh.workerData&&Gh.workerData.restartNumber!==sJ.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=d,e.dbisDB.put(h.key,h);if(i)return}f>gAe?await s:f>SAe&&await new Promise(h=>setImmediate(h))}for(let d of t)delete d.lastIndexedKey,delete d.indexingPID,d.dbi.isIndexing=!1,s=e.dbisDB.put(d.key,d)}await s,await SA.signalSchemaChange(new TA.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),qt.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){qt.error("Error in indexing",n)}}function AAe({table:e,database:t}){let r=qu({database:t,table:e}),n=[],s=r.dbisDb;for(let i of s.getKeys({start:e+"/",end:e+"0"}))n.push(s.remove(i));return Promise.all(n)}function Tl(e){return Hh.push(e),{remove(){let t=Hh.indexOf(e);t>-1&&Hh.splice(t,1)}}}function pp(e){return kh.push(e),{remove(){let t=kh.indexOf(e);t>-1&&kh.splice(t,1)}}}function CS(){let e=(0,Zt.get)(x.STORAGE_COMPRESSION),t=(0,Zt.get)(x.STORAGE_COMPRESSION_DICTIONARY),r=(0,Zt.get)(x.STORAGE_COMPRESSION_THRESHOLD)||iJ,n={startingOffset:32};return t&&(n.dictionary=Fh.readFileSync(t)),r&&(n.threshold=r),e&&n}var Zt,gA,_f,Lt,us,df,eu,kP,Fh,FP,nJ,SA,TA,Gh,qt,sJ,GP,RA,iJ,Jn,qe,uf,Hh,kh,AA,ea,ff,gAe,SAe,De=be(()=>{Zt=M(ae()),gA=M(xt()),_f=require("lmdb"),Lt=require("path"),us=require("fs"),df=M(gt());qf();eu=M(s_()),kP=M(i_());H();Fh=M(require("fs-extra")),FP=M(Ti()),nJ=M(_n()),SA=M(To()),TA=M(ri()),Gh=require("worker_threads"),qt=M(z()),sJ=M(rt());fo();wu();gs();GP="data",RA=Symbol("defined-tables"),iJ=((0,Zt.get)(x.STORAGE_PAGESIZE)||4096)-60;(0,Zt.initSync)();Jn=Object.create(null),qe=Object.create(null);(0,FP._assignPackageExport)("databases",qe);(0,FP._assignPackageExport)("tables",Jn);uf=Symbol.for("next-table-id"),Hh=[],kh=[],ea=new Map;a(EAe,"getTables");a(Xe,"getDatabases");a(Dd,"resetDatabases");a(Bh,"readMetaDb");a(oJ,"ensureDB");a(aJ,"setTable");a(qu,"database");a(Xb,"dropDatabase");a(ft,"table");gAe=1e3,SAe=10;a(TAe,"runIndexing");a(AAe,"dropTableMeta");a(Tl,"onUpdatedTable");a(pp,"onRemovedDB");a(CS,"getDefaultCompression")});var ie=w((gxe,AJ)=>{"use strict";var Ec=require("path"),fJ=require("fs-extra"),Mn=z(),cJ=require("fs-extra"),yA=require("os"),RAe=require("net"),yAe=require("recursive-iterator"),yr=(H(),C(G)),{PACKAGE_ROOT:bAe}=it(),OAe=iR(),lJ=require("papaparse"),bA=require("moment"),{inspect:NAe}=require("util"),uJ=require("is-number"),Exe=require("lodash"),wAe=require("minimist"),IAe=require("https"),CAe=require("http"),{hdb_errors:OA}=pe(),PAe=/^((\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d\.\d+([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z)))$/,_J=require("util").promisify(setTimeout),DAe=100,LAe=5,MAe="",vAe=4,dJ={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};AJ.exports={isEmpty:ds,isEmptyOrZeroLength:to,arrayHasEmptyValues:BAe,arrayHasEmptyOrZeroLengthValues:HAe,buildFolderPath:kAe,isBoolean:pJ,errorizeMessage:UAe,stripFileExtension:GAe,autoCast:qAe,autoCastJSON:hJ,autoCastJSONDeep:$P,removeDir:$Ae,compareVersions:VAe,isCompatibleDataVersion:KAe,escapeRawValue:YAe,unescapeValue:WAe,stringifyProps:zAe,timeoutPromise:JAe,isClusterOperation:XAe,getClusterUser:eRe,checkGlobalSchemaTable:ZAe,getHomeDir:EJ,getPropsFilePath:jAe,promisifyPapaParse:tRe,removeBOM:gJ,createEventPromise:rRe,checkProcessRunning:nRe,checkSchemaTableExist:sRe,checkSchemaExists:SJ,checkTableExists:TJ,getStartOfTomorrowInSeconds:iRe,getLimitKey:oRe,isObject:FAe,isNotEmptyAndHasValue:xAe,autoCasterIsNumberCheck:mJ,backtickASTSchemaItems:aRe,isPortTaken:QAe,createForkArgs:cRe,autoCastBoolean:lRe,async_set_timeout:_J,getTableHashAttribute:uRe,doesSchemaExist:dRe,doesTableExist:fRe,stringifyObj:_Re,ms_to_time:pRe,changeExtension:hRe,getEnvCliRootPath:VP,noBootFile:mRe,httpRequest:ERe,transformReq:gRe,convertToMS:SRe,PACKAGE_ROOT:bAe};function UAe(e){return e instanceof Error?e:new Error(e)}a(UAe,"errorizeMessage");function ds(e){return e==null}a(ds,"isEmpty");function xAe(e){return!ds(e)&&(e||e===0||e===""||pJ(e))}a(xAe,"isNotEmptyAndHasValue");function to(e){return ds(e)||e.length===0||e.size===0}a(to,"isEmptyOrZeroLength");function BAe(e){if(ds(e))return!0;for(let t=0;t<e.length;t++)if(ds(e[t]))return!0;return!1}a(BAe,"arrayHasEmptyValues");function HAe(e){if(to(e))return!0;for(let t=0;t<e.length;t++)if(to(e[t]))return!0;return!1}a(HAe,"arrayHasEmptyOrZeroLengthValues");function kAe(...e){try{return e.join(Ec.sep)}catch{console.error(e)}}a(kAe,"buildFolderPath");function pJ(e){return ds(e)?!1:e===!0||e===!1}a(pJ,"isBoolean");function FAe(e){return ds(e)?!1:typeof e=="object"}a(FAe,"isObject");function GAe(e){return to(e)?MAe:e.slice(0,-vAe)}a(GAe,"stripFileExtension");function qAe(e){return ds(e)||e===""||typeof e!="string"?e:dJ[e]!==void 0?dJ[e]:mJ(e)===!0?Number(e):PAe.test(e)?new Date(e):e}a(qAe,"autoCast");function hJ(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(hJ,"autoCastJSON");function $P(e){if(e&&typeof e=="object"){if(Array.isArray(e))for(let t=0,r=e.length;t<r;t++){let n=e[t],s=$P(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=$P(r);n!==r&&(e[t]=n)}return e}else return hJ(e)}a($P,"autoCastJSONDeep");function mJ(e){if(e.startsWith("0.")&&uJ(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&uJ(e))}a(mJ,"autoCasterIsNumberCheck");async function $Ae(e){if(to(e))throw new Error(`Directory path: ${e} does not exist`);try{await cJ.emptyDir(e),await cJ.remove(e)}catch(t){throw Mn.error(`Error removing files in ${e} -- ${t}`),t}}a($Ae,"removeDir");function VAe(e,t){if(to(e)){Mn.info("Invalid current version sent as parameter.");return}if(to(t)){Mn.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,o=s.replace(n,"").split("."),c=i.replace(n,"").split("."),l=Math.min(o.length,c.length);for(let u=0;u<l;u++)if(r=parseInt(o[u],10)-parseInt(c[u],10),r)return r;return o.length-c.length}a(VAe,"compareVersions");function KAe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(KAe,"isCompatibleDataVersion");function YAe(e){if(ds(e))return e;let t=String(e);return t==="."?yr.UNICODE_PERIOD:t===".."?yr.UNICODE_PERIOD+yr.UNICODE_PERIOD:t.replace(yr.FORWARD_SLASH_REGEX,yr.UNICODE_FORWARD_SLASH)}a(YAe,"escapeRawValue");function WAe(e){if(ds(e))return e;let t=String(e);return t===yr.UNICODE_PERIOD?".":t===yr.UNICODE_PERIOD+yr.UNICODE_PERIOD?"..":String(e).replace(yr.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(WAe,"unescapeValue");function zAe(e,t){if(ds(e))return Mn.info("Properties object is null"),"";let r="";return e.each(function(n,s){try{if(t&&t[n]){let i=t[n];for(let o of i)r+=";"+o+yA.EOL}!to(n)&&n[0]===";"?r+=" "+n+s+yA.EOL:to(n)||(r+=n+"="+s+yA.EOL)}catch{Mn.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(zAe,"stringifyProps");function EJ(){let e;try{e=yA.homedir()}catch{e=process.env.HOME}return e}a(EJ,"getHomeDir");function jAe(){let e=Ec.join(EJ(),yr.HDB_HOME_DIR_NAME,yr.BOOT_PROPS_FILE_NAME);return fJ.existsSync(e)||(e=Ec.join(__dirname,"../","hdb_boot_properties.file")),e}a(jAe,"getPropsFilePath");function JAe(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:a(function(){clearTimeout(r)},"cancel")}}a(JAe,"timeoutPromise");async function QAe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=RAe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(QAe,"isPortTaken");function XAe(e){try{return yr.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){Mn.error(`Error checking operation against cluster ops ${t}`)}return!1}a(XAe,"isClusterOperation");function ZAe(e,t){let r=(De(),C(nt)).getDatabases();if(!r[e])return OA.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return OA.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(ZAe,"checkGlobalSchemaTable");function eRe(e,t){if(ds(t)){Mn.warn("No CLUSTERING_USER defined, clustering disabled");return}if(ds(e)||to(e)){Mn.warn("No users to search.");return}let r;try{let n=e.get(t);n&&n.role.permission.cluster_user===!0&&n.active===!0&&(r=n)}catch(n){Mn.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){Mn.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(eRe,"getClusterUser");function tRe(){lJ.parsePromise=function(e,t,r){return new Promise(function(n,s){lJ.parse(e,{header:!0,transformHeader:gJ,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(tRe,"promisifyPapaParse");function gJ(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(gJ,"removeBOM");function rRe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;Mn.info(`Got cluster status event response: ${NAe(s)}`);try{i.cancel()}catch{Mn.error("Error trying to cancel timeout.")}n(s)})})}a(rRe,"createEventPromise");async function nRe(e){let t=!0,r=0;do await _J(DAe*r++),(await OAe.findPs(e)).length>0&&(t=!1);while(t&&r<LAe);if(t)throw new Error(`process ${e} was not started`)}a(nRe,"checkProcessRunning");function sRe(e,t){let r=SJ(e);if(r)return r;let n=TJ(e,t);if(n)return n}a(sRe,"checkSchemaTableExist");function SJ(e){let{getDatabases:t}=(De(),C(nt));if(!t()[e])return OA.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(SJ,"checkSchemaExists");function TJ(e,t){let{getDatabases:r}=(De(),C(nt));if(!r()[e][t])return OA.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(TJ,"checkTableExists");function iRe(){let e=bA().utc().add(1,"d").startOf("d").unix(),t=bA().utc().unix();return e-t}a(iRe,"getStartOfTomorrowInSeconds");function oRe(){return bA().utc().format("DD-MM-YYYY")}a(oRe,"getLimitKey");function aRe(e){try{let t=new yAe(e);for(let{node:r}of t)r&&(r.columnid&&typeof r.columnid!="string"&&(r.columnid=r.columnid.toString()),r.columnid&&!r.columnid.startsWith("`")&&(r.columnid_orig=r.columnid,r.columnid=`\`${r.columnid}\``),r.tableid&&!r.tableid.startsWith("`")&&(r.tableid_orig=r.tableid,r.tableid=`\`${r.tableid}\``),r.databaseid&&!r.databaseid.startsWith("`")&&(r.databaseid_orig=r.databaseid,r.databaseid=`\`${r.databaseid}\``),r.as&&typeof r.as=="string"&&!r.as.startsWith("[")&&(r.as_orig=r.as,r.as=`\`${r.as}\``))}catch(t){Mn.error("Got an error back ticking items."),Mn.error(t)}}a(aRe,"backtickASTSchemaItems");function cRe(e){return[e]}a(cRe,"createForkArgs");function lRe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(lRe,"autoCastBoolean");function uRe(e,t){let{getDatabases:r}=(De(),C(nt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(uRe,"getTableHashAttribute");function dRe(e){let{getDatabases:t}=(De(),C(nt));return t()[e]!==void 0}a(dRe,"doesSchemaExist");function fRe(e,t){let{getDatabases:r}=(De(),C(nt));return r()[e]?.[t]!==void 0}a(fRe,"doesTableExist");function _Re(e){try{return JSON.stringify(e)}catch{return e}}a(_Re,"stringifyObj");function pRe(e){let t=bA.duration(e),r=t.seconds()>0?t.seconds()+"s":"",n=t.minutes()>0?t.minutes()+"m ":"",s=t.hours()>0?t.hours()+"h ":"",i=t.days()>0?t.days()+"d ":"";return(t.years()>0?t.years()+"y ":"")+i+s+n+r}a(pRe,"ms_to_time");function hRe(e,t){let r=Ec.basename(e,Ec.extname(e));return Ec.join(Ec.dirname(e),r+t)}a(hRe,"changeExtension");function VP(){if(process.env[yr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[yr.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=wAe(process.argv);if(e[yr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[yr.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(VP,"getEnvCliRootPath");var qP;function mRe(){if(qP)return qP;let e=VP();if(VP()&&fJ.pathExistsSync(Ec.join(e,yr.HDB_CONFIG_FILE)))return qP=!0,!0}a(mRe,"noBootFile");function ERe(e,t){let r;return e.protocol==="http:"?r=CAe:r=IAe,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8"),o.body="",o.on("data",c=>{o.body+=c}),o.on("end",()=>{n(o)})});i.on("error",o=>{s(o)}),i.write(t instanceof Buffer?t:JSON.stringify(t)),i.end()})}a(ERe,"httpRequest");function gRe(e){if(!e.schema&&!e.database){e.schema=yr.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(gRe,"transformReq");function SRe(e){let t=0;if(typeof e=="number"&&(t=e),typeof e=="string")switch(t=parseFloat(e),e.slice(-1)){case"M":t*=86400*30;break;case"D":case"d":t*=86400;break;case"H":case"h":t*=3600;break;case"m":t*=60;break}return t*1e3}a(SRe,"convertToMS")});var ae=w((NJ,wJ)=>{"use strict";var KP=require("fs-extra"),tu=require("path"),RJ=require("os"),TRe=require("properties-reader"),$h=z(),qh=ie(),Me=(H(),C(G)),NA=yt(),ARe="Error initializing environment manager",wA="BOOT_PROPS_FILE_PATH",yJ=!1,RRe={[Me.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},ta={};Object.assign(NJ,wJ.exports={BOOT_PROPS_FILE_PATH:wA,getHdbBasePath:yRe,setHdbBasePath:bRe,get:bJ,initSync:NRe,setProperty:Ke,initTestEnvironment:IRe,setCloneVar:wRe});function yRe(){return ta[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(yRe,"getHdbBasePath");function bRe(e){ta[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(bRe,"setHdbBasePath");function bJ(e){let t=NA.getConfigValue(e);return t===void 0?ta[e]:t}a(bJ,"get");function Ke(e,t){RRe[e]&&(ta[e]=t),NA.updateConfigObject(e,t)}a(Ke,"setProperty");function ORe(){let e;try{e=qh.getPropsFilePath(),KP.accessSync(e,KP.constants.F_OK|KP.constants.R_OK),yJ=!0;let t=TRe(e);return ta[Me.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(Me.HDB_SETTINGS_NAMES.INSTALL_USER),ta[Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),ta[wA]=e,!0}catch{return $h.trace(`Environment manager found no properties file at ${e}`),!1}}a(ORe,"doesPropFileExist");function NRe(e=!1){try{((yJ||ORe()||qh.noBootFile())&&!OJ||e)&&(NA.initConfig(e),ta[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=NA.getConfigValue(Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){$h.error(ARe),$h.error(t),console.error(t),process.exit(1)}}a(NRe,"initSync");var OJ=!1;function wRe(e){OJ=e}a(wRe,"setCloneVar");function IRe(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=tu.join(__dirname,"../../","unitTests");ta[wA]=tu.join(l,"hdb_boot_properties.file"),Ke(Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,tu.join(l,"settings.test")),Ke(Me.HDB_SETTINGS_NAMES.INSTALL_USER,RJ.userInfo()?RJ.userInfo().username:void 0),Ke(Me.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Ke(Me.HDB_SETTINGS_NAMES.LOG_PATH_KEY,tu.join(l,"envDir","log")),Ke(Me.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Ke(Me.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Ke(Me.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Ke(Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,tu.join(l,"envDir")),Ke(Me.CONFIG_PARAMS.STORAGE_PATH,tu.join(l,"envDir")),s&&(Ke(Me.CONFIG_PARAMS.HTTP_SECUREPORT,bJ(Me.CONFIG_PARAMS.HTTP_PORT)),Ke(Me.CONFIG_PARAMS.HTTP_PORT,null)),Ke(Me.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Ke(Me.CONFIG_PARAMS.HTTP_PORT,9926),Ke(Me.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Ke(Me.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),Ke(Me.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,qh.isEmpty(i)?!1:i),Ke(Me.CONFIG_PARAMS.HTTP_CORS,qh.isEmpty(i)?!1:i),Ke(Me.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Ke(Me.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Ke(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Ke(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Ke(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,tu.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Ke(Me.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,qh.isEmpty(c)?!1:c),o&&(Ke("CORS_ACCESSLIST",o),Ke(Me.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Ke(Me.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Ke(Me.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Ke(Me.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Ke(Me.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Ke(Me.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Ke(Me.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${wA}. Please check your boot props and settings files`;$h.fatal(r),$h.error(t)}}a(IRe,"initTestEnvironment")});var LJ=w((Axe,DJ)=>{"use strict";var CA=ae();CA.initSync();var IA=(H(),C(G)),{httpRequest:CRe}=ie(),PJ=require("path"),IJ=require("fs-extra"),PRe=require("yaml"),{packageDirectory:DRe}=(Kw(),C(Vw)),{encode:LRe}=require("cbor-x"),MRe=["describe_table","describe_all","describe_database","list_users","list_roles","drop_role","add_user","alter_user","drop_user","restart_service","restart","create_database","drop_database","create_table","drop_table","create_attribute","drop_attribute","search_by_id","insert","update","upsert","delete","search_by_value","csv_file_load","csv_url_load","cluster_get_routes","cluster_network","cluster_status","remove_node","add_component","deploy_component","package_component","drop_component","get_components","get_component_file","set_component_file","registration_info","get_fingerprint","set_license","get_job","search_jobs_by_start_date","read_log","read_transaction_log","read_audit_log","delete_transaction_logs_before","purge_stream","delete_records_before","install_node_modules","set_configuration","get_configuration","create_authentication_tokens","refresh_operation_token","system_information","sql","create_csr","sign_certificate","list_certificates","add_certificate","remove_certificate","add_ssh_key","update_ssh_key","delete_ssh_key","list_ssh_keys","set_ssh_known_hosts","get_ssh_known_hosts"],CJ={deploy:"deploy_component",package:"package_component"};DJ.exports={cliOperations:xRe,buildRequest:URe};var vRe={deploy_component:a(async e=>{if(e.package)return;let t=process.cwd();e.payload=await DRe(t,{skip_node_modules:!0,...e}),e.cborEncode=!0,e.project||(e.project=PJ.basename(t))},"deploy_component")};function URe(){let e={};for(let t of process.argv.slice(2))if(MRe.includes(t))e.operation=t;else if(CJ.hasOwnProperty(t))e.operation=CJ[t];else if(t.includes("=")){let[r,...n]=t.split("=");n=n.join("=");try{n=JSON.parse(n)}catch{}e[r]=n}return e}a(URe,"buildRequest");async function xRe(e){e.target||(e.target=process.env.CLI_TARGET);let t;if(e.target){try{t=new URL(e.target)}catch(r){try{t=new URL(`https://${e.target}:9925`)}catch{throw r}}t={protocol:t.protocol,hostname:t.hostname,port:t.port,username:e.username||t.username||process.env.CLI_TARGET_USERNAME,password:e.password||t.password||process.env.CLI_TARGET_PASSWORD,rejectUnauthorized:e.rejectUnauthorized}}else IJ.existsSync(PJ.join(CA.get(IA.CONFIG_PARAMS.ROOTPATH),IA.HDB_PID_FILE))||(console.error("HarperDB must be running to perform this operation"),process.exit()),IJ.existsSync(CA.get(IA.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET))||(console.error("No domain socket found, unable to perform this operation"),process.exit());await vRe[e.operation]?.(e);try{let r=t??{protocol:"http:",socketPath:CA.get(IA.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)};r.method="POST",r.headers={"Content-Type":"application/json"},t?.username&&(r.headers.Authorization=`Basic ${Buffer.from(`${t.username}:${t.password}`).toString("base64")}`),e.cborEncode&&(r.headers["Content-Type"]="application/cbor",e=LRe(e));let n=await CRe(r,e),s;try{s=JSON.parse(n.body)}catch{s={status:n.statusCode+" "+(n.statusMessage||"Unknown"),body:n.body}}e.json?console.log(JSON.stringify(s,null,2)):console.log(PRe.stringify(s).trim())}catch(r){let n="Error: ";if(r?.response?.data?.error)n+=r.response.data.error;else if(r?.response?.data)n+=r?.response?.data;else return console.error(r);console.error(n)}}a(xRe,"cliOperations")});var UJ=w((yxe,vJ)=>{"use strict";var MJ=require("semver/functions/major"),{packageJson:BRe}=it(),YP=process.versions&&process.versions.node?process.versions.node:void 0;vJ.exports=HRe;function HRe(){let e=BRe.engines["minimum-node"];if(YP&&MJ(YP)<MJ(e))return{error:`The minimum version of Node.js HarperDB supports is: ${e}, the currently installed Node.js version is: ${YP}. Please install a version of Node.js that is withing the defined range.`}}a(HRe,"checkNodeVersion")});var ZP=w((Nxe,r2)=>{"use strict";var xJ=require("os"),PA=require("https"),BJ=require("http"),$t=require("fs-extra"),HJ=require("yaml"),{pipeline:kJ}=require("stream/promises"),{createWriteStream:DA,ensureDir:Vh,writeFileSync:FJ}=require("fs-extra"),{join:$s}=require("path"),VJ=require("lodash"),kRe=require("minimist"),ra=require("path"),FRe=require("node:crypto"),GRe=require("properties-reader"),qs=ae(),qRe=Po(),JP=z(),LA=yt(),{restart:$Re}=za(),MA=ie(),VRe=ua(),KRe=As(),{main:vA,launch:YRe}=Qd(),{install:KJ,updateConfigEnv:WRe,setIgnoreExisting:xA}=PT(),YJ=SC(),an=(H(),C(G)),{packageJson:zRe}=it(),jRe=mh(),{sendOperationToNode:jP}=(Xn(),C(wo)),{updateConfigCert:JRe}=Zn(),{restartWorkers:QRe}=rt(),{databases:XRe}=(De(),C(nt)),{SYSTEM_TABLE_NAMES:WP,SYSTEM_SCHEMA_NAME:Oxe,CONFIG_PARAMS:Kh,OPERATIONS_ENUM:ps}=an,ZRe=1e4,eye="clone-node-config.yaml",WJ=[WP.ROLE_TABLE_NAME,WP.USER_TABLE_NAME,WP.NODE_TABLE_NAME],tye={clustering_nodename:!0,clustering_leafserver_streams_path:!0,clustering_tls_certificate:!0,clustering_tls_privatekey:!0,clustering_tls_certificateauthority:!0,logging_file:!0,logging_root:!0,logging_rotation_path:!0,operationsapi_network_domainsocket:!0,operationsapi_tls_certificate:!0,operationsapi_tls_privatekey:!0,operationsapi_tls_certificateauthority:!0,rootpath:!0,storage_path:!0,storage_audit_path:!0,databases:!0,mqtt_network_mtls_certificateauthority:!0,componentsroot:!0,tls_certificate:!0,tls_privatekey:!0,tls_certificateauthority:!0,replication_hostname:!0,replication_url:!0,cloned:!0},Fr={HDB_LEADER_USERNAME:"HDB_LEADER_USERNAME",HDB_LEADER_PASSWORD:"HDB_LEADER_PASSWORD",HDB_LEADER_URL:"HDB_LEADER_URL",REPLICATION_HOSTNAME:"REPLICATION_HOSTNAME",HDB_CLONE_OVERTOP:"HDB_CLONE_OVERTOP",CLONE_KEYS:"CLONE_KEYS",CLONE_USING_WS:"CLONE_USING_WS",NO_START:"NO_START"},sa=kRe(process.argv),pf=sa[Fr.HDB_LEADER_USERNAME]??process.env[Fr.HDB_LEADER_USERNAME],hf=sa[Fr.HDB_LEADER_PASSWORD]??process.env[Fr.HDB_LEADER_PASSWORD],nu=sa[Fr.HDB_LEADER_URL]??process.env[Fr.HDB_LEADER_URL],na=sa[Fr.REPLICATION_HOSTNAME]??process.env[Fr.REPLICATION_HOSTNAME],zJ,jJ;na&&([zJ,jJ]=na.split(":"));var QP=(sa[Fr.HDB_CLONE_OVERTOP]??process.env[Fr.HDB_CLONE_OVERTOP])==="true",JJ=sa[Kh.CLONED.toUpperCase()]??process.env[Kh.CLONED.toUpperCase()],rye=sa[Fr.CLONE_KEYS]!=="false"&&process.env[Fr.CLONE_KEYS]!=="false",QJ=(sa[Fr.CLONE_USING_WS]??process.env[Fr.CLONE_USING_WS])==="true",XJ=(sa[Fr.NO_START]??process.env[Fr.NO_START])==="true",_s,gc={},GJ,qJ,ru={},on,Mt,Gs,ro,su=!1,XP=!1,fs,mf;r2.exports=a(async function(t=!1,r=!1){if(console.info(`Starting clone node from leader node: ${nu}`),delete process.env.HDB_LEADER_URL,Mt=MA.getEnvCliRootPath(),!Mt)try{let i=$s(xJ.homedir(),an.HDB_HOME_DIR_NAME,an.BOOT_PROPS_FILE_NAME);if(await $t.pathExists(i)){let o=GRe(i);Mt=ra.parse(o.get(an.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)).dir}}catch{throw new Error("There was an error setting the clone default root path. Please set ROOTPATH using an environment or CLI variable.")}Mt?await $t.pathExists(Mt)?console.log(`Existing HarperDB install found at ${Mt}. Clone node will only clone items that do not already exist on clone.`):(console.log(`No HarperDB install found at ${Mt} starting fresh clone`),su=!0):(console.log("No HarperDB install found, starting fresh clone"),su=!0),Mt||(Mt=$s(xJ.homedir(),an.HDB_ROOT_DIR_NAME),console.log("Using default root path",Mt));let n;try{n=$s(Mt,eye),_s=HJ.parseDocument(await $t.readFile(n,"utf8"),{simpleKeys:!0}).toJSON(),console.log("Clone config file found")}catch{}let s=$s(Mt,an.HDB_CONFIG_FILE);if(await $t.pathExists(s))try{GJ=HJ.parseDocument(await $t.readFile(s,"utf8"),{simpleKeys:!0}).toJSON(),gc=LA.flattenConfig(GJ)}catch(i){console.error("Error reading existing harperdb-config.yaml on clone",i)}if(na){let i=new URL(nu);mf=`${i.protocol==="https:"?"wss://":"ws://"}${i.hostname}:${jJ||9933}`}if(QJ){await nye();return}if(gc?.cloned&&JJ!=="false")return console.log("Instance marked as cloned, clone will not run"),qs.setCloneVar(!1),qs.initSync(),vA();on=await UA({operation:ps.DESCRIBE_ALL}),await e2(),qs.setCloneVar(!1),qs.setHdbBasePath(Mt),$t.ensureDir(qs.get(an.CONFIG_PARAMS.LOGGING_ROOT)),JP.initLogSettings(),await iye(),XP||await oye(),await lye(t,r),na&&(await dye(),await ZJ()),console.info(`
134
- Successfully cloned node: `+nu),(t||XJ)&&process.exit()},"cloneNode");async function nye(){if(gc?.cloned&&JJ!=="false")return console.log("Instance marked as cloned, clone will not run"),qs.setCloneVar(!1),qs.initSync(),vA();console.log("Cloning using WebSockets");let e=Sc("system"),t=$s(e,"system.mdb"),r=$t.existsSync(t);su||!r||QP?(console.info("Clone node installing HarperDB"),process.env.TC_AGREEMENT="yes",process.env.ROOTPATH=Mt,process.env.HDB_ADMIN_USERNAME="clone-temp-admin",process.env.HDB_ADMIN_PASSWORD=FRe.randomBytes(10).toString("base64").slice(0,10),xA(!0),await KJ()):(qs.setCloneVar(!1),qs.initSync()),await vA(),await e2(!0),await JRe(),r||await XRe.system.hdb_user.delete({username:"clone-temp-admin"}),await QRe(),await sye(),console.log("Adding node to the cluster");let s=await Sd()({operation:ps.ADD_NODE,url:mf});console.log("Add node response: ",s),await ZJ(),console.log(`Successfully cloned node: ${nu} using WebSockets`),LA.updateConfigValue(Kh.CLONED,!0),XJ&&process.exit()}a(nye,"cloneUsingWS");async function sye(){let e=a(i=>{let o=0;for(let c in i){let l=i[c];typeof l=="object"&&l.last_updated_record>o&&(o=l.last_updated_record)}return o},"findMostRecentTimestamp");console.log("Getting last updated record timestamp for all database");let t={},r=await UA({operation:"describe_database",database:"system"});t.system=e(r);let n=await UA({operation:"describe_all"});for(let i in n)typeof n[i]=="object"&&(t[i]=e(n[i]));let s=$s(Mt,"tmp","lastUpdated.json");console.log("Writing last updated database timestamps to:",s),await $t.outputJson(s,t)}a(sye,"getLastUpdatedRecord");async function UA(e){return QJ?jP({url:mf},e,{rejectUnauthorized:!1}):JSON.parse((await fye(e)).body)}a(UA,"leaderReq");async function ZJ(){try{if(rye!==!1){console.log("Cloning JWT keys");let e=ra.join(Mt,an.LICENSE_KEY_DIR_NAME),t=await jP({url:mf},{operation:ps.GET_KEY,name:".jwtPublic"},{rejectUnauthorized:!1});FJ(ra.join(e,an.JWT_ENUM.JWT_PUBLIC_KEY_NAME),t.message);let r=await jP({url:mf},{operation:ps.GET_KEY,name:".jwtPrivate"},{rejectUnauthorized:!1});FJ(ra.join(e,an.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r.message)}}catch(e){console.error("Error cloning JWT keys",e)}}a(ZJ,"cloneKeys");async function e2(e=!1){console.info("Cloning configuration"),qJ=await UA({operation:ps.GET_CONFIGURATION}),ru=LA.flattenConfig(qJ);let t=_s?.componentConfig?.exclude,r={rootpath:Mt};na&&(r.replication_hostname=zJ);for(let i in ru)if(!(ru[i]!==null&&typeof ru[i]=="object"&&!(ru[i]instanceof Array)||tye[i])){if(i.includes("_package")||i.includes("_port")){if(ru[i]?.includes?.("hdb/components"))continue;if(t){let o=!1;for(let c of t)if(i.includes(c.name)){o=!0;break}if(o)continue}}gc[i]||(r[i]=ru[i])}for(let i in gc)i!=="databases"&&typeof gc[i]=="object"&&!(gc[i]instanceof Array)||(r[i]=gc[i]);let n={};if(_s?.databaseConfig?.excludeDatabases&&_s.databaseConfig.excludeDatabases.forEach(i=>{n[i.database]=!0}),_s?.clusteringConfig?.excludeDatabases&&_s.clusteringConfig.excludeDatabases.forEach(i=>{n[i.database]=!0}),Object.keys(n).length>0){r.replication_databases=[],n.system||r.replication_databases.push("system");for(let i in on)n[i]||r.replication_databases.push(i)}let s=VRe(Object.keys(an.CONFIG_PARAM_MAP),!0);Object.assign(r,s),e||(r.cloned=!0),LA.createConfigFile(r,!0)}a(e2,"cloneConfig");async function iye(){process.env.HDB_FETCH==="true"?(await cye(),process.env.NODE_TLS_REJECT_UNAUTHORIZED&&delete process.env.NODE_TLS_REJECT_UNAUTHORIZED):await aye()}a(iye,"cloneDatabases");async function oye(){if(console.info("Clone node installing HarperDB."),process.env.TC_AGREEMENT="yes",process.env.ROOTPATH=Mt,!pf)throw new Error("HDB_LEADER_USERNAME is undefined.");if(process.env.HDB_ADMIN_USERNAME=pf,!hf)throw new Error("HDB_LEADER_PASSWORD is undefined.");process.env.HDB_ADMIN_PASSWORD=hf,process.env.OPERATIONSAPI_NETWORK_PORT=qs.get(Kh.OPERATIONSAPI_NETWORK_PORT),WRe(ra.join(Mt,an.HDB_CONFIG_FILE)),xA(!0),await KJ()}a(oye,"installHDB");function Sc(e){return qs.get(an.CONFIG_PARAMS.DATABASES)?.[e]?.path||qs.get(Kh.STORAGE_PATH)||ra.join(Mt,an.DATABASES_DIR_NAME)}a(Sc,"getDBPath");async function aye(){let e=Sc("system"),t=$s(e,"system.mdb");if(await Vh(e),su||!await $t.exists(t)||QP){if(!na){console.info("Cloning system database"),await Vh(e);let r=DA(t,{overwrite:!0}),n={operation:ps.GET_BACKUP,database:"system",tables:WJ},s=await $J(n,r),i=new Date(s.date);(!fs||i<fs)&&(fs=i),await $t.utimes(t,Date.now(),i)}su||(await YJ(Mt),await t2(),xA(!0))}else XP=!0,console.log("Not cloning system database due to it already existing on clone");Gs=_s?.databaseConfig?.excludeDatabases,Gs=Gs?Gs.reduce((r,n)=>({...r,[n.database]:!0}),{}):{};for(let r in on)await $t.exists(ra.join(Sc(r),r+".mdb"))&&(console.log(`Not cloning database ${r} due to it already existing on clone`),Gs[r]=!0);ro=_s?.databaseConfig?.excludeTables,ro=ro?ro.reduce((r,n)=>({...r,[n.database==null?null:n.database+n.table]:!0}),{}):{};for(let r in on){if(Gs[r]){on[r]="excluded";continue}if(VJ.isEmpty(on[r]))continue;let n=[],s=!1;for(let d in on[r])ro[r+d]?(s=!0,on[r][d]="excluded"):n.push(on[r][d]);if(n.length===0)continue;if(na){JP.debug("Setting up tables for #{db}");let d=(De(),C(nt)).table;for(let p of n){for(let _ of p.attributes)(_.is_hash_attribute||_.is_primary_key)&&(_.isPrimaryKey=!0);d({database:r,table:p.name,attributes:p.attributes})}continue}n=n.map(d=>d.name);let i;s?(console.info(`Cloning database: ${r} tables: ${n}`),i={operation:ps.GET_BACKUP,database:r,tables:n}):(console.info(`Cloning database: ${r}`),i={operation:ps.GET_BACKUP,database:r});let o=Sc(r);await Vh(o);let c=$s(o,r+".mdb"),l=DA(c,{overwrite:!0}),u=await $J(i,l),f=new Date(u.date);(!fs||f<fs)&&(fs=f),await $t.utimes(c,Date.now(),f)}}a(aye,"cloneTablesHttp");async function cye(){let e=Sc("system"),t=$s(e,"system.mdb");if(su||!await $t.exists(t)||QP){if(!na){console.info("Cloning system database using fetch");let r={operation:ps.GET_BACKUP,database:"system",tables:WJ},n=await zP(r,!0),s=Sc("system");await Vh(s);let i=$s(s,"system.mdb");await kJ(n.body,DA(i,{overwrite:!0}));let o=new Date(n.headers.get("date"));(!fs||o<fs)&&(fs=o),await $t.utimes(i,Date.now(),new Date(n.headers.get("date")))}su||(await YJ(Mt),await t2(),xA(!0))}else XP=!0,console.log("Not cloning system database due to it already existing on clone");if(na){JP.info("Replication hostname set, not using backup to clone databases, replication will clone");return}Gs=_s?.databaseConfig?.excludeDatabases,Gs=Gs?Gs.reduce((r,n)=>({...r,[n.database]:!0}),{}):{};for(let r in on)await $t.exists(ra.join(Sc(r),r+".mdb"))&&(console.log(`Not cloning database ${r} due to it already existing on clone`),Gs[r]=!0);ro=_s?.databaseConfig?.excludeTables,ro=ro?ro.reduce((r,n)=>({...r,[n.database==null?null:n.database+n.table]:!0}),{}):{};for(let r in on){if(Gs[r]){on[r]="excluded";continue}if(VJ.isEmpty(on[r]))continue;let n=[],s=!1;for(let f in on[r])ro[r+f]?(s=!0,on[r][f]="excluded"):n.push(f);if(n.length===0)return;let i;s?(console.info(`Cloning database: ${r} tables: ${n}`),i=await zP({operation:ps.GET_BACKUP,database:r,tables:n},!0)):(console.info(`Cloning database: ${r}`),i=await zP({operation:ps.GET_BACKUP,database:r},!0));let o=Sc(r);await Vh(o);let c=new Date(i.headers.get("date")),l=$s(o,`${c.getTime()}-${r}.mdb`);await kJ(i.body,DA(l,{overwrite:!0}));let u=$s(o,r+".mdb");await $t.rename(l,u),(!fs||c<fs)&&(fs=c),await $t.utimes(u,Date.now(),c)}}a(cye,"cloneTablesFetch");async function zP(e,t=!1){let r=_s?.httpsRejectUnauthorized??!1,n=new PA.Agent({rejectUnauthorized:r});r||(process.env.NODE_TLS_REJECT_UNAUTHORIZED="0");let i={Authorization:"Basic "+Buffer.from(pf+":"+hf).toString("base64"),"Content-Type":"application/json"};t&&(i["Accept-Encoding"]="gzip");let o=await fetch(nu,{method:"POST",headers:i,body:JSON.stringify(e),agent:n,compress:!0});if(o.ok)return o;throw console.error(`HTTP Error Response: ${o.status} ${o.statusText}`),new Error(await o.text())}a(zP,"leaderHttpReqFetch");async function lye(e,t=!1){let r=await qRe.getHDBProcessInfo();r.clustering.length===0||r.core.length===0?e?await YRe(!1):(t&&await uye(),await vA()):(console.info(await $Re({operation:ps.RESTART})),await MA.async_set_timeout(ZRe)),e&&await MA.async_set_timeout(2e3)}a(lye,"startHDB");async function uye(){let e=process.argv[3];e&&e[0]!=="-"&&(await $t.exists(e)||console.error(`The folder ${e} does not exist`),$t.statSync(e).isDirectory()||console.error(`The path ${e} is not a folder`),e=await $t.realpath(e),await $t.exists(ra.join(e,an.HDB_CONFIG_FILE))?process.env.ROOTPATH=e:process.env.RUN_HDB_APP=e)}a(uye,"setAppPath");async function dye(){console.info("Setting up replication"),await KRe.setSchemaDataToGlobalAsync();let t=await Sd()({operation:ps.ADD_NODE,verify_tls:!1,url:mf,start_time:fs,authorization:{username:pf,password:hf}},!0);console.log("Add node response: ",t)}a(dye,"setupReplication");async function fye(e){let t=new PA.Agent({rejectUnauthorized:_s?.httpsRejectUnauthorized??!1}),n={Authorization:"Basic "+Buffer.from(pf+":"+hf).toString("base64"),"Content-Type":"application/json"},s=new URL(nu),i={protocol:s.protocol,host:s.hostname,method:"POST",headers:n};return s.protocol==="https:"&&(i.agent=t),s.port&&(i.port=s.port),await MA.httpRequest(i,e)}a(fye,"leaderHttpReq");async function $J(e,t){let r=new PA.Agent({rejectUnauthorized:_s?.httpsRejectUnauthorized??!1}),s={Authorization:"Basic "+Buffer.from(pf+":"+hf).toString("base64"),"Content-Type":"application/json"},i=new URL(nu),o={protocol:i.protocol,host:i.hostname,method:"POST",headers:s};return i.protocol==="https:"&&(o.agent=r,BJ=PA),i.port&&(o.port=i.port),new Promise((c,l)=>{let u=BJ.request(o,f=>{f.statusCode!==200&&l("Request to leader node failed with code: "+f.statusCode),f.pipe(t),f.on("end",()=>{t.close(),c(f.headers)})});u.on("error",f=>{l(f)}),u.write(JSON.stringify(e)),u.end()})}a($J,"leaderHttpStream");async function t2(){let e=zRe.version;if(e)await jRe.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(t2,"insertHdbVersionInfo")});var s2=w((Ixe,n2)=>{var _ye=PT(),pye=z();n2.exports=hye;async function hye(){try{await _ye.install()}catch(e){console.error("There was an error during the install."),console.error(e),pye.error(e),process.exit(1)}}a(hye,"install")});var a2=w((Pxe,o2)=>{"use strict";var mye=mS(),Eye=z(),i2="Registration failed.";async function gye(){let e;try{e=await mye.register()}catch(t){return Eye.error(`Registration error ${t}`),i2}return e||i2}a(gye,"register");o2.exports={register:gye}});var d2=w((Lxe,u2)=>{"use strict";var Sye=z(),Tye=(H(),C(G)),Aye=require("util"),Rye=require("child_process"),c2=Aye.promisify(Rye.exec),yye=Po(),Yh=Pd(),l2="Stopping HarperDB.";u2.exports=bye;async function bye(){if(console.log(l2),Sye.notify(l2),await Yh.isServiceRegistered(Tye.PROCESS_DESCRIPTORS.HDB)){Yh.enterPM2Mode();let r=await Yh.getUniqueServicesList();for(let n in r)await Yh.stop(n)}await Yh.kill();let t=await yye.getHDBProcessInfo();t.clustering.forEach(r=>{c2(`kill ${r.pid}`)}),t.core.forEach(r=>{c2(`kill ${r.pid}`)})}a(bye,"stop")});var p2=w((vxe,_2)=>{"use strict";var tD=require("fs-extra"),rD=require("path"),eD=require("yaml"),Wh=ir(),Tc=(H(),C(G)),f2=Tt(),nD=z(),Oye=Rn(),Nye=uS(),wye=cS(),Iye=Po(),zh=ae(),Cye=Qd(),Pye=ie();zh.initSync();var Vs={RUNNING:"running",STOPPED:"stopped",ERRORED:"errored",NOT_INSTALLED:"not installed"},vn={LEAF:"leaf server",HUB:"hub server"},BA;_2.exports=Dye;async function Dye(){let e={harperdb:{status:Vs.STOPPED}};if(!await Cye.isHdbInstalled()){e.harperdb.status=Vs.NOT_INSTALLED,console.log(eD.stringify(e));return}BA=zh.get(Tc.CONFIG_PARAMS.ROOTPATH);let t;try{t=Number.parseInt(await tD.readFile(rD.join(BA,Tc.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Tc.NODE_ERROR_CODES.ENOENT){nD.info("`harperdb status` did not find a hdb.pid file"),e.harperdb.status=Vs.STOPPED,console.log(eD.stringify(e));return}throw n}let r=await Iye.getHDBProcessInfo();for(let n of r.core)if(n.pid===t){e.harperdb.status=Vs.RUNNING,e.harperdb.pid=t;break}if((zh.get(Tc.CONFIG_PARAMS.REPLICATION_URL)||zh.get(Tc.CONFIG_PARAMS.REPLICATION_HOSTNAME))&&(e.replication=await Mye()),e.clustering=await Lye(r),e.clustering[vn.HUB].status===Vs.RUNNING&&e.clustering[vn.LEAF].status===Vs.RUNNING){let n=[],s=await Nye({});for(let o of s.nodes){let c={};for(let l in o)c[l.replace("_"," ")]=o[l];n.push(c)}e.clustering.network=n;let i=await wye.clusterStatus();e.clustering.replication={"node name":i.node_name,"is enabled":i.is_enabled,connections:[]};for(let o of i.connections){let c={};c["node name"]=o?.node_name,c.status=o?.status,c.ports={clustering:o?.ports?.clustering,"operations api":o?.ports?.operations_api},c["latency ms"]=o?.latency_ms,c.uptime=o?.uptime,c.subscriptions=o?.subscriptions,c["system info"]={"hdb version":o?.system_info?.hdb_version,"node version":o?.system_info?.node_version,platform:o?.system_info?.platform},e.clustering.replication.connections.push(c)}await Wh.closeConnection()}console.log(eD.stringify(e)),process.exit()}a(Dye,"status");async function Lye(e){let t={[vn.HUB]:{},[vn.LEAF]:{}};if(e.clustering.length===0)return t[vn.HUB].status=Vs.STOPPED,t[vn.LEAF].status=Vs.STOPPED,t;let{port:r}=Wh.getServerConfig(Tc.PROCESS_DESCRIPTORS.CLUSTERING_HUB),{username:n,decrypt_hash:s}=await Oye.getClusterUser();try{(await Wh.createConnection(r,n,s,!1)).close(),t[vn.HUB].status=Vs.RUNNING}catch{t[vn.HUB].status=Vs.ERRORED}let{port:i}=Wh.getServerConfig(Tc.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);try{(await Wh.createConnection(i,n,s,!1)).close(),t[vn.LEAF].status=Vs.RUNNING}catch{t[vn.LEAF].status=Vs.ERRORED}try{t[vn.HUB].pid=Number.parseInt(await tD.readFile(rD.join(BA,"clustering",f2.PID_FILES.HUB),"utf8"))}catch(o){nD.error(o),t[vn.HUB].pid=void 0}try{t[vn.LEAF].pid=Number.parseInt(await tD.readFile(rD.join(BA,"clustering",f2.PID_FILES.LEAF),"utf8"))}catch(o){nD.error(o),t[vn.LEAF].pid=void 0}return t}a(Lye,"getHubLeafStatus");async function Mye(){let e=await Pye.httpRequest({method:"POST",protocol:"http:",socketPath:zh.get(Tc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET),headers:{"Content-Type":"application/json"}},{operation:"cluster_status"});e=JSON.parse(e.body);let t={"node name":e.node_name,"is enabled":e.is_enabled,connections:[]};for(let r of e.connections)t.connections.push({"node name":r.name,url:r.url,subscriptions:r.subscriptions,replicates:r.replicates,"database sockets":r.database_sockets.map(n=>({database:n.database,connected:n.connected,latency:n.latency,"catching up from":n.catching_up_from,"thread id":n.thread_id,nodes:n.nodes}))});return t}a(Mye,"getReplicationStatus")});nm();var sD=process.env.HDB_LEADER_URL||process.argv.includes("--HDB_LEADER_URL");sD&&ae().setCloneVar(!0);var jh=require("node:fs"),h2=require("node:path"),iu=z(),m2=LJ(),{packageJson:vye,PACKAGE_ROOT:E2}=it(),Uye=UJ(),iD=(H(),C(G)),{SERVICE_ACTIONS_ENUM:cn}=iD,xye=`
131
+ `))}},25).unref()}o.close?.(()=>{if(mt.get(Qt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&Zd()==0)try{iz(cz(mt.get(Qt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,kT),o.cantCleanupProperly||Mn.warn("Had to forcefully exit the thread",kT),process.exit(0)},5e3).unref()})}if(lz||process.env.DEV_MODE)try{require("inspector").close()}catch(i){Mn.info("Could not close debugger",i)}}}).ref();let e;Oh&&!vSe&&(e=dz()),Promise.resolve(e).then(()=>{if(Zd()===0)try{DSe(FC)}catch(t){console.error("Error displaying start-up log",t)}Nh?.postMessage({type:Qt.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(uz,"startServers");function dz(){let e=[];for(let t in Xi){let r=Xi[t];if(t.includes?.("/")&&Zd()==0){bSe(t)&&iz(t),e.push(new Promise((o,c)=>{r.listen({path:t},()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),Mn.info("Domain socket listening on "+t)}).on("error",c)}));continue}let n,s=mt.get(Qt.CONFIG_PARAMS.HTTP_THREADRANGE);if(s){let o=typeof s=="string"?s.split("-"):s,c=Zd();if(c<o[0]||c>o[1])continue}let i;try{let o=t.lastIndexOf(":");o>0?Oh?n={fd:Oh(+t.slice(o+1).replace(/[\[\]]/g,""),t.slice(0,o))}:n={host:+t.slice(o+1).replace(/[\[\]]/g,""),port:t.slice(0,o)}:Oh?n={fd:Oh(+t,"::")}:n={port:t}}catch(o){console.error(`Unable to bind to port ${t}`,o);continue}e.push(new Promise((o,c)=>{r.listen(n,()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),Mn.trace("Listening on port "+t,kT)}).on("error",c)}))}return Promise.all(e)}a(dz,"listenOnPorts");!HC&&!mSe?.noServerStart&&uz();function $C(e,t,r){let n=e?.read?e:new ESe({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=Xi[t];if(s.isSecure&&(n.startTime=performance.now()),s)typeof s=="function"?s(n):s.emit("connection",n),r&&n.emit("data",r);else{let i=a(o=>{setTimeout(()=>{let c=Xi[t];c?(typeof c=="function"?c(n):c.emit("connection",n),r&&n.emit("data",r)):o<5?i(o+1):(Mn.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a($C,"deliverSocket");var ez=new Map;function USe(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=ez.get(s),r){case"connection":i=$C(void 0,t),ez.set(s,i),i.write=(c,l,u)=>(Nh.postMessage({requestId:s,event:"data",data:c.toString("latin1")}),u&&u(),!0),i.end=(c,l,u)=>(Nh.postMessage({requestId:s,event:"end",data:c?.toString("latin1")}),u&&u(),!0);let o=i.destroy;i.destroy=()=>{o.call(i),Nh.postMessage({requestId:s,event:"destroy"})};break;case"data":i._readableState.destroyed||i.emit("data",Buffer.from(n,"latin1"));break;case"drain":i._readableState.destroyed||i.emit("drain",{});break;case"end":i._readableState.destroyed||i.emit("end",{});break;case"error":i._readableState.destroyed||i.emit("error",{});break}}a(USe,"proxyRequest");var{getComponentName:GT}=(Jp(),P(jp));function VC(e,t,r=!0){t||(t=mt.get(Qt.CONFIG_PARAMS.HTTP_PORT));let n=Xi[t];if(n){let s=n.lastServer||n;if(s===e)throw new Error(`Can not register the same server twice for the same port ${t}`);if(r&&!!s.sessionIdContext!=!!e.sessionIdContext&&+t)throw new Error(`Can not mix secure HTTPS and insecure HTTP on the same port ${t}`);s.off("unhandled",sz),s.on("unhandled",(i,o)=>{e.cantCleanupProperly&&(n.cantCleanupProperly=!0),e.emit("request",i,o)}),n.lastServer=e}else Xi[t]=e;e.on("unhandled",sz)}a(VC,"registerServer");function KC(e){let t=[],r=e?.securePort;return r&&t.push({port:r,secure:!0}),r=e?.port,r&&t.push({port:r,secure:!1}),t.length===0&&(t=[],mt.get(Qt.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:mt.get(Qt.CONFIG_PARAMS.HTTP_PORT),secure:mt.get(Qt.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),mt.get(Qt.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:mt.get(Qt.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&mt.get(Qt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:cz(mt.get(Qt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)),secure:!1}),t}a(KC,"getPorts");function YC(e,t){let r=[];for(let{port:n,secure:s}of KC(t))r.push(fz(n,s,t?.isOperationsServer,t?.mtls)),typeof e=="function"?GC[t?.runFirst?"unshift":"push"]({listener:e,port:t?.port||n}):(e.isSecure=s,VC(e,n,!1)),FT[n]=$T(GC,n);return r}a(YC,"httpServer");function qT(e,t){let r=FC.get(e)??[];FC.set(e,[...r,t])}a(qT,"setPortServerMap");function fz(e,t,r,n){if(qT(e,{protocol_name:t?"HTTPS":"HTTP",name:GT()}),!HT[e]){let s=r?"operationsApi_network":"http",i=mt.get(s+"_keepAliveTimeout"),o=mt.get(s+"_timeout"),c=mt.get(s+"_headersTimeout"),l={keepAliveTimeout:i,headersTimeout:c,requestTimeout:o,highWaterMark:128*1024,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,maxHeaderSize:mt.get(Qt.CONFIG_PARAMS.HTTP_MAXHEADERSIZE)},u=mt.get(s+"_mtls"),f=mt.get(s+"_mtls_required"),d;t&&(d=mt.get(s+"_http2"),Object.assign(l,{allowHTTP1:!0,rejectUnauthorized:!!f,requestCert:!!(u||n),ticketKeys:wSe(),SNICallback:az(r?"operations-api":"server",u)}));let p=PSe(),_=HT[e]=(t?d?RSe:ASe:SSe)(l,async(h,S)=>{try{let R=performance.now(),E=new oz(h,S);r&&(E.isOperationsServer=!0);let A=await FT[e](E);if(!A){if(E._nodeResponse.statusCode)return;A=_z(E)}if(A.headers?.set||(A.headers=new kC(A.headers)),p?A.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):A.headers?.set?.("Server","HarperDB"),A.status===-1){for(let se of A.headers||[])S.setHeader(se[0],se[1]);return h.baseRequest=E,S.baseResponse=A,HT[e].emit("unhandled",h,S)}let N=A.status||200,v=performance.now(),F=v-R,$=A.body,Y,ee=!1;if(!A.handlesHeaders){let se=A.headers||new kC;$?$.length>=0?(typeof $=="string"?se.set("Content-Length",Buffer.byteLength($)):se.set("Content-Length",$.length),Y=!0):$ instanceof ySe&&($.size?se.set("Content-Length",$.size):$.on&&(ee=!0,$.on("size",me=>{S.headersSent||S.setHeader("Content-Length",me)})),$=$.stream()):(se.set("Content-Length","0"),Y=!0);let z=`hdb;dur=${F.toFixed(2)}`;if(A.wasCacheMiss&&(z+=", miss"),CSe(se,"Server-Timing",z,!0),!S.headersSent)if(ee){if(S.statusCode=N,se)if(se[Symbol.iterator])for(let[me,Ae]of se)S.setHeader(me,Ae);else for(let me in se)S.setHeader(me,se[me])}else S.writeHead(N,se&&(se[Symbol.iterator]?Array.from(se):se));Y&&S.end($)}let oe=E.handlerPath,j=E.method;if(yh(F,"duration",oe,j,A.wasCacheMiss==null?void 0:A.wasCacheMiss?"cache-miss":"cache-hit"),XW(N<400,"success",oe,j),XW(1,"response_"+N,oe,j),!Y)if($ instanceof ReadableStream&&($=ZW.fromWeb($)),($[Symbol.iterator]||$[Symbol.asyncIterator])&&($=ZW.from($)),$?.pipe){$.pipe(S),$.destroy&&S.on("close",()=>{$.destroy()});let se=0;$.on("data",z=>{se+=z.length}),$.on("end",()=>{yh(performance.now()-v,"transfer",oe,j),yh(se,"bytes-sent",oe,j)})}else $?.then?$.then(se=>{S.end(se)},g):S.end($)}catch(R){g(R)}function g(R){let E=R.headers;S.writeHead(R.statusCode||500,E&&(E[Symbol.iterator]?Array.from(E):E)),S.end(R.toString()),R.statusCode?R.statusCode===500?Mn.warn(R):Mn.info(R):Mn.error(R)}a(g,"onError")});i>=0&&(_.keepAliveTimeout=i),c>=0&&(_.headersTimeout=c),t&&(_.ports||(_.ports=[]),_.ports.push(e),l.SNICallback.initialize(_),u&&(_.mtlsConfig=u),_.on("secureConnection",h=>{h._parent.startTime&&yh(performance.now()-h._parent.startTime,"tls-handshake",e),yh(h.isSessionReused(),"tls-reused",e)}),_.isSecure=!0),VC(_,e)}return HT[e]}a(fz,"getHTTPServer");function $T(e,t){let r=_z;for(let n=e.length;n>0;){let{listener:s,port:i}=e[--n];if(i===t||i==="all"){let o=r;r=a((...c)=>s(...c,o),"next_callback")}}return r}a($T,"makeCallbackChain");function _z(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new kC}}a(_z,"unhandled");function xSe(e,t){YC(e,{requestOnly:!0,...t})}a(xSe,"onRequest");function BSe(e,t){let r;if(t.securePort){qT(t.securePort,{protocol_name:"TLS",name:GT()});let n=az("server",t.mtls);r=NSe({rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,SNICallback:n},e),n.initialize(r),Xi[t.securePort]=r}return t.port&&(qT(t.port,{protocol_name:"TCP",name:GT()}),r=gSe(e,{noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600}),Xi[t.port]=r),r}a(BSe,"onSocket");Object.defineProperty(TSe.prototype,"upgrade",{get(){return"connection"in this.headers&&"upgrade"in this.headers&&this.headers.connection.toLowerCase().includes("upgrade")&&this.headers.upgrade.toLowerCase()=="websocket"},set(e){}});var tz=[],qC={};function pz(e,t){for(let{port:r}of KC(t))tz[t?.runFirst?"unshift":"push"]({listener:e,port:r}),qC[r]=$T(tz,r)}a(pz,"onUpgrade");var rz=[],nz={};function HSe(e,t){let r=[];for(let{port:n,secure:s}of KC(t)){qT(n,{protocol_name:s?"WSS":"WS",name:GT()});let i=fz(n,s,t?.isOperationsServer,t?.mtls);bh[n]||(bh[n]=new OSe({noServer:!0,maxPayload:t.maxPayload??100*1024*1024}),bh[n].on("connection",(o,c)=>{let l=new oz(c);l.isWebSocket=!0;let u=FT[n](l);nz[n](o,l,u)}),pz((o,c,l,u)=>o.__harperdb_request_upgraded?u(o,c,l):bh[n].handleUpgrade(o,c,l,f=>{o.__harperdb_request_upgraded=!0,u(o,c,l),bh[n].emit("connection",f,o)}),{port:n}),i.on("upgrade",(o,c,l)=>{qC[n]&&qC[n](o,c,l)})),r.push(i),rz[t?.runFirst?"unshift":"push"]({listener:e,port:n}),nz[n]=$T(rz,n),FT[n]=$T(GC,n)}return r}a(HSe,"onWebSocket");function sz(e,t){t.writeHead(404),t.end(`Not found
132
+ `)}a(sz,"defaultNotFound")});var QW={};Ue(QW,{startHTTPThreads:()=>FSe,startSocketServer:()=>XC,updateWorkerIdleness:()=>yz});async function FSe(e=2,t){try{if(t)JC(0,1,!0);else{let{loadRootComponents:r}=VT();if(e===0)return(0,Hs.setMainIsWorker)(!0),await WC().startServers(),Promise.resolve([]);await r()}Rz();for(let r=0;r<e;r++)JC(r,e);return Promise.all(Az)}finally{(0,Hs.threadsHaveStarted)()}}function Rz(){let e=(0,gz.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),jC=setInterval(()=>{WT.notify(e)},kSe).unref())}function JC(e,t=1,r){if(zC++,(0,Hs.startWorker)("server/threads/threadServer.js",{name:eR.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(u){u.type===QA.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});Az.push(s),await s,ef.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=YT.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=ef.indexOf(n);o>-1&&ef.splice(o,1)}if(a(i,"removeWorker"),tf){let o=tf;tf=[];for(let c of o)Tz[c.localPort](null,c)}}}),r){let n=setInterval(()=>{QC?QC=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,Hs.shutdownWorkers)(),zC=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function XC(e=0,t){if(typeof e=="string")try{(0,zT.existsSync)(e)&&(0,zT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=GSe:r=qSe(t):r=ZC;let n=(0,rf.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);return n._handle&&(n._handle.onconnection=Tz[e]=function(s,i){r.readsData||(i.reading=!1,i.readStop()),QC=!0,r(i,(o,c)=>{if(!o){if(hz){let u=i._socket||new rf.Socket({handle:i,writable:!0,readable:!0});hz.deliverSocket(u,e,c),u.resume()}else zC>0?(tf.length===0&&setTimeout(()=>{tf.length>0&&console.warn("Incoming sockets/requests have been queued for workers to start, and no workers have handled them. Check to make sure an error is not preventing workers from starting")},1e4).unref(),i.localPort=e,tf.push(i)):(console.log("start up a dynamic thread to handle request"),JC(0));sr(!1,"socket-routed");return}o.requests++;let l=i.fd;if(l>=0)o.postMessage({port:e,fd:l,data:c});else{let u=i._socket||new rf.Socket({handle:i,writable:!0,readable:!0});KSe(u,o,e)}sr(!0,"socket-routed")})},WT.info(`HarperDB ${Sz.packageJson.version} Server running on port ${e}`)),n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function ZC(e,t){let r,n=0;for(let s of ef){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=KT)return KT=i,t(r);n=i}KT=0,t(r)}function GSe(e,t){let r={};e.getpeername(r);let n=r.address,s=nf.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);ZC(e,o=>{nf.set(n,{worker:o,lastUsed:i}),t(o)})}function qSe(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new rf.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let l=o.toString("latin1").match(t)?.[1],u=nf.get(l),f=Date.now();if(u&&u.worker.threadId!==-1)return u.lastUsed=f,s(u.worker);ZC(n,d=>{nf.set(l,{worker:d,lastUsed:f}),s(d,o)})})}a(r,"findByHeaderAffinity")}function yz(){KT=0;for(let e of ef)e.expectedIdle=e.recentELU.idle+$Se,e.requests=1;ef.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function KSe(e,t,r){let n=VSe++;t.postMessage({port:r,requestId:n,event:"connection"}),e.on("data",s=>{let i=s.toString("latin1");t.postMessage({port:r,requestId:n,data:i,event:"data"})}).on("close",s=>{t.postMessage({port:r,requestId:n,event:"close",hadError:s})}).on("error",s=>{t.postMessage({port:r,requestId:n,event:"error",error:s})}).on("drain",s=>{t.postMessage({port:r,requestId:n,event:"drain",error:s})}).on("end",()=>{t.postMessage({port:r,requestId:n,event:"end"})}).resume(),YT.set(n,s=>{s.event=="data"&&e.write(Buffer.from(s.data,"latin1")),s.event=="end"&&(e.end(s.data&&Buffer.from(s.data,"latin1")),YT.delete(n)),s.event=="destroy"&&(e.destroy(),YT.delete(n))})}var Hs,rf,WT,zT,Ez,gz,Sz,ef,tf,Tz,hz,zC,Az,jC,kSe,QC,KT,mz,nf,$Se,YT,VSe,BC=be(()=>{Hs=M(rt()),rf=require("net");H();WT=M(W()),zT=require("fs");Fi();Ez=require("worker_threads"),gz=M(Nd()),Sz=M(st()),ef=[],tf=[],Tz=[],zC=0,Az=[];Ez.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,Hs.onMessageFromWorkers)(e=>{e.type===ZA.RESTART&&jC&&(clearInterval(jC),Rz())}));kSe=6e5;a(FSe,"startHTTPThreads");a(Rz,"licenseWarning");a(JC,"startHTTPWorker");a(XC,"startSocketServer");KT=0;a(ZC,"findMostIdleWorker");mz=36e5,nf=new Map;a(GSe,"findByRemoteAddressAffinity");a(qSe,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of nf)r.lastUsed+mz<e&&nf.delete(t)},mz).unref();$Se=1e3;a(yz,"updateWorkerIdleness");(0,Hs.setMonitorListener)(yz);YT=new Map,VSe=1;a(KSe,"proxySocket")});var Hz=I((QUe,Bz)=>{var Oz=M(require("cluster")),dc=M(ce());H();var Zi=M(W()),Nz=M(require("fastify")),wz=M(require("@fastify/cors")),Iz=M(require("@fastify/compress")),Cz=M(require("@fastify/static")),Pz=M(yO()),Dz=M(require("path")),Lz=M(st()),Mz=M(Rs()),vz=M(ae()),Uz=M(yn()),xz=M(Nd());Kr();var fc=M(mT());co();dc.default.initSync();var YSe=6e4,WSe=1024*1024*1024,zSe="TRUE",{CONFIG_PARAMS:Ih}=G,sf;Bz.exports={hdbServer:bz,start:bz};async function bz(e){try{Zi.default.debug("In Fastify server"+process.cwd()),Zi.default.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Zi.default.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=Oz.default.isMaster,await jSe();let t=e.securePort>0;sf=JSe(t),await sf.ready(),e||(e={}),e.isOperationsServer=!0;try{We.http(sf.server,e),sf.server.closeIdleConnections||await sf.listen({port:0,host:"::"})}catch(r){throw sf.close(),Zi.default.error(r),Zi.default.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),Zi.default.fatal(t),process.exit(1)}}a(bz,"operationsServer");async function jSe(){Zi.default.trace("Configuring HarperDB process."),Mz.default.setSchemaDataToGlobal(),await Uz.default.setUsersWithRolesCache(),await xz.default.getLicense()}a(jSe,"setUp");function JSe(e){Zi.default.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=QSe(e),r=(0,Nz.default)(t);r.server.headersTimeout=ZSe(),r.setErrorHandler(fc.serverErrorHandler);let n=XSe();n&&r.register(wz.default,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,u){r.server.emit("unhandled",l.raw,u.raw)}),c()}),r.register(Pz.default),r.register(Iz.default),r.register(Cz.default,{root:Dz.default.join(Lz.PACKAGE_ROOT,"studio/build-local")}),Jf(r);let s=dc.default.get(JA.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!vz.default.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[fc.reqBodyValidationHandler,fc.authHandler],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),(0,fc.handlePostRequest)(i,o)}),r.get("/health",()=>"HarperDB is running."),Zi.default.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(JSe,"buildServer");function QSe(e){let t=dc.default.get(Ih.OPERATIONSAPI_NETWORK_TIMEOUT),r=dc.default.get(Ih.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:WSe,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(QSe,"getServerOptions");function XSe(){let e=dc.default.get(Ih.OPERATIONSAPI_NETWORK_CORS),t=dc.default.get(Ih.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===zSe)&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},t&&t.length>0&&t[0]!==null&&t[0]!=="*"&&(r.origin=(n,s)=>s(null,t.indexOf(n)!==-1))),r}a(XSe,"getCORSOpts");function ZSe(){return dc.default.get(Ih.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??YSe}a(ZSe,"getHeaderTimeoutConfig")});var iP={};Ue(iP,{disableNATS:()=>tTe,publishToStream:()=>QT,setNATSReplicator:()=>eP,setPublishToStream:()=>rTe,setSubscription:()=>sP,start:()=>eTe});function eTe(){Ch.default.get(x.CLUSTERING_ENABLED)&&sTe()}function tTe(e=!0){$z=e}function rTe(e,t){QT=e,sP=t}function sTe(){if($z||process.env._DISABLE_NATS)return;let e=Xe(),t=Object.keys(e);t.push("system");for(let r of t){let n=e[r];for(let s in n){let i=n[s];eP(s,r,i)}}Al((r,n)=>{eP(r.tableName,r.databaseName,r),n&&Kz(r)}),!kz&&(kz=!0)}function eP(e,t,r){if(t==="system"&&iTe.includes(e))return;if(!r)return console.error(`Attempt to replicate non-existent table ${e} from database ${t}`);if(r.sources.some(s=>s?.isNATSReplicator))return;r.sourcedFrom(class extends Vr{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this.getId(),record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this.getId()})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this.getId(),record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this.getId(),record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this.getId()})}static defineSchema(i){Kz(i)}static subscribe(){let i=new Hn;return sP(t,e,i),i}static subscribeOnThisThread(i){return i<(Ch.default.get(x.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??nTe)}static isEqual(i){return i.isNATSReplicator}static isNATSReplicator=!0;static shouldReceiveInvalidations=!0},{intermediateSource:!0});function n(s){let i=s?.transaction?.nats;if(!i)if(s?.transaction){s.transaction.nats=i=new jT(s.transaction,s);let o=s.transaction;for(;o.next;)o=o.next;o.next=s.transaction.nats,i.user=s.user,i.context=s}else i=Vz;return i}a(n,"getNATSTransaction")}function Kz(e){let t=Ch.default.get(x.CLUSTERING_NODENAME);QT(`${rP.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,nP.createNatsTableStreamName)(e.databaseName,e.tableName),void 0,{operation:"define_schema",schema:e.databaseName,table:e.tableName,attributes:e.attributes,__origin:{timestamp:Date.now(),node_name:t}})}var Fz,rP,nP,Gz,qz,Ch,JT,$z,QT,sP,nTe,Vz,kz,iTe,jT,tP,Yz=be(()=>{De();ga();Fz=M(ir()),rP=M(St()),nP=M(go());hu();Gz=M(BO()),qz=M(pn()),Ch=M(ce());H();JT=M(W());a(eTe,"start");a(tTe,"disableNATS");QT=Fz.publishToStream,sP=Gz.setSubscription;a(rTe,"setPublishToStream");nTe=2;a(sTe,"assignReplicationSource");iTe=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(eP,"setNATSReplicator");a(Kz,"publishSchema");jT=class{constructor(t,r){this.transaction=t;this.options=r}static{a(this,"NATSTransaction")}user;writes_by_db=new Map;addWrite(t,r){r.expiresAt=this.context?.expiresAt;let n=this.writes_by_db.get(t);n||this.writes_by_db.set(t,n=[]),n.push(r)}commit({timestamp:t}){let r=Ch.default.get(x.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],l,u;for(let f of i){let d=f.table,p=f.operation=="put"?"upsert":f.operation;l||(JT.trace(`Sending transaction event ${p}`),u=l={operation:p,schema:s,table:d,__origin:{user:this.user?.username,timestamp:t,node_name:r}},l.hash_values=c,p!=="delete"&&p!=="invalidate"&&(l.records=o)),l.table===d&&l.operation===p?(o.push(f.record),c.push(f.id)):u=u.next={operation:p,table:d,id:f.id,record:f.record},f.expiresAt&&(u.expiresAt=f.expiresAt)}l&&n.push(QT(`${rP.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,nP.createNatsTableStreamName)(s,l.table),void 0,l)?.catch(f=>{throw JT.error("An error has occurred trying to replicate transaction",l,f),f.statusCode=504,f}))}return Promise.all(n)}},tP=class extends jT{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,qz.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};Vz=new tP});async function Qz({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await oP.get(e,{returnNonexistent:!0});i=new lP(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await oP.get(e);o&&o.delete()}i=new ZT(e,t)}return n&&(n.id=e,n.user={username:t?.username},Ph.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function aP(){return XT++,XT>65500&&(XT=1),XT}function cP(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=Ni.getMatch(n,"mqtt");if(!i)throw new Error(`Can not publish to topic ${n} as it does not exist, no resource has been defined to handle this topic`);e.url=i.relativeURL;let o=i.Resource;return Nt(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var zz,_c,jz,Jz,Wz,oP,Ph,XT,ZT,lP,Xz=be(()=>{De();Au();zz=M(pn()),_c=M(W());Cc();jz=M(rt()),Jz=M(WC());Kr();Wz=100,oP=dt({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),Ph=dt({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,jz.getWorkerIndex)()===0&&(async()=>{await Jz.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of Ph.search({})){let t=e.data,r={...e};r.user?.username&&(r.user=await We.getUser(r.user.username));try{await cP(r,t,r)}catch{(0,_c.warn)("Failed to publish will",t)}Ph.delete(e.id)}})();a(Qz,"getSession");XT=1;a(aP,"getNextMessageId");ZT=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;request;socket;subscriptions=[];awaitingAcks;sessionWasPresent;keepalive;keepaliveTimer;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),l,u;if(c>-1?(l=s.slice(c),u=s.slice(0,c)):u=s,!u)throw new Error("No topic provided");if(u.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let f=this.subscriptions.find(R=>R.topic===s),d;f?(d=i>0,f.end(),this.subscriptions.splice(this.subscriptions.indexOf(f),1)):d=i===2;let p={search:l,async:!0,user:this.user,startTime:o,omitCurrent:d,url:""};o&&(0,_c.trace)("Resuming subscription from",s,"from",o);let _=Ni.getMatch(u,"mqtt");if(!_){let R=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw R.statusCode=404,R}if(p.url=_.relativeURL,p.url.indexOf("+")>-1||p.url.indexOf("#")>-1){let R=p.url.slice(1);if(R.indexOf("#")>-1&&R.indexOf("#")!==R.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(p.isCollection=!0,R.indexOf("+")===R.length-1)p.onlyChildren=!0,p.url="/"+R.slice(0,R.length-1);else{let E=R.split("/"),A;for(let F=0;F<E.length;F++)if(E[F].indexOf("+")>-1)if(E[F]==="+")A=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&A)throw new Error("Filters can not be combined");let N=!0;E[E.length-1]==="#"&&(E.length--,N=!1),A&&(n=a(F=>{let $=F.id;if(!Array.isArray($))if($?.indexOf?.("/")>-1)$=$.split("/");else return!1;if(N&&$.length!==E.length)return!1;for(let Y=0;Y<E.length;Y++)if(E[Y]!=="+"&&E[Y]!==$[Y])return!1;return!0},"filter"));let v=E.indexOf("+");p.url="/"+(v>-1?E.slice(0,v):E).concat("").join("/")}}let h=_.path,S=_.Resource,g=await Nt(p,async()=>{let R=this.createContext();R.topic=s,R.retainHandling=i;let E=await S.subscribe(p,R);if(!E)return;if(!E[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let A=(async()=>{for await(let N of E)try{let v;if(N.type&&N.type!=="put"&&N.type!=="delete"&&N.type!=="message"&&N.type!=="patch"||n&&!n(N))continue;r?(N.topic=s,v=this.needsAcknowledge(N)):(N.acknowledge?.(),v=aP());let F=N.id;if(Array.isArray(F)&&(F=Tu(F)),F==null&&(F=""),await this.listener(h+"/"+F,N.value,v,t)===!1)break;this.awaitingAcks?.size>Wz?await new Promise(Y=>setTimeout(Y,this.awaitingAcks.size-Wz)):await new Promise(setImmediate)}catch(v){(0,_c.warn)(v)}})();return E});if(g)return g.topic=s,g.qos=t.qos,this.subscriptions.push(g),g}resume(){}needsAcknowledge(t){let r=aP();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,{acknowledge:t.acknowledge})),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r.acknowledge())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),this.subscriptions.splice(this.subscriptions.indexOf(r),1),!0}async publish(t,r){return cP(t,r,this.createContext())}createContext(){let t={session:this,socket:this.socket,user:this.user,authorize:!0};return this.request&&(t.request=this.request,t.url=this.request.url,t.headers=this.request.headers),t}setListener(t){this.listener=t}disconnect(t){this.keepaliveTimer&&clearTimeout(this.keepaliveTimer);let r=this.createContext();Nt(r,async()=>{try{if(!t){let n=await Ph.get(this.sessionId);n?.doesExist()&&await cP(n,n.data,r)}}finally{await Ph.delete(this.sessionId)}}).catch(n=>{(0,_c.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}receivedPacket(){this.keepalive&&(clearTimeout(this.keepaliveTimer),this.keepaliveTimer=setTimeout(()=>{this.socket?.destroy?this.socket.destroy(new Error("Keepalive timeout")):this.socket?.terminate()},this.keepalive*1500))}};a(cP,"publish");lP=class extends ZT{static{a(this,"DurableSubscriptionsSession")}sessionRecord;constructor(t,r,n){super(t,r),this.sessionRecord=n||{id:t,subscriptions:[]}}async resume(){for(let t of this.sessionRecord.subscriptions||[])await this.resumeSubscription({omitCurrent:!0,topic:t.topic,qos:t.qos,startTime:t.startTime},!0,t.acks?r=>!t.acks.includes(r.localTime):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=aP(),n={topic:t.topic,timestamp:t.localTime};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks?.get(t);if(!r)return;this.awaitingAcks?.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,_c.trace)("Received ack",n,r.timestamp),this.sessionRecord.update();return}}for(let s of this.sessionRecord.subscriptions)s.topic===n&&(s.startTime=r.timestamp);this.sessionRecord.update()}async addSubscription(t,r){await this.resumeSubscription(t,r);let{qos:n,startTime:s}=t;return n>0&&!s&&this.saveSubscriptions(),t.qos}removeSubscription(t){let r=this.subscriptions.find(s=>s.topic===t),n=super.removeSubscription(t);return r.qos>0&&this.saveSubscriptions(),n}saveSubscriptions(){this.sessionRecord.subscriptions=this.subscriptions.map(t=>{let r=t.startTime;return r||(r=t.startTime=(0,zz.getNextMonotonicTime)()),(0,_c.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),oP.put(this.sessionRecord)}}});var dP={};Ue(dP,{bypassAuth:()=>oTe,start:()=>aTe});function oTe(){nj=!0}function aTe({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new rj.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c=[],l=r?.mtls;return n&&(c=e.ws((u,f,d,p)=>{if(f.headers.get("sec-websocket-protocol")!=="mqtt")return p(u,f,d);o.events.emit("connection",u),hr.debug?.("Received WebSocket connection for MQTT from",u._socket.remoteAddress);let{onMessage:_,onClose:h}=ej(u,S=>{u.send(S)},f,Promise.resolve(d).then(()=>f?.user),o);u.on("message",_),u.on("close",h),u.on("error",S=>{hr.info?.("WebSocket error",S)})},{...n})),(t||s)&&c.push(e.socket(async u=>{let f;if(o.events.emit("connection",u),hr.debug?.(`Received ${u.getCertificate?"SSL":"TCP"} connection for MQTT from ${u.remoteAddress}`),l){if(u.authorized)try{let _=l.user;if(_!==null){(_===void 0||_==="Common Name"||_==="CN")&&(_=u.getPeerCertificate().subject.CN);try{f=await e.getUser(_,null,null),(0,of.get)(x.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&tA.notify?.({username:f?.username,status:Ws.SUCCESS,type:ua.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:u.remoteAddress})}catch(h){throw(0,of.get)(x.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&tA.error?.({username:_,status:Ws.FAILURE,type:ua.AUTHENTICATION,auth_strategy:"mqtt",remote_address:u.remoteAddress}),h}}else hr.debug?.("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",u.remoteAddress)}catch(_){o.events.emit("error",_,u),hr.error?.(_)}else if(l.required)return hr.info?.(`Unauthorized connection attempt, no authorized client certificate provided, error: ${u.authorizationError}`),u.end()}!f&&nj&&u.remoteAddress.includes("127.0.0.1")&&(f=await(0,tj.getSuperUser)(),hr.debug?.("Auto-authorizing local connection",f?.username));let{onMessage:d,onClose:p}=ej(u,_=>u.write(_),null,f,o);u.on("data",d),u.on("close",p),u.on("error",_=>{hr.info?.("Socket error",_)})},{port:t,securePort:s,mtls:l})),c}function ej(e,t,r,n,s){Zz||(Zz=!0,W_(d=>{eA>0&&d.push({metric:"mqtt-connections",connections:eA,byThread:!0})}));let i;eA++;let o,c={protocolVersion:4},l=(0,rA.parser)({protocolVersion:5});function u(d){l.parse(d)}a(u,"onMessage");function f(){eA--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),Xn(!1,"connection","mqtt","disconnect"),hr.debug?.("MQTT connection was closed",e.remoteAddress))}return a(f,"onClose"),l.on("packet",async d=>{n?.then&&(n=await n);let p=d.cmd;if(o)o.then&&await o;else if(p!=="connect"){hr.info?.("Received packet before connection was established, closing connection"),e?.destroy?e.destroy():e?.terminate();return}let _=d.topic,h=_?.indexOf("/",1),S=h>0?_.slice(0,h):_;sr(d.length,"bytes-received",S,R(d),"mqtt");try{switch(o?.receivedPacket?.(),p){case"connect":if(c.protocolVersion=d.protocolVersion,d.username)try{n=await We.getUser(d.username,d.password.toString(),r),(0,of.get)(x.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&tA.notify?.({username:n?.username,status:Ws.SUCCESS,type:ua.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(oe){return(0,of.get)(x.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&tA.error?.({username:d.username,status:Ws.FAILURE,type:ua.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",d,e,oe),Xn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",d,e),Xn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(d,n),d.will){let oe=e.deserialize||(e.deserialize=fo(r?.headers.get?.("content-type")));d.will.data=d.will.payload?.length>0?oe(d.will.payload):void 0,delete d.will.payload}o=Qz({user:n,...d}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(oe){return hr.error?.(oe),s.events.emit("auth-failed",d,e,oe),Xn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:oe.code||5,returnCode:oe.code||128})}s.events.emit("connected",o,e),Xn(!0,"connection","mqtt","connect"),g({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0});let A=a(async(oe,j,se,z)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",oe);let me=oe.indexOf("/",1),Ae=me>0?oe.slice(0,me):oe;g({cmd:"publish",topic:oe,payload:await E(j),messageId:se||Math.floor(Math.random()*1e8),qos:z.qos},Ae);let Pe=e._socket??e;return Pe.writableNeedDrain?new Promise(he=>Pe.once("drain",he)):!Pe.closed}catch(me){return hr.error?.(me),o?.disconnect(),s.sessions.delete(o),!1}},"listener");o.setListener(A),o.sessionWasPresent&&await o.resume();break;case"subscribe":let N=[];for(let oe of d.subscriptions){let j;try{let se=await o.addSubscription(oe,oe.qos>=1);j=se?se.qos||0:c.protocolVersion<5?128:143}catch(se){s.events.emit("error",se,e,oe,o),se.statusCode?se.statusCode===500?hr.warn?.(se):hr.info?.(se):hr.error?.(se),j=c.protocolVersion<5?128:se.statusCode===403?135:se.statusCode===404?143:128}N.push(j)}await o.committed,g({cmd:"suback",granted:N,messageId:d.messageId});break;case"unsubscribe":{let oe=[];for(let j of d.unsubscriptions)oe.push(o.removeSubscription(j)?0:17);g({cmd:"unsuback",granted:oe,messageId:d.messageId});break}case"pubrel":g({cmd:"pubcomp",messageId:d.messageId,reasonCode:0});return;case"publish":let v=d.qos===2?"pubrec":"puback",F=e.deserialize||(e.deserialize=fo(r?.headers.get?.("content-type"))),Y=(d.payload?.length||0)>0?F(d.payload):void 0,ee;try{ee=await o.publish(d,Y)}catch(oe){s.events.emit("error",oe,e,d,o),hr.warn?.(oe),d.qos>0&&g({cmd:v,messageId:d.messageId,reasonCode:128},d.topic);break}d.qos>0&&g({cmd:v,messageId:d.messageId,reasonCode:ee===!1?144:0},d.topic);break;case"pubrec":g({cmd:"pubrel",messageId:d.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(d.messageId);break;case"pingreq":g({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),Xn(!0,"connection","mqtt","disconnect"),hr.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(A){s.events.emit("error",A,e,d,o),hr.error?.(A),g({cmd:"disconnect"})}function g(A,N){let v=(0,rA.generate)(A,c);t(v),sr(v.length,"bytes-sent",N,R(A),"mqtt")}a(g,"sendPacket");function R(A){return A.qos>0?A.cmd+",qos="+A.qos:A.cmd}a(R,"packetMethodName");function E(A){return Ra(A,r)}a(E,"serialize")}),l.on("error",d=>{hr.warn("MQTT parsing error, closing connection:",d.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:u,onClose:f}}var rA,tj,of,uP,rj,tA,hr,nj,Zz,eA,sj=be(()=>{rA=require("mqtt-packet");Xz();tj=M(yn());co();Fi();Kr();of=M(ce());H();uP=M(wi()),rj=require("events"),tA=(0,uP.loggerWithTag)("auth-event"),hr=(0,uP.loggerWithTag)("mqtt"),nj=(0,of.get)(x.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(oTe,"bypassAuth");a(aTe,"start");eA=0;a(ej,"onSocket")});var jp={};Ue(jp,{component_errors:()=>cf,getComponentName:()=>fTe,loadComponent:()=>iA,loadComponentDirectories:()=>lj,setErrorReporter:()=>dTe});function lj(e,t){t&&(_P=t),e&&(EP=e);let r=[];if((0,lt.existsSync)(fP)){let s=(0,lt.readdirSync)(fP,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,gt.join)(fP,o);r.push(iA(c,_P,YA,!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(iA(n,_P,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{cj=!0})}function dTe(e){Dh=e}async function iA(e,t,r,n,s,i){let o=(0,lt.realpathSync)(e);if(nA.has(o))return nA.get(o);nA.set(o,!0),s&&(EP=s);try{let c;n&&(cf=new Map);let l=(0,gt.join)(e,"harperdb-config.yaml");(0,lt.existsSync)(l)?c=n?(0,oA.getConfigObj)():(0,pP.parseDocument)((0,lt.readFileSync)(l,"utf8")).toJSON():!n&&(0,lt.existsSync)(l=(0,gt.join)(e,"config.yaml"))?c=(0,pP.parseDocument)((0,lt.readFileSync)(l,"utf8")).toJSON():c=gP;let u=(0,gt.join)(e,"node_modules","harperdb");try{Jl.isMainThread&&(n||((0,lt.existsSync)(u)||!e.startsWith((0,mP.getHdbBasePath)()))&&(!(0,lt.existsSync)(u)||(0,lt.realpathSync)(hP.PACKAGE_ROOT)!==(0,lt.realpathSync)(u)))&&((0,lt.rmSync)(u,{recursive:!0,force:!0}),(0,lt.existsSync)((0,gt.join)(e,"node_modules"))||(0,lt.mkdirSync)((0,gt.join)(e,"node_modules")),(0,lt.symlinkSync)(hP.PACKAGE_ROOT,u,"dir"))}catch(p){af.default.error("Error symlinking harperdb module",p)}let f=sA,d=n;for(let p in c){sA=p;let _=c[p];if(cf.set(n?p:(0,gt.basename)(e),!1),!_)continue;let h,S=_.package;try{if(S){let N=e,v;for(;!(0,lt.existsSync)(v=(0,gt.join)(N,"node_modules",p));)if(N=(0,gt.dirname)(N),N.length<(0,mP.getHdbBasePath)().length){v=null;break}if(v)h=await iA(v,t,r,!1),d=!0;else throw new Error(`Unable to find package ${p}:${S}`)}else h=uTe[p];if(!h)continue;let g=a(N=>(N.origin=r,dt(N)),"ensureTable"),R=_.network||(_.port||_.securePort)&&_,E=R?.securePort||R?.https&&R.port,A=!R?.https&&R?.port;if(Jl.isMainThread&&(h=await h.startOnMainThread?.({server:We,ensureTable:g,port:A,securePort:E,resources:t,..._})||h,n&&R))for(let N of[A,E])try{if(+N&&!ij.includes(N)){let v=SP.get(x.HTTP_SESSIONAFFINITY);v&&af.default.warn("Session affinity is not recommended and may cause memory leaks"),(v||!ST)&&(ij.push(N),XC(N,v))}}catch(v){console.error("Error listening on socket",N,v,p)}if(t.isWorker&&(h=await h.start?.({server:We,ensureTable:g,port:A,securePort:E,resources:t,..._})||h),EP.set(h,!0),(h.handleFile||h.handleDirectory||h.setupFile||h.setupDirectory)&&_.files!=null){if(_.files.includes(".."))throw(0,aj.handleHDBError)("Can not reference parent directories");let N=(0,gt.join)(e,_.files).replace(/\\/g,"/"),v=N.indexOf("/*");if(v>-1&&_.files!==gP[p]?.files&&!(0,lt.existsSync)(N.slice(0,v)))throw new Error(`The path '${N.slice(0,v)}' does not exist and cannot be used as the base of the resolved 'files' path value '${_.files}'`);let F=(0,gt.basename)(e),$=_.path||"/";$=$.startsWith("/")?$:$.startsWith("./")?"/"+F+$.slice(2):$==="."?"/"+F:"/"+F+"/"+$;let Y,ee,oe;if(_.root){let se=_.root;se.startsWith("/")&&(se=se.slice(1)),se.endsWith("/")&&(se=se.slice(0,-1)),se+="/",ee=(0,gt.join)(e,se)}else(oe=N.indexOf("/*"))>-1?(ee=N.slice(0,oe+1),Y=(0,gt.relative)(e,ee)):_.files.indexOf("/")>-1&&(ee=N.slice(0,N.lastIndexOf("/")+1),Y=(0,gt.relative)(e,ee));let j=!1;if(Jl.isMainThread&&h.setupDirectory&&(j=await h.setupDirectory?.($,ee,t)),t.isWorker&&h.handleDirectory&&(j=await h.handleDirectory?.($,ee,t)),j){d=!0;continue}for(let se of await(0,oj.default)(N,{onlyFiles:!1,objectMode:!0})){let{path:z,dirent:me}=se;d=!0;let Ae=(0,gt.relative)(e,z).replace(/\\/g,"/");if(Y)if(Ae.startsWith(Y))Ae=Ae.slice(Y.length+1);else throw new Error(`The root path '${_.root}' does not reference a valid part of the file path '${Ae}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let Pe=$+($.endsWith("/")?"":"/")+Ae;try{if(me.isFile()){let he=await lTe(z);Jl.isMainThread&&await h.setupFile?.(he,Pe,z,t),t.isWorker&&await h.handleFile?.(he,Pe,z,t)}else Jl.isMainThread&&await h.setupDirectory?.(Pe,z,t),t.isWorker&&await h.handleDirectory?.(Pe,z,t)}catch(he){let Ot=`Could not load ${me.isFile()?"file":"directory"} '${z}'${_.module?` using '${_.module}'`:""} for application '${e}' due to:
133
+ `;he.message=`${Ot}${he.message}`,he.stack=`${Ot}${he.stack}`,Dh?.(he),af.default.error(he),t.set(_.path||"/",new Sa(he)),cf.set(n?p:(0,gt.basename)(e),he.message)}}}}catch(g){g.message=`Could not load component '${p}' for application '${(0,gt.basename)(e)}' due to: ${g.message}`,Dh?.(g),((0,Lh.getWorkerIndex)()===0?console:af.default).error(g),t.set(_.path||"/",new Sa(g),null,!0),cf.set(n?p:(0,gt.basename)(e),g.message)}}if(sA=f,Jl.isMainThread&&!cj&&i&&(0,Lh.watchDir)(e,async()=>lj()),c.extensionModule){let p=await JE((0,gt.join)(e,c.extensionModule));return nA.set(o,p),p}if(!d&&t.isWorker){let p=`${e} did not load any modules, resources, or files, is this a valid component?`;Dh?.(new Error(p)),((0,Lh.getWorkerIndex)()===0?console:af.default).error(p),cf.set((0,gt.basename)(e),p)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,Dh?.(c),t.set("",new Sa(c))}}var lt,gt,Jl,pP,SP,hP,oj,Lh,af,aj,mP,cTe,oA,lTe,fP,EP,cj,_P,cf,uTe,gP,ij,nA,Dh,sA,fTe,Jp=be(()=>{lt=require("fs"),gt=require("path"),Jl=require("worker_threads"),pP=require("yaml"),SP=M(ce()),hP=M(st());H();HL();AM();JB();eH();tH();BH();mY();RY();bY();oj=M(require("fast-glob")),Lh=M(rt()),af=M(W());aO();Kr();aj=M(pe());De();BC();mP=M(ce()),cTe=M(Hz());US();Yz();Zn();sj();oA=M(Rt());ZI();TR();({readFile:lTe}=lt.promises),fP=(0,oA.resolvePath)(SP.get(x.COMPONENTSROOT)),EP=new Map,cf=new Map;a(lj,"loadComponentDirectories");uTe={REST:rg,rest:rg,graphql:kR,graphqlSchema:yR,roles:oO,jsResource:lO,fastifyRoutes:WI,login:dO,static:zI,operationsApi:cTe,customFunctions:{},http:{},clustering:iP,replication:Io,authentication:qp,mqtt:dP,loadEnv:jI},gP={rest:!0,graphqlSchema:{files:"*.graphql"},roles:{files:"roles.yaml"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(gP,"static",{value:{files:"web/**"}});ij=[],nA=new Map;a(dTe,"setErrorReporter");fTe=a(()=>sA,"getComponentName");a(iA,"loadComponent")});var VT=I((w0e,dj)=>{var{isMainThread:uj}=require("worker_threads"),{getTables:_Te,getDatabases:O0e,table:N0e}=(De(),P(nt)),{loadComponentDirectories:pTe,loadComponent:hTe}=(Jp(),P(jp)),{resetResources:mTe}=(Au(),P(vL)),ETe=$w(),gTe=Rt(),{dirname:STe}=require("path"),{getConnection:TTe}=ir(),ATe=ce(),{CONFIG_PARAMS:RTe}=(H(),P(G)),{loadCertificates:yTe}=es(),TP=new Map;async function bTe(e=!1){!uj&&ATe.get(RTe.CLUSTERING_ENABLED)&&TTe();try{uj&&await ETe()}catch(n){console.error(n)}let t=mTe();_Te(),t.isWorker=e,await yTe(),await hTe(STe(gTe.getConfigFilePath()),t,"hdb",!0,TP),await pTe(TP,t);let r=[];for(let[n]of TP)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(bTe,"loadRootComponents");dj.exports.loadRootComponents=bTe});var rt=I((C0e,Ti)=>{"use strict";sm();var{Worker:OTe,MessageChannel:NTe,parentPort:eo,isMainThread:OP,threadId:wTe,workerData:to}=require("worker_threads"),{PACKAGE_ROOT:ITe}=st(),{join:hj,isAbsolute:CTe,extname:PTe}=require("path"),{server:mj}=(Kr(),P(Ru)),{watch:DTe,readdir:LTe}=require("fs/promises"),{totalmem:fj}=require("os"),lf=(H(),P(G)),Ej=ce(),Si=W(),{randomBytes:MTe}=require("crypto"),{_assignPackageExport:vTe}=Ai(),_j=1024*1024,pc=[],ks=[],UTe=50,NP=1e4,xTe="restart",gj="request_thread_info",Sj="resource_report",Tj="thread_info",Aj="added-port",BTe="ack",AP;vTe("threads",ks);Ti.exports={startWorker:RP,restartWorkers:IP,shutdownWorkers:qTe,workers:pc,setMonitorListener:JTe,onMessageFromWorkers:$Te,onMessageByType:Ij,broadcast:KTe,broadcastWithAcknowledgement:WTe,setChildListenerByType:GTe,getWorkerIndex:Rj,getWorkerCount:yj,getTicketKeys:Oj,setMainIsWorker:kTe,setTerminateTimeout:HTe,restartNumber:to?.restartNumber||1};ks.onMessageByType=Ij;ks.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=ks.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};Ti.exports.whenThreadsStarted=new Promise(e=>{Ti.exports.threadsHaveStarted=e});var wP;function HTe(e){NP=e}a(HTe,"setTerminateTimeout");function Rj(){return to?to.workerIndex:wP?0:void 0}a(Rj,"getWorkerIndex");function yj(){return to?to.workerCount:wP?1:void 0}a(yj,"getWorkerCount");function kTe(e){wP=e,Ti.exports.threadsHaveStarted()}a(kTe,"setMainIsWorker");var bj=1,aA;function Oj(){return aA||(aA=OP?MTe(48):to.ticketKeys,aA)}a(Oj,"getTicketKeys");Object.defineProperty(mj,"workerIndex",{get(){return Rj()}});Object.defineProperty(mj,"workerCount",{get(){return yj()}});var Nj={[gj](e,t){zTe(t)},[Sj](e,t){jTe(t,e)}};function RP(e,t={}){let r=process.constrainedMemory?.()||fj();r=Math.min(r,fj(),2e4*_j);let n=Ej.get(lf.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/_j/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let l of ks){let u=new NTe;u.existingPort=l,i.push(u),o.push(u.port2)}PTe(e)||(e+=".js");let c=new OTe(CTe(e)?e:hj(ITe,e),{resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps","--expose-internals"],argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(l=>l.existingPort.threadId),workerIndex:t.workerIndex,workerCount:bj=t.threadCount,name:t.name,restartNumber:Ti.exports.restartNumber,ticketKeys:Oj()},transferList:o,...t});for(let{port1:l,existingPort:u}of i)u.postMessage({type:Aj,port:l,threadId:c.threadId},[l]);return lA(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>RP(e,t),c.on("error",l=>{Si.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{pc.splice(pc.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<UTe?(t.unexpectedRestarts=c.unexpectedRestarts+1,RP(e,t)):Si.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{Nj[l.type]?.(l,c)}),pc.push(c),XTe(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(RP,"startWorker");var FTe=[lf.THREAD_TYPES.HTTP];async function IP(e=null,t=Math.max(bj>3,1),r=!0){if(OP){try{process.chdir(process.cwd())}catch(o){Si.error("Unable to reestablish current working directory",o)}if(r){let{loadRootComponents:o}=VT();await o()}Ti.exports.restartNumber++,t<1&&(t=t*pc.length);let n=[],s=[];for(let o of pc.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;Si.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:Ti.exports.restartNumber,type:lf.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=FTe.indexOf(o.name)>-1,l=new Promise(u=>{let f=setTimeout(()=>{Si.warn("Thread did not voluntarily terminate, terminating from the outside",o.threadId),o.terminate()},NP*2).unref();o.on("exit",()=>{clearTimeout(f),n.splice(n.indexOf(l)),!c&&r&&o.startCopy(),u()})});if(n.push(l),c&&r){let u=o.startCopy(),f=new Promise(d=>{let p=a(_=>{_.type===lf.ITC_EVENT_TYPES.CHILD_STARTED&&(Si.trace("Worker has started",u.threadId),d(),s.splice(s.indexOf(f)),u.off("message",p))},"startListener");Si.trace("Waiting for worker to start",u.threadId),u.on("message",p)});s.push(f),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=ja();r&&(e==="http"||!e)&&Ej.get(lf.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else eo.postMessage({type:xTe,workerType:e})}a(IP,"restartWorkers");function GTe(e,t){Nj[e]=t}a(GTe,"setChildListenerByType");function qTe(e){return IP(e,1/0,!1)}a(qTe,"shutdownWorkers");var wj=[];function $Te(e){wj.push(e)}a($Te,"onMessageFromWorkers");var yP=new Map;function Ij(e,t){let r=yP.get(e);r||yP.set(e,r=[]),r.push(t)}a(Ij,"onMessageByType");var VTe=10;async function KTe(e,t){let r=0;for(let n of ks)try{n.postMessage(e),r++>VTe&&(r=0,await new Promise(setImmediate))}catch(s){Si.error("Unable to send message to worker",s)}t&&Pj(e,null)}a(KTe,"broadcast");var cA=new Map,YTe=1;function WTe(e){return new Promise(t=>{let r=0;for(let n of ks)try{let s=YTe++,i=a(()=>{cA.delete(s),--r===0&&t(),n!==eo&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,cA.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of cA)o.port===n&&o()})),n.postMessage(e),r++}catch(s){Si.error("Unable to send message to worker",s)}r===0&&t()})}a(WTe,"broadcastWithAcknowledgement");function zTe(e){e.postMessage({type:Tj,workers:Cj()})}a(zTe,"sendThreadInfo");function Cj(){let e=Date.now();return pc.map(t=>({threadId:t.threadId,name:t.name,heapTotal:t.resources?.heapTotal,heapUsed:t.resources?.heapUsed,externalMemory:t.resources?.external,arrayBuffers:t.resources?.arrayBuffers,sinceLastUpdate:e-t.resources?.updated,...t.recentELU}))}a(Cj,"getChildWorkerInfo");function jTe(e,t){e.resources=t,e.resources.updated=Date.now()}a(jTe,"recordResourceReport");var bP;function JTe(e){bP=e}a(JTe,"setMonitorListener");var QTe=1e3,pj=!1;function XTe(){pj||(pj=!0,setInterval(()=>{for(let e of pc){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}bP&&bP()},QTe).unref())}a(XTe,"startMonitoring");var ZTe=1e3;if(eo&&to?.addPorts){lA(eo);for(let e=0,t=to.addPorts.length;e<t;e++){let r=to.addPorts[e];r.threadId=to.addThreadIds[e],lA(r)}setInterval(()=>{let e=process.memoryUsage();eo.postMessage({type:Sj,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},ZTe).unref(),AP=a(()=>new Promise((e,t)=>{eo.on("message",r),eo.postMessage({type:gj});function r(n){n.type===Tj&&(eo.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else AP=Cj;Ti.exports.getThreadInfo=AP;function lA(e,t){ks.push(e),e.on("message",r=>{if(r.type===Aj)r.port.threadId=r.threadId,lA(r.port);else if(r.type===BTe){let n=cA.get(r.id);n&&n()}else Pj(r,e)}).on("close",()=>{ks.splice(ks.indexOf(e),1)}).on("exit",()=>{ks.splice(ks.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(lA,"addPort");function Pj(e,t){for(let n of wj)n(e,t);let r=yP.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){Si.error(s)}}a(Pj,"notifyMessageListeners");if(OP){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await LTe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(hj(s,o.name));try{for await(let{filename:o}of DTe(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await IP(),console.log("Reloaded HarperDB components, changed files:",Array.from(r)),r.clear()},100)}catch(o){console.warn("Error trying to watch component directory",s,o)}},"watch_dir");Ti.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else eo.on("message",async e=>{let{type:t}=e;t===lf.ITC_EVENT_TYPES.SHUTDOWN&&(Ti.exports.restartNumber=e.restartNumber,eo.unref(),setTimeout(()=>{Si.warn("Thread did not voluntarily terminate",wTe),process.exit(0)},NP).unref())})});var hB={};Ue(hB,{ACTION_32_BIT:()=>jm,ACTION_64_BIT:()=>rAe,AUDIT_STORE_OPTIONS:()=>Bp,Decoder:()=>Tl,HAS_BLOBS:()=>Gn,HAS_CURRENT_RESIDENCY_ID:()=>Fc,HAS_EXPIRATION_EXTENDED_TYPE:()=>s_,HAS_ORIGINATING_OPERATION:()=>n_,HAS_PREVIOUS_RESIDENCY_ID:()=>Gc,REMOTE_SEQUENCE_UPDATE:()=>Ug,createAuditEntry:()=>wu,getLastRemoved:()=>TN,openAuditStore:()=>fA,readAuditEntry:()=>wt,removeAuditEntry:()=>_A,setAuditRetention:()=>tAe,transactionKeyEncoder:()=>kj});function fA(e){let t=e.auditStore=e.openDB(CP.AUDIT_STORE_NAME,{create:!1,...Bp});t||(t=e.auditStore=e.openDB(CP.AUDIT_STORE_NAME,Bp),Lj(t,1)),t.rootStore=e,t.tableStores=[];let r=[];t.addDeleteRemovalCallback=function(l,u,f){return r[l]=f,t.tableStores[l]=u,t.deleteCallbacks=r,{remove(){delete r[l]}}};let n=null,s,i=0,o=DP;Rh(t.env.path,l=>{if(i=l,l)return c(100)});function c(l){l&&(o=l),clearTimeout(n);let u=new Promise(f=>{n=setTimeout(async()=>{if(await s,s=u,t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let d=0,p,_;try{for(let{key:h,value:S}of t.getRange({start:1,snapshot:!1,end:Date.now()-PP/(1+i*i)})){try{p=_A(t,h,S)}catch(g){uf.warn("Error removing audit entry",g)}if(_=h,await new Promise(setImmediate),++d>=eAe){o=10;break}}await p}finally{d===0?o=Math.min(o<<1,PP/10):(Lj(t,_),o>100&&(o=o>>1)),f(void 0),c()}},o).unref()});return u}if(a(c,"scheduleAuditCleanup"),t.scheduleAuditCleanup=c,(0,vh.getWorkerIndex)()===(0,vh.getWorkerCount)()-1&&c(),(0,vh.getWorkerIndex)()===0&&!Dj)for(let l of t.getKeys({reverse:!0,limit:1}))l>Date.now()&&(Dj=!0,uf.error("The current time is before the last recorded entry in the audit log. Time reversal can undermine the integrity of data tracking and certificate validation and the time must be corrected."));return t}function _A(e,t,r){let n=nAe(r),s;if(n&Gn){s=wt(r);let i=e.tableStores[s.tableId],o=i?.getEntry(s.recordId);(!o||o.version!==s.version||!o.value)&&Uc(()=>Aa(s.getValue(i)),i.rootStore)}if((n&15)===LP){s=s||wt(r);let i=s.tableId;e.tableStores[s.tableId]?.getEntry(s.recordId).version===s.version&&e.deleteCallbacks?.[i]?.(s.recordId,s.version)}return e.remove(t)}function Lj(e,t){MP[0]=t,e.put(Symbol.for("last-removed"),Fj)}function TN(e){let t=e.get(Symbol.for("last-removed"));if(t)return Fj.set(t),MP[0]}function tAe(e,t=DP){PP=e,DP=t}function wu(e,t,r,n,s,i,o,c,l,u,f,d,p){let _=Gj[o];if(!_)throw new Error(`Invalid audit entry type ${o}`);let h=1;if(n&&(n>1?hc.setFloat64(0,n):Fs.set(jR),h=9),l){if(l&255)throw new Error("Illegal extended type");h+=3}R(s),R(t),g(r),hc.setFloat64(h,e),h+=8,l&Fc&&R(u),l&Gc&&R(f),l&s_&&(hc.setFloat64(h,d),h+=8),l&n_&&R(qj[p]),i?g(i):Fs[h++]=0,l?hc.setUint32(n?8:0,_|l|3221225472):Fs[n?8:0]=_;let S=Fs.subarray(0,h);if(c)return Buffer.concat([S,c]);return S;function g(E){let A=h;h+=1,h=(0,Ql.writeKey)(E,Fs,h);let N=h-A-1;N>127?N>16383?(uf.error("Key or username was too large for audit entry",E),h=A+1,Fs[A]=0):(Fs.copyWithin(A+2,A+1,h),hc.setUint16(A,N|32768),h++):Fs[A]=N}function R(E){E<128?Fs[h++]=E:E<16384?(hc.setUint16(h,E|32768),h+=2):E<1056964608?(hc.setUint32(h,E|3221225472),h+=4):(Fs[h]=255,hc.setUint32(h+1,E),h+=5)}}function nAe(e){let t=0;e[0]==66&&(t=8);let r=e[t];if(r<128)return r;let n=e.dataView||(e.dataView=new Tl(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function wt(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new Tl(e.buffer,e.byteOffset,e.byteLength));n.position=t;let s;e[n.position]==66&&(s=n.readFloat64());let i=n.readInt(),o=n.readInt(),c=n.readInt(),l=n.readInt(),u=n.position,f=n.position+=l,d=n.readFloat64(),p,_,h,S;if(i&Fc&&(p=n.readInt()),i&Gc&&(_=n.readInt()),i&s_&&(h=n.readFloat64()),i&n_){let A=n.readInt();S=qj[A]}l=n.readInt();let g=n.position,R=n.position+=l,E;return{type:Gj[i&7],tableId:c,nodeId:o,get recordId(){return(0,Ql.readKey)(e,u,f)},getBinaryRecordId(){return e.subarray(u,f)},version:d,previousLocalTime:s,get user(){return R>g?(0,Ql.readKey)(e,g,R):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(A,N,v){if(i&uA||i&Mh&&!N)return E||(E=Uc(()=>A.decoder.decode(e.subarray(n.position,r)),A.rootStore)),E;if(i&Mh&&v)return Kb(A.getEntry(this.recordId),v,A)},getBinaryValue(){return i&(uA|Mh)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:p,previousResidencyId:_,expiresAt:h,originatingOperation:S}}catch(n){return uf.error("Reading audit entry error",n,e),{}}}var Ql,dA,CP,vh,Hj,uf,Fs,hc,kj,Bp,PP,eAe,MP,Fj,DP,Dj,uA,Mh,Mj,LP,vj,Uj,xj,Bj,jm,rAe,Ug,Fc,Gc,n_,s_,Gn,Gj,qj,Tl,_o=be(()=>{Ql=require("ordered-binary"),dA=M(ce()),CP=M(xt());H();vh=M(rt()),Hj=M(ae());Iu();uf=M(W());BE();Ss();xT();(0,dA.initSync)();Fs=Buffer.alloc(2816),hc=new DataView(Fs.buffer,Fs.byteOffset,2816),kj={writeKey(e,t,r){return e===r_?(t.set(r_,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,Ql.writeKey)(e,t,r)},readKey(e,t,r){return e[t]===66?(e.dataView||(e.dataView=new DataView(e.buffer,e.byteOffset,e.byteLength))).getFloat64(t):(0,Ql.readKey)(e,t,r)}},Bp={encoding:"binary",keyEncoder:kj},PP=(0,Hj.convertToMS)((0,dA.get)(x.LOGGING_AUDITRETENTION))||86400*3,eAe=1e3,MP=new Float64Array(1),Fj=new Uint8Array(MP.buffer),DP=1e4,Dj=!1;a(fA,"openAuditStore");a(_A,"removeAuditEntry");a(Lj,"updateLastRemoved");a(TN,"getLastRemoved");a(tAe,"setAuditRetention");uA=16,Mh=32,Mj=1,LP=2,vj=3,Uj=4,xj=5,Bj=6,jm=14,rAe=15,Ug=11,Fc=512,Gc=1024,n_=2048,s_=4096,Gn=8192,Gj={put:Mj|uA,[Mj]:"put",delete:LP,[LP]:"delete",message:vj|uA,[vj]:"message",invalidate:Uj|Mh,[Uj]:"invalidate",patch:xj|Mh,[xj]:"patch",relocate:Bj,[Bj]:"relocate"},qj={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};a(wu,"createAuditEntry");a(nAe,"readAction");a(wt,"readAuditEntry");Tl=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t;return t=this.getUint8(this.position++),t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch(t){throw t.message=`Error reading float64: ${t.message} at position ${this.position}`,t}}}});function xP(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=Vj,sAe(e.primaryStore,e.auditStore)):(c=$j,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{Kj($j[i])})));let l=c[i]||(c[i]=[]);if(l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now()),s?.scope==="full-database")return;let u=l[o];u||(u=l[o]=new Map,u.envs=l,u.tableId=o,u.store=e.primaryStore),t=Tu(t);let f=new UP(r);f.startTime=n;let d=u.get(t);return d?d.push(f):(u.set(t,d=[f]),d.tables=u,d.key=t),f.subscriptions=d,f}function Kj(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),Yj(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=wt(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,l=Tu(c),u=0;do{let f=o.get(l);if(f){for(let p of f)if(!(u>0&&!(p.includeDescendants&&!(p.onlyChildren&&u>1)))){if(p.startTime>=n){(0,vP.info)("omitting",c,p.startTime,n);continue}try{let _;p.supportsTransactions&&p.txnInProgress!==i.version&&(_=!0,p.txnInProgress||(r?r.push(p):r=[p]),p.txnInProgress=i.version),p.listener(c,i,n,_)}catch(_){console.error(_),(0,vP.info)(_)}}}if(l==null)break;let d=l.lastIndexOf?.("/",l.length-2);d!==l.length-1&&u++,d>-1?l=l.slice(0,d+1):l=null}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function sAe(e,t){let r=t||e,n=r.env;if(!n.hasAfterCommitListener){n.hasAfterCommitListener=!0;let s=n.path;r.on("aftercommit",({next:i,last:o,txnId:c})=>{let l=Vj[s];if(!l)return;let u=a(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),l.txnTime=r.threadLocalWrites[0]||Date.now();try{Kj(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function Yj(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function HF(e){return e.nextTransaction||(xP({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),Yj(e)),e.nextTransaction}var vP,$j,Vj,UP,AN=be(()=>{vP=M(W());hu();Au();_o();$j=Object.create(null),Vj=Object.create(null);a(xP,"addSubscription");UP=class extends Hn{static{a(this,"Subscription")}listener;subscriptions;startTime;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;if(t){let r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};a(Kj,"notifyFromTransactionData");a(sAe,"listenToCommits");a(Yj,"nextTransaction");a(HF,"whenNextTransaction")});var II={};Ue(II,{EVICTED:()=>Ea,INVALIDATED:()=>En,coerceType:()=>mA,makeTable:()=>gA,setServerUtilities:()=>fAe});function gA(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:l,schemaDefined:u,dbisDB:f,sealed:d,splitSegments:p,replicate:_}=e,{expirationMS:h,evictionMS:S,audit:g,trackDeletes:R}=e;S??=0;let{attributes:E}=e;E||(E=[]);let A=XR(i,n,l),N,v,F={},$=Promise.resolve(),Y,ee,oe;for(let V of E)(V.assignCreatedTime||V.name==="__createdtime__")&&(Y=V),(V.assignUpdatedTime||V.name==="__updatedtime__")&&(ee=V),V.expiresAt&&(oe=V),V.isPrimaryKey&&(F=V);let j,se=[],z=[],me=1,Ae=2,Pe={},he={},Ot=864e5,ut=0,br,ms,xn,au=!1,cu,kA=new Map,FA=new Map,Mt,gf,Qh=Zl.get(x.REPLICATION_DATABASES);if(Array.isArray(Qh)){for(let V of Qh)if(V.name===c&&V.replicateTo>=0){gf=V.replicateTo;break}}let Xh=i.getRange({start:!1,end:!1}).constructor,Sf=10,Zh=6;g&&Rf(),Rh(i.env.path,V=>{if(v)return ca(V)});class Ie extends Vr{#e;#t;#n;#r;#s;#i;static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=g;static databasePath=o;static databaseName=c;static attributes=E;static replicate=_;static sealed=d;static splitSegments=p??!0;static createdTimeProperty=Y;static updatedTimeProperty=ee;static propertyResolvers;static userResolvers={};static sources=[];static getResidencyById;static get expirationMS(){return h}static dbisDB=f;static schemaDefined=u;static sourcedFrom(m,T){if(T&&(this.sourceOptions=T,(T.expiration||T.eviction||T.scanInterval)&&this.setTTLExpiration(T)),T?.intermediateSource)m.intermediateSource=!0,this.sources.unshift(m);else{if(this.sources.some(O=>!O.intermediateSource)){if(this.sources.some(O=>O.name===m.name))return;throw new Error("Can not have multiple canonical (non-intermediate) sources")}this.sources.push(m)}v=v||m.get&&(!m.get.reliesOnPrototype||m.prototype.get),N=N||m.load;let b=a(O=>{let U=this.sources;if(U=U.filter(L=>L.intermediateSource&&L[O]&&(!L[O].reliesOnPrototype||L.prototype[O])),U.length>0)if(U.length===1){let L=U[0];return(C,B,q)=>{if(C?.source!==L)return L[O](B,q,C)}}else return(L,C,B)=>{let q=[];for(let Q of U){if(L?.source===Q)break;q.push(Q[O](C,B,L))}return Promise.all(q)}},"getApplyToIntermediateSource"),w=this.sources[this.sources.length-1];w.intermediateSource&&(w={});let y=a(O=>{if(w[O]&&(!w[O].reliesOnPrototype||w.prototype[O]))return(U,L,C)=>{if(!U?.source)return w[O](L,C,U)}},"getApplyToCanonicalSource");Pe={put:y("put"),patch:y("patch"),delete:y("delete"),publish:y("publish")},he={put:b("put"),patch:b("patch"),delete:b("delete"),publish:b("publish"),invalidate:b("invalidate")};let D=w.shouldRevalidateEvents;return(async()=>{let O=!1,U,L=a(async(C,B)=>{let q=C.value,Q=C.table?$e[c][C.table]:Ie;if(c===Of&&(C.table===_u.ROLE_TABLE_NAME||C.table===_u.USER_TABLE_NAME)&&(O=!0),C.id===void 0&&(C.id=q[Q.primaryKey],C.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(C));C.source=m;let X={residencyId:yc(C.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:C.nodeId},k=await Q.getResource(C.id,B,X);switch(C.finished&&await C.finished,C.type){case"put":return D?k._writeInvalidate(q,X):k._writeUpdate(q,!0,X);case"patch":return D?k._writeInvalidate(q,X):k._writeUpdate(q,!1,X);case"delete":return k._writeDelete(X);case"publish":return k._writePublish(q,X);case"invalidate":return k._writeInvalidate(q,X);case"relocate":return k._writeRelocate(X);default:xe.default.error?.("Unknown operation",C.type,C.id)}},"writeUpdate");try{let C=m.subscribe;C&&R==null&&(R=!0);let B={crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0},q=m.subscribeOnThisThread?m.subscribeOnThisThread((0,Xl.getWorkerIndex)(),B):(0,Xl.getWorkerIndex)()===0,Q=C&&q&&await m.subscribe?.(B);if(Q){let X;for await(let k of Q)try{if(!(k.type==="transaction"?k.writes[0]:k)){xe.default.error?.("Bad subscription event",k);continue}if(k.source=m,k.type==="end_txn"){if(X?.resolve(),k.localTime&&U!==k.localTime){if(k.remoteNodeIds?.length>0){let fe=[Symbol.for("seq"),k.remoteNodeIds[0]],ie=f.get(fe),J=ie?.nodes;J||(J=[]);for(let Re of k.remoteNodeIds.slice(1)){let Te=J.find(ve=>ve.id===Re);J=J.filter(ve=>ve.id!==Re||ve===Te),Te||(Te={id:Re,seqId:0},J.push(Te)),Te.seqId=Math.max(ie?.seqId??1,k.localTime),Re===X?.nodeId&&(Te.lastTxnTime=k.timestamp)}let le=Math.max(ie?.seqId??1,k.localTime);xe.default.trace?.("Received txn",c,new Date(le),new Date(k.localTime),k.remoteNodeIds),f.put(fe,{seqId:le,nodes:J})}U=k.localTime}k.onCommit&&X?.committed.then(k.onCommit);continue}if(X)if(k.beginTxn)X.resolve();else{X.write_promises.push(L(k,X));continue}!k.timestamp&&k.version&&(k.timestamp=k.version);let re=Nt(k,()=>{if(k.type==="transaction"){let fe=[];for(let ie of k.writes)try{fe.push(L(ie,k))}catch(J){throw J.message+=" writing "+JSON.stringify(ie)+" of event "+JSON.stringify(k),J}return Promise.all(fe)}else if(k.type==="define_schema"){let fe=this.attributes.slice(0),ie;for(let J of k.attributes)fe.find(le=>le.name===J.name)||(fe.push(J),ie=!0);ie&&(dt({table:s,database:c,attributes:fe,origin:"cluster"}),xh.signalSchemaChange(new Bh.SchemaEventMsg(process.pid,Kt.CREATE_TABLE,c,s)))}else return k.beginTxn?(X=k,X.write_promises=[L(k,k)],new Promise(fe=>{X.resolve=()=>fe(Promise.all(X.write_promises))})):L(k,k)});X&&(X.committed=re),O&&re&&!re?.waitingForUserChange&&(re.then(()=>xh.signalUserChange(new Bh.UserEventMsg(process.pid))),re.waitingForUserChange=!0),k.onCommit&&(re?re.then(k.onCommit):k.onCommit())}catch(de){xe.default.error?.("error in subscription handler",de)}}}catch(C){xe.default.error?.(C)}})(),this}static get isCaching(){return v}static get shouldRevalidateEvents(){return this.prototype.get!==Ie.prototype.get}static getResource(m,T,b){let w=super.getResource(m,T,b);if(m!=null){Cr(m);try{if(w.getRecord?.())return w;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let y=!b?.async||i.cache?.get?.(m),D=Gr(T),O=D.getReadTxn();if(O?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return lu(m,T,{transaction:O,ensureLoaded:b?.ensureLoaded},y,U=>{if(U?Ie._updateResource(w,U):w.#e=null,T.onlyIfCached&&T.noCacheStore){if(!w.doesExist())throw new Ir.ServerError("Entry is not cached",504)}else if(b?.ensureLoaded){let L=dn(m,U,T,w);if(L)return D?.disregardReadTxn(),w.#i=!0,HP(L,C=>(Ie._updateResource(w,C),w))}return w})}catch(y){throw y.message.includes("Unable to serialize object")&&(y.message+=": "+JSON.stringify(m)),y}}return w}static _updateResource(m,T){m.#r=T,m.#e=T?.value??null,m.#n=T?.version}ensureLoaded(){let m=dn(this.getId(),this.#r,this.getContext());if(m)return this.#i=!0,HP(m,T=>{this.#r=T,this.#e=T.value,this.#n=T.version})}static getNewId(){let m=F?.type;if(m==="String"||m==="ID")return super.getNewId();if(!Mt){let y=i.getEntry(Symbol.for("id_allocation")),D=y?.value,O;if(D&&D.nodeName===server.hostname&&(!pAe(i)||D.pid===process.pid)){let U=D.start,L=D.end;O=U;for(let C of i.getKeys({start:L,end:U,limit:1,reverse:!0}))O=C}else D=w(y?.version??null),O=D.start;Mt=new BigInt64Array([BigInt(O)+1n]),Mt=new BigInt64Array(i.getUserSharedBuffer("id",Mt.buffer)),Mt.maxSafeId=D.end}let T=Number(Atomics.add(Mt,0,1n)),b=m==="Int"?512:1048576;if(T+b>=Mt.maxSafeId){let y=a(D=>{Mt.maxSafeId=T+(m==="Int"?1023:4194303);let O=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,U=D?void 0:i.useReadTransaction(),L=Number(Mt[0]);for(let q of i.getKeys({start:L+1,end:O,limit:1,transaction:U}))O=q;U?.done();let{value:C,version:B}=i.getEntry(Symbol.for("id_allocation"));if(Mt.maxSafeId<O){if(C.end>Mt.maxSafeId-100)return;xe.default.info?.("New id allocation",T,Mt.maxSafeId,B),i.put(Symbol.for("id_allocation"),{start:C.start,end:Mt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),B)}else{xe.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${Mt.maxSafeId}, but id of ${O} detected`);let q=w(B);q.alreadyUpdated||Atomics.store(Mt,0,BigInt(q.start+1)),Mt.maxSafeId=q.end}},"updateEnd");T+b===Mt.maxSafeId?setImmediate(y):T+100>=Mt.maxSafeId&&(xe.default.warn?.(`Synchronous id allocation required on table ${s}${m=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>y(!0)))}return T;function w(y){let D=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,O=D/4,U,L,C=!1,B,q;do{B=Math.floor(Math.random()*D),q={start:B,end:B+(m==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},U=0;for(let Q of i.getKeys({start:B,limit:1,reverse:!0}))U=Q;L=D;for(let Q of i.getKeys({start:B+1,end:D,limit:1}))L=Q;O*=.875,O<1e3&&!C&&(C=!0,xe.default.error?.(`Id allocation in table ${s} is very dense, limited safe range of numbers to allocate ids in${m==="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`,B,U,L,O))}while(!(O<L-B&&(O<B-U||U===0)));return i.transactionSync(()=>{let Q=i.getEntry(Symbol.for("id_allocation"));return(Q?.version??null)==y?(xe.default.info?.("Allocated new id range",q),i.put(Symbol.for("id_allocation"),q,Date.now()),q):(xe.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...Q.value})})}}static setTTLExpiration(m){if(typeof m=="number")h=m*1e3,S||(S=0);else if(m&&typeof m=="object")h=m.expiration*1e3,S=(m.eviction||0)*1e3,Ot=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(h<0)throw new Error("Expiration can not be negative");Ot=Ot||(h+S)/4,ca()}static getResidencyRecord(m){return f.get([Symbol.for("residency_by_id"),m])}static setResidency(m){Ie.getResidency=m}static setResidencyById(m){Ie.getResidencyById=m}static getResidency(m,T){if(Ie.getResidencyById)return Ie.getResidencyById(m[t]);let b=gf;if(T.replicateTo!=null){if(Array.isArray(T.replicateTo))return T.replicateTo.includes(server.hostname)?T.replicateTo:[server.hostname,...T.replicateTo];T.replicateTo>=0&&(b=T.replicateTo)}if(b>=0&&server.nodes){let w=[server.hostname];if(T.previousResidency)w.push(...T.previousResidency.slice(0,b));else{let y=server.nodes.map(U=>U.name),D=Math.floor(y.length*Math.random());w.push(...y.slice(D,D+b));let O=D+b-y.length;O>0&&w.push(...y.slice(0,O))}return w}}static enableAuditing(m=!0){g=m,m&&Rf(),Ie.audit=m}static coerceId(m){return m===""?null:mA(m,F)}static async dropTable(){delete $e[c][s];for(let m of i.getRange({versions:!0,snapshot:!1,lazy:!0}))m.metadataFlags&Gn&&m.value&&Aa(m.value);if(c===o){for(let m of E)f.remove(Ie.tableName+"/"+m.name),r[m.name]?.drop();f.remove(Ie.tableName+"/"),i.drop(),await f.committed}else console.log("legacy dropTable"),await i.close(),await hA.default.remove(data_path),await hA.default.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));xh.signalSchemaChange(new Bh.SchemaEventMsg(process.pid,Kt.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this.isCollection)return this.search(m);if(this.getId()===null)return m?.conditions?this.search(m):{records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:E};if(m?.property)return this.getProperty(m.property);if(this.doesExist()||m?.ensureLoaded===!1||this.getContext()?.returnNonexistent)return this}allowRead(m,T){let b=Af(m);if(b?.read){if(b.isSuperUser)return!0;let w=b.attribute_permissions,y=T?.select;if(w?.length>0||au&&y){if(T||(T={}),y){let D=w?.length>0&&BP(w,"read");T.select=y.map(O=>{let U=O.name||O;if(!D||D[U]){let L=xn[U]?.definition?.tableClass;if(L){if(O.name||(O={name:O}),!L.prototype.allowRead.call(null,m,O))return!1;if(!O.select)return O.name}return O}}).filter(Boolean)}else T.select=w.filter(D=>D.read&&!xn[D.attribute_name]).map(D=>D.attribute_name);return T}else return!0}}allowUpdate(m,T){let b=Af(m);if(b?.update){let w=b.attribute_permissions;if(w?.length>0){let y=BP(w,"update");for(let D in T)if(!y[D])return!1;for(let D of w){let O=D.attribute_name;!D.update&&!(O in T)&&(T[O]=this.getProperty(O))}}return aa(this.getContext())}}allowCreate(m,T){if(this.isCollection){let b=Af(m);if(b?.insert){let w=b.attribute_permissions;if(w?.length>0){let y=BP(w,"insert");for(let D in T)if(!y[D])return!1;return aa(this.getContext())}else return aa(this.getContext())}}else return this.allowUpdate(m,{})}allowDelete(m){return Af(m)?.delete&&aa(this.getContext())}update(m,T){if(!Gr(this.getContext()))throw new Error("Can not update a table resource outside of a transaction");if(m===!1)return this;let w;return typeof m=="object"&&m&&(T?(Object.isFrozen(m)&&(m={...m}),this.#e={},this.#t=m):(w=this.#t,w&&(m=Object.assign(w,m)),this.#t=m)),this._writeUpdate(this.#t,T),this}addTo(m,T){if(typeof T=="number"||typeof T=="bigint")this.#s===zj?this.set(m,(+this.getProperty(m)||0)+T):(this.#s||this.update(),this.set(m,new FE(T)));else throw new Error("Can not add a non-numeric value")}subtractFrom(m,T){if(typeof T=="number")return this.addTo(m,-T);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this.#r}getRecord(){return this.#e}getChanges(){return this.#t}_setChanges(m){this.#t=m}setRecord(m){this.#e=m}invalidate(){this._writeInvalidate()}_writeInvalidate(m,T){let b=this.getContext(),w=this.getId();Cr(w),Gr(this.getContext()).addWrite({key:w,store:i,invalidated:!0,entry:this.#r,before:Pe.invalidate?.bind(this,b,w),beforeIntermediate:he.invalidate?.bind(this,b,w),commit:a((D,O)=>{if(!(oa(D,O,T?.nodeId)<=0)){m??=null;for(let U in r)m||(m={}),m[U]===void 0&&(m[U]=this.getProperty(U));xe.default.trace?.(`Invalidating entry id: ${w}, timestamp: ${new Date(D).toISOString()}`),A(w,m,this.#r,D,En,g,{user:b?.user,residencyId:T?.residencyId,nodeId:T?.nodeId},"invalidate")}},"commit")})}_writeRelocate(m){let T=this.getContext(),b=this.getId();Cr(b),Gr(this.getContext()).addWrite({key:b,store:i,invalidated:!0,entry:this.#r,before:Pe.relocate?.bind(this,T,b),beforeIntermediate:he.relocate?.bind(this,T,b),commit:a((y,D)=>{if(oa(y,D,m?.nodeId)<=0)return;let O=Ie.getResidencyRecord(m.residencyId),U=0,L=null,C=D?.value;if(O&&!O.includes(server.hostname)){for(let B in r)L||(L={}),L[B]=C(B);U=En}else L=C;xe.default.trace?.(`Relocating entry id: ${b}, timestamp: ${new Date(y).toISOString()}`),A(b,L,this.#r,y,U,g,{user:T.user,residencyId:m.residencyId,nodeId:m.nodeId,expiresAt:m.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(m,T){let b={previousResidency:this.getResidencyRecord(m.residencyId),isRelocation:!0},w=Rc(this.getResidency(T.value,b)),y;if(w){if(!w.includes(server.hostname))return;y=yc(w)}let O=A(m.key,T.value,m,m.version,0,!0,{residencyId:y,expiresAt:T.expiresAt},"relocate",!1,null)}static evict(m,T,b){let w=this.Source,y;if(!((v||g)&&(!T||(y=i.getEntry(m),!y||!T)||y.version!==b))){if(v){if(i.hasLock(m,y.version))return;let D;for(let O in r)D||(D={}),D[O]=T[O];if(D)return A(m,D,y,b,Ea,null,null,null,!0)}if(i.ifVersion(m,b,()=>{un(m,T,null)}),g)return A(m,null,y,b,Ea,null,null,null,!0);kc(i,y??i.getEntry(m),b)}}lock(){throw new Error("Not yet implemented")}static operation(m,T){return m.table||=s,m.schema||=c,rJ.operation(m,T)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,T,b){let w=this.getContext(),y=Gr(w),D=this.getId();Cr(D);let O=this.#r;this.#s=T?zj:lAe;let U={key:D,store:i,entry:O,nodeName:w?.nodeName,validate:a(L=>{m||(m=this.#t),T||m&&HE(this.#t===m?this:m)?w?.source||(y.checkOverloaded(),this.validate(m,!T),ee&&(m[ee.name]=ee.type==="Date"?new Date(L):ee.type==="String"?new Date(L).toISOString():L),T&&(t&&m[t]!==D&&(m[t]=D),Y&&(O?.value?m[Y.name]=O?.value[Y.name]:m[Y.name]=Y.type==="Date"?new Date(L):Y.type==="String"?new Date(L).toISOString():L),m=il(m))):y.removeWrite(U)},"validate"),before:T?Pe.put?()=>Pe.put(w,D,m):null:Pe.patch?()=>Pe.patch(w,D,m):Pe.put?()=>Pe.put(w,D,il(this)):null,beforeIntermediate:T?he.put?()=>he.put(w,D,m):null:he.patch?()=>he.patch(w,D,m):he.put?()=>he.put(w,D,il(this)):null,commit:a((L,C,B)=>{if(B){if(w&&C?.version>(w.lastModified||0)&&(w.lastModified=C.version),this.#r=C,C?.value&&C.value.getRecord)throw new Error("Can not assign a record to a record, check for circular references");T||(this.#e=C?.value??null)}this.#t=void 0,this.#n=L;let q=C?.value,Q=m;this.#s=0;let X=!1,k=oa(L,C,b?.nodeId),de;if(k<=0)if(g){let le=C.localTime,Re=C.version;xe.default.trace?.("Applying CRDT update to record with id: ",D,"applying later update:",Re);let Te=[];for(;le>L||Re>=L&&le>0;){let ve=l.get(le);if(!ve)break;let Je=wt(ve);if(Re=Je.version,Re>=L){if(Re===L){if(k=oa(L,{version:Re,localTime:le},b?.nodeId),k===0)return;if(k>0)continue}if(Je.type==="patch")Te.push(Je),de=m;else if(Je.type==="put"||Je.type==="delete")return}le=Je.previousLocalTime}Te.sort((ve,Je)=>ve.version-Je.version);for(let ve of Te){let Je=ve.getValue(i);if(Q=xE(Q,Je,T),xe.default.debug?.("Rebuilding update with future patch:",Q),!Q)return}}else{if(T)return;Q=xE(Q,q,T),xe.default.debug?.("Rebuilding update without audit:",Q)}let re;if(T?re=Q:(this.#e=q,re=il(this,Q)),this.#e=re,re&&re.getRecord)throw new Error("Can not assign a record to a record, check for circular references");let fe;if(b?.residencyId!=null)fe=b.residencyId;else{O?.residencyId&&(w.previousResidency=Ie.getResidencyRecord(O.residencyId));let le=Rc(Ie.getResidency(re,w));if(le&&!le.includes(server.hostname))if(de??=re,X=!0,Ie.getResidencyById)re=void 0;else{re=null;for(let Re in r)re||(re={}),re[Re]=de[Re]}fe=yc(le)}T||(de=m);let ie=w?.expiresAt??(h?h+Date.now():-1);xe.default.trace?.(`Saving record with id: ${D}, timestamp: ${new Date(L).toISOString()}${ie?", expires at: "+new Date(ie).toISOString():""}${C?", replaces entry from: "+new Date(C.version).toISOString():", new entry"}`,(()=>{try{return JSON.stringify(re).slice(0,100)}catch{return""}})()),un(D,q,re);let J=T?"put":"patch";A(D,re,C,L,X?En:0,g,{omitLocalRecord:X,user:w?.user,residencyId:fe,expiresAt:ie,nodeId:b?.nodeId,originatingOperation:w?.originatingOperation},J,!1,de),w.expiresAt&&ca()},"commit")};y.addWrite(U)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this.isCollection){for await(let T of this.search(m))(await Ie.getResource(T[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this.#e?this._writeDelete(m):!1}_writeDelete(m){let T=Gr(this.getContext()),b=this.getId();Cr(b);let w=this.getContext();return T.addWrite({key:b,store:i,entry:this.#r,nodeName:w?.nodeName,before:Pe.delete?.bind(this,w,b),beforeIntermediate:he.delete?.bind(this,w,b),commit:a((y,D,O)=>{let U=D?.value;O&&(w&&D?.version>(w.lastModified||0)&&(w.lastModified=D.version),Ie._updateResource(this,D)),!(oa(y,D,m?.nodeId)<=0)&&(un(this.getId(),U),xe.default.trace?.(`Deleting record with id: ${b}, txn timestamp: ${new Date(y).toISOString()}`),g||R?(A(b,null,this.#r,y,0,g,{user:w?.user,nodeId:m?.nodeId},"delete"),g||ca()):kc(i,D))},"commit")}),!0}search(m){let T=this.getContext(),b=Gr(T);if(!m)throw new Error("No query provided");let w=m.conditions;w?w.length===void 0&&(w=w[Symbol.iterator]?Array.from(w):[w]):w=Array.isArray(m)?m:m[Symbol.iterator]?Array.from(m):[],this.getId()&&(w=[{attribute:null,comparator:Array.isArray(this.getId())?"prefix":"starts_with",value:this.getId()}].concat(w));let y,D={};function O(J,le){let Re;switch(le){case"and":case void 0:if(J.length<1)throw new Error('An "and" operator requires at least one condition');Re=!0;break;case"or":if(J.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+le)}for(let Te of J){if(Te.conditions){Te.conditions=O(Te.conditions,Te.operator);continue}let ve=Te[0]??Te.attribute,Je=ve==null?F:Oi(E,ve);if(Je)(Je.type||hR[Te.comparator])&&(Te[1]===void 0?Te.value=L(Te.value,Je):Te[1]=L(Te[1],Je));else if(ve!=null)throw(0,Ir.handleHDBError)(new Error,`${ve} is not a defined attribute`,404);if(Te.chainedConditions)if(Te.chainedConditions.length===1&&(!Te.operator||Te.operator=="and")){let Zt=Te.chainedConditions[0],qr,ye;if(Zt.comparator==="gt"||Zt.comparator==="greater_than"||Zt.comparator==="ge"||Zt.comparator==="greater_than_equal"?(qr=Te,ye=Zt):(qr=Zt,ye=Te),qr.comparator!=="lt"&&qr.comparator!=="less_than"&&qr.comparator!=="le"&&qr.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let tt=ye.comparator==="ge"||ye.comparator==="greater_than_equal",vt=qr.comparator==="le"||qr.comparator==="less_than_equal";Te.comparator=(tt?"ge":"gt")+(vt?"le":"lt"),Te.value=[ye.value,qr.value]}else throw new Error("Multiple chained conditions are not currently supported")}return J}a(O,"prepareConditions");function U(J,le){if(m.enforceExecutionOrder)return J;for(let Re of J)Re.conditions&&(Re.conditions=U(Re.conditions,Re.operator));return J.length>1&&le!=="or"?(0,eJ.sortBy)(J,Om(Ie)):J}a(U,"orderConditions");function L(J,le){return Array.isArray(J)?J.map(Re=>mA(Re,le)):mA(J,le)}a(L,"coerceTypedValues");let C=m.operator;(w.length>0||C)&&(w=O(w,C));let B=typeof m.sort=="object"&&m.sort,q;if(B&&C!=="or"){let J=B.attribute;if(J==null)throw new Ir.ClientError("Sort requires an attribute");if(y=w.find(le=>Su(le.attribute)===Su(J)),!y){let le=Oi(E,J);if(!le)throw(0,Ir.handleHDBError)(new Error,`${Array.isArray(J)?J.join("."):J} is not a defined attribute`,404);if(le.indexed)y={attribute:J,comparator:"sort"},w.push(y);else if(w.length===0&&!m.allowFullScan)throw(0,Ir.handleHDBError)(new Error,`${Array.isArray(J)?J.join("."):J} is not indexed and not combined with any other conditions`,404)}y&&(y.descending=!!B.descending)}w=U(w,C),B&&(y&&w[0]===y?B.next&&(q={dbOrderedAttribute:B.attribute,attribute:B.next.attribute,descending:B.next.descending,next:B.next.next}):(y&&w.splice(w.indexOf(y),1),q=B));let Q=m.select;if(w.length===0&&(w=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:w,operator:C,postOrdering:q,selectApplied:!!Q};let X=b.useReadTxn(),k=mR(w,C,Ie,X,m,T,(J,le)=>du(J,Q,T,X,le),D),de=m.ensureLoaded!==!1;q||(k=ie(k));let re=Ie.transformEntryForSelect(Q,T,X,D,de,!0),fe=Ie.transformToOrderedSelect(k,Q,q,X,T,re);function ie(J){return m.offset||m.limit!==void 0?J.slice(m.offset,m.limit!==void 0?(m.offset||0)+m.limit:void 0):J}return a(ie,"applyOffset"),q&&(fe=ie(fe)),fe.onDone=()=>{fe.onDone=null,b.doneReadTxn()},fe.selectApplied=!0,fe.getColumns=()=>{if(Q){let J=[];for(let le of Q)le==="*"?J.push(...E.map(Re=>Re.name)):J.push(le.name||le);return J}return E.filter(J=>!J.computed&&!J.relationship).map(J=>J.name)},fe}static transformToOrderedSelect(m,T,b,w,y,D){let O=new Xh;if(b){m=du(m,T,w,y,null);let U;O.iterate=function(){let C,B=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),q,Q=b.dbOrderedAttribute,X,k,de=!0;function re(ie){let J=ie.next&&re(ie.next),le=ie.descending;return(Re,Te)=>{let ve=uu(Re,ie.attribute,w),Je=uu(Te,ie.attribute,w),Zt=le?(0,eu.compareKeys)(Je,ve):(0,eu.compareKeys)(ve,Je);return Zt===0?J?.(Re,Te)||0:Zt}}a(re,"createComparator");let fe=re(b);return{async next(){let ie;if(C)if(ie=C.next(),ie.done){if(q)return O.onDone&&O.onDone(),ie}else return{value:await D.call(this,ie.value)};U=[],X&&U.push(X);do if(ie=await B.next(),ie.done){if(q=!0,U.length)break;return O.onDone&&O.onDone(),ie}else{let J=ie.value;if(J?.then&&(J=await J),Q){let le=uu(J,Q,w);if(de)de=!1,k=le;else if(le!==k){k=le,X=J;break}}U.push(J)}while(!0);return b.isGrouped,U.sort(fe),C=U[Symbol.iterator](),ie=C.next(),ie.done?(O.onDone&&O.onDone(),ie):{value:await D.call(this,ie.value)}},return(){O.onDone&&O.onDone(),B.return()},throw(){O.onDone&&O.onDone(),B.throw()}}};let L=a(C=>{if(typeof T=="object"&&Array.isArray(C.attribute))for(let B=0;B<T.length;B++){let q=T[B],Q;if(q.name===C.attribute[0]){for(Q=q.sort||(q.sort={});Q.next;)Q=Q.next;Q.attribute=C.attribute.slice(1),Q.descending=C.descending}else q===C.attribute[0]&&(T[B]=Q={name:q,sort:{attribute:C.attribute.slice(1),descending:C.descending}})}C.next&&L(C.next)},"applySortingOnSelect");L(b)}else O.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),O=O.map(function(U){try{let L=D.call(this,U);return typeof L?.catch=="function"?L.catch(C=>{throw C.partialObject={[t]:U.key},C}):L}catch(L){throw L.partialObject={[t]:U.key},L}});return O}static transformEntryForSelect(m,T,b,w,y,D){if(m&&(m===t||m?.length===1&&m[0]===t&&Array.isArray(m))){let C=a(B=>(T?.transaction?.stale&&(T.transaction.stale=!1),B?.key??B),"transform");return m===t?C:m.asArray?B=>[C(B)]:B=>({[t]:C(B)})}let O;y&&v&&!(typeof m=="string"?[m]:m)?.every(C=>{let B;return typeof C=="object"?B=C.name:B=C,r[B]||B===t})&&(O=!0);let U,L=a(function(C){let B;if(T?.transaction?.stale&&(T.transaction.stale=!1),C!=null){if(B=C.value||C.deref?.()?.value,!B&&(C.key===void 0||C.deref)||C.metadataFlags&En){if(C.metadataFlags&En&&T.replicateFrom===!1&&D&&C.residencyId)return Ec.SKIP;if(C=lu(C.key??C,T,{transaction:b,lazy:m?.length<4,ensureLoaded:y},this?.isSync,q=>q),C?.then)return C.then(L.bind(this));B=C?.value}if(O&&C?.metadataFlags&(En|Ea)||C?.expiresAt!=null&&C?.expiresAt<Date.now()){if(T.onlyIfCached&&T.noCacheStore)return{[t]:C.key,message:"This entry has expired"};let q=dn(C.key??C,C,T);if(q?.then)return q.then(L)}}if(B==null)return D?Ec.SKIP:B;if(m&&!(m[0]==="*"&&m.length===1)){let q,Q=a((k,de)=>{let re;typeof k=="object"?re=k.name:re=k;let fe=xn?.[re],ie;if(fe){let J=w?.[re];if(J)if(J.hasMappings){let Re=fe.from?B[fe.from]:Su(C.key);ie=J.get(Re),ie||(ie=[])}else ie=J.fromRecord?.(B);else ie=fe(B,T,C);let le=a(Re=>{if(Re&&typeof Re=="object"){let Te=fe.definition?.tableClass||Ie;U||(U={});let ve=U[re]||(U[re]=Te.transformEntryForSelect(re===k?null:k.select||(Array.isArray(k)?k:null),T,b,J,y));if(Array.isArray(Re)){let Je=[],Zt=Te.transformToOrderedSelect(Re,k.select,typeof k.sort=="object"&&k.sort,T,b,ve)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),qr=a(tt=>{for(;!tt.done;){if(tt?.then)return tt.then(qr);Je.push(tt.value),tt=Zt.next()}de(Je,re)},"nextValue"),ye=qr(Zt.next());ye&&(q||(q=[]),q.push(ye));return}else if(Re=ve.call(this,Re),Re?.then){q||(q=[]),q.push(Re.then(Je=>de(Je,re)));return}}de(Re,re)},"handleResolvedValue");ie?.then?(q||(q=[]),q.push(ie.then(le))):le(ie);return}else ie=B[re],ie&&typeof ie=="object"&&re!==k&&(ie=Ie.transformEntryForSelect(k.select||k,T,b,null)({value:ie}));de(ie,re)},"selectAttribute"),X;if(typeof m=="string")Q(m,k=>{X=k});else if(Array.isArray(m))if(m.asArray)X=[],m.forEach((k,de)=>{k==="*"?m[de]=B:Q(k,re=>X[de]=re)});else{X={};let k=m.forceNulls;for(let de of m)if(de==="*")for(let re in B)X[re]=B[re];else Q(de,(re,fe)=>{re===void 0&&k&&(re=null),X[fe]=re})}else throw new Ir.ClientError("Invalid select"+m);return q?Promise.all(q).then(()=>X):X}return B},"transform");return L}async subscribe(m){if(!l)throw new Error("Can not subscribe to a table without an audit log");g||dt({table:s,database:c,schemaDefined:u,attributes:E,audit:!0}),m||(m={});let T=!m.rawEvents,b=[],w=this,y=xP(Ie,this.getId()??null,function(O,U,L,C){try{let B=U.getValue?.(i,T),q=U.type;if(!B&&q==="patch"&&T){let X=i.getEntry(O);X?.version===U.version?B=X.value:B=U.getValue?.(i,!0,L),q="put"}let Q={id:O,localTime:L,value:B,version:U.version,type:q,beginTxn:C};b?b.push(Q):this.send(Q)}catch(B){xe.default.error?.(B)}},m.startTime||0,m),D=(async()=>{this.isCollection&&(y.includeDescendants=!0,m.onlyChildren&&(y.onlyChildren=!0)),m.supportsTransactions&&(y.supportsTransactions=!0);let O=this.getId(),U=m.previousCount;U>1e3&&(U=1e3);let L=m.startTime;if(this.isCollection){if(L){if(U)throw new Ir.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:C,value:B}of l.getRange({start:L,exclusiveStart:!0,snapshot:!1})){let q=wt(B);if(q.tableId!==n)continue;let Q=q.recordId;if(O==null||Xj(O,Q)){let X=q.getValue(i,T,C);if(y.send({id:Q,localTime:C,value:X,version:q.version,type:q.type}),y.queue?.length>Jj&&await y.waitForDrain()===!1)return}y.startTime=C}}else if(U){let C=[];for(let{key:B,value:q}of l.getRange({start:"z",end:!1,reverse:!0}))try{let Q=wt(q);if(Q.tableId!==n)continue;let X=Q.recordId;if(O==null||Xj(O,X)){let k=Q.getValue(i,T,B);if(C.push({id:X,localTime:B,value:k,version:Q.version,type:Q.type}),--U<=0)break}}catch(Q){xe.default.error("Error getting history entry",B,Q)}for(let B=C.length;B>0;)y.send(C[--B]);C[0]&&(y.startTime=C[0].localTime)}else if(!m.omitCurrent){for(let{key:C,value:B,version:q,localTime:Q}of i.getRange({start:O??!1,end:O==null?void 0:[O,eu.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(B&&(y.send({id:C,localTime:Q,value:B,version:q,type:"put"}),y.queue?.length>Jj&&await y.waitForDrain()===!1))return}}else{U&&!L&&(L=0);let C=this.#r?.localTime;if(C===QR&&(i.cache?.delete(O),this.#r=i.getEntry(O),xe.default.trace?.("re-retrieved record",C,this.#r?.localTime),C=this.#r?.localTime),xe.default.trace?.("Subscription from",L,"from",O,C),L<C){let B=[],q=C;do{let Q=l.get(q);if(Q){m.omitCurrent=!0;let X=wt(Q),k=X.getValue(i,T,q);T&&(X.type="put"),B.push({id:O,value:k,localTime:q,...X}),q=X.previousLocalTime}else break;U&&U--}while(q>L&&U!==0);for(let Q=B.length;Q>0;)y.send(B[--Q]);y.startTime=C}!m.omitCurrent&&this.doesExist()&&y.send({id:O,localTime:C,value:this.#e,version:this.#n,type:"put"})}for(let C of b)y.send(C);b=null})();return m.listener&&y.on("data",m.listener),y}static subscribeOnThisThread(m,T){return m===0||T?.crossThreads===!1}doesExist(){return!!(this.#e||this.#s)}publish(m,T){this._writePublish(m,T)}_writePublish(m,T){let b=Gr(this.getContext()),w=this.getId()||null;w!=null&&Cr(w);let y=this.getContext();b.addWrite({key:w,store:i,entry:this.#r,nodeName:y?.nodeName,validate:a(()=>{y?.source||(b.checkOverloaded(),this.validate(m))},"validate"),before:Pe.publish?.bind(this,y,w,m),beforeIntermediate:he.publish?.bind(this,y,w,m),commit:a((D,O,U)=>{O===void 0&&R&&!g&&ca(),xe.default.trace?.(`Publishing message to id: ${w}, timestamp: ${new Date(D).toISOString()}`),A(w,O?.value??null,O,O?.version||D,0,!0,{user:y?.user,residencyId:T?.residencyId,expiresAt:y?.expiresAt,nodeId:T?.nodeId},"message",!1,m)},"commit")})}validate(m,T){let b,w=a((y,D,O)=>{if(D.type&&y!=null)if(T&&y.__op__&&(y=y.value),D.properties){typeof y!="object"&&(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be an object${D.type?" ("+D.type+")":""}`);let U=D.properties;for(let L=0,C=U.length;L<C;L++){let B=U[L],q=w(y[B.name],B,O+"."+B.name);q&&(y[B.name]=q)}if(D.sealed&&y!=null&&typeof y=="object")for(let L in y)U.find(C=>C.name===L)||(b||(b=[])).push(`Property ${L} is not allowed within object in property ${O}`)}else switch(D.type){case"Int":(typeof y!="number"||y>>0!==y)&&(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof y!="number"||!(Math.floor(y)===y&&Math.abs(y)<=9007199254740992))&&(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof y!="number"&&(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be a number`);break;case"ID":typeof y=="string"||y?.length>0&&y.every?.(U=>typeof U=="string")||(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be a string, or an array of strings`);break;case"String":typeof y!="string"&&(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be a string`);break;case"Boolean":typeof y!="boolean"&&(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be a boolean`);break;case"Date":if(!(y instanceof Date)){if(typeof y=="string"||typeof y=="number")return new Date(y);(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be a Date`)}break;case"BigInt":if(typeof y!="bigint"){if(typeof y=="string"||typeof y=="number")return BigInt(y);(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be a bigint`)}break;case"Bytes":if(!(y instanceof Uint8Array)){if(typeof y=="string")return Buffer.from(y);(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be a Buffer or Uint8Array`)}break;case"Blob":if(!(y instanceof Ii)){if(typeof y=="string"&&(y=Buffer.from(y)),y instanceof Buffer)return createBlob(y,{type:"text/plain"});(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be a Blob`)}break;case"array":if(Array.isArray(y)){if(D.elements)for(let U=0,L=y.length;U<L;U++){let C=y[U],B=w(C,D.elements,O+"[*]");B&&(y[U]=B)}}else(b||(b=[])).push(`Value ${Gs(y)} in property ${O} must be an Array`);break}D.nullable===!1&&y==null&&(b||(b=[])).push(`Property ${O} is required (and not does not allow null values)`)},"validateValue");for(let y=0,D=E.length;y<D;y++){let O=E[y];if(!(O.relationship||O.computed)&&(!T||O.name in m)){let U=w(m[O.name],O,O.name);U&&(m[O.name]=U)}}if(d)for(let y in m)E.find(D=>D.name===y)||(b||(b=[])).push(`Property ${y} is not allowed`);if(b)throw new Ir.ClientError(b.join(". "))}getUpdatedTime(){return this.#n}wasLoadedFromSource(){return v?!!this.#i:void 0}static async addAttributes(m){let T=E.slice(0);for(let b of m){if(!b.name)throw new Ir.ClientError("Attribute name is required");if(b.name.match(/[`/]/))throw new Ir.ClientError("Attribute names cannot include backticks or forward slashes");(0,tJ.validateAttribute)(b.name),T.push(b)}return dt({table:s,database:c,schemaDefined:u,attributes:T}),Ie.indexingOperation}static async removeAttributes(m){let T=E.filter(b=>!m.includes(b.name));return dt({table:s,database:c,schemaDefined:u,attributes:T}),Ie.indexingOperation}static getSize(){let m=i.getStats();return(m.treeBranchPageCount+m.treeLeafPageCount+m.overflowPages)*m.pageSize}static getAuditSize(){let m=l?.getStats();return m&&(m.treeBranchPageCount+m.treeLeafPageCount+m.overflowPages)*m.pageSize}static getStorageStats(){let m=i.env.path,T=hA.default.statfsSync?.(m)??{};return{available:T.bavail*T.bsize,free:T.bfree*T.bsize,size:T.blocks*T.bsize}}static async getRecordCount(m){let T=i.getStats().entryCount,b=1e3/2,w=performance.now(),y=Math.floor(T/2),D=m?.exactCount,O=0,U=0,L;for(let{value:C}of i.getRange({start:!0,lazy:!0,snapshot:!1}))if(C!=null&&O++,U++,await mc(),!D&&U<y&&performance.now()-w>b){L=U;break}if(L){let C=O;O=0;for(let{value:ie}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:L,snapshot:!1}))ie!=null&&O++,await mc();let B=L*2,q=(O+C)/B,Q=Math.pow((O-C+1)/L/2,2)+q*(1-q)/B,X=Math.max(Math.sqrt(Q)*T,1),k=Math.round(q*T),de=Math.max(k-1.96*X,O+C),re=Math.min(k+1.96*X,T),fe=Math.pow(10,Math.round(Math.log10(X)));return fe>k&&(fe=fe/10),O=Math.round(k/fe)*fe,{recordCount:O,estimatedRange:[Math.round(de),Math.round(re)]}}return{recordCount:O}}static updatedAttributes(){xn=this.propertyResolvers={$id:a((m,T,b)=>({value:b.key}),"$id"),$updatedtime:a((m,T,b)=>b.version,"$updatedtime"),$record:a((m,T,b)=>b?{value:m}:m,"$record")};for(let m of this.attributes){m.resolve=null;let T=m.relationship,b=m.computed;if(T)if(m.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),b&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),au=!0,T.to)m.elements?.definition?(xn[m.name]=m.resolve=(w,y,D)=>{let O=w[T.from?T.from:t],U=m.elements.definition.tableClass;return D?gu({attribute:T.to,value:O},Gr(y).getReadTxn(),!1,U,!1).asArray:U.search([{attribute:T.to,value:O}],y).asArray},m.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},m.resolve.definition=m.elements.definition,T.from&&(m.resolve.from=T.from)):console.error(`The one-to-many/many-to-many relationship property "${m.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(T.from){let w=m.definition||m.elements?.definition;w?(xn[m.name]=m.resolve=(y,D,O)=>{let U=y[T.from];if(U!==void 0){if(m.elements){let L,C=U?.map(B=>{let q=O?w.tableClass.primaryStore.getEntry(B,{transaction:Gr(D).getReadTxn()}):w.tableClass.get(B,D);return q?.then&&(L=!0),q});return T.filterMissing?L?Promise.all(C).then(B=>B.filter(Zj)):C.filter(Zj):L?Promise.all(C):C}return O?w.tableClass.primaryStore.getEntry(U,{transaction:Gr(D).getReadTxn()}):w.tableClass.get(U,D)}},m.set=(y,D)=>{if(Array.isArray(D)){let O=D.map(U=>U.getId?.()||U[w.tableClass.primaryKey]);y[T.from]=O}else{let O=D.getId?.()||D[w.tableClass.primaryKey];y[T.from]=O}},m.resolve.definition=m.definition||m.elements?.definition,m.resolve.from=T.from):console.error(`The relationship property "${m.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${m.name}" in table "${s}" must use either "from" or "to" arguments`);else b&&(typeof b.from=="function"&&this.setComputedAttribute(m.name,b.from),xn[m.name]=m.resolve=(w,y,D)=>{let O=typeof b.from=="string"?w[b.from]:w,U=this.userResolvers[m.name];if(U)return U(O,y,D);xe.default.warn(`Computed attribute "${m.name}" does not have a function assigned to it. Please use setComputedAttribute('${m.name}', resolver) to assign a resolver function.`),this.userResolvers[m.name]=()=>{}})}GE(this,this)}static setComputedAttribute(m,T){let b=Oi(E,m);if(!b){console.error(`The attribute "${m}" does not exist in the table "${s}"`);return}if(!b.computed){console.error(`The attribute "${m}" is not defined as computed in the table "${s}"`);return}this.userResolvers[m]=T}static async deleteHistory(m=0,T=!1){let b;for(let{key:w,value:y}of l.getRange({start:0,end:m}))await mc(),wt(y).tableId===n&&(b=_A(l,w,y));if(T)for(let w of i.getRange({start:0,versions:!0})){let{key:y,value:D,localTime:O}=w;await mc(),D===null&&O<m&&(b=kc(i,w))}await b}static async*getHistory(m=0,T=1/0){for(let{key:b,value:w}of l.getRange({start:m||1,end:T})){await mc();let y=wt(w);y.tableId===n&&(yield{id:y.recordId,localTime:b,version:y.version,type:y.type,value:y.getValue(i,!0,b),user:y.user,operation:y.originatingOperation})}}static async getHistoryOfRecord(m){let T=[];if(m==null)throw new Error("An id is required");let b=i.getEntry(m);if(!b)return T;let w=b.localTime;if(!w)throw new Error("The entry does not have a local audit time");let y=0;do{await mc();let D=l.get(w);if(D){let O=wt(D);T.push({id:O.recordId,localTime:w,version:O.version,type:O.type,value:O.getValue(i,!0,w),user:O.user}),w=O.previousLocalTime}else break}while(y<1e3&&w);return T.reverse()}static cleanup(){j?.remove()}}Ie.updatedAttributes();let Tf=Ie.prototype;return h&&Ie.setTTLExpiration(h/1e3),oe&&fu(),Ie;function un(V,m,T){let b;for(let w in r){let y=r[w],D=y.isIndexing,O=xn[w],U=T&&(O?O(T):T[w]),L=m&&(O?O(m):m[w]);if(U===L&&!D)continue;b=!0;let C=y.indexNulls,B=(0,Uh.getIndexedValues)(U,C),q=(0,Uh.getIndexedValues)(L,C);if(q?.length>0){let Q=new Set(q);if(B=B?B.filter(X=>{if(Q.has(X))Q.delete(X);else return!0}):[],q=Array.from(Q),(q.length>0||B.length>0)&&Wj){let X=q.concat(B).map(k=>({key:k,value:V}));y.prefetch(X,Qj)}for(let X=0,k=q.length;X<k;X++)y.remove(q[X],V)}else B?.length>0&&Wj&&y.prefetch(B.map(Q=>({key:Q,value:V})),Qj);if(B)for(let Q=0,X=B.length;Q<X;Q++)y.put(B[Q],V)}return b}a(un,"updateIndices");function Cr(V){switch(typeof V){case"number":return!0;case"string":if(V.length<659)return!0;if(V.length>jj)throw new Error("Primary key size is too large: "+V.length);break;case"object":if(V===null)throw new Error("Invalid primary key of null");break;case"bigint":if(V<2n**64n&&V>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof V)}if((0,eu.writeKey)(V,uAe,0)>jj)throw new Error("Primary key size is too large: "+V.length);return!0}a(Cr,"checkValidId");function lu(V,m,T,b,w){if(Ie.getResidencyById&&T.ensureLoaded&&m?.replicateFrom!==!1){let D=Rc(Ie.getResidencyById(V));if(D&&!D.includes(server.hostname)&&N)return N({key:V,residency:D}).then(w)}let y=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),T.transaction?.isDone)return w(null,V);let D=i.getEntry(V,T);return D?.residencyId&&D.metadataFlags&En&&N&&T.ensureLoaded&&m?.replicateFrom!==!1?N(D).then(O=>w(O,V),O=>(xe.default.error?.("Error loading remote record",V,D,T,O),w(null,V))):(D&&m&&(D?.version>(m.lastModified||0)&&(m.lastModified=D.version),D?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=D.localTime)),w(D,V))},"whenPrefetched");return b?y():me>0?(me--,y()):new Promise((D,O)=>{me===0?(me--,i.prefetch([V],()=>{U(),L()})):(se.push(V),z.push(L),se.length>Zh&&(me--,U()));function U(){if(se.length>0){let C=z;i.prefetch(se,()=>{me===-1?U():me++;for(let B of C)B()}),se=[],z=[],Ae>2&&Ae--}else me=Ae,Ae<Sf&&Ae++}a(U,"prefetch");function L(){try{D(y())}catch(C){O(C)}}a(L,"load")})}a(lu,"loadLocalRecord");function Af(V){if(!V?.role)return;let m=V.role.permission;if(m.super_user)return dAe;let T=m[c],b,w=T?.tables;if(w)return w[s];if(c==="data"&&(b=m[s])&&!b.tables)return b}a(Af,"getTablePermissions");function dn(V,m,T,b){if(v){let w=!1;if(T.noCache?w=!0:(m?(!m.value||m.metadataFlags&(En|Ea)||m.expiresAt!=null&&m.expiresAt<Date.now())&&(w=!0):w=!0,Xn(!w,"cache-hit",s)),w){let y=em(V,m,T).then(D=>(D?.value&&D?.value.getRecord?.()&&xe.default.error?.("Can not assign a record that is already a resource"),T&&(D?.version>(T.lastModified||0)&&(T.lastModified=D.version),T.lastRefreshed=Date.now()),D));if(T?.onlyIfCached||m?.value&&b?.allowStaleWhileRevalidate?.(m,V)){if(y.catch(D=>xe.default.warn?.(D)),T?.onlyIfCached&&!b.doesExist())throw new Ir.ServerError("Entry is not cached",504);return}else return y}}else if(m?.value&&m.expiresAt!=null&&m.expiresAt<Date.now())return Ie.evict(m.key,m.value,m.version),m.value=null,{then(w){return w(m)}}}a(dn,"ensureLoadedFromSource");function Gr(V){let m=V?.transaction;if(m){if(!m.lmdbDb)return m.lmdbDb=i,m;do{if(m.lmdbDb?.path===i.path)return m;let T=m.next;if(!T)return m=m.next=new Ic,m.lmdbDb=i,m;m=T}while(!0)}else return new Rm}a(Gr,"txnForContext");function uu(V,m,T){if(!V)return;let b=V.value||i.getEntry(V.key)?.value;if(typeof m=="object"){let y=xn,D=b;for(let O=0,U=m.length;O<U;O++){let L=m[O],C=y?.[L];D=C&&D?C(D,T,!0)?.value:D?.[L],y=C?.definition?.tableClass?.propertyResolvers}return D}let w=xn[m];return w?w(b,T):b[m]}a(uu,"getAttributeValue");function du(V,m,T,b,w){let y=w?.length,D={transaction:b,lazy:y>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},O;function U(L,C){let B=L?.value;if(!B)return Ec.SKIP;for(let q=0;q<y;q++)if(!O?.includes(q)&&!w[q](B,L))return Ec.SKIP;return C!==void 0&&(L.key=C),L}if(a(U,"processEntry"),y>0||!V.hasEntries){let L=V.map(C=>{if(O=null,typeof C=="object"&&C?.key!==void 0)return y>0?U(C):C;if(C==null)return Ec.SKIP;for(let B=0;B<y;B++){let Q=w[B].idFilter;if(Q){if(!Q(C))return Ec.SKIP;O||(O=[]),O.push(B)}}return lu(C,T,D,!1,U)});return Array.isArray(V)&&(L=L.filter(C=>C!==Ec.SKIP)),L.hasEntries=!0,L}return V}a(du,"transformToEntries");function oa(V,m,T=server.replication?.getThisNodeId(l)){if(V<=m?.version){if(m?.version===V&&T!==void 0){let b=server.replication?.exportIdMapping(l),w=m.localTime,y=w&&l.get(w);if(y){let D,O,U=wt(y);for(let L in b)b[L]===T&&(D=L),b[L]===U.nodeId&&(O=L);if(D>O)return 1;if(D===O)return 0}}return-1}return 1}a(oa,"precedesExistingVersion");async function em(V,m,T){let b=m?.metadataFlags,w=m?.version,y,D;if(!i.attemptLock(V,w,()=>{clearTimeout(D);let C=i.getEntry(V);!C||!C.value||C.metadataFlags&(En|Ea)?y(em(V,i.getEntry(V),T)):y(C)}))return new Promise(C=>{y=C,D=setTimeout(()=>{i.unlock(V,w)},cAe)});let O=m?.value,U={requestContext:T,replacingRecord:O,replacingEntry:m,replacingVersion:w,noCacheStore:!1,source:null,resourceCache:T?.resourceCache},L=T?.responseHeaders;return new Promise((C,B)=>{let q;HP(Nt(U,async Q=>{let X=performance.now(),k,de,re;try{for(let le of Ie.sources)if(le.get&&(!le.get.reliesOnPrototype||le.prototype.get)){if(le.available?.(m)===!1)continue;if(U.source=le,k=await le.get(V,U),k)break}re=b&En;let ie=U.lastModified||re&&w;de=re||ie>w||!O,ie||(ie=(0,Uh.getNextMonotonicTime)());let J=performance.now()-X;if(sr(J,"cache-resolution",s,null,"success"),L&&eg(L,"Server-Timing",`cache-resolve;dur=${J.toFixed(2)}`,!0),Q.timestamp=ie,h&&U.expiresAt==null&&(U.expiresAt=Date.now()+h),k){if(typeof k!="object")throw new Error("Only objects can be cached and stored in tables");if(k.status>0&&k.headers)if(k.status>=300)if(k.status===304)k=O,ie=w;else throw new Ir.ServerError(k.body||"Error from source",k.status);else k=k.body;typeof k.toJSON=="function"&&(k=k.toJSON()),t&&k[t]!==V&&(k[t]=V)}q=!0,C({key:V,version:ie,value:k})}catch(ie){ie.message+=` while resolving record ${V} for ${s}`,O&&((ie.code==="ECONNRESET"||ie.code==="ECONNREFUSED"||ie.code==="EAI_AGAIN")&&!T?.mustRevalidate||T?.staleIfError&&(ie.statusCode===500||ie.statusCode===502||ie.statusCode===503||ie.statusCode===504))?(C({key:V,version:w,value:O}),xe.default.trace?.(ie.message,"(returned stale record)")):B(ie);let J=performance.now()-X;sr(J,"cache-resolution",s,null,"fail"),L&&eg(L,"Server-Timing",`cache-resolve;dur=${J.toFixed(2)}`,!0),U.transaction.abort();return}if(T?.noCacheStore||U.noCacheStore){U.transaction.abort();return}Gr(U).addWrite({key:V,store:i,entry:m,nodeName:"source",commit:a((ie,J)=>{if(J?.version!==w)return;let le=un(V,O,k);if(k){he.put?.(U,V,k),J&&(T.previousResidency=Ie.getResidencyRecord(J.residencyId));let Re,Te=!1,ve,Je=Rc(Ie.getResidency(k,T));if(Je){if(!Je.includes(server.hostname))if(Re=k,Te=!0,Ie.getResidencyById)k=void 0;else{k=null;for(let Zt in r)k||(k={}),k[Zt]=Re[Zt]}ve=yc(Je)}xe.default.trace?.(`Writing resolved record from source with id: ${V}, timestamp: ${new Date(ie).toISOString()}`),A(V,k,J,ie,Te?En:0,g&&(de||Te)||null,{user:U?.user,expiresAt:U.expiresAt,residencyId:ve},"put",!!re,Re)}else J&&(he.delete?.(U,V),xe.default.trace?.(`Deleting resolved record from source with id: ${V}, timestamp: ${new Date(ie).toISOString()}`),g||R?A(V,null,J,ie,0,g&&de||null,{user:U?.user},"delete",!!re):kc(i,J,w))},"commit")})}),()=>{i.unlock(V,w)},Q=>{i.unlock(V,w),q&&xe.default.error?.("Error committing cache update",Q)})})}a(em,"getFromSource");function aa(V){if(!V||V.user?.role?.permission?.super_user)return!0;if(V.replicateTo)throw new Ir.ClientError("Can not specify replication parameters without super user permissions",403);if(V.replicatedConfirmation)throw new Ir.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}a(aa,"checkContextPermissions");function ca(V){let m=!1;if(V&&(V-ut>1&&(m=!0),ut=V),!(Ot===br&&!m)&&(br=Ot,(0,Xl.getWorkerIndex)()===(0,Xl.getWorkerCount)()-1))return ms&&clearTimeout(ms),Ot?new Promise(T=>{let b=new Date;b.setMonth(0),b.setDate(1),b.setHours(0),b.setMinutes(0),b.setSeconds(0);let w=Ot/(1+ut),y=m?Date.now():Math.ceil((Date.now()-b.getTime())/w)*w+b.getTime(),D=a(O=>{xe.default.trace?.(`Scheduled next cleanup scan at ${new Date(O)}`),ms=setTimeout(()=>$=$.then(async()=>{if(D(Math.max(O+Ot,Date.now())),i.rootStore.status!=="open"){clearTimeout(ms);return}let U=50,L=new Array(U),C=0,B=Math.pow(ut,8)*(Zl.get(x.STORAGE_RECLAMATION_EVICTIONFACTOR)??1e5),q=S/Math.pow(Math.max(ut,1),4);xe.default.info?.(`Starting cleanup scan for ${s}, evict threshold ${B}, adjusted eviction ${q}ms`);function Q(X,k,de,re){let fe=X+q-Date.now();if(fe<0)return!0;if(ut){let ie=i.lastSize;return de&Gn&&bu(re,J=>{J.size&&(ie+=J.size)}),xe.default.trace?.(`shouldEvict adjusted ${fe} ${ie}, ${fe*(X-k)/ie} < ${B}`),fe*(X-k)/ie<B}return!1}a(Q,"shouldEvict");try{let X=0;for(let k of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let{key:de,value:re,version:fe,expiresAt:ie,metadataFlags:J}=k,le;re===null&&!g&&fe+aAe<Date.now()?le=kc(i,k,fe):ie!=null&&Q(ie,fe,J,re)&&(le=Ie.evict(de,re,fe),X++),le&&(await L[C],L[C]=le.catch(Re=>{xe.default.error?.("Cleanup error",Re)}),++C>=U&&(C=0)),await mc()}xe.default.info?.(`Finished cleanup scan for ${s}, evicted ${X} entries`)}catch(X){xe.default.warn?.(`Error in cleanup scan for ${s}:`,X)}T(void 0),ut=0}),Math.min(O-Date.now(),2147483647)).unref()},"startNextTimer");D(y)}):void 0}a(ca,"scheduleCleanup");function Rf(){j=l?.addDeleteRemovalCallback(n,i,(V,m)=>{i.remove(V,m)})}a(Rf,"addDeleteRemoval");function fu(){(0,Xl.getWorkerIndex)()===0&&setInterval(async()=>{if(!cu){cu=!0;try{let V=oe.name,m=r[V];if(!m)throw new Error(`expiresAt attribute ${oe} must be indexed`);for(let T of m.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let b of m.getValues(T)){let w=i.getEntry(b);w?.value?w.value[V]<Date.now()&&Ie.evict(b,w.value,w.version):i.ifVersion(b,w?.version,()=>m.remove(T,b))}await mc()}}catch(V){xe.default.error?.("Error in evicting old records",V)}finally{cu=!1}}},oAe).unref()}a(fu,"runRecordExpirationEviction");function Rc(V){if(V!=null){if(Array.isArray(V))return V;if(typeof V=="number"){if(V>=65536)throw new Error(`Shard id ${V} must be below 65536`);let m=server.shards?.get?.(V);if(m)return xe.default.trace?.(`Shard ${V} mapped to ${m.map(T=>T.name).join(", ")}`),m.map(T=>T.name);throw new Error(`Shard ${V} is not defined`)}throw new Error(`Shard or residency list ${V} is not a valid type, must be a shard number or residency list of node hostnames`)}}a(Rc,"residencyFromFunction");function yc(V){if(V){let m=V.join(","),T=f.get([Symbol.for("residency_by_set"),m]);return T||(f.put([Symbol.for("residency_by_set"),m],T=Math.floor(Math.random()*2147418112)+65535),f.put([Symbol.for("residency_by_id"),T],V),T)}}a(yc,"getResidencyId")}function BP(e,t){let r=e.attr_object||(e.attr_object={}),n=r[t];if(n)return n;n=r[t]=Object.create(null);for(let s of e)n[s.attribute_name]=s[t];return n}function Qj(){}function fAe(e){rJ=e}function mA(e,t){let r=t?.type;if(e===null)return e;if(e===""&&r&&r!=="String"&&r!=="Any")return null;try{switch(r){case"Int":case"Long":if(e[0]==="$")return pA(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return pA(+e);case"Float":return e==="null"?null:pA(+e);case"BigInt":return e==="null"?null:BigInt(e);case"Boolean":return e==="true"?!0:e==="false"?!1:e;case"Date":if(isNaN(e)){if(e==="null")return null;_Ae.test(e)||(e+="Z");let n=new Date(e);return pA(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,EA.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function pA(e){if(isNaN(e))throw new SyntaxError;return e}function Xj(e,t){if(e==null)return!0;if(!Array.isArray(t))return e===t||t.startsWith?.(e);if(Array.isArray(e)){let r=e.length;if(e[r-1]===null&&r--,t.length>=r){for(let n=0;n<r;n++)if(t[n]!==e[n])return!1;return!0}return!1}else if(t[0]===e)return!0}function HP(e,t,r){return e?.then?e.then(t,r):t(e)}function Zj(e){return e!=null}function Gs(e){try{return JSON.stringify(e)}catch{return e}}function pAe(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var Ec,Uh,eJ,tJ,Zl,Ir,xh,Bh,xe,eu,Xl,EA,hA,iAe,rJ,oAe,aAe,Wj,cAe,zj,lAe,En,Ea,uAe,jj,Jj,dAe,oxe,_Ae,mc,$f=be(()=>{H();Ec=require("lmdb"),Uh=M(pn()),eJ=require("lodash"),tJ=M(Bf());ga();ym();Zl=M(ce());AN();Ir=M(pe()),xh=M(Ao()),Bh=M(ni());De();qf();xe=M(wi());zb();Cc();eu=require("ordered-binary"),Xl=M(rt());_o();EA=M(ae());Iu();Fi();BE();j_();hA=M(require("node:fs"));Ss();xT();iAe=new Uint8Array(9);iAe[8]=192;oAe=6e4,aAe=864e5;Zl.initSync();Wj=Zl.get(x.STORAGE_PREFETCHWRITES),cAe=1e4,zj=1,lAe=2,En=1,Ea=8,uAe=Buffer.allocUnsafeSlow(8192),jj=1978,Jj=100,dAe={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},oxe=(0,EA.convertToMS)(Zl.get(x.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(gA,"makeTable");a(BP,"attributesAsObject");a(Qj,"noop");a(fAe,"setServerUtilities");_Ae=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(mA,"coerceType");a(pA,"rejectNaN");a(Xj,"isDescendantId");mc=a(()=>new Promise(setImmediate),"rest");a(HP,"when");a(Zj,"exists");a(Gs,"stringify");a(pAe,"hasOtherProcesses")});var nt={};Ue(nt,{database:()=>$u,database_envs:()=>ta,databases:()=>$e,dropDatabase:()=>Zb,dropTableMeta:()=>SAe,getDatabases:()=>Xe,getDefaultCompression:()=>PS,getTables:()=>hAe,onRemovedDB:()=>hp,onUpdatedTable:()=>Al,readMetaDb:()=>Hh,resetDatabases:()=>Ld,table:()=>dt,tables:()=>Qn});function hAe(){return RA||Xe(),Qn||{}}function Xe(){if(RA)return $e;RA=!0,_f=new Map;let e=(0,Xt.getHdbBasePath)()&&(0,Dt.join)((0,Xt.getHdbBasePath)(),wc),t=(0,Xt.get)(x.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,Xt.get)(x.STORAGE_PATH)||e&&((0,ds.existsSync)(e)?e:(0,Dt.join)((0,Xt.getHdbBasePath)(),am)),!e)return;if((0,ds.existsSync)(e))for(let n of(0,ds.readdirSync)(e,{withFileTypes:!0})){let s=(0,Dt.basename)(n.name,".mdb");n.isFile()&&(0,Dt.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&Hh((0,Dt.join)(e,n.name),null,s)}if((0,ds.existsSync)((0,ff.getBaseSchemaPath)())){for(let n of(0,ds.readdirSync)((0,ff.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,Dt.join)((0,ff.getBaseSchemaPath)(),n.name),i=(0,Dt.join)((0,ff.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,ds.readdirSync)(s,{withFileTypes:!0}))if(o.isFile()&&(0,Dt.extname)(o.name).toLowerCase()===".mdb"){let c=(0,Dt.join)(i,o.name);Hh((0,Dt.join)(s,o.name),(0,Dt.basename)(o.name,".mdb"),n.name,c,!0)}}}if(t)for(let n in t){let s=t[n],i=s.path;if((0,ds.existsSync)(i))for(let c of(0,ds.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,Dt.extname)(c.name).toLowerCase()===".mdb"&&Hh((0,Dt.join)(i,c.name),(0,Dt.basename)(c.name,".mdb"),n);let o=s.tables;if(o)for(let c in o){let l=o[c],u=(0,Dt.join)(l.path,(0,Dt.basename)(c+".mdb"));(0,ds.existsSync)(u)&&Hh(u,c,n,null,!0)}}for(let n in $e){let s=_f.get(n);if(s){let i=$e[n];n.includes("delete")&&qt.trace(`defined tables ${Array.from(s.keys())}`);for(let o in i)s.has(o)||(qt.trace(`delete table class ${o}`),delete i[o])}else if(delete $e[n],n==="data"){for(let i in Qn)delete Qn[i];delete Qn[yA]}}let r=["hdb_temp","hdb_certificate","hdb_analytics","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if($e.system)for(let n of r)$e.system[n]&&($e.system[n].replicate=!1);return _f=null,$e}function Ld(){RA=!1;for(let[,e]of ta)e.needsDeletion=!0;Xe();for(let[e,t]of ta)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),ta.delete(e),delete $e[t.databaseName],Fh.forEach(r=>r(t.databaseName)));return $e}function Hh(e,t,r=GP,n,s){let i=new kP.default(e,!1);try{let o=ta.get(e);o?o.needsDeletion=!1:(o=(0,pf.open)(i),ta.set(e,o));let c=new tu.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(SA.INTERNAL_DBIS_NAME,c)),u=o.auditStore;u||(n?(0,ds.existsSync)(n)&&(i.path=n,u=(0,pf.open)(i),u.isLegacy=!0):u=fA(o));let f=oJ(r),d=f[yA],p=new Map;for(let{key:_,value:h}of l.getRange({start:!1})){let[S,g]=_.toString().split("/");g===""?g=h.name:g||(g=S,S=t,h.name||(h.name=g,h.indexed=!h.is_hash_attribute)),d?.add(S);let R=p.get(S);R||p.set(S,R={attributes:[]}),(g==null||h.is_hash_attribute)&&(R.primary=h),g!=null&&R.attributes.push(h),Object.defineProperty(h,"key",{value:_,configurable:!0})}for(let[_,h]of p){let{attributes:S,primary:g}=h;if(!g){for(let z of S)if(z.is_hash_attribute||z.isPrimaryKey){g=z;break}if(!g){qt.warn(`Unable to find a primary key attribute on table ${_}, with attributes: ${JSON.stringify(S)}`);continue}}let R=f[_],E={},A=[],N,v,F=typeof g.audit=="boolean"?g.audit:(0,Xt.get)(x.LOGGING_AUDITLOG),$=g.trackDeletes,Y=g.expiration,ee=g.eviction,oe=g.sealed,j=g.splitSegments,se=g.replicate;if(R)E=R.indices,A=R.attributes,R.schemaVersion++;else{N=g.tableId,N?N>=(l.get(df)||0)&&(l.putSync(df,N+1),qt.info(`Updating next table id (it was out of sync) to ${N+1} for ${_}`)):(g.tableId=N=l.get(df),N||(N=1),qt.debug("Table {table_name} missing an id, assigning {table_id}"),l.putSync(df,N+1),l.putSync(g.key,g));let z=new tu.default(!g.is_hash_attribute,g.is_hash_attribute);if(z.compression=g.compression,z.compression){let me=(0,Xt.get)(x.STORAGE_COMPRESSION_THRESHOLD)||iJ;z.compression.threshold=me}v=Qm(o.openDB(g.key,z),o),o.databaseName=r,v.tableId=N}for(let z of S){z.attribute=z.name;try{if(!z.is_hash_attribute&&(z.indexed||z.attribute&&!z.name)){if(!E[z.name]){let Ae=new tu.default(!z.is_hash_attribute,z.is_hash_attribute);E[z.name]=o.openDB(z.key,Ae),E[z.name].indexNulls=z.indexNulls}let me=A.find(Ae=>Ae.name===z.name);me?A.splice(A.indexOf(me),1,z):A.push(z)}}catch(me){qt.error("Error trying to update attribute",z,A,E,me)}}if(!R){R=aJ(f,_,gA({primaryStore:v,auditStore:u,audit:F,sealed:oe,splitSegments:j,replicate:se,expirationMS:Y&&Y*1e3,evictionMS:ee&&ee*1e3,trackDeletes:$,tableName:_,tableId:N,primaryKey:g.name,databasePath:s?r+"/"+_:r,databaseName:r,indices:E,attributes:S,schemaDefined:g.schemaDefined,dbisDB:l})),R.schemaVersion=1;for(let z of kh)z(R)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function oJ(e){let t=$e[e];if(t||(e==="data"?t=$e[e]=Qn:e==="system"?Object.defineProperty($e,"system",{value:t=Object.create(null),configurable:!0}):t=$e[e]=Object.create(null)),_f&&!_f.has(e)){let r=new Set;t[yA]=r,_f.set(e,r)}return t}function aJ(e,t,r){return e[t]=r,r}function $u({database:e,table:t}){e||(e=GP),Xe();let r=oJ(e),n=(0,Dt.join)((0,Xt.getHdbBasePath)(),wc),s=(0,Xt.get)(x.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,Xt.get)(x.STORAGE_PATH)||((0,ds.existsSync)(n)?n:(0,Dt.join)((0,Xt.getHdbBasePath)(),am));let o=(0,Dt.join)(n,(i?t:e)+".mdb"),c=ta.get(o);if(!c||c.status==="closed"){let l=new kP.default(o,!1);c=(0,pf.open)(l),ta.set(o,c)}return c.auditStore||(c.auditStore=fA(c)),c}async function Zb(e){if(!$e[e])throw new Error("Schema does not exist");let t=$e[e],r;for(let n in t)r=t[n].primaryStore.rootStore,ta.delete(r.path),r.status==="open"&&(await r.close(),await Gh.remove(r.path));if(r||(r=$u({database:e,table:null}),r.status==="open"&&(await r.close(),await Gh.remove(r.path))),e==="data"){for(let n in Qn)delete Qn[n];delete Qn[yA]}delete $e[e],Fh.forEach(n=>n(e)),await CR(r)}function dt(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:o,audit:c,sealed:l,splitSegments:u,replicate:f,trackDeletes:d,schemaDefined:p,origin:_}=e;r||(r=GP);let h=$u({database:r,table:t}),S=$e[r];qt.trace(`Defining ${t} in ${r}`);let g=S?.[t];if(h.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let R,E,A;p==null&&(p=!0);let N=new tu.default(!1);for(let j of o)j.attribute&&!j.name?(j.name=j.attribute,j.indexed=!0):j.attribute=j.name,j.expiresAt&&(j.indexed=!0);let v,F;if(g){if(R=g.primaryKey,g.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);u==null&&(u=g.splitSegments),g.attributes.splice(0,g.attributes.length,...o)}else{let j=h.auditStore;E=o.find(Ae=>Ae.isPrimaryKey)||{},R=E.name,E.is_hash_attribute=E.isPrimaryKey=!0,E.schemaDefined=p,E.compression=PS(),d&&(E.trackDeletes=!0),c=E.audit=typeof c=="boolean"?c:(0,Xt.get)(x.LOGGING_AUDITLOG),n&&(E.expiration=n),s&&(E.eviction=s),u??=!1,E.splitSegments=u,typeof l=="boolean"&&(E.sealed=l),typeof f=="boolean"&&(E.replicate=f),_&&(E.origins?E.origins.includes(_)||E.origins.push(_):E.origins=[_]),qt.trace(`${t} table loading, opening primary store`);let se=new tu.default(!1,!0);se.compression=E.compression;let z=t+"/";if(A=h.dbisDb=h.openDB(SA.INTERNAL_DBIS_NAME,N),oe(),A.get(z))return F&&F(),Ld(),dt(e);let me=Qm(h.openDB(z,se),h);h.databaseName=r,me.tableId=A.get(df),qt.trace(`Assigning new table id ${me.tableId} for ${t}`),me.tableId||(me.tableId=1),A.put(df,me.tableId+1),E.tableId=me.tableId,g=aJ(S,t,gA({primaryStore:me,auditStore:j,audit:c,sealed:l,splitSegments:u,replicate:f,trackDeletes:d,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:R,tableName:t,tableId:me.tableId,databasePath:r,databaseName:r,indices:{},attributes:o,schemaDefined:p,dbisDB:A})),g.schemaVersion=1,v=!0,A.put(z,E)}let $=g.indices;A=A||(h.dbisDb=h.openDB(SA.INTERNAL_DBIS_NAME,N)),g.dbisDB=A;let Y=[];for(let{key:j,value:se}of A.getRange({start:!0})){let[z,me]=j.toString().split("/");if(me===""&&(me=se.name),me){if(z!==t)continue}else continue;let Ae=o.find(he=>he.name===me),Pe=!Ae?.indexed&&se.indexed&&!se.isPrimaryKey;if((!Ae||Pe)&&(oe(),v=!0,Ae||A.remove(j),Pe)){let he=g.indices[z];he&&Y.push(he)}}let ee=[];try{for(let j of o||[]){if((j.relationship||j.computed)&&(v=!0,j.relationship))continue;let se=t+"/"+(j.name||"");Object.defineProperty(j,"key",{value:se,configurable:!0});let z=A.get(se);if(j.isPrimaryKey){if(z=z||A.get(se=t+"/")||{},c!==void 0&&c!==g.audit||l!==void 0&&l!==g.sealed||f!==void 0&&f!==g.replicate||(+n||void 0)!==(+z.expiration||void 0)||(+s||void 0)!==(+z.eviction||void 0)){let Ae={...z};typeof c=="boolean"&&(c&&g.enableAuditing(c),Ae.audit=c),n&&(Ae.expiration=+n),s&&(Ae.eviction=+s),l!==void 0&&(Ae.sealed=l),f!==void 0&&(Ae.replicate=f),v=!0,oe(),A.put(se,Ae)}continue}z?.attribute&&!z.name&&(z.indexed=!0);let me=!z||z.type!==j.type||z.indexed!==j.indexed||z.nullable!==j.nullable||z.version!==j.version||JSON.stringify(z.properties)!==JSON.stringify(j.properties)||JSON.stringify(z.elements)!==JSON.stringify(j.elements);if(j.indexed){let Ae=new tu.default(!0,!1),Pe=h.openDB(se,Ae);(me||z.indexingPID&&z.indexingPID!==process.pid||z.restartNumber<qh.workerData?.restartNumber)&&(v=!0,oe(),z=A.get(se),(me||z.indexingPID&&z.indexingPID!==process.pid||z.restartNumber<qh.workerData?.restartNumber)&&(v=!0,j.indexNulls===void 0&&(j.indexNulls=!0),g.primaryStore.getStats().entryCount>0&&(j.lastIndexedKey=z?.lastIndexedKey??void 0,j.indexingPID=process.pid,Pe.isIndexing=!0,Object.defineProperty(j,"dbi",{value:Pe}),ee.push(j))),A.put(se,j)),z?.indexNulls&&j.indexNulls===void 0&&(j.indexNulls=!0),Pe.indexNulls=j.indexNulls,$[j.name]=Pe}else me&&(v=!0,oe(),A.put(se,j))}}finally{F&&F()}if(v&&(g.schemaVersion++,g.updatedAttributes()),qt.trace(`${t} table loading, running index`),ee.length>0||Y.length>0?g.indexingOperation=gAe(g,ee,Y):v&&TA.signalSchemaChange(new AA.SchemaEventMsg(process.pid,"schema-change",g.databaseName,g.tableName)),g.origin=_,v)for(let j of kh)j(g,_!=="cluster");return(n||s||i)&&g.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),qt.trace(`${t} table loaded`),g;function oe(){F||h.transactionSync(()=>({then(j){F=j}}))}a(oe,"startTxn")}async function gAe(e,t,r){try{qt.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await TA.signalSchemaChange(new AA.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o={},c=0,l=t.length;if(await new Promise(u=>setImmediate(u)),l>0){let u;for(let d of t)(0,pf.compareKeys)(d.lastIndexedKey,u)<0&&(u=d.lastIndexedKey),d.lastIndexedKey==null&&d.dbi.clearAsync();let f=0;for(let{key:d,value:p,version:_}of e.primaryStore.getRange({start:u,lazy:l<4,versions:!0,snapshot:!1}))if(p){if(f++,s=e.primaryStore.ifVersion(d,_,()=>{for(let h=0;h<l;h++){let S=t[h],g=S.name;try{let R=S.resolve,E=p&&(R?R(p):p[g]),A=(0,nJ.getIndexedValues)(E);if(A)for(let N=0,v=A.length;N<v;N++)S.dbi.put(A[N],d)}catch(R){o[g]||(o[g]=!0,qt.error(`Error indexing attribute ${g}`,R))}}}),s.then(()=>f--,h=>{f--,qt.error(h)}),qh.workerData&&qh.workerData.restartNumber!==sJ.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=d,e.dbisDB.put(h.key,h);if(i)return}f>mAe?await s:f>EAe&&await new Promise(h=>setImmediate(h))}for(let d of t)delete d.lastIndexedKey,delete d.indexingPID,d.dbi.isIndexing=!1,s=e.dbisDB.put(d.key,d)}await s,await TA.signalSchemaChange(new AA.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),qt.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){qt.error("Error in indexing",n)}}function SAe({table:e,database:t}){let r=$u({database:t,table:e}),n=[],s=r.dbisDb;for(let i of s.getKeys({start:e+"/",end:e+"0"}))n.push(s.remove(i));return Promise.all(n)}function Al(e){return kh.push(e),{remove(){let t=kh.indexOf(e);t>-1&&kh.splice(t,1)}}}function hp(e){return Fh.push(e),{remove(){let t=Fh.indexOf(e);t>-1&&Fh.splice(t,1)}}}function PS(){let e=(0,Xt.get)(x.STORAGE_COMPRESSION),t=(0,Xt.get)(x.STORAGE_COMPRESSION_DICTIONARY),r=(0,Xt.get)(x.STORAGE_COMPRESSION_THRESHOLD)||iJ,n={startingOffset:32};return t&&(n.dictionary=Gh.readFileSync(t)),r&&(n.threshold=r),e&&n}var Xt,SA,pf,Dt,ds,ff,tu,kP,Gh,FP,nJ,TA,AA,qh,qt,sJ,GP,yA,iJ,Qn,$e,df,kh,Fh,RA,ta,_f,mAe,EAe,De=be(()=>{Xt=M(ce()),SA=M(xt()),pf=require("lmdb"),Dt=require("path"),ds=require("fs"),ff=M(Et());$f();tu=M(i_()),kP=M(o_());H();Gh=M(require("fs-extra")),FP=M(Ai()),nJ=M(pn()),TA=M(Ao()),AA=M(ni()),qh=require("worker_threads"),qt=M(W()),sJ=M(rt());_o();Iu();Ss();GP="data",yA=Symbol("defined-tables"),iJ=((0,Xt.get)(x.STORAGE_PAGESIZE)||4096)-60;(0,Xt.initSync)();Qn=Object.create(null),$e=Object.create(null);(0,FP._assignPackageExport)("databases",$e);(0,FP._assignPackageExport)("tables",Qn);df=Symbol.for("next-table-id"),kh=[],Fh=[],ta=new Map;a(hAe,"getTables");a(Xe,"getDatabases");a(Ld,"resetDatabases");a(Hh,"readMetaDb");a(oJ,"ensureDB");a(aJ,"setTable");a($u,"database");a(Zb,"dropDatabase");a(dt,"table");mAe=1e3,EAe=10;a(gAe,"runIndexing");a(SAe,"dropTableMeta");a(Al,"onUpdatedTable");a(hp,"onRemovedDB");a(PS,"getDefaultCompression")});var ae=I((Exe,AJ)=>{"use strict";var gc=require("path"),fJ=require("fs-extra"),vn=W(),cJ=require("fs-extra"),bA=require("os"),TAe=require("net"),AAe=require("recursive-iterator"),yr=(H(),P(G)),{PACKAGE_ROOT:RAe}=st(),yAe=oR(),lJ=require("papaparse"),OA=require("moment"),{inspect:bAe}=require("util"),uJ=require("is-number"),mxe=require("lodash"),OAe=require("minimist"),NAe=require("https"),wAe=require("http"),{hdb_errors:NA}=pe(),IAe=/^((\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d\.\d+([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z)))$/,_J=require("util").promisify(setTimeout),CAe=100,PAe=5,DAe="",LAe=4,dJ={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};AJ.exports={isEmpty:fs,isEmptyOrZeroLength:ro,arrayHasEmptyValues:UAe,arrayHasEmptyOrZeroLengthValues:xAe,buildFolderPath:BAe,isBoolean:pJ,errorizeMessage:MAe,stripFileExtension:kAe,autoCast:FAe,autoCastJSON:hJ,autoCastJSONDeep:$P,removeDir:GAe,compareVersions:qAe,isCompatibleDataVersion:$Ae,escapeRawValue:VAe,unescapeValue:KAe,stringifyProps:YAe,timeoutPromise:zAe,isClusterOperation:JAe,getClusterUser:XAe,checkGlobalSchemaTable:QAe,getHomeDir:EJ,getPropsFilePath:WAe,promisifyPapaParse:ZAe,removeBOM:gJ,createEventPromise:eRe,checkProcessRunning:tRe,checkSchemaTableExist:rRe,checkSchemaExists:SJ,checkTableExists:TJ,getStartOfTomorrowInSeconds:nRe,getLimitKey:sRe,isObject:HAe,isNotEmptyAndHasValue:vAe,autoCasterIsNumberCheck:mJ,backtickASTSchemaItems:iRe,isPortTaken:jAe,createForkArgs:oRe,autoCastBoolean:aRe,async_set_timeout:_J,getTableHashAttribute:cRe,doesSchemaExist:lRe,doesTableExist:uRe,stringifyObj:dRe,ms_to_time:fRe,changeExtension:_Re,getEnvCliRootPath:VP,noBootFile:pRe,httpRequest:hRe,transformReq:mRe,convertToMS:ERe,PACKAGE_ROOT:RAe};function MAe(e){return e instanceof Error?e:new Error(e)}a(MAe,"errorizeMessage");function fs(e){return e==null}a(fs,"isEmpty");function vAe(e){return!fs(e)&&(e||e===0||e===""||pJ(e))}a(vAe,"isNotEmptyAndHasValue");function ro(e){return fs(e)||e.length===0||e.size===0}a(ro,"isEmptyOrZeroLength");function UAe(e){if(fs(e))return!0;for(let t=0;t<e.length;t++)if(fs(e[t]))return!0;return!1}a(UAe,"arrayHasEmptyValues");function xAe(e){if(ro(e))return!0;for(let t=0;t<e.length;t++)if(ro(e[t]))return!0;return!1}a(xAe,"arrayHasEmptyOrZeroLengthValues");function BAe(...e){try{return e.join(gc.sep)}catch{console.error(e)}}a(BAe,"buildFolderPath");function pJ(e){return fs(e)?!1:e===!0||e===!1}a(pJ,"isBoolean");function HAe(e){return fs(e)?!1:typeof e=="object"}a(HAe,"isObject");function kAe(e){return ro(e)?DAe:e.slice(0,-LAe)}a(kAe,"stripFileExtension");function FAe(e){return fs(e)||e===""||typeof e!="string"?e:dJ[e]!==void 0?dJ[e]:mJ(e)===!0?Number(e):IAe.test(e)?new Date(e):e}a(FAe,"autoCast");function hJ(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(hJ,"autoCastJSON");function $P(e){if(e&&typeof e=="object"){if(Array.isArray(e))for(let t=0,r=e.length;t<r;t++){let n=e[t],s=$P(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=$P(r);n!==r&&(e[t]=n)}return e}else return hJ(e)}a($P,"autoCastJSONDeep");function mJ(e){if(e.startsWith("0.")&&uJ(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&uJ(e))}a(mJ,"autoCasterIsNumberCheck");async function GAe(e){if(ro(e))throw new Error(`Directory path: ${e} does not exist`);try{await cJ.emptyDir(e),await cJ.remove(e)}catch(t){throw vn.error(`Error removing files in ${e} -- ${t}`),t}}a(GAe,"removeDir");function qAe(e,t){if(ro(e)){vn.info("Invalid current version sent as parameter.");return}if(ro(t)){vn.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,o=s.replace(n,"").split("."),c=i.replace(n,"").split("."),l=Math.min(o.length,c.length);for(let u=0;u<l;u++)if(r=parseInt(o[u],10)-parseInt(c[u],10),r)return r;return o.length-c.length}a(qAe,"compareVersions");function $Ae(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a($Ae,"isCompatibleDataVersion");function VAe(e){if(fs(e))return e;let t=String(e);return t==="."?yr.UNICODE_PERIOD:t===".."?yr.UNICODE_PERIOD+yr.UNICODE_PERIOD:t.replace(yr.FORWARD_SLASH_REGEX,yr.UNICODE_FORWARD_SLASH)}a(VAe,"escapeRawValue");function KAe(e){if(fs(e))return e;let t=String(e);return t===yr.UNICODE_PERIOD?".":t===yr.UNICODE_PERIOD+yr.UNICODE_PERIOD?"..":String(e).replace(yr.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(KAe,"unescapeValue");function YAe(e,t){if(fs(e))return vn.info("Properties object is null"),"";let r="";return e.each(function(n,s){try{if(t&&t[n]){let i=t[n];for(let o of i)r+=";"+o+bA.EOL}!ro(n)&&n[0]===";"?r+=" "+n+s+bA.EOL:ro(n)||(r+=n+"="+s+bA.EOL)}catch{vn.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(YAe,"stringifyProps");function EJ(){let e;try{e=bA.homedir()}catch{e=process.env.HOME}return e}a(EJ,"getHomeDir");function WAe(){let e=gc.join(EJ(),yr.HDB_HOME_DIR_NAME,yr.BOOT_PROPS_FILE_NAME);return fJ.existsSync(e)||(e=gc.join(__dirname,"../","hdb_boot_properties.file")),e}a(WAe,"getPropsFilePath");function zAe(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:a(function(){clearTimeout(r)},"cancel")}}a(zAe,"timeoutPromise");async function jAe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=TAe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(jAe,"isPortTaken");function JAe(e){try{return yr.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){vn.error(`Error checking operation against cluster ops ${t}`)}return!1}a(JAe,"isClusterOperation");function QAe(e,t){let r=(De(),P(nt)).getDatabases();if(!r[e])return NA.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return NA.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(QAe,"checkGlobalSchemaTable");function XAe(e,t){if(fs(t)){vn.warn("No CLUSTERING_USER defined, clustering disabled");return}if(fs(e)||ro(e)){vn.warn("No users to search.");return}let r;try{let n=e.get(t);n&&n.role.permission.cluster_user===!0&&n.active===!0&&(r=n)}catch(n){vn.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){vn.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(XAe,"getClusterUser");function ZAe(){lJ.parsePromise=function(e,t,r){return new Promise(function(n,s){lJ.parse(e,{header:!0,transformHeader:gJ,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(ZAe,"promisifyPapaParse");function gJ(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(gJ,"removeBOM");function eRe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;vn.info(`Got cluster status event response: ${bAe(s)}`);try{i.cancel()}catch{vn.error("Error trying to cancel timeout.")}n(s)})})}a(eRe,"createEventPromise");async function tRe(e){let t=!0,r=0;do await _J(CAe*r++),(await yAe.findPs(e)).length>0&&(t=!1);while(t&&r<PAe);if(t)throw new Error(`process ${e} was not started`)}a(tRe,"checkProcessRunning");function rRe(e,t){let r=SJ(e);if(r)return r;let n=TJ(e,t);if(n)return n}a(rRe,"checkSchemaTableExist");function SJ(e){let{getDatabases:t}=(De(),P(nt));if(!t()[e])return NA.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(SJ,"checkSchemaExists");function TJ(e,t){let{getDatabases:r}=(De(),P(nt));if(!r()[e][t])return NA.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(TJ,"checkTableExists");function nRe(){let e=OA().utc().add(1,"d").startOf("d").unix(),t=OA().utc().unix();return e-t}a(nRe,"getStartOfTomorrowInSeconds");function sRe(){return OA().utc().format("DD-MM-YYYY")}a(sRe,"getLimitKey");function iRe(e){try{let t=new AAe(e);for(let{node:r}of t)r&&(r.columnid&&typeof r.columnid!="string"&&(r.columnid=r.columnid.toString()),r.columnid&&!r.columnid.startsWith("`")&&(r.columnid_orig=r.columnid,r.columnid=`\`${r.columnid}\``),r.tableid&&!r.tableid.startsWith("`")&&(r.tableid_orig=r.tableid,r.tableid=`\`${r.tableid}\``),r.databaseid&&!r.databaseid.startsWith("`")&&(r.databaseid_orig=r.databaseid,r.databaseid=`\`${r.databaseid}\``),r.as&&typeof r.as=="string"&&!r.as.startsWith("[")&&(r.as_orig=r.as,r.as=`\`${r.as}\``))}catch(t){vn.error("Got an error back ticking items."),vn.error(t)}}a(iRe,"backtickASTSchemaItems");function oRe(e){return[e]}a(oRe,"createForkArgs");function aRe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(aRe,"autoCastBoolean");function cRe(e,t){let{getDatabases:r}=(De(),P(nt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(cRe,"getTableHashAttribute");function lRe(e){let{getDatabases:t}=(De(),P(nt));return t()[e]!==void 0}a(lRe,"doesSchemaExist");function uRe(e,t){let{getDatabases:r}=(De(),P(nt));return r()[e]?.[t]!==void 0}a(uRe,"doesTableExist");function dRe(e){try{return JSON.stringify(e)}catch{return e}}a(dRe,"stringifyObj");function fRe(e){let t=OA.duration(e),r=t.seconds()>0?t.seconds()+"s":"",n=t.minutes()>0?t.minutes()+"m ":"",s=t.hours()>0?t.hours()+"h ":"",i=t.days()>0?t.days()+"d ":"";return(t.years()>0?t.years()+"y ":"")+i+s+n+r}a(fRe,"ms_to_time");function _Re(e,t){let r=gc.basename(e,gc.extname(e));return gc.join(gc.dirname(e),r+t)}a(_Re,"changeExtension");function VP(){if(process.env[yr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[yr.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=OAe(process.argv);if(e[yr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[yr.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(VP,"getEnvCliRootPath");var qP;function pRe(){if(qP)return qP;let e=VP();if(VP()&&fJ.pathExistsSync(gc.join(e,yr.HDB_CONFIG_FILE)))return qP=!0,!0}a(pRe,"noBootFile");function hRe(e,t){let r;return e.protocol==="http:"?r=wAe:r=NAe,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8"),o.body="",o.on("data",c=>{o.body+=c}),o.on("end",()=>{n(o)})});i.on("error",o=>{s(o)}),i.write(t instanceof Buffer?t:JSON.stringify(t)),i.end()})}a(hRe,"httpRequest");function mRe(e){if(!e.schema&&!e.database){e.schema=yr.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(mRe,"transformReq");function ERe(e){let t=0;if(typeof e=="number"&&(t=e),typeof e=="string")switch(t=parseFloat(e),e.slice(-1)){case"M":t*=86400*30;break;case"D":case"d":t*=86400;break;case"H":case"h":t*=3600;break;case"m":t*=60;break}return t*1e3}a(ERe,"convertToMS")});var ce=I((NJ,wJ)=>{"use strict";var KP=require("fs-extra"),ru=require("path"),RJ=require("os"),gRe=require("properties-reader"),Vh=W(),$h=ae(),Me=(H(),P(G)),wA=Rt(),SRe="Error initializing environment manager",IA="BOOT_PROPS_FILE_PATH",yJ=!1,TRe={[Me.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},ra={};Object.assign(NJ,wJ.exports={BOOT_PROPS_FILE_PATH:IA,getHdbBasePath:ARe,setHdbBasePath:RRe,get:bJ,initSync:bRe,setProperty:Ye,initTestEnvironment:NRe,setCloneVar:ORe});function ARe(){return ra[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(ARe,"getHdbBasePath");function RRe(e){ra[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(RRe,"setHdbBasePath");function bJ(e){let t=wA.getConfigValue(e);return t===void 0?ra[e]:t}a(bJ,"get");function Ye(e,t){TRe[e]&&(ra[e]=t),wA.updateConfigObject(e,t)}a(Ye,"setProperty");function yRe(){let e;try{e=$h.getPropsFilePath(),KP.accessSync(e,KP.constants.F_OK|KP.constants.R_OK),yJ=!0;let t=gRe(e);return ra[Me.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(Me.HDB_SETTINGS_NAMES.INSTALL_USER),ra[Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),ra[IA]=e,!0}catch{return Vh.trace(`Environment manager found no properties file at ${e}`),!1}}a(yRe,"doesPropFileExist");function bRe(e=!1){try{((yJ||yRe()||$h.noBootFile())&&!OJ||e)&&(wA.initConfig(e),ra[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=wA.getConfigValue(Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){Vh.error(SRe),Vh.error(t),console.error(t),process.exit(1)}}a(bRe,"initSync");var OJ=!1;function ORe(e){OJ=e}a(ORe,"setCloneVar");function NRe(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=ru.join(__dirname,"../../","unitTests");ra[IA]=ru.join(l,"hdb_boot_properties.file"),Ye(Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,ru.join(l,"settings.test")),Ye(Me.HDB_SETTINGS_NAMES.INSTALL_USER,RJ.userInfo()?RJ.userInfo().username:void 0),Ye(Me.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Ye(Me.HDB_SETTINGS_NAMES.LOG_PATH_KEY,ru.join(l,"envDir","log")),Ye(Me.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Ye(Me.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Ye(Me.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Ye(Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,ru.join(l,"envDir")),Ye(Me.CONFIG_PARAMS.STORAGE_PATH,ru.join(l,"envDir")),s&&(Ye(Me.CONFIG_PARAMS.HTTP_SECUREPORT,bJ(Me.CONFIG_PARAMS.HTTP_PORT)),Ye(Me.CONFIG_PARAMS.HTTP_PORT,null)),Ye(Me.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Ye(Me.CONFIG_PARAMS.HTTP_PORT,9926),Ye(Me.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Ye(Me.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),Ye(Me.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,$h.isEmpty(i)?!1:i),Ye(Me.CONFIG_PARAMS.HTTP_CORS,$h.isEmpty(i)?!1:i),Ye(Me.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Ye(Me.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Ye(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Ye(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Ye(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,ru.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Ye(Me.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,$h.isEmpty(c)?!1:c),o&&(Ye("CORS_ACCESSLIST",o),Ye(Me.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Ye(Me.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Ye(Me.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Ye(Me.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Ye(Me.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Ye(Me.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Ye(Me.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${IA}. Please check your boot props and settings files`;Vh.fatal(r),Vh.error(t)}}a(NRe,"initTestEnvironment")});var LJ=I((Txe,DJ)=>{"use strict";var PA=ce();PA.initSync();var CA=(H(),P(G)),{httpRequest:wRe}=ae(),PJ=require("path"),IJ=require("fs-extra"),IRe=require("yaml"),{packageDirectory:CRe}=(Kw(),P(Vw)),{encode:PRe}=require("cbor-x"),DRe=["describe_table","describe_all","describe_database","list_users","list_roles","drop_role","add_user","alter_user","drop_user","restart_service","restart","create_database","drop_database","create_table","drop_table","create_attribute","drop_attribute","search_by_id","insert","update","upsert","delete","search_by_value","csv_file_load","csv_url_load","cluster_get_routes","cluster_network","cluster_status","remove_node","add_component","deploy_component","package_component","drop_component","get_components","get_component_file","set_component_file","registration_info","get_fingerprint","set_license","get_job","search_jobs_by_start_date","read_log","read_transaction_log","read_audit_log","delete_transaction_logs_before","purge_stream","delete_records_before","install_node_modules","set_configuration","get_configuration","create_authentication_tokens","refresh_operation_token","system_information","sql","create_csr","sign_certificate","list_certificates","add_certificate","remove_certificate","add_ssh_key","update_ssh_key","delete_ssh_key","list_ssh_keys","set_ssh_known_hosts","get_ssh_known_hosts"],CJ={deploy:"deploy_component",package:"package_component"};DJ.exports={cliOperations:vRe,buildRequest:MRe};var LRe={deploy_component:a(async e=>{if(e.package)return;let t=process.cwd();e.payload=await CRe(t,{skip_node_modules:!0,...e}),e.cborEncode=!0,e.project||(e.project=PJ.basename(t))},"deploy_component")};function MRe(){let e={};for(let t of process.argv.slice(2))if(DRe.includes(t))e.operation=t;else if(CJ.hasOwnProperty(t))e.operation=CJ[t];else if(t.includes("=")){let[r,...n]=t.split("=");n=n.join("=");try{n=JSON.parse(n)}catch{}e[r]=n}return e}a(MRe,"buildRequest");async function vRe(e){e.target||(e.target=process.env.CLI_TARGET);let t;if(e.target){try{t=new URL(e.target)}catch(r){try{t=new URL(`https://${e.target}:9925`)}catch{throw r}}t={protocol:t.protocol,hostname:t.hostname,port:t.port,username:e.username||t.username||process.env.CLI_TARGET_USERNAME,password:e.password||t.password||process.env.CLI_TARGET_PASSWORD,rejectUnauthorized:e.rejectUnauthorized}}else IJ.existsSync(PJ.join(PA.get(CA.CONFIG_PARAMS.ROOTPATH),CA.HDB_PID_FILE))||(console.error("HarperDB must be running to perform this operation"),process.exit()),IJ.existsSync(PA.get(CA.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET))||(console.error("No domain socket found, unable to perform this operation"),process.exit());await LRe[e.operation]?.(e);try{let r=t??{protocol:"http:",socketPath:PA.get(CA.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)};r.method="POST",r.headers={"Content-Type":"application/json"},t?.username&&(r.headers.Authorization=`Basic ${Buffer.from(`${t.username}:${t.password}`).toString("base64")}`),e.cborEncode&&(r.headers["Content-Type"]="application/cbor",e=PRe(e));let n=await wRe(r,e),s;try{s=JSON.parse(n.body)}catch{s={status:n.statusCode+" "+(n.statusMessage||"Unknown"),body:n.body}}e.json?console.log(JSON.stringify(s,null,2)):console.log(IRe.stringify(s).trim())}catch(r){let n="Error: ";if(r?.response?.data?.error)n+=r.response.data.error;else if(r?.response?.data)n+=r?.response?.data;else return console.error(r);console.error(n)}}a(vRe,"cliOperations")});var UJ=I((Rxe,vJ)=>{"use strict";var MJ=require("semver/functions/major"),{packageJson:URe}=st(),YP=process.versions&&process.versions.node?process.versions.node:void 0;vJ.exports=xRe;function xRe(){let e=URe.engines["minimum-node"];if(YP&&MJ(YP)<MJ(e))return{error:`The minimum version of Node.js HarperDB supports is: ${e}, the currently installed Node.js version is: ${YP}. Please install a version of Node.js that is withing the defined range.`}}a(xRe,"checkNodeVersion")});var ZP=I((Oxe,r2)=>{"use strict";var xJ=require("os"),DA=require("https"),BJ=require("http"),$t=require("fs-extra"),HJ=require("yaml"),{pipeline:kJ}=require("stream/promises"),{createWriteStream:LA,ensureDir:Kh,writeFileSync:FJ}=require("fs-extra"),{join:Vs}=require("path"),VJ=require("lodash"),BRe=require("minimist"),na=require("path"),HRe=require("node:crypto"),kRe=require("properties-reader"),$s=ce(),FRe=Do(),JP=W(),MA=Rt(),{restart:GRe}=ja(),vA=ae(),qRe=da(),$Re=Rs(),{main:UA,launch:VRe}=Xd(),{install:KJ,updateConfigEnv:KRe,setIgnoreExisting:BA}=DT(),YJ=SC(),cn=(H(),P(G)),{packageJson:YRe}=st(),WRe=Eh(),{sendOperationToNode:jP}=(Zn(),P(Io)),{updateConfigCert:zRe}=es(),{restartWorkers:jRe}=rt(),{databases:JRe}=(De(),P(nt)),{SYSTEM_TABLE_NAMES:WP,SYSTEM_SCHEMA_NAME:bxe,CONFIG_PARAMS:Yh,OPERATIONS_ENUM:hs}=cn,QRe=1e4,XRe="clone-node-config.yaml",WJ=[WP.ROLE_TABLE_NAME,WP.USER_TABLE_NAME,WP.NODE_TABLE_NAME],ZRe={clustering_nodename:!0,clustering_leafserver_streams_path:!0,clustering_tls_certificate:!0,clustering_tls_privatekey:!0,clustering_tls_certificateauthority:!0,logging_file:!0,logging_root:!0,logging_rotation_path:!0,operationsapi_network_domainsocket:!0,operationsapi_tls_certificate:!0,operationsapi_tls_privatekey:!0,operationsapi_tls_certificateauthority:!0,rootpath:!0,storage_path:!0,storage_audit_path:!0,databases:!0,mqtt_network_mtls_certificateauthority:!0,componentsroot:!0,tls_certificate:!0,tls_privatekey:!0,tls_certificateauthority:!0,replication_hostname:!0,replication_url:!0,cloned:!0},Fr={HDB_LEADER_USERNAME:"HDB_LEADER_USERNAME",HDB_LEADER_PASSWORD:"HDB_LEADER_PASSWORD",HDB_LEADER_URL:"HDB_LEADER_URL",REPLICATION_HOSTNAME:"REPLICATION_HOSTNAME",HDB_CLONE_OVERTOP:"HDB_CLONE_OVERTOP",CLONE_KEYS:"CLONE_KEYS",CLONE_USING_WS:"CLONE_USING_WS",NO_START:"NO_START"},ia=BRe(process.argv),hf=ia[Fr.HDB_LEADER_USERNAME]??process.env[Fr.HDB_LEADER_USERNAME],mf=ia[Fr.HDB_LEADER_PASSWORD]??process.env[Fr.HDB_LEADER_PASSWORD],su=ia[Fr.HDB_LEADER_URL]??process.env[Fr.HDB_LEADER_URL],sa=ia[Fr.REPLICATION_HOSTNAME]??process.env[Fr.REPLICATION_HOSTNAME],zJ,jJ;sa&&([zJ,jJ]=sa.split(":"));var QP=(ia[Fr.HDB_CLONE_OVERTOP]??process.env[Fr.HDB_CLONE_OVERTOP])==="true",JJ=ia[Yh.CLONED.toUpperCase()]??process.env[Yh.CLONED.toUpperCase()],eye=ia[Fr.CLONE_KEYS]!=="false"&&process.env[Fr.CLONE_KEYS]!=="false",QJ=(ia[Fr.CLONE_USING_WS]??process.env[Fr.CLONE_USING_WS])==="true",XJ=(ia[Fr.NO_START]??process.env[Fr.NO_START])==="true",ps,Sc={},GJ,qJ,nu={},an,Lt,qs,no,iu=!1,XP=!1,_s,Ef;r2.exports=a(async function(t=!1,r=!1){if(console.info(`Starting clone node from leader node: ${su}`),delete process.env.HDB_LEADER_URL,Lt=vA.getEnvCliRootPath(),!Lt)try{let i=Vs(xJ.homedir(),cn.HDB_HOME_DIR_NAME,cn.BOOT_PROPS_FILE_NAME);if(await $t.pathExists(i)){let o=kRe(i);Lt=na.parse(o.get(cn.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)).dir}}catch{throw new Error("There was an error setting the clone default root path. Please set ROOTPATH using an environment or CLI variable.")}Lt?await $t.pathExists(Lt)?console.log(`Existing HarperDB install found at ${Lt}. Clone node will only clone items that do not already exist on clone.`):(console.log(`No HarperDB install found at ${Lt} starting fresh clone`),iu=!0):(console.log("No HarperDB install found, starting fresh clone"),iu=!0),Lt||(Lt=Vs(xJ.homedir(),cn.HDB_ROOT_DIR_NAME),console.log("Using default root path",Lt));let n;try{n=Vs(Lt,XRe),ps=HJ.parseDocument(await $t.readFile(n,"utf8"),{simpleKeys:!0}).toJSON(),console.log("Clone config file found")}catch{}let s=Vs(Lt,cn.HDB_CONFIG_FILE);if(await $t.pathExists(s))try{GJ=HJ.parseDocument(await $t.readFile(s,"utf8"),{simpleKeys:!0}).toJSON(),Sc=MA.flattenConfig(GJ)}catch(i){console.error("Error reading existing harperdb-config.yaml on clone",i)}if(sa){let i=new URL(su);Ef=`${i.protocol==="https:"?"wss://":"ws://"}${i.hostname}:${jJ||9933}`}if(QJ){await tye();return}if(Sc?.cloned&&JJ!=="false")return console.log("Instance marked as cloned, clone will not run"),$s.setCloneVar(!1),$s.initSync(),UA();an=await xA({operation:hs.DESCRIBE_ALL}),await e2(),$s.setCloneVar(!1),$s.setHdbBasePath(Lt),$t.ensureDir($s.get(cn.CONFIG_PARAMS.LOGGING_ROOT)),JP.initLogSettings(),await nye(),XP||await sye(),await aye(t,r),sa&&(await lye(),await ZJ()),console.info(`
134
+ Successfully cloned node: `+su),(t||XJ)&&process.exit()},"cloneNode");async function tye(){if(Sc?.cloned&&JJ!=="false")return console.log("Instance marked as cloned, clone will not run"),$s.setCloneVar(!1),$s.initSync(),UA();console.log("Cloning using WebSockets");let e=Tc("system"),t=Vs(e,"system.mdb"),r=$t.existsSync(t);iu||!r||QP?(console.info("Clone node installing HarperDB"),process.env.TC_AGREEMENT="yes",process.env.ROOTPATH=Lt,process.env.HDB_ADMIN_USERNAME="clone-temp-admin",process.env.HDB_ADMIN_PASSWORD=HRe.randomBytes(10).toString("base64").slice(0,10),BA(!0),await KJ()):($s.setCloneVar(!1),$s.initSync()),await UA(),await e2(!0),await zRe(),r||await JRe.system.hdb_user.delete({username:"clone-temp-admin"}),await jRe(),await rye(),console.log("Adding node to the cluster");let s=await Td()({operation:hs.ADD_NODE,url:Ef});console.log("Add node response: ",s),await ZJ(),console.log(`Successfully cloned node: ${su} using WebSockets`),MA.updateConfigValue(Yh.CLONED,!0),XJ&&process.exit()}a(tye,"cloneUsingWS");async function rye(){let e=a(i=>{let o=0;for(let c in i){let l=i[c];typeof l=="object"&&l.last_updated_record>o&&(o=l.last_updated_record)}return o},"findMostRecentTimestamp");console.log("Getting last updated record timestamp for all database");let t={},r=await xA({operation:"describe_database",database:"system"});t.system=e(r);let n=await xA({operation:"describe_all"});for(let i in n)typeof n[i]=="object"&&(t[i]=e(n[i]));let s=Vs(Lt,"tmp","lastUpdated.json");console.log("Writing last updated database timestamps to:",s),await $t.outputJson(s,t)}a(rye,"getLastUpdatedRecord");async function xA(e){return QJ?jP({url:Ef},e,{rejectUnauthorized:!1}):JSON.parse((await uye(e)).body)}a(xA,"leaderReq");async function ZJ(){try{if(eye!==!1){console.log("Cloning JWT keys");let e=na.join(Lt,cn.LICENSE_KEY_DIR_NAME),t=await jP({url:Ef},{operation:hs.GET_KEY,name:".jwtPublic"},{rejectUnauthorized:!1});FJ(na.join(e,cn.JWT_ENUM.JWT_PUBLIC_KEY_NAME),t.message);let r=await jP({url:Ef},{operation:hs.GET_KEY,name:".jwtPrivate"},{rejectUnauthorized:!1});FJ(na.join(e,cn.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r.message)}}catch(e){console.error("Error cloning JWT keys",e)}}a(ZJ,"cloneKeys");async function e2(e=!1){console.info("Cloning configuration"),qJ=await xA({operation:hs.GET_CONFIGURATION}),nu=MA.flattenConfig(qJ);let t=ps?.componentConfig?.exclude,r={rootpath:Lt};sa&&(r.replication_hostname=zJ);for(let i in nu)if(!(nu[i]!==null&&typeof nu[i]=="object"&&!(nu[i]instanceof Array)||ZRe[i])){if(i.includes("_package")||i.includes("_port")){if(nu[i]?.includes?.("hdb/components"))continue;if(t){let o=!1;for(let c of t)if(i.includes(c.name)){o=!0;break}if(o)continue}}Sc[i]||(r[i]=nu[i])}for(let i in Sc)i!=="databases"&&typeof Sc[i]=="object"&&!(Sc[i]instanceof Array)||(r[i]=Sc[i]);let n={};if(ps?.databaseConfig?.excludeDatabases&&ps.databaseConfig.excludeDatabases.forEach(i=>{n[i.database]=!0}),ps?.clusteringConfig?.excludeDatabases&&ps.clusteringConfig.excludeDatabases.forEach(i=>{n[i.database]=!0}),Object.keys(n).length>0){r.replication_databases=[],n.system||r.replication_databases.push("system");for(let i in an)n[i]||r.replication_databases.push(i)}let s=qRe(Object.keys(cn.CONFIG_PARAM_MAP),!0);Object.assign(r,s),e||(r.cloned=!0),MA.createConfigFile(r,!0)}a(e2,"cloneConfig");async function nye(){process.env.HDB_FETCH==="true"?(await oye(),process.env.NODE_TLS_REJECT_UNAUTHORIZED&&delete process.env.NODE_TLS_REJECT_UNAUTHORIZED):await iye()}a(nye,"cloneDatabases");async function sye(){if(console.info("Clone node installing HarperDB."),process.env.TC_AGREEMENT="yes",process.env.ROOTPATH=Lt,!hf)throw new Error("HDB_LEADER_USERNAME is undefined.");if(process.env.HDB_ADMIN_USERNAME=hf,!mf)throw new Error("HDB_LEADER_PASSWORD is undefined.");process.env.HDB_ADMIN_PASSWORD=mf,process.env.OPERATIONSAPI_NETWORK_PORT=$s.get(Yh.OPERATIONSAPI_NETWORK_PORT),KRe(na.join(Lt,cn.HDB_CONFIG_FILE)),BA(!0),await KJ()}a(sye,"installHDB");function Tc(e){return $s.get(cn.CONFIG_PARAMS.DATABASES)?.[e]?.path||$s.get(Yh.STORAGE_PATH)||na.join(Lt,cn.DATABASES_DIR_NAME)}a(Tc,"getDBPath");async function iye(){let e=Tc("system"),t=Vs(e,"system.mdb");if(await Kh(e),iu||!await $t.exists(t)||QP){if(!sa){console.info("Cloning system database"),await Kh(e);let r=LA(t,{overwrite:!0}),n={operation:hs.GET_BACKUP,database:"system",tables:WJ},s=await $J(n,r),i=new Date(s.date);(!_s||i<_s)&&(_s=i),await $t.utimes(t,Date.now(),i)}iu||(await YJ(Lt),await t2(),BA(!0))}else XP=!0,console.log("Not cloning system database due to it already existing on clone");qs=ps?.databaseConfig?.excludeDatabases,qs=qs?qs.reduce((r,n)=>({...r,[n.database]:!0}),{}):{};for(let r in an)await $t.exists(na.join(Tc(r),r+".mdb"))&&(console.log(`Not cloning database ${r} due to it already existing on clone`),qs[r]=!0);no=ps?.databaseConfig?.excludeTables,no=no?no.reduce((r,n)=>({...r,[n.database==null?null:n.database+n.table]:!0}),{}):{};for(let r in an){if(qs[r]){an[r]="excluded";continue}if(VJ.isEmpty(an[r]))continue;let n=[],s=!1;for(let d in an[r])no[r+d]?(s=!0,an[r][d]="excluded"):n.push(an[r][d]);if(n.length===0)continue;if(sa){JP.debug("Setting up tables for #{db}");let d=(De(),P(nt)).table;for(let p of n){for(let _ of p.attributes)(_.is_hash_attribute||_.is_primary_key)&&(_.isPrimaryKey=!0);d({database:r,table:p.name,attributes:p.attributes})}continue}n=n.map(d=>d.name);let i;s?(console.info(`Cloning database: ${r} tables: ${n}`),i={operation:hs.GET_BACKUP,database:r,tables:n}):(console.info(`Cloning database: ${r}`),i={operation:hs.GET_BACKUP,database:r});let o=Tc(r);await Kh(o);let c=Vs(o,r+".mdb"),l=LA(c,{overwrite:!0}),u=await $J(i,l),f=new Date(u.date);(!_s||f<_s)&&(_s=f),await $t.utimes(c,Date.now(),f)}}a(iye,"cloneTablesHttp");async function oye(){let e=Tc("system"),t=Vs(e,"system.mdb");if(iu||!await $t.exists(t)||QP){if(!sa){console.info("Cloning system database using fetch");let r={operation:hs.GET_BACKUP,database:"system",tables:WJ},n=await zP(r,!0),s=Tc("system");await Kh(s);let i=Vs(s,"system.mdb");await kJ(n.body,LA(i,{overwrite:!0}));let o=new Date(n.headers.get("date"));(!_s||o<_s)&&(_s=o),await $t.utimes(i,Date.now(),new Date(n.headers.get("date")))}iu||(await YJ(Lt),await t2(),BA(!0))}else XP=!0,console.log("Not cloning system database due to it already existing on clone");if(sa){JP.info("Replication hostname set, not using backup to clone databases, replication will clone");return}qs=ps?.databaseConfig?.excludeDatabases,qs=qs?qs.reduce((r,n)=>({...r,[n.database]:!0}),{}):{};for(let r in an)await $t.exists(na.join(Tc(r),r+".mdb"))&&(console.log(`Not cloning database ${r} due to it already existing on clone`),qs[r]=!0);no=ps?.databaseConfig?.excludeTables,no=no?no.reduce((r,n)=>({...r,[n.database==null?null:n.database+n.table]:!0}),{}):{};for(let r in an){if(qs[r]){an[r]="excluded";continue}if(VJ.isEmpty(an[r]))continue;let n=[],s=!1;for(let f in an[r])no[r+f]?(s=!0,an[r][f]="excluded"):n.push(f);if(n.length===0)return;let i;s?(console.info(`Cloning database: ${r} tables: ${n}`),i=await zP({operation:hs.GET_BACKUP,database:r,tables:n},!0)):(console.info(`Cloning database: ${r}`),i=await zP({operation:hs.GET_BACKUP,database:r},!0));let o=Tc(r);await Kh(o);let c=new Date(i.headers.get("date")),l=Vs(o,`${c.getTime()}-${r}.mdb`);await kJ(i.body,LA(l,{overwrite:!0}));let u=Vs(o,r+".mdb");await $t.rename(l,u),(!_s||c<_s)&&(_s=c),await $t.utimes(u,Date.now(),c)}}a(oye,"cloneTablesFetch");async function zP(e,t=!1){let r=ps?.httpsRejectUnauthorized??!1,n=new DA.Agent({rejectUnauthorized:r});r||(process.env.NODE_TLS_REJECT_UNAUTHORIZED="0");let i={Authorization:"Basic "+Buffer.from(hf+":"+mf).toString("base64"),"Content-Type":"application/json"};t&&(i["Accept-Encoding"]="gzip");let o=await fetch(su,{method:"POST",headers:i,body:JSON.stringify(e),agent:n,compress:!0});if(o.ok)return o;throw console.error(`HTTP Error Response: ${o.status} ${o.statusText}`),new Error(await o.text())}a(zP,"leaderHttpReqFetch");async function aye(e,t=!1){let r=await FRe.getHDBProcessInfo();r.clustering.length===0||r.core.length===0?e?await VRe(!1):(t&&await cye(),await UA()):(console.info(await GRe({operation:hs.RESTART})),await vA.async_set_timeout(QRe)),e&&await vA.async_set_timeout(2e3)}a(aye,"startHDB");async function cye(){let e=process.argv[3];e&&e[0]!=="-"&&(await $t.exists(e)||console.error(`The folder ${e} does not exist`),$t.statSync(e).isDirectory()||console.error(`The path ${e} is not a folder`),e=await $t.realpath(e),await $t.exists(na.join(e,cn.HDB_CONFIG_FILE))?process.env.ROOTPATH=e:process.env.RUN_HDB_APP=e)}a(cye,"setAppPath");async function lye(){console.info("Setting up replication"),await $Re.setSchemaDataToGlobalAsync();let t=await Td()({operation:hs.ADD_NODE,verify_tls:!1,url:Ef,start_time:_s,authorization:{username:hf,password:mf}},!0);console.log("Add node response: ",t)}a(lye,"setupReplication");async function uye(e){let t=new DA.Agent({rejectUnauthorized:ps?.httpsRejectUnauthorized??!1}),n={Authorization:"Basic "+Buffer.from(hf+":"+mf).toString("base64"),"Content-Type":"application/json"},s=new URL(su),i={protocol:s.protocol,host:s.hostname,method:"POST",headers:n};return s.protocol==="https:"&&(i.agent=t),s.port&&(i.port=s.port),await vA.httpRequest(i,e)}a(uye,"leaderHttpReq");async function $J(e,t){let r=new DA.Agent({rejectUnauthorized:ps?.httpsRejectUnauthorized??!1}),s={Authorization:"Basic "+Buffer.from(hf+":"+mf).toString("base64"),"Content-Type":"application/json"},i=new URL(su),o={protocol:i.protocol,host:i.hostname,method:"POST",headers:s};return i.protocol==="https:"&&(o.agent=r,BJ=DA),i.port&&(o.port=i.port),new Promise((c,l)=>{let u=BJ.request(o,f=>{f.statusCode!==200&&l("Request to leader node failed with code: "+f.statusCode),f.pipe(t),f.on("end",()=>{t.close(),c(f.headers)})});u.on("error",f=>{l(f)}),u.write(JSON.stringify(e)),u.end()})}a($J,"leaderHttpStream");async function t2(){let e=YRe.version;if(e)await WRe.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(t2,"insertHdbVersionInfo")});var s2=I((wxe,n2)=>{var dye=DT(),fye=W();n2.exports=_ye;async function _ye(){try{await dye.install()}catch(e){console.error("There was an error during the install."),console.error(e),fye.error(e),process.exit(1)}}a(_ye,"install")});var a2=I((Cxe,o2)=>{"use strict";var pye=ES(),hye=W(),i2="Registration failed.";async function mye(){let e;try{e=await pye.register()}catch(t){return hye.error(`Registration error ${t}`),i2}return e||i2}a(mye,"register");o2.exports={register:mye}});var d2=I((Dxe,u2)=>{"use strict";var Eye=W(),gye=(H(),P(G)),Sye=require("util"),Tye=require("child_process"),c2=Sye.promisify(Tye.exec),Aye=Do(),Wh=Dd(),l2="Stopping HarperDB.";u2.exports=Rye;async function Rye(){if(console.log(l2),Eye.notify(l2),await Wh.isServiceRegistered(gye.PROCESS_DESCRIPTORS.HDB)){Wh.enterPM2Mode();let r=await Wh.getUniqueServicesList();for(let n in r)await Wh.stop(n)}await Wh.kill();let t=await Aye.getHDBProcessInfo();t.clustering.forEach(r=>{c2(`kill ${r.pid}`)}),t.core.forEach(r=>{c2(`kill ${r.pid}`)})}a(Rye,"stop")});var p2=I((Mxe,_2)=>{"use strict";var tD=require("fs-extra"),rD=require("path"),eD=require("yaml"),zh=ir(),Ac=(H(),P(G)),f2=St(),nD=W(),yye=yn(),bye=dS(),Oye=lS(),Nye=Do(),jh=ce(),wye=Xd(),Iye=ae();jh.initSync();var Ks={RUNNING:"running",STOPPED:"stopped",ERRORED:"errored",NOT_INSTALLED:"not installed"},Un={LEAF:"leaf server",HUB:"hub server"},HA;_2.exports=Cye;async function Cye(){let e={harperdb:{status:Ks.STOPPED}};if(!await wye.isHdbInstalled()){e.harperdb.status=Ks.NOT_INSTALLED,console.log(eD.stringify(e));return}HA=jh.get(Ac.CONFIG_PARAMS.ROOTPATH);let t;try{t=Number.parseInt(await tD.readFile(rD.join(HA,Ac.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Ac.NODE_ERROR_CODES.ENOENT){nD.info("`harperdb status` did not find a hdb.pid file"),e.harperdb.status=Ks.STOPPED,console.log(eD.stringify(e));return}throw n}let r=await Nye.getHDBProcessInfo();for(let n of r.core)if(n.pid===t){e.harperdb.status=Ks.RUNNING,e.harperdb.pid=t;break}if((jh.get(Ac.CONFIG_PARAMS.REPLICATION_URL)||jh.get(Ac.CONFIG_PARAMS.REPLICATION_HOSTNAME))&&(e.replication=await Dye()),e.clustering=await Pye(r),e.clustering[Un.HUB].status===Ks.RUNNING&&e.clustering[Un.LEAF].status===Ks.RUNNING){let n=[],s=await bye({});for(let o of s.nodes){let c={};for(let l in o)c[l.replace("_"," ")]=o[l];n.push(c)}e.clustering.network=n;let i=await Oye.clusterStatus();e.clustering.replication={"node name":i.node_name,"is enabled":i.is_enabled,connections:[]};for(let o of i.connections){let c={};c["node name"]=o?.node_name,c.status=o?.status,c.ports={clustering:o?.ports?.clustering,"operations api":o?.ports?.operations_api},c["latency ms"]=o?.latency_ms,c.uptime=o?.uptime,c.subscriptions=o?.subscriptions,c["system info"]={"hdb version":o?.system_info?.hdb_version,"node version":o?.system_info?.node_version,platform:o?.system_info?.platform},e.clustering.replication.connections.push(c)}await zh.closeConnection()}console.log(eD.stringify(e)),process.exit()}a(Cye,"status");async function Pye(e){let t={[Un.HUB]:{},[Un.LEAF]:{}};if(e.clustering.length===0)return t[Un.HUB].status=Ks.STOPPED,t[Un.LEAF].status=Ks.STOPPED,t;let{port:r}=zh.getServerConfig(Ac.PROCESS_DESCRIPTORS.CLUSTERING_HUB),{username:n,decrypt_hash:s}=await yye.getClusterUser();try{(await zh.createConnection(r,n,s,!1)).close(),t[Un.HUB].status=Ks.RUNNING}catch{t[Un.HUB].status=Ks.ERRORED}let{port:i}=zh.getServerConfig(Ac.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);try{(await zh.createConnection(i,n,s,!1)).close(),t[Un.LEAF].status=Ks.RUNNING}catch{t[Un.LEAF].status=Ks.ERRORED}try{t[Un.HUB].pid=Number.parseInt(await tD.readFile(rD.join(HA,"clustering",f2.PID_FILES.HUB),"utf8"))}catch(o){nD.error(o),t[Un.HUB].pid=void 0}try{t[Un.LEAF].pid=Number.parseInt(await tD.readFile(rD.join(HA,"clustering",f2.PID_FILES.LEAF),"utf8"))}catch(o){nD.error(o),t[Un.LEAF].pid=void 0}return t}a(Pye,"getHubLeafStatus");async function Dye(){let e=await Iye.httpRequest({method:"POST",protocol:"http:",socketPath:jh.get(Ac.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET),headers:{"Content-Type":"application/json"}},{operation:"cluster_status"});e=JSON.parse(e.body);let t={"node name":e.node_name,"is enabled":e.is_enabled,connections:[]};for(let r of e.connections)t.connections.push({"node name":r.name,url:r.url,subscriptions:r.subscriptions,replicates:r.replicates,"database sockets":r.database_sockets.map(n=>({database:n.database,connected:n.connected,latency:n.latency,"catching up from":n.catching_up_from,"thread id":n.thread_id,nodes:n.nodes}))});return t}a(Dye,"getReplicationStatus")});sm();var sD=process.env.HDB_LEADER_URL||process.argv.includes("--HDB_LEADER_URL");sD&&ce().setCloneVar(!0);var Jh=require("node:fs"),h2=require("node:path"),ou=W(),m2=LJ(),{packageJson:Lye,PACKAGE_ROOT:E2}=st(),Mye=UJ(),iD=(H(),P(G)),{SERVICE_ACTIONS_ENUM:ln}=iD,vye=`
135
135
  Usage: harperdb [command]
136
136
 
137
137
  With no command, harperdb will simply run HarperDB (in the foreground)
@@ -153,4 +153,4 @@ stop - Stop the harperdb background process
153
153
  help - Display this output
154
154
  upgrade - Upgrade harperdb
155
155
  version - Print the version
156
- `;async function Bye(){let e=Uye();if(e)if(e.error){console.error(e.error),iu.error(e.error);return}else e.warn&&(console.warn(e.warn),iu.warn(e.warn));let t;jh.existsSync(h2.join(E2,"bin"))||(iu.error(`Missing \`bin\` directory at ${E2}`),process.exit(0)),process.argv&&process.argv[2]&&!process.argv[2].startsWith("-")&&(t=process.argv[2].toLowerCase());let r=m2.buildRequest();switch(r.operation&&(t=cn.OPERATION),t){case cn.OPERATION:return iu.trace("calling cli operations with:",r),m2.cliOperations(r);case cn.START:return sD?ZP()(!0):Qd().launch();case cn.INSTALL:return s2()();case cn.REGISTER:return a2().register();case cn.STOP:return d2()().then(()=>{process.exit(0)});case cn.RESTART:return za().restart({});case cn.VERSION:return vye.version;case cn.UPGRADE:return iu.setLogLevel(iD.LOG_LEVELS.INFO),IC().upgrade(null).then(()=>"Your instance of HarperDB is up to date!");case cn.STATUS:return p2()();case cn.RENEWCERTS:return Zn().renewSelfSigned().then(()=>"Successfully renewed self-signed certificates");case cn.COPYDB:{let n=process.argv[3],s=process.argv[4];return(IS(),C(wS)).copyDb(n,s)}case cn.DEV:process.env.DEV_MODE=!0;case cn.RUN:{let n=process.argv[3];if(n&&n[0]!=="-"){if(!jh.existsSync(n))throw new Error(`The folder ${n} does not exist`);if(!jh.statSync(n).isDirectory())throw new Error(`The path ${n} is not a folder`);n=jh.realpathSync(n),jh.existsSync(h2.join(n,iD.HDB_CONFIG_FILE))?process.env.ROOTPATH=n:process.env.RUN_HDB_APP=n}}case void 0:return sD?ZP()():Qd().main();default:console.warn(`The "${t}" command is not understood.`);case cn.HELP:return xye}}a(Bye,"harperdb");Bye().then(e=>{e&&(console.log(e),iu.notify(e))}).catch(e=>{e&&(console.error(e),iu.error(e)),process.exit(1)});
156
+ `;async function Uye(){let e=Mye();if(e)if(e.error){console.error(e.error),ou.error(e.error);return}else e.warn&&(console.warn(e.warn),ou.warn(e.warn));let t;Jh.existsSync(h2.join(E2,"bin"))||(ou.error(`Missing \`bin\` directory at ${E2}`),process.exit(0)),process.argv&&process.argv[2]&&!process.argv[2].startsWith("-")&&(t=process.argv[2].toLowerCase());let r=m2.buildRequest();switch(r.operation&&(t=ln.OPERATION),t){case ln.OPERATION:return ou.trace("calling cli operations with:",r),m2.cliOperations(r);case ln.START:return sD?ZP()(!0):Xd().launch();case ln.INSTALL:return s2()();case ln.REGISTER:return a2().register();case ln.STOP:return d2()().then(()=>{process.exit(0)});case ln.RESTART:return ja().restart({});case ln.VERSION:return Lye.version;case ln.UPGRADE:return ou.setLogLevel(iD.LOG_LEVELS.INFO),IC().upgrade(null).then(()=>"Your instance of HarperDB is up to date!");case ln.STATUS:return p2()();case ln.RENEWCERTS:return es().renewSelfSigned().then(()=>"Successfully renewed self-signed certificates");case ln.COPYDB:{let n=process.argv[3],s=process.argv[4];return(CS(),P(IS)).copyDb(n,s)}case ln.DEV:process.env.DEV_MODE=!0;case ln.RUN:{let n=process.argv[3];if(n&&n[0]!=="-"){if(!Jh.existsSync(n))throw new Error(`The folder ${n} does not exist`);if(!Jh.statSync(n).isDirectory())throw new Error(`The path ${n} is not a folder`);n=Jh.realpathSync(n),Jh.existsSync(h2.join(n,iD.HDB_CONFIG_FILE))?process.env.ROOTPATH=n:process.env.RUN_HDB_APP=n}}case void 0:return sD?ZP()():Xd().main();default:console.warn(`The "${t}" command is not understood.`);case ln.HELP:return vye}}a(Uye,"harperdb");Uye().then(e=>{e&&(console.log(e),ou.notify(e))}).catch(e=>{e&&(console.error(e),ou.error(e)),process.exit(1)});