harperdb 4.4.16 → 4.4.18

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.
@@ -1,43 +1,43 @@
1
- "use strict";var JW=Object.create;var Ud=Object.defineProperty;var XW=Object.getOwnPropertyDescriptor;var ZW=Object.getOwnPropertyNames;var ej=Object.getPrototypeOf,tj=Object.prototype.hasOwnProperty;var a=(e,t)=>Ud(e,"name",{value:t,configurable:!0});var Oe=(e,t)=>()=>(e&&(t=e(e=0)),t);var N=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),je=(e,t)=>{for(var r in t)Ud(e,r,{get:t[r],enumerable:!0})},Hw=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of ZW(t))!tj.call(e,s)&&s!==r&&Ud(e,s,{get:()=>t[s],enumerable:!(n=XW(t,s))||n.enumerable});return e};var L=(e,t,r)=>(r=e!=null?JW(ej(e)):{},Hw(t||!e||!e.__esModule?Ud(r,"default",{value:e,enumerable:!0}):r,e)),oe=e=>Hw(Ud({},"__esModule",{value:!0}),e);var Fw=N((Tge,kw)=>{var rj=require("fast-glob"),{statSync:ig,existsSync:og,readFileSync:nj,writeFileSync:sj}=require("fs"),{spawnSync:ij,spawn:oj,execFileSync:Sge}=require("child_process"),{isMainThread:aj}=require("worker_threads"),{join:Go,relative:xw}=require("path"),{PACKAGE_ROOT:Hs}=M(),{tmpdir:cj,platform:lj}=require("os");require("source-map-support").install();var uj=["resources","server","dataLayer","components"],vd="ts-build",ag,dj=__filename.endsWith("tsBuild.js");if(dj){if(aj){let r;try{ig(Go(Hs,vd)),r=!0}catch{}if(r)for(let n of rj.sync(uj.map(s=>s+"/**/*.ts"),{cwd:Hs})){let s=0,i=0;try{s=ig(Go(Hs,n)).mtimeMs-5e3,i=ig(Go(Hs,vd,n.replace(/.ts$/,".js"))).mtimeMs}catch{}if(s>i){console.warn(`TypeScript ${n} is not compiled`+(i?` (TS source file was modified at ${new Date(s)} and compiled file at ${new Date(i)})`:"")+", consider enabling auto-compilation of TypeScript in your IDE), compiling now."),ag=!0;break}}else console.log("TypeScript modules are not compiled, compiling now"),ag=!0;if(ag){let n=Go(Hs,"node_modules/.bin/tsc");lj()==="win32"&&(n+=".cmd");let s=ij(n,{cwd:Hs});if(s.stdout?.length&&console.log(s.stdout.toString()),s.stderr?.length&&console.log(s.stderr.toString()),r){let i=Go(cj(),"harperdb-tsc.pid"),o;if(og(i))try{process.kill(+nj(i,{encoding:"utf8"}),0),o=!0}catch{}if(!o){console.log("starting tsc background process");let c=oj(n,["--watch"],{cwd:Hs,detached:!0,stdio:"ignore"});sj(i,c.pid.toString()),c.unref()}}}}let e=kw.constructor,t=e._findPath;e._findPath=function(r,n,s){if(r.startsWith(".")&&!s&&n.length===1&&n[0].startsWith(Hs)&&!n[0].includes("node_modules")){let i=xw(Hs,n[0]),o;i.startsWith(vd)?o=Go(Hs,xw(vd,i)):o=Go(Hs,vd,i);let c=Go(o,r),l=c+".js";if(og(l))return l;if(c.includes(".")&&og(c))return c}return t(r,n,s)}}});var M=N((Age,eC)=>{"use strict";var is=require("path"),_j=require("fs"),{relative:gge,join:Rge}=is,{existsSync:fj}=_j;function Ej(){let e=__dirname;for(;!fj(is.join(e,"package.json"));){let t=is.dirname(e);if(t===e)throw new Error("Could not find package root");e=t}return e}a(Ej,"getHDBPackageRoot");var qo=Ej(),Gw="js",eh=Gw,hj="harperdb-config.yaml",pj="defaultConfig.yaml",mj="hdb",qw=`harperdb.${eh}`,$w=`customFunctionsServer.${eh}`,Sj=`restartHdb.${eh}`,lg="HarperDB",ZE="Custom Functions",th="Clustering Hub",rh="Clustering Leaf",Tj="Clustering Ingest Service",gj="Clustering Reply Service",Rj="foreground.pid",Aj="hdb.pid",yj="data",bj={HDB:lg,CLUSTERING_HUB:th,CLUSTERING_LEAF:rh,CLUSTERING_INGEST_SERVICE:Tj,CLUSTERING_REPLY_SERVICE:gj,CUSTOM_FUNCTIONS:ZE,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"},Oj={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},Nj={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},Ij={harperdb:lg,"clustering hub":th,"clustering leaf":rh,"custom functions":ZE,custom_functions:ZE,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers",http:"http"},wj={CLUSTERING_HUB_PROC_DESCRIPTOR:th,CLUSTERING_LEAF_PROC_DESCRIPTOR:rh},cg={HDB:is.join(qo,"server/harperdb"),CUSTOM_FUNCTIONS:is.join(qo,"server/customFunctions"),CLUSTERING_HUB:is.join(qo,"server/nats"),CLUSTERING_LEAF:is.join(qo,"server/nats")},Cj={HDB:is.join(cg.HDB,qw),CUSTOM_FUNCTIONS:is.join(cg.CUSTOM_FUNCTIONS,$w)},Dj={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:is.join(qo,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:is.join(qo,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:is.join(qo,"launchServiceScripts/launchUpdateNodes4-0-0.js")},Pj={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},Vw="support@harperdb.io",Lj="customer-success@harperdb.io",Kw=1,Mj=4141,Yw="https://harperdbhelp.zendesk.com/hc/en-us/requests/new",Uj="https://www.harperdb.io/product",vj=`For support, please submit a request at ${Yw} or contact ${Vw}`,Ww=`For license support, please contact ${Lj}`,Bj="None of the specified records were found.",Hj="hash attribute not found",xj=`Your current license only supports ${Kw} role. ${Ww}`,kj="Your current license only supports 3 connections to a node.",Fj="127.0.0.1",Gj=1,qj=/^\.$/,$j=/^\.\.$/,Vj="U+002E",Kj=/\//g,Yj="U+002F",Wj=/U\+002F/g,jj=/^U\+002E$/,zj=/^U\+002EU\+002E$/,Qj="d",Jj=999999,Xj="*",Zj="--max-old-space-size=",ez="system",tz="__hdb_hash",rz=".harperdb",nz=".hdb",sz="keys",iz="hdb_boot_properties.file",oz=".updateConfig.json",az="SIGTSTP",cz=24,lz=6e4,uz=448,dz="blob",_z="database",fz="schema",Ez="transactions",hz=".count",pz="id",mz="PROCESS_NAME",jw={SETTINGS_PATH_KEY:"settings_path"},zw=require("lodash"),Sz={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"},Tz={HDB_PATH_KEY:"HDB_INTERNAL_PATH",HDB_AUTH_HEADER:"hdb_auth_header",HDB_USER_DATA_KEY:"hdb_user",CHUNK_SIZE:1e3,MAX_CHARACTER_SIZE:250},gz={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},Rz={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"},Az={JOB_TABLE_HASH_ATTRIBUTE:"id",NODE_TABLE_HASH_ATTRIBUTE:"name",ATTRIBUTE_TABLE_HASH_ATTRIBUTE:"id",LICENSE_TABLE_HASH_ATTRIBUTE:"license_key",ROLE_TABLE_HASH_ATTRIBUTE:"id",SCHEMA_TABLE_HASH_ATTRIBUTE:"name",TABLE_TABLE_HASH_ATTRIBUTE:"id",USER_TABLE_HASH_ATTRIBUTE:"username",INFO_TABLE_ATTRIBUTE:"info_id"},Cn="hdb_internal:",yz={CREATE_SCHEMA:Cn+"create_schema",CREATE_TABLE:Cn+"create_table",CREATE_ATTRIBUTE:Cn+"create_attribute",ADD_USER:Cn+"add_user",ALTER_USER:Cn+"alter_user",DROP_USER:Cn+"drop_user",HDB_NODES:Cn+"hdb_nodes",HDB_USERS:Cn+"hdb_users",HDB_WORKERS:Cn+"hdb_workers",CATCHUP:Cn+"catchup",SCHEMA_CATCHUP:Cn+"schema_catchup",WORKER_ROOM:Cn+"cluster_workers"},bz={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"},Oz="060493.ks",Nz=".license",Iz={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},le={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"},wz={CSV:".csv",JSON:".json"},Cz={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},Dz={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},Bd={};Bd[le.INSERT]=le.INSERT;Bd[le.UPDATE]=le.UPDATE;Bd[le.UPSERT]=le.UPSERT;Bd[le.DELETE]=le.DELETE;var nt=Object.create(null);nt[le.DESCRIBE_ALL]=le.DESCRIBE_ALL;nt[le.DESCRIBE_TABLE]=le.DESCRIBE_TABLE;nt[le.DESCRIBE_SCHEMA]=le.DESCRIBE_SCHEMA;nt[le.READ_LOG]=le.READ_LOG;nt[le.ADD_NODE]=le.ADD_NODE;nt[le.LIST_USERS]=le.LIST_USERS;nt[le.LIST_ROLES]=le.LIST_ROLES;nt[le.USER_INFO]=le.USER_INFO;nt[le.SQL]=le.SQL;nt[le.GET_JOB]=le.GET_JOB;nt[le.SEARCH_JOBS_BY_START_DATE]=le.SEARCH_JOBS_BY_START_DATE;nt[le.DELETE_FILES_BEFORE]=le.DELETE_FILES_BEFORE;nt[le.EXPORT_LOCAL]=le.EXPORT_LOCAL;nt[le.EXPORT_TO_S3]=le.EXPORT_TO_S3;nt[le.CLUSTER_STATUS]=le.CLUSTER_STATUS;nt[le.REMOVE_NODE]=le.REMOVE_NODE;nt[le.RESTART]=le.RESTART;nt[le.CUSTOM_FUNCTIONS_STATUS]=le.CUSTOM_FUNCTIONS_STATUS;nt[le.GET_CUSTOM_FUNCTIONS]=le.GET_CUSTOM_FUNCTIONS;nt[le.GET_CUSTOM_FUNCTION]=le.GET_CUSTOM_FUNCTION;nt[le.SET_CUSTOM_FUNCTION]=le.SET_CUSTOM_FUNCTION;nt[le.DROP_CUSTOM_FUNCTION]=le.DROP_CUSTOM_FUNCTION;nt[le.ADD_CUSTOM_FUNCTION_PROJECT]=le.ADD_CUSTOM_FUNCTION_PROJECT;nt[le.DROP_CUSTOM_FUNCTION_PROJECT]=le.DROP_CUSTOM_FUNCTION_PROJECT;nt[le.PACKAGE_CUSTOM_FUNCTION_PROJECT]=le.PACKAGE_CUSTOM_FUNCTION_PROJECT;nt[le.DEPLOY_CUSTOM_FUNCTION_PROJECT]=le.DEPLOY_CUSTOM_FUNCTION_PROJECT;nt[le.ADD_SSH_KEY]=le.ADD_SSH_KEY;nt[le.UPDATE_SSH_KEY]=le.UPDATE_SSH_KEY;nt[le.DELETE_SSH_KEY]=le.DELETE_SSH_KEY;var Pz={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"},Lz={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},Qw={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"},Mz=zw.invert(Qw),Uz={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"},P={ANALYTICS_AGGREGATEPERIOD:"analytics_aggregatePeriod",AUTHENTICATION_AUTHORIZELOCAL:"authentication_authorizeLocal",AUTHENTICATION_CACHETTL:"authentication_cacheTTL",AUTHENTICATION_ENABLESESSIONS:"authentication_enableSessions",AUTHENTICATION_OPERATIONTOKENTIMEOUT:"authentication_operationTokenTimeout",AUTHENTICATION_REFRESHTOKENTIMEOUT:"authentication_refreshTokenTimeout",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_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",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_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_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",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_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",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"},Jw={settings_path:jw.SETTINGS_PATH_KEY,hdb_root_key:P.ROOTPATH,hdb_root:P.ROOTPATH,rootpath:P.ROOTPATH,server_port_key:P.OPERATIONSAPI_NETWORK_PORT,server_port:P.OPERATIONSAPI_NETWORK_PORT,cert_key:P.TLS_CERTIFICATE,certificate:P.TLS_CERTIFICATE,private_key_key:P.TLS_PRIVATEKEY,private_key:P.TLS_PRIVATEKEY,http_secure_enabled_key:P.OPERATIONSAPI_NETWORK_HTTPS,https_on:P.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:P.OPERATIONSAPI_NETWORK_CORS,cors_on:P.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:P.LOGGING_LEVEL,log_level:P.LOGGING_LEVEL,log_path_key:P.LOGGING_ROOT,log_path:P.LOGGING_ROOT,clustering_node_name_key:P.CLUSTERING_NODENAME,node_name:P.CLUSTERING_NODENAME,clustering_enabled_key:P.CLUSTERING_ENABLED,clustering:P.CLUSTERING_ENABLED,max_http_threads:P.THREADS_COUNT,max_hdb_processes:P.THREADS_COUNT,server_timeout_key:P.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:P.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:P.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:P.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:P.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:P.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:P.LOGGING_AUDITLOG,disable_transaction_log:P.LOGGING_AUDITLOG,operation_token_timeout_key:P.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:P.AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:P.AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:P.AUTHENTICATION_REFRESHTOKENTIMEOUT,custom_functions_port_key:P.HTTP_PORT,custom_functions_port:P.HTTP_PORT,custom_functions_directory_key:P.COMPONENTSROOT,custom_functions_directory:P.COMPONENTSROOT,max_custom_function_processes:P.THREADS_COUNT,logging_console:P.LOGGING_CONSOLE,log_to_file:P.LOGGING_FILE,log_to_stdstreams:P.LOGGING_STDSTREAMS,local_studio_on:P.LOCALSTUDIO_ENABLED,clustering_port:P.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:P.CLUSTERING_USER,clustering_enabled:P.CLUSTERING_ENABLED,clustering_hubserver_cluster_name:P.CLUSTERING_HUBSERVER_CLUSTER_NAME,clustering_hubserver_cluster_network_port:P.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_hubserver_cluster_network_routes:P.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,clustering_hubserver_leafnodes_network_port:P.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT,clustering_hubserver_network_port:P.CLUSTERING_HUBSERVER_NETWORK_PORT,clustering_leafserver_network_port:P.CLUSTERING_LEAFSERVER_NETWORK_PORT,clustering_leafserver_network_routes:P.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,clustering_leafserver_streams_maxage:P.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE,clustering_leafserver_streams_maxbytes:P.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES,clustering_leafserver_streams_maxconsumemsgs:P.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS,clustering_leafserver_streams_maxingestthreads:P.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS,clustering_leafserver_streams_maxmsgs:P.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS,clustering_leafserver_streams_path:P.CLUSTERING_LEAFSERVER_STREAMS_PATH,clustering_nodename:P.CLUSTERING_NODENAME,clustering_tls_certificate:P.CLUSTERING_TLS_CERTIFICATE,clustering_tls_privatekey:P.CLUSTERING_TLS_PRIVATEKEY,clustering_tls_certificateauthority:P.CLUSTERING_TLS_CERT_AUTH,clustering_tls_insecure:P.CLUSTERING_TLS_INSECURE,clustering_tls_verify:P.CLUSTERING_TLS_VERIFY,clustering_loglevel:P.CLUSTERING_LOGLEVEL,clustering_republishmessages:P.CLUSTERING_REPUBLISHMESSAGES,clustering_databaselevel:P.CLUSTERING_DATABASELEVEL,customfunctions_network_port:P.HTTP_PORT,customfunctions_tls_certificate:P.TLS_CERTIFICATE,customfunctions_network_cors:P.HTTP_CORS,customfunctions_network_corsaccesslist:P.HTTP_CORSACCESSLIST,customfunctions_network_headerstimeout:P.HTTP_HEADERSTIMEOUT,customfunctions_network_https:P.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:P.HTTP_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:P.TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:P.TLS_CERTIFICATEAUTHORITY,customfunctions_network_timeout:P.HTTP_TIMEOUT,customfunctions_tls:P.TLS,http_threads:P.THREADS_COUNT,threads:P.THREADS_COUNT,threads_count:P.THREADS_COUNT,threads_debug:P.THREADS_DEBUG,threads_debug_startingport:P.THREADS_DEBUG_STARTINGPORT,threads_debug_port:P.THREADS_DEBUG_PORT,threads_debug_host:P.THREADS_DEBUG_HOST,threads_debug_waitfordebugger:P.THREADS_DEBUG_WAITFORDEBUGGER,threads_maxheapmemory:P.THREADS_MAXHEAPMEMORY,http_session_affinity:P.HTTP_SESSIONAFFINITY,http_compressionthreshold:P.HTTP_COMPRESSIONTHRESHOLD,http_cors:P.HTTP_CORS,http_corsaccesslist:P.HTTP_CORSACCESSLIST,http_headerstimeout:P.HTTP_HEADERSTIMEOUT,http_keepalivetimeout:P.HTTP_KEEPALIVETIMEOUT,http_maxparamlength:P.HTTP_MAXPARAMLENGTH,http_timeout:P.HTTP_TIMEOUT,http_port:P.HTTP_PORT,http_secureport:P.HTTP_SECUREPORT,http_mtls:P.HTTP_MTLS,http_mtls_user:P.HTTP_MTLS_USER,http_mtls_required:P.HTTP_MTLS_REQUIRED,http_maxheadersize:P.HTTP_MAXHEADERSIZE,http_threadrange:P.HTTP_THREADRANGE,customfunctions_processes:P.THREADS_COUNT,customfunctions_root:P.COMPONENTSROOT,localstudio_enabled:P.LOCALSTUDIO_ENABLED,logging_file:P.LOGGING_FILE,logging_level:P.LOGGING_LEVEL,logging_root:P.LOGGING_ROOT,logging_rotation_enabled:P.LOGGING_ROTATION_ENABLED,logging_rotation_compress:P.LOGGING_ROTATION_COMPRESS,logging_rotation_interval:P.LOGGING_ROTATION_INTERVAL,logging_rotation_maxsize:P.LOGGING_ROTATION_MAXSIZE,logging_rotation_path:P.LOGGING_ROTATION_PATH,logging_stdstreams:P.LOGGING_STDSTREAMS,logging_auditlog:P.LOGGING_AUDITLOG,logging_auditretention:P.LOGGING_AUDITRETENTION,logging_auditauthevents_logfailed:P.LOGGING_AUDITAUTHEVENTS_LOGFAILED,logging_auditauthevents_logsuccessful:P.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL,operationsapi_authentication_operationtokentimeout:P.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operationsapi_authentication_refreshtokentimeout:P.AUTHENTICATION_REFRESHTOKENTIMEOUT,operationsapi_network_cors:P.OPERATIONSAPI_NETWORK_CORS,operationsapi_network_corsaccesslist:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,operationsapi_network_headerstimeout:P.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,operationsapi_network_https:P.OPERATIONSAPI_NETWORK_HTTPS,operationsapi_network_keepalivetimeout:P.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,operationsapi_network_port:P.OPERATIONSAPI_NETWORK_PORT,operationsapi_network_domainsocket:P.OPERATIONSAPI_NETWORK_DOMAINSOCKET,operationsapi_network_secureport:P.OPERATIONSAPI_NETWORK_SECUREPORT,operationsapi_tls:P.OPERATIONSAPI_TLS,operationsapi_tls_certificate:P.OPERATIONSAPI_TLS_CERTIFICATE,operationsapi_tls_privatekey:P.OPERATIONSAPI_TLS_PRIVATEKEY,operationsapi_tls_certificateauthority:P.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY,operationsapi_network_timeout:P.OPERATIONSAPI_NETWORK_TIMEOUT,operationsapi_root:P.ROOTPATH,operationsapi_sysinfo_network:P.OPERATIONSAPI_SYSINFO_NETWORK,operationsapi_sysinfo_disk:P.OPERATIONSAPI_SYSINFO_DISK,databases:P.DATABASES,storage_path:P.STORAGE_PATH,storage_maxtransactionqueuetime:P.STORAGE_MAXTRANSACTIONQUEUETIME,ignorescripts:P.IGNORE_SCRIPTS,mqtt_network_port:P.MQTT_NETWORK_PORT,mqtt_websocket:P.MQTT_WEBSOCKET,mqtt_network_secureport:P.MQTT_NETWORK_SECUREPORT,mqtt_network_mtls:P.MQTT_NETWORK_MTLS,mqtt_network_mtls_certificateAuthority:P.MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY,mqtt_network_mtls_user:P.MQTT_NETWORK_MTLS_USER,mqtt_network_mtls_required:P.MQTT_NETWORK_MTLS_REQUIRED,mqtt_requireauthentication:P.MQTT_REQUIREAUTHENTICATION,analytics_aggregatePeriod:P.ANALYTICS_AGGREGATEPERIOD,authentication_authorizelocal:P.AUTHENTICATION_AUTHORIZELOCAL,authentication_cachettl:P.AUTHENTICATION_CACHETTL,authentication_enablesessions:P.AUTHENTICATION_ENABLESESSIONS,authentication_operationtokentimeout:P.AUTHENTICATION_OPERATIONTOKENTIMEOUT,authentication_refreshtokentimeout:P.AUTHENTICATION_REFRESHTOKENTIMEOUT,componentsroot:P.COMPONENTSROOT,replication:P.REPLICATION,replication_port:P.REPLICATION_PORT,replication_secureport:P.REPLICATION_SECUREPORT,replication_hostname:P.REPLICATION_HOSTNAME,replication_url:P.REPLICATION_URL,replication_routes:P.REPLICATION_ROUTES,tls:P.TLS,tls_certificate:P.TLS_CERTIFICATE,tls_privatekey:P.TLS_PRIVATEKEY,tls_certificateauthority:P.TLS_CERTIFICATEAUTHORITY,tls_ciphers:P.TLS_CIPHERS};for(let e in P){let t=P[e];Jw[t.toLowerCase()]=t}var vz={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},Bz={csv_file_load:"csv_file_load",csv_data_load:le.CSV_DATA_LOAD,csv_url_load:le.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"},Hz={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"},xz={BIDIRECTIONAL:"BIDIRECTIONAL",OUTBOUND:"OUTBOUND",INBOUND:"INBOUND"},kz={VERSION_DEFAULT:"2.2.0"},Fz={DEVELOPMENT:8192,DEFAULT:512},Gz={IDENTIFY:"identify",AUTHENTICATE:"authenticate",AUTHENTICATE_OK:"authenticated",AUTHENTICATE_FAIL:"authenticate_fail",CONNECTION:"connection",CONNECT:"connect",CATCHUP_REQUEST:"catchup_request",CATCHUP_RESPONSE:"catchup",CONFIRM_MSG:"confirm_msg",ERROR:"error",DISCONNECT:"disconnect",SCHEMA_UPDATE_REQ:"schema_update_request",SCHEMA_UPDATE_RES:"schema_update_response",RECONNECT_ATTEMPT:"reconnect_attempt",CONNECT_ERROR:"connect_error",MESSAGE:"msg",VERSION_MISMATCH:"version_mismatch",DIRECTION_CHANGE:"direction_change"},qz={1e3:"SUCCESSFUL_SHUTDOWN",1001:"CLOSE_GOING_AWAY",1002:"CLOSE_PROTOCOL_ERROR",1003:"CLOSE_UNSUPPORTED",1005:"CLOSE_NO_STATUS",1006:"CLOSE_ABNORMAL",1007:"UNSUPPORTED_PAYLOAD",1008:"POLICY_VIOLATION",1009:"CLOSE_TOO_LARGE",1010:"MANDATORY_EXTENSION",1011:"SERVER_ERROR",1012:"SERVICE_RESTART",1013:"SERVER_BUSY",1014:"BAD_GATEWAY",1015:"HANDSHAKE_FAIL",4141:"LICENSE_LIMIT_REACHED"},$z={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},Xw={CREATED_TIME:"__createdtime__",UPDATED_TIME:"__updatedtime__"},Vz=Symbol("metadata"),Kz="__clustering__",Yz=Object.values(Xw),Wz=15984864e5,Zw={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},jz=zw.invert(Zw),zz={GET_CLUSTER_STATUS:"GET_CLUSTER_STATUS",CLUSTER_STATUS_RESPONSE:"CLUSTER_STATUS_RESPONSE",ERROR_RESPONSE:"ERROR",ADD_USER:"ADD_USER",ALTER_USER:"ALTER_USER",DROP_USER:"DROP_USER",HDB_OPERATION:"HDB_OPERATION",ADD_NODE:"ADD_NODE",UPDATE_NODE:"UPDATE_NODE",REMOVE_NODE:"REMOVE_NODE",HDB_USERS_MSG:"HDB_USERS_MSG",HDB_WORKERS:"HDB_WORKERS",HDB_TRANSACTION:"HDB_TRANSACTION"},Qz=111,Jz=`\r
2
- `,Xz={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},Zz=["*","%"],eQ="unauthorized_access",tQ="func_val",rQ={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},nQ={JWT_PRIVATE_KEY_NAME:".jwtPrivate.key",JWT_PUBLIC_KEY_NAME:".jwtPublic.key",JWT_PASSPHRASE_NAME:".jwtPass"},sQ={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"},iQ={HDB_CORE:"hdb_core",CUSTOM_FUNCTIONS:"custom_functions"},oQ={HTTP:"http"},aQ={STOPPED:"stopped",ONLINE:"online"},cQ="3.x.x",lQ={SUCCESS:"success",FAILURE:"failure"},uQ={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"};eC.exports={LOCAL_HARPERDB_OPERATIONS:nt,HDB_SUPPORT_ADDRESS:Vw,HDB_SUPPORT_URL:Yw,HDB_PRICING_URL:Uj,SUPPORT_HELP_MSG:vj,LICENSE_HELP_MSG:Ww,HDB_PROC_NAME:qw,HDB_PROC_DESCRIPTOR:lg,CLUSTERING_LEAF_PROC_DESCRIPTOR:rh,CLUSTERING_HUB_PROC_DESCRIPTOR:th,SYSTEM_SCHEMA_NAME:ez,HASH_FOLDER_NAME:tz,HDB_HOME_DIR_NAME:rz,UPDATE_FILE_NAME:oz,LICENSE_KEY_DIR_NAME:sz,BOOT_PROPS_FILE_NAME:iz,JOB_TYPE_ENUM:Bz,JOB_STATUS_ENUM:Iz,SYSTEM_TABLE_NAMES:Rz,SYSTEM_TABLE_HASH_ATTRIBUTES:Az,OPERATIONS_ENUM:le,VALID_S3_FILE_TYPES:wz,S3_BUCKET_AUTH_KEYS:Cz,VALID_SQL_OPS_ENUM:Dz,GEO_CONVERSION_ENUM:Lz,HDB_SETTINGS_NAMES:Qw,HDB_SETTINGS_NAMES_REVERSE_LOOKUP:Mz,SERVICE_ACTIONS_ENUM:Pz,CLUSTER_MESSAGE_TYPE_ENUM:Hz,CLUSTER_CONNECTION_DIRECTION_ENUM:xz,CLUSTER_EVENTS_DEFS_ENUM:Gz,PERIOD_REGEX:qj,DOUBLE_PERIOD_REGEX:$j,UNICODE_PERIOD:Vj,FORWARD_SLASH_REGEX:Kj,UNICODE_FORWARD_SLASH:Yj,ESCAPED_FORWARD_SLASH_REGEX:Wj,ESCAPED_PERIOD_REGEX:jj,ESCAPED_DOUBLE_PERIOD_REGEX:zj,REG_KEY_FILE_NAME:Oz,RESTART_TIMEOUT_MS:lz,HDB_FILE_PERMISSIONS:uz,DATABASES_DIR_NAME:_z,LEGACY_DATABASES_DIR_NAME:fz,TRANSACTIONS_DIR_NAME:Ez,LIMIT_COUNT_NAME:hz,ID_ATTRIBUTE_STRING:pz,INSERT_MODULE_ENUM:Tz,UPGRADE_JSON_FIELD_NAMES_ENUM:gz,RESTART_CODE:az,RESTART_CODE_NUM:cz,CLUSTER_OPERATIONS:Bd,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:bz,HDB_INTERNAL_SC_CHANNEL_PREFIX:Cn,INTERNAL_SC_CHANNELS:yz,CLUSTERING_MESSAGE_TYPES:zz,HDB_FILE_SUFFIX:nz,BLOB_FOLDER_NAME:dz,ORIGINATOR_SET_VALUE:Qz,LICENSE_VALUES:kz,RAM_ALLOCATION_ENUM:Fz,TIME_STAMP_NAMES_ENUM:Xw,TIME_STAMP_NAMES:Yz,PERMS_UPDATE_RELEASE_TIMESTAMP:Wz,SEARCH_NOT_FOUND_MESSAGE:Bj,SEARCH_ATTRIBUTE_NOT_FOUND:Hj,LICENSE_ROLE_DENIED_RESPONSE:xj,LICENSE_MAX_CONNS_REACHED:kj,BASIC_LICENSE_MAX_NON_CU_ROLES:Kw,BASIC_LICENSE_CLUSTER_CONNECTION_LIMIT_WS_ERROR_CODE:Mj,VALUE_SEARCH_COMPARATORS:Zw,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:jz,LICENSE_FILE_NAME:Nz,WEBSOCKET_CLOSE_CODE_DESCRIPTION_LOOKUP:qz,NEW_LINE:Jz,BASIC_LICENSE_MAX_CLUSTER_USER_ROLES:Gj,MOMENT_DAYS_TAG:Qj,API_TURNOVER_SEC:Jj,LOOPBACK:Fj,CODE_EXTENSION:eh,WILDCARD_SEARCH_VALUE:Xj,NODE_ERROR_CODES:$z,JAVASCRIPT_EXTENSION:Gw,PERMS_CRUD_ENUM:Xz,UNAUTHORIZED_PERMISSION_NAME:eQ,SEARCH_WILDCARDS:Zz,FUNC_VAL:tQ,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:rQ,JWT_ENUM:nQ,CLUSTERING_FLAG:Kz,ITC_EVENT_TYPES:sQ,CUSTOM_FUNCTION_PROC_NAME:$w,CUSTOM_FUNCTION_PROC_DESCRIPTOR:ZE,SERVICES:iQ,THREAD_TYPES:oQ,MEM_SETTING_KEY:Zj,HDB_RESTART_SCRIPT:Sj,PROCESS_DESCRIPTORS:bj,SERVICE_SERVERS:Cj,SERVICE_SERVERS_CWD:cg,PROCESS_DESCRIPTORS_VALIDATE:Ij,LAUNCH_SERVICE_SCRIPTS:Dj,LOG_LEVELS:Nj,PROCESS_NAME_ENV_PROP:mz,LOG_NAMES:Oj,PM2_PROCESS_STATUSES:aQ,CONFIG_PARAM_MAP:Jw,CONFIG_PARAMS:P,HDB_CONFIG_FILE:hj,HDB_DEFAULT_CONFIG_FILE:pj,ROLE_TYPES_ENUM:Pj,BOOT_PROP_PARAMS:jw,INSTALL_PROMPTS:Sz,HDB_ROOT_DIR_NAME:mj,CLUSTERING_PROCESSES:wj,FOREGROUND_PID_FILE:Rj,PACKAGE_ROOT:qo,PRE_4_0_0_VERSION:cQ,DATABASES_PARAM_CONFIG:vz,METADATA_PROPERTY:Vz,AUTH_AUDIT_STATUS:lQ,AUTH_AUDIT_TYPES:uQ,HDB_PID_FILE:Aj,DEFAULT_DATABASE_NAME:yj,LEGACY_CONFIG_PARAMS:Uz};Fw()});var Wa=N((bge,nC)=>{"use strict";var tC=require("minimist");nC.exports=dQ;function dQ(e=[],t=!1){if(!Array.isArray(e))return{};let r,n;t?(r=rC(process.env),n=rC(tC(process.argv))):(r=process.env,n=tC(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(dQ,"assignCMDENVVariables");function rC(e){let t,r=Object.keys(e),n=r.length,s={};for(;n--;)t=r[n],s[t.toLowerCase()]=e[t];return s}a(rC,"objKeysToLowerCase")});var fi=N(_i=>{"use strict";global.Resource=_i.Resource=void 0;global.tables=_i.tables={};global.databases=_i.databases={};global.getUser=_i.getUser=void 0;global.server=_i.server={};global.contentTypes=_i.contentTypes=null;global.threads=_i.threads=[];global.logger={};_i._assignPackageExport=(e,t)=>{global[e]=_i[e]=t}});var W=N((SC,TC)=>{"use strict";var zi=require("fs-extra"),{workerData:_Q,threadId:fQ,isMainThread:EQ}=require("worker_threads"),hi=require("path"),aC=require("yaml"),cC=require("properties-reader"),Wt=M(),sC=Wa(),hQ=require("os"),{PACKAGE_ROOT:fg}=M(),{_assignPackageExport:pQ}=fi(),iC=process.stdout.nativeWrite||(process.stdout.nativeWrite=process.stdout.write),fr={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},lC={STDOUT:"stdOut",STDERR:"stdErr"},mQ=hi.join(fg,"logs"),SQ=hi.join(fg,"config/yaml/",Wt.HDB_DEFAULT_CONFIG_FILE),TQ=1e4,ug,Ei,os,wr,nh,Hd,sh,$o,xd;xd===void 0&&uC();Object.assign(SC,{notify:hC,fatal:pC,error:ih,warn:mC,info:_C,debug:EC,trace:fC,setLogLevel:IQ,log_level:wr,loggerWithTag:AQ,suppressLogging:yQ,initLogSettings:uC,logCustomLevel:OQ,closeLogFile:Eg,logsAtLevel:gQ,getLogFilePath:a(()=>sh,"getLogFilePath"),OUTPUTS:lC,AuthAuditLog:DQ});pQ("logger",TC.exports);var dg;function gQ(e){return fr[wr]<=fr[e]}a(gQ,"logsAtLevel");function uC(e=!1){try{if(xd===void 0||e){Eg();let t=NQ(),r=sC(["ROOTPATH"]);try{xd=cC(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!zi.pathExistsSync(hi.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE)))throw n}if({level:wr,config_log_path:Hd,to_file:Ei,to_stream:os}=wQ(r.ROOTPATH?hi.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE):xd.get("settings_path")),nh=Wt.LOG_NAMES.HDB,sh=hi.join(Hd,nh),EQ)try{require("segfault-handler").registerHandler(hi.join(Hd,"crash.log"))}catch{}}}catch(t){if(xd=void 0,t.code===Wt.NODE_ERROR_CODES.ENOENT||t.code===Wt.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=sC(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){wr=l;continue}if(c===Wt.CONFIG_PARAMS.LOGGING_STDSTREAMS){os=l;continue}c===Wt.CONFIG_PARAMS.LOGGING_FILE&&(Ei=c),c===Wt.CONFIG_PARAMS.LOGGING_CONSOLE&&(ug=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=CQ();Ei=Ei===void 0?s:Ei,Ei=oC(Ei),os=os===void 0?i:os,os=oC(os),wr=wr===void 0?n:wr,Hd=mQ,nh=Wt.LOG_NAMES.INSTALL,sh=hi.join(Hd,nh);return}throw ih("Error initializing log settings"),ih(t),t}process.env.DEV_MODE&&(os=!0),RQ()}a(uC,"initLogSettings");var Vo=!0;function RQ(){Ei&&(process.stdout.write=function(e){return typeof e=="string"&&Vo&&ug!==!1&&(_g(),e=e.toString(),e[e.length-1]===`
3
- `&&(e=e.slice(0,-1)),zi.appendFileSync($o,xs("stdout",[e]))),iC.apply(process.stdout,arguments)},process.stderr.write=function(e){return typeof e=="string"&&Vo&&ug!==!1&&(_g(),e[e.length-1]===`
4
- `&&(e=e.slice(0,-1)),zi.appendFileSync($o,xs("stderr",[e]))),iC.apply(process.stderr,arguments)})}a(RQ,"stdioLogging");function AQ(e,t){let r={tagName:e.replace(/ /g,"-")};return{notify:n(hC,"notify"),fatal:n(pC,"fatal"),error:n(ih,"error"),warn:n(mC,"warn"),info:n(_C,"info"),debug:n(EC,"debug"),trace:n(fC,"trace")};function n(s,i){return!t||fr[wr]<=fr[i]?function(...o){return s(r,...o)}:null}}a(AQ,"loggerWithTag");function yQ(e){try{Vo=!1,e()}finally{Vo=!0}}a(yQ,"suppressLogging");var bQ=_Q?.name?.replace(/ /g,"-")||"main";function xs(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||bQ+"/"+fQ);c<s;c++){let u=t[c];if(u instanceof Error&&u.stack)n+=u.stack,Object.keys(u).length>0&&(n+=`
1
+ "use strict";var ej=Object.create;var vd=Object.defineProperty;var tj=Object.getOwnPropertyDescriptor;var rj=Object.getOwnPropertyNames;var nj=Object.getPrototypeOf,sj=Object.prototype.hasOwnProperty;var a=(e,t)=>vd(e,"name",{value:t,configurable:!0});var Ie=(e,t)=>()=>(e&&(t=e(e=0)),t);var N=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),je=(e,t)=>{for(var r in t)vd(e,r,{get:t[r],enumerable:!0})},xw=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of rj(t))!sj.call(e,s)&&s!==r&&vd(e,s,{get:()=>t[s],enumerable:!(n=tj(t,s))||n.enumerable});return e};var L=(e,t,r)=>(r=e!=null?ej(nj(e)):{},xw(t||!e||!e.__esModule?vd(r,"default",{value:e,enumerable:!0}):r,e)),oe=e=>xw(vd({},"__esModule",{value:!0}),e);var Gw=N((yge,Fw)=>{var ij=require("fast-glob"),{statSync:ig,existsSync:og,readFileSync:oj,writeFileSync:aj}=require("fs"),{spawnSync:cj,spawn:lj,execFileSync:Rge}=require("child_process"),{isMainThread:uj}=require("worker_threads"),{join:Fo,relative:kw}=require("path"),{PACKAGE_ROOT:Hs}=M(),{tmpdir:dj,platform:_j}=require("os");require("source-map-support").install();var fj=["resources","server","dataLayer","components"],Bd="ts-build",ag,Ej=__filename.endsWith("tsBuild.js");if(Ej){if(uj){let r;try{ig(Fo(Hs,Bd)),r=!0}catch{}if(r)for(let n of ij.sync(fj.map(s=>s+"/**/*.ts"),{cwd:Hs})){let s=0,i=0;try{s=ig(Fo(Hs,n)).mtimeMs-5e3,i=ig(Fo(Hs,Bd,n.replace(/.ts$/,".js"))).mtimeMs}catch{}if(s>i){console.warn(`TypeScript ${n} is not compiled`+(i?` (TS source file was modified at ${new Date(s)} and compiled file at ${new Date(i)})`:"")+", consider enabling auto-compilation of TypeScript in your IDE), compiling now."),ag=!0;break}}else console.log("TypeScript modules are not compiled, compiling now"),ag=!0;if(ag){let n=Fo(Hs,"node_modules/.bin/tsc");_j()==="win32"&&(n+=".cmd");let s=cj(n,{cwd:Hs});if(s.stdout?.length&&console.log(s.stdout.toString()),s.stderr?.length&&console.log(s.stderr.toString()),r){let i=Fo(dj(),"harperdb-tsc.pid"),o;if(og(i))try{process.kill(+oj(i,{encoding:"utf8"}),0),o=!0}catch{}if(!o){console.log("starting tsc background process");let c=lj(n,["--watch"],{cwd:Hs,detached:!0,stdio:"ignore"});aj(i,c.pid.toString()),c.unref()}}}}let e=Fw.constructor,t=e._findPath;e._findPath=function(r,n,s){if(r.startsWith(".")&&!s&&n.length===1&&n[0].startsWith(Hs)&&!n[0].includes("node_modules")){let i=kw(Hs,n[0]),o;i.startsWith(Bd)?o=Fo(Hs,kw(Bd,i)):o=Fo(Hs,Bd,i);let c=Fo(o,r),l=c+".js";if(og(l))return l;if(c.includes(".")&&og(c))return c}return t(r,n,s)}}});var M=N((Nge,tC)=>{"use strict";var is=require("path"),hj=require("fs"),{relative:bge,join:Oge}=is,{existsSync:pj}=hj;function mj(){let e=__dirname;for(;!pj(is.join(e,"package.json"));){let t=is.dirname(e);if(t===e)throw new Error("Could not find package root");e=t}return e}a(mj,"getHDBPackageRoot");var Go=mj(),qw="js",eh=qw,Sj="harperdb-config.yaml",Tj="defaultConfig.yaml",gj="hdb",$w=`harperdb.${eh}`,Vw=`customFunctionsServer.${eh}`,Aj=`restartHdb.${eh}`,lg="HarperDB",ZE="Custom Functions",th="Clustering Hub",rh="Clustering Leaf",Rj="Clustering Ingest Service",yj="Clustering Reply Service",bj="foreground.pid",Oj="hdb.pid",Nj="data",Ij={HDB:lg,CLUSTERING_HUB:th,CLUSTERING_LEAF:rh,CLUSTERING_INGEST_SERVICE:Rj,CLUSTERING_REPLY_SERVICE:yj,CUSTOM_FUNCTIONS:ZE,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"},wj={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},Cj={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},Dj={harperdb:lg,"clustering hub":th,"clustering leaf":rh,"custom functions":ZE,custom_functions:ZE,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers",http:"http"},Pj={CLUSTERING_HUB_PROC_DESCRIPTOR:th,CLUSTERING_LEAF_PROC_DESCRIPTOR:rh},cg={HDB:is.join(Go,"server/harperdb"),CUSTOM_FUNCTIONS:is.join(Go,"server/customFunctions"),CLUSTERING_HUB:is.join(Go,"server/nats"),CLUSTERING_LEAF:is.join(Go,"server/nats")},Lj={HDB:is.join(cg.HDB,$w),CUSTOM_FUNCTIONS:is.join(cg.CUSTOM_FUNCTIONS,Vw)},Mj={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:is.join(Go,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:is.join(Go,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:is.join(Go,"launchServiceScripts/launchUpdateNodes4-0-0.js")},Uj={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},Kw="support@harperdb.io",vj="customer-success@harperdb.io",Yw=1,Bj=4141,Ww="https://harperdbhelp.zendesk.com/hc/en-us/requests/new",Hj="https://www.harperdb.io/product",xj=`For support, please submit a request at ${Ww} or contact ${Kw}`,jw=`For license support, please contact ${vj}`,kj="None of the specified records were found.",Fj="hash attribute not found",Gj=`Your current license only supports ${Yw} role. ${jw}`,qj="Your current license only supports 3 connections to a node.",$j="127.0.0.1",Vj=1,Kj=/^\.$/,Yj=/^\.\.$/,Wj="U+002E",jj=/\//g,zj="U+002F",Qj=/U\+002F/g,Jj=/^U\+002E$/,Xj=/^U\+002EU\+002E$/,Zj="d",ez=999999,tz="*",rz="--max-old-space-size=",nz="system",sz="__hdb_hash",iz=".harperdb",oz=".hdb",az="keys",cz="hdb_boot_properties.file",lz=".updateConfig.json",uz="SIGTSTP",dz=24,_z=6e4,fz=448,Ez="blob",hz="database",pz="schema",mz="transactions",Sz=".count",Tz="id",gz="PROCESS_NAME",zw={SETTINGS_PATH_KEY:"settings_path"},Qw=require("lodash"),Az={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"},Rz={HDB_PATH_KEY:"HDB_INTERNAL_PATH",HDB_AUTH_HEADER:"hdb_auth_header",HDB_USER_DATA_KEY:"hdb_user",CHUNK_SIZE:1e3,MAX_CHARACTER_SIZE:250},yz={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},bz={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"},Oz={JOB_TABLE_HASH_ATTRIBUTE:"id",NODE_TABLE_HASH_ATTRIBUTE:"name",ATTRIBUTE_TABLE_HASH_ATTRIBUTE:"id",LICENSE_TABLE_HASH_ATTRIBUTE:"license_key",ROLE_TABLE_HASH_ATTRIBUTE:"id",SCHEMA_TABLE_HASH_ATTRIBUTE:"name",TABLE_TABLE_HASH_ATTRIBUTE:"id",USER_TABLE_HASH_ATTRIBUTE:"username",INFO_TABLE_ATTRIBUTE:"info_id"},Cn="hdb_internal:",Nz={CREATE_SCHEMA:Cn+"create_schema",CREATE_TABLE:Cn+"create_table",CREATE_ATTRIBUTE:Cn+"create_attribute",ADD_USER:Cn+"add_user",ALTER_USER:Cn+"alter_user",DROP_USER:Cn+"drop_user",HDB_NODES:Cn+"hdb_nodes",HDB_USERS:Cn+"hdb_users",HDB_WORKERS:Cn+"hdb_workers",CATCHUP:Cn+"catchup",SCHEMA_CATCHUP:Cn+"schema_catchup",WORKER_ROOM:Cn+"cluster_workers"},Iz={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"},wz="060493.ks",Cz=".license",Dz={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},le={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"},Pz={CSV:".csv",JSON:".json"},Lz={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},Mz={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},Hd={};Hd[le.INSERT]=le.INSERT;Hd[le.UPDATE]=le.UPDATE;Hd[le.UPSERT]=le.UPSERT;Hd[le.DELETE]=le.DELETE;var nt=Object.create(null);nt[le.DESCRIBE_ALL]=le.DESCRIBE_ALL;nt[le.DESCRIBE_TABLE]=le.DESCRIBE_TABLE;nt[le.DESCRIBE_SCHEMA]=le.DESCRIBE_SCHEMA;nt[le.READ_LOG]=le.READ_LOG;nt[le.ADD_NODE]=le.ADD_NODE;nt[le.LIST_USERS]=le.LIST_USERS;nt[le.LIST_ROLES]=le.LIST_ROLES;nt[le.USER_INFO]=le.USER_INFO;nt[le.SQL]=le.SQL;nt[le.GET_JOB]=le.GET_JOB;nt[le.SEARCH_JOBS_BY_START_DATE]=le.SEARCH_JOBS_BY_START_DATE;nt[le.DELETE_FILES_BEFORE]=le.DELETE_FILES_BEFORE;nt[le.EXPORT_LOCAL]=le.EXPORT_LOCAL;nt[le.EXPORT_TO_S3]=le.EXPORT_TO_S3;nt[le.CLUSTER_STATUS]=le.CLUSTER_STATUS;nt[le.REMOVE_NODE]=le.REMOVE_NODE;nt[le.RESTART]=le.RESTART;nt[le.CUSTOM_FUNCTIONS_STATUS]=le.CUSTOM_FUNCTIONS_STATUS;nt[le.GET_CUSTOM_FUNCTIONS]=le.GET_CUSTOM_FUNCTIONS;nt[le.GET_CUSTOM_FUNCTION]=le.GET_CUSTOM_FUNCTION;nt[le.SET_CUSTOM_FUNCTION]=le.SET_CUSTOM_FUNCTION;nt[le.DROP_CUSTOM_FUNCTION]=le.DROP_CUSTOM_FUNCTION;nt[le.ADD_CUSTOM_FUNCTION_PROJECT]=le.ADD_CUSTOM_FUNCTION_PROJECT;nt[le.DROP_CUSTOM_FUNCTION_PROJECT]=le.DROP_CUSTOM_FUNCTION_PROJECT;nt[le.PACKAGE_CUSTOM_FUNCTION_PROJECT]=le.PACKAGE_CUSTOM_FUNCTION_PROJECT;nt[le.DEPLOY_CUSTOM_FUNCTION_PROJECT]=le.DEPLOY_CUSTOM_FUNCTION_PROJECT;nt[le.ADD_SSH_KEY]=le.ADD_SSH_KEY;nt[le.UPDATE_SSH_KEY]=le.UPDATE_SSH_KEY;nt[le.DELETE_SSH_KEY]=le.DELETE_SSH_KEY;var Uz={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"},vz={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},Jw={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"},Bz=Qw.invert(Jw),Hz={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"},P={ANALYTICS_AGGREGATEPERIOD:"analytics_aggregatePeriod",AUTHENTICATION_AUTHORIZELOCAL:"authentication_authorizeLocal",AUTHENTICATION_CACHETTL:"authentication_cacheTTL",AUTHENTICATION_ENABLESESSIONS:"authentication_enableSessions",AUTHENTICATION_OPERATIONTOKENTIMEOUT:"authentication_operationTokenTimeout",AUTHENTICATION_REFRESHTOKENTIMEOUT:"authentication_refreshTokenTimeout",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_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",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_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_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_COPY_TABLES_TO_CATCHUP:"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_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",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"},Xw={settings_path:zw.SETTINGS_PATH_KEY,hdb_root_key:P.ROOTPATH,hdb_root:P.ROOTPATH,rootpath:P.ROOTPATH,server_port_key:P.OPERATIONSAPI_NETWORK_PORT,server_port:P.OPERATIONSAPI_NETWORK_PORT,cert_key:P.TLS_CERTIFICATE,certificate:P.TLS_CERTIFICATE,private_key_key:P.TLS_PRIVATEKEY,private_key:P.TLS_PRIVATEKEY,http_secure_enabled_key:P.OPERATIONSAPI_NETWORK_HTTPS,https_on:P.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:P.OPERATIONSAPI_NETWORK_CORS,cors_on:P.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:P.LOGGING_LEVEL,log_level:P.LOGGING_LEVEL,log_path_key:P.LOGGING_ROOT,log_path:P.LOGGING_ROOT,clustering_node_name_key:P.CLUSTERING_NODENAME,node_name:P.CLUSTERING_NODENAME,clustering_enabled_key:P.CLUSTERING_ENABLED,clustering:P.CLUSTERING_ENABLED,max_http_threads:P.THREADS_COUNT,max_hdb_processes:P.THREADS_COUNT,server_timeout_key:P.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:P.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:P.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:P.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:P.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:P.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:P.LOGGING_AUDITLOG,disable_transaction_log:P.LOGGING_AUDITLOG,operation_token_timeout_key:P.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:P.AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:P.AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:P.AUTHENTICATION_REFRESHTOKENTIMEOUT,custom_functions_port_key:P.HTTP_PORT,custom_functions_port:P.HTTP_PORT,custom_functions_directory_key:P.COMPONENTSROOT,custom_functions_directory:P.COMPONENTSROOT,max_custom_function_processes:P.THREADS_COUNT,logging_console:P.LOGGING_CONSOLE,log_to_file:P.LOGGING_FILE,log_to_stdstreams:P.LOGGING_STDSTREAMS,local_studio_on:P.LOCALSTUDIO_ENABLED,clustering_port:P.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:P.CLUSTERING_USER,clustering_enabled:P.CLUSTERING_ENABLED,clustering_hubserver_cluster_name:P.CLUSTERING_HUBSERVER_CLUSTER_NAME,clustering_hubserver_cluster_network_port:P.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_hubserver_cluster_network_routes:P.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,clustering_hubserver_leafnodes_network_port:P.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT,clustering_hubserver_network_port:P.CLUSTERING_HUBSERVER_NETWORK_PORT,clustering_leafserver_network_port:P.CLUSTERING_LEAFSERVER_NETWORK_PORT,clustering_leafserver_network_routes:P.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,clustering_leafserver_streams_maxage:P.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE,clustering_leafserver_streams_maxbytes:P.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES,clustering_leafserver_streams_maxconsumemsgs:P.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS,clustering_leafserver_streams_maxingestthreads:P.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS,clustering_leafserver_streams_maxmsgs:P.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS,clustering_leafserver_streams_path:P.CLUSTERING_LEAFSERVER_STREAMS_PATH,clustering_nodename:P.CLUSTERING_NODENAME,clustering_tls_certificate:P.CLUSTERING_TLS_CERTIFICATE,clustering_tls_privatekey:P.CLUSTERING_TLS_PRIVATEKEY,clustering_tls_certificateauthority:P.CLUSTERING_TLS_CERT_AUTH,clustering_tls_insecure:P.CLUSTERING_TLS_INSECURE,clustering_tls_verify:P.CLUSTERING_TLS_VERIFY,clustering_loglevel:P.CLUSTERING_LOGLEVEL,clustering_republishmessages:P.CLUSTERING_REPUBLISHMESSAGES,clustering_databaselevel:P.CLUSTERING_DATABASELEVEL,customfunctions_network_port:P.HTTP_PORT,customfunctions_tls_certificate:P.TLS_CERTIFICATE,customfunctions_network_cors:P.HTTP_CORS,customfunctions_network_corsaccesslist:P.HTTP_CORSACCESSLIST,customfunctions_network_headerstimeout:P.HTTP_HEADERSTIMEOUT,customfunctions_network_https:P.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:P.HTTP_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:P.TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:P.TLS_CERTIFICATEAUTHORITY,customfunctions_network_timeout:P.HTTP_TIMEOUT,customfunctions_tls:P.TLS,http_threads:P.THREADS_COUNT,threads:P.THREADS_COUNT,threads_count:P.THREADS_COUNT,threads_debug:P.THREADS_DEBUG,threads_debug_startingport:P.THREADS_DEBUG_STARTINGPORT,threads_debug_port:P.THREADS_DEBUG_PORT,threads_debug_host:P.THREADS_DEBUG_HOST,threads_debug_waitfordebugger:P.THREADS_DEBUG_WAITFORDEBUGGER,threads_maxheapmemory:P.THREADS_MAXHEAPMEMORY,http_session_affinity:P.HTTP_SESSIONAFFINITY,http_compressionthreshold:P.HTTP_COMPRESSIONTHRESHOLD,http_cors:P.HTTP_CORS,http_corsaccesslist:P.HTTP_CORSACCESSLIST,http_headerstimeout:P.HTTP_HEADERSTIMEOUT,http_keepalivetimeout:P.HTTP_KEEPALIVETIMEOUT,http_maxparamlength:P.HTTP_MAXPARAMLENGTH,http_timeout:P.HTTP_TIMEOUT,http_port:P.HTTP_PORT,http_secureport:P.HTTP_SECUREPORT,http_mtls:P.HTTP_MTLS,http_mtls_user:P.HTTP_MTLS_USER,http_mtls_required:P.HTTP_MTLS_REQUIRED,http_maxheadersize:P.HTTP_MAXHEADERSIZE,http_threadrange:P.HTTP_THREADRANGE,customfunctions_processes:P.THREADS_COUNT,customfunctions_root:P.COMPONENTSROOT,localstudio_enabled:P.LOCALSTUDIO_ENABLED,logging_file:P.LOGGING_FILE,logging_level:P.LOGGING_LEVEL,logging_root:P.LOGGING_ROOT,logging_rotation_enabled:P.LOGGING_ROTATION_ENABLED,logging_rotation_compress:P.LOGGING_ROTATION_COMPRESS,logging_rotation_interval:P.LOGGING_ROTATION_INTERVAL,logging_rotation_maxsize:P.LOGGING_ROTATION_MAXSIZE,logging_rotation_path:P.LOGGING_ROTATION_PATH,logging_stdstreams:P.LOGGING_STDSTREAMS,logging_auditlog:P.LOGGING_AUDITLOG,logging_auditretention:P.LOGGING_AUDITRETENTION,logging_auditauthevents_logfailed:P.LOGGING_AUDITAUTHEVENTS_LOGFAILED,logging_auditauthevents_logsuccessful:P.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL,operationsapi_authentication_operationtokentimeout:P.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operationsapi_authentication_refreshtokentimeout:P.AUTHENTICATION_REFRESHTOKENTIMEOUT,operationsapi_network_cors:P.OPERATIONSAPI_NETWORK_CORS,operationsapi_network_corsaccesslist:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,operationsapi_network_headerstimeout:P.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,operationsapi_network_https:P.OPERATIONSAPI_NETWORK_HTTPS,operationsapi_network_keepalivetimeout:P.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,operationsapi_network_port:P.OPERATIONSAPI_NETWORK_PORT,operationsapi_network_domainsocket:P.OPERATIONSAPI_NETWORK_DOMAINSOCKET,operationsapi_network_secureport:P.OPERATIONSAPI_NETWORK_SECUREPORT,operationsapi_tls:P.OPERATIONSAPI_TLS,operationsapi_tls_certificate:P.OPERATIONSAPI_TLS_CERTIFICATE,operationsapi_tls_privatekey:P.OPERATIONSAPI_TLS_PRIVATEKEY,operationsapi_tls_certificateauthority:P.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY,operationsapi_network_timeout:P.OPERATIONSAPI_NETWORK_TIMEOUT,operationsapi_root:P.ROOTPATH,operationsapi_sysinfo_network:P.OPERATIONSAPI_SYSINFO_NETWORK,operationsapi_sysinfo_disk:P.OPERATIONSAPI_SYSINFO_DISK,databases:P.DATABASES,storage_path:P.STORAGE_PATH,storage_maxtransactionqueuetime:P.STORAGE_MAXTRANSACTIONQUEUETIME,ignorescripts:P.IGNORE_SCRIPTS,mqtt_network_port:P.MQTT_NETWORK_PORT,mqtt_websocket:P.MQTT_WEBSOCKET,mqtt_network_secureport:P.MQTT_NETWORK_SECUREPORT,mqtt_network_mtls:P.MQTT_NETWORK_MTLS,mqtt_network_mtls_certificateAuthority:P.MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY,mqtt_network_mtls_user:P.MQTT_NETWORK_MTLS_USER,mqtt_network_mtls_required:P.MQTT_NETWORK_MTLS_REQUIRED,mqtt_requireauthentication:P.MQTT_REQUIREAUTHENTICATION,analytics_aggregatePeriod:P.ANALYTICS_AGGREGATEPERIOD,authentication_authorizelocal:P.AUTHENTICATION_AUTHORIZELOCAL,authentication_cachettl:P.AUTHENTICATION_CACHETTL,authentication_enablesessions:P.AUTHENTICATION_ENABLESESSIONS,authentication_operationtokentimeout:P.AUTHENTICATION_OPERATIONTOKENTIMEOUT,authentication_refreshtokentimeout:P.AUTHENTICATION_REFRESHTOKENTIMEOUT,componentsroot:P.COMPONENTSROOT,replication:P.REPLICATION,replication_port:P.REPLICATION_PORT,replication_secureport:P.REPLICATION_SECUREPORT,replication_hostname:P.REPLICATION_HOSTNAME,replication_url:P.REPLICATION_URL,replication_routes:P.REPLICATION_ROUTES,replication_enablerootcas:P.REPLICATION_ENABLEROOTCAS,replication_databases:P.REPLICATION_DATABASES,replication_copy_tables_to_catchup:P.REPLICATION_COPY_TABLES_TO_CATCHUP,tls:P.TLS,tls_certificate:P.TLS_CERTIFICATE,tls_privatekey:P.TLS_PRIVATEKEY,tls_certificateauthority:P.TLS_CERTIFICATEAUTHORITY,tls_ciphers:P.TLS_CIPHERS};for(let e in P){let t=P[e];Xw[t.toLowerCase()]=t}var xz={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},kz={csv_file_load:"csv_file_load",csv_data_load:le.CSV_DATA_LOAD,csv_url_load:le.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"},Fz={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"},Gz={BIDIRECTIONAL:"BIDIRECTIONAL",OUTBOUND:"OUTBOUND",INBOUND:"INBOUND"},qz={VERSION_DEFAULT:"2.2.0"},$z={DEVELOPMENT:8192,DEFAULT:512},Vz={IDENTIFY:"identify",AUTHENTICATE:"authenticate",AUTHENTICATE_OK:"authenticated",AUTHENTICATE_FAIL:"authenticate_fail",CONNECTION:"connection",CONNECT:"connect",CATCHUP_REQUEST:"catchup_request",CATCHUP_RESPONSE:"catchup",CONFIRM_MSG:"confirm_msg",ERROR:"error",DISCONNECT:"disconnect",SCHEMA_UPDATE_REQ:"schema_update_request",SCHEMA_UPDATE_RES:"schema_update_response",RECONNECT_ATTEMPT:"reconnect_attempt",CONNECT_ERROR:"connect_error",MESSAGE:"msg",VERSION_MISMATCH:"version_mismatch",DIRECTION_CHANGE:"direction_change"},Kz={1e3:"SUCCESSFUL_SHUTDOWN",1001:"CLOSE_GOING_AWAY",1002:"CLOSE_PROTOCOL_ERROR",1003:"CLOSE_UNSUPPORTED",1005:"CLOSE_NO_STATUS",1006:"CLOSE_ABNORMAL",1007:"UNSUPPORTED_PAYLOAD",1008:"POLICY_VIOLATION",1009:"CLOSE_TOO_LARGE",1010:"MANDATORY_EXTENSION",1011:"SERVER_ERROR",1012:"SERVICE_RESTART",1013:"SERVER_BUSY",1014:"BAD_GATEWAY",1015:"HANDSHAKE_FAIL",4141:"LICENSE_LIMIT_REACHED"},Yz={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},Zw={CREATED_TIME:"__createdtime__",UPDATED_TIME:"__updatedtime__"},Wz=Symbol("metadata"),jz="__clustering__",zz=Object.values(Zw),Qz=15984864e5,eC={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},Jz=Qw.invert(eC),Xz={GET_CLUSTER_STATUS:"GET_CLUSTER_STATUS",CLUSTER_STATUS_RESPONSE:"CLUSTER_STATUS_RESPONSE",ERROR_RESPONSE:"ERROR",ADD_USER:"ADD_USER",ALTER_USER:"ALTER_USER",DROP_USER:"DROP_USER",HDB_OPERATION:"HDB_OPERATION",ADD_NODE:"ADD_NODE",UPDATE_NODE:"UPDATE_NODE",REMOVE_NODE:"REMOVE_NODE",HDB_USERS_MSG:"HDB_USERS_MSG",HDB_WORKERS:"HDB_WORKERS",HDB_TRANSACTION:"HDB_TRANSACTION"},Zz=111,eQ=`\r
2
+ `,tQ={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},rQ=["*","%"],nQ="unauthorized_access",sQ="func_val",iQ={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},oQ={JWT_PRIVATE_KEY_NAME:".jwtPrivate.key",JWT_PUBLIC_KEY_NAME:".jwtPublic.key",JWT_PASSPHRASE_NAME:".jwtPass"},aQ={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"},cQ={HDB_CORE:"hdb_core",CUSTOM_FUNCTIONS:"custom_functions"},lQ={HTTP:"http"},uQ={STOPPED:"stopped",ONLINE:"online"},dQ="3.x.x",_Q={SUCCESS:"success",FAILURE:"failure"},fQ={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"};tC.exports={LOCAL_HARPERDB_OPERATIONS:nt,HDB_SUPPORT_ADDRESS:Kw,HDB_SUPPORT_URL:Ww,HDB_PRICING_URL:Hj,SUPPORT_HELP_MSG:xj,LICENSE_HELP_MSG:jw,HDB_PROC_NAME:$w,HDB_PROC_DESCRIPTOR:lg,CLUSTERING_LEAF_PROC_DESCRIPTOR:rh,CLUSTERING_HUB_PROC_DESCRIPTOR:th,SYSTEM_SCHEMA_NAME:nz,HASH_FOLDER_NAME:sz,HDB_HOME_DIR_NAME:iz,UPDATE_FILE_NAME:lz,LICENSE_KEY_DIR_NAME:az,BOOT_PROPS_FILE_NAME:cz,JOB_TYPE_ENUM:kz,JOB_STATUS_ENUM:Dz,SYSTEM_TABLE_NAMES:bz,SYSTEM_TABLE_HASH_ATTRIBUTES:Oz,OPERATIONS_ENUM:le,VALID_S3_FILE_TYPES:Pz,S3_BUCKET_AUTH_KEYS:Lz,VALID_SQL_OPS_ENUM:Mz,GEO_CONVERSION_ENUM:vz,HDB_SETTINGS_NAMES:Jw,HDB_SETTINGS_NAMES_REVERSE_LOOKUP:Bz,SERVICE_ACTIONS_ENUM:Uz,CLUSTER_MESSAGE_TYPE_ENUM:Fz,CLUSTER_CONNECTION_DIRECTION_ENUM:Gz,CLUSTER_EVENTS_DEFS_ENUM:Vz,PERIOD_REGEX:Kj,DOUBLE_PERIOD_REGEX:Yj,UNICODE_PERIOD:Wj,FORWARD_SLASH_REGEX:jj,UNICODE_FORWARD_SLASH:zj,ESCAPED_FORWARD_SLASH_REGEX:Qj,ESCAPED_PERIOD_REGEX:Jj,ESCAPED_DOUBLE_PERIOD_REGEX:Xj,REG_KEY_FILE_NAME:wz,RESTART_TIMEOUT_MS:_z,HDB_FILE_PERMISSIONS:fz,DATABASES_DIR_NAME:hz,LEGACY_DATABASES_DIR_NAME:pz,TRANSACTIONS_DIR_NAME:mz,LIMIT_COUNT_NAME:Sz,ID_ATTRIBUTE_STRING:Tz,INSERT_MODULE_ENUM:Rz,UPGRADE_JSON_FIELD_NAMES_ENUM:yz,RESTART_CODE:uz,RESTART_CODE_NUM:dz,CLUSTER_OPERATIONS:Hd,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:Iz,HDB_INTERNAL_SC_CHANNEL_PREFIX:Cn,INTERNAL_SC_CHANNELS:Nz,CLUSTERING_MESSAGE_TYPES:Xz,HDB_FILE_SUFFIX:oz,BLOB_FOLDER_NAME:Ez,ORIGINATOR_SET_VALUE:Zz,LICENSE_VALUES:qz,RAM_ALLOCATION_ENUM:$z,TIME_STAMP_NAMES_ENUM:Zw,TIME_STAMP_NAMES:zz,PERMS_UPDATE_RELEASE_TIMESTAMP:Qz,SEARCH_NOT_FOUND_MESSAGE:kj,SEARCH_ATTRIBUTE_NOT_FOUND:Fj,LICENSE_ROLE_DENIED_RESPONSE:Gj,LICENSE_MAX_CONNS_REACHED:qj,BASIC_LICENSE_MAX_NON_CU_ROLES:Yw,BASIC_LICENSE_CLUSTER_CONNECTION_LIMIT_WS_ERROR_CODE:Bj,VALUE_SEARCH_COMPARATORS:eC,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:Jz,LICENSE_FILE_NAME:Cz,WEBSOCKET_CLOSE_CODE_DESCRIPTION_LOOKUP:Kz,NEW_LINE:eQ,BASIC_LICENSE_MAX_CLUSTER_USER_ROLES:Vj,MOMENT_DAYS_TAG:Zj,API_TURNOVER_SEC:ez,LOOPBACK:$j,CODE_EXTENSION:eh,WILDCARD_SEARCH_VALUE:tz,NODE_ERROR_CODES:Yz,JAVASCRIPT_EXTENSION:qw,PERMS_CRUD_ENUM:tQ,UNAUTHORIZED_PERMISSION_NAME:nQ,SEARCH_WILDCARDS:rQ,FUNC_VAL:sQ,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:iQ,JWT_ENUM:oQ,CLUSTERING_FLAG:jz,ITC_EVENT_TYPES:aQ,CUSTOM_FUNCTION_PROC_NAME:Vw,CUSTOM_FUNCTION_PROC_DESCRIPTOR:ZE,SERVICES:cQ,THREAD_TYPES:lQ,MEM_SETTING_KEY:rz,HDB_RESTART_SCRIPT:Aj,PROCESS_DESCRIPTORS:Ij,SERVICE_SERVERS:Lj,SERVICE_SERVERS_CWD:cg,PROCESS_DESCRIPTORS_VALIDATE:Dj,LAUNCH_SERVICE_SCRIPTS:Mj,LOG_LEVELS:Cj,PROCESS_NAME_ENV_PROP:gz,LOG_NAMES:wj,PM2_PROCESS_STATUSES:uQ,CONFIG_PARAM_MAP:Xw,CONFIG_PARAMS:P,HDB_CONFIG_FILE:Sj,HDB_DEFAULT_CONFIG_FILE:Tj,ROLE_TYPES_ENUM:Uj,BOOT_PROP_PARAMS:zw,INSTALL_PROMPTS:Az,HDB_ROOT_DIR_NAME:gj,CLUSTERING_PROCESSES:Pj,FOREGROUND_PID_FILE:bj,PACKAGE_ROOT:Go,PRE_4_0_0_VERSION:dQ,DATABASES_PARAM_CONFIG:xz,METADATA_PROPERTY:Wz,AUTH_AUDIT_STATUS:_Q,AUTH_AUDIT_TYPES:fQ,HDB_PID_FILE:Oj,DEFAULT_DATABASE_NAME:Nj,LEGACY_CONFIG_PARAMS:Hz};Gw()});var Wa=N((wge,sC)=>{"use strict";var rC=require("minimist");sC.exports=EQ;function EQ(e=[],t=!1){if(!Array.isArray(e))return{};let r,n;t?(r=nC(process.env),n=nC(rC(process.argv))):(r=process.env,n=rC(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(EQ,"assignCMDENVVariables");function nC(e){let t,r=Object.keys(e),n=r.length,s={};for(;n--;)t=r[n],s[t.toLowerCase()]=e[t];return s}a(nC,"objKeysToLowerCase")});var fi=N(_i=>{"use strict";global.Resource=_i.Resource=void 0;global.tables=_i.tables={};global.databases=_i.databases={};global.getUser=_i.getUser=void 0;global.server=_i.server={};global.contentTypes=_i.contentTypes=null;global.threads=_i.threads=[];global.logger={};_i._assignPackageExport=(e,t)=>{global[e]=_i[e]=t}});var W=N((TC,gC)=>{"use strict";var zi=require("fs-extra"),{workerData:hQ,threadId:pQ,isMainThread:mQ}=require("worker_threads"),hi=require("path"),cC=require("yaml"),lC=require("properties-reader"),Wt=M(),iC=Wa(),SQ=require("os"),{PACKAGE_ROOT:fg}=M(),{_assignPackageExport:TQ}=fi(),oC=process.stdout.nativeWrite||(process.stdout.nativeWrite=process.stdout.write),fr={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},uC={STDOUT:"stdOut",STDERR:"stdErr"},gQ=hi.join(fg,"logs"),AQ=hi.join(fg,"config/yaml/",Wt.HDB_DEFAULT_CONFIG_FILE),RQ=1e4,ug,Ei,os,wr,nh,xd,sh,qo,kd;kd===void 0&&dC();Object.assign(TC,{notify:pC,fatal:mC,error:ih,warn:SC,info:fC,debug:hC,trace:EC,setLogLevel:DQ,log_level:wr,loggerWithTag:OQ,suppressLogging:NQ,initLogSettings:dC,logCustomLevel:wQ,closeLogFile:Eg,logsAtLevel:yQ,getLogFilePath:a(()=>sh,"getLogFilePath"),OUTPUTS:uC,AuthAuditLog:MQ});TQ("logger",gC.exports);var dg;function yQ(e){return fr[wr]<=fr[e]}a(yQ,"logsAtLevel");function dC(e=!1){try{if(kd===void 0||e){Eg();let t=CQ(),r=iC(["ROOTPATH"]);try{kd=lC(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!zi.pathExistsSync(hi.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE)))throw n}if({level:wr,config_log_path:xd,to_file:Ei,to_stream:os}=PQ(r.ROOTPATH?hi.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE):kd.get("settings_path")),nh=Wt.LOG_NAMES.HDB,sh=hi.join(xd,nh),mQ)try{require("segfault-handler").registerHandler(hi.join(xd,"crash.log"))}catch{}}}catch(t){if(kd=void 0,t.code===Wt.NODE_ERROR_CODES.ENOENT||t.code===Wt.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=iC(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){wr=l;continue}if(c===Wt.CONFIG_PARAMS.LOGGING_STDSTREAMS){os=l;continue}c===Wt.CONFIG_PARAMS.LOGGING_FILE&&(Ei=c),c===Wt.CONFIG_PARAMS.LOGGING_CONSOLE&&(ug=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=LQ();Ei=Ei===void 0?s:Ei,Ei=aC(Ei),os=os===void 0?i:os,os=aC(os),wr=wr===void 0?n:wr,xd=gQ,nh=Wt.LOG_NAMES.INSTALL,sh=hi.join(xd,nh);return}throw ih("Error initializing log settings"),ih(t),t}process.env.DEV_MODE&&(os=!0),bQ()}a(dC,"initLogSettings");var $o=!0;function bQ(){Ei&&(process.stdout.write=function(e){return typeof e=="string"&&$o&&ug!==!1&&(_g(),e=e.toString(),e[e.length-1]===`
3
+ `&&(e=e.slice(0,-1)),zi.appendFileSync(qo,xs("stdout",[e]))),oC.apply(process.stdout,arguments)},process.stderr.write=function(e){return typeof e=="string"&&$o&&ug!==!1&&(_g(),e[e.length-1]===`
4
+ `&&(e=e.slice(0,-1)),zi.appendFileSync(qo,xs("stderr",[e]))),oC.apply(process.stderr,arguments)})}a(bQ,"stdioLogging");function OQ(e,t){let r={tagName:e.replace(/ /g,"-")};return{notify:n(pC,"notify"),fatal:n(mC,"fatal"),error:n(ih,"error"),warn:n(SC,"warn"),info:n(fC,"info"),debug:n(hC,"debug"),trace:n(EC,"trace")};function n(s,i){return!t||fr[wr]<=fr[i]?function(...o){return s(r,...o)}:null}}a(OQ,"loggerWithTag");function NQ(e){try{$o=!1,e()}finally{$o=!0}}a(NQ,"suppressLogging");var IQ=hQ?.name?.replace(/ /g,"-")||"main";function xs(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||IQ+"/"+pQ);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(xs,"createLogRecord");function kd(e){if(Ei){if(dC(e),os){Vo=!1;try{process.stdout.write(e)}finally{Vo=!0}}}else os&&process.stdout.write(e)}a(kd,"logStdOut");function oh(e){if(Ei){if(dC(e),os){Vo=!1;try{process.stderr.write(e)}finally{Vo=!0}}}else os&&process.stderr.write(e)}a(oh,"logStdErr");function dC(e){_g(),$o?zi.appendFileSync($o,e):dg||console.log(e)}a(dC,"logToFile");function Eg(){try{zi.closeSync($o)}catch{}$o=null}a(Eg,"closeLogFile");function _g(){if(!$o){try{$o=zi.openSync(sh,"a")}catch(e){dg||(dg=!0,console.error(e))}setTimeout(()=>{Eg()},TQ).unref()}}a(_g,"openLogFile");function _C(...e){fr[wr]<=fr.info&&kd(xs("info",e))}a(_C,"info");function fC(...e){fr[wr]<=fr.trace&&kd(xs("trace",e))}a(fC,"trace");function ih(...e){fr[wr]<=fr.error&&oh(xs("error",e))}a(ih,"error");function EC(...e){fr[wr]<=fr.debug&&kd(xs("debug",e))}a(EC,"debug");function hC(...e){fr[wr]<=fr.notify&&kd(xs("notify",e))}a(hC,"notify");function pC(...e){fr[wr]<=fr.fatal&&oh(xs("fatal",e))}a(pC,"fatal");function mC(...e){fr[wr]<=fr.warn&&oh(xs("warn",e))}a(mC,"warn");function OQ(e,t,...r){t===lC.STDERR?oh(xs(e,r)):kd(xs(e,r))}a(OQ,"logCustomLevel");function NQ(){let e;try{e=hQ.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=hi.join(e,Wt.HDB_HOME_DIR_NAME,Wt.BOOT_PROPS_FILE_NAME);return zi.existsSync(t)||(t=hi.join(fg,"utility/hdb_boot_properties.file")),t}a(NQ,"getPropsFilePath");function IQ(e){wr=e}a(IQ,"setLogLevel");function oC(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(oC,"autoCastBoolean");function wQ(e){try{if(e.includes("config/settings.js")){let o=cC(e);return{level:o.get(Wt.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY),config_log_path:hi.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=aC.parseDocument(zi.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(wQ,"getLogConfig");function CQ(){try{let e=aC.parseDocument(zi.readFileSync(SQ,"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(CQ,"getDefaultConfig");function DQ(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(DQ,"AuthAuditLog")});var hg=N((wge,gC)=>{"use strict";var PQ=require("util"),LQ=require("path"),MQ=require("child_process"),UQ=PQ.promisify(MQ.execFile),vQ=1e3*1e3*10;gC.exports={findPs:BQ};async function BQ(e){let t={};try{await Promise.all(["comm","args","ppid","uid","%cpu","%mem"].map(async r=>{let{stdout:n}=await UQ("ps",["wwxo",`pid,${r}`],{maxBuffer:vQ});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:LQ.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(BQ,"findPs")});var Bt=N((Dge,AC)=>{"use strict";var HQ="__dbis__",xQ="__txns__",kQ="__environment_name__",FQ="__dbi_defintion__",GQ={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"},qQ=["__createdtime__","__updatedtime__"],$Q="\uFFFF",RC={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},VQ=Object.values(RC);AC.exports={AUDIT_STORE_NAME:xQ,INTERNAL_DBIS_NAME:HQ,DBI_DEFINITION_NAME:FQ,SEARCH_TYPES:GQ,TIMESTAMP_NAMES:qQ,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:kQ,TRANSACTIONS_DBI_NAMES_ENUM:RC,TRANSACTIONS_DBIS:VQ,OVERFLOW_MARKER:$Q}});var Dn=N((Pge,PC)=>{"use strict";var yC=M(),bC=Bt(),OC={CONTINUE:100,OK:200,CREATED:201,BAD_REQUEST:400,UNAUTHORIZED:401,FORBIDDEN:403,NOT_FOUND:404,METHOD_NOT_ALLOWED:405,REQUEST_TIMEOUT:408,CONFLICT:409,TOO_MANY_REQUESTS:429,INTERNAL_SERVER_ERROR:500,NOT_IMPLEMENTED:501,BAD_GATEWAY:502,SERVICE_UNAVAILABLE:503,GATEWAY_TIMEOUT:504,HTTP_VERSION_NOT_SUPPORTED:505,INSUFFICIENT_STORAGE:507,NETWORK_AUTHENTICATION_REQUIRED:511},NC=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),IC={500:NC("There was an error processing your request."),400:"Invalid request"},KQ=IC[OC.INTERNAL_SERVER_ERROR],YQ={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")},WQ={CONFIG_VALIDATION:a(e=>`HarperDB config file validation error: ${e}`,"CONFIG_VALIDATION")},jQ={DEFAULT_BULK_LOAD_ERR:"There was an error during your bulk load into HarperDB.",DOWNLOAD_FILE_ERR:a(e=>`There was an error downloading '${e}'.`,"DOWNLOAD_FILE_ERR"),INSERT_JSON_ERR:"There was an error inserting the downloaded JSON data.",INSERT_CSV_ERR:"There was an error inserting the downloaded CSV data.",INVALID_ACTION_PARAM_ERR:a(e=>`Bulk load operation failed - ${e} is not a valid 'action' parameter`,"INVALID_ACTION_PARAM_ERR"),INVALID_FILE_EXT_ERR:a(e=>`Error selecting correct parser - valid file type not found in json - ${e}`,"INVALID_FILE_EXT_ERR"),MAX_FILE_SIZE_ERR:a((e,t)=>`File size is ${e} bytes, which exceeded the maximum size allowed of: ${t} bytes`,"MAX_FILE_SIZE_ERR"),PAPA_PARSE_ERR:"There was an error parsing the downloaded CSV data.",S3_DOWNLOAD_ERR:a(e=>`There was an error downloading '${e}' from AWS.`,"S3_DOWNLOAD_ERR"),WRITE_TEMP_FILE_ERR:"Error writing temporary file to storage"},zQ={BASE_PATH_REQUIRED:"base_path is required",DESTINATION_PATH_REQUIRED:"destination_path is required",ENV_NAME_REQUIRED:"env_name is required",INVALID_BASE_PATH:"invalid base_path",INVALID_DESTINATION_PATH:"invalid destination_path",INVALID_ENVIRONMENT:"invalid environment",ENV_REQUIRED:"env is required",DBI_NAME_REQUIRED:"dbi_name is required",DBI_DOES_NOT_EXIST:"dbi does not exist",HASH_ATTRIBUTE_REQUIRED:"hash_attribute is required",ID_REQUIRED:"id is required",IDS_REQUIRED:"ids is required",IDS_MUST_BE_ITERABLE:"ids must be iterable",FETCH_ATTRIBUTES_REQUIRED:"fetch_attributes is required",FETCH_ATTRIBUTES_MUST_BE_ARRAY:"fetch_attributes must be an array",ATTRIBUTE_REQUIRED:"attribute is required",SEARCH_VALUE_REQUIRED:"search_value is required",SEARCH_VALUE_TOO_LARGE:"search_value is too long",WRITE_ATTRIBUTES_REQUIRED:"write_attributes is required",WRITE_ATTRIBUTES_MUST_BE_ARRAY:"write_attributes must be an array",RECORDS_REQUIRED:"records is required",RECORDS_MUST_BE_ARRAY:"records must be an array",CANNOT_CREATE_INTERNAL_DBIS_NAME:`cannot create a dbi named ${bC.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${bC.INTERNAL_DBIS_NAME}`,START_VALUE_REQUIRED:"start_value is required",END_VALUE_REQUIRED:"end_value is required",CANNOT_COMPARE_STRING_TO_NUMERIC_KEYS:"cannot compare a string to numeric keys",END_VALUE_MUST_BE_GREATER_THAN_START_VALUE:"end_value must be greater than or equal to start_value",UNKNOWN_SEARCH_TYPE:"unknown search type",CANNOT_DROP_TABLE_HASH_ATTRIBUTE:"cannot drop a table's hash attribute"},QQ={ATTR_NAME_LENGTH_ERR:a(e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${yC.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes.`,"ATTR_NAME_LENGTH_ERR"),ATTR_NAME_NULLISH_ERR:"transaction aborted due to record(s) with an attribute name that is null, undefined or empty string",HASH_VAL_LENGTH_ERR:`transaction aborted due to record(s) with a hash value that exceeds ${yC.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes, check log for more info`,INVALID_FORWARD_SLASH_IN_HASH_ERR:"transaction aborted due to record(s) with a hash value that contains a forward slash, check log for more info",RECORD_MISSING_HASH_ERR:"transaction aborted due to record(s) with no hash value, check log for more info"},wC={GENERIC_AUTH_FAIL:"Login failed",USER_INACTIVE:"Cannot complete request: User is inactive",INVALID_TOKEN:"invalid token",NO_ENCRYPTION_KEYS:"unable to generate JWT as there are no encryption keys. please contact your administrator",INVALID_CREDENTIALS:"invalid credentials",PASSWORD_REQUIRED:"password is required",USERNAME_REQUIRED:"username is required",REFRESH_TOKEN_REQUIRED:"refresh_token is required",INVALID_AUTH_OBJECT:"invalid auth_object",INVALID_BODY:"invalid body",TOKEN_EXPIRED:"token expired",REFRESH_TOKEN_SAVE_FAILED:"unable to store refresh_token"},JQ={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."},XQ={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")},ZQ={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"},e2={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},t2={ALTER_USER_DUP_ROLES:a(e=>`Update failed. There are duplicates for the '${e}' role which is not allowed. Update your roles and try again.`,"ALTER_USER_DUP_ROLES"),ALTER_USER_ROLE_NOT_FOUND:a(e=>`Update failed. Requested '${e}' role not found.`,"ALTER_USER_ROLE_NOT_FOUND"),DUP_ROLES_FOUND:a(e=>`Multiple ${e} roles found. Roles must have unique 'role' value. Please update and try again.`,"DUP_ROLES_FOUND"),ROLE_NAME_NOT_FOUND:a(e=>`${e} role not found`,"ROLE_NAME_NOT_FOUND"),USER_ALREADY_EXISTS:a(e=>`User ${e} already exists`,"USER_ALREADY_EXISTS"),USER_NOT_EXIST:a(e=>`User ${e} does not exist`,"USER_NOT_EXIST")},CC={INVALID_DATE:"Invalid date, must be in ISO-8601 format (YYYY-MM-DD).",SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE:a(e=>`invalid sort attribute '${e}', the attribute must either be the table's hash attribute or an attribute used in conditions.`,"SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE")},DC={INVALID_ITC_DATA_TYPE:"Invalid ITC event data type, must be an object",MISSING_TYPE:"ITC event missing 'type'",MISSING_MSG:"ITC event missing 'message'",MISSING_ORIGIN:"ITC event message missing 'originator' property",INVALID_EVENT:a(e=>`ITC server received invalid event type: ${e}`,"INVALID_EVENT")},r2={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"},n2={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},s2={...wC,...jQ,...YQ,...JQ,...XQ,...ZQ,...e2,...t2,...QQ,...CC,...DC,...r2,...n2,...WQ};PC.exports={CHECK_LOGS_WRAPPER:NC,HDB_ERROR_MSGS:s2,DEFAULT_ERROR_MSGS:IC,DEFAULT_ERROR_RESP:KQ,HTTP_STATUS_CODES:OC,LMDB_ERRORS_ENUM:zQ,AUTHENTICATION_ERROR_MSGS:wC,VALIDATION_ERROR_MSGS:CC,ITC_ERRORS:DC}});var _e=N((Mge,UC)=>{"use strict";var Ol=Dn(),i2=W(),o2=M(),ah=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,LC),this.statusCode=n||Ol.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(Ol.DEFAULT_ERROR_MSGS[n]?Ol.DEFAULT_ERROR_MSGS[n]:Ol.DEFAULT_ERROR_MSGS[Ol.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&&i2[s](i)}},pg=class extends Error{static{a(this,"ClientError")}constructor(t,r){if(t instanceof Error)return t.statusCode=r||400,t;super(t),this.statusCode=r||400}},mg=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function LC(e,t,r,n=o2.LOG_LEVELS.ERROR,s=null,i=!1){if(MC(e))return e;let o=new ah(e,t,r,n,s);return i&&delete o.stack,o}a(LC,"handleHDBError");function MC(e){return e.__proto__.constructor.name===ah.name}a(MC,"isHDBError");UC.exports={isHDBError:MC,handleHDBError:LC,ClientError:pg,ServerError:mg,hdb_errors:Ol}});var Sg=N(vC=>{"use strict";var a2={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
7
+ `}a(xs,"createLogRecord");function Fd(e){if(Ei){if(_C(e),os){$o=!1;try{process.stdout.write(e)}finally{$o=!0}}}else os&&process.stdout.write(e)}a(Fd,"logStdOut");function oh(e){if(Ei){if(_C(e),os){$o=!1;try{process.stderr.write(e)}finally{$o=!0}}}else os&&process.stderr.write(e)}a(oh,"logStdErr");function _C(e){_g(),qo?zi.appendFileSync(qo,e):dg||console.log(e)}a(_C,"logToFile");function Eg(){try{zi.closeSync(qo)}catch{}qo=null}a(Eg,"closeLogFile");function _g(){if(!qo){try{qo=zi.openSync(sh,"a")}catch(e){dg||(dg=!0,console.error(e))}setTimeout(()=>{Eg()},RQ).unref()}}a(_g,"openLogFile");function fC(...e){fr[wr]<=fr.info&&Fd(xs("info",e))}a(fC,"info");function EC(...e){fr[wr]<=fr.trace&&Fd(xs("trace",e))}a(EC,"trace");function ih(...e){fr[wr]<=fr.error&&oh(xs("error",e))}a(ih,"error");function hC(...e){fr[wr]<=fr.debug&&Fd(xs("debug",e))}a(hC,"debug");function pC(...e){fr[wr]<=fr.notify&&Fd(xs("notify",e))}a(pC,"notify");function mC(...e){fr[wr]<=fr.fatal&&oh(xs("fatal",e))}a(mC,"fatal");function SC(...e){fr[wr]<=fr.warn&&oh(xs("warn",e))}a(SC,"warn");function wQ(e,t,...r){t===uC.STDERR?oh(xs(e,r)):Fd(xs(e,r))}a(wQ,"logCustomLevel");function CQ(){let e;try{e=SQ.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=hi.join(e,Wt.HDB_HOME_DIR_NAME,Wt.BOOT_PROPS_FILE_NAME);return zi.existsSync(t)||(t=hi.join(fg,"utility/hdb_boot_properties.file")),t}a(CQ,"getPropsFilePath");function DQ(e){wr=e}a(DQ,"setLogLevel");function aC(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(aC,"autoCastBoolean");function PQ(e){try{if(e.includes("config/settings.js")){let o=lC(e);return{level:o.get(Wt.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY),config_log_path:hi.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=cC.parseDocument(zi.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(PQ,"getLogConfig");function LQ(){try{let e=cC.parseDocument(zi.readFileSync(AQ,"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(LQ,"getDefaultConfig");function MQ(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(MQ,"AuthAuditLog")});var hg=N((Lge,AC)=>{"use strict";var UQ=require("util"),vQ=require("path"),BQ=require("child_process"),HQ=UQ.promisify(BQ.execFile),xQ=1e3*1e3*10;AC.exports={findPs:kQ};async function kQ(e){let t={};try{await Promise.all(["comm","args","ppid","uid","%cpu","%mem"].map(async r=>{let{stdout:n}=await HQ("ps",["wwxo",`pid,${r}`],{maxBuffer:xQ});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:vQ.basename(n.comm),cmd:n.args,ppid:Number.parseInt(n.ppid,10),uid:Number.parseInt(n.uid,10),cpu:Number.parseFloat(n["%cpu"]),memory:Number.parseFloat(n["%mem"])}))}a(kQ,"findPs")});var Ht=N((Uge,yC)=>{"use strict";var FQ="__dbis__",GQ="__txns__",qQ="__environment_name__",$Q="__dbi_defintion__",VQ={EQUALS:"equals",STARTS_WITH:"startsWith",_STARTS_WITH:"starts_with",ENDS_WITH:"endsWith",_ENDS_WITH:"ends_with",CONTAINS:"contains",SEARCH_ALL:"searchAll",SEARCH_ALL_TO_MAP:"searchAllToMap",BATCH_SEARCH_BY_HASH:"batchSearchByHash",BATCH_SEARCH_BY_HASH_TO_MAP:"batchSearchByHashToMap",GREATER_THAN:"greaterThan",_GREATER_THAN:"greater_than",GREATER_THAN_EQUAL:"greaterThanEqual",_GREATER_THAN_EQUAL:"greater_than_equal",LESS_THAN:"lessThan",_LESS_THAN:"less_than",LESS_THAN_EQUAL:"lessThanEqual",_LESS_THAN_EQUAL:"less_than_equal",BETWEEN:"between"},KQ=["__createdtime__","__updatedtime__"],YQ="\uFFFF",RC={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},WQ=Object.values(RC);yC.exports={AUDIT_STORE_NAME:GQ,INTERNAL_DBIS_NAME:FQ,DBI_DEFINITION_NAME:$Q,SEARCH_TYPES:VQ,TIMESTAMP_NAMES:KQ,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:qQ,TRANSACTIONS_DBI_NAMES_ENUM:RC,TRANSACTIONS_DBIS:WQ,OVERFLOW_MARKER:YQ}});var Dn=N((vge,LC)=>{"use strict";var bC=M(),OC=Ht(),NC={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},IC=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),wC={500:IC("There was an error processing your request."),400:"Invalid request"},jQ=wC[NC.INTERNAL_SERVER_ERROR],zQ={OP_NOT_SUPPORTED_FOR_FS:a(e=>`${e} is not available for this instance because it uses the File System data store.`,"OP_NOT_SUPPORTED_FOR_FS"),MISSING_VALUE:a(e=>`${e} is missing.`,"MISSING_VALUE"),INVALID_VALUE:a(e=>`${e} is invalid.`,"INVALID_VALUE"),NOT_FOUND:a(e=>`${e} not found.`,"NOT_FOUND")},QQ={CONFIG_VALIDATION:a(e=>`HarperDB config file validation error: ${e}`,"CONFIG_VALIDATION")},JQ={DEFAULT_BULK_LOAD_ERR:"There was an error during your bulk load into HarperDB.",DOWNLOAD_FILE_ERR:a(e=>`There was an error downloading '${e}'.`,"DOWNLOAD_FILE_ERR"),INSERT_JSON_ERR:"There was an error inserting the downloaded JSON data.",INSERT_CSV_ERR:"There was an error inserting the downloaded CSV data.",INVALID_ACTION_PARAM_ERR:a(e=>`Bulk load operation failed - ${e} is not a valid 'action' parameter`,"INVALID_ACTION_PARAM_ERR"),INVALID_FILE_EXT_ERR:a(e=>`Error selecting correct parser - valid file type not found in json - ${e}`,"INVALID_FILE_EXT_ERR"),MAX_FILE_SIZE_ERR:a((e,t)=>`File size is ${e} bytes, which exceeded the maximum size allowed of: ${t} bytes`,"MAX_FILE_SIZE_ERR"),PAPA_PARSE_ERR:"There was an error parsing the downloaded CSV data.",S3_DOWNLOAD_ERR:a(e=>`There was an error downloading '${e}' from AWS.`,"S3_DOWNLOAD_ERR"),WRITE_TEMP_FILE_ERR:"Error writing temporary file to storage"},XQ={BASE_PATH_REQUIRED:"base_path is required",DESTINATION_PATH_REQUIRED:"destination_path is required",ENV_NAME_REQUIRED:"env_name is required",INVALID_BASE_PATH:"invalid base_path",INVALID_DESTINATION_PATH:"invalid destination_path",INVALID_ENVIRONMENT:"invalid environment",ENV_REQUIRED:"env is required",DBI_NAME_REQUIRED:"dbi_name is required",DBI_DOES_NOT_EXIST:"dbi does not exist",HASH_ATTRIBUTE_REQUIRED:"hash_attribute is required",ID_REQUIRED:"id is required",IDS_REQUIRED:"ids is required",IDS_MUST_BE_ITERABLE:"ids must be iterable",FETCH_ATTRIBUTES_REQUIRED:"fetch_attributes is required",FETCH_ATTRIBUTES_MUST_BE_ARRAY:"fetch_attributes must be an array",ATTRIBUTE_REQUIRED:"attribute is required",SEARCH_VALUE_REQUIRED:"search_value is required",SEARCH_VALUE_TOO_LARGE:"search_value is too long",WRITE_ATTRIBUTES_REQUIRED:"write_attributes is required",WRITE_ATTRIBUTES_MUST_BE_ARRAY:"write_attributes must be an array",RECORDS_REQUIRED:"records is required",RECORDS_MUST_BE_ARRAY:"records must be an array",CANNOT_CREATE_INTERNAL_DBIS_NAME:`cannot create a dbi named ${OC.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${OC.INTERNAL_DBIS_NAME}`,START_VALUE_REQUIRED:"start_value is required",END_VALUE_REQUIRED:"end_value is required",CANNOT_COMPARE_STRING_TO_NUMERIC_KEYS:"cannot compare a string to numeric keys",END_VALUE_MUST_BE_GREATER_THAN_START_VALUE:"end_value must be greater than or equal to start_value",UNKNOWN_SEARCH_TYPE:"unknown search type",CANNOT_DROP_TABLE_HASH_ATTRIBUTE:"cannot drop a table's hash attribute"},ZQ={ATTR_NAME_LENGTH_ERR:a(e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${bC.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes.`,"ATTR_NAME_LENGTH_ERR"),ATTR_NAME_NULLISH_ERR:"transaction aborted due to record(s) with an attribute name that is null, undefined or empty string",HASH_VAL_LENGTH_ERR:`transaction aborted due to record(s) with a hash value that exceeds ${bC.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes, check log for more info`,INVALID_FORWARD_SLASH_IN_HASH_ERR:"transaction aborted due to record(s) with a hash value that contains a forward slash, check log for more info",RECORD_MISSING_HASH_ERR:"transaction aborted due to record(s) with no hash value, check log for more info"},CC={GENERIC_AUTH_FAIL:"Login failed",USER_INACTIVE:"Cannot complete request: User is inactive",INVALID_TOKEN:"invalid token",NO_ENCRYPTION_KEYS:"unable to generate JWT as there are no encryption keys. please contact your administrator",INVALID_CREDENTIALS:"invalid credentials",PASSWORD_REQUIRED:"password is required",USERNAME_REQUIRED:"username is required",REFRESH_TOKEN_REQUIRED:"refresh_token is required",INVALID_AUTH_OBJECT:"invalid auth_object",INVALID_BODY:"invalid body",TOKEN_EXPIRED:"token expired",REFRESH_TOKEN_SAVE_FAILED:"unable to store refresh_token"},e2={DEFAULT_INVALID_REQUEST:"Invalid request",OP_AUTH_PERMS_ERROR:"This operation is not authorized due to role restrictions and/or invalid database items",OP_IS_SU_ONLY:a(e=>`Operation '${e}' is restricted to 'super_user' roles`,"OP_IS_SU_ONLY"),OP_NOT_FOUND:a(e=>`Operation '${e}' not found`,"OP_NOT_FOUND"),SYSTEM_TIMESTAMP_PERMS_ERR:"Internal timestamp attributes - '__createdtime_' and '__updatedtime__' - cannot be inserted to or updated by HDB users.",UNKNOWN_OP_AUTH_ERROR:a((e,t,r)=>`There was an error authorizing ${e} op on table '${t}.${r}'`,"UNKNOWN_OP_AUTH_ERROR"),USER_HAS_NO_PERMS:a(e=>`User ${e} has no role or permissions. Please assign the user a valid role.`,"USER_HAS_NO_PERMS"),DROP_SYSTEM:"The 'system' database, tables and records are used internally by HarperDB and cannot be updated or removed."},t2={ATTR_PERM_MISSING:a((e,t)=>`${e.toUpperCase()} attribute permission missing for '${t}'`,"ATTR_PERM_MISSING"),ATTR_PERM_MISSING_NAME:"Permission object in 'attribute_permission' missing an 'attribute_name'",ATTR_PERM_NOT_BOOLEAN:a((e,t)=>`${e.toUpperCase()} attribute permission for '${t}' must be a boolean`,"ATTR_PERM_NOT_BOOLEAN"),ATTR_PERMS_ARRAY_MISSING:"Missing 'attribute_permissions' array",ATTR_PERMS_NOT_ARRAY:"Value for 'attribute_permissions' must be an array",INVALID_ATTRIBUTE_IN_PERMS:a(e=>`Invalid attribute '${e}' in 'attribute_permissions'`,"INVALID_ATTRIBUTE_IN_PERMS"),INVALID_PERM_KEY:a(e=>`Invalid table permission key value '${e}'`,"INVALID_PERM_KEY"),INVALID_ATTR_PERM_KEY:a(e=>`Invalid attribute permission key value '${e}'`,"INVALID_ATTR_PERM_KEY"),INVALID_ROLE_JSON_KEYS:a(e=>`Invalid ${e.length>1?"keys":"key"} in JSON body - '${e.join("', '")}'`,"INVALID_ROLE_JSON_KEYS"),MISMATCHED_TABLE_ATTR_PERMS:a(e=>`You have a conflict with TABLE permissions for '${e}' being false and ATTRIBUTE permissions being true`,"MISMATCHED_TABLE_ATTR_PERMS"),OUTDATED_PERMS_TRANSLATION_ERROR:"This instance was recently upgraded and uses our new role permissions structure. Please login to this instance in HarperDB Studio, go to 'Roles', and click 'Update Role Permission' for all standard roles to migrate them to the new structure.",ROLE_ALREADY_EXISTS:a(e=>`A role with name '${e}' already exists`,"ROLE_ALREADY_EXISTS"),ROLE_NOT_FOUND:"Role not found",ROLE_PERMS_ERROR:"Errors in the role permissions JSON provided",SCHEMA_PERM_ERROR:a(e=>`Your role does not have permission to view database metadata for '${e}'`,"SCHEMA_PERM_ERROR"),SCHEMA_TABLE_PERM_ERROR:a((e,t)=>`Your role does not have permission to view database.table metadata for '${e}.${t}'`,"SCHEMA_TABLE_PERM_ERROR"),SU_ROLE_MISSING_ERROR:"Missing 'super_user' key/value in permission set",SU_CU_ROLE_BOOLEAN_ERROR:a(e=>`Value for '${e}' permission must be a boolean`,"SU_CU_ROLE_BOOLEAN_ERROR"),STRUCTURE_USER_ROLE_TYPE_ERROR:a(e=>`Value for '${e}' permission must be a boolean or Array`,"STRUCTURE_USER_ROLE_TYPE_ERROR"),SU_CU_ROLE_NO_PERMS_ALLOWED:a(e=>`Roles with '${e}' set to true cannot have other permissions set.`,"SU_CU_ROLE_NO_PERMS_ALLOWED"),SU_CU_ROLE_COMBINED_ERROR:"Roles cannot have both 'super_user' and 'cluster_user' values included in their permissions set.",TABLE_PERM_MISSING:a(e=>`Missing table ${e.toUpperCase()} permission`,"TABLE_PERM_MISSING"),TABLE_PERM_NOT_BOOLEAN:a(e=>`Table ${e.toUpperCase()} permission must be a boolean`,"TABLE_PERM_NOT_BOOLEAN")},r2={ATTR_NOT_FOUND:a((e,t,r)=>`Attribute '${r}' does not exist on '${e}.${t}'`,"ATTR_NOT_FOUND"),ATTR_EXISTS_ERR:a((e,t,r)=>`Attribute '${r}' already exists in ${e}.${t}'`,"ATTR_EXISTS_ERR"),DESCRIBE_ALL_ERR:"There was an error during describeAll. Please check the logs and try again.",INVALID_TABLE_ERR:a(e=>`Invalid table ${JSON.stringify(e)}`,"INVALID_TABLE_ERR"),SCHEMA_NOT_FOUND:a(e=>`database '${e}' does not exist`,"SCHEMA_NOT_FOUND"),SCHEMA_EXISTS_ERR:a(e=>`database '${e}' already exists`,"SCHEMA_EXISTS_ERR"),TABLE_EXISTS_ERR:a((e,t)=>`Table '${t}' already exists in '${e}'`,"TABLE_EXISTS_ERR"),SCHEMA_REQUIRED_ERR:"database is required",TABLE_NOT_FOUND:a((e,t)=>`Table '${e}.${t}' does not exist`,"TABLE_NOT_FOUND"),TABLE_REQUIRED_ERR:"table is required"},n2={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},s2={ALTER_USER_DUP_ROLES:a(e=>`Update failed. There are duplicates for the '${e}' role which is not allowed. Update your roles and try again.`,"ALTER_USER_DUP_ROLES"),ALTER_USER_ROLE_NOT_FOUND:a(e=>`Update failed. Requested '${e}' role not found.`,"ALTER_USER_ROLE_NOT_FOUND"),DUP_ROLES_FOUND:a(e=>`Multiple ${e} roles found. Roles must have unique 'role' value. Please update and try again.`,"DUP_ROLES_FOUND"),ROLE_NAME_NOT_FOUND:a(e=>`${e} role not found`,"ROLE_NAME_NOT_FOUND"),USER_ALREADY_EXISTS:a(e=>`User ${e} already exists`,"USER_ALREADY_EXISTS"),USER_NOT_EXIST:a(e=>`User ${e} does not exist`,"USER_NOT_EXIST")},DC={INVALID_DATE:"Invalid date, must be in ISO-8601 format (YYYY-MM-DD).",SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE:a(e=>`invalid sort attribute '${e}', the attribute must either be the table's hash attribute or an attribute used in conditions.`,"SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE")},PC={INVALID_ITC_DATA_TYPE:"Invalid ITC event data type, must be an object",MISSING_TYPE:"ITC event missing 'type'",MISSING_MSG:"ITC event missing 'message'",MISSING_ORIGIN:"ITC event message missing 'originator' property",INVALID_EVENT:a(e=>`ITC server received invalid event type: ${e}`,"INVALID_EVENT")},i2={FUNCTION_STATUS:"Error getting custom function status, check the log for more details",GET_FUNCTIONS:"Error getting custom functions, check the log for more details",GET_FUNCTION:"Error getting custom function, check the log for more details",SET_FUNCTION:"Error setting custom function, check the log for more details",NO_PROJECT:"Project does not exist. Create one using 'add_custom_function_project'",PROJECT_EXISTS:"Project already exists",VALIDATION_ERR:"Error validating request, check the log for more details",NO_FILE:"File does not exist",BAD_FILE_NAME:"File name can only contain alphanumeric, dash and underscore characters",BAD_PROJECT_NAME:"Project name can only contain alphanumeric, dash and underscores characters",BAD_PACKAGE:"Packaged project must be base64-encoded tar file of project directory",DROP_FUNCTION:"Error dropping custom function, check the log for more details",ADD_FUNCTION:"Error adding custom function project, check the log for more details",DROP_FUNCTION_PROJECT:"Error dropping custom function project, check the log for more details",BAD_FILE_PATH:"Filepath must be valid, and contain the name of the tarball you wish to write",NOT_ENABLED:"Custom functions is not enabled, to enable set fastifyRoutes enabled to true in hdb/harperdb-config.yaml file.",BAD_SSH_KEY_NAME:"SSH key name can only contain alphanumeric, dash and underscore characters"},o2={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},a2={...CC,...JQ,...zQ,...e2,...t2,...r2,...n2,...s2,...ZQ,...DC,...PC,...i2,...o2,...QQ};LC.exports={CHECK_LOGS_WRAPPER:IC,HDB_ERROR_MSGS:a2,DEFAULT_ERROR_MSGS:wC,DEFAULT_ERROR_RESP:jQ,HTTP_STATUS_CODES:NC,LMDB_ERRORS_ENUM:XQ,AUTHENTICATION_ERROR_MSGS:CC,VALIDATION_ERROR_MSGS:DC,ITC_ERRORS:PC}});var _e=N((Hge,vC)=>{"use strict";var wl=Dn(),c2=W(),l2=M(),ah=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,MC),this.statusCode=n||wl.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(wl.DEFAULT_ERROR_MSGS[n]?wl.DEFAULT_ERROR_MSGS[n]:wl.DEFAULT_ERROR_MSGS[wl.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR]),this.message=t.message?t.message:this.http_resp_msg,this.type=t.name,s&&(this.logLevel=s),typeof this.message!="string"&&(this.stack=t.stack),i&&c2[s](i)}},pg=class extends Error{static{a(this,"ClientError")}constructor(t,r){if(t instanceof Error)return t.statusCode=r||400,t;super(t),this.statusCode=r||400}},mg=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function MC(e,t,r,n=l2.LOG_LEVELS.ERROR,s=null,i=!1){if(UC(e))return e;let o=new ah(e,t,r,n,s);return i&&delete o.stack,o}a(MC,"handleHDBError");function UC(e){return e.__proto__.constructor.name===ah.name}a(UC,"isHDBError");vC.exports={isHDBError:UC,handleHDBError:MC,ClientError:pg,ServerError:mg,hdb_errors:wl}});var Sg=N(BC=>{"use strict";var u2={cert:"-----BEGIN CERTIFICATE-----\rMIIDXDCCAkSgAwIBAgIFNTE4MzQwDQYJKoZIhvcNAQELBQAwXTEXMBUGA1UEAxMO\rSGFycGVyREIsIEluYy4xCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDTzEPMA0GA1UE\rBxMGRGVudmVyMRcwFQYDVQQKEw5IYXJwZXJEQiwgSW5jLjAeFw0yMjAzMTEyMzAz\rNDlaFw0yNzAzMTAyMzAzNDlaMF0xFzAVBgNVBAMTDkhhcnBlckRCLCBJbmMuMQsw\rCQYDVQQGEwJVUzELMAkGA1UECBMCQ08xDzANBgNVBAcTBkRlbnZlcjEXMBUGA1UE\rChMOSGFycGVyREIsIEluYy4wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB\rAQCsEUlBF8WImS78rCFXVKyntxfrW++4qZ3hGnoD2MHZAuDHyeP/5eGnaE9GQhKc\r4DwG4DGvh0wP2zIYnBfiQ3L2ZtnlDR9ZkKIQYGlVxTUn6T43krhK5nZKqDF43Yg3\rZEvO3cbJBjiKZx0eA2/toehdSsTAHHQx5gTDcggNe2tgoJHYPwi9YF/AxSBZrbgb\ryWlYgtYDmF32ytHP03GUCIdKOFuBPsHTGu4SkdEIdLIqO9oglW1YFH5qZ6NiwApW\rsP+GCuqOwDXXbdjr75iq9Tq/CDrjGFLaTPmvd2Q0qG/BtaCll0ghpG+yIHvt/iQs\rajS+LxEWAnVlGMaDdFErbDUtAgMBAAGjIzAhMA8GA1UdEwEB/wQFMAMBAf8wDgYD\rVR0PAQH/BAQDAgIEMA0GCSqGSIb3DQEBCwUAA4IBAQASR4YW/rPK7PNArHVe9zzM\rb0rKNX/2T9/0nybRhmE/+hdlSgliTAeebmwkUS2APckmekYt/q2ZY2NS65Fo/jjp\rG8TJrtcF4h+ylVqUp0ZXQLFtIsr7r2JZA7hJ6njW6G4DHSZ0gxtECLi4CBlTjzm5\rNmnmIDObvGRTuqmcdAZmXeObbta/He2XIzietukPAYX062pNM+G5XT5UM1eG/Vlp\rN86vjhpyI+ffKy+C60SJqxmKM3ydgN7oLscE7+2wLPN25XqN4W99OwGsp5dTdu/f\r5lPtFayXdJ55e/sNQKmGN+UGLrL05c2MWgjb8U/LFilnupUianceoeSERZmVjzKX\r-----END CERTIFICATE-----\r".replace(/\r/g,`\r
9
9
  `),key:"-----BEGIN RSA PRIVATE KEY-----\rMIIEowIBAAKCAQEArBFJQRfFiJku/KwhV1Ssp7cX61vvuKmd4Rp6A9jB2QLgx8nj\r/+Xhp2hPRkISnOA8BuAxr4dMD9syGJwX4kNy9mbZ5Q0fWZCiEGBpVcU1J+k+N5K4\rSuZ2SqgxeN2IN2RLzt3GyQY4imcdHgNv7aHoXUrEwBx0MeYEw3IIDXtrYKCR2D8I\rvWBfwMUgWa24G8lpWILWA5hd9srRz9NxlAiHSjhbgT7B0xruEpHRCHSyKjvaIJVt\rWBR+amejYsAKVrD/hgrqjsA1123Y6++YqvU6vwg64xhS2kz5r3dkNKhvwbWgpZdI\rIaRvsiB77f4kLGo0vi8RFgJ1ZRjGg3RRK2w1LQIDAQABAoIBAQCEOmh78EOpnGZC\rYBjjHrvrysVD5gvLcfVUtl8Ls7gMB60re1eOIF+PoZZCHKZnDd6zPfiQtj1adg0C\rYnnsM/8VoaZS4gm0b3RLd3ubIQifWhuo40RissY2yxfxlPSH9LhZCY8ojnJG0cTL\resK579E8WCfopjUY33XLqEbN7Ylv39J+DSqInjqV3efJZUa+HqUJ98VxxzodcKMD\rP3bwUU4gHoSSp4pAsOFH5sQhaIWH1IcNjrAwpee2cJQuh4G157RRIuuUpagtaEG/\rXJIiAyBguJyu3JQFnIBQF01N5+omJgXYJ1L0m54543/iIRThmF3zDCDgCyUzmOk+\rH6As9fv1AoGBANOpOtOZLSAScjGsgJamT3ceJ2wCa86g2j8Oxu8lJUmUp5s3tA0v\rBFW5O3S4KR1EXwkLMBUMrfFM8YvzHWxsXBI6XV8azGLvyqPHxr65OhmpGYkGZMXu\rn9okgjkqlewnY2I073gvyK7ppX51UL5y9fF1vlsk+UlW+Rgx/vMHbdcjAoGBANAc\rxRUsxs4QJpbS4zD3JOkHjr24a97TrS3kCybAHUMpR2NrEHPZw9zex0/aphOJUHfL\rIMkOZdpfDqMfxWy4FAEmqBEMkO2SB+h0Wp4P+qp81ax4vGFiB0cD3wtixr11U1tt\rlZ/ZTdv4VDpDFNK1KaplhTDeyuCjeYfS3/GJia9vAoGAcOsAgjBevZR5rXx84WH6\rVO8WUu37u7FenXNxt9VWTinrPMh72uixZFY8nOk+rely1e1NCn3IMko9Ns9NbDFm\r8SaH95vhXArXTYbfxZIlp9jp0YtCqcHDL+p4Oq04bFMbFyJseu7rHj1x18QYfnHw\rOY/6LL/N6k1m+Hx7qgXVmIcCgYB/w0nTCBw84XlvWqSTqQaF8VfWbWP79mP5KmkW\rLxdH5g2noVEGbohqDnK6OXd/wusdwByukiJBf94Skyy25AOT+VFwthA7aU1ljhkb\rtJ+lDuJ28eBkwLPLCzthWBC+u0qjdJFJAzVjd/7tjcU43nNn4s90AzL12iaAFhvZ\rwyA+DQKBgGc/4cdyGJ3YkcA8150gQBawgJZ7q8V1JND87ggWA8wnK3cHn7rMZQl2\r3emDp9HEFXFex5dbGDDqZFAoesZCDxjknIn9oNfW4PvaWS8q7b6ZKLZG1p03Pu7/\rtYaD0kPbo0kysfFT/co+NgHbdykvIyboomfGdNLTUjYuy6lpwpvs\r-----END RSA PRIVATE KEY-----\r".replace(/\r/g,`\r
10
- `)},c2="certificate.pem",l2="privateKey.pem",u2="caCertificate.pem",d2="natsCertificate.pem",_2="natsCaCertificate.pem",At={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},f2={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"]},E2={[At.SERVER]:2,[At.DEFAULT]:1},h2={[At["OPERATIONS-API"]]:3,[At.SERVER]:2,[At.DEFAULT]:1},p2={[At["OPERATIONS-API"]]:3,[At.SERVER]:2,[At.DEFAULT]:1},m2={[At["OPERATIONS-CA"]]:3,[At.CA]:2,[At["DEFAULT-CA"]]:1},S2={[At["OPERATIONS-CA"]]:3,[At.CA]:2,[At["DEFAULT-CA"]]:1},T2={[At.CA]:2,[At["DEFAULT-CA"]]:1};Object.assign(vC,{CERTIFICATE_PEM_NAME:c2,PRIVATEKEY_PEM_NAME:l2,CA_PEM_NAME:u2,CERT_NAME:At,CERT_CONFIG_NAME_MAP:f2,CERT_PREFERENCE_APP:E2,CERT_PREFERENCE_OPS:h2,CERT_PREFERENCE_REP:p2,CA_CERT_PREFERENCE_REP:m2,CA_CERT_PREFERENCE_OPS:S2,CA_CERT_PREFERENCE_APP:T2,CERTIFICATE_VALUES:a2,NATS_CERTIFICATE_PEM_NAME:d2,NATS_CA_PEM_NAME:_2})});var Tt=N((Bge,BC)=>{"use strict";var nn=require("validate.js");nn.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||nn.validators.type.checks[t](e)?null:` must be a '${t}' value`};nn.validators.type.checks={Object:a(function(e){return nn.isObject(e)&&!nn.isArray(e)},"Object"),Array:nn.isArray,Integer:nn.isInteger,Number:nn.isNumber,String:nn.isString,Date:nn.isDate,Boolean:a(function(e){return typeof e=="boolean"},"Boolean")};nn.validators.hasValidFileExt=function(e,t){return nn.isString(e)?e===""?"can't be blank":t.filter(r=>e.endsWith(r)).length>0?null:`must include one of the following valid file extensions - '${t.join("', '")}'`:null};BC.exports={validateObject:g2,validateObjectAsync:R2,validateBySchema:A2};function g2(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=nn(e,t,{format:"flat"});return r?new Error(r):null}a(g2,"validateObject");async function R2(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await nn.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(R2,"validateObjectAsync");function A2(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(A2,"validateBySchema")});var gg=N((kge,qC)=>{"use strict";var FC=require("fs-extra"),me=require("joi"),y2=require("os"),{boolean:qe,string:It,number:tr,array:za}=me.types(),{totalmem:HC}=require("os"),ja=require("path"),b2=W(),Tg=te(),xge=Sg(),xC=M(),O2=Tt(),kC="log",N2="components",I2="Invalid logging.rotation.maxSize unit. Available units are G, M or K",w2="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",C2="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",D2="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",P2="rootPath config parameter is undefined",sn=me.alternatives([tr.min(0),It]).optional().empty(null),ch=me.alternatives([za.items(It,{host:It.required(),port:sn},{hostname:It.required(),port:sn}).empty(null),za.items(It)]),pi,GC=!1;qC.exports={configValidator:L2,routesValidator:x2,route_constraints:ch};function L2(e,t=!1){if(GC=t,pi=e.rootPath,Tg.isEmpty(pi))throw P2;let r=qe.optional(),n=tr.min(0).max(1e3).empty(null).default(H2),s=It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(Fd),i=It.optional().empty(null),o=It.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=me.string().empty(null).default(Fd),l=me.custom(U2).empty(null).default(Fd),u=e.clustering?.enabled,d=me.object({certificate:i,certificateAuthority:i,privateKey:i}),_;return u===!0?_=me.object({enabled:r,hubServer:me.object({cluster:me.object({name:me.required().empty(null),network:me.object({port:sn,routes:ch}).required()}).required(),leafNodes:me.object({network:me.object({port:sn}).required()}).required(),network:me.object({port:sn}).required()}).required(),leafServer:me.object({network:me.object({port:sn,routes:ch}).required(),streams:me.object({maxAge:tr.min(120).allow(null).optional(),maxBytes:tr.min(1).allow(null).optional(),maxMsgs:tr.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:me.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:qe.optional(),databaseLevel:qe.optional(),tls:me.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:qe.required(),verify:qe.optional()}),user:It.optional().empty(null)}).optional():_=me.object({enabled:r,tls:me.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:qe.optional()})}).optional(),me.object({authentication:me.alternatives(me.object({authorizeLocal:qe,cacheTTL:tr.required(),enableSessions:qe}),qe).optional(),analytics:me.object({aggregatePeriod:tr}),replication:me.object({hostname:me.alternatives(It,tr).optional().empty(null),url:It.optional().empty(null),port:sn,securePort:sn,routes:za.optional().empty(null),databases:me.alternatives(It,za),enableRootCAs:qe.optional()}).optional(),componentsRoot:s.optional(),clustering:_,localStudio:me.object({enabled:r}).required(),logging:me.object({auditAuthEvents:me.object({logFailed:qe,logSuccessful:qe}),file:qe.required(),level:me.valid("notify","fatal","error","warn","info","debug","trace"),rotation:me.object({enabled:qe.optional(),compress:qe.optional(),interval:It.custom(B2).optional().empty(null),maxSize:It.custom(v2).optional().empty(null),path:It.optional().empty(null).default(Fd)}).required(),root:s,stdStreams:qe.required(),auditLog:qe.required()}).required(),operationsApi:me.object({network:me.object({cors:qe.optional(),corsAccessList:za.optional(),headersTimeout:tr.min(1).optional(),keepAliveTimeout:tr.min(1).optional(),port:sn,domainSocket:me.optional().empty("hdb/operations-server").default(Fd),securePort:sn,timeout:tr.min(1).optional()}).optional(),tls:me.alternatives([me.array().items(d),d])}).required(),rootPath:It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:me.object({network:me.object({port:sn,securePort:sn,mtls:me.alternatives([qe.optional(),me.object({user:It.optional(),certificateAuthority:i,required:qe.optional()})])}).required(),webSocket:qe.optional(),requireAuthentication:qe.optional()}),http:me.object({compressionThreshold:tr.optional(),cors:qe.optional(),corsAccessList:za.optional(),headersTimeout:tr.min(1).optional(),port:sn,securePort:sn,maxHeaderSize:tr.optional(),mtls:me.alternatives([qe.optional(),me.object({user:It.optional(),certificateAuthority:i,required:qe.optional()})]),threadRange:me.alternatives([za.optional(),It.optional()])}).required(),threads:me.alternatives(n.optional(),me.object({count:n.optional(),debug:me.alternatives(qe.optional(),me.object({startingPort:tr.min(1).optional(),host:It.optional(),waitForDebugger:qe.optional()})),maxHeapMemory:tr.min(0).optional()})),storage:me.object({writeAsync:qe.required(),overlappingSync:qe.optional(),caching:qe.optional(),compression:me.alternatives([qe.optional(),me.object({dictionary:It.optional(),threshold:tr.optional()})]),compactOnStart:qe.optional(),compactOnStartKeepBackup:qe.optional(),noReadAhead:qe.optional(),path:l,prefetchWrites:qe.optional(),maxFreeSpaceToLoad:tr.optional(),maxFreeSpaceToRetain:tr.optional()}).required(),ignoreScripts:qe.optional(),tls:me.alternatives([me.array().items(d),d])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(L2,"configValidator");function M2(e){return GC||FC.existsSync(e)?null:`Specified path ${e} does not exist.`}a(M2,"doesPathExist");function U2(e,t){me.assert(e,It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=M2(e);if(r)return t.message(r)}a(U2,"validatePath");function v2(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(I2);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(C2):e}a(v2,"validateRotationMaxSize");function B2(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(w2);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(D2):e}a(B2,"validateRotationInterval");function H2(e,t){let r=t.state.path.join("."),n=y2.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||HC();return i=Math.round(Math.min(i,HC())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),b2.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(H2,"setDefaultThreads");function Fd(e,t){let r=t.state.path.join(".");if(!Tg.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(Tg.isEmpty(pi))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return ja.join(pi,N2);case"logging.root":return ja.join(pi,kC);case"clustering.leafServer.streams.path":return ja.join(pi,"clustering","leaf");case"storage.path":let n=ja.join(pi,xC.LEGACY_DATABASES_DIR_NAME);return FC.existsSync(n)?n:ja.join(pi,xC.DATABASES_DIR_NAME);case"logging.rotation.path":return ja.join(pi,kC);case"operationsApi.network.domainSocket":return r==null?null:ja.join(pi,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(Fd,"setDefaultRoot");function x2(e){let t=me.object({routes:ch});return O2.validateBySchema({routes:e},t)}a(x2,"routesValidator")});var Qa={};je(Qa,{server:()=>it});var $C,it,qr=Oe(()=>{$C=L(fi()),it={};(0,$C._assignPackageExport)("server",it)});var wt=N(ZC=>{"use strict";var on=M(),Er=te(),hr=W(),{configValidator:k2,routesValidator:VC}=gg(),$r=require("fs-extra"),YC=require("yaml"),Ln=require("path"),F2=require("is-number"),WC=require("properties-reader"),G2=require("lodash"),{handleHDBError:q2}=_e(),{HTTP_STATUS_CODES:$2,HDB_ERROR_MSGS:Nl}=Dn(),{server:V2}=(qr(),oe(Qa)),{DATABASES_PARAM_CONFIG:Gd,CONFIG_PARAMS:Pn,CONFIG_PARAM_MAP:ks}=on,K2="Unable to get config value because config is uninitialized",Y2="Config successfully initialized",W2="Error backing up config file",j2="Empty parameter sent to getConfigValue",jC=Ln.join(on.PACKAGE_ROOT,"config","yaml",on.HDB_DEFAULT_CONFIG_FILE),z2=Ln.join(on.PACKAGE_ROOT,"config","yaml","defaultNatsConfig.yaml"),Q2="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",KC={logging_rotation_retain:"logging.rotation.retain",logging_rotation_rotate:"logging.rotation.rotate",logging_rotation_rotateinterval:"logging.rotation.rotateInterval",logging_rotation_rotatemodule:"logging.rotation.rotateModule",logging_rotation_timezone:"logging.rotation.timezone",logging_rotation_workerinterval:"logging.rotation.workerInterval"},lh,jt,uh;Object.assign(ZC,{createConfigFile:J2,getDefaultConfig:X2,getConfigValue:QC,initConfig:dh,flattenConfig:Il,updateConfigValue:JC,updateConfigObject:e4,getConfiguration:n4,setConfiguration:s4,readConfigFile:bg,getClusteringRoutes:i4,initOldConfig:XC,getConfigFromFile:o4,getConfigFilePath:Ja,addConfig:a4,deleteConfigFromFile:c4,getConfigObj:l4,resolvePath:Rg,getFlatConfigObj:u4});function Rg(e){if(e?.startsWith("~/"))return Ln.join(Er.getHomeDir(),e.slice(1));let t=se();return Ln.resolve(t.getHdbBasePath(),e)}a(Rg,"resolvePath");function J2(e,t=!1){let r=Ko(jC);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=YC.parseDocument($r.readFileSync(z2,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}lh=Il(r.toJSON());let n;for(let c in e){let l=ks[c.toLowerCase()];if(l===Pn.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(u=>({[u]:e[c][u]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let u=l.split("_"),d=Ag(l,e[c]);l==="rootPath"&&d?.endsWith("/")&&(d=d.slice(0,-1));try{r.setIn([...u],d)}catch(_){hr.error(_)}}}n&&zC(r,n),yg(r,t);let s=r.toJSON();jt=Il(s);let i=r.getIn(["rootPath"]),o=Ln.join(i,on.HDB_CONFIG_FILE);$r.createFileSync(o),$r.writeFileSync(o,String(r)),hr.trace(`Config file written to ${o}`)}a(J2,"createConfigFile");function zC(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!Er.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(Gd.TABLES))for(let i in n[s][Gd.TABLES])for(let o in n[s][Gd.TABLES][i]){let c=n[s][Gd.TABLES][i][o],l=[Pn.DATABASES,s,Gd.TABLES,i,o];e.hasIn(l)?e.setIn(l,c):e.addIn(l,c)}else for(let i in n[s]){let o=n[s][i],c=[Pn.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){hr.error("Error parsing schemas CLI/env config arguments",n)}}a(zC,"setSchemasConfig");function X2(e){if(lh===void 0){let r=Ko(jC);lh=Il(r.toJSON())}let t=ks[e.toLowerCase()];if(t!==void 0)return lh[t.toLowerCase()]}a(X2,"getDefaultConfig");function QC(e){if(e==null){hr.info(j2);return}if(jt===void 0){hr.trace(K2);return}let t=ks[e.toLowerCase()];if(t!==void 0)return jt[t.toLowerCase()]}a(QC,"getConfigValue");function Ja(e=Er.getPropsFilePath()){let t=Er.getEnvCliRootPath();if(t)return Rg(Ln.join(t,on.HDB_CONFIG_FILE));let r=WC(e);return Rg(r.get(on.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(Ja,"getConfigFilePath");function dh(e=!1){if(jt===void 0||e){let t;if(!Er.noBootFile()){t=Er.getPropsFilePath();try{$r.accessSync(t,$r.constants.F_OK|$r.constants.R_OK)}catch(i){throw hr.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Ja(t),n;if(r.includes("config/settings.js"))try{XC(r);return}catch(i){if(i.code!==on.NODE_ERROR_CODES.ENOENT)throw i}try{n=Ko(r)}catch(i){if(i.code===on.NODE_ERROR_CODES.ENOENT){hr.trace(`HarperDB config file not found at ${r}.
11
- This can occur during early stages of install where the config file has not yet been created`);return}else throw hr.error(i),new Error(`Error reading HarperDB config file at ${r}`)}Z2(n,r),yg(n);let s=n.toJSON();if(V2.config=s,jt=Il(s),jt.logging_rotation_rotate)for(let i in KC)jt[i]&&hr.error(`Config ${KC[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);hr.trace(Y2)}}a(dh,"initConfig");function Z2(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Ln.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Ln.join(r,"log")),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n&&(hr.trace("Updating config file with missing config params"),$r.writeFileSync(t,String(e)))}a(Z2,"checkForUpdatedConfig");function yg(e,t=!1){let r=e.toJSON();if(r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads),r.http?.port&&r.http?.port===r.http?.securePort)throw Nl.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 Nl.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=k2(r,t);if(n.error)throw Nl.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket),r?.clustering?.enabled&&e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path)}a(yg,"validateConfig");function e4(e,t){jt===void 0&&(jt={});let r=ks[e.toLowerCase()];if(r===void 0){hr.trace(`Unable to update config object because config param '${e}' does not exist`);return}jt[r.toLowerCase()]=t}a(e4,"updateConfigObject");function JC(e,t,r=void 0,n=!1,s=!1,i=!1){jt===void 0&&dh();let o=QC(ks.hdb_root),c=Ln.join(o,on.HDB_CONFIG_FILE),l=Ko(c),u;if(r===void 0&&e.toLowerCase()===Pn.DATABASES)u=t;else if(r===void 0){let E;if(i)E=e;else if(E=ks[e.toLowerCase()],E===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let f=E.split("_"),h=Ag(E,t);l.setIn([...f],h)}else for(let E in r){let f=ks[E.toLowerCase()];if(f===Pn.HTTP_SECUREPORT&&r[E]===jt[Pn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),f===Pn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===jt[Pn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),f===Pn.DATABASES){u=r[E];continue}if(f?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!f&&(E.endsWith("_package")||E.endsWith("_port"))&&(f=E),f!==void 0){let h=f.split("_"),T=on.LEGACY_CONFIG_PARAMS[E.toUpperCase()];T&&T.startsWith("customFunctions")&&l.hasIn(T.split("_"))&&(f=T,h=T.split("_"));let m=Ag(f,r[E]);f==="rootPath"&&m?.endsWith("/")&&(m=m.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],m)}catch(g){hr.error(g)}}}u&&zC(l,u),yg(l);let d=l.getIn(["rootPath"]),_=Ln.join(d,on.HDB_CONFIG_FILE);n===!0&&t4(c,d),$r.writeFileSync(_,String(l)),s&&(jt=Il(l.toJSON())),hr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(JC,"updateConfigValue");function t4(e,t){try{let r=Ln.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${on.HDB_CONFIG_FILE}.bak`);$r.copySync(e,r),hr.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){hr.error(W2),hr.error(r)}}a(t4,"backupConfigFile");var r4=["databases"];function Il(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network={...e.http,...e.operationsApi.network}),e?.operationsApi&&(e.operationsApi.tls={...e.tls,...e.operationsApi.tls}),uh=e,r(e);function r(n){let s={};for(let i in n)if(n.hasOwnProperty(i)){if(typeof n[i]=="object"&&n[i]!==null&&!Array.isArray(n[i])&&!r4.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!Pn[l.toUpperCase()]&&ks[l]&&(s[ks[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Il,"flattenConfig");function Ag(e,t){if(e===Pn.CLUSTERING_NODENAME||e===Pn.CLUSTERING_USER){if(t==null)return t;if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if(F2(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Er.isObject(t)||t===null)return t;if(typeof t=="string"&&t.toLowerCase()==="true")return!0;if(typeof t=="string"&&t.toLowerCase()==="false")return!1}if(t===void 0||t.toLowerCase()==="undefined")return null;if(typeof t=="string"&&(t.startsWith("{")&&t.endsWith("}")||t.startsWith("[")&&t.endsWith("]")))try{return JSON.parse(t)}catch{}return Er.autoCast(t)}a(Ag,"castConfigValue");function n4(){let e=Er.getPropsFilePath(),t=Ja(e);return Ko(t).toJSON()}a(n4,"getConfiguration");async function s4(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return JC(void 0,void 0,s,!0),Q2}catch(i){throw typeof i=="string"||i instanceof String?q2(i,i,$2.BAD_REQUEST,void 0,void 0,!0):i}}a(s4,"setConfiguration");function bg(){let e=Er.getPropsFilePath();try{$r.accessSync(e,$r.constants.F_OK|$r.constants.R_OK)}catch(n){if(!Er.noBootFile())throw hr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Ja(e);return Ko(t).toJSON()}a(bg,"readConfigFile");function Ko(e){return YC.parseDocument($r.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Ko,"parseYamlDoc");function i4(){let e=bg(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Er.isEmptyOrZeroLength(t)?[]:t;let r=VC(t);if(r)throw Nl.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Er.isEmptyOrZeroLength(n)?[]:n;let s=VC(n);if(s)throw Nl.CONFIG_VALIDATION(s.message);if(!Er.isEmptyOrZeroLength(n)&&!Er.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Er.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw Nl.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(i4,"getClusteringRoutes");function XC(e){let t=WC(e);jt={};for(let r in ks){let n=t.get(r.toUpperCase());if(Er.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=ks[r].toLowerCase();s===Pn.LOGGING_ROOT?jt[s]=Ln.dirname(n):jt[s]=n}return jt}a(XC,"initOldConfig");function o4(e){let t=bg();return G2.get(t,e.replaceAll("_","."))}a(o4,"getConfigFromFile");async function a4(e,t){let r=Ko(Ja());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await $r.writeFile(Ja(),String(r))}a(a4,"addConfig");function c4(e){let t=Ja(Er.getPropsFilePath()),r=Ko(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Ln.join(n,on.HDB_CONFIG_FILE);$r.writeFileSync(s,String(r))}a(c4,"deleteConfigFromFile");function l4(){return uh||(dh(),uh)}a(l4,"getConfigObj");function u4(){return jt||dh(),jt}a(u4,"getFlatConfigObj")});var se=N((sD,iD)=>{"use strict";var Og=require("fs-extra"),Xa=require("path"),eD=require("os"),d4=require("properties-reader"),$d=W(),qd=te(),De=M(),_h=wt(),_4="Error initializing environment manager",fh="BOOT_PROPS_FILE_PATH",tD=!1,f4={[De.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},Qi={};Object.assign(sD,iD.exports={BOOT_PROPS_FILE_PATH:fh,getHdbBasePath:E4,setHdbBasePath:h4,get:rD,initSync:m4,setProperty:Qe,initTestEnvironment:T4,setCloneVar:S4});function E4(){return Qi[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(E4,"getHdbBasePath");function h4(e){Qi[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(h4,"setHdbBasePath");function rD(e){let t=_h.getConfigValue(e);return t===void 0?Qi[e]:t}a(rD,"get");function Qe(e,t){f4[e]&&(Qi[e]=t),_h.updateConfigObject(e,t)}a(Qe,"setProperty");function p4(){let e;try{e=qd.getPropsFilePath(),Og.accessSync(e,Og.constants.F_OK|Og.constants.R_OK),tD=!0;let t=d4(e);return Qi[De.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(De.HDB_SETTINGS_NAMES.INSTALL_USER),Qi[De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),Qi[fh]=e,!0}catch{return $d.trace(`Environment manager found no properties file at ${e}`),!1}}a(p4,"doesPropFileExist");function m4(e=!1){try{((tD||p4()||qd.noBootFile())&&!nD||e)&&(_h.initConfig(e),Qi[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=_h.getConfigValue(De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){$d.error(_4),$d.error(t),console.error(t),process.exit(1)}}a(m4,"initSync");var nD=!1;function S4(e){nD=e}a(S4,"setCloneVar");function T4(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:n,https_enabled:s,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,l=Xa.join(__dirname,"../../","unitTests");Qi[fh]=Xa.join(l,"hdb_boot_properties.file"),Qe(De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Xa.join(l,"settings.test")),Qe(De.HDB_SETTINGS_NAMES.INSTALL_USER,eD.userInfo()?eD.userInfo().username:void 0),Qe(De.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Qe(De.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Xa.join(l,"envDir","log")),Qe(De.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Qe(De.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Qe(De.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Qe(De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Xa.join(l,"envDir")),Qe(De.CONFIG_PARAMS.STORAGE_PATH,Xa.join(l,"envDir")),s&&(Qe(De.CONFIG_PARAMS.HTTP_SECUREPORT,rD(De.CONFIG_PARAMS.HTTP_PORT)),Qe(De.CONFIG_PARAMS.HTTP_PORT,null)),Qe(De.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Qe(De.CONFIG_PARAMS.HTTP_PORT,9926),Qe(De.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Qe(De.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),Qe(De.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,qd.isEmpty(i)?!1:i),Qe(De.CONFIG_PARAMS.HTTP_CORS,qd.isEmpty(i)?!1:i),Qe(De.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Qe(De.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Qe(De.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Qe(De.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Qe(De.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Xa.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Qe(De.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,qd.isEmpty(c)?!1:c),o&&(Qe("CORS_ACCESSLIST",o),Qe(De.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Qe(De.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Qe(De.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Qe(De.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Qe(De.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Qe(De.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Qe(De.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${fh}. Please check your boot props and settings files`;$d.fatal(r),$d.error(t)}}a(T4,"initTestEnvironment")});var gt=N((Vge,_D)=>{"use strict";var jd=M(),g4=te(),an=se(),zd=require("path"),R4=require("minimist"),oD=require("fs-extra"),aD=require("lodash");an.initSync();var{CONFIG_PARAMS:Yo,DATABASES_PARAM_CONFIG:Vd,SYSTEM_SCHEMA_NAME:Eh}=jd,Kd,Yd,Wd;function cD(){if(Kd!==void 0)return Kd;if(an.getHdbBasePath()!==void 0)return Kd=an.get(Yo.STORAGE_PATH)||zd.join(an.getHdbBasePath(),jd.DATABASES_DIR_NAME),Kd}a(cD,"getBaseSchemaPath");function lD(){if(Yd!==void 0)return Yd;if(an.getHdbBasePath()!==void 0)return Yd=dD(Eh),Yd}a(lD,"getSystemSchemaPath");function uD(){if(Wd!==void 0)return Wd;if(an.getHdbBasePath()!==void 0)return Wd=an.get(jd.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||zd.join(an.getHdbBasePath(),jd.TRANSACTIONS_DIR_NAME),Wd}a(uD,"getTransactionAuditStoreBasePath");function A4(e,t){let r=an.get(Yo.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||zd.join(uD(),e.toString())}a(A4,"getTransactionAuditStorePath");function dD(e,t){e=e.toString(),t=t&&t.toString();let r=an.get(jd.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||zd.join(cD(),e)}a(dD,"getSchemaPath");function y4(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,R4(process.argv));let n=r[Yo.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!g4.isObject(n))throw o;i=n}for(let o of i){let c=o[Eh];if(!c)continue;let l=an.get(Yo.DATABASES);l=l??{};let u=c?.tables?.[t]?.[Vd.PATH];if(u)return aD.set(l,[Eh,Vd.TABLES,t,Vd.PATH],u),an.setProperty(Yo.DATABASES,l),u;let d=c?.[Vd.PATH];if(d)return aD.set(l,[Eh,Vd.PATH],d),an.setProperty(Yo.DATABASES,l),d}}let s=r[Yo.STORAGE_PATH.toUpperCase()];if(s){if(!oD.pathExistsSync(s))throw new Error(s+" does not exist");let i=zd.join(s,e);return oD.mkdirsSync(i),an.setProperty(Yo.STORAGE_PATH,s),i}return lD()}a(y4,"initSystemSchemaPaths");function b4(){Kd=void 0,Yd=void 0,Wd=void 0}a(b4,"resetPaths");_D.exports={getBaseSchemaPath:cD,getSystemSchemaPath:lD,getTransactionAuditStorePath:A4,getTransactionAuditStoreBasePath:uD,getSchemaPath:dD,initSystemSchemaPaths:y4,resetPaths:b4}});var cn=N((jge,mD)=>{"use strict";var O4=Dn().LMDB_ERRORS_ENUM,Yge=require("lmdb"),N4=Bt(),Wge=require("buffer").Buffer,{OVERFLOW_MARKER:fD,MAX_SEARCH_KEY_LENGTH:hh}=N4,ED=["number","string","symbol","boolean","bigint"];function I4(e){if(e=e?.primaryStore||e,!e)throw new Error(O4.ENV_REQUIRED)}a(I4,"validateEnv");function w4(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(w4,"stringifyData");function C4(e){return e instanceof Date?e.valueOf():e}a(C4,"convertKeyValueToWrite");function D4(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(ED.includes(typeof e))return e.length>hh?[e.slice(0,hh)+fD]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(ED.includes(typeof i))i.length>hh?r.push(i.slice(0,hh)+fD):r.push(i);else{if(i===null&&t)return r.push(null);if(i instanceof Date)return r.push(i.getTime())}}}else if(e instanceof Date)return[e.getTime()];return r}a(D4,"getIndexedValues");var ph=0,hD=0;function pD(){hD=Date.now()-performance.now()}a(pD,"adjustStartTime");pD();var P4=6e4;setInterval(pD,P4).unref();function L4(){let e=performance.now()+hD;return e>ph?(ph=e,e):(ph+=488e-6,ph)}a(L4,"getNextMonotonicTime");mD.exports={validateEnv:I4,stringifyData:w4,convertKeyValueToWrite:C4,getNextMonotonicTime:L4,getIndexedValues:D4}});var Qd=N((Qge,SD)=>{"use strict";var M4=M().OPERATIONS_ENUM,Ng=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=M4.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};SD.exports=Ng});var Jd=N((Zge,AD)=>{"use strict";var Xge=Qd(),mh=M(),Ig=te(),TD=W(),U4=require("uuid"),{handleHDBError:Sh,hdb_errors:v4}=_e(),{HDB_ERROR_MSGS:Th,HTTP_STATUS_CODES:gh}=v4;AD.exports=gD;function gD(e,t,r){for(let s=0;s<t.length;s++)RD(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];B4(i,r,e.operation)}}a(gD,"processRows");gD.validateAttribute=RD;function RD(e){if(Buffer.byteLength(String(e))>mh.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw Sh(new Error,Th.ATTR_NAME_LENGTH_ERR(e),gh.BAD_REQUEST,void 0,void 0,!0);if(Ig.isEmptyOrZeroLength(e)||Ig.isEmpty(e.trim()))throw Sh(new Error,Th.ATTR_NAME_NULLISH_ERR,gh.BAD_REQUEST,void 0,void 0,!0)}a(RD,"validateAttribute");function B4(e,t,r){if(!e.hasOwnProperty(t)||Ig.isEmptyOrZeroLength(e[t])){if(r===mh.OPERATIONS_ENUM.INSERT||r===mh.OPERATIONS_ENUM.UPSERT){e[t]=U4.v4();return}throw TD.error("Update transaction aborted due to record with no hash value:",e),Sh(new Error,Th.RECORD_MISSING_HASH_ERR,gh.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>mh.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw TD.error(e),Sh(new Error,Th.HASH_VAL_LENGTH_ERR,gh.BAD_REQUEST,void 0,void 0,!0)}a(B4,"validateHash")});var yD,Mn,wg,wl=Oe(()=>{yD=require("events"),Mn=class extends yD.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new wg;return t.queue=this,t}push(t){this.send(t)}send(t){this.resolveNext?(this.resolveNext({value:t}),this.resolveNext=null):this.hasDataListeners?this.emit("data",t):(this.queue||(this.queue=[]),this.queue.push(t))}getNextMessage(){let t=this.queue?.shift();return t||this.emit("drained"),t}waitForDrain(){return new Promise(t=>{!this.queue||this.queue.length===0?t(!0):(this.once("drained",()=>t(!0)),this.currentDrainResolver=t,this.drainCloseListener||(this.drainCloseListener=!0,this.on("close",()=>{this.currentDrainResolver?.(!1)})))})}on(t,r){if(t==="data"&&!this.hasDataListeners)for(this.hasDataListeners=!0;this.queue?.length>0;)r(this.queue.shift());return super.on(t,r)}},wg=class{static{a(this,"EventQueueIterator")}queue;push(t){this.queue.send(t)}next(){let t=this.queue.getNextMessage();return t?{value:t}:new Promise(r=>this.queue.resolveNext=r)}return(t){return this.queue.emit("close"),{value:t,done:!0}}throw(t){return this.queue.emit("close",t),{done:!0}}}});var Pg={};je(Pg,{loadGQLSchema:()=>k4,start:()=>Dg,startOnMainThread:()=>x4});function Dg({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:u,StringValueNode:d}=await import("graphql"),_=o(new c(r.toString(),s)),E=new Map,f=[],h;for(let g of _.definitions)switch(g.kind){case l.OBJECT_TYPE_DEFINITION:let H=function(Y){if(Y.kind==="NonNullType"){let Q=H(Y.type);return Q.nullable=!1,Q}if(Y.kind==="ListType")return{type:"array",elements:H(Y.type)};let ne={type:Y.name?.value};return Object.defineProperty(ne,"location",{value:Y.loc.startToken}),ne};a(H,"getProperty");let S=g.name.value,b=[],I={table:null,database:null,properties:b};E.set(S,I);for(let Y of g.directives){if(Y.name.value==="table"){for(let ne of Y.arguments)I[ne.name.value]=ne.value.value;I.schema&&(I.database=I.schema),I.table||(I.table=S),I.audit&&(I.audit=I.audit!=="false"),I.attributes=I.properties,f.push(I)}if(Y.name.value==="sealed"&&(I.sealed=!0),Y.name.value==="splitSegments"&&(I.splitSegments=!0),Y.name.value==="replicate"&&(I.replicate=!0),Y.name.value==="export"){I.export=!0;for(let ne of Y.arguments)typeof I.export!="object"&&(I.export={}),I.export[ne.name.value]=ne.value.value}}let B=!1,X={};for(let Y of g.fields){let V=H(Y.type);V.name=Y.name.value,b.push(V),X[V.name]=void 0;for(let ne of Y.directives){let Q=ne.name.value;if(Q==="primaryKey")B?console.warn("Can not define two attributes as a primary key at",ne.loc):(V.isPrimaryKey=!0,B=!0);else if(Q==="indexed")V.indexed=!0;else if(Q==="computed"){for(let de of ne.arguments||[])if(de.name.value==="from"){let j=de.value.value;V.computed={from:m(j,de,X)},V.version==null&&(V.version=j)}else de.name.value==="version"&&(V.version=de.value.value);V.computed=V.computed||!0}else if(Q==="relationship"){let de={};for(let j of ne.arguments)de[j.name.value]=j.value.value;V.relationship=de}else if(Q==="createdTime")V.assignCreatedTime=!0;else if(Q==="updatedTime")V.assignUpdatedTime=!0;else if(Q==="expiresAt")V.expiresAt=!0;else if(Q==="allow"){let de=V.authorizedRoles=[];for(let j of ne.arguments)j.name.value==="role"&&de.push(j.value.value)}else server.knownGraphQLDirectives.includes(Q)&&console.warn(`@${Q} is an unknown directive, at`,ne.loc)}}I.type=S,S==="Query"&&(h=I)}function T(g){let S=E.get(g.type);S?(Object.defineProperty(g,"properties",{value:S.properties}),Object.defineProperty(g,"definition",{value:S})):g.type==="array"?T(g.elements):H4.includes(g.type)||(0,OD.getWorkerIndex)()===0&&console.error(`The type ${g.type} is unknown at line ${g.location.line}, column ${g.location.column}, in ${s}`)}a(T,"connectPropertyType");for(let g of E.values())for(let S of g.properties)T(S);for(let g of f)g.tableClass=e(g),g.export&&(g.export.name===""?i.set((0,Cg.dirname)(n),g.tableClass):i.set((0,Cg.dirname)(n)+"/"+(g.export.name||g.type),g.tableClass,g.export));function m(g,S,b){return new bD.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${g}; } } } } computed;`,{filename:s,lineOffset:S.loc.startToken.line-1,columnOffset:S.loc.startToken.column}).runInThisContext()(b)}a(m,"createComputedFrom")}}var Cg,bD,OD,H4,x4,k4,ND=Oe(()=>{Cg=require("path"),bD=require("node:vm");Pe();OD=L(dt()),H4=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];server.knownGraphQLDirectives&&(server.knownGraphQLDirectives=["table","sealed","export","primaryKey","indexed","computed","relationship","createdTime","updatedTime","expiresAt","allow"]);a(Dg,"start");x4=Dg,k4=Dg({ensureTable:Et}).handleFile});var MD={};je(MD,{parse:()=>Mg,streamAsJSON:()=>Xd,stringify:()=>Za});function Xd(e){return new Lg({value:e})}function ID(e){return console.error(e),JSON.stringify(e.toString())}function wD(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Za(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===PD)return LD(e);if(t.resolution)return t.resolution.then(()=>Za(e));throw t}}function LD(e){let t=typeof e;if(t==="object"){if(e===null)return"null";e.toJSON&&(e=e.toJSON());let r;if(Array.isArray(e)){r="[";for(let n=0;n<e.length;n++)n>0&&(r+=","),r+=LD(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Za(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function Mg(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),q4.test(e)?F4.parse(e):JSON.parse(e)):null}var CD,DD,F4,G4,PD,Lg,q4,Ug=Oe(()=>{CD=require("stream"),DD=L(require("json-bigint-fixes")),F4=(0,DD.default)({useNativeBigInt:!0}),G4=1e4,PD={message:"Cannot serialize BigInt to JSON"};BigInt.prototype.toJSON=function(){throw PD};a(Xd,"streamAsJSON");Lg=class extends CD.Readable{static{a(this,"JSONStream")}constructor(t){super(t),this.buffer=[],this.bufferSize=0,this.iterator=this.serialize(t.value,!0),this.activeIterators=[]}*serialize(t){if(t&&typeof t=="object"){let r=t[Symbol.asyncIterator],n=t[Symbol.iterator];if((n||r)&&!t.then){yield"[";let s=!0;if((r||n)&&!(t instanceof Array)){let i=r?t[Symbol.asyncIterator]():t[Symbol.iterator]();this.activeIterators.push(i);let o;for(;;){try{o=i.next(),o.then&&(yield o.then(c=>(o=c,""),c=>(o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")},"")))}catch(c){o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")}}if(o.done){this.activeIterators.splice(this.activeIterators.indexOf(i),1),yield"]";return}else s?s=!1:yield",",yield*this.serialize(o.value)}}for(let i of t)s?s=!1:yield",",yield*this.serialize(i);yield"]";return}if(t.then)try{yield t.then(s=>this.serialize(s),ID)}catch(s){yield ID(s)}else yield Za(t)}else yield Za(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);wD(this.readIterator(this.iterator),t=>{t?(this.done=!0,this.push(null)):this._amReading=!1},t=>{console.error(t),this.done=!0,this.push(t.toString()),this.push(null)})}}push(t){return t===null||t instanceof Buffer?(this.bufferSize>0&&this.flush(),super.push(t)):(this.bufferSize+=t.length||t.toString().length,this.buffer.push(t),this.bufferSize>G4?this.flush():!0)}flush(){let t=super.push(this.buffer.join(""));return this.buffer=[],this.bufferSize=0,t}readIterator(t){try{let r;if(t.childIterator)return wD(this.readIterator(t.childIterator),n=>{if(n)return t.childIterator=null,this.readIterator(t)});do{let n=t.next();if(n.done)return!0;if(r=n.value,r==null)r="null";else{if(r.then)return this.flush(),Promise.resolve(r).then(s=>{if(s&&typeof s.return=="function")return t.childIterator=s,this.readIterator(t);if(this.push(s+""))return this.readIterator(t)});if(typeof r.return=="function")return t.childIterator=r,this.readIterator(t)}}while(this.push(r))}catch(r){return console.error(r),this.push(r.toString()),this.push(null),!0}}_destroy(t,r){for(let n of this.activeIterators)t?n.throw(t):n.return();r()}};a(ID,"handleError");a(wD,"when");a(Za,"stringify");a(LD,"jsStringify");q4=/[[,:]\s*-?\d{16,}/;a(Mg,"parse")});var YD=N((aRe,KD)=>{"use strict";var vg=require("recursive-iterator"),$4=require("alasql"),Bg=require("clone"),UD=te(),{handleHDBError:vD,hdb_errors:V4}=_e(),{HDB_ERROR_MSGS:BD,HTTP_STATUS_CODES:HD}=V4,{getDatabases:K4}=(Pe(),oe(lt)),Y4=["DISTINCT_ARRAY"],xD=Symbol("validateTables"),Hg=Symbol("validateTable"),oRe=Symbol("getAllColumns"),kD=Symbol("validateAllColumns"),Rh=Symbol("findColumn"),FD=Symbol("validateOrderBy"),Zd=Symbol("validateSegment"),xg=Symbol("validateColumn"),GD=Symbol("setColumnsForTable"),qD=Symbol("checkColumnsForAsterisk"),$D=Symbol("validateGroupBy"),VD=Symbol("hasColumns"),kg=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[xD](),this[qD](),this[kD]()}[xD](){if(this[VD]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[Hg](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[Hg](t.table)})}}[VD](){let t=!1,r=new vg(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[Hg](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=K4();if(!r[t.databaseid])throw vD(new Error,BD.SCHEMA_NOT_FOUND(t.databaseid),HD.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw vD(new Error,BD.TABLE_NOT_FOUND(t.databaseid,t.tableid),HD.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=Bg(s);i.table=Bg(t),this.attributes.push(i)})}[Rh](t){return this.attributes.filter(r=>t.tableid?(r.table.as===t.tableid||r.table.tableid===t.tableid)&&r.attribute===t.columnid:r.attribute===t.columnid)}[qD](){let t=new vg(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[GD](r.tableid)}[GD](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new $4.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[kD](){this[Zd](this.statement.columns,!1),this[Zd](this.statement.joins,!1),this[Zd](this.statement.where,!1),this[$D](this.statement.group,!1),this[Zd](this.statement.order,!0)}[Zd](t,r){if(!t)return;let n=new vg(t),s=[];for(let{node:i,path:o}of n)!UD.isEmpty(i)&&!UD.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[FD](i):s.push(this[xg](i)));return s}[$D](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&Y4.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=Bg(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[Rh](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[Rh](n);if(!i||i.length===0)throw`unknown column '${n.toString()}' in group by`;if(i.length>1)throw`ambiguously defined column '${n.toString()}' in group by`;r.forEach((o,c)=>{if(o.attribute===i[0].attribute&&o.table.tableid===i[0].table.tableid){s=o,r.splice(c,1);return}})}if(!s)throw`group by column '${n.toString()}' must be in select`}),r.length>0)throw`select column '${r[0].attribute?r[0].attribute:r[0].toString()}' must be in group by`}[FD](t){let r=this.statement.columns.filter(n=>n.as===t.columnid);if(r.length>1)throw`ambiguous column reference ${(t.tableid?t.tableid+".":"")+t.columnid} in order by`;r.length===0&&this[xg](t)}[xg](t){let r=this[Rh](t),n=(t.tableid?t.tableid+".":"")+t.columnid;if(r.length===0)throw`unknown column ${n}`;if(r.length>1)throw`ambiguous column reference ${n}`;return r[0]}};KD.exports=kg});var jD=N((lRe,WD)=>{"use strict";var Fg=class{static{a(this,"BridgeMethods")}createSchema(){throw new Error("createSchema bridge method is not defined")}dropSchema(){throw new Error("dropSchema bridge method is not defined")}createTable(){throw new Error("createTable bridge method is not defined")}dropTable(){throw new Error("dropTable bridge method is not defined")}createRecords(){throw new Error("createRecords bridge method is not defined")}updateRecords(){throw new Error("updateRecords bridge method is not defined")}async upsertRecords(){throw new Error("upsertRecords bridge method is not defined")}deleteRecords(){throw new Error("deleteRecords bridge method is not defined")}createAttribute(){throw new Error("createAttribute bridge method is not defined")}dropAttribute(){throw new Error("dropAttribute bridge method is not defined")}searchByConditions(){throw new Error("searchByConditions bridge method is not defined")}searchByHash(){throw new Error("searchByHash bridge method is not defined")}searchByValue(){throw new Error("searchByValue bridge method is not defined")}getDataByHash(){throw new Error("getDataByHash bridge method is not defined")}getDataByValue(){throw new Error("getDataByValue bridge method is not defined")}deleteRecordsBefore(){throw new Error("deleteRecordsBefore bridge method is not defined")}deleteAuditLogsBefore(){throw new Error("deleteAuditLogsBefore bridge method is not defined")}async readAuditLog(){throw new Error("readAuditLog bridge method is not defined")}};WD.exports=Fg});var QD=N((dRe,zD)=>{"use strict";var Gg=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};zD.exports=Gg});var eP={};je(eP,{HAS_EXPIRATION:()=>bh,HAS_RESIDENCY_ID:()=>zg,HAS_STRUCTURE_UPDATE:()=>Oh,LAST_TIMESTAMP_PLACEHOLDER:()=>n_,LOCAL_TIMESTAMP:()=>W4,METADATA:()=>e_,NO_TIMESTAMP:()=>$g,PENDING_LOCAL_TIME:()=>Qg,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>jg,RecordEncoder:()=>Wg,TIMESTAMP_ASSIGN_LAST:()=>z4,TIMESTAMP_ASSIGN_NEW:()=>XD,TIMESTAMP_ASSIGN_PREVIOUS:()=>ZD,TIMESTAMP_PLACEHOLDER:()=>Ah,TIMESTAMP_RECORD_PREVIOUS:()=>Vg,getUpdateRecord:()=>Jg,handleLocalTimeForGets:()=>Nh});function J4(){return r_[0]=r_[0]^64,j4.getFloat64(0)}function Nh(e){let t=e.getEntry;e.readCount=0,e.cachePuts=!1,e.getEntry=function(i,o){e.readCount++;let c=t.call(this,i,o),l=c?.value,u=l?.[e_];return u>=0&&(c.metadataFlags=u,c.localTime=l.localTime,c.value=l.value,c.residencyId=l.residencyId,l.expiresAt>=0&&(c.expiresAt=l.expiresAt)),c&&(c.key=i),c};let r=e.get;e.get=function(i,o){let c=r.call(this,i,o);return c?.[e_]>=0?c.value:c};let n=e.getRange;e.getRange=function(i){let o=n.call(this,i);return i.valuesForKey?o.map(c=>c?.value):i.values===!1||i.onlyCount?o:o.map(c=>{let l=c.value,u=l[e_];return u>=0&&(c.metadataFlags=u,c.localTime=l.localTime,c.value=l.value,c.residencyId=l.residencyId,l.expiresAt>=0&&(c.expiresAt=l.expiresAt)),c})};let s=e.useReadTransaction();if(s.done(),!s.done.isTracked){let i=s.constructor,o=s.use,c=s.done;i.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,ec.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let l=0;l<ec.length;l++){let u=ec[l].deref();(!u||u.isDone||u.isCommitted)&&ec.splice(l--,1)}},i.prototype.done.isTracked=!0}return e}function Jg(e,t,r){return function(n,s,i,o,c=-1,l,u,d="put",_,E){_||l==null?Cl=i?.localTime?Vg|ZD:$g:Cl=l?i?.localTime?Vg|16384:XD|16384:$g;let f=u?.expiresAt;if(f>=0&&(c|=bh),t_=c,Kg=f,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:Cl>0},T,m=0;try{let g=i?.residencyId,S=u?.residencyId;S&&(Yg=S,t_|=zg,m|=tc),g!==S&&(m|=rc,g||(g=0)),c&bh&&(m|=i_),u?.originatingOperation&&(m|=s_),_&&(h.ifVersion=T=i?.version??null);let b=e.put(n,s,h);if(l){let I=u?.user?.username;if(E&&(yh=e.encoder.encode(E)),e.encoder.hasStructureUpdate&&(m|=Oh,e.encoder.hasStructureUpdate=!1),_&&i?.localTime){let B=i?.localTime,H=r.get(B);if(H){let X=Ht(H).previousLocalTime;return r.put(B,Dl(o,t,n,X,u?.nodeId??server.replication.getThisNodeId(r)??0,I,d,yh,m,S,g,f),{ifVersion:T}),b}}r.put(n_,Dl(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,I,d,yh,m,S,g,f,u?.originatingOperation),{append:d!=="invalidate",instructedWrite:!0,ifVersion:T})}return b}catch(g){throw g.message+=" id: "+n+" options: "+h,g}}}var JD,qg,Ah,n_,jg,W4,e_,r_,j4,$g,XD,z4,ZD,Vg,bh,zg,Qg,Oh,Q4,yh,Cl,t_,Kg,Yg,Wg,ec,Pl=Oe(()=>{JD=require("msgpackr");Ji();qg=L(W()),Ah=new Uint8Array([1,1,1,1,4,64,0,0]),n_=new Uint8Array([1,1,1,1,1,0,0,0]),jg=new Uint8Array([1,1,1,1,3,64,0,0]),W4=Symbol("local-timestamp"),e_=Symbol("metadata"),r_=new Uint8Array(8),j4=new DataView(r_.buffer,0,8),$g=0,XD=0,z4=1,ZD=3,Vg=4,bh=16,zg=32,Qg=1,Oh=256,Cl=0,t_=-1,Kg=-1,Yg=0,Wg=class extends JD.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(Cl||t_>=0){let o=0,c=Cl;c&&(o+=8,Cl=0);let l=t_,u=Kg,d=Yg;l>=0&&(o+=2,t_=-1,u>=0&&(o+=8,Kg=-1),d&&(o+=4,Yg=0));let _=Q4=r.call(this,s,i|2048|o);yh=_.subarray((_.start||0)+o,_.end);let E=_.start||0;return c&&(Ah[4]=c,Ah[5]=c>>8,_.set(Ah,E),E+=8),l>=0&&(_[E++]=l&31,_[E++]=l>>5,u>=0&&((_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(E,u),E+=8),d&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setUint32(E,d)),_}else return r.call(this,s,i)};let n=this.saveStructures;this.saveStructures=function(s,i){let o=n.call(this,s,i);return this.hasStructureUpdate=!0,o}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(r_,0,c),c+=8;else for(let E=0;E<8;E++)r_[E]=t[c++];l=J4(),i=t[c]}let u,d;i<32&&(o=i|t[c+1]<<5,c+=2,o&bh&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&zg&&(d=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let _=r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c);return{localTime:l,value:_,[e_]:o,expiresAt:u,residencyId:d}}return r?.valueAsBuffer?t:super.decode(t,r)}catch(c){throw c.message+=", data: "+t.slice(0,40).toString("hex"),c}}};a(J4,"getTimestamp");a(Nh,"handleLocalTimeForGets");ec=[];setInterval(()=>{for(let e=0;e<ec.length;e++){let t=ec[e].deref();!t||t.isDone||t.isCommitted?ec.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(qg.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):qg.error("Read transaction detected that has been open too long (over one minute), make sure read transactions are quickly closed",t)),t.openTimer++):t.openTimer=1)}},15e3).unref();a(Jg,"getUpdateRecord")});var o_=N((pRe,rP)=>{"use strict";var tP=se(),X4=M(),{RecordEncoder:Z4}=(Pl(),oe(eP)),hRe=require("fs");tP.initSync();var eJ=tP.get(X4.CONFIG_PARAMS.STORAGE_CACHING)!==!1,Xg=class{static{a(this,"OpenDBIObject")}constructor(t,r=!1){this.dupSort=t===!0,this.encoding=t?"ordered-binary":"msgpack",this.useVersions=r,this.sharedStructuresKey=Symbol.for("structures"),r&&(this.cache=eJ&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:Z4})}};rP.exports=Xg});var a_=N((SRe,nP)=>{"use strict";var Un=se(),as=M();Un.initSync();var Ih=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Un.get(as.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Un.get(as.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Un.get(as.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Un.get(as.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Un.get(as.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Un.get(as.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Un.get(as.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Un.get(as.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};nP.exports=Ih;Ih.MAX_DBS=1e4});var ht=N((gRe,fP)=>{"use strict";var eR=require("lmdb"),Fs=require("fs-extra"),vn=require("path"),wh=cn(),oP=W(),ln=Dn().LMDB_ERRORS_ENUM,Ch=QD(),tR=o_(),aP=a_(),Wo=Bt(),sP=M(),{table:tJ,resetDatabases:rJ}=(Pe(),oe(lt)),iP=se(),Gs=Wo.INTERNAL_DBIS_NAME,cP=Wo.DBI_DEFINITION_NAME,nJ="data.mdb",sJ="lock.mdb",c_=".mdb",iJ="-lock",Zg=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=cs(t,r),this.key_type=this.dbi[Wo.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[Wo.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new eR.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function Dh(e,t){if(e===void 0)throw new Error(ln.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(ln.ENV_NAME_REQUIRED)}a(Dh,"pathEnvNameValidation");async function rR(e,t,r=!0){try{await Fs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(ln.INVALID_BASE_PATH):n}try{let n=vn.join(e,t+c_);return await Fs.access(n,Fs.constants.R_OK|Fs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Fs.access(vn.join(e,t,nJ),Fs.constants.R_OK|Fs.constants.F_OK),vn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(ln.INVALID_ENVIRONMENT)}else throw new Error(ln.INVALID_ENVIRONMENT);throw n}}a(rR,"validateEnvironmentPath");function Ph(e,t){if(wh.validateEnv(e),t===void 0)throw new Error(ln.DBI_NAME_REQUIRED)}a(Ph,"validateEnvDBIName");async function oJ(e,t,r=!1,n=!1){Dh(e,t);let s=vn.basename(e);t=t.toString();let i=iP.get(sP.CONFIG_PARAMS.DATABASES);i||iP.setProperty(sP.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await rR(e,t,n),lP(e,t,r)}catch(o){if(o.message===ln.INVALID_ENVIRONMENT){let c=vn.join(e,t);await Fs.mkdirp(n?c:e);let l=new aP(n?c:c+c_,!1),u=eR.open(l);u.dbis=Object.create(null);let d=new tR(!1);u.openDB(Gs,d),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let _=nR(e,t,r);return u[Wo.ENVIRONMENT_NAME_KEY]=_,global.lmdb_map[_]=u,u}throw o}}a(oJ,"createEnvironment");async function aJ(e,t,r,n=!0){Dh(e,t),t=t.toString();let s=vn.join(e,t);return tJ({table:t,database:vn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(aJ,"copyEnvironment");async function lP(e,t,r=!1){Dh(e,t),t=t.toString();let n=nR(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 rR(e,t),i=vn.join(e,t+c_),o=s!=i,c=new aP(s,o),l=eR.open(c);l.dbis=Object.create(null);let u=dP(l);for(let d=0;d<u.length;d++)cs(l,u[d]);return l[Wo.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(lP,"openEnvironment");async function cJ(e,t,r=!1){Dh(e,t),t=t.toString();let n=vn.join(e,t+c_),s=await rR(e,t);if(global.lmdb_map!==void 0){let i=nR(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await uP(o),delete global.lmdb_map[i]}}await Fs.remove(s),await Fs.remove(s===n?s+iJ:vn.join(vn.dirname(s),sJ))}a(cJ,"deleteEnvironment");async function uP(e){wh.validateEnv(e);let t=e[Wo.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(uP,"closeEnvironment");function nR(e,t,r=!1){let s=`${vn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(nR,"getCachedEnvironmentName");function lJ(e){wh.validateEnv(e);let t=Object.create(null),r=cs(e,Gs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Gs)try{t[n]=Object.assign(new Ch,s)}catch{oP.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(lJ,"listDBIDefinitions");function dP(e){wh.validateEnv(e);let t=[],r=cs(e,Gs);for(let{key:n}of r.getRange({start:!1}))n!==Gs&&t.push(n);return t}a(dP,"listDBIs");function uJ(e,t){let n=cs(e,Gs).getEntry(t),s=new Ch;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{oP.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(uJ,"getDBIDefinition");function _P(e,t,r,n=!r){if(Ph(e,t),t=t.toString(),t===Gs)throw new Error(ln.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return cs(e,t)}catch(s){if(s.message===ln.DBI_DOES_NOT_EXIST){let i=new tR(r,n===!0),o=e.openDB(t,i),c=new Ch(r===!0,n);return o[cP]=c,cs(e,Gs).putSync(t,c),e.dbis[t]=o,o}throw s}}a(_P,"createDBI");function cs(e,t){if(Ph(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Gs?r=uJ(e,t):r=new Ch,r===void 0)throw new Error(ln.DBI_DOES_NOT_EXIST);let n;try{let s=new tR(r.dup_sort,r.useVersions);if(n=e.openDB(t,s),n.db===void 0)throw new Error("MDB_NOTFOUND")}catch(s){throw s.message.includes("MDB_NOTFOUND")===!0?new Error(ln.DBI_DOES_NOT_EXIST):s}return n[cP]=r,e.dbis[t]=n,n}a(cs,"openDBI");function dJ(e,t){Ph(e,t),t=t.toString();let r=cs(e,t),n=r.getStats();return r[Wo.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(dJ,"statDBI");async function _J(e,t){try{let r=vn.join(e,t+c_);return(await Fs.stat(r)).size}catch{throw new Error(ln.INVALID_ENVIRONMENT)}}a(_J,"environmentDataSize");function fJ(e,t){if(Ph(e,t),t=t.toString(),t===Gs)throw new Error(ln.CANNOT_DROP_INTERNAL_DBIS_NAME);cs(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],cs(e,Gs).removeSync(t)}a(fJ,"dropDBI");function EJ(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{cs(e,i)}catch(o){if(o.message===ln.DBI_DOES_NOT_EXIST)_P(e,i,i!==t,i===t),n=!0;else throw o}}n&&rJ()}a(EJ,"initializeDBIs");fP.exports={openDBI:cs,openEnvironment:lP,createEnvironment:oJ,listDBIs:dP,listDBIDefinitions:lJ,createDBI:_P,dropDBI:fJ,statDBI:dJ,deleteEnvironment:cJ,initializeDBIs:EJ,TransactionCursor:Zg,environmentDataSize:_J,copyEnvironment:aJ,closeEnvironment:uP}});var hP=N((ARe,EP)=>{"use strict";var sR=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};EP.exports=sR});var mP=N((bRe,pP)=>{"use strict";var iR=class{static{a(this,"UpdateRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n,this.original_records=s}};pP.exports=iR});var TP=N((NRe,SP)=>{"use strict";var oR=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};SP.exports=oR});var sc=N((PRe,AP)=>{"use strict";var hJ=ht(),pJ=hP(),mJ=mP(),SJ=TP(),mi=cn(),l_=Dn().LMDB_ERRORS_ENUM,TJ=Bt(),Xi=M(),gJ=te(),RJ=require("uuid"),wRe=require("lmdb"),{handleHDBError:AJ,hdb_errors:yJ}=_e(),{OVERFLOW_MARKER:CRe,MAX_SEARCH_KEY_LENGTH:DRe}=TJ,gP=se();gP.initSync();var Lh=gP.get(Xi.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),aR=Xi.TIME_STAMP_NAMES_ENUM.CREATED_TIME,nc=Xi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function bJ(e,t,r,n,s=mi.getNextMonotonicTime()){dR(e,t,r,n),cR(e,t,r);let i=new pJ,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];RP(u,!0,s);let d=OJ(e,t,r,u),_=u[t];o.push(d),c.push(_)}return lR(o,c,n,i,s)}a(bJ,"insertRecords");function OJ(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let d=c([[{}]]);Array.isArray(d)&&(c=d[0][Xi.FUNC_VAL],n[o]=c)}let l=mi.getIndexedValues(c),u=e.dbis[o];if(l){Lh&&u.prefetch(l.map(d=>({key:d,value:s})),Mh);for(let d=0,_=l.length;d<_;d++)u.put(l[d],s)}}Lh&&e.dbis[t].prefetch([s],Mh),e.dbis[t].put(s,n,n[nc])})}a(OJ,"insertRecord");function NJ(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(NJ,"removeSkippedRecords");function RP(e,t,r){let n=r>0;(n||!Number.isInteger(e[nc]))&&(e[nc]=r||(r=mi.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[aR]))&&(e[aR]=r||mi.getNextMonotonicTime()):delete e[aR]}a(RP,"setTimestamps");function cR(e,t,r){r.indexOf(Xi.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Xi.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Xi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Xi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),hJ.initializeDBIs(e,t,r)}a(cR,"initializeTransaction");async function IJ(e,t,r,n,s=mi.getNextMonotonicTime()){dR(e,t,r,n),cR(e,t,r);let i=new mJ,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let d=n[u],_=d[t],E;try{E=uR(e,t,d,_,i,!0,s)}catch{i.skipped_hashes.push(_),o.push(u);continue}c.push(E),l.push(_)}return lR(c,l,n,i,s,o)}a(IJ,"updateRecords");async function wJ(e,t,r,n,s=mi.getNextMonotonicTime()){try{dR(e,t,r,n)}catch(l){throw AJ(l,l.message,yJ.HTTP_STATUS_CODES.BAD_REQUEST)}cR(e,t,r);let i=new SJ,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],d;gJ.isEmpty(u[t])?(d=RJ.v4(),u[t]=d):d=u[t];let _=uR(e,t,u,d,i,!1,s);o.push(_),c.push(d)}return lR(o,c,n,i,s)}a(wJ,"upsertRecords");async function lR(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(),NJ(r,i),n}a(lR,"finalizeWrite");function uR(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),u=l?.value,d=u;if(!u){if(i)return!1;u={}}if(RP(r,!d,o),Number.isInteger(r[nc])&&u[nc]>r[nc])return!1;d&&s.original_records.push(u);let _,E=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let T=r[h],m=e.dbis[h];if(m===void 0)continue;let g=u[h];if(typeof T=="function"){let b=T([[u]]);Array.isArray(b)&&(T=b[0][Xi.FUNC_VAL],r[h]=T)}if(T===g)continue;let S=mi.getIndexedValues(g);if(S){Lh&&m.prefetch(S.map(b=>({key:b,value:n})),Mh);for(let b=0,I=S.length;b<I;b++)m.remove(S[b],n)}if(S=mi.getIndexedValues(T),S){Lh&&m.prefetch(S.map(b=>({key:b,value:n})),Mh);for(let b=0,I=S.length;b<I;b++)m.put(S[b],n)}}let f={...u,...r};c.put(n,f,f[nc])},"do_put");return l?_=c.ifVersion(n,l.version,E):_=c.ifNoExists(n,E),_.then(f=>f?!0:uR(e,t,r,n,s,i,o))}a(uR,"updateUpsertRecord");function CJ(e,t,r){if(mi.validateEnv(e),t===void 0)throw new Error(l_.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(l_.WRITE_ATTRIBUTES_REQUIRED):new Error(l_.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(CJ,"validateBasic");function dR(e,t,r,n){if(CJ(e,t,r),!Array.isArray(n))throw n===void 0?new Error(l_.RECORDS_REQUIRED):new Error(l_.RECORDS_MUST_BE_ARRAY)}a(dR,"validateWrite");function Mh(){}a(Mh,"noop");AP.exports={insertRecords:bJ,updateRecords:IJ,upsertRecords:wJ}});var Zi=N((MRe,DJ)=>{DJ.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"}]},hdb_certificate:{hash_attribute:"name",name:"hdb_certificate",schema:"system",attributes:[{attribute:"name"},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var Ti=N((URe,OP)=>{"use strict";var bP=te(),yP=M(),Ll=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Si=require("joi"),jo={schema_format:{pattern:Ll,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},PJ=Si.alternatives(Si.string().min(1).max(jo.schema_length.maximum).pattern(Ll).messages({"string.pattern.base":"{:#label} "+jo.schema_format.message}),Si.number(),Si.array()).required(),LJ=Si.alternatives(Si.string().min(1).max(jo.schema_length.maximum).pattern(Ll).messages({"string.pattern.base":"{:#label} "+jo.schema_format.message}),Si.number()),MJ=Si.alternatives(Si.string().min(1).max(jo.schema_length.maximum).pattern(Ll).messages({"string.pattern.base":"{:#label} "+jo.schema_format.message}),Si.number()).required();function UJ(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>jo.schema_length.maximum?`'${e}' maximum of 250 characters`:Ll.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(UJ,"checkValidTable");function vJ(e,t){return bP.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(vJ,"validateSchemaExists");function BJ(e,t){let r=t.state.ancestors[0].schema;return bP.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(BJ,"validateTableExists");function HJ(e,t){return e.toLowerCase()===yP.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${yP.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(HJ,"validateSchemaName");OP.exports={common_validators:jo,schema_regex:Ll,hdb_schema_table:PJ,validateSchemaExists:vJ,validateTableExists:BJ,validateSchemaName:HJ,checkValidTable:UJ,hdb_database:LJ,hdb_table:MJ}});var Uh=N((BRe,NP)=>{var{common_validators:gi}=Ti(),d_=Tt(),u_="is required",rr={database:{presence:!1,format:gi.schema_format,length:gi.schema_length},schema:{presence:!1,format:gi.schema_format,length:gi.schema_length},table:{presence:!0,format:gi.schema_format,length:gi.schema_length},attribute:{presence:!0,format:gi.schema_format,length:gi.schema_length},hash_attribute:{presence:!0,format:gi.schema_format,length:gi.schema_length}};function __(e){for(let t in e)e[t]=e[t]===null||e[t]===void 0||typeof e[t]=="object"?e[t]:e[t].toString();return e}a(__,"makeAttributesStrings");function xJ(e){return e=__(e),rr.table.presence=!1,rr.attribute.presence=!1,rr.hash_attribute.presence=!1,d_.validateObject(e,rr)}a(xJ,"schema_object");function kJ(e){return e=__(e),rr.table.presence={message:u_},rr.attribute.presence=!1,rr.hash_attribute.presence=!1,d_.validateObject(e,rr)}a(kJ,"table_object");function FJ(e){return e=__(e),rr.table.presence={message:u_},rr.attribute.presence=!1,d_.validateObject(e,rr)}a(FJ,"create_table_object");function GJ(e){return e=__(e),rr.table.presence={message:u_},rr.attribute.presence={message:u_},rr.hash_attribute.presence=!1,d_.validateObject(e,rr)}a(GJ,"attribute_object");function qJ(e){return e=__(e),rr.table.presence={message:u_},rr.attribute.presence=!1,rr.hash_attribute.presence=!1,d_.validateObject(e,rr)}a(qJ,"describe_table");function $J(e){if(e){if(!Array.isArray(e))throw new Error("residence must be a string array");if(e.length===0)throw new Error("residence cannot be an empty array");for(let t=0;t<e.length;t++)if(typeof e[t]!="string")throw new Error(`residence must be a string array, item '${e[t]}' is not a string`)}}a($J,"validateTableResidence");NP.exports={schema_object:xJ,create_table_object:FJ,table_object:kJ,attribute_object:GJ,describe_table:qJ,validateTableResidence:$J}});var wP=N((xRe,IP)=>{"use strict";var VJ=require("uuid"),_R=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||VJ.v4(),this.schema_table=`${this.schema}.${this.table}`}};IP.exports=_R});var vh=N((FRe,CP)=>{"use strict";var KJ=wP(),fR=class extends KJ{static{a(this,"LMDBCreateAttributeObject")}constructor(t,r,n,s,i=!0,o=!1){super(t,r,n,s),this.dup_sort=i,this.is_hash_attribute=o}};CP.exports=fR});var PP=N((qRe,DP)=>{"use strict";DP.exports=WJ;var YJ="inserted";function WJ(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===YJ?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(WJ,"returnObject")});var Bh=N((KRe,vP)=>{"use strict";var jJ=M(),ER=ht(),zJ=sc(),{getSystemSchemaPath:QJ,getSchemaPath:JJ}=gt(),VRe=Zi(),XJ=Uh(),ZJ=vh(),e3=PP(),{handleHDBError:LP,hdb_errors:UP}=_e(),MP=te(),{HTTP_STATUS_CODES:t3}=UP,r3="inserted";vP.exports=n3;async function n3(e){let t=XJ.attribute_object(e);if(t)throw LP(new Error,t.message,UP.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&MP.checkGlobalSchemaTable(e.schema,e.table);if(r)throw LP(new Error,r,t3.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=MP.isEmpty(e.dup_sort)||e.dup_sort=="true";let n=[];if(global.hdb_schema[e.schema]&&global.hdb_schema[e.schema][e.table]&&(n=global.hdb_schema[e.schema][e.table].attributes),Array.isArray(n)&&n.length>0){for(let i of n)if(i.attribute===e.attribute)throw new Error(`attribute '${i.attribute}' already exists in ${e.schema}.${e.table}`)}let s=new ZJ(e.schema,e.table,e.attribute,e.id);try{let i=await ER.openEnvironment(JJ(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}`);ER.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await ER.openEnvironment(QJ(),jJ.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await zJ.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return e3(r3,c,{records:[s]},l)}catch(i){throw i}}a(n3,"lmdbCreateAttribute")});var pR=N((WRe,HP)=>{var{hdb_table:s3,hdb_database:BP}=Ti(),i3=Tt(),hR=require("joi"),o3={undefined:"undefined",null:"null"},a3=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||o3[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"),c3=hR.object({database:BP,schema:BP,table:s3,records:hR.array().items(hR.object().custom(a3)).required()});HP.exports=function(e){return i3.validateBySchema(e,c3)}});var f_=N((QRe,kP)=>{"use strict";var eo=te(),xP=W(),zRe=pR(),{getDatabases:l3}=(Pe(),oe(lt)),{ClientError:ic}=_e();kP.exports=u3;function u3(e){if(eo.isEmpty(e))throw new ic("invalid update parameters defined.");if(eo.isEmptyOrZeroLength(e.schema))throw new ic("invalid schema specified.");if(eo.isEmptyOrZeroLength(e.table))throw new ic("invalid table specified.");if(!Array.isArray(e.records))throw new ic("records must be an array");let t=l3()[e.schema]?.[e.table];if(eo.isEmpty(t))throw new ic(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&eo.isEmptyOrZeroLength(o[r]))throw xP.error("a valid hash attribute must be provided with update record:",o),new ic("a valid hash attribute must be provided with update record, check log for more info");if(!eo.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw xP.error(`a valid hash value must be provided with ${e.operation} record:`,o),new ic(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!eo.isEmpty(o[r])&&o[r]!==""&&n.has(eo.autoCast(o[r]))&&(o.skip=!0),n.add(eo.autoCast(o[r]));for(let c in o)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}a(u3,"insertUpdateValidate")});var GP=N((XRe,FP)=>{"use strict";var mR=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};FP.exports=mR});var VP=N((eAe,$P)=>{"use strict";var SR=ht(),d3=W(),qP=Dn().LMDB_ERRORS_ENUM;$P.exports=_3;async function _3(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 SR.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==qP.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await SR.closeEnvironment(global.lmdb_map[n]),await SR.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==qP.ENV_REQUIRED)throw i}break;case"drop_attribute":r=global.lmdb_map[`${e.schema}.${e.table}`],r!==void 0&&typeof r.dbis=="object"&&r.dbis[`${e.attribute}`]!==void 0&&delete r.dbis[`${e.attribute}`];break;default:break}}}catch(t){d3.error(t)}}a(_3,"cleanLMDBMap")});var to=N((rAe,jP)=>{"use strict";var E_=require("crypto"),f3=se(),{CONFIG_PARAMS:E3}=M(),YP="aes-256-cbc",h3=32,p3=16,TR=64,WP=32,m3=TR+WP,KP=new Map;jP.exports={encrypt:S3,decrypt:T3,createNatsTableStreamName:g3};function S3(e){let t=E_.randomBytes(h3),r=E_.randomBytes(p3),n=E_.createCipheriv(YP,Buffer.from(t),r),s=n.update(e);s=Buffer.concat([s,n.final()]);let i=t.toString("hex"),o=r.toString("hex"),c=s.toString("hex");return i+o+c}a(S3,"encrypt");function T3(e){let t=e.substr(0,TR),r=e.substr(TR,WP),n=e.substr(m3,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=E_.createDecipheriv(YP,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(T3,"decrypt");function g3(e,t){let r=f3.get(E3.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=KP.get(r);return n||(n=E_.createHash("md5").update(r).digest("hex"),KP.set(r,n)),n}a(g3,"createNatsTableStreamName")});var ro=N((iAe,JP)=>{"use strict";var sAe=Vr(),h_=W(),zP=Uh(),R3=to(),Hh=te(),{handleHDBError:xh,hdb_errors:A3}=_e(),{HDB_ERROR_MSGS:kh,HTTP_STATUS_CODES:gR}=A3,QP=se();QP.initSync();var{getDatabases:RR}=(Pe(),oe(lt)),y3=require("fs-extra"),b3=M();JP.exports={describeAll:O3,describeTable:Fh,describeSchema:N3};async function O3(e={}){try{let t=Hh.isEmptyOrZeroLength(e),r=!!e.bypass_auth,n,s;!t&&!r&&(n=e.hdb_user?.role?.permission,s=n?.super_user||n?.cluster_user);let i=RR(),o={},c={},l=[],u=e?.exact_count;for(let _ in i){o[_]=!0,!t&&!s&&!r&&(c[_]=e.hdb_user?.role?.permission[_]?.describe);let E=i[_];for(let f in E)try{let h;if(t||s||r)h=await Fh({schema:_,table:f,exact_count:u});else if(n&&n[_].describe&&n[_].tables[f].describe){let T=n[_].tables[f].attribute_permissions;h=await Fh({schema:_,table:f,exact_count:u},T)}h&&l.push(h)}catch(h){h_.error(h)}}let d={};for(let _ in l)t||s||r?(d[l[_].schema]==null&&(d[l[_].schema]={}),d[l[_].schema][l[_].name]=l[_],o[l[_].schema]&&delete o[l[_].schema]):c[l[_].schema]&&(d[l[_].schema]==null&&(d[l[_].schema]={}),d[l[_].schema][l[_].name]=l[_],o[l[_].schema]&&delete o[l[_].schema]);for(let _ in o)t||s||r?d[_]={}:c[_]&&(d[_]={});return d}catch(t){return h_.error("Got an error in describeAll"),h_.error(t),xh(new Error,kh.DESCRIBE_ALL_ERR)}}a(O3,"describeAll");async function Fh(e,t){Hh.transformReq(e);let{schema:r,table:n}=e;r=r?.toString(),n=n?.toString();let s=t;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(s=e.hdb_user?.role?.permission[r]?.tables[n]?.attribute_permissions);let i=zP.describe_table(e);if(i)throw i;let c=RR()[r];if(!c)throw xh(new Error,kh.SCHEMA_NOT_FOUND(e.schema),gR.NOT_FOUND);let l=c[n];if(!l)throw xh(new Error,kh.TABLE_NOT_FOUND(e.schema,e.table),gR.NOT_FOUND);function u(f){d.push({attribute:f.attribute,type:f.type,elements:f.elements?.type,indexed:f.indexed,is_primary_key:f.isPrimaryKey,assigned_created_time:f.assignCreatedTime,assigned_updated_time:f.assignUpdatedTime,nullable:f.nullable,properties:f.properties?f.properties.map(h=>({type:h.type,name:h.name})):void 0})}a(u,"pushAtt");let d=[];if(s){let f={};s.forEach(h=>{h.describe&&(f[h.attribute_name]=!0)}),l.attributes.forEach(h=>{f[h.name]&&u(h)})}else l.attributes?.forEach(f=>u(f));let _;try{_=(await y3.stat(l.primaryStore.env.path)).size}catch(f){h_.warn("unable to get database size",f)}let E={schema:r,name:l.tableName,hash_attribute:l.attributes.find(f=>f.isPrimaryKey||f.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:d,db_size:_};l.replicate!==void 0&&(E.replicate=l.replicate),l.expirationMS!==void 0&&(E.expiration=l.expirationMS/1e3+"s"),l.sealed!==void 0&&(E.sealed=l.sealed),l.sources?.length>0&&(E.sources=l.sources.map(f=>f.name).filter(f=>f&&f!=="NATSReplicator"&&f!=="Replicator")),QP.get(b3.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(E.clustering_stream_name=R3.createNatsTableStreamName(E.schema,E.name));try{let f=l.getRecordCount({exactCount:e.exact_count==="true"});E.record_count=f.recordCount,E.table_size=l.getSize(),E.estimated_record_range=f.estimatedRange;let h=l.auditStore;if(h)for(let T of h.getKeys({reverse:!0,limit:1}))E.last_updated_record=T[0];if(!E.last_updated_record&&l.indices.__updatedtime__)for(let T of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))E.last_updated_record=T}catch(f){h_.warn(`unable to stat table dbi due to ${f}`)}return E}a(Fh,"descTable");async function N3(e){Hh.transformReq(e);let t=zP.schema_object(e);if(t)throw t;let r;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(r=e.hdb_user?.role?.permission[e.schema]);let n=e.schema.toString(),i=RR()[n];if(!i)throw xh(new Error,kh.SCHEMA_NOT_FOUND(e.schema),gR.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),Hh.isEmpty(l)||l.describe){let u=await Fh({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(N3,"describeSchema")});var ls=N((lAe,rL)=>{var I3=Zi(),{callbackify:ZP,promisify:w3}=require("util"),{getDatabases:eL}=(Pe(),oe(lt));rL.exports={setSchemaDataToGlobal:XP,getTableSchema:C3,getSystemSchema:D3,setSchemaDataToGlobalAsync:w3(XP)};var tL=ro(),aAe=ZP(tL.describeAll),cAe=ZP(tL.describeTable);function XP(e){global.hdb_schema=eL(),e&&e()}a(XP,"setSchemaDataToGlobal");function C3(e,t,r){let n=eL()[e];if(!n)return r(`schema ${e} does not exist`);let s=n[t];return s?r(null,{schema:e,name:t,hash_attribute:s.primaryKey}):r(`table ${e}.${t} does not exist`)}a(C3,"getTableSchema");function D3(){return I3}a(D3,"getSystemSchema")});var un=N((dAe,oL)=>{"use strict";var qh=pR(),Cr=te(),P3=require("util"),$h=Bn(),L3=ls(),nL=W(),{handleHDBError:oc,hdb_errors:M3}=_e(),{HTTP_STATUS_CODES:ac}=M3,U3=P3.promisify(L3.getTableSchema),v3="updated",sL="inserted",iL="upserted";oL.exports={insert:H3,update:x3,upsert:k3,validation:B3,flush:F3};async function B3(e){if(Cr.isEmpty(e))throw new Error("invalid update parameters defined.");if(Cr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Cr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await U3(e.schema,e.table),r=qh(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let n=t.hash_attribute,s=new Set,i={},o=!1;return e.operation==="update"&&(o=!0),e.records.forEach(c=>{if(o&&Cr.isEmptyOrZeroLength(c[n]))throw nL.error("a valid hash attribute must be provided with update record:",c),new Error("a valid hash attribute must be provided with update record");if(!Cr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw nL.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Cr.isEmpty(c[n])&&c[n]!==""&&s.has(Cr.autoCast(c[n]))&&(c.skip=!0),s.add(Cr.autoCast(c[n]));for(let l in c)i[l]=1}),i[n]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(i)}}a(B3,"validation");async function H3(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=qh(e);if(t)throw oc(new Error,t.message,ac.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw oc(new Error,r,ac.BAD_REQUEST);let n=await $h.createRecords(e);return Gh(sL,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(H3,"insertData");async function x3(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=qh(e);if(t)throw oc(new Error,t.message,ac.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw oc(new Error,r,ac.BAD_REQUEST);let n=await $h.updateRecords(e);return Cr.isEmpty(n.existing_rows)?Gh(v3,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):Gh(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(x3,"updateData");async function k3(e){if(e.operation!=="upsert")throw oc(new Error,"invalid operation, must be upsert",ac.INTERNAL_SERVER_ERROR);let t=qh(e);if(t)throw oc(new Error,t.message,ac.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw oc(new Error,r,ac.BAD_REQUEST);let n=await $h.upsertRecords(e);return Gh(iL,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(k3,"upsertData");function Gh(e,t,r,n,s,i){let o={message:`${e} ${t.length} of ${t.length+n.length} records`,new_attributes:s,txn_time:i};return e===sL?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===iL?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(Gh,"returnObject");function F3(e){return Cr.transformReq(e),$h.flush(e.schema,e.table)}a(F3,"flush")});var yR=N((fAe,lL)=>{var G3=Tt(),AR=require("joi"),{hdb_table:q3,hdb_database:aL}=Ti(),cL={schema:aL,database:aL,table:q3},$3={date:AR.date().iso().required()},V3={timestamp:AR.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};lL.exports=function(e,t){let r=t==="timestamp"?{...cL,...V3}:{...cL,...$3},n=AR.object(r);return G3.validateBySchema(e,n)}});var _L=N((EAe,dL)=>{var K3=Tt(),bR=require("joi"),{hdb_table:Y3,hdb_database:uL}=Ti(),W3=bR.object({schema:uL,database:uL,table:Y3,hash_values:bR.array().required(),ids:bR.array()});dL.exports=function(e){return K3.validateBySchema(e,W3)}});var wR=N((hAe,fL)=>{"use strict";var OR=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}},NR=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}},IR=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};fL.exports={InsertObject:OR,NoSQLSeachObject:NR,DeleteResponseObject:IR}});var uc=N((mAe,SL)=>{"use strict";var hL=yR(),j3=_L(),cc=te(),EL=require("moment"),pL=W(),{promisify:z3,callbackify:Q3}=require("util"),lc=M(),J3=ls(),CR=z3(J3.getTableSchema),DR=Bn(),{DeleteResponseObject:X3}=wR(),{handleHDBError:zo,hdb_errors:Z3}=_e(),{HDB_ERROR_MSGS:Vh,HTTP_STATUS_CODES:Qo}=Z3,eX="records successfully deleted",tX=Q3(mL);SL.exports={delete:tX,deleteRecord:mL,deleteFilesBefore:rX,deleteAuditLogsBefore:nX};async function rX(e){let t=hL(e,"date");if(t)throw zo(t,t.message,Qo.BAD_REQUEST,void 0,void 0,!0);if(cc.transformReq(e),!EL(e.date,EL.ISO_8601).isValid())throw zo(new Error,Vh.INVALID_DATE,Qo.BAD_REQUEST,lc.LOG_LEVELS.ERROR,Vh.INVALID_DATE,!0);let n=cc.checkSchemaTableExist(e.schema,e.table);if(n)throw zo(new Error,n,Qo.NOT_FOUND,lc.LOG_LEVELS.ERROR,n,!0);let s=await DR.deleteRecordsBefore(e);if(await CR(e.schema,e.table),pL.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(rX,"deleteFilesBefore");async function nX(e){let t=hL(e,"timestamp");if(t)throw zo(t,t.message,Qo.BAD_REQUEST,void 0,void 0,!0);if(cc.transformReq(e),isNaN(e.timestamp))throw zo(new Error,Vh.INVALID_VALUE("Timestamp"),Qo.BAD_REQUEST,lc.LOG_LEVELS.ERROR,Vh.INVALID_VALUE("Timestamp"),!0);let r=cc.checkSchemaTableExist(e.schema,e.table);if(r)throw zo(new Error,r,Qo.NOT_FOUND,lc.LOG_LEVELS.ERROR,r,!0);let n=await DR.deleteAuditLogsBefore(e);return await CR(e.schema,e.table),pL.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(nX,"deleteAuditLogsBefore");async function mL(e){e.ids&&(e.hash_values=e.ids);let t=j3(e);if(t)throw zo(t,t.message,Qo.BAD_REQUEST,void 0,void 0,!0);cc.transformReq(e);let r=cc.checkSchemaTableExist(e.schema,e.table);if(r)throw zo(new Error,r,Qo.NOT_FOUND,lc.LOG_LEVELS.ERROR,r,!0);try{await CR(e.schema,e.table);let n=await DR.deleteRecords(e);return cc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${eX}`),n}catch(n){if(n.message===lc.SEARCH_NOT_FOUND_MESSAGE){let s=new X3;return s.message=lc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(mL,"deleteRecord")});var Kh=N((TAe,RL)=>{var sX=require("crypto"),TL=9;function iX(e){let t=aX(TL),r=gL(e+t);return t+r}a(iX,"createHash");function oX(e,t){let r=e?.substr(0,TL),n=r+gL(t+r);return e===n}a(oX,"validateHash");function aX(e){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ",r=t.length,n="";for(let s=0;s<e;s++){let i=Math.floor(Math.random()*r);n+=t[i]}return n}a(aX,"generateSalt");function gL(e){return sX.createHash("md5").update(e).digest("hex")}a(gL,"md5");RL.exports={hash:iX,validate:oX}});var yL=N((RAe,AL)=>{var PR=Tt(),Kr={username:{presence:!0,exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function cX(e){return Kr.password.presence=!0,Kr.username.presence=!0,Kr.role.presence=!0,Kr.active.presence=!0,PR.validateObject(e,Kr)}a(cX,"addUserValidation");function lX(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,PR.validateObject(e,Kr)}a(lX,"alterUserValidation");function uX(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,PR.validateObject(e,Kr)}a(uX,"dropUserValidation");AL.exports={addUserValidation:cX,alterUserValidation:lX,dropUserValidation:uX}});var Ct=N((bAe,OL)=>{"use strict";var{platform:yAe}=require("os"),dX="nats-server.zip",LR="nats-server",_X=process.platform==="win32"?`${LR}.exe`:LR,fX=/^[^\s.,*>]+$/,bL="__request__",EX=a(e=>`${e}.${bL}`,"REQUEST_SUBJECT"),hX={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},pX={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},mX={HUB:"hub.pid",LEAF:"leaf.pid"},SX={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},TX={SUCCESS:"success",ERROR:"error"},gX={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},RX={TXN:"txn",MSGID:"msgid"},Ml={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},AX={[Ml.ERR]:1,[Ml.WRN]:2,[Ml.INF]:3,[Ml.DBG]:4,[Ml.TRC]:5},yX={debug:"-D",trace:"-DVV"};OL.exports={NATS_SERVER_ZIP:dX,NATS_SERVER_NAME:LR,NATS_BINARY_NAME:_X,PID_FILES:mX,NATS_CONFIG_FILES:pX,SERVER_SUFFIX:SX,NATS_TERM_CONSTRAINTS_RX:fX,REQUEST_SUFFIX:bL,UPDATE_REMOTE_RESPONSE_STATUSES:TX,CLUSTER_STATUS_STATUSES:gX,REQUEST_SUBJECT:EX,SUBJECT_PREFIXES:RX,MSG_HEADERS:hX,LOG_LEVELS:Ml,LOG_LEVEL_FLAGS:yX,LOG_LEVEL_HIERARCHY:AX}});var IL=N((NAe,NL)=>{"use strict";var Yh=M(),Wh=class{static{a(this,"BaseLicense")}constructor(t=0,r=Yh.RAM_ALLOCATION_ENUM.DEFAULT,n=Yh.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},MR=class extends Wh{static{a(this,"ExtendedLicense")}constructor(t=0,r=Yh.RAM_ALLOCATION_ENUM.DEFAULT,n=Yh.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};NL.exports={BaseLicense:Wh,ExtendedLicense:MR}});var dc=N((wAe,UL)=>{"use strict";var vl=require("fs-extra"),CL=Kh(),DL=require("crypto"),bX=require("moment"),OX=require("uuid").v4,Yr=W(),vR=require("path"),NX=te(),Jo=M(),{totalmem:wL}=require("os"),IX=IL().ExtendedLicense,Ul="invalid license key format",wX="061183",CX="mofi25",DX="aes-256-cbc",PX=16,LX=32,PL=se(),{resolvePath:LL}=wt();PL.initSync();var UR;UL.exports={validateLicense:ML,generateFingerPrint:UX,licenseSearch:xR,getLicense:HX,checkMemoryLimit:xX};function BR(){return vR.join(PL.getHdbBasePath(),Jo.LICENSE_KEY_DIR_NAME,Jo.LICENSE_FILE_NAME)}a(BR,"getLicenseDirPath");function MX(){let e=BR();return LL(vR.join(e,Jo.LICENSE_FILE_NAME))}a(MX,"getLicenseFilePath");function HR(){let e=BR();return LL(vR.join(e,Jo.REG_KEY_FILE_NAME))}a(HR,"getFingerPrintFilePath");async function UX(){let e=HR();try{return await vl.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await vX();throw Yr.error(`Error writing fingerprint file to ${e}`),Yr.error(t),new Error("There was an error generating the fingerprint")}}a(UX,"generateFingerPrint");async function vX(){let e=OX(),t=CL.hash(e),r=HR();try{await vl.mkdirp(BR()),await vl.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw Yr.error(`Error writing fingerprint file to ${r}`),Yr.error(n),new Error("There was an error generating the fingerprint")}return t}a(vX,"writeFingerprint");function ML(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:Jo.RAM_ALLOCATION_ENUM.DEFAULT,version:Jo.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Yr.error("empty license key passed to validate."),r;let n=HR(),s=!1;try{s=vl.statSync(n)}catch(i){Yr.error(i)}if(s){let i;try{i=vl.readFileSync(n,"utf8")}catch{Yr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(CX),c=o[1];c=Buffer.concat([Buffer.from(c)],PX);let l=Buffer.concat([Buffer.from(i)],LX),u=DL.createDecipheriv(DX,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let d=null;try{d=u.update(o[0],"hex","utf8"),d.trim(),d+=u.final("utf8")}catch{let f=BX(o[0],i);if(f)d=f;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Ul),Yr.error(Ul),new Error(Ul)}let _;if(isNaN(d))try{_=JSON.parse(d),r.version=_.version,r.exp_date=_.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),_.ram_allocation&&(r.ram_allocation=_.ram_allocation)}catch{throw console.error(Ul),Yr.error(Ul),new Error(Ul)}else r.exp_date=d;r.exp_date<bX().valueOf()&&(r.valid_date=!1),CL.validate(o[1],`${wX}${i}${t}`)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||Yr.error("Invalid licence"),r}a(ML,"validateLicense");function BX(e,t){try{let r=DL.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{Yr.warn("Check old license failed")}}a(BX,"checkOldLicense");function xR(){let e=new IX,t=[];try{t=vl.readFileSync(MX(),"utf-8").split(Jo.NEW_LINE)}catch(r){r.code==="ENOENT"?Yr.debug("no license file found"):Yr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(NX.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=ML(s.license_key,s.company);i.valid_machine===!0&&i.valid_date===!0&&i.valid_machine===!0&&(e.exp_date=i.exp_date>e.exp_date?i.exp_date:e.exp_date,e.ram_allocation=i.ram_allocation,e.enterprise=!0)}catch(s){Yr.error("There was an error parsing the license string."),Yr.error(s),e.ram_allocation=Jo.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return UR=e,e}a(xR,"licenseSearch");async function HX(){return UR||await xR(),UR}a(HX,"getLicense");function xX(){let e=xR().ram_allocation,t=process.constrainedMemory?.()||wL();if(t=Math.round(Math.min(t,wL())/2**20),t>e)return`This server has more memory (${t}MB) than HarperDB is licensed for (${e}MB), this should only be used for educational and development purposes.`}a(xX,"checkMemoryLimit")});var xn=N((MAe,QL)=>{"use strict";var xL="username is required",kL="nothing to update, must supply active, role or password to update",FL="password cannot be an empty string",GL="If role is specified, it cannot be empty.",qL="active must be true or false";QL.exports={addUser:WX,alterUser:jX,dropUser:QX,getSuperUser:eZ,userInfo:JX,listUsers:zh,listUsersExternal:XX,setUsersToGlobal:Hl,findAndValidateUser:jL,getClusterUser:tZ,USERNAME_REQUIRED:xL,ALTERUSER_NOTHING_TO_UPDATE:kL,EMPTY_PASSWORD:FL,EMPTY_ROLE:GL,ACTIVE_BOOLEAN:qL};var $L=un(),kX=uc(),GR=Kh(),VL=yL(),KL=Vr(),qR=no(),Hn=te(),YL=require("validate.js"),Ke=W(),{promisify:FX}=require("util"),$R=to(),vL=M(),BL=Ct(),GX=wt(),DAe=se(),PAe=dc(),qX=Zi(),{table:LAe}=(Pe(),oe(lt)),{handleHDBError:Ri,hdb_errors:$X}=_e(),{HTTP_STATUS_CODES:Ai,AUTHENTICATION_ERROR_MSGS:kR,HDB_ERROR_MSGS:Bl}=$X,{UserEventMsg:VR}=qs(),FR=require("lodash"),{server:KR}=(qr(),oe(Qa)),VX=W();KR.getUser=(e,t)=>jL(e,t,t!=null);var WL={username:!0,active:!0,role:!0,password:!0},HL=new Map,jh=KL.searchByValue,KX=KL.searchByHash,YX=FX(kX.delete);async function WX(e){let t=YL.cleanAttributes(e,WL),r=VL.addUserValidation(t);if(r)throw Ri(new Error,r.message,Ai.BAD_REQUEST,void 0,void 0,!0);let n={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]},s;try{s=await jh(n),s=s&&Array.from(s)}catch(l){throw Ke.error("There was an error searching for a role in add user"),Ke.error(l),l}if(!s||s.length<1)throw Ri(new Error,Bl.ROLE_NAME_NOT_FOUND(t.role),Ai.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw Ri(new Error,Bl.DUP_ROLES_FOUND(t.role),Ai.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=$R.encrypt(t.password)),t.password=GR.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await $L.insert(i)}catch(l){throw Ke.error("There was an error searching for a user."),Ke.error(l),l}Ke.debug(o);try{await Hl()}catch(l){throw Ke.error("Got an error setting users to global"),Ke.error(l),l}if(o.skipped_hashes.length===1)throw Ri(new Error,Bl.USER_ALREADY_EXISTS(t.username),Ai.CONFLICT,void 0,void 0,!0);let c={...t};return c.role=s[0],qR.signalUserChange(new VR(process.pid)),`${c.username} successfully added`}a(WX,"addUser");async function jX(e){let t=YL.cleanAttributes(e,WL);if(Hn.isEmptyOrZeroLength(t.username))throw new Error(xL);if(Hn.isEmptyOrZeroLength(t.password)&&Hn.isEmptyOrZeroLength(t.role)&&Hn.isEmptyOrZeroLength(t.active))throw new Error(kL);if(!Hn.isEmpty(t.password)&&Hn.isEmptyOrZeroLength(t.password.trim()))throw new Error(FL);if(!Hn.isEmpty(t.active)&&!Hn.isBoolean(t.active))throw new Error(qL);let r=zX(t.username);if(!Hn.isEmpty(t.password)&&!Hn.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=$R.encrypt(t.password)),t.password=GR.hash(t.password)),t.role==="")throw new Error(GL);if(t.role){let i={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]},o;try{o=Array.from(await jh(i)||[])}catch(c){throw Ke.error("Got an error searching for a role."),Ke.error(c),c}if(!o||o.length===0){let c=Bl.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Ke.error(c),Ri(new Error,c,Ai.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=Bl.ALTER_USER_DUP_ROLES(t.role);throw Ke.error(c),Ri(new Error,c,Ai.CONFLICT,void 0,void 0,!0)}t.role=o[0].id}let n={operation:"update",schema:"system",table:"hdb_user",records:[t]},s;try{s=await $L.update(n)}catch(i){throw Ke.error("Error during update."),Ke.error(i),i}try{await Hl()}catch(i){throw Ke.error("Got an error setting users to global"),Ke.error(i),i}return qR.signalUserChange(new VR(process.pid)),s}a(jX,"alterUser");function zX(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(zX,"isClusterUser");async function QX(e){try{let t=VL.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(Hn.isEmpty(global.hdb_users.get(e.username)))throw Ri(new Error,Bl.USER_NOT_EXIST(e.username),Ai.NOT_FOUND,void 0,void 0,!0);let n;try{n=await YX(r)}catch(s){throw Ke.error("Got an error deleting a user."),Ke.error(s),s}Ke.debug(n);try{await Hl()}catch(s){throw Ke.error("Got an error setting users to global."),Ke.error(s),s}return qR.signalUserChange(new VR(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(QX,"dropUser");async function JX(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=FR.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await KX(r)}catch(s){throw Ke.error("Got an error searching for a role."),Ke.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw Ke.error(r),r}return t}a(JX,"userInfo");async function XX(){let e;try{e=await zh()}catch(t){throw Ke.error("Got an error listing users."),Ke.error(t),t}try{e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token})}catch{throw new Error("there was an error massaging the user data")}return[...e.values()]}a(XX,"listUsersExternal");async function zh(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await jh(e)}catch(o){throw Ke.error("Got an error searching for roles."),Ke.error(o),o}let r={};for(let o of t)r[o.id]=FR.cloneDeep(o);if(Object.keys(r).length===0)return null;let n={schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]},s;try{s=await jh(n)}catch(o){throw Ke.error("Got an error searching for users."),Ke.error(o),o}let i=new Map;for(let o of s)o=FR.cloneDeep(o),o.role=r[o.role],ZX(o.role),i.set(o.username,o);return i}catch(e){throw Ke.error("got an error listing users"),Ke.error(e),Hn.errorizeMessage(e)}return null}a(zh,"listUsers");function ZX(e){try{if(!e){Ke.error("invalid user role found.");return}e.permission.system||(e.permission.system={}),e.permission.system.tables||(e.permission.system.tables={});for(let t of Object.keys(qX)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){Ke.error("Got an error trying to set system permissions."),Ke.error(t)}}a(ZX,"appendSystemTablesToRole");async function Hl(){try{let e=await zh();global.hdb_users=e}catch(e){throw Ke.error(e),e}}a(Hl,"setUsersToGlobal");async function jL(e,t,r=!0){global.hdb_users||await Hl();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw Ri(new Error,kR.GENERIC_AUTH_FAIL,Ai.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw Ri(new Error,kR.USER_INACTIVE,Ai.UNAUTHORIZED,void 0,void 0,!0);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(HL.get(t)===n.password)return s;if(GR.validate(n.password,t))HL.set(t,n.password);else throw Ri(new Error,kR.GENERIC_AUTH_FAIL,Ai.UNAUTHORIZED,void 0,void 0,!0)}return s}a(jL,"findAndValidateUser");async function eZ(){global.hdb_users||await Hl();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(eZ,"getSuperUser");async function tZ(){let e=await zh(),t=GX.getConfigFromFile(vL.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!Hn.isEmpty(r)&&r?.role?.role===vL.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=$R.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+BL.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+BL.SERVER_SUFFIX.ADMIN,r}a(tZ,"getClusterUser");var zL=[];KR.invalidateUser=function(e){for(let t of zL)try{t(e)}catch(r){VX.error("Error invalidating user",r)}};KR.onInvalidatedUser=function(e){zL.push(e)}});var m_=N((HAe,eM)=>{"use strict";var _c=W(),kn=M(),rZ=VP(),vAe=ls(),BAe=ro(),nZ=xn(),{validateEvent:JL}=qs(),p_=Bn(),sZ=require("process"),{resetDatabases:iZ}=(Pe(),oe(lt)),oZ={[kn.ITC_EVENT_TYPES.SCHEMA]:aZ,[kn.ITC_EVENT_TYPES.USER]:ZL};async function aZ(e){let t=JL(e);if(t){_c.error(t);return}_c.trace("ITC schemaHandler received schema event:",e),await rZ(e.message),await cZ(e.message)}a(aZ,"schemaHandler");async function cZ(e){try{p_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),p_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),p_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=iZ();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){_c.error(t)}}a(cZ,"syncSchemaMetadata");var XL=[];async function ZL(e){try{try{p_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),p_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){_c.warn(r)}let t=JL(e);if(t){_c.error(t);return}_c.trace(`ITC userHandler ${kn.HDB_ITC_CLIENT_PREFIX}${sZ.pid} received user event:`,e),await nZ.setUsersToGlobal();for(let r of XL)r()}catch(t){_c.error(t)}}a(ZL,"userHandler");ZL.addListener=function(e){XL.push(e)};eM.exports=oZ});var qs=N(($Ae,rM)=>{"use strict";var kAe=W(),YR=te(),lZ=M(),{ITC_ERRORS:S_}=Dn(),{parentPort:FAe,threadId:uZ,isMainThread:dZ,workerData:GAe}=require("worker_threads"),{onMessageFromWorkers:_Z,broadcast:qAe,broadcastWithAcknowledgement:fZ}=dt();rM.exports={sendItcEvent:EZ,validateEvent:tM,SchemaEventMsg:hZ,UserEventMsg:pZ};var Qh;_Z(async(e,t)=>{Qh=Qh||m_(),tM(e),Qh[e.type]&&await Qh[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function EZ(e){return!dZ&&e.message&&(e.message.originator=uZ),fZ(e)}a(EZ,"sendItcEvent");function tM(e){if(typeof e!="object")return S_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||YR.isEmpty(e.type))return S_.MISSING_TYPE;if(!e.hasOwnProperty("message")||YR.isEmpty(e.message))return S_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||YR.isEmpty(e.message.originator))return S_.MISSING_ORIGIN;if(lZ.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return S_.INVALID_EVENT(e.type)}a(tM,"validateEvent");function hZ(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(hZ,"SchemaEventMsg");function pZ(e){this.originator=e}a(pZ,"UserEventMsg")});var no=N((YAe,oM)=>{"use strict";var nM=M(),KAe=te(),Jh=W(),sM=GP(),xl,{sendItcEvent:iM}=qs();function mZ(e){try{Jh.info("signalSchemaChange called with message:",e),xl=xl||m_();let t=new sM(nM.ITC_EVENT_TYPES.SCHEMA,e);return xl.schema(t),iM(t)}catch(t){Jh.error(t)}}a(mZ,"signalSchemaChange");function SZ(e){try{Jh.trace("signalUserChange called with message:",e),xl=xl||m_();let t=new sM(nM.ITC_EVENT_TYPES.USER,e);return xl.user(t),iM(t)}catch(t){Jh.error(t)}}a(SZ,"signalUserChange");oM.exports={signalSchemaChange:mZ,signalUserChange:SZ}});var Xh=N((jAe,cM)=>{"use strict";var aM=te(),TZ=M(),gZ=W(),RZ=Bh(),AZ=vh(),yZ=no(),{SchemaEventMsg:bZ}=qs(),OZ="already exists in";cM.exports=NZ;async function NZ(e,t,r){if(aM.isEmptyOrZeroLength(r))return r;let n=[];aM.isEmptyOrZeroLength(t.attributes)||t.attributes.forEach(i=>{n.push(i.attribute)});let s=r.filter(i=>n.indexOf(i)<0);return s.length===0||await Promise.all(s.map(async i=>{await IZ(e,t.schema,t.name,i)})),s}a(NZ,"lmdbCheckForNewAttributes");async function IZ(e,t,r,n){let s=new AZ(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await wZ(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(OZ))gZ.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(IZ,"createNewAttribute");async function wZ(e){let t;return t=await RZ(e),yZ.signalSchemaChange(new bZ(process.pid,TZ.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(wZ,"createAttribute")});var kl=N((QAe,lM)=>{"use strict";var WR=class{static{a(this,"LMDBTransactionObject")}constructor(t,r,n,s,i=void 0){this.operation=t,this.user_name=r,this.timestamp=n,this.hash_values=s,this.origin=i}};lM.exports=WR});var dM=N((XAe,uM)=>{"use strict";var CZ=kl(),DZ=M().OPERATIONS_ENUM,jR=class extends CZ{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(DZ.INSERT,r,n,s,i),this.records=t}};uM.exports=jR});var fM=N((eye,_M)=>{"use strict";var PZ=kl(),LZ=M().OPERATIONS_ENUM,zR=class extends PZ{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(LZ.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};_M.exports=zR});var hM=N((rye,EM)=>{"use strict";var MZ=kl(),UZ=M().OPERATIONS_ENUM,QR=class extends MZ{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(UZ.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};EM.exports=QR});var mM=N((sye,pM)=>{"use strict";var vZ=kl(),BZ=M().OPERATIONS_ENUM,JR=class extends vZ{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(BZ.DELETE,n,s,t,i),this.original_records=r}};pM.exports=JR});var T_=N((aye,RM)=>{"use strict";var oye=require("path"),SM=ht(),HZ=dM(),xZ=fM(),kZ=hM(),FZ=mM(),Fl=Bt(),TM=te(),{CONFIG_PARAMS:GZ}=M(),gM=se();gM.initSync();var Zh=M().OPERATIONS_ENUM,{getTransactionAuditStorePath:qZ}=gt();RM.exports=$Z;async function $Z(e,t){if(gM.get(GZ.LOGGING_AUDITLOG)===!1)return;let r=qZ(e.schema,e.table),n=await SM.openEnvironment(r,e.table,!0),s=VZ(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){SM.initializeDBIs(n,Fl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Fl.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Fl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Fl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),TM.isEmpty(s.user_name)||n.dbis[Fl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Fl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a($Z,"writeTransaction");function VZ(e,t){let r=TM.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===Zh.INSERT)return new HZ(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zh.UPDATE)return new xZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zh.UPSERT)return new kZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zh.DELETE)return new FZ(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(VZ,"createTransactionObject")});var XR=N((uye,AM)=>{"use strict";var KZ=f_(),lye=Qd(),g_=M(),YZ=Jd(),WZ=sc().insertRecords,jZ=ht(),zZ=W(),QZ=Xh(),{getSchemaPath:JZ}=gt(),XZ=T_();AM.exports=ZZ;async function ZZ(e){try{let{schema_table:t,attributes:r}=KZ(e);YZ(e,r,t.hash_attribute),e.schema!==g_.SYSTEM_SCHEMA_NAME&&(r.includes(g_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(g_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(g_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(g_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await QZ(e.hdb_auth_header,t,r),s=JZ(e.schema,e.table),i=await jZ.openEnvironment(s,e.table),o=await WZ(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await XZ(e,o)}catch(c){zZ.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(ZZ,"lmdbCreateRecords")});var OM=N((_ye,bM)=>{"use strict";var yM=M(),e5=XR(),t5=Qd(),r5=require("fs-extra"),{getSchemaPath:n5}=gt();bM.exports=s5;async function s5(e){let t=[{name:e.schema,createddate:Date.now()}],r=new t5(yM.SYSTEM_SCHEMA_NAME,yM.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await e5(r),await r5.mkdirp(n5(e.schema))}a(s5,"lmdbCreateSchema")});var IM=N((Eye,NM)=>{"use strict";var ZR=class{static{a(this,"DeleteRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.deleted=t,this.skipped=r,this.txn_time=n,this.original_records=s}};NM.exports=ZR});var PM=N((Tye,DM)=>{"use strict";var wM=ht(),eA=cn(),tA=Dn().LMDB_ERRORS_ENUM,i5=Bt(),CM=W(),pye=te(),o5=require("lmdb"),a5=IM(),c5=M(),{OVERFLOW_MARKER:mye,MAX_SEARCH_KEY_LENGTH:Sye}=i5,l5=c5.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function u5(e,t,r,n){if(eA.validateEnv(e),t===void 0)throw new Error(tA.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(tA.IDS_REQUIRED):new Error(tA.IDS_MUST_BE_ITERABLE);try{let s=wM.listDBIs(e);wM.initializeDBIs(e,t,s);let i=new a5,o,c=[],l=[];for(let E=0,f=r.length;E<f;E++)try{o=r[E];let h=e.dbis[t].get(o);if(!h||n&&h[l5]>n){i.skipped.push(o);continue}let T=e.dbis[t].ifVersion(o,o5.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let m=0;m<s.length;m++){let g=s[m];if(!h.hasOwnProperty(g)||g===t)continue;let S=e.dbis[g],b=h[g];if(b!=null)try{let I=eA.getIndexedValues(b);if(I)for(let B=0,H=I.length;B<H;B++)S.remove(I[B],o)}catch{CM.warn(`cannot delete from attribute: ${g}, ${b}:${o}`)}}});c.push(T),l.push(o),i.original_records.push(h)}catch(h){CM.warn(h),i.skipped.push(o)}let u=[],d=await Promise.all(c);for(let E=0,f=d.length;E<f;E++)d[E]===!0?i.deleted.push(l[E]):(i.skipped.push(l[E]),u.push(E));let _=0;for(let E=0;E<u.length;E++){let f=u[E];i.original_records.splice(f-_,1),_++}return i.txn_time=eA.getNextMonotonicTime(),i}catch(s){throw s}}a(u5,"deleteRecords");DM.exports={deleteRecords:u5}});var R_=N((Rye,MM)=>{"use strict";var Gl=te(),d5=PM(),_5=ht(),{getSchemaPath:f5}=gt(),E5=T_(),h5=W();MM.exports=p5;async function p5(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Gl.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Gl.isEmptyOrZeroLength(e.hash_values)&&!Gl.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Gl.isEmpty(l)||e.hash_values.push(l)}}if(Gl.isEmptyOrZeroLength(e.hash_values))return LM([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Gl.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=f5(e.schema,e.table),i=await _5.openEnvironment(s,e.table),o=await d5.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await E5(e,o)}catch(c){h5.error(`unable to write transaction due to ${c.message}`)}return LM(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(p5,"lmdbDeleteRecords");function LM(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}a(LM,"createDeleteResponse")});var nA=N((bye,UM)=>{"use strict";var m5=M(),yye=cn();function rA(e,t){let r=Object.create(null);if(t.length===1&&m5.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(rA,"parseRow");function S5(e,t,r,n){let s=rA(r,e);n.push(s)}a(S5,"searchAll");function T5(e,t,r,n){let s=rA(r,e);n[t]=s}a(T5,"searchAllToMap");function g5(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(g5,"iterateDBI");function fc(e,t,r,n,s){let i=Object.create(null);i[s]=e;let o;n===s?o=e:(o=t,n!==void 0&&(i[n]=o)),r[0].push(o),r[1].push(i)}a(fc,"pushResults");function R5(e,t,r,n,s,i){t.toString().endsWith(e)&&fc(t,r,n,s,i)}a(R5,"endsWith");function A5(e,t,r,n,s,i){t.toString().includes(e)&&fc(t,r,n,s,i)}a(A5,"contains");function y5(e,t,r,n,s,i){t>e&&fc(t,r,n,s,i)}a(y5,"greaterThanCompare");function b5(e,t,r,n,s,i){t>=e&&fc(t,r,n,s,i)}a(b5,"greaterThanEqualCompare");function O5(e,t,r,n,s,i){t<e&&fc(t,r,n,s,i)}a(O5,"lessThanCompare");function N5(e,t,r,n,s,i){t<=e&&fc(t,r,n,s,i)}a(N5,"lessThanEqualCompare");UM.exports={parseRow:rA,searchAll:S5,searchAllToMap:T5,iterateDBI:g5,endsWith:R5,contains:A5,greaterThanCompare:y5,greaterThanEqualCompare:b5,lessThanCompare:O5,lessThanEqualCompare:N5,pushResults:fc}});var ql=N((Cye,GM)=>{"use strict";var Xo=ht(),Nye=W(),Fn=cn(),ep=Bt(),zt=Dn().LMDB_ERRORS_ENUM,Iye=te(),I5=M(),tp=nA(),{parseRow:w5}=tp,wye=require("lmdb"),{OVERFLOW_MARKER:vM,MAX_SEARCH_KEY_LENGTH:C5}=ep;function BM(e,t,r,n=!1,s=void 0,i=void 0){return Ec(e,t,r,(o,c)=>c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}))}a(BM,"iterateFullIndex");function A_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return Ec(e,t,r,(d,_,E,f)=>{let S={transaction:d,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return f===r?(S.values=!1,_.getRange(S).map(b=>({value:b}))):_.getRange(S)})}a(A_,"iterateRangeBetween");function Ec(e,t,r,n){let s=e.database||e,i=Xo.openDBI(s,r);i[ep.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&Xo.openDBI(s,t);let o;e.database?o=e:(o=e.useReadTransaction(),o.database=e);let c=n(o,i,s,t);return c.transaction=o,e.database||(c.onDone=()=>{o.done()}),c}a(Ec,"setupTransaction");function HM(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(vM)){if(!s)if(r)s=Xo.openDBI(e,r);else{let l=Xo.listDBIs(e);for(let u=0,d=l.length;u<d&&(s=Xo.openDBI(e,l[u]),!s[ep.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(HM,"getOverflowCheck");function D5(e,t,r,n=!1,s=void 0,i=void 0){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return Ec(e,t,t,(o,c,l)=>(rp(r),r=y_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>w5(u.value,r))))}a(D5,"searchAll");function P5(e,t,r,n=!1,s=void 0,i=void 0){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);rp(r),r=y_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of BM(e,t,t,n,s,i))o.set(c,tp.parseRow(l,r));return o}a(P5,"searchAllToMap");function L5(e,t,r=!1,n=void 0,s=void 0){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=BM(e,void 0,t,r,n,s),c=o.transaction,l=HM(c.database,c,void 0,t);for(let{key:u,value:d}of o){let _=l(u,d);i[_]===void 0&&(i[_]=[]),i[_].push(d)}return i}a(L5,"iterateDBI");function M5(e,t){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return Xo.statDBI(e,t).entryCount}a(M5,"countAll");function U5(e,t,r,n,s=!1,i=void 0,o=void 0){return Zo(e,r,n),Ec(e,t,r,(c,l,u,d)=>(n=Fn.convertKeyValueToWrite(n),d===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(_=>({key:n,value:_}))))}a(U5,"equals");function v5(e,t,r){return Zo(e,t,r),Xo.openDBI(e,t).getValuesCount(r)}a(v5,"count");function B5(e,t,r,n,s=!1,i=void 0,o=void 0){return Zo(e,r,n),Ec(e,null,r,(c,l)=>{n=Fn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let d;if(s===!0){let _;for(let E of l.getKeys({transaction:c,start:n}))if(!E.startsWith(n)){_=E;break}return _!==void 0&&(Number.isInteger(o)?o++:i++),d=l.getRange({transaction:c,start:_,end:void 0,reverse:s,limit:i,offset:o}).map(E=>{let{key:f}=E;if(f!==_){if(f.toString().startsWith(n))return E;if(u===!0)return d.DONE}}),d.filter(E=>E)}else return d=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(_=>{if(_.key.toString().startsWith(n))return _;if(u===!0)return d.DONE}),u?d:d.filter(_=>_)})}a(B5,"startsWith");function H5(e,t,r,n,s=!1,i=void 0,o=void 0){return xM(e,t,r,n,s,i,o,!0)}a(H5,"endsWith");function xM(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Zo(e,r,n),Ec(e,null,r,(l,u,d,_)=>{let E=HM(d,l,_,r);return o=Number.isInteger(o)?o:0,u.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(f=>{let h=f.toString();return h.endsWith(vM)?u.getValues(f,{transaction:l}).map(T=>{let m=E(f,T);if(c?m.endsWith(n):m.includes(n))return{key:m,value:T}}).filter(T=>T):(c?h.endsWith(n):h.includes(n))?u[ep.DBI_DEFINITION_NAME].is_hash_attribute?{key:f,value:f}:u.getValues(f,{transaction:l}).map(T=>({key:f,value:T})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(xM,"contains");function x5(e,t,r,n,s=!1,i=void 0,o=void 0){Zo(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),A_(e,t,r,n,l,s,i,o,!0,!1)}a(x5,"greaterThan");function k5(e,t,r,n,s=!1,i=void 0,o=void 0){Zo(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),A_(e,t,r,n,l,s,i,o,!1,!1)}a(k5,"greaterThanEqual");function F5(e,t,r,n,s=!1,i=void 0,o=void 0){Zo(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),A_(e,t,r,l,n,s,i,o,!1,!0)}a(F5,"lessThan");function G5(e,t,r,n,s=!1,i=void 0,o=void 0){Zo(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),A_(e,t,r,l,n,s,i,o,!1,!1)}a(G5,"lessThanEqual");function q5(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Fn.validateEnv(e),r===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(zt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(zt.END_VALUE_REQUIRED);if(n=Fn.convertKeyValueToWrite(n),s=Fn.convertKeyValueToWrite(s),n>s)throw new Error(zt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return A_(e,t,r,n,s,i,o,c)}a(q5,"between");function $5(e,t,r,n){Fn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(rp(r),r=y_(s,r),n===void 0)throw new Error(zt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=tp.parseRow(c,r)),o}a($5,"searchByHash");function V5(e,t,r){Fn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(V5,"checkHashExists");function K5(e,t,r,n,s=[]){return FM(e,t,r,n,s),kM(e,t,r,n,s).map(i=>i[1])}a(K5,"batchSearchByHash");function Y5(e,t,r,n,s=[]){FM(e,t,r,n,s);let i=new Map;for(let[o,c]of kM(e,t,r,n,s))i.set(o,c);return i}a(Y5,"batchSearchByHashToMap");function kM(e,t,r,n,s=[]){return Ec(e,t,t,(i,o,c)=>{r=y_(c,r);let l=r.length<3;return n.map(u=>{let d=c.dbis[t].get(u,{transaction:i,lazy:l});if(d)return[u,tp.parseRow(d,r)];s.push(u)}).filter(u=>u)})}a(kM,"batchHashSearch");function FM(e,t,r,n,s){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(rp(r),n==null)throw new Error(zt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(zt.IDS_MUST_BE_ITERABLE)}a(FM,"initializeBatchSearchByHash");function rp(e){if(!Array.isArray(e))throw e===void 0?new Error(zt.FETCH_ATTRIBUTES_REQUIRED):new Error(zt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(rp,"validateFetchAttributes");function Zo(e,t,r){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.SEARCH_VALUE_REQUIRED);if(r?.length>C5)throw new Error(zt.SEARCH_VALUE_TOO_LARGE)}a(Zo,"validateComparisonFunctions");function y_(e,t){return t.length===1&&I5.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=Xo.listDBIs(e)),t}a(y_,"setGetWholeRowAttributes");GM.exports={searchAll:D5,searchAllToMap:P5,count:v5,countAll:M5,equals:U5,startsWith:B5,endsWith:H5,contains:xM,searchByHash:$5,setGetWholeRowAttributes:y_,batchSearchByHash:K5,batchSearchByHashToMap:Y5,checkHashExists:V5,iterateDBI:L5,greaterThan:x5,greaterThanEqual:k5,lessThan:F5,lessThanEqual:G5,between:q5}});var $l=N((Pye,YM)=>{var qM=require("lodash"),$M=Tt(),He=require("joi"),W5=te(),{hdb_schema_table:b_,checkValidTable:VM,hdb_table:KM,hdb_database:np}=Ti(),{handleHDBError:j5,hdb_errors:z5}=_e(),{getDatabases:Q5}=(Pe(),oe(lt)),{HTTP_STATUS_CODES:J5}=z5,X5=He.object({database:np,schema:np,table:KM,search_attribute:b_,search_value:He.any().required(),get_attributes:He.array().min(1).items(He.alternatives(b_,He.object())).optional(),desc:He.bool(),limit:He.number().integer().min(1),offset:He.number().integer().min(0)}),Z5=He.object({database:np,schema:np,table:KM,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(b_,He.object())).optional(),sort:He.object({attribute:He.alternatives(b_,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(b_,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()});YM.exports=function(e,t){let r=null;switch(t){case"value":r=$M.validateBySchema(e,X5);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(VM("database",e.schema)),i(VM("table",e.table)),e.hash_values?Array.isArray(e.hash_values)?e.hash_values.every(o=>typeof o=="string"||typeof o=="number")||i("'hash_values' must be strings or numbers"):i("'hash_values' must be an array"):i("'hash_values' is required"),e.get_attributes?Array.isArray(e.get_attributes)?e.get_attributes.length===0?i("'get_attributes' must contain at least 1 item"):e.get_attributes.every(o=>typeof o=="string"||typeof o=="number")||i("'get_attributes' must be strings or numbers"):i("'get_attributes' must be an array"):i("'get_attributes' is required"),s&&(r=new Error(s.trim()));break;case"conditions":r=$M.validateBySchema(e,Z5);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=W5.checkGlobalSchemaTable(e.schema,e.table);if(s)return j5(new Error,s,J5.NOT_FOUND);let o=Q5()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(d=>{for(let _=0,E=d.conditions.length;_<E;_++){let f=d.conditions[_];f.conditions?l(f):c.push(f.search_attribute)}},"addConditions");t==="conditions"&&l(e);let u=qM.filter(c,d=>d!=="*"&&!d.startsWith?.("$")&&d.attribute!=="*"&&!Array.isArray(d)&&!d.name&&!qM.some(o,_=>_===d||_.attribute===d||_.attribute===d.attribute));if(u&&u.length>0){let d=u.join(", ");return d=d.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${d}'`)}}return r}});var sA=N((Mye,WM)=>{"use strict";var e6=ht(),t6=$l(),{getSchemaPath:r6}=gt();WM.exports=n6;function n6(e){let t=t6(e,"hashes");if(t)throw t;let r=r6(e.schema,e.table);return e6.openEnvironment(r,e.table)}a(n6,"initialize")});var iA=N((vye,jM)=>{"use strict";var s6=ql(),i6=sA();jM.exports=o6;async function o6(e){let t=await i6(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return s6.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(o6,"lmdbGetDataByHash")});var Vl=N((Hye,zM)=>{"use strict";var oA=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};zM.exports=oA});var JM=N((Fye,QM)=>{"use strict";var kye=Vl(),a6=ql(),c6=sA();QM.exports=l6;async function l6(e){let t=await c6(e),r=global.hdb_schema[e.schema][e.table];return a6.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(l6,"lmdbSearchByHash")});var $s=N((qye,XM)=>{"use strict";var aA=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,u=void 0,d=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=u,this.offset=d}};XM.exports=aA});var sp=N((Vye,sU)=>{"use strict";var Wr=ql(),u6=ht(),d6=te(),xe=Bt(),hc=M(),_6=Zi(),ZM=Dn().LMDB_ERRORS_ENUM,{getSchemaPath:f6}=gt(),so=hc.SEARCH_WILDCARDS;async function E6(e,t,r){let n;e.schema===hc.SYSTEM_SCHEMA_NAME?n=_6[e.table]:n=global.hdb_schema[e.schema][e.table];let s=nU(e,n.hash_attribute,r,t);return tU(e,s,n.hash_attribute,r)}a(E6,"prepSearch");async function tU(e,t,r,n){let s=f6(e.schema,e.table),i=await u6.openEnvironment(s,e.table),o=rU(i,e,t,r),c=o.transaction||i;if([xe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,xe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,xe.SEARCH_TYPES.SEARCH_ALL,xe.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(h6(e,r)===!1){let d=e.search_attribute;if(d===r)return n?eU(o,()=>!0):o.map(E=>({[r]:E.key}));let _=a(E=>({[r]:E.value,[d]:E.key}),"toObject");return n?eU(o,_):o.map(_)}let u=e.search_attribute===r?o.map(d=>d.key):o.map(d=>d.value);return n===!0?Wr.batchSearchByHashToMap(c,r,e.get_attributes,u):Wr.batchSearchByHash(c,r,e.get_attributes,u)}a(tU,"executeSearch");function rU(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case xe.SEARCH_TYPES.EQUALS:s=Wr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case xe.SEARCH_TYPES.CONTAINS:s=Wr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case xe.SEARCH_TYPES.ENDS_WITH:case xe.SEARCH_TYPES._ENDS_WITH:s=Wr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case xe.SEARCH_TYPES.STARTS_WITH:case xe.SEARCH_TYPES._STARTS_WITH:s=Wr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case xe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Wr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case xe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Wr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case xe.SEARCH_TYPES.SEARCH_ALL:return Wr.searchAll(e,n,t.get_attributes,o,c,l);case xe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Wr.searchAllToMap(e,n,t.get_attributes,o,c,l);case xe.SEARCH_TYPES.BETWEEN:s=Wr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case xe.SEARCH_TYPES.GREATER_THAN:case xe.SEARCH_TYPES._GREATER_THAN:s=Wr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case xe.SEARCH_TYPES.GREATER_THAN_EQUAL:case xe.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Wr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case xe.SEARCH_TYPES.LESS_THAN:case xe.SEARCH_TYPES._LESS_THAN:s=Wr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case xe.SEARCH_TYPES.LESS_THAN_EQUAL:case xe.SEARCH_TYPES._LESS_THAN_EQUAL:s=Wr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(rU,"searchByType");function eU(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(eU,"createMapFromIterable");function h6(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(h6,"checkToFetchMore");function nU(e,t,r,n){if(d6.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),o=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),so.indexOf(s)>-1)return r===!0?xe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:xe.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(so[0])<0&&s.indexOf(so[1])<0)return c===!0?r===!0?xe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:xe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:xe.SEARCH_TYPES.EQUALS;if(so.indexOf(i)>=0&&so.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),xe.SEARCH_TYPES.CONTAINS;if(so.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),xe.SEARCH_TYPES.ENDS_WITH;if(so.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),xe.SEARCH_TYPES.STARTS_WITH;if(s.includes(so[0])||s.includes(so[1]))return xe.SEARCH_TYPES.EQUALS;throw new Error(ZM.UNKNOWN_SEARCH_TYPE)}else switch(n){case hc.VALUE_SEARCH_COMPARATORS.BETWEEN:return xe.SEARCH_TYPES.BETWEEN;case hc.VALUE_SEARCH_COMPARATORS.GREATER:return xe.SEARCH_TYPES.GREATER_THAN;case hc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return xe.SEARCH_TYPES.GREATER_THAN_EQUAL;case hc.VALUE_SEARCH_COMPARATORS.LESS:return xe.SEARCH_TYPES.LESS_THAN;case hc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return xe.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(ZM.UNKNOWN_SEARCH_TYPE)}}a(nU,"createSearchTypeFromSearchObject");sU.exports={executeSearch:tU,createSearchTypeFromSearchObject:nU,prepSearch:E6,searchByType:rU}});var oU=N((Wye,iU)=>{"use strict";var Yye=$s(),p6=$l(),m6=te(),S6=M(),T6=sp();iU.exports=g6;function g6(e,t){if(!m6.isEmpty(t)&&S6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=p6(e,"value");if(n)throw n;return T6.prepSearch(e,t,!0)}a(g6,"lmdbGetDataByValue")});var O_=N((Qye,aU)=>{"use strict";var zye=$s(),R6=$l(),A6=te(),y6=M(),b6=sp();aU.exports=O6;async function O6(e,t){if(!A6.isEmpty(t)&&y6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=R6(e,"value");if(n)throw n;return b6.prepSearch(e,t,!1)}a(O6,"lmdbSearchByValue")});var lU=N((Zye,cU)=>{"use strict";var Xye=Bt(),cA=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}},lA=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},uA=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};cU.exports={SearchByConditionsObject:cA,SearchCondition:lA,SortAttribute:uA}});var EU=N((nbe,fU)=>{"use strict";var tbe=lU().SearchByConditionsObject,N6=$s(),I6=$l(),dA=ql(),ip=Bt(),{Resource:rbe}=(Vs(),oe(_A)),_U=sp(),w6=nA(),C6=require("lodash"),{getSchemaPath:D6}=gt(),uU=ht(),{handleHDBError:P6,hdb_errors:L6}=_e(),{HTTP_STATUS_CODES:M6}=L6,U6=1e8;fU.exports=v6;async function v6(e){let t=I6(e,"conditions");if(t)throw P6(t,t.message,M6.BAD_REQUEST,void 0,void 0,!0);e.operator=e.operator?e.operator.toLowerCase():void 0,e.offset=Number.isInteger(e.offset)?e.offset:0;let r=D6(e.schema,e.table),n=await uU.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)uU.openDBI(n,u.search_attribute);let i=C6.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let d=u.search_type;d===ip.SEARCH_TYPES.EQUALS?u.estimated_count=dA.count(n,u.search_attribute,u.search_value):d===ip.SEARCH_TYPES.CONTAINS||d===ip.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=U6}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await dU(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let u=n.dbis[s.hash_attribute],d=i.slice(1).map(_U.filterByType),_=d.length,E=dA.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(f=>u.get(f,{transaction:o,lazy:!0})),_>0&&(l=l.filter(f=>{for(let h=0;h<_;h++)if(!d[h](f))return!1;return!0})),(e.offset||e.limit!==void 0)&&(l=l.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),l=l.map(f=>w6.parseRow(f,E))}else{for(let _=1;_<i.length;_++){let E=i[_],f=await dU(o,e,E,s.hash_attribute);c=c.concat(f)}let u=new Set,d=e.offset||0;c=c.filter(_=>u.has(_)?!1:(u.add(_),!0)).slice(d,e.limit&&e.limit+d),l=dA.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(v6,"lmdbSearchByConditions");async function dU(e,t,r,n){let s=new N6(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===ip.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,_U.searchByType(e,s,i,n).map(o=>o.value)}a(dU,"executeConditionSearch")});var N_=N((ibe,hU)=>{"use strict";var B6=M().OPERATIONS_ENUM,fA=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=B6.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};hU.exports=fA});var EA=N((abe,yU)=>{"use strict";var TU=$s(),gU=N_(),RU=O_(),AU=R_(),dn=M(),pU=te(),mU=ht(),{getTransactionAuditStorePath:H6,getSchemaPath:x6}=gt(),SU=W();yU.exports=k6;async function k6(e){try{if(pU.isEmpty(global.hdb_schema[e.schema])||pU.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await F6(e),await G6(e);let t=x6(e.schema,e.table);try{await mU.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")SU.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=H6(e.schema,e.table);await mU.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")SU.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(k6,"lmdbDropTable");async function F6(e){let t=new TU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await RU(t)),n=[];for(let i=0;i<r.length;i++){let o=r[i];n.push(o.id)}if(n.length===0)return;let s=new gU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await AU(s)}a(F6,"deleteAttributesFromSystem");async function G6(e){let t=new TU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await RU(t))}catch(i){throw i}for(let i=0;i<r.length;i++){let o=r[i];o.name===e.table&&o.schema===e.schema&&(n=o)}if(!n)throw new Error(`${e.schema}.${e.table} was not found`);let s=new gU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await AU(s)}catch(i){throw i}}a(G6,"dropTableFromSystem")});var OU=N((lbe,bU)=>{"use strict";var q6=require("fs-extra"),$6=$s(),V6=Vl(),K6=N_(),Y6=EA(),W6=R_(),j6=iA(),z6=O_(),io=M(),{getSchemaPath:Q6}=gt(),{handleHDBError:J6,hdb_errors:X6}=_e(),{HDB_ERROR_MSGS:Z6,HTTP_STATUS_CODES:e8}=X6;bU.exports=t8;async function t8(e){let t;try{t=await r8(e.schema);let r=new $6(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await z6(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await Y6(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new K6(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await W6(s);let i=Q6(t);await q6.remove(i)}catch(r){throw r}}a(t8,"lmdbDropSchema");async function r8(e){let t=new V6(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await j6(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw J6(new Error,Z6.SCHEMA_NOT_FOUND(e),e8.NOT_FOUND,void 0,void 0,!0);return n}a(r8,"validateDropSchema")});var I_=N((dbe,NU)=>{"use strict";var hA=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};NU.exports=hA});var mA=N((Ebe,IU)=>{"use strict";var n8=require("fs-extra"),op=ht(),{getTransactionAuditStorePath:s8}=gt(),pA=Bt(),fbe=I_();IU.exports=i8;async function i8(e){let t;try{let r=s8(e.schema,e.table);await n8.mkdirp(r),t=await op.createEnvironment(r,e.table,!0)}catch(r){throw r.message=`unable to create transactions audit environment for ${e.schema}.${e.table} due to: ${r.message}`,r}try{op.createDBI(t,pA.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),op.createDBI(t,pA.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),op.createDBI(t,pA.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(i8,"createTransactionsAuditEnvironment")});var DU=N((mbe,CU)=>{"use strict";var SA=M(),wU=ht(),o8=sc(),{getSystemSchemaPath:a8,getSchemaPath:c8}=gt(),pbe=Zi(),l8=Bh(),TA=vh(),u8=W(),d8=mA();CU.exports=_8;async function _8(e,t){let r=c8(t.schema,t.table),n=new TA(t.schema,t.table,SA.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new TA(t.schema,t.table,SA.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new TA(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await wU.createEnvironment(r,t.table),e!==void 0){let o=await wU.openEnvironment(a8(),SA.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await o8.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 gA(n),await gA(s),await gA(i)}await d8(t)}catch(o){throw o}}a(_8,"lmdbCreateTable");async function gA(e){try{await l8(e)}catch(t){u8.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(gA,"createAttribute")});var LU=N((Tbe,PU)=>{"use strict";var f8=f_(),E8=Jd(),h8=Xh(),w_=M(),p8=sc().updateRecords,m8=ht(),{getSchemaPath:S8}=gt(),T8=T_(),g8=W();PU.exports=R8;async function R8(e){try{let{schema_table:t,attributes:r}=f8(e);E8(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 h8(e.hdb_auth_header,t,r),s=S8(e.schema,e.table),i=await m8.openEnvironment(s,e.table),o=await p8(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await T8(e,o)}catch(c){g8.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(R8,"lmdbUpdateRecords")});var UU=N((Rbe,MU)=>{"use strict";var A8=M().OPERATIONS_ENUM,RA=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=A8.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};MU.exports=RA});var BU=N((bbe,vU)=>{"use strict";var ybe=UU(),y8=f_(),b8=Jd(),O8=Xh(),C_=M(),N8=sc().upsertRecords,I8=ht(),{getSchemaPath:w8}=gt(),C8=T_(),D8=W(),{handleHDBError:P8,hdb_errors:L8}=_e();vU.exports=M8;async function M8(e){let t;try{t=y8(e)}catch(l){throw P8(l,l.message,L8.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;b8(e,n,r.hash_attribute),e.schema!==C_.SYSTEM_SCHEMA_NAME&&(n.includes(C_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(C_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(C_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(C_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await O8(e.hdb_auth_header,r,n),i=w8(e.schema,e.table),o=await I8.openEnvironment(i,e.table),c=await N8(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await C8(e,c)}catch(l){D8.error(`unable to write transaction due to ${l.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:s,txn_time:c.txn_time}}a(M8,"lmdbUpsertRecords")});var xU=N((Nbe,HU)=>{"use strict";var AA=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};HU.exports=AA});var FU=N((wbe,kU)=>{"use strict";var yA=class{static{a(this,"DeleteAuditLogsBeforeResults")}constructor(t=void 0,r=void 0,n=0){this.start_timestamp=t,this.end_timestamp=r,this.transactions_deleted=n}};kU.exports=yA});var $U=N((Pbe,qU)=>{"use strict";var bA=ht(),{getTransactionAuditStorePath:U8}=gt(),Dbe=xU(),D_=Bt(),v8=te(),GU=FU(),B8=require("util").promisify,H8=B8(setTimeout),x8=1e4,k8=100;qU.exports=F8;async function F8(e){let t=U8(e.schema,e.table),r=await bA.openEnvironment(t,e.table,!0),n=bA.listDBIs(r);bA.initializeDBIs(r,D_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new GU;do s=await G8(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 H8(k8);while(s.transactions_deleted>0);return i}a(F8,"deleteAuditLogsBefore");async function G8(e,t){let r=new GU;try{let n=e.dbis[D_.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[D_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];v8.isEmpty(c)||(s=e.dbis[D_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[D_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>x8)break}return await s,r}catch(n){throw n}}a(G8,"deleteTransactions")});var KU=N((Mbe,VU)=>{"use strict";var OA=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};VU.exports=OA});var WU=N((Bbe,YU)=>{"use strict";var q8=$s(),$8=N_(),vbe=KU(),yi=M(),V8=te(),NA=ht(),K8=Zi(),Y8=O_(),W8=R_(),{getSchemaPath:j8}=gt();YU.exports=z8;async function z8(e,t=!0){let r;e.schema===yi.SYSTEM_SCHEMA_NAME?r=K8[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await J8(e),s=j8(e.schema,e.table),i=await NA.openEnvironment(s,e.table);return t===!0&&await Q8(e,i,r.hash_attribute),NA.dropDBI(i,e.attribute),n}a(z8,"lmdbDropAttribute");async function Q8(e,t,r){let n=NA.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let u={};for(let d in c)d!==i&&(u[d]=c[d]);s=t.dbis[r].put(o,u,l)}await s}a(Q8,"removeAttributeFromAllObjects");async function J8(e){let t=new q8(yi.SYSTEM_SCHEMA_NAME,yi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await Y8(t)).filter(o=>o[yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(V8.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new $8(yi.SYSTEM_SCHEMA_NAME,yi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return W8(i)}a(J8,"dropAttributeFromSystem")});var ZU=N((kbe,XU)=>{"use strict";var IA=ht(),Kl=Bt(),xbe=cn(),wA=M(),jU=te(),{getTransactionAuditStorePath:X8}=gt(),Z8=ql(),ap=kl(),e9=W();XU.exports=t9;async function t9(e){let t=X8(e.schema,e.table),r=await IA.openEnvironment(t,e.table,!0),n=IA.listDBIs(r);IA.initializeDBIs(r,Kl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case wA.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return zU(r,e.search_values);case wA.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,n9(r,e.search_values,s);case wA.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return r9(r,e.search_values);default:return zU(r)}}a(t9,"readAuditLog");function zU(e,t=[0,Date.now()]){jU.isEmpty(t[0])&&(t[0]=0),jU.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[Kl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let s of r.getKeys({start:t[1]}))if(s!==t[1]){n=s;break}return r.getRange({start:t[0],end:n}).map(({value:s})=>Object.assign(new ap,s))}a(zU,"searchTransactionsByTimestamp");function r9(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[Kl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,JU(e,i))}return Object.fromEntries(r)}a(r9,"searchTransactionsByUsername");function n9(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],d=Z8.equals(e,Kl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Kl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:_}of d){let E=Number(_);n.has(E)?n.get(E).push(u.toString()):n.set(E,[u.toString()])}}let s=Array.from(n.keys()),i=JU(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,d=n.get(u);QU(l,"records",r,d,o),QU(l,"original_records",r,d,o)}return Object.fromEntries(o)}a(n9,"searchTransactionsByHashValues");function QU(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let u=s.get(l),d=u[u.length-1];if(d.timestamp===i)d[t]=[c];else{let _=new ap(e.operation,e.user_name,i,void 0);_[t]=[c],u.push(_)}}else{let u=new ap(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}a(QU,"loopRecords");function JU(e,t){let r=[];try{let n=e.dbis[Kl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let s=0;s<t.length;s++)try{let i=n.get(t[s]);if(i){let o=Object.assign(new ap,i);r.push(o)}}catch(i){e9.warn(i)}return r}catch(n){throw n}}a(JU,"batchSearchTransactions")});var tv=N(($be,ev)=>{"use strict";var{getSchemaPath:Gbe}=gt(),qbe=ht(),{database:s9}=(Pe(),oe(lt));ev.exports={writeTransaction:i9};async function i9(e,t,r){return s9({database:e,table:t}).transaction(r)}a(i9,"writeTransaction")});var iv=N((Kbe,sv)=>{"use strict";var{getSchemaPath:rv}=gt(),nv=ht();sv.exports={flush:o9,resetReadTxn:a9};async function o9(e,t){return(await nv.openEnvironment(rv(e,t),t.toString())).flushed}a(o9,"flush");async function a9(e,t){try{(await nv.openEnvironment(rv(e,t),t.toString())).resetReadTxn()}catch{}}a(a9,"resetReadTxn")});var lv=N((Wbe,cv)=>{"use strict";var{Readable:c9}=require("stream"),{getDatabases:l9}=(Pe(),oe(lt)),{readSync:u9,openSync:d9,createReadStream:ov}=require("fs"),{open:_9}=require("lmdb"),av=o_(),f9=a_(),{AUDIT_STORE_OPTIONS:E9}=(Ji(),oe(uv)),{INTERNAL_DBIS_NAME:h9,AUDIT_STORE_NAME:p9}=Bt();cv.exports=S9;var CA=32768,m9=100;async function S9(e){let t=e.database||e.schema||"data",r=l9()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let u=r[s[0]];if(!u)throw new Error(`Can not find table ${s[0]}`);let d=u.dbisDB,_=_9({noSync:!0,maxDbs:f9.MAX_DBS}),E,f=_.openDB(h9,new av(!1)),h=d.useReadTransaction(),T=0,m=a(async function(S,b){b.encoding="binary",b.encoder=void 0;let I=_.openDB(S,b),B=d.openDB(S,b);for(let{key:H,version:X,value:Y}of B.getRange({start:null,transaction:h,versions:B.useVersions}))E=I.put(H,Y,X),T++%m9===0&&(await new Promise(V=>setTimeout(V,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:S,value:b}of d.getRange({transaction:h,start:!1}))if(s.some(I=>S.startsWith?.(I+"/"))){f.put(S,b);let[,I]=S.split("/"),B=!I,H=new av(!B,B);await m(S,H)}e.include_audit&&await m(p9,{...E9}),await E;let g=ov(_.path);return g.headers=l(),g.on("close",()=>{h.done(),_.close()}),g}let o=r[Object.keys(r)[0]].primaryStore,c=d9(o.path);return o.transaction(()=>{let u=Buffer.alloc(CA);u9(c,u,0,CA),o.resetReadTxn();let d=o.useReadTransaction();d.renew();let _=ov(null,{fd:c,start:CA}),E=new c9.from(async function*(){yield u;for await(let f of _)d.openTimer&&(d.openTimer=0),yield f;d.done()}());return E.headers=l(),E});function l(){let u=new Map;return u.set("content-type","application/octet-stream"),u.set("content-disposition",`attachment; filename="${t}"`),u.set("date",n),u}}a(S9,"getBackup")});var fv=N((zbe,_v)=>{"use strict";var T9=W(),{handleHDBError:g9}=_e(),R9=jD(),A9=Bh(),y9=XR(),b9=OM(),O9=R_(),N9=iA(),I9=JM(),w9=oU(),C9=O_(),D9=EU(),P9=OU(),L9=DU(),M9=LU(),U9=BU(),v9=$U(),B9=EA(),H9=WU(),x9=ZU(),k9=tv(),dv=iv(),F9=lv(),DA=class extends R9{static{a(this,"LMDBBridge")}async searchByConditions(t){return D9(t)}async getDataByHash(t){return await N9(t)}async searchByHash(t){return await I9(t)}async getDataByValue(t,r){return await w9(t,r)}async searchByValue(t){return await C9(t)}async createSchema(t){return await b9(t)}async dropSchema(t){return await P9(t)}async createTable(t,r){return await L9(t,r)}async dropTable(t){return await B9(t)}async createAttribute(t){return await A9(t)}async createRecords(t){return await y9(t)}async updateRecords(t){return await M9(t)}async upsertRecords(t){try{return await U9(t)}catch(r){throw g9(r,null,null,T9.ERR,r)}}async deleteRecords(t){return await O9(t)}async dropAttribute(t){return await H9(t)}async deleteAuditLogsBefore(t){return await v9(t)}async readAuditLog(t){return await x9(t)}writeTransaction(t,r,n){return k9.writeTransaction(t,r,n)}flush(t,r){return dv.flush(t,r)}resetReadTxn(t,r){return dv.resetReadTxn(t,r)}getBackup(t){return F9(t)}};_v.exports=DA});function Rv(e){LA=e}function V9(){$9=setInterval(function(){for(let e of PA)if(e.stale){let t=e[ke]?.url;mv.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},q9).unref()}var MA,pv,mv,Sv,Tv,gv,Ev,PA,G9,P_,hv,LA,pc,cp,q9,$9,lp=Oe(()=>{MA=L(cn()),pv=L(_e()),mv=L(W());Vs();Sv=L(se()),Tv=L(M()),gv=L(te()),Ev=100,PA=new Set,G9=(0,gv.convertToMS)(Sv.get(Tv.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(Rv,"replicationConfirmation");pc=class e{static{a(this,"DatabaseTransaction")}writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxnsUsed=1,this.readTxn.openTimer&&(this.readTxn.openTimer=0),PA.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(PA.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(P_&&!this.overloadChecked&&performance.now()-hv>G9)throw new pv.ServerError("Outstanding write transactions have too long of queue, please try again later",503);this.overloadChecked=!0}addWrite(t){if(this.open===0)throw new Error("Can not use a transaction that is no longer open");if(this.open===2){let r=new e;return r.addWrite(t),r.commit({})}else this.writes.push(t)}removeWrite(t){let r=this.writes.indexOf(t);r>-1&&(this.writes[r]=null)}commit(t={}){let r=this.timestamp;r||(r=this.timestamp=t.timestamp||(0,MA.getNextMonotonicTime)()),t.timestamp||(t.timestamp=r);let n=t.retries||0;if(this.validated<this.writes.length)try{let _=this.validated;this.validated=this.writes.length;for(let f=_;f<this.validated;f++)this.writes[f]?.validate?.(this.timestamp);let E;for(let f=_;f<this.validated;f++){let h=this.writes[f];h&&(h.before||h.beforeIntermediate)&&(E=!0)}if(E)return(async()=>{try{for(let f=0;f<2;f++){let h;for(let T=_;T<this.validated;T++){let m=this.writes[T];if(!m)continue;let g=m[f===0?"before":"beforeIntermediate"];if(g){let S=g();h?h.push?h.push(S):h=[h,S]:h=S}}h&&await(h.push?Promise.all(h):h)}}catch(f){throw this.abort(),f}return this.commit(t)})()}catch(_){throw this.abort(),_}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(_=>_);let c=a(_=>{_.commit(r,_.entry,n)},"doWrite"),l=a(()=>{let _=this.writes[o++];if(_)if(_.key){n>0&&(_.entry=_.store.getEntry(_.key));let E=_.store.ifVersion(_.key,_.entry?.version??null,l);s=s||E}else l();else for(let E of this.writes)c(E)},"nextCondition"),u=this.lmdbDb;if(this.writes.length>0&&(u?.retryRisk&&(u.retryRisk*=.99),this.writes.length+(u?.retryRisk||0)<Ev>>n?l():s=this.writes[0].store.transaction(()=>{for(let _ of this.writes)_.entry=_.store.getEntry(_.key),c(_);return!0})),s)return P_||(P_=s,hv=performance.now(),P_.then(()=>{P_=null})),s.then(_=>{if(_){if(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.replicatedConfirmation){let E=this.writes[0].store.rootStore.databaseName,f=this.writes[this.writes.length-1];LA&&f&&i.push(LA(E,f.store.getEntry(f.key).localTime,this.replicatedConfirmation))}return this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))}else return u&&(u.retryRisk=(u.retryRisk||0)+Ev/2),t?t.retries=n+1:t={retries:1},this.commit(t)});let d={txnTime:r};if(this.next){let _=this.next?.commit(t);if(_?.then)return _?.then(E=>({txnTime:r,next:E}));d.next=_}return d}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},cp=class extends pc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,MA.getNextMonotonicTime)())}getReadTxn(){}},q9=3e4;a(V9,"startMonitoringTxns");V9()});function Dt(e,t,r){if(!t)t=e,e={};else if(!e)e={};else if(e?.transaction?.open===1&&typeof t=="function")return t(e.transaction);if(typeof t!="function")throw new Error("Callback function must be provided to transaction");let n=e.transaction=new pc;e.timestamp&&(n.timestamp=e.timestamp),e.replicatedConfirmation&&(n.replicatedConfirmation=e.replicatedConfirmation),n[ke]=e,e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var Av,mc=Oe(()=>{Av=L(fi());Vs();lp();a(Dt,"transaction");(0,Av._assignPackageExport)("transaction",Dt);Dt.commit=function(e){let t=(e[ke]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Dt.abort=function(e){let t=(e[ke]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var Dv={};je(Dv,{ResourceBridge:()=>BA});function HA({get_attributes:e},t){if(e){if(e[0]==="*"){if(t.schemaDefined)return;e=t.attributes.map(r=>r.name)}return e.forceNulls=!0,e}}function bv(e,t){let r=bi(e),n=HA(e,r);if(!r)throw new Ks.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache,replicateFrom:e.replicateFrom},o;Dt(i,()=>new Promise(u=>o=u));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let u=c[l++],d;try{d=await r.get({id:u,lazy:s,select:n},i),d=d&&dp(d)}catch(_){d={message:_.toString()}}return t?{value:{key:u,value:d}}:{value:d}}else return o(),{done:!0}},return(u){return o(),{value:u,done:!0}},throw(u){return o(),{done:!0}}}}}}function bi(e){let t=e.database||e.schema||Y9,r=ut()[t];if(!r)throw(0,Ks.handleHDBError)(new Error,K9.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function Ov(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}async function*Nv(e,t,r,n){let s,i=0;for await(let o of e.getHistory(t,r)){let c=o.operation??o.type;c==="put"&&(c="upsert");let{id:l,version:u,value:d}=o;if(s?.timestamp===u)s.hash_values.push(l),s.records.push(d);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:u,hash_values:[l],records:[d]}}}s&&(yield s)}var Iv,up,Ks,wv,Ys,UA,vA,Cv,K9,Y9,W9,j9,yv,BA,Pv=Oe(()=>{"use strict";Iv=L(fv()),up=L($l()),Ks=L(_e());Pe();wv=L(f_()),Ys=L(M()),UA=L(no()),vA=L(qs()),Cv=L(te());mc();_p();({HDB_ERROR_MSGS:K9}=Ks.hdb_errors),Y9="data",W9=1e4,j9=10,BA=class extends Iv.default{static{a(this,"ResourceBridge")}constructor(t){super(t),yv=this}async searchByConditions(t){t.select!==void 0&&(t.get_attributes=t.select);for(let o of t.conditions||[])o?.attribute!==void 0&&(o.search_attribute=o.attribute),o?.comparator!==void 0&&(o.search_type=o.comparator),o?.value!==void 0&&(o.search_value=o.value);let r=(0,up.default)(t,"conditions");if(r)throw(0,Ks.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=bi(t);if(!n)throw new Ks.ClientError(`Table ${t.table} not found`);let s=t.conditions.map(i);function i(o){return o.conditions?(o.conditions=o.conditions.map(i),o):{attribute:o.search_attribute??o.attribute,comparator:o.search_type??o.comparator,value:o.search_value!==void 0?o.search_value:o.value}}return a(i,"mapCondition"),n.search({conditions:s,operator:t.operator?t.operator.toLowerCase():void 0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:HA(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new Ks.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}Et({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await bi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=bi(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c={...c},delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(u=>{if(!u){let{value:d,version:_}=r.primaryStore.getEntry(o);return i(o,d,_)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(u=>setImmediate(u));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){bi(t).dropTable()}createSchema(t){return Yl({database:t.schema,table:null}),UA.signalSchemaChange(new vA.SchemaEventMsg(process.pid,Ys.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await xA(t.schema),UA.signalSchemaChange(new vA.SchemaEventMsg(process.pid,Ys.OPERATIONS_ENUM.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,yv.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,wv.default)(t),s,i=ut()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(o.replicateTo=t.replicateTo),t.replicatedConfirmation&&(o.replicatedConfirmation=t.replicatedConfirmation),Dt(o,async c=>{if(!i.schemaDefined){s=[];for(let d of n)i.attributes.find(E=>E.name==d)||s.push(d);s.length>0&&await i.addAttributes(s.map(d=>({name:d,indexed:!0})))}let l=[],u=[];for(let d of t.records){let _=d[i.primaryKey],E=_!=null&&await i.get(_,o);if(t.requires_existing&&!E||t.requires_no_existing&&E){u.push(d[i.primaryKey]);continue}E&&(E=dp(E));for(let f in d)if(Object.prototype.hasOwnProperty.call(d,f)){let h=d[f];if(typeof h=="function")try{let T=h([[E]]);Array.isArray(T)&&(h=T[0].func_val,d[f]=h)}catch(T){throw T.message+="Trying to set key "+f+" on object"+JSON.stringify(d),T}}if(E)for(let f in E)Object.prototype.hasOwnProperty.call(d,f)||(d[f]=E[f]);await(_==null?i.create(d,o):i.put(d,o)),l.push(d[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:u}})}async deleteRecords(t){let r=ut()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),Dt(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),o=[],c=[];for(let l of i)await r.delete(l,n)?o.push(l):c.push(l);return Ov(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=ut()[t.schema][t.table];if(!r.createdTimeProperty)throw new Ks.ClientError("Table must have a '__createdtime__' attribute or @createdTime timestamp defined to perform this operation");let n=await r.search({conditions:[{attribute:r.createdTimeProperty.name,value:Date.parse(t.date),comparator:Ys.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,l=[],u=a(async()=>{let d=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...d.deleted_hashes),o.push(...d.skipped_hashes),await(0,Cv.async_set_timeout)(j9),l=[],s=!0},"chunkDelete");for await(let d of n)l.push(d[r.primaryKey]),c++,c%W9===0&&await u();return l.length>0&&await u(),s?Ov(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,up.default)(t,"hashes");if(r)throw r;return bv(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of bv(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Ys.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r]===void 0)throw new Error(`Value search comparator - ${r} - is not valid`);t.select!==void 0&&(t.get_attributes=t.select),t.attribute!==void 0&&(t.search_attribute=condition.attribute),t.value!==void 0&&(t.search_value=condition.value);let n=(0,up.default)(t,"value");if(n)throw n;let s=bi(t);if(!s)throw new Ks.ClientError(`Table ${t.table} not found`);let i=t.search_value;i.includes?.("*")&&(i.startsWith("*")?i.endsWith("*")?i!=="*"&&(r="contains",i=i.slice(1,-1)):(r="ends_with",i=i.slice(1)):i.endsWith("*")&&(r="starts_with",i=i.slice(0,-1))),r===Ys.VALUE_SEARCH_COMPARATORS.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,sort:t.sort,select:HA(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=bi(t);t.get_attributes&&!t.get_attributes.includes(s.primaryKey)&&t.get_attributes[0]!=="*"&&t.get_attributes.push(s.primaryKey);for await(let i of this.searchByValue(t,r))n.set(i[s.primaryKey],i);return n}resetReadTxn(t,r){bi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return bi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=bi(t),n={};switch(t.search_type){case Ys.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.operation??o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case Ys.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of Nv(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return Nv(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(HA,"getSelect");a(bv,"getRecords");a(bi,"getTable");a(Ov,"createDeleteResponse");a(Nv,"groupRecordsInHistory")});var Bn=N((uOe,Lv)=>{"use strict";var{ResourceBridge:z9}=(Pv(),oe(Dv)),Q9=se();Q9.initSync();var fp;function J9(){return fp||(fp=new z9,fp)}a(J9,"getBridge");Lv.exports=J9()});var Bv=N((_Oe,vv)=>{"use strict";var Mv=require("lodash"),L_=require("mathjs"),X9=require("jsonata"),Uv=te();vv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?Mv.uniqWith(e,Mv.isEqual):e,"distinct_array"),searchJSON:Z9,mad:M_.bind(null,L_.mad),mean:M_.bind(null,L_.mean),mode:M_.bind(null,L_.mode),prod:M_.bind(null,L_.prod),median:M_.bind(null,L_.median)};function M_(e,t,r,n){return n===1?t==null?[]:[t]:n===2?(t!=null&&r.push(t),r):r!=null&&r.length>0?e(r):null}a(M_,"aggregateFunction");function Z9(e,t){if(typeof e!="string"||e.length===0)throw new Error("search json expression must be a non-empty string");let r="__"+e+"__";if(Uv.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),Uv.isEmpty(this.__ala__.res[r])){let n=X9(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(Z9,"searchJSON")});var xv=N((EOe,Hv)=>{"use strict";var nr=require("moment"),kA="YYYY-MM-DDTHH:mm:ss.SSSZZ";nr.suppressDeprecationWarnings=!0;Hv.exports={current_date:a(()=>nr().utc().format("YYYY-MM-DD"),"current_date"),current_time:a(()=>nr().utc().format("HH:mm:ss.SSS"),"current_time"),extract:a((e,t)=>{switch(t.toLowerCase()){case"year":return nr(e).utc().format("YYYY");case"month":return nr(e).utc().format("MM");case"day":return nr(e).utc().format("DD");case"hour":return nr(e).utc().format("HH");case"minute":return nr(e).utc().format("mm");case"second":return nr(e).utc().format("ss");case"millisecond":return nr(e).utc().format("SSS");default:break}},"extract"),date:a(e=>nr(e).utc().format(kA),"date"),date_format:a((e,t)=>nr(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>nr(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>nr(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=nr(e).utc(),s=nr(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>nr().utc().valueOf(),"now"),get_server_time:a(()=>nr().format(kA),"get_server_time"),offset_utc:a((e,t)=>nr(e).utc().utcOffset(t).format(kA),"offset_utc")}});var qv=N((pOe,Gv)=>{"use strict";var e7=require("@turf/area"),t7=require("@turf/length"),r7=require("@turf/circle"),n7=require("@turf/difference"),s7=require("@turf/distance"),i7=require("@turf/boolean-contains"),o7=require("@turf/boolean-equal"),a7=require("@turf/boolean-disjoint"),c7=require("@turf/helpers"),kv=M(),$e=te(),oo=W();Gv.exports={geoArea:l7,geoLength:u7,geoCircle:d7,geoDifference:_7,geoDistance:Fv,geoNear:f7,geoContains:E7,geoEqual:h7,geoCrosses:p7,geoConvert:m7};function l7(e){if($e.isEmpty(e))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return e7.default(e)}catch(t){return oo.trace(t,e),NaN}}a(l7,"geoArea");function u7(e,t){if($e.isEmpty(e))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return t7.default(e,{units:t||"kilometers"})}catch(r){return oo.trace(r,e),NaN}}a(u7,"geoLength");function d7(e,t,r){if($e.isEmpty(e))return NaN;if($e.isEmpty(t))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return r7.default(e,t,{units:r||"kilometers"})}catch(n){return oo.trace(n,e,t),NaN}}a(d7,"geoCircle");function _7(e,t){if($e.isEmpty(e))return NaN;if($e.isEmpty(t))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return n7(e,t)}catch(r){return oo.trace(r,e,t),NaN}}a(_7,"geoDifference");function Fv(e,t,r){if($e.isEmpty(e))return NaN;if($e.isEmpty(t))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return s7.default(e,t,{units:r||"kilometers"})}catch(n){return oo.trace(n,e,t),NaN}}a(Fv,"geoDistance");function f7(e,t,r,n){if($e.isEmpty(e)||$e.isEmpty(t))return!1;if($e.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return Fv(e,t,n)<=r}catch(s){return oo.trace(s,e,t),!1}}a(f7,"geoNear");function E7(e,t){if($e.isEmpty(e)||$e.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return i7.default(e,t)}catch(r){return oo.trace(r,e,t),!1}}a(E7,"geoContains");function h7(e,t){if($e.isEmpty(e)||$e.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return o7.default(e,t)}catch(r){return oo.trace(r,e,t),!1}}a(h7,"geoEqual");function p7(e,t){if($e.isEmpty(e)||$e.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return!a7.default(e,t)}catch(r){return oo.trace(r,e,t),!1}}a(p7,"geoCrosses");function m7(e,t,r){if($e.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if($e.isEmpty(t))throw new Error("geo_type is required");if($e.isEmpty(kv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(kv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=$e.autoCastJSON(e)),c7[t](e,r)}a(m7,"geoConvert")});var Ep=N((SOe,$v)=>{var Sc=Bv(),Gn=xv(),Oi=qv();$v.exports=e=>{e.aggr.mad=e.aggr.MAD=Sc.mad,e.aggr.mean=e.aggr.MEAN=Sc.mean,e.aggr.mode=e.aggr.MODE=Sc.mode,e.aggr.prod=e.aggr.PROD=Sc.prod,e.aggr.median=e.aggr.MEDIAN=Sc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Sc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Sc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Gn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Gn.current_time,e.fn.extract=e.fn.EXTRACT=Gn.extract,e.fn.date=e.fn.DATE=Gn.date,e.fn.date_format=e.fn.DATE_FORMAT=Gn.date_format,e.fn.date_add=e.fn.DATE_ADD=Gn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Gn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Gn.date_diff,e.fn.now=e.fn.NOW=Gn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Gn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Gn.get_server_time,e.fn.getdate=e.fn.GETDATE=Gn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Gn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Oi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Oi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Oi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Oi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Oi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Oi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Oi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Oi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Oi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Oi.geoNear}});var Wv=N((TOe,Yv)=>{"use strict";var U_=require("lodash"),_n=require("alasql");_n.options.cache=!1;var S7=Ep(),Vv=require("clone"),hp=require("recursive-iterator"),Ue=W(),et=te(),Wl=Bn(),T7=M(),{hdb_errors:g7}=_e(),{getDatabases:Kv}=(Pe(),oe(lt)),R7="IS NULL",Ws="There was a problem performing this search. Please check the logs and try again.";S7(_n);var FA=class{static{a(this,"SQLSearch")}constructor(t,r){if(et.isEmpty(t))throw Ue.error("AST statement for SQL select process cannot be empty"),"statement cannot be null";this.statement=t,this.columns={},this.all_table_attributes=r,this.fetch_attributes=[],this.exact_search_values={},this.comparator_search_values={},this.tables=[],this.data={},this.has_aggregator=!1,this.has_ordinal=!1,this.has_outer_join=!1,this._getColumns(),this._getTables(),this._conditionsToFetchAttributeValues(),this._setAliasesForColumns(),et.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!et.isEmptyOrZeroLength(n))return Ue.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw Ue.error("Error thrown from checkEmptySQL in SQLSearch class method search."),Ue.error(n),new Error(Ws)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw Ue.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),Ue.error(n),new Error(Ws)}if(Object.keys(this.data).length===0)return Ue.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw Ue.error("Error thrown from processJoins in SQLSearch class method search."),Ue.error(n),new Error(Ws)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw Ue.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),Ue.error(n),new Error(Ws)}try{return t=await this._finalSQL(),t}catch(n){throw Ue.error("Error thrown from finalSQL in SQLSearch class method search."),Ue.error(n),new Error(Ws)}}_getColumns(){let t=new hp(this.statement);for(let{node:r,path:n}of t)r&&r.columnid&&(this.columns[n[0]]||(this.columns[n[0]]=[]),this.columns[n[0]].push(Vv(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=U_.uniqBy(t,r=>[r.databaseid,r.tableid,r.as].join()),this.tables.forEach(r=>{let n=`${r.databaseid}_${r.as?r.as:r.tableid}`;this.data[n]={},this.data[n].__hash_name=Kv()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(et.isEmpty(this.statement.where)){Ue.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new hp(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!et.isEmpty(r)&&r.right)if(et.isNotEmptyAndHasValue(r.right.value)){let n=et.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new _n.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=et.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new _n.yy.LogicValue({value:i}):n instanceof _n.yy.StringValue&&et.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new _n.yy.NumValue({value:i}))});if(t){Ue.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new hp(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let n=new Set,s=r.left.columnid?r.left:r.right,i=this._findColumn(s);if(!i)continue;let o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!et.isEmpty(T7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(et.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(et.isEmptyOrZeroLength(r.left.columnid)||et.isEmptyOrZeroLength(r.right.value)){this.comparator_search_values[o].ignore=!0,this.comparator_search_values[o].comparators=[];continue}this.comparator_search_values[o].comparators.push({attribute:r.left.columnid,operation:r.op,search_value:r.right.value})}continue}if(et.isEmpty(this.exact_search_values[o])&&(this.exact_search_values[o]={ignore:!1,values:new Set}),!this.exact_search_values[o].ignore){let c=!1;switch(r.op){case"=":!et.isEmpty(r.right.value)||!et.isEmpty(r.left.value)?n.add(et.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let l=Array.isArray(r.right)?r.right:r.left;for(let u=0;u<l.length;u++)if(l[u].value)n.add(l[u].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(et.isEmptyOrZeroLength(this.all_table_attributes)&&et.isEmptyOrZeroLength(this.statement.from)&&et.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((n,s)=>{if(n.columnid==="*"){t.push(s);return}if(n.aggregatorid&&(this.has_aggregator=!0),!n.aggregatorid&&!n.funcid)if(n.as_orig=n.as?n.as:n.columnid,this.statement.joins)if(r[n.as_orig]>=0){let i=r[n.as_orig]+1;n.as=`[${n.as_orig+i}]`,r[n.as_orig]=i}else n.as=`[${n.as_orig}]`,r[n.as_orig]=0;else n.as=`[${n.as_orig}]`;!n.aggregatorid&&n.funcid&&n.args&&(n.as_orig=n.as?n.as:n.toString().replace(/'/g,'"'),n.as=`[${n.as_orig}]`),n.aggregatorid&&n.expression.columnid!=="*"&&(n.as_orig=n.as?n.as:n.expression.tableid?`${n.aggregatorid}(${n.expression.tableid}.${n.expression.columnid})`:`${n.aggregatorid}(${n.expression.columnid})`,n.as=`[${n.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&U_.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(et.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);et.isEmptyOrZeroLength(n)||(r=this.all_table_attributes.filter(s=>s.attribute===n[0].columnid&&n[0].tableid&&n[0].tableid===(s.table.as?s.table.as:s.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(et.isEmptyOrZeroLength(this.all_table_attributes)&&!et.isEmptyOrZeroLength(this.columns.columns))return t;if(et.isEmptyOrZeroLength(this.all_table_attributes)&&et.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await _n.promise(r)}catch(r){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),Ue.error(r),new Error("There was a problem with the SQL statement")}return t}_addFetchColumns(t){t&&t.length>0&&t.forEach(r=>{let n=this._findColumn(r);n&&this.fetch_attributes.push(Vv(n))})}_addColumnToMergedAttributes(t,r){this.data[t].__merged_attributes.push(r),this.data[t].__merged_attr_map[r]=this.data[t].__merged_attributes.length-1}_setMergedHashAttribute(t,r){this.data[t].__merged_data[r].splice(0,1,r)}_updateMergedAttribute(t,r,n,s){let i=this.data[t].__merged_attr_map[n];this.data[t].__merged_data[r].splice(i,1,s)}async _getFetchAttributeValues(){if(et.isEmptyOrZeroLength(Object.keys(this.columns)))return[];this._addFetchColumns(this.columns.joins);let t=null;try{t=this.statement.where?this.statement.where.toString():""}catch{throw new Error("Could not generate proper where clause")}this.columns.where&&this._addFetchColumns(this.columns.where);let r=this._isSimpleSelect();if(r?this._addFetchColumns(this.columns.columns):(!this.columns.where&&this.fetch_attributes.length===0)|t.indexOf(R7)>-1&&this.tables.forEach(s=>{let i={columnid:Kv()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=U_.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,u=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!et.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!et.isEmptyOrZeroLength(this.exact_search_values[u].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[u].values);let d=await Wl.getDataByHash(c);for(let _ of c.hash_values)d.get(_)&&!this.data[i].__merged_data[_]&&(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_))}catch(d){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(d),new Error(Ws)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async d=>{let _={...c};_.search_value=d;let E=await Wl.getDataByValue(_);for(let[f,h]of E)this.data[i].__merged_data[f]?this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]):(this.data[i].__merged_data[f]=[...n[i]],this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,f))}))}catch(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(d),new Error(Ws)}else if(!et.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!et.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let d=this.comparator_search_values[u].comparators;for(let _=0,E=d.length;_<E;_++){let f=d[_];c.search_attribute=f.attribute,c.search_value=f.search_value;let h=await Wl.getDataByValue(c,f.operation);if(l)for(let[T]of h)this.data[i].__merged_data[T]||(this.data[i].__merged_data[T]=[...n[i]],this._setMergedHashAttribute(i,T));else for(let[T,m]of h)this.data[i].__merged_data[T]?this._updateMergedAttribute(i,T,s.attribute,m[s.attribute]):(this.data[i].__merged_data[T]=[...n[i]],this._updateMergedAttribute(i,T,s.attribute,m[s.attribute]),this._setMergedHashAttribute(i,T))}}catch(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),Ue.error(d),new Error(Ws)}else try{c.search_attribute=s.attribute,c.search_value="*";let d=await Wl.getDataByValue(c);if(l)for(let[_]of d)this.data[i].__merged_data[_]||(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_));else for(let[_,E]of d)this.data[i].__merged_data[_]?this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]):(this.data[i].__merged_data[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]),this._setMergedHashAttribute(i,_))}catch(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),Ue.error(d),new Error(Ws)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof _n.yy.Column||(t=!1)}),t)}_updateOrderByToAliases(){this.statement.order.forEach(t=>{if(t.expression.aggregatorid){t.is_aggregator=!0;return}if(t.expression.value){t.is_ordinal=!0,this.has_ordinal=!0;return}else t.is_ordinal=!1;let r=this.statement.columns.filter(s=>{let i=s.aggregatorid?s.expression:s,o=s.aggregatorid?s.as_orig:i.as_orig;return t.expression.tableid?i.columnid_orig===t.expression.columnid_orig&&i.tableid_orig===t.expression.tableid_orig:i.columnid_orig===t.expression.columnid_orig||t.expression.columnid_orig===o});r[0]||r.push(this._findColumn(t.expression));let n=r[0];if(t.is_func=!!n.funcid,t.is_aggregator=!!n.aggregatorid,n.as)if(n.as&&!t.expression.tableid)t.expression.columnid=n.as,t.expression.columnid_orig=n.as_orig;else{let s=new _n.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new _n.yy.Column,t.expression),t.initial_select_column.as=`[${t.expression.columnid_orig}]`,t.expression.columnid=t.initial_select_column.as;return}if(!t.is_aggregator){let s=t.is_func?new _n.yy.FuncValue:new _n.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(f=>{f.joinmode&&f.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(f.table);let h=f.joinmode+" JOIN ? AS "+(f.as?f.as:f.table.tableid);f.on&&(h+=" ON "+f.on.toString()),i.push(h),t.push(Object.values(this.data[`${f.table.databaseid_orig}_${f.table.as?f.table.as_orig:f.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(f=>{let h=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__hash_name,T=f.as?f.as_orig:f.tableid_orig;o.push({key:`'${T}.${h}'`,schema:f.databaseid_orig,table:f.as?f.as_orig:f.tableid_orig,keys:new Set}),r.push(`${f.as?f.as:f.tableid}.\`${h}\` AS "${T}.${h}"`),c[f.as?f.as_orig:f.tableid_orig]=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let u="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(u="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(f=>{f.is_func?r.push(f.initial_select_column.toString()):f.initial_select_column.tableid?r.push(`${f.initial_select_column.tableid}.${f.initial_select_column.columnid} AS ${f.expression.columnid}`):r.push(`${f.initial_select_column.columnid} AS ${f.expression.columnid}`)}));let d="",_="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(d=this.statement.limit?"LIMIT "+this.statement.limit:"",_=this.statement.offset?"OFFSET "+this.statement.offset:"");let E=[];try{let f=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${u} ${d} ${_}`,h=this._convertColumnsToIndexes(f,s);E=await _n.promise(h,t),t=null}catch(f){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),Ue.error(f),new Error("There was a problem processing the data.")}if(E&&E.length>0){for(let f=0,h=E.length;f<h;f++){let T=E[f];o.forEach(m=>{T[m.key]!==null&&T[m.key]!==void 0&&m.keys.add(T[m.key])})}o.forEach(f=>{let h=Object.keys(this.data[`${f.schema}_${f.table}`].__merged_data),T=U_.difference(h,[...f.keys].map(m=>m.toString()));for(let m=0,g=T.length;m<g;m++){let S=T[m];delete this.data[`${f.schema}_${f.table}`].__merged_data[S]}})}return{existing_attributes:c,joined_length:E?E.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new hp(this.columns);for(let{node:i}of s)if(i&&i.columnid){let o=this._findColumn(i);if(o){let c=o.table.as?o.table.as:o.table.tableid;(!t[c]||t[c].indexOf(o.attribute)<0)&&n.push(o)}}n=U_.uniqBy(n,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(n)}catch(i){throw Ue.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),Ue.error(i),new Error(Ws)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__merged_data,o=[];for(let d in i)o.push(i[d][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await Wl.getDataByHash(c),u=s.columns.length;for(let d=0,_=o.length;d<_;d++){let E=o[d],f=l.get(E);for(let h=0;h<u;h++){let T=s.columns[h],m=f[T]===void 0?null:f[T];this.data[n].__merged_data[E].push(m)}}}}catch(r){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getData."),Ue.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__merged_data)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,l=o.aggregatorid?o.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===l}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();Ue.trace(`Final SQL: ${s}`),n=await _n.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),Ue.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),Ue.error(s),new Error("There was a problem running the generated sql.")}return n}_translateUndefinedValues(t){try{let r=[];for(let n of t){let s=Object.create(null);Object.keys(n).forEach(i=>{n[i]===void 0?s[i]=null:s[i]=n[i]}),r.push(s)}return r}catch(r){return Ue.error(g7.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),Ue.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],u=new RegExp(`${l}.\`${o}\``,"g"),d=`${l}.[${c}]`;n=n.replace(u,d)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),u=`[${c}]`;n=n.replace(l,u)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await Wl.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]={...r[s]}),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw Ue.error("There was an error when processing this SQL operation. Check your logs"),Ue.error(o),new Error(Ws)}}return Object.values(Object.values(this.data)[0].__merged_data)}};Yv.exports=FA});var Vr=N((ROe,jv)=>{"use strict";var A7=YD();jv.exports={searchByConditions:b7,searchByHash:O7,searchByValue:N7,search:I7};var GA=Bn(),{transformReq:qA}=te(),y7=Wv();async function b7(e){return qA(e),GA.searchByConditions(e)}a(b7,"searchByConditions");async function O7(e){qA(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of GA.searchByHash(e))r&&t.push(r);return t}a(O7,"searchByHash");async function N7(e){qA(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of GA.searchByValue(e))t.push(r);return t}a(N7,"searchByValue");function I7(e,t){try{let r=new A7(e);r.validate(),new y7(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(I7,"search")});var pp=N((yOe,zv)=>{"use strict";var w7=Bn();zv.exports={writeTransaction:C7};function C7(e,t,r){return w7.writeTransaction(e,t,r)}a(C7,"writeTransaction")});var Zv=N((NOe,Xv)=>{"use strict";var D7=Vr(),P7=ls(),Qv=W(),L7=un(),OOe=pp(),M7=require("clone"),VA=require("alasql"),U7=Ep(),Jv=require("util"),v7=Jv.promisify(P7.getTableSchema),B7=Jv.promisify(D7.search),H7=M(),$A=te();U7(VA);Xv.exports={update:k7};var x7="There was a problem performing this update. Please check the logs and try again.";async function k7({statement:e,hdb_user:t}){let r=await v7(e.table.databaseid,e.table.tableid),n=F7(e.columns);$A.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=M7(s),c=$A.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=VA.parse(l).statements[0],d=await B7(u),_=G7(n,d);return q7(o,_,t)}a(k7,"update");function F7(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=VA.compile(`SELECT ${r.expression.toString()} AS [${H7.FUNC_VAL}] FROM ?`)}),t}catch(t){throw Qv.error(t),new Error(x7)}}a(F7,"createUpdateRecord");function G7(e,t){return $A.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(G7,"buildUpdateRecords");async function q7(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await L7.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){Qv.error(`Error delete new_attributes from update response: ${i}`)}return s}a(q7,"updateRecords")});var t0=N((DOe,e0)=>{var $7=require("alasql"),V7=Vr(),K7=W(),Y7=Bn(),YA=require("util"),KA=te(),W7=M(),j7=ls(),wOe=pp(),COe=un(),z7="record",Q7="successfully deleted",J7=YA.callbackify(tee),X7=YA.promisify(V7.search),Z7=YA.promisify(j7.getTableSchema);e0.exports={convertDelete:J7};function eee(e){return`${e.deleted_hashes.length} ${z7}${e.deleted_hashes.length===1?"":"s"} ${Q7}`}a(eee,"generateReturnMessage");async function tee({statement:e,hdb_user:t}){let r=await Z7(e.table.databaseid,e.table.tableid);KA.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=KA.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=$7.parse(o).statements[0],l={operation:W7.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await X7(c);let u=await Y7.deleteRecords(l);return KA.isEmptyOrZeroLength(u.message)&&(u.message=eee(u)),delete u.txn_time,u}catch(u){throw K7.error(u),u.hdb_code?u.message:u}}a(tee,"convertDelete")});var o0=N((LOe,i0)=>{"use strict";var ree=ro(),{hdb_errors:r0}=_e(),{getDatabases:n0}=(Pe(),oe(lt));i0.exports={checkSchemaExists:s0,checkSchemaTableExists:nee,schema_describe:ree};async function s0(e){if(!n0()[e])return r0.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(s0,"checkSchemaExists");async function nee(e,t){let r=await s0(e);if(r)return r;if(!n0()[e][t])return r0.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(nee,"checkSchemaTableExists")});var jl=N((UOe,see)=>{see.exports={name:"harperdb",version:"4.4.16",description:"HarperDB is a distributed database, caching service, streaming broker, and application development platform focused on performance and ease of use.",keywords:["database","nosql","api","distributed","broker","mqtt","real-time","enterprise","Fastify","NATS","HarperDB","Harper","clustering","replication","REST","WebSockets","decentralized","server-sent events","document store"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{"minimum-node":"16.0.0","go-lang":"1.21.7","nats-server":"2.10.11"},exports:{".":"./index.js"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"SEE LICENSE IN LICENSE",scripts:{submodules:"git submodule update --init --recursive","cover:test":"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && nyc --no-clean --reporter=lcovonly npm run test:replication && nyc --no-clean --reporter=lcovonly npm run test:apitests && nyc --no-clean --reporter=lcovonly npm run test:resources && nyc --no-clean --reporter=lcovonly npm run test:logging && nyc --no-clean --reporter=lcovonly npm run test:upgrade && nyc --no-clean --reporter=lcovonly npm run test:nats && nyc --no-clean --reporter=lcovonly npm run test:cfserver && nyc --no-clean --reporter=lcovonly npm run test:hdbserver && nyc --no-clean --reporter=lcovonly npm run test:bin && nyc --no-clean --reporter=lcovonly npm run test:main && nyc --no-clean --reporter=lcovonly npm run test:security && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license",test:"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && npm run test:replication && npm run test:apitests && npm run test:resources && npm run test:logging && npm run test:upgrade && npm run test:nats && npm run test:cfserver && npm run test:hdbserver && npm run test:bin && npm run test:main && npm run test:security && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license","test:resources":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/resources/**/*.js' --config '../unitTests/.mocharc.json'","test:bin":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/bin/**/*.js' --config '../unitTests/.mocharc.json'","test:main":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","test:lmdbbridge":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --config '../unitTests/.mocharc.json'","test:lmdbutility":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --config '../unitTests/.mocharc.json'","test:hdbserver":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --config '../unitTests/.mocharc.json'","test:cfserver":"npm run submodules && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/fastifyRoutes/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","test:nats":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","test:upgrade":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --config '../unitTests/.mocharc.json'","test:apitests":"pm2 kill && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/apiTests/**/*-test.mjs' --config '../unitTests/.mocharc.json'","test:logging":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/logging/*.js' --config '../unitTests/.mocharc.json'","test:ci":" cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --retries 3 --config '../unitTests/.mocharc-main.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter","test:security":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/security/**/*.js' --config '../unitTests/.mocharc.json'","test:replication":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/replication/**/*.js' --config '../unitTests/.mocharc.json'","hdb-check":"./utility/devops/hdb-check.sh","download-prebuilds":"node ./utility/devops/build/download-prebuilds.js",prebuild:"date",postinstall:"node ./launchServiceScripts/launchInstallNATSServer.js",build_nats_dependency:"node ./utility/devops/nats/builder.js",coverage:"nyc --reporter=lcov npm test",format:"prettier .","format:fix":"npm run format -- --write",lint:"eslint .","lint:fix":"npm run lint -- --fix"},dependencies:{"@aws-sdk/client-s3":"3.717.0","@aws-sdk/lib-storage":"3.717.0","@endo/static-module-record":"^1.0.4","@fastify/autoload":"5.10.0","@fastify/compress":"~6.5.0","@fastify/cors":"~9.0.1","@fastify/static":"~7.0.4","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"4.1.10","cbor-x":"1.6.0",chalk:"4.1.2","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.2",fastify:"~4.29.0","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.10.0","gunzip-maybe":"1.4.2","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.12.2","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.7",jsonwebtoken:"9.0.2",lmdb:"3.2.2",lodash:"4.17.21",mathjs:"11.12.0",minimist:"1.2.8",moment:"2.30.1","mqtt-packet":"~9.0.0",msgpackr:"1.11.2",nats:"2.19.0",needle:"3.3.1","node-forge":"^1.3.1","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.3",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.4.1",prompt:"1.3.0","properties-reader":"2.3.0","recursive-iterator":"3.3.0",semver:"7.5.4",send:"^1.1.0","serve-static":"2.1.0",ses:"1.1.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.24.5","tar-fs":"3.0.6",ulidx:"0.5.0",uuid:"10.0.0","validate.js":"0.13.1",ws:"8.18.0",yaml:"2.7.0"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"20.14.8","@typescript-eslint/eslint-plugin":"^7.18.0","@typescript-eslint/parser":"^7.18.0",axios:"1.7.5",chai:"4.4.1","chai-integer":"0.1.0",esbuild:"^0.24.2",eslint:"^9.17.0","eslint-config-prettier":"^9.1.0","eslint-plugin-sonarjs":"^3.0.1",eventsource:"^2.0.2","graphql-http":"^1.22.3","hook-std":"3.0.0","intercept-stdout":"0.1.2",mkcert:"1.5.1",mocha:"^11.0.1","mocha-teamcity-reporter":"^4.2.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.8",newman:"6.1.3","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"3.3.3",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0","source-map-support":"^0.5.21",typescript:"^5.7.2",undici:"^6.19.8","why-is-node-still-running":"^1.0.0"},overrides:{alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","segfault-handler":"^1.3.0","utf-8-validate":"^5.0.10"}}});var k_={};je(k_,{addAnalyticsListener:()=>x_,recordAction:()=>pr,recordActionBinary:()=>qn,setAnalyticsEnabled:()=>iee});function iee(e){h0=e}function pr(e,t,r,n,s){if(!h0)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=Tp.get(i);if(o)if(typeof e=="number"){let c=o.values,l=c.index++;if(l>=c.length){let u=c;o.values=c=new Float32Array(l*2),c.set(u),c.index=l+1}c[l]=e,o.total+=e}else if(typeof e=="boolean")e&&o.total++,o.count++;else if(typeof e=="function")o.count++;else throw new TypeError("Invalid metric value type "+typeof e);else{if(typeof e=="number")o={total:e,values:new Float32Array(4)},o.values.index=1,o.values[0]=e,o.total=e;else if(typeof e=="boolean")o={},o.total=e?1:0,o.count=1;else if(typeof e=="function")o={},o.count=1,o.callback=e;else throw new TypeError("Invalid metric value type "+typeof e);o.description={metric:t,path:r,method:n,type:s},Tp.set(i,o)}mp||oee()}function qn(e,t,r,n,s){pr(!!e,t,r,n,s)}function x_(e){S0.push(e)}function oee(){mp=performance.now(),setTimeout(async()=>{let e=performance.now()-mp;mp=0;let t=[],r={time:Date.now(),period:e,threadId:Tc.threadId,metrics:t};for(let[s,i]of Tp){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,u=[],d;for(let _ of T0){let E=Math.floor(c*_),f=o[E-1];if(E>l){let h=E-l;if(f===d){let T=u[u.length-1];typeof T=="number"?u[u.length-1]={value:T,count:1+h}:T.count+=h}else u.push(h>1?{value:f,count:h}:f),d=f;l=E}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:u,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await g0()}let n=process.memoryUsage();t.push({metric:"memory",threadId:Tc.threadId,byThread:!0,...n});for(let s of S0)s(t);Tp=new Map,Tc.parentPort?Tc.parentPort.postMessage({type:m0,report:r}):y0({report:r})},p0).unref()}async function aee(e,t=6e4){let r=zA(),n=R0(),s=new Promise(T=>{let m=performance.now();setImmediate(()=>{let g=performance.now();g-m>5e3&&(0,v_.warn)("Unusually high event queue latency on the main thread of "+Math.round(g-m)+"ms"),m=performance.now()}),n.primaryStore.prefetch([1],()=>{let g=performance.now();g-m>5e3&&(0,v_.warn)("Unusually high task queue latency on the main thread of "+Math.round(g-m)+"ms"),T(g-m)})}),i;for(let T of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(T.value?.time){i=T.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,u=[],d;for(let{key:T,value:m}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!m)continue;if(o){if(T>o+t)break}else o=T;d=T;let{metrics:g,threadId:S}=m;for(let b of g||[]){let{path:I,method:B,type:H,metric:X,count:Y,total:V,distribution:ne,threads:Q,...de}=b;Y||(Y=1);let j=X+(I?"-"+I:"");B!==void 0&&(j+="-"+B),H!==void 0&&(j+="-"+H);let ae=c.get(j);if(ae){if(ae.threads){let ye=ae.threads[S];if(ye)ae=ye;else{ae.threads[S]={...de};continue}}ae.count||(ae.count=1);let Ae=ae.count;for(let ye in de){let Me=de[ye];typeof Me=="number"&&(ae[ye]=(ae[ye]*Ae+Me*Y)/(Ae+Y))}ae.count+=Y,V>=0&&(ae.total+=V,ae.ratio=ae.total/ae.count)}else ae={period:t,...b},delete ae.distribution,c.set(j,ae),ae.byThread&&(ae.threads=[],ae.threads[S]={...de},u.push(ae));if(ne){ne=ne.map(ye=>typeof ye=="number"?{value:ye,count:1}:ye);let Ae=l.get(j);Ae?Ae.push(...ne):l.set(j,ne)}}await g0()}for(let T of u){let{path:m,method:g,type:S,metric:b,count:I,total:B,distribution:H,threads:X,...Y}=T;X=X.filter(V=>V);for(let V in Y){if(typeof T[V]!="number")continue;let ne=0;for(let Q of X){let de=Q[V];typeof de=="number"&&(ne+=de)}T[V]=ne}T.count=X.length,delete T.threads,delete T.byThread}for(let[T,m]of l){let g=c.get(T);m.sort((ye,Me)=>ye.value>Me.value?1:-1);let S=g.count-1,b=[],I=0,B=0,H;for(let ye of T0){let Me=S*ye;for(;I<Me;)H=m[B++],I+=H.count,B===1&&I--;let Gr=m[B>1?B-2:0];H||(H=m[0]),b.push(H.value-(H.value-Gr.value)*(I-Me)/H.count)}let[X,Y,V,ne,Q,de,j,ae,Ae]=b;Object.assign(g,{p1:X,p10:Y,p25:V,median:ne,p75:Q,p90:de,p95:j,p99:ae,p999:Ae})}let _;for(let[T,m]of c)m.id=(0,Sp.getNextMonotonicTime)(),m.time=d,n.primaryStore.put(m.id,m,{append:!0}).then(g=>{g||n.primaryStore.put(m.id,m)}),_=!0;let E=Date.now(),{idle:f,active:h}=performance.eventLoopUtilization();if(_||h*10>f){let T=(0,Sp.getNextMonotonicTime)(),m={id:T,metric:"main-thread-utilization",idle:f-a0,active:h-c0,taskQueueLatency:await s,time:E,...process.memoryUsage()};n.primaryStore.put(T,m,{append:!0}).then(g=>{g||n.primaryStore.put(T,m)})}a0=f,c0=h}async function l0(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function zA(){return u0||(u0=Et({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function R0(){return d0||(d0=Et({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function uee(){A0=!0;let e=(0,H_.get)(jA.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await aee(p0,e),await l0(zA(),cee),await l0(R0(),lee)},Math.min(e/2,2147483647)).unref()}function y0(e,t){let r=e.report;r.threadId=t?.threadId||Tc.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(_0+=n.mean*n.count);r.totalBytesProcessed=_0,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(f0.get(t))}),f0.set(t,t.performance.eventLoopUtilization())),r.id=(0,Sp.getNextMonotonicTime)(),zA().primaryStore.put(r.id,r),A0||uee(),dee&&(b0=fee(r))}async function fee(e){if(await b0,!ea){let r=(0,B_.dirname)((0,v_.getLogFilePath)());try{ea=await(0,WA.open)((0,B_.join)(r,"analytics.log"),"r+")}catch{ea=await(0,WA.open)((0,B_.join)(r,"analytics.log"),"w+")}}let t=(await ea.stat()).size;if(t>_ee){let r=Buffer.alloc(t);await ea.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await ea.write(r,{position:0}),await ea.truncate(r.length),t=r.length}await ea.write(JSON.stringify(e)+`
12
- `,t)}var Tc,E0,v_,B_,WA,Sp,H_,jA,Tp,h0,mp,p0,m0,S0,T0,a0,c0,g0,cee,lee,u0,d0,A0,_0,f0,dee,b0,ea,_ee,Ni=Oe(()=>{Tc=require("worker_threads"),E0=L(dt());Pe();v_=L(W()),B_=require("path"),WA=require("fs/promises"),Sp=L(cn()),H_=L(se()),jA=L(M());qr();(0,H_.initSync)();Tp=new Map,h0=(0,H_.get)(jA.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)>-1;a(iee,"setAnalyticsEnabled");a(pr,"recordAction");it.recordAnalytics=pr;a(qn,"recordActionBinary");mp=0,p0=1e3,m0="analytics-report",S0=[];a(x_,"addAnalyticsListener");T0=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(oee,"sendAnalytics");a(aee,"aggregation");a0=0,c0=0,g0=a(()=>new Promise(setImmediate),"rest");a(l0,"cleanup");cee=36e5,lee=31536e6;a(zA,"getRawAnalyticsTable");a(R0,"getAnalyticsTable");(0,E0.setChildListenerByType)(m0,y0);a(uee,"startScheduledTasks");_0=0,f0=new Map,dee=!1;a(y0,"recordAnalytics");_ee=1e6;a(fee,"logAnalytics")});var ey=N((WOe,B0)=>{"use strict";var{decode:Eee}=require("msgpackr"),{isMainThread:VOe,parentPort:KOe,threadId:YOe}=require("worker_threads"),Ap=mr(),zl=Ct(),XA=M(),jr=W(),JA=se(),hee=M(),{onMessageByType:pee}=dt(),w0=to(),{recordAction:O0,recordActionBinary:mee}=(Ni(),oe(k_)),{publishToStream:See}=Ap,{ConsumerEvents:N0}=require("nats"),Tee=Vr(),{promisify:gee}=require("util"),C0=gee(setTimeout),yp=1e4,bp,Rp,Ree,Aee,D0,F_=new Map,Ql=new Map;B0.exports={initialize:P0,ingestConsumer:ZA,setSubscription:yee,setIgnoreOrigin:Nee,getDatabaseSubscriptions:Oee,updateConsumer:L0};async function P0(){pee(XA.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await L0(n)}),D0=!0,jr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await Ap.getNATSReferences();bp=e,Rp=e.info.server_name,Ree=t,Aee=r}a(P0,"initialize");async function L0(e){if(e.status==="start"){let{js:t,jsm:r}=await M0(e.node_domain_name);ZA(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=F_.get(e.stream_name+e.node_domain_name);t&&(jr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),F_.set(e.stream_name+e.node_domain_name,"close")),Ql.get(e.node_domain_name)==="failed"&&Ql.set(e.node_domain_name,"close")}}a(L0,"updateConsumer");var Op=new Map;function yee(e,t,r){let n=Op.get(e);n||Op.set(e,n=new Map),n.set(t,r),D0||P0().then(bee)}a(yee,"setSubscription");async function bee(){let e=await Tee.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+zl.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions||[])if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await M0(r),!n))break;let{schema:o,table:c}=i,l=w0.createNatsTableStreamName(o,c);ZA(l,n,s,r)}}}a(bee,"accessConsumers");async function M0(e){let t,r,n=1;for(;!r;)try{t=await bp.jetstream({domain:e}),r=await bp.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(Ql.get(e)==="close")break;Ql.set(e,"failed"),n%10===1&&jr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<yp?n++*100:yp;await C0(i)}return{js:t,jsm:r}}a(M0,"connectToRemoteJS");function Oee(){return Op}a(Oee,"getDatabaseSubscriptions");var U0;function Nee(e){U0=e}a(Nee,"setIgnoreOrigin");var v0=100,I0=new Array(v0),gp=0;async function ZA(e,t,r,n){let{connection:s}=await Ap.getNATSReferences();bp=s,Rp=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,Rp),jr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(Ql.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 Ap.createConsumer(r,e,Rp,new Date(Date.now()).toISOString()));let d=o++*100<yp?o++*100:yp;await C0(d)}let c=!1,l;for(;!c;){if(F_.get(e+n)==="close"||Ql.get(n)==="close"){F_.delete(e+n),c=!0;continue}l=await i.consume({max_messages:JA.get(XA.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),F_.set(e+n,l);let u=!1;(async()=>{for await(let d of await l.status())if(d.type===N0.ConsumerDeleted&&(await l.close(),c=!0),d.type===N0.HeartbeatsMissed){let _=d.data;jr.trace(`${_} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),_===100&&(jr.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${l.consumer.stream}`),l.stop(),u=!0)}})();try{for await(let d of l)await I0[gp],I0[gp]=Iee(d).catch(_=>{jr.error(_)}),++gp>=v0&&(gp=0)}catch(d){d.message==="consumer deleted"?(jr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):jr.error("Error consuming clustering ingest, restarting consumer",d)}}}a(ZA,"ingestConsumer");async function Iee(e){let t=Eee(e.data);O0(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),jr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=JA.get(XA.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(zl.MSG_HEADERS.TRANSACTED_NODES)&&r.values(zl.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(zl.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!U0),mee(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(zl.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:u,records:d,hash_values:_,__origin:E,expiresAt:f}=t;jr.trace("processing message:",o,c,u,(d?"records: "+d.map(B=>B?.id):"")+(_?"ids: "+_:""),"with sequence:",e.seq),jr.trace(`messageProcessor nats msg id: ${e.headers.get(zl.MSG_HEADERS.NATS_MSG_ID)}`);let h;d||(d=_);let T=new Promise(B=>h=B),{timestamp:m,user:g,node_name:S}=E||{},b=Op.get(c)?.get(u);if(!b)throw new Error(`Missing table for replication message: ${u}`);if(o==="define_schema")t.type=o,t.onCommit=h,b.send(t);else if(d.length===1&&!l)b.send({type:QA(o),value:d[0],id:_?.[0],expiresAt:f,timestamp:m,table:u,onCommit:h,user:g,nodeName:S});else{let B=d.map((H,X)=>({type:QA(o),value:H,expiresAt:f,id:_?.[X],table:u}));for(;l;)B.push({type:QA(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;b.send({type:"transaction",writes:B,table:u,timestamp:m,onCommit:h,user:g,nodeName:S})}JA.get(hee.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&See(e.subject.split(".").slice(0,-1).join("."),w0.createNatsTableStreamName(c,u),e.headers,e.data),await T;let I=Date.now()-m;m&&O0(I,"replication-latency",e.subject,o,"ingest")}catch(o){jr.error(o)}e.ack()}a(Iee,"messageProcessor");function QA(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(QA,"convertOperation")});var mr=N((eNe,Z0)=>{"use strict";var br=se();br.initSync();var wee=require("fs-extra"),Cee=require("semver"),$_=require("path"),{monotonicFactory:Dee}=require("ulidx"),x0=Dee(),Pee=require("util"),k0=require("child_process"),Lee=Pee.promisify(k0.exec),Mee=k0.spawn,Dr=Ct(),Je=M(),Np=te(),js=W(),Ip=to(),Uee=pp(),G_=wt(),{broadcast:vee,onMessageByType:Bee,getWorkerIndex:Hee}=dt(),{isMainThread:F0}=require("worker_threads"),{Encoder:xee,decode:sy}=require("msgpackr"),G0=new xee,{isEmpty:yc}=Np,q0=xn(),zOe=48*36e11;F0&&Bee(Je.ITC_EVENT_TYPES.RESTART,()=>{zr=void 0,Ac=void 0});var{connect:kee,StorageType:Fee,RetentionPolicy:Gee,AckPolicy:iy,DeliverPolicy:oy,DiscardPolicy:qee,NatsConnection:QOe,JetStreamManager:JOe,JetStreamClient:XOe,StringCodec:ZOe,JSONCodec:$ee,createInbox:ay,headers:Vee,ErrorCode:H0}=require("nats"),{PACKAGE_ROOT:Kee}=M(),Yee=jl(),{recordAction:Wee}=(Ni(),oe(k_)),$0=$ee(),jee="clustering",zee=Yee.engines[Dr.NATS_SERVER_NAME],Qee=$_.join(Kee,"dependencies"),ny=$_.join(Qee,`${process.platform}-${process.arch}`,Dr.NATS_BINARY_NAME),ty,ry,q_,gc,Rc;Z0.exports={runCommand:V0,checkNATSServerInstalled:Jee,createConnection:cy,getConnection:V_,getJetStreamManager:K_,getJetStream:Y0,getNATSReferences:Ii,getServerList:Zee,createLocalStream:ly,listStreams:W0,deleteLocalStream:ete,getServerConfig:Jl,listRemoteStreams:tte,viewStream:rte,viewStreamIterator:nte,publishToStream:ste,request:ate,reloadNATS:uy,reloadNATSHub:cte,reloadNATSLeaf:lte,extractServerName:ote,requestErrorHandler:ute,createLocalTableStream:J0,createTableStreams:fte,purgeTableStream:X0,purgeSchemaTableStreams:Ete,getStreamInfo:hte,updateLocalStreams:mte,closeConnection:Xee,getJsmServerName:wp,addNatsMsgHeader:j0,clearClientCache:K0,updateRemoteConsumer:dte,createConsumer:z0,updateConsumerIterator:_te};async function V0(e,t=void 0){let{stdout:r,stderr:n}=await Lee(e,{cwd:t});if(n)throw new Error(n.replace(`
10
+ `)},d2="certificate.pem",_2="privateKey.pem",f2="caCertificate.pem",E2="natsCertificate.pem",h2="natsCaCertificate.pem",Rt={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},p2={tls_certificate:Rt.SERVER,tls_certificateAuthority:Rt.CA,customFunctions_tls_certificate:Rt.SERVER,customFunctions_tls_certificateAuthority:Rt.CA,operationsApi_tls_certificate:Rt["OPERATIONS-API"],operationsApi_tls_certificateAuthority:Rt["OPERATIONS-CA"]},m2={[Rt.SERVER]:2,[Rt.DEFAULT]:1},S2={[Rt["OPERATIONS-API"]]:3,[Rt.SERVER]:2,[Rt.DEFAULT]:1},T2={[Rt["OPERATIONS-API"]]:3,[Rt.SERVER]:2,[Rt.DEFAULT]:1},g2={[Rt["OPERATIONS-CA"]]:3,[Rt.CA]:2,[Rt["DEFAULT-CA"]]:1},A2={[Rt["OPERATIONS-CA"]]:3,[Rt.CA]:2,[Rt["DEFAULT-CA"]]:1},R2={[Rt.CA]:2,[Rt["DEFAULT-CA"]]:1};Object.assign(BC,{CERTIFICATE_PEM_NAME:d2,PRIVATEKEY_PEM_NAME:_2,CA_PEM_NAME:f2,CERT_NAME:Rt,CERT_CONFIG_NAME_MAP:p2,CERT_PREFERENCE_APP:m2,CERT_PREFERENCE_OPS:S2,CERT_PREFERENCE_REP:T2,CA_CERT_PREFERENCE_REP:g2,CA_CERT_PREFERENCE_OPS:A2,CA_CERT_PREFERENCE_APP:R2,CERTIFICATE_VALUES:u2,NATS_CERTIFICATE_PEM_NAME:E2,NATS_CA_PEM_NAME:h2})});var Tt=N((Fge,HC)=>{"use strict";var nn=require("validate.js");nn.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||nn.validators.type.checks[t](e)?null:` must be a '${t}' value`};nn.validators.type.checks={Object:a(function(e){return nn.isObject(e)&&!nn.isArray(e)},"Object"),Array:nn.isArray,Integer:nn.isInteger,Number:nn.isNumber,String:nn.isString,Date:nn.isDate,Boolean:a(function(e){return typeof e=="boolean"},"Boolean")};nn.validators.hasValidFileExt=function(e,t){return nn.isString(e)?e===""?"can't be blank":t.filter(r=>e.endsWith(r)).length>0?null:`must include one of the following valid file extensions - '${t.join("', '")}'`:null};HC.exports={validateObject:y2,validateObjectAsync:b2,validateBySchema:O2};function y2(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=nn(e,t,{format:"flat"});return r?new Error(r):null}a(y2,"validateObject");async function b2(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await nn.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(b2,"validateObjectAsync");function O2(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(O2,"validateBySchema")});var gg=N(($ge,$C)=>{"use strict";var GC=require("fs-extra"),me=require("joi"),N2=require("os"),{boolean:He,string:It,number:tr,array:za}=me.types(),{totalmem:xC}=require("os"),ja=require("path"),I2=W(),Tg=te(),qge=Sg(),kC=M(),w2=Tt(),FC="log",C2="components",D2="Invalid logging.rotation.maxSize unit. Available units are G, M or K",P2="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",L2="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",M2="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",U2="rootPath config parameter is undefined",sn=me.alternatives([tr.min(0),It]).optional().empty(null),ch=me.alternatives([za.items(It,{host:It.required(),port:sn},{hostname:It.required(),port:sn}).empty(null),za.items(It)]),pi,qC=!1;$C.exports={configValidator:v2,routesValidator:G2,route_constraints:ch};function v2(e,t=!1){if(qC=t,pi=e.rootPath,Tg.isEmpty(pi))throw U2;let r=He.optional(),n=tr.min(0).max(1e3).empty(null).default(F2),s=It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(Gd),i=It.optional().empty(null),o=It.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=me.string().empty(null).default(Gd),l=me.custom(H2).empty(null).default(Gd),u=e.clustering?.enabled,d=me.object({certificate:i,certificateAuthority:i,privateKey:i}),_;return u===!0?_=me.object({enabled:r,hubServer:me.object({cluster:me.object({name:me.required().empty(null),network:me.object({port:sn,routes:ch}).required()}).required(),leafNodes:me.object({network:me.object({port:sn}).required()}).required(),network:me.object({port:sn}).required()}).required(),leafServer:me.object({network:me.object({port:sn,routes:ch}).required(),streams:me.object({maxAge:tr.min(120).allow(null).optional(),maxBytes:tr.min(1).allow(null).optional(),maxMsgs:tr.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:me.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:He.optional(),databaseLevel:He.optional(),tls:me.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:He.required(),verify:He.optional()}),user:It.optional().empty(null)}).optional():_=me.object({enabled:r,tls:me.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:He.optional()})}).optional(),me.object({authentication:me.alternatives(me.object({authorizeLocal:He,cacheTTL:tr.required(),enableSessions:He}),He).optional(),analytics:me.object({aggregatePeriod:tr}),replication:me.object({hostname:me.alternatives(It,tr).optional().empty(null),url:It.optional().empty(null),port:sn,securePort:sn,routes:za.optional().empty(null),databases:me.alternatives(It,za),enableRootCAs:He.optional(),copyTablesToCatchUp:He.optional()}).optional(),componentsRoot:s.optional(),clustering:_,localStudio:me.object({enabled:r}).required(),logging:me.object({auditAuthEvents:me.object({logFailed:He,logSuccessful:He}),file:He.required(),level:me.valid("notify","fatal","error","warn","info","debug","trace"),rotation:me.object({enabled:He.optional(),compress:He.optional(),interval:It.custom(k2).optional().empty(null),maxSize:It.custom(x2).optional().empty(null),path:It.optional().empty(null).default(Gd)}).required(),root:s,stdStreams:He.required(),auditLog:He.required()}).required(),operationsApi:me.object({network:me.object({cors:He.optional(),corsAccessList:za.optional(),headersTimeout:tr.min(1).optional(),keepAliveTimeout:tr.min(1).optional(),port:sn,domainSocket:me.optional().empty("hdb/operations-server").default(Gd),securePort:sn,timeout:tr.min(1).optional()}).optional(),tls:me.alternatives([me.array().items(d),d])}).required(),rootPath:It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:me.object({network:me.object({port:sn,securePort:sn,mtls:me.alternatives([He.optional(),me.object({user:It.optional(),certificateAuthority:i,required:He.optional()})])}).required(),webSocket:He.optional(),requireAuthentication:He.optional()}),http:me.object({compressionThreshold:tr.optional(),cors:He.optional(),corsAccessList:za.optional(),headersTimeout:tr.min(1).optional(),port:sn,securePort:sn,maxHeaderSize:tr.optional(),mtls:me.alternatives([He.optional(),me.object({user:It.optional(),certificateAuthority:i,required:He.optional()})]),threadRange:me.alternatives([za.optional(),It.optional()])}).required(),threads:me.alternatives(n.optional(),me.object({count:n.optional(),debug:me.alternatives(He.optional(),me.object({startingPort:tr.min(1).optional(),host:It.optional(),waitForDebugger:He.optional()})),maxHeapMemory:tr.min(0).optional()})),storage:me.object({writeAsync:He.required(),overlappingSync:He.optional(),caching:He.optional(),compression:me.alternatives([He.optional(),me.object({dictionary:It.optional(),threshold:tr.optional()})]),compactOnStart:He.optional(),compactOnStartKeepBackup:He.optional(),noReadAhead:He.optional(),path:l,prefetchWrites:He.optional(),maxFreeSpaceToLoad:tr.optional(),maxFreeSpaceToRetain:tr.optional()}).required(),ignoreScripts:He.optional(),tls:me.alternatives([me.array().items(d),d])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(v2,"configValidator");function B2(e){return qC||GC.existsSync(e)?null:`Specified path ${e} does not exist.`}a(B2,"doesPathExist");function H2(e,t){me.assert(e,It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=B2(e);if(r)return t.message(r)}a(H2,"validatePath");function x2(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(D2);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(L2):e}a(x2,"validateRotationMaxSize");function k2(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(P2);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(M2):e}a(k2,"validateRotationInterval");function F2(e,t){let r=t.state.path.join("."),n=N2.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||xC();return i=Math.round(Math.min(i,xC())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),I2.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(F2,"setDefaultThreads");function Gd(e,t){let r=t.state.path.join(".");if(!Tg.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(Tg.isEmpty(pi))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return ja.join(pi,C2);case"logging.root":return ja.join(pi,FC);case"clustering.leafServer.streams.path":return ja.join(pi,"clustering","leaf");case"storage.path":let n=ja.join(pi,kC.LEGACY_DATABASES_DIR_NAME);return GC.existsSync(n)?n:ja.join(pi,kC.DATABASES_DIR_NAME);case"logging.rotation.path":return ja.join(pi,FC);case"operationsApi.network.domainSocket":return r==null?null:ja.join(pi,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(Gd,"setDefaultRoot");function G2(e){let t=me.object({routes:ch});return w2.validateBySchema({routes:e},t)}a(G2,"routesValidator")});var Qa={};je(Qa,{server:()=>it});var VC,it,qr=Ie(()=>{VC=L(fi()),it={};(0,VC._assignPackageExport)("server",it)});var wt=N(eD=>{"use strict";var on=M(),Er=te(),hr=W(),{configValidator:q2,routesValidator:KC}=gg(),$r=require("fs-extra"),WC=require("yaml"),Ln=require("path"),$2=require("is-number"),jC=require("properties-reader"),V2=require("lodash"),{handleHDBError:K2}=_e(),{HTTP_STATUS_CODES:Y2,HDB_ERROR_MSGS:Cl}=Dn(),{server:W2}=(qr(),oe(Qa)),{DATABASES_PARAM_CONFIG:qd,CONFIG_PARAMS:Pn,CONFIG_PARAM_MAP:ks}=on,j2="Unable to get config value because config is uninitialized",z2="Config successfully initialized",Q2="Error backing up config file",J2="Empty parameter sent to getConfigValue",zC=Ln.join(on.PACKAGE_ROOT,"config","yaml",on.HDB_DEFAULT_CONFIG_FILE),X2=Ln.join(on.PACKAGE_ROOT,"config","yaml","defaultNatsConfig.yaml"),Z2="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",YC={logging_rotation_retain:"logging.rotation.retain",logging_rotation_rotate:"logging.rotation.rotate",logging_rotation_rotateinterval:"logging.rotation.rotateInterval",logging_rotation_rotatemodule:"logging.rotation.rotateModule",logging_rotation_timezone:"logging.rotation.timezone",logging_rotation_workerinterval:"logging.rotation.workerInterval"},lh,jt,uh;Object.assign(eD,{createConfigFile:e4,getDefaultConfig:t4,getConfigValue:JC,initConfig:dh,flattenConfig:Dl,updateConfigValue:XC,updateConfigObject:n4,getConfiguration:o4,setConfiguration:a4,readConfigFile:bg,getClusteringRoutes:c4,initOldConfig:ZC,getConfigFromFile:l4,getConfigFilePath:Ja,addConfig:u4,deleteConfigFromFile:d4,getConfigObj:_4,resolvePath:Ag,getFlatConfigObj:f4});function Ag(e){if(e?.startsWith("~/"))return Ln.join(Er.getHomeDir(),e.slice(1));let t=se();return Ln.resolve(t.getHdbBasePath(),e)}a(Ag,"resolvePath");function e4(e,t=!1){let r=Vo(zC);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=WC.parseDocument($r.readFileSync(X2,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}lh=Dl(r.toJSON());let n;for(let c in e){let l=ks[c.toLowerCase()];if(l===Pn.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(u=>({[u]:e[c][u]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let u=l.split("_"),d=Rg(l,e[c]);l==="rootPath"&&d?.endsWith("/")&&(d=d.slice(0,-1));try{r.setIn([...u],d)}catch(_){hr.error(_)}}}n&&QC(r,n),yg(r,t);let s=r.toJSON();jt=Dl(s);let i=r.getIn(["rootPath"]),o=Ln.join(i,on.HDB_CONFIG_FILE);$r.createFileSync(o),$r.writeFileSync(o,String(r)),hr.trace(`Config file written to ${o}`)}a(e4,"createConfigFile");function QC(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!Er.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(qd.TABLES))for(let i in n[s][qd.TABLES])for(let o in n[s][qd.TABLES][i]){let c=n[s][qd.TABLES][i][o],l=[Pn.DATABASES,s,qd.TABLES,i,o];e.hasIn(l)?e.setIn(l,c):e.addIn(l,c)}else for(let i in n[s]){let o=n[s][i],c=[Pn.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){hr.error("Error parsing schemas CLI/env config arguments",n)}}a(QC,"setSchemasConfig");function t4(e){if(lh===void 0){let r=Vo(zC);lh=Dl(r.toJSON())}let t=ks[e.toLowerCase()];if(t!==void 0)return lh[t.toLowerCase()]}a(t4,"getDefaultConfig");function JC(e){if(e==null){hr.info(J2);return}if(jt===void 0){hr.trace(j2);return}let t=ks[e.toLowerCase()];if(t!==void 0)return jt[t.toLowerCase()]}a(JC,"getConfigValue");function Ja(e=Er.getPropsFilePath()){let t=Er.getEnvCliRootPath();if(t)return Ag(Ln.join(t,on.HDB_CONFIG_FILE));let r=jC(e);return Ag(r.get(on.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(Ja,"getConfigFilePath");function dh(e=!1){if(jt===void 0||e){let t;if(!Er.noBootFile()){t=Er.getPropsFilePath();try{$r.accessSync(t,$r.constants.F_OK|$r.constants.R_OK)}catch(i){throw hr.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Ja(t),n;if(r.includes("config/settings.js"))try{ZC(r);return}catch(i){if(i.code!==on.NODE_ERROR_CODES.ENOENT)throw i}try{n=Vo(r)}catch(i){if(i.code===on.NODE_ERROR_CODES.ENOENT){hr.trace(`HarperDB config file not found at ${r}.
11
+ This can occur during early stages of install where the config file has not yet been created`);return}else throw hr.error(i),new Error(`Error reading HarperDB config file at ${r}`)}r4(n,r),yg(n);let s=n.toJSON();if(W2.config=s,jt=Dl(s),jt.logging_rotation_rotate)for(let i in YC)jt[i]&&hr.error(`Config ${YC[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);hr.trace(z2)}}a(dh,"initConfig");function r4(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Ln.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Ln.join(r,"log")),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n&&(hr.trace("Updating config file with missing config params"),$r.writeFileSync(t,String(e)))}a(r4,"checkForUpdatedConfig");function yg(e,t=!1){let r=e.toJSON();if(r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads),r.http?.port&&r.http?.port===r.http?.securePort)throw Cl.CONFIG_VALIDATION("http.port and http.securePort cannot be the same value");if(r.operationsApi?.network?.port&&r.operationsApi?.network?.port===r.operationsApi?.network?.securePort)throw Cl.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=q2(r,t);if(n.error)throw Cl.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket),r?.clustering?.enabled&&e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path)}a(yg,"validateConfig");function n4(e,t){jt===void 0&&(jt={});let r=ks[e.toLowerCase()];if(r===void 0){hr.trace(`Unable to update config object because config param '${e}' does not exist`);return}jt[r.toLowerCase()]=t}a(n4,"updateConfigObject");function XC(e,t,r=void 0,n=!1,s=!1,i=!1){jt===void 0&&dh();let o=JC(ks.hdb_root),c=Ln.join(o,on.HDB_CONFIG_FILE),l=Vo(c),u;if(r===void 0&&e.toLowerCase()===Pn.DATABASES)u=t;else if(r===void 0){let E;if(i)E=e;else if(E=ks[e.toLowerCase()],E===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let f=E.split("_"),h=Rg(E,t);l.setIn([...f],h)}else for(let E in r){let f=ks[E.toLowerCase()];if(f===Pn.HTTP_SECUREPORT&&r[E]===jt[Pn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),f===Pn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===jt[Pn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),f===Pn.DATABASES){u=r[E];continue}if(f?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!f&&(E.endsWith("_package")||E.endsWith("_port"))&&(f=E),f!==void 0){let h=f.split("_"),T=on.LEGACY_CONFIG_PARAMS[E.toUpperCase()];T&&T.startsWith("customFunctions")&&l.hasIn(T.split("_"))&&(f=T,h=T.split("_"));let m=Rg(f,r[E]);f==="rootPath"&&m?.endsWith("/")&&(m=m.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],m)}catch(g){hr.error(g)}}}u&&QC(l,u),yg(l);let d=l.getIn(["rootPath"]),_=Ln.join(d,on.HDB_CONFIG_FILE);n===!0&&s4(c,d),$r.writeFileSync(_,String(l)),s&&(jt=Dl(l.toJSON())),hr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(XC,"updateConfigValue");function s4(e,t){try{let r=Ln.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${on.HDB_CONFIG_FILE}.bak`);$r.copySync(e,r),hr.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){hr.error(Q2),hr.error(r)}}a(s4,"backupConfigFile");var i4=["databases"];function Dl(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network={...e.http,...e.operationsApi.network}),e?.operationsApi&&(e.operationsApi.tls={...e.tls,...e.operationsApi.tls}),uh=e,r(e);function r(n){let s={};for(let i in n)if(n.hasOwnProperty(i)){if(typeof n[i]=="object"&&n[i]!==null&&!Array.isArray(n[i])&&!i4.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!Pn[l.toUpperCase()]&&ks[l]&&(s[ks[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Dl,"flattenConfig");function Rg(e,t){if(e===Pn.CLUSTERING_NODENAME||e===Pn.CLUSTERING_USER){if(t==null)return t;if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if($2(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Er.isObject(t)||t===null)return t;if(typeof t=="string"&&t.toLowerCase()==="true")return!0;if(typeof t=="string"&&t.toLowerCase()==="false")return!1}if(t===void 0||t.toLowerCase()==="undefined")return null;if(typeof t=="string"&&(t.startsWith("{")&&t.endsWith("}")||t.startsWith("[")&&t.endsWith("]")))try{return JSON.parse(t)}catch{}return Er.autoCast(t)}a(Rg,"castConfigValue");function o4(){let e=Er.getPropsFilePath(),t=Ja(e);return Vo(t).toJSON()}a(o4,"getConfiguration");async function a4(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return XC(void 0,void 0,s,!0),Z2}catch(i){throw typeof i=="string"||i instanceof String?K2(i,i,Y2.BAD_REQUEST,void 0,void 0,!0):i}}a(a4,"setConfiguration");function bg(){let e=Er.getPropsFilePath();try{$r.accessSync(e,$r.constants.F_OK|$r.constants.R_OK)}catch(n){if(!Er.noBootFile())throw hr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Ja(e);return Vo(t).toJSON()}a(bg,"readConfigFile");function Vo(e){return WC.parseDocument($r.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Vo,"parseYamlDoc");function c4(){let e=bg(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Er.isEmptyOrZeroLength(t)?[]:t;let r=KC(t);if(r)throw Cl.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Er.isEmptyOrZeroLength(n)?[]:n;let s=KC(n);if(s)throw Cl.CONFIG_VALIDATION(s.message);if(!Er.isEmptyOrZeroLength(n)&&!Er.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Er.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw Cl.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(c4,"getClusteringRoutes");function ZC(e){let t=jC(e);jt={};for(let r in ks){let n=t.get(r.toUpperCase());if(Er.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=ks[r].toLowerCase();s===Pn.LOGGING_ROOT?jt[s]=Ln.dirname(n):jt[s]=n}return jt}a(ZC,"initOldConfig");function l4(e){let t=bg();return V2.get(t,e.replaceAll("_","."))}a(l4,"getConfigFromFile");async function u4(e,t){let r=Vo(Ja());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await $r.writeFile(Ja(),String(r))}a(u4,"addConfig");function d4(e){let t=Ja(Er.getPropsFilePath()),r=Vo(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Ln.join(n,on.HDB_CONFIG_FILE);$r.writeFileSync(s,String(r))}a(d4,"deleteConfigFromFile");function _4(){return uh||(dh(),uh)}a(_4,"getConfigObj");function f4(){return jt||dh(),jt}a(f4,"getFlatConfigObj")});var se=N((iD,oD)=>{"use strict";var Og=require("fs-extra"),Xa=require("path"),tD=require("os"),E4=require("properties-reader"),Vd=W(),$d=te(),De=M(),_h=wt(),h4="Error initializing environment manager",fh="BOOT_PROPS_FILE_PATH",rD=!1,p4={[De.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},Qi={};Object.assign(iD,oD.exports={BOOT_PROPS_FILE_PATH:fh,getHdbBasePath:m4,setHdbBasePath:S4,get:nD,initSync:g4,setProperty:Qe,initTestEnvironment:R4,setCloneVar:A4});function m4(){return Qi[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(m4,"getHdbBasePath");function S4(e){Qi[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(S4,"setHdbBasePath");function nD(e){let t=_h.getConfigValue(e);return t===void 0?Qi[e]:t}a(nD,"get");function Qe(e,t){p4[e]&&(Qi[e]=t),_h.updateConfigObject(e,t)}a(Qe,"setProperty");function T4(){let e;try{e=$d.getPropsFilePath(),Og.accessSync(e,Og.constants.F_OK|Og.constants.R_OK),rD=!0;let t=E4(e);return Qi[De.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(De.HDB_SETTINGS_NAMES.INSTALL_USER),Qi[De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),Qi[fh]=e,!0}catch{return Vd.trace(`Environment manager found no properties file at ${e}`),!1}}a(T4,"doesPropFileExist");function g4(e=!1){try{((rD||T4()||$d.noBootFile())&&!sD||e)&&(_h.initConfig(e),Qi[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=_h.getConfigValue(De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){Vd.error(h4),Vd.error(t),console.error(t),process.exit(1)}}a(g4,"initSync");var sD=!1;function A4(e){sD=e}a(A4,"setCloneVar");function R4(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:n,https_enabled:s,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,l=Xa.join(__dirname,"../../","unitTests");Qi[fh]=Xa.join(l,"hdb_boot_properties.file"),Qe(De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Xa.join(l,"settings.test")),Qe(De.HDB_SETTINGS_NAMES.INSTALL_USER,tD.userInfo()?tD.userInfo().username:void 0),Qe(De.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Qe(De.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Xa.join(l,"envDir","log")),Qe(De.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Qe(De.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Qe(De.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Qe(De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Xa.join(l,"envDir")),Qe(De.CONFIG_PARAMS.STORAGE_PATH,Xa.join(l,"envDir")),s&&(Qe(De.CONFIG_PARAMS.HTTP_SECUREPORT,nD(De.CONFIG_PARAMS.HTTP_PORT)),Qe(De.CONFIG_PARAMS.HTTP_PORT,null)),Qe(De.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Qe(De.CONFIG_PARAMS.HTTP_PORT,9926),Qe(De.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Qe(De.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),Qe(De.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,$d.isEmpty(i)?!1:i),Qe(De.CONFIG_PARAMS.HTTP_CORS,$d.isEmpty(i)?!1:i),Qe(De.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Qe(De.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Qe(De.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Qe(De.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Qe(De.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Xa.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Qe(De.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,$d.isEmpty(c)?!1:c),o&&(Qe("CORS_ACCESSLIST",o),Qe(De.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Qe(De.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Qe(De.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Qe(De.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Qe(De.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Qe(De.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Qe(De.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${fh}. Please check your boot props and settings files`;Vd.fatal(r),Vd.error(t)}}a(R4,"initTestEnvironment")});var gt=N((jge,fD)=>{"use strict";var zd=M(),y4=te(),an=se(),Qd=require("path"),b4=require("minimist"),aD=require("fs-extra"),cD=require("lodash");an.initSync();var{CONFIG_PARAMS:Ko,DATABASES_PARAM_CONFIG:Kd,SYSTEM_SCHEMA_NAME:Eh}=zd,Yd,Wd,jd;function lD(){if(Yd!==void 0)return Yd;if(an.getHdbBasePath()!==void 0)return Yd=an.get(Ko.STORAGE_PATH)||Qd.join(an.getHdbBasePath(),zd.DATABASES_DIR_NAME),Yd}a(lD,"getBaseSchemaPath");function uD(){if(Wd!==void 0)return Wd;if(an.getHdbBasePath()!==void 0)return Wd=_D(Eh),Wd}a(uD,"getSystemSchemaPath");function dD(){if(jd!==void 0)return jd;if(an.getHdbBasePath()!==void 0)return jd=an.get(zd.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||Qd.join(an.getHdbBasePath(),zd.TRANSACTIONS_DIR_NAME),jd}a(dD,"getTransactionAuditStoreBasePath");function O4(e,t){let r=an.get(Ko.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||Qd.join(dD(),e.toString())}a(O4,"getTransactionAuditStorePath");function _D(e,t){e=e.toString(),t=t&&t.toString();let r=an.get(zd.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||Qd.join(lD(),e)}a(_D,"getSchemaPath");function N4(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,b4(process.argv));let n=r[Ko.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!y4.isObject(n))throw o;i=n}for(let o of i){let c=o[Eh];if(!c)continue;let l=an.get(Ko.DATABASES);l=l??{};let u=c?.tables?.[t]?.[Kd.PATH];if(u)return cD.set(l,[Eh,Kd.TABLES,t,Kd.PATH],u),an.setProperty(Ko.DATABASES,l),u;let d=c?.[Kd.PATH];if(d)return cD.set(l,[Eh,Kd.PATH],d),an.setProperty(Ko.DATABASES,l),d}}let s=r[Ko.STORAGE_PATH.toUpperCase()];if(s){if(!aD.pathExistsSync(s))throw new Error(s+" does not exist");let i=Qd.join(s,e);return aD.mkdirsSync(i),an.setProperty(Ko.STORAGE_PATH,s),i}return uD()}a(N4,"initSystemSchemaPaths");function I4(){Yd=void 0,Wd=void 0,jd=void 0}a(I4,"resetPaths");fD.exports={getBaseSchemaPath:lD,getSystemSchemaPath:uD,getTransactionAuditStorePath:O4,getTransactionAuditStoreBasePath:dD,getSchemaPath:_D,initSystemSchemaPaths:N4,resetPaths:I4}});var cn=N((Xge,SD)=>{"use strict";var w4=Dn().LMDB_ERRORS_ENUM,Qge=require("lmdb"),C4=Ht(),Jge=require("buffer").Buffer,{OVERFLOW_MARKER:ED,MAX_SEARCH_KEY_LENGTH:hh}=C4,hD=["number","string","symbol","boolean","bigint"];function D4(e){if(e=e?.primaryStore||e,!e)throw new Error(w4.ENV_REQUIRED)}a(D4,"validateEnv");function P4(e){if(e==null)return null;let t;try{t=typeof e=="object"?JSON.stringify(e):e.toString()}catch{t=e.toString()}return t}a(P4,"stringifyData");function L4(e){return e instanceof Date?e.valueOf():e}a(L4,"convertKeyValueToWrite");function M4(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(hD.includes(typeof e))return e.length>hh?[e.slice(0,hh)+ED]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(hD.includes(typeof i))i.length>hh?r.push(i.slice(0,hh)+ED):r.push(i);else{if(i===null&&t)return r.push(null);if(i instanceof Date)return r.push(i.getTime())}}}else if(e instanceof Date)return[e.getTime()];return r}a(M4,"getIndexedValues");var ph=0,pD=0;function mD(){pD=Date.now()-performance.now()}a(mD,"adjustStartTime");mD();var U4=6e4;setInterval(mD,U4).unref();function v4(){let e=performance.now()+pD;return e>ph?(ph=e,e):(ph+=488e-6,ph)}a(v4,"getNextMonotonicTime");SD.exports={validateEnv:D4,stringifyData:P4,convertKeyValueToWrite:L4,getNextMonotonicTime:v4,getIndexedValues:M4}});var Jd=N((eAe,TD)=>{"use strict";var B4=M().OPERATIONS_ENUM,Ng=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=B4.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};TD.exports=Ng});var Xd=N((nAe,yD)=>{"use strict";var rAe=Jd(),mh=M(),Ig=te(),gD=W(),H4=require("uuid"),{handleHDBError:Sh,hdb_errors:x4}=_e(),{HDB_ERROR_MSGS:Th,HTTP_STATUS_CODES:gh}=x4;yD.exports=AD;function AD(e,t,r){for(let s=0;s<t.length;s++)RD(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];k4(i,r,e.operation)}}a(AD,"processRows");AD.validateAttribute=RD;function RD(e){if(Buffer.byteLength(String(e))>mh.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw Sh(new Error,Th.ATTR_NAME_LENGTH_ERR(e),gh.BAD_REQUEST,void 0,void 0,!0);if(Ig.isEmptyOrZeroLength(e)||Ig.isEmpty(e.trim()))throw Sh(new Error,Th.ATTR_NAME_NULLISH_ERR,gh.BAD_REQUEST,void 0,void 0,!0)}a(RD,"validateAttribute");function k4(e,t,r){if(!e.hasOwnProperty(t)||Ig.isEmptyOrZeroLength(e[t])){if(r===mh.OPERATIONS_ENUM.INSERT||r===mh.OPERATIONS_ENUM.UPSERT){e[t]=H4.v4();return}throw gD.error("Update transaction aborted due to record with no hash value:",e),Sh(new Error,Th.RECORD_MISSING_HASH_ERR,gh.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>mh.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw gD.error(e),Sh(new Error,Th.HASH_VAL_LENGTH_ERR,gh.BAD_REQUEST,void 0,void 0,!0)}a(k4,"validateHash")});var bD,Mn,wg,Pl=Ie(()=>{bD=require("events"),Mn=class extends bD.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new wg;return t.queue=this,t}push(t){this.send(t)}send(t){this.resolveNext?(this.resolveNext({value:t}),this.resolveNext=null):this.hasDataListeners?this.emit("data",t):(this.queue||(this.queue=[]),this.queue.push(t))}getNextMessage(){let t=this.queue?.shift();return t||this.emit("drained"),t}waitForDrain(){return new Promise(t=>{!this.queue||this.queue.length===0?t(!0):(this.once("drained",()=>t(!0)),this.currentDrainResolver=t,this.drainCloseListener||(this.drainCloseListener=!0,this.on("close",()=>{this.currentDrainResolver?.(!1)})))})}on(t,r){if(t==="data"&&!this.hasDataListeners)for(this.hasDataListeners=!0;this.queue?.length>0;)r(this.queue.shift());return super.on(t,r)}},wg=class{static{a(this,"EventQueueIterator")}queue;push(t){this.queue.send(t)}next(){let t=this.queue.getNextMessage();return t?{value:t}:new Promise(r=>this.queue.resolveNext=r)}return(t){return this.queue.emit("close"),{value:t,done:!0}}throw(t){return this.queue.emit("close",t),{done:!0}}}});var Pg={};je(Pg,{loadGQLSchema:()=>q4,start:()=>Dg,startOnMainThread:()=>G4});function Dg({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:u,StringValueNode:d}=await import("graphql"),_=o(new c(r.toString(),s)),E=new Map,f=[],h;for(let g of _.definitions)switch(g.kind){case l.OBJECT_TYPE_DEFINITION:let H=function(Y){if(Y.kind==="NonNullType"){let Q=H(Y.type);return Q.nullable=!1,Q}if(Y.kind==="ListType")return{type:"array",elements:H(Y.type)};let ne={type:Y.name?.value};return Object.defineProperty(ne,"location",{value:Y.loc.startToken}),ne};a(H,"getProperty");let S=g.name.value,b=[],I={table:null,database:null,properties:b};E.set(S,I);for(let Y of g.directives){if(Y.name.value==="table"){for(let ne of Y.arguments)I[ne.name.value]=ne.value.value;I.schema&&(I.database=I.schema),I.table||(I.table=S),I.audit&&(I.audit=I.audit!=="false"),I.attributes=I.properties,f.push(I)}if(Y.name.value==="sealed"&&(I.sealed=!0),Y.name.value==="splitSegments"&&(I.splitSegments=!0),Y.name.value==="replicate"&&(I.replicate=!0),Y.name.value==="export"){I.export=!0;for(let ne of Y.arguments)typeof I.export!="object"&&(I.export={}),I.export[ne.name.value]=ne.value.value}}let B=!1,X={};for(let Y of g.fields){let V=H(Y.type);V.name=Y.name.value,b.push(V),X[V.name]=void 0;for(let ne of Y.directives){let Q=ne.name.value;if(Q==="primaryKey")B?console.warn("Can not define two attributes as a primary key at",ne.loc):(V.isPrimaryKey=!0,B=!0);else if(Q==="indexed")V.indexed=!0;else if(Q==="computed"){for(let de of ne.arguments||[])if(de.name.value==="from"){let j=de.value.value;V.computed={from:m(j,de,X)},V.version==null&&(V.version=j)}else de.name.value==="version"&&(V.version=de.value.value);V.computed=V.computed||!0}else if(Q==="relationship"){let de={};for(let j of ne.arguments)de[j.name.value]=j.value.value;V.relationship=de}else if(Q==="createdTime")V.assignCreatedTime=!0;else if(Q==="updatedTime")V.assignUpdatedTime=!0;else if(Q==="expiresAt")V.expiresAt=!0;else if(Q==="allow"){let de=V.authorizedRoles=[];for(let j of ne.arguments)j.name.value==="role"&&de.push(j.value.value)}else server.knownGraphQLDirectives.includes(Q)&&console.warn(`@${Q} is an unknown directive, at`,ne.loc)}}I.type=S,S==="Query"&&(h=I)}function T(g){let S=E.get(g.type);S?(Object.defineProperty(g,"properties",{value:S.properties}),Object.defineProperty(g,"definition",{value:S})):g.type==="array"?T(g.elements):F4.includes(g.type)||(0,ND.getWorkerIndex)()===0&&console.error(`The type ${g.type} is unknown at line ${g.location.line}, column ${g.location.column}, in ${s}`)}a(T,"connectPropertyType");for(let g of E.values())for(let S of g.properties)T(S);for(let g of f)g.tableClass=e(g),g.export&&(g.export.name===""?i.set((0,Cg.dirname)(n),g.tableClass):i.set((0,Cg.dirname)(n)+"/"+(g.export.name||g.type),g.tableClass,g.export));function m(g,S,b){return new OD.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${g}; } } } } computed;`,{filename:s,lineOffset:S.loc.startToken.line-1,columnOffset:S.loc.startToken.column}).runInThisContext()(b)}a(m,"createComputedFrom")}}var Cg,OD,ND,F4,G4,q4,ID=Ie(()=>{Cg=require("path"),OD=require("node:vm");Pe();ND=L(dt()),F4=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];server.knownGraphQLDirectives&&(server.knownGraphQLDirectives=["table","sealed","export","primaryKey","indexed","computed","relationship","createdTime","updatedTime","expiresAt","allow"]);a(Dg,"start");G4=Dg,q4=Dg({ensureTable:Et}).handleFile});var UD={};je(UD,{parse:()=>Mg,streamAsJSON:()=>Zd,stringify:()=>Za});function Zd(e){return new Lg({value:e})}function wD(e){return console.error(e),JSON.stringify(e.toString())}function CD(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Za(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===LD)return MD(e);if(t.resolution)return t.resolution.then(()=>Za(e));throw t}}function MD(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+=MD(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Za(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function Mg(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),K4.test(e)?$4.parse(e):JSON.parse(e)):null}var DD,PD,$4,V4,LD,Lg,K4,Ug=Ie(()=>{DD=require("stream"),PD=L(require("json-bigint-fixes")),$4=(0,PD.default)({useNativeBigInt:!0}),V4=1e4,LD={message:"Cannot serialize BigInt to JSON"};BigInt.prototype.toJSON=function(){throw LD};a(Zd,"streamAsJSON");Lg=class extends DD.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),wD)}catch(s){yield wD(s)}else yield Za(t)}else yield Za(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);CD(this.readIterator(this.iterator),t=>{t?(this.done=!0,this.push(null)):this._amReading=!1},t=>{console.error(t),this.done=!0,this.push(t.toString()),this.push(null)})}}push(t){return t===null||t instanceof Buffer?(this.bufferSize>0&&this.flush(),super.push(t)):(this.bufferSize+=t.length||t.toString().length,this.buffer.push(t),this.bufferSize>V4?this.flush():!0)}flush(){let t=super.push(this.buffer.join(""));return this.buffer=[],this.bufferSize=0,t}readIterator(t){try{let r;if(t.childIterator)return CD(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(wD,"handleError");a(CD,"when");a(Za,"stringify");a(MD,"jsStringify");K4=/[[,:]\s*-?\d{16,}/;a(Mg,"parse")});var WD=N((dAe,YD)=>{"use strict";var vg=require("recursive-iterator"),Y4=require("alasql"),Bg=require("clone"),vD=te(),{handleHDBError:BD,hdb_errors:W4}=_e(),{HDB_ERROR_MSGS:HD,HTTP_STATUS_CODES:xD}=W4,{getDatabases:j4}=(Pe(),oe(lt)),z4=["DISTINCT_ARRAY"],kD=Symbol("validateTables"),Hg=Symbol("validateTable"),uAe=Symbol("getAllColumns"),FD=Symbol("validateAllColumns"),Ah=Symbol("findColumn"),GD=Symbol("validateOrderBy"),e_=Symbol("validateSegment"),xg=Symbol("validateColumn"),qD=Symbol("setColumnsForTable"),$D=Symbol("checkColumnsForAsterisk"),VD=Symbol("validateGroupBy"),KD=Symbol("hasColumns"),kg=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[kD](),this[$D](),this[FD]()}[kD](){if(this[KD]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[Hg](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[Hg](t.table)})}}[KD](){let t=!1,r=new vg(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[Hg](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=j4();if(!r[t.databaseid])throw BD(new Error,HD.SCHEMA_NOT_FOUND(t.databaseid),xD.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw BD(new Error,HD.TABLE_NOT_FOUND(t.databaseid,t.tableid),xD.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=Bg(s);i.table=Bg(t),this.attributes.push(i)})}[Ah](t){return this.attributes.filter(r=>t.tableid?(r.table.as===t.tableid||r.table.tableid===t.tableid)&&r.attribute===t.columnid:r.attribute===t.columnid)}[$D](){let t=new vg(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[qD](r.tableid)}[qD](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new Y4.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[FD](){this[e_](this.statement.columns,!1),this[e_](this.statement.joins,!1),this[e_](this.statement.where,!1),this[VD](this.statement.group,!1),this[e_](this.statement.order,!0)}[e_](t,r){if(!t)return;let n=new vg(t),s=[];for(let{node:i,path:o}of n)!vD.isEmpty(i)&&!vD.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[GD](i):s.push(this[xg](i)));return s}[VD](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&z4.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=Bg(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[Ah](n)[0];s&&r.push(s)}}}),this.statement.group.forEach(n=>{let s=null;if(!n.columnid)r.forEach((i,o)=>{if(i.toString()===n.toString()){s=i,r.splice(o,1);return}});else{let i=this[Ah](n);if(!i||i.length===0)throw`unknown column '${n.toString()}' in group by`;if(i.length>1)throw`ambiguously defined column '${n.toString()}' in group by`;r.forEach((o,c)=>{if(o.attribute===i[0].attribute&&o.table.tableid===i[0].table.tableid){s=o,r.splice(c,1);return}})}if(!s)throw`group by column '${n.toString()}' must be in select`}),r.length>0)throw`select column '${r[0].attribute?r[0].attribute:r[0].toString()}' must be in group by`}[GD](t){let r=this.statement.columns.filter(n=>n.as===t.columnid);if(r.length>1)throw`ambiguous column reference ${(t.tableid?t.tableid+".":"")+t.columnid} in order by`;r.length===0&&this[xg](t)}[xg](t){let r=this[Ah](t),n=(t.tableid?t.tableid+".":"")+t.columnid;if(r.length===0)throw`unknown column ${n}`;if(r.length>1)throw`ambiguous column reference ${n}`;return r[0]}};YD.exports=kg});var zD=N((fAe,jD)=>{"use strict";var Fg=class{static{a(this,"BridgeMethods")}createSchema(){throw new Error("createSchema bridge method is not defined")}dropSchema(){throw new Error("dropSchema bridge method is not defined")}createTable(){throw new Error("createTable bridge method is not defined")}dropTable(){throw new Error("dropTable bridge method is not defined")}createRecords(){throw new Error("createRecords bridge method is not defined")}updateRecords(){throw new Error("updateRecords bridge method is not defined")}async upsertRecords(){throw new Error("upsertRecords bridge method is not defined")}deleteRecords(){throw new Error("deleteRecords bridge method is not defined")}createAttribute(){throw new Error("createAttribute bridge method is not defined")}dropAttribute(){throw new Error("dropAttribute bridge method is not defined")}searchByConditions(){throw new Error("searchByConditions bridge method is not defined")}searchByHash(){throw new Error("searchByHash bridge method is not defined")}searchByValue(){throw new Error("searchByValue bridge method is not defined")}getDataByHash(){throw new Error("getDataByHash bridge method is not defined")}getDataByValue(){throw new Error("getDataByValue bridge method is not defined")}deleteRecordsBefore(){throw new Error("deleteRecordsBefore bridge method is not defined")}deleteAuditLogsBefore(){throw new Error("deleteAuditLogsBefore bridge method is not defined")}async readAuditLog(){throw new Error("readAuditLog bridge method is not defined")}};jD.exports=Fg});var JD=N((hAe,QD)=>{"use strict";var Gg=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};QD.exports=Gg});var tP={};je(tP,{HAS_EXPIRATION:()=>bh,HAS_RESIDENCY_ID:()=>zg,HAS_STRUCTURE_UPDATE:()=>Oh,LAST_TIMESTAMP_PLACEHOLDER:()=>s_,LOCAL_TIMESTAMP:()=>Q4,METADATA:()=>t_,NO_TIMESTAMP:()=>$g,PENDING_LOCAL_TIME:()=>Qg,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>jg,RecordEncoder:()=>Wg,TIMESTAMP_ASSIGN_LAST:()=>X4,TIMESTAMP_ASSIGN_NEW:()=>ZD,TIMESTAMP_ASSIGN_PREVIOUS:()=>eP,TIMESTAMP_PLACEHOLDER:()=>Rh,TIMESTAMP_RECORD_PREVIOUS:()=>Vg,getUpdateRecord:()=>Jg,handleLocalTimeForGets:()=>Nh});function eJ(){return n_[0]=n_[0]^64,J4.getFloat64(0)}function Nh(e){let t=e.getEntry;e.readCount=0,e.cachePuts=!1,e.getEntry=function(i,o){e.readCount++;let c=t.call(this,i,o),l=c?.value,u=l?.[t_];return u>=0&&(c.metadataFlags=u,c.localTime=l.localTime,c.value=l.value,c.residencyId=l.residencyId,l.expiresAt>=0&&(c.expiresAt=l.expiresAt)),c&&(c.key=i),c};let r=e.get;e.get=function(i,o){let c=r.call(this,i,o);return c?.[t_]>=0?c.value:c};let n=e.getRange;e.getRange=function(i){let o=n.call(this,i);return i.valuesForKey?o.map(c=>c?.value):i.values===!1||i.onlyCount?o:o.map(c=>{let l=c.value,u=l[t_];return u>=0&&(c.metadataFlags=u,c.localTime=l.localTime,c.value=l.value,c.residencyId=l.residencyId,l.expiresAt>=0&&(c.expiresAt=l.expiresAt)),c})};let s=e.useReadTransaction();if(s.done(),!s.done.isTracked){let i=s.constructor,o=s.use,c=s.done;i.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,ec.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let l=0;l<ec.length;l++){let u=ec[l].deref();(!u||u.isDone||u.isCommitted)&&ec.splice(l--,1)}},i.prototype.done.isTracked=!0}return e}function Jg(e,t,r){return function(n,s,i,o,c=-1,l,u,d="put",_,E){_||l==null?Ll=i?.localTime?Vg|eP:$g:Ll=l?i?.localTime?Vg|16384:ZD|16384:$g;let f=u?.expiresAt;if(f>=0&&(c|=bh),r_=c,Kg=f,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:Ll>0},T,m=0;try{let g=i?.residencyId,S=u?.residencyId;S&&(Yg=S,r_|=zg,m|=tc),g!==S&&(m|=rc,g||(g=0)),c&bh&&(m|=o_),u?.originatingOperation&&(m|=i_),_&&(h.ifVersion=T=i?.version??null);let b=e.put(n,s,h);if(l){let I=u?.user?.username;if(E&&(yh=e.encoder.encode(E)),e.encoder.hasStructureUpdate&&(m|=Oh,e.encoder.hasStructureUpdate=!1),_&&i?.localTime){let B=i?.localTime,H=r.get(B);if(H){let X=xt(H).previousLocalTime;return r.put(B,Ml(o,t,n,X,u?.nodeId??server.replication.getThisNodeId(r)??0,I,d,yh,m,S,g,f),{ifVersion:T}),b}}r.put(s_,Ml(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,I,d,yh,m,S,g,f,u?.originatingOperation),{append:d!=="invalidate",instructedWrite:!0,ifVersion:T})}return b}catch(g){throw g.message+=" id: "+n+" options: "+h,g}}}var XD,qg,Rh,s_,jg,Q4,t_,n_,J4,$g,ZD,X4,eP,Vg,bh,zg,Qg,Oh,Z4,yh,Ll,r_,Kg,Yg,Wg,ec,Ul=Ie(()=>{XD=require("msgpackr");Ji();qg=L(W()),Rh=new Uint8Array([1,1,1,1,4,64,0,0]),s_=new Uint8Array([1,1,1,1,1,0,0,0]),jg=new Uint8Array([1,1,1,1,3,64,0,0]),Q4=Symbol("local-timestamp"),t_=Symbol("metadata"),n_=new Uint8Array(8),J4=new DataView(n_.buffer,0,8),$g=0,ZD=0,X4=1,eP=3,Vg=4,bh=16,zg=32,Qg=1,Oh=256,Ll=0,r_=-1,Kg=-1,Yg=0,Wg=class extends XD.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(Ll||r_>=0){let o=0,c=Ll;c&&(o+=8,Ll=0);let l=r_,u=Kg,d=Yg;l>=0&&(o+=2,r_=-1,u>=0&&(o+=8,Kg=-1),d&&(o+=4,Yg=0));let _=Z4=r.call(this,s,i|2048|o);yh=_.subarray((_.start||0)+o,_.end);let E=_.start||0;return c&&(Rh[4]=c,Rh[5]=c>>8,_.set(Rh,E),E+=8),l>=0&&(_[E++]=l&31,_[E++]=l>>5,u>=0&&((_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(E,u),E+=8),d&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setUint32(E,d)),_}else return r.call(this,s,i)};let n=this.saveStructures;this.saveStructures=function(s,i){let o=n.call(this,s,i);return this.hasStructureUpdate=!0,o}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(n_,0,c),c+=8;else for(let E=0;E<8;E++)n_[E]=t[c++];l=eJ(),i=t[c]}let u,d;i<32&&(o=i|t[c+1]<<5,c+=2,o&bh&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&zg&&(d=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let _=r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c);return{localTime:l,value:_,[t_]:o,expiresAt:u,residencyId:d}}return r?.valueAsBuffer?t:super.decode(t,r)}catch(c){throw c.message+=", data: "+t.slice(0,40).toString("hex"),c}}};a(eJ,"getTimestamp");a(Nh,"handleLocalTimeForGets");ec=[];setInterval(()=>{for(let e=0;e<ec.length;e++){let t=ec[e].deref();!t||t.isDone||t.isCommitted?ec.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(qg.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):qg.error("Read transaction detected that has been open too long (over one minute), make sure read transactions are quickly closed",t)),t.openTimer++):t.openTimer=1)}},15e3).unref();a(Jg,"getUpdateRecord")});var a_=N((gAe,nP)=>{"use strict";var rP=se(),tJ=M(),{RecordEncoder:rJ}=(Ul(),oe(tP)),TAe=require("fs");rP.initSync();var nJ=rP.get(tJ.CONFIG_PARAMS.STORAGE_CACHING)!==!1,Xg=class{static{a(this,"OpenDBIObject")}constructor(t,r=!1){this.dupSort=t===!0,this.encoding=t?"ordered-binary":"msgpack",this.useVersions=r,this.sharedStructuresKey=Symbol.for("structures"),r&&(this.cache=nJ&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:rJ})}};nP.exports=Xg});var c_=N((RAe,sP)=>{"use strict";var Un=se(),as=M();Un.initSync();var Ih=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Un.get(as.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Un.get(as.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Un.get(as.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Un.get(as.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Un.get(as.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Un.get(as.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Un.get(as.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Un.get(as.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};sP.exports=Ih;Ih.MAX_DBS=1e4});var ht=N((bAe,EP)=>{"use strict";var eA=require("lmdb"),Fs=require("fs-extra"),vn=require("path"),wh=cn(),aP=W(),ln=Dn().LMDB_ERRORS_ENUM,Ch=JD(),tA=a_(),cP=c_(),Yo=Ht(),iP=M(),{table:sJ,resetDatabases:iJ}=(Pe(),oe(lt)),oP=se(),Gs=Yo.INTERNAL_DBIS_NAME,lP=Yo.DBI_DEFINITION_NAME,oJ="data.mdb",aJ="lock.mdb",l_=".mdb",cJ="-lock",Zg=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=cs(t,r),this.key_type=this.dbi[Yo.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[Yo.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new eA.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function Dh(e,t){if(e===void 0)throw new Error(ln.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(ln.ENV_NAME_REQUIRED)}a(Dh,"pathEnvNameValidation");async function rA(e,t,r=!0){try{await Fs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(ln.INVALID_BASE_PATH):n}try{let n=vn.join(e,t+l_);return await Fs.access(n,Fs.constants.R_OK|Fs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Fs.access(vn.join(e,t,oJ),Fs.constants.R_OK|Fs.constants.F_OK),vn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(ln.INVALID_ENVIRONMENT)}else throw new Error(ln.INVALID_ENVIRONMENT);throw n}}a(rA,"validateEnvironmentPath");function Ph(e,t){if(wh.validateEnv(e),t===void 0)throw new Error(ln.DBI_NAME_REQUIRED)}a(Ph,"validateEnvDBIName");async function lJ(e,t,r=!1,n=!1){Dh(e,t);let s=vn.basename(e);t=t.toString();let i=oP.get(iP.CONFIG_PARAMS.DATABASES);i||oP.setProperty(iP.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await rA(e,t,n),uP(e,t,r)}catch(o){if(o.message===ln.INVALID_ENVIRONMENT){let c=vn.join(e,t);await Fs.mkdirp(n?c:e);let l=new cP(n?c:c+l_,!1),u=eA.open(l);u.dbis=Object.create(null);let d=new tA(!1);u.openDB(Gs,d),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let _=nA(e,t,r);return u[Yo.ENVIRONMENT_NAME_KEY]=_,global.lmdb_map[_]=u,u}throw o}}a(lJ,"createEnvironment");async function uJ(e,t,r,n=!0){Dh(e,t),t=t.toString();let s=vn.join(e,t);return sJ({table:t,database:vn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(uJ,"copyEnvironment");async function uP(e,t,r=!1){Dh(e,t),t=t.toString();let n=nA(e,t,r);if(global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null)),global.lmdb_map[n]!==void 0)return global.lmdb_map[n];let s=await rA(e,t),i=vn.join(e,t+l_),o=s!=i,c=new cP(s,o),l=eA.open(c);l.dbis=Object.create(null);let u=_P(l);for(let d=0;d<u.length;d++)cs(l,u[d]);return l[Yo.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(uP,"openEnvironment");async function dJ(e,t,r=!1){Dh(e,t),t=t.toString();let n=vn.join(e,t+l_),s=await rA(e,t);if(global.lmdb_map!==void 0){let i=nA(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await dP(o),delete global.lmdb_map[i]}}await Fs.remove(s),await Fs.remove(s===n?s+cJ:vn.join(vn.dirname(s),aJ))}a(dJ,"deleteEnvironment");async function dP(e){wh.validateEnv(e);let t=e[Yo.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(dP,"closeEnvironment");function nA(e,t,r=!1){let s=`${vn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(nA,"getCachedEnvironmentName");function _J(e){wh.validateEnv(e);let t=Object.create(null),r=cs(e,Gs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Gs)try{t[n]=Object.assign(new Ch,s)}catch{aP.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(_J,"listDBIDefinitions");function _P(e){wh.validateEnv(e);let t=[],r=cs(e,Gs);for(let{key:n}of r.getRange({start:!1}))n!==Gs&&t.push(n);return t}a(_P,"listDBIs");function fJ(e,t){let n=cs(e,Gs).getEntry(t),s=new Ch;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{aP.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(fJ,"getDBIDefinition");function fP(e,t,r,n=!r){if(Ph(e,t),t=t.toString(),t===Gs)throw new Error(ln.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return cs(e,t)}catch(s){if(s.message===ln.DBI_DOES_NOT_EXIST){let i=new tA(r,n===!0),o=e.openDB(t,i),c=new Ch(r===!0,n);return o[lP]=c,cs(e,Gs).putSync(t,c),e.dbis[t]=o,o}throw s}}a(fP,"createDBI");function cs(e,t){if(Ph(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Gs?r=fJ(e,t):r=new Ch,r===void 0)throw new Error(ln.DBI_DOES_NOT_EXIST);let n;try{let s=new tA(r.dup_sort,r.useVersions);if(n=e.openDB(t,s),n.db===void 0)throw new Error("MDB_NOTFOUND")}catch(s){throw s.message.includes("MDB_NOTFOUND")===!0?new Error(ln.DBI_DOES_NOT_EXIST):s}return n[lP]=r,e.dbis[t]=n,n}a(cs,"openDBI");function EJ(e,t){Ph(e,t),t=t.toString();let r=cs(e,t),n=r.getStats();return r[Yo.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(EJ,"statDBI");async function hJ(e,t){try{let r=vn.join(e,t+l_);return(await Fs.stat(r)).size}catch{throw new Error(ln.INVALID_ENVIRONMENT)}}a(hJ,"environmentDataSize");function pJ(e,t){if(Ph(e,t),t=t.toString(),t===Gs)throw new Error(ln.CANNOT_DROP_INTERNAL_DBIS_NAME);cs(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],cs(e,Gs).removeSync(t)}a(pJ,"dropDBI");function mJ(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{cs(e,i)}catch(o){if(o.message===ln.DBI_DOES_NOT_EXIST)fP(e,i,i!==t,i===t),n=!0;else throw o}}n&&iJ()}a(mJ,"initializeDBIs");EP.exports={openDBI:cs,openEnvironment:uP,createEnvironment:lJ,listDBIs:_P,listDBIDefinitions:_J,createDBI:fP,dropDBI:pJ,statDBI:EJ,deleteEnvironment:dJ,initializeDBIs:mJ,TransactionCursor:Zg,environmentDataSize:hJ,copyEnvironment:uJ,closeEnvironment:dP}});var pP=N((NAe,hP)=>{"use strict";var sA=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};hP.exports=sA});var SP=N((wAe,mP)=>{"use strict";var iA=class{static{a(this,"UpdateRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n,this.original_records=s}};mP.exports=iA});var gP=N((DAe,TP)=>{"use strict";var oA=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};TP.exports=oA});var sc=N((vAe,yP)=>{"use strict";var SJ=ht(),TJ=pP(),gJ=SP(),AJ=gP(),mi=cn(),u_=Dn().LMDB_ERRORS_ENUM,RJ=Ht(),Xi=M(),yJ=te(),bJ=require("uuid"),LAe=require("lmdb"),{handleHDBError:OJ,hdb_errors:NJ}=_e(),{OVERFLOW_MARKER:MAe,MAX_SEARCH_KEY_LENGTH:UAe}=RJ,AP=se();AP.initSync();var Lh=AP.get(Xi.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),aA=Xi.TIME_STAMP_NAMES_ENUM.CREATED_TIME,nc=Xi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function IJ(e,t,r,n,s=mi.getNextMonotonicTime()){dA(e,t,r,n),cA(e,t,r);let i=new TJ,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];RP(u,!0,s);let d=wJ(e,t,r,u),_=u[t];o.push(d),c.push(_)}return lA(o,c,n,i,s)}a(IJ,"insertRecords");function wJ(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let d=c([[{}]]);Array.isArray(d)&&(c=d[0][Xi.FUNC_VAL],n[o]=c)}let l=mi.getIndexedValues(c),u=e.dbis[o];if(l){Lh&&u.prefetch(l.map(d=>({key:d,value:s})),Mh);for(let d=0,_=l.length;d<_;d++)u.put(l[d],s)}}Lh&&e.dbis[t].prefetch([s],Mh),e.dbis[t].put(s,n,n[nc])})}a(wJ,"insertRecord");function CJ(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(CJ,"removeSkippedRecords");function RP(e,t,r){let n=r>0;(n||!Number.isInteger(e[nc]))&&(e[nc]=r||(r=mi.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[aA]))&&(e[aA]=r||mi.getNextMonotonicTime()):delete e[aA]}a(RP,"setTimestamps");function cA(e,t,r){r.indexOf(Xi.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Xi.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Xi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Xi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),SJ.initializeDBIs(e,t,r)}a(cA,"initializeTransaction");async function DJ(e,t,r,n,s=mi.getNextMonotonicTime()){dA(e,t,r,n),cA(e,t,r);let i=new gJ,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let d=n[u],_=d[t],E;try{E=uA(e,t,d,_,i,!0,s)}catch{i.skipped_hashes.push(_),o.push(u);continue}c.push(E),l.push(_)}return lA(c,l,n,i,s,o)}a(DJ,"updateRecords");async function PJ(e,t,r,n,s=mi.getNextMonotonicTime()){try{dA(e,t,r,n)}catch(l){throw OJ(l,l.message,NJ.HTTP_STATUS_CODES.BAD_REQUEST)}cA(e,t,r);let i=new AJ,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],d;yJ.isEmpty(u[t])?(d=bJ.v4(),u[t]=d):d=u[t];let _=uA(e,t,u,d,i,!1,s);o.push(_),c.push(d)}return lA(o,c,n,i,s)}a(PJ,"upsertRecords");async function lA(e,t,r,n,s,i=[]){let o=await Promise.all(e);for(let c=0,l=o.length;c<l;c++)o[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||mi.getNextMonotonicTime(),CJ(r,i),n}a(lA,"finalizeWrite");function uA(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),u=l?.value,d=u;if(!u){if(i)return!1;u={}}if(RP(r,!d,o),Number.isInteger(r[nc])&&u[nc]>r[nc])return!1;d&&s.original_records.push(u);let _,E=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let T=r[h],m=e.dbis[h];if(m===void 0)continue;let g=u[h];if(typeof T=="function"){let b=T([[u]]);Array.isArray(b)&&(T=b[0][Xi.FUNC_VAL],r[h]=T)}if(T===g)continue;let S=mi.getIndexedValues(g);if(S){Lh&&m.prefetch(S.map(b=>({key:b,value:n})),Mh);for(let b=0,I=S.length;b<I;b++)m.remove(S[b],n)}if(S=mi.getIndexedValues(T),S){Lh&&m.prefetch(S.map(b=>({key:b,value:n})),Mh);for(let b=0,I=S.length;b<I;b++)m.put(S[b],n)}}let f={...u,...r};c.put(n,f,f[nc])},"do_put");return l?_=c.ifVersion(n,l.version,E):_=c.ifNoExists(n,E),_.then(f=>f?!0:uA(e,t,r,n,s,i,o))}a(uA,"updateUpsertRecord");function LJ(e,t,r){if(mi.validateEnv(e),t===void 0)throw new Error(u_.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(u_.WRITE_ATTRIBUTES_REQUIRED):new Error(u_.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(LJ,"validateBasic");function dA(e,t,r,n){if(LJ(e,t,r),!Array.isArray(n))throw n===void 0?new Error(u_.RECORDS_REQUIRED):new Error(u_.RECORDS_MUST_BE_ARRAY)}a(dA,"validateWrite");function Mh(){}a(Mh,"noop");yP.exports={insertRecords:IJ,updateRecords:DJ,upsertRecords:PJ}});var Zi=N((HAe,MJ)=>{MJ.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"}]},hdb_certificate:{hash_attribute:"name",name:"hdb_certificate",schema:"system",attributes:[{attribute:"name"},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var Ti=N((xAe,NP)=>{"use strict";var OP=te(),bP=M(),vl=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Si=require("joi"),Wo={schema_format:{pattern:vl,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},UJ=Si.alternatives(Si.string().min(1).max(Wo.schema_length.maximum).pattern(vl).messages({"string.pattern.base":"{:#label} "+Wo.schema_format.message}),Si.number(),Si.array()).required(),vJ=Si.alternatives(Si.string().min(1).max(Wo.schema_length.maximum).pattern(vl).messages({"string.pattern.base":"{:#label} "+Wo.schema_format.message}),Si.number()),BJ=Si.alternatives(Si.string().min(1).max(Wo.schema_length.maximum).pattern(vl).messages({"string.pattern.base":"{:#label} "+Wo.schema_format.message}),Si.number()).required();function HJ(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>Wo.schema_length.maximum?`'${e}' maximum of 250 characters`:vl.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(HJ,"checkValidTable");function xJ(e,t){return OP.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(xJ,"validateSchemaExists");function kJ(e,t){let r=t.state.ancestors[0].schema;return OP.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(kJ,"validateTableExists");function FJ(e,t){return e.toLowerCase()===bP.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${bP.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(FJ,"validateSchemaName");NP.exports={common_validators:Wo,schema_regex:vl,hdb_schema_table:UJ,validateSchemaExists:xJ,validateTableExists:kJ,validateSchemaName:FJ,checkValidTable:HJ,hdb_database:vJ,hdb_table:BJ}});var Uh=N((FAe,IP)=>{var{common_validators:gi}=Ti(),__=Tt(),d_="is required",rr={database:{presence:!1,format:gi.schema_format,length:gi.schema_length},schema:{presence:!1,format:gi.schema_format,length:gi.schema_length},table:{presence:!0,format:gi.schema_format,length:gi.schema_length},attribute:{presence:!0,format:gi.schema_format,length:gi.schema_length},hash_attribute:{presence:!0,format:gi.schema_format,length:gi.schema_length}};function f_(e){for(let t in e)e[t]=e[t]===null||e[t]===void 0||typeof e[t]=="object"?e[t]:e[t].toString();return e}a(f_,"makeAttributesStrings");function GJ(e){return e=f_(e),rr.table.presence=!1,rr.attribute.presence=!1,rr.hash_attribute.presence=!1,__.validateObject(e,rr)}a(GJ,"schema_object");function qJ(e){return e=f_(e),rr.table.presence={message:d_},rr.attribute.presence=!1,rr.hash_attribute.presence=!1,__.validateObject(e,rr)}a(qJ,"table_object");function $J(e){return e=f_(e),rr.table.presence={message:d_},rr.attribute.presence=!1,__.validateObject(e,rr)}a($J,"create_table_object");function VJ(e){return e=f_(e),rr.table.presence={message:d_},rr.attribute.presence={message:d_},rr.hash_attribute.presence=!1,__.validateObject(e,rr)}a(VJ,"attribute_object");function KJ(e){return e=f_(e),rr.table.presence={message:d_},rr.attribute.presence=!1,rr.hash_attribute.presence=!1,__.validateObject(e,rr)}a(KJ,"describe_table");function YJ(e){if(e){if(!Array.isArray(e))throw new Error("residence must be a string array");if(e.length===0)throw new Error("residence cannot be an empty array");for(let t=0;t<e.length;t++)if(typeof e[t]!="string")throw new Error(`residence must be a string array, item '${e[t]}' is not a string`)}}a(YJ,"validateTableResidence");IP.exports={schema_object:GJ,create_table_object:$J,table_object:qJ,attribute_object:VJ,describe_table:KJ,validateTableResidence:YJ}});var CP=N((qAe,wP)=>{"use strict";var WJ=require("uuid"),_A=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||WJ.v4(),this.schema_table=`${this.schema}.${this.table}`}};wP.exports=_A});var vh=N((VAe,DP)=>{"use strict";var jJ=CP(),fA=class extends jJ{static{a(this,"LMDBCreateAttributeObject")}constructor(t,r,n,s,i=!0,o=!1){super(t,r,n,s),this.dup_sort=i,this.is_hash_attribute=o}};DP.exports=fA});var LP=N((YAe,PP)=>{"use strict";PP.exports=QJ;var zJ="inserted";function QJ(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===zJ?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(QJ,"returnObject")});var Bh=N((zAe,BP)=>{"use strict";var JJ=M(),EA=ht(),XJ=sc(),{getSystemSchemaPath:ZJ,getSchemaPath:e3}=gt(),jAe=Zi(),t3=Uh(),r3=vh(),n3=LP(),{handleHDBError:MP,hdb_errors:vP}=_e(),UP=te(),{HTTP_STATUS_CODES:s3}=vP,i3="inserted";BP.exports=o3;async function o3(e){let t=t3.attribute_object(e);if(t)throw MP(new Error,t.message,vP.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&UP.checkGlobalSchemaTable(e.schema,e.table);if(r)throw MP(new Error,r,s3.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=UP.isEmpty(e.dup_sort)||e.dup_sort=="true";let n=[];if(global.hdb_schema[e.schema]&&global.hdb_schema[e.schema][e.table]&&(n=global.hdb_schema[e.schema][e.table].attributes),Array.isArray(n)&&n.length>0){for(let i of n)if(i.attribute===e.attribute)throw new Error(`attribute '${i.attribute}' already exists in ${e.schema}.${e.table}`)}let s=new r3(e.schema,e.table,e.attribute,e.id);try{let i=await EA.openEnvironment(e3(e.schema,e.table),e.table);if(i.dbis[e.attribute]!==void 0)throw new Error(`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`);EA.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await EA.openEnvironment(ZJ(),JJ.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await XJ.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return n3(i3,c,{records:[s]},l)}catch(i){throw i}}a(o3,"lmdbCreateAttribute")});var pA=N((JAe,xP)=>{var{hdb_table:a3,hdb_database:HP}=Ti(),c3=Tt(),hA=require("joi"),l3={undefined:"undefined",null:"null"},u3=a((e,t)=>{let r=Object.keys(e),n=r.length,s;for(let i=0;i<n;i++){let o=r[i];(!o||o.length===0||l3[o]!==void 0)&&(s===void 0?s=`Invalid attribute name: '${o}'`:s+=`. Invalid attribute name: '${o}'`)}return s?t.message(s):e},"custom_records_val"),d3=hA.object({database:HP,schema:HP,table:a3,records:hA.array().items(hA.object().custom(u3)).required()});xP.exports=function(e){return c3.validateBySchema(e,d3)}});var E_=N((eRe,FP)=>{"use strict";var eo=te(),kP=W(),ZAe=pA(),{getDatabases:_3}=(Pe(),oe(lt)),{ClientError:ic}=_e();FP.exports=f3;function f3(e){if(eo.isEmpty(e))throw new ic("invalid update parameters defined.");if(eo.isEmptyOrZeroLength(e.schema))throw new ic("invalid schema specified.");if(eo.isEmptyOrZeroLength(e.table))throw new ic("invalid table specified.");if(!Array.isArray(e.records))throw new ic("records must be an array");let t=_3()[e.schema]?.[e.table];if(eo.isEmpty(t))throw new ic(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&eo.isEmptyOrZeroLength(o[r]))throw kP.error("a valid hash attribute must be provided with update record:",o),new ic("a valid hash attribute must be provided with update record, check log for more info");if(!eo.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw kP.error(`a valid hash value must be provided with ${e.operation} record:`,o),new ic(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!eo.isEmpty(o[r])&&o[r]!==""&&n.has(eo.autoCast(o[r]))&&(o.skip=!0),n.add(eo.autoCast(o[r]));for(let c in o)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}a(f3,"insertUpdateValidate")});var qP=N((rRe,GP)=>{"use strict";var mA=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};GP.exports=mA});var KP=N((sRe,VP)=>{"use strict";var SA=ht(),E3=W(),$P=Dn().LMDB_ERRORS_ENUM;VP.exports=h3;async function h3(e){try{if(global.lmdb_map!==void 0&&e.operation!==void 0){let t=Object.keys(global.lmdb_map),r;switch(e.operation){case"drop_schema":for(let i=0;i<t.length;i++){let o=t[i];if(o.startsWith(`${e.schema}.`)||o.startsWith(`txn.${e.schema}.`))try{await SA.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==$P.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await SA.closeEnvironment(global.lmdb_map[n]),await SA.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==$P.ENV_REQUIRED)throw i}break;case"drop_attribute":r=global.lmdb_map[`${e.schema}.${e.table}`],r!==void 0&&typeof r.dbis=="object"&&r.dbis[`${e.attribute}`]!==void 0&&delete r.dbis[`${e.attribute}`];break;default:break}}}catch(t){E3.error(t)}}a(h3,"cleanLMDBMap")});var to=N((oRe,zP)=>{"use strict";var h_=require("crypto"),p3=se(),{CONFIG_PARAMS:m3}=M(),WP="aes-256-cbc",S3=32,T3=16,TA=64,jP=32,g3=TA+jP,YP=new Map;zP.exports={encrypt:A3,decrypt:R3,createNatsTableStreamName:y3};function A3(e){let t=h_.randomBytes(S3),r=h_.randomBytes(T3),n=h_.createCipheriv(WP,Buffer.from(t),r),s=n.update(e);s=Buffer.concat([s,n.final()]);let i=t.toString("hex"),o=r.toString("hex"),c=s.toString("hex");return i+o+c}a(A3,"encrypt");function R3(e){let t=e.substr(0,TA),r=e.substr(TA,jP),n=e.substr(g3,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=h_.createDecipheriv(WP,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(R3,"decrypt");function y3(e,t){let r=p3.get(m3.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=YP.get(r);return n||(n=h_.createHash("md5").update(r).digest("hex"),YP.set(r,n)),n}a(y3,"createNatsTableStreamName")});var ro=N((lRe,XP)=>{"use strict";var cRe=Vr(),p_=W(),QP=Uh(),b3=to(),Hh=te(),{handleHDBError:xh,hdb_errors:O3}=_e(),{HDB_ERROR_MSGS:kh,HTTP_STATUS_CODES:gA}=O3,JP=se();JP.initSync();var{getDatabases:AA}=(Pe(),oe(lt)),N3=require("fs-extra"),I3=M();XP.exports={describeAll:w3,describeTable:Fh,describeSchema:C3};async function w3(e={}){try{let t=Hh.isEmptyOrZeroLength(e),r=!!e.bypass_auth,n,s;!t&&!r&&(n=e.hdb_user?.role?.permission,s=n?.super_user||n?.cluster_user);let i=AA(),o={},c={},l=[],u=e?.exact_count;for(let _ in i){o[_]=!0,!t&&!s&&!r&&(c[_]=e.hdb_user?.role?.permission[_]?.describe);let E=i[_];for(let f in E)try{let h;if(t||s||r)h=await Fh({schema:_,table:f,exact_count:u});else if(n&&n[_].describe&&n[_].tables[f].describe){let T=n[_].tables[f].attribute_permissions;h=await Fh({schema:_,table:f,exact_count:u},T)}h&&l.push(h)}catch(h){p_.error(h)}}let d={};for(let _ in l)t||s||r?(d[l[_].schema]==null&&(d[l[_].schema]={}),d[l[_].schema][l[_].name]=l[_],o[l[_].schema]&&delete o[l[_].schema]):c[l[_].schema]&&(d[l[_].schema]==null&&(d[l[_].schema]={}),d[l[_].schema][l[_].name]=l[_],o[l[_].schema]&&delete o[l[_].schema]);for(let _ in o)t||s||r?d[_]={}:c[_]&&(d[_]={});return d}catch(t){return p_.error("Got an error in describeAll"),p_.error(t),xh(new Error,kh.DESCRIBE_ALL_ERR)}}a(w3,"describeAll");async function Fh(e,t){Hh.transformReq(e);let{schema:r,table:n}=e;r=r?.toString(),n=n?.toString();let s=t;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(s=e.hdb_user?.role?.permission[r]?.tables[n]?.attribute_permissions);let i=QP.describe_table(e);if(i)throw i;let c=AA()[r];if(!c)throw xh(new Error,kh.SCHEMA_NOT_FOUND(e.schema),gA.NOT_FOUND);let l=c[n];if(!l)throw xh(new Error,kh.TABLE_NOT_FOUND(e.schema,e.table),gA.NOT_FOUND);function u(f){d.push({attribute:f.attribute,type:f.type,elements:f.elements?.type,indexed:f.indexed,is_primary_key:f.isPrimaryKey,assigned_created_time:f.assignCreatedTime,assigned_updated_time:f.assignUpdatedTime,nullable:f.nullable,properties:f.properties?f.properties.map(h=>({type:h.type,name:h.name})):void 0})}a(u,"pushAtt");let d=[];if(s){let f={};s.forEach(h=>{h.describe&&(f[h.attribute_name]=!0)}),l.attributes.forEach(h=>{f[h.name]&&u(h)})}else l.attributes?.forEach(f=>u(f));let _;try{_=(await N3.stat(l.primaryStore.env.path)).size}catch(f){p_.warn("unable to get database size",f)}let E={schema:r,name:l.tableName,hash_attribute:l.attributes.find(f=>f.isPrimaryKey||f.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:d,db_size:_};l.replicate!==void 0&&(E.replicate=l.replicate),l.expirationMS!==void 0&&(E.expiration=l.expirationMS/1e3+"s"),l.sealed!==void 0&&(E.sealed=l.sealed),l.sources?.length>0&&(E.sources=l.sources.map(f=>f.name).filter(f=>f&&f!=="NATSReplicator"&&f!=="Replicator")),JP.get(I3.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(E.clustering_stream_name=b3.createNatsTableStreamName(E.schema,E.name));try{let f=l.getRecordCount({exactCount:e.exact_count==="true"});E.record_count=f.recordCount,E.table_size=l.getSize(),E.db_audit_size=l.getAuditSize(),E.estimated_record_range=f.estimatedRange;let h=l.auditStore;if(h)for(let T of h.getKeys({reverse:!0,limit:1}))E.last_updated_record=T[0];if(!E.last_updated_record&&l.indices.__updatedtime__)for(let T of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))E.last_updated_record=T}catch(f){p_.warn(`unable to stat table dbi due to ${f}`)}return E}a(Fh,"descTable");async function C3(e){Hh.transformReq(e);let t=QP.schema_object(e);if(t)throw t;let r;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(r=e.hdb_user?.role?.permission[e.schema]);let n=e.schema.toString(),i=AA()[n];if(!i)throw xh(new Error,kh.SCHEMA_NOT_FOUND(e.schema),gA.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),Hh.isEmpty(l)||l.describe){let u=await Fh({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(C3,"describeSchema")});var ls=N((fRe,nL)=>{var D3=Zi(),{callbackify:eL,promisify:P3}=require("util"),{getDatabases:tL}=(Pe(),oe(lt));nL.exports={setSchemaDataToGlobal:ZP,getTableSchema:L3,getSystemSchema:M3,setSchemaDataToGlobalAsync:P3(ZP)};var rL=ro(),dRe=eL(rL.describeAll),_Re=eL(rL.describeTable);function ZP(e){global.hdb_schema=tL(),e&&e()}a(ZP,"setSchemaDataToGlobal");function L3(e,t,r){let n=tL()[e];if(!n)return r(`schema ${e} does not exist`);let s=n[t];return s?r(null,{schema:e,name:t,hash_attribute:s.primaryKey}):r(`table ${e}.${t} does not exist`)}a(L3,"getTableSchema");function M3(){return D3}a(M3,"getSystemSchema")});var un=N((hRe,aL)=>{"use strict";var qh=pA(),Cr=te(),U3=require("util"),$h=Bn(),v3=ls(),sL=W(),{handleHDBError:oc,hdb_errors:B3}=_e(),{HTTP_STATUS_CODES:ac}=B3,H3=U3.promisify(v3.getTableSchema),x3="updated",iL="inserted",oL="upserted";aL.exports={insert:F3,update:G3,upsert:q3,validation:k3,flush:$3};async function k3(e){if(Cr.isEmpty(e))throw new Error("invalid update parameters defined.");if(Cr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Cr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await H3(e.schema,e.table),r=qh(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let n=t.hash_attribute,s=new Set,i={},o=!1;return e.operation==="update"&&(o=!0),e.records.forEach(c=>{if(o&&Cr.isEmptyOrZeroLength(c[n]))throw sL.error("a valid hash attribute must be provided with update record:",c),new Error("a valid hash attribute must be provided with update record");if(!Cr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw sL.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Cr.isEmpty(c[n])&&c[n]!==""&&s.has(Cr.autoCast(c[n]))&&(c.skip=!0),s.add(Cr.autoCast(c[n]));for(let l in c)i[l]=1}),i[n]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(i)}}a(k3,"validation");async function F3(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=qh(e);if(t)throw oc(new Error,t.message,ac.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw oc(new Error,r,ac.BAD_REQUEST);let n=await $h.createRecords(e);return Gh(iL,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(F3,"insertData");async function G3(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=qh(e);if(t)throw oc(new Error,t.message,ac.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw oc(new Error,r,ac.BAD_REQUEST);let n=await $h.updateRecords(e);return Cr.isEmpty(n.existing_rows)?Gh(x3,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):Gh(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(G3,"updateData");async function q3(e){if(e.operation!=="upsert")throw oc(new Error,"invalid operation, must be upsert",ac.INTERNAL_SERVER_ERROR);let t=qh(e);if(t)throw oc(new Error,t.message,ac.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw oc(new Error,r,ac.BAD_REQUEST);let n=await $h.upsertRecords(e);return Gh(oL,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(q3,"upsertData");function Gh(e,t,r,n,s,i){let o={message:`${e} ${t.length} of ${t.length+n.length} records`,new_attributes:s,txn_time:i};return e===iL?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===oL?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(Gh,"returnObject");function $3(e){return Cr.transformReq(e),$h.flush(e.schema,e.table)}a($3,"flush")});var yA=N((mRe,uL)=>{var V3=Tt(),RA=require("joi"),{hdb_table:K3,hdb_database:cL}=Ti(),lL={schema:cL,database:cL,table:K3},Y3={date:RA.date().iso().required()},W3={timestamp:RA.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};uL.exports=function(e,t){let r=t==="timestamp"?{...lL,...W3}:{...lL,...Y3},n=RA.object(r);return V3.validateBySchema(e,n)}});var fL=N((SRe,_L)=>{var j3=Tt(),bA=require("joi"),{hdb_table:z3,hdb_database:dL}=Ti(),Q3=bA.object({schema:dL,database:dL,table:z3,hash_values:bA.array().required(),ids:bA.array()});_L.exports=function(e){return j3.validateBySchema(e,Q3)}});var wA=N((TRe,EL)=>{"use strict";var OA=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i){this.operation=t,this.schema=r,this.table=n,this.hash_attribute=s,this.records=i}},NA=class{static{a(this,"NoSQLSeachObject")}constructor(t,r,n,s,i,o){this.schema=t,this.table=r,this.search_attribute=n,this.hash_attribute=s,this.get_attributes=i,this.search_value=o}},IA=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};EL.exports={InsertObject:OA,NoSQLSeachObject:NA,DeleteResponseObject:IA}});var uc=N((ARe,TL)=>{"use strict";var pL=yA(),J3=fL(),cc=te(),hL=require("moment"),mL=W(),{promisify:X3,callbackify:Z3}=require("util"),lc=M(),eX=ls(),CA=X3(eX.getTableSchema),DA=Bn(),{DeleteResponseObject:tX}=wA(),{handleHDBError:jo,hdb_errors:rX}=_e(),{HDB_ERROR_MSGS:Vh,HTTP_STATUS_CODES:zo}=rX,nX="records successfully deleted",sX=Z3(SL);TL.exports={delete:sX,deleteRecord:SL,deleteFilesBefore:iX,deleteAuditLogsBefore:oX};async function iX(e){let t=pL(e,"date");if(t)throw jo(t,t.message,zo.BAD_REQUEST,void 0,void 0,!0);if(cc.transformReq(e),!hL(e.date,hL.ISO_8601).isValid())throw jo(new Error,Vh.INVALID_DATE,zo.BAD_REQUEST,lc.LOG_LEVELS.ERROR,Vh.INVALID_DATE,!0);let n=cc.checkSchemaTableExist(e.schema,e.table);if(n)throw jo(new Error,n,zo.NOT_FOUND,lc.LOG_LEVELS.ERROR,n,!0);let s=await DA.deleteRecordsBefore(e);if(await CA(e.schema,e.table),mL.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(iX,"deleteFilesBefore");async function oX(e){let t=pL(e,"timestamp");if(t)throw jo(t,t.message,zo.BAD_REQUEST,void 0,void 0,!0);if(cc.transformReq(e),isNaN(e.timestamp))throw jo(new Error,Vh.INVALID_VALUE("Timestamp"),zo.BAD_REQUEST,lc.LOG_LEVELS.ERROR,Vh.INVALID_VALUE("Timestamp"),!0);let r=cc.checkSchemaTableExist(e.schema,e.table);if(r)throw jo(new Error,r,zo.NOT_FOUND,lc.LOG_LEVELS.ERROR,r,!0);let n=await DA.deleteAuditLogsBefore(e);return await CA(e.schema,e.table),mL.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(oX,"deleteAuditLogsBefore");async function SL(e){e.ids&&(e.hash_values=e.ids);let t=J3(e);if(t)throw jo(t,t.message,zo.BAD_REQUEST,void 0,void 0,!0);cc.transformReq(e);let r=cc.checkSchemaTableExist(e.schema,e.table);if(r)throw jo(new Error,r,zo.NOT_FOUND,lc.LOG_LEVELS.ERROR,r,!0);try{await CA(e.schema,e.table);let n=await DA.deleteRecords(e);return cc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${nX}`),n}catch(n){if(n.message===lc.SEARCH_NOT_FOUND_MESSAGE){let s=new tX;return s.message=lc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(SL,"deleteRecord")});var Kh=N((yRe,RL)=>{var aX=require("crypto"),gL=9;function cX(e){let t=uX(gL),r=AL(e+t);return t+r}a(cX,"createHash");function lX(e,t){let r=e?.substr(0,gL),n=r+AL(t+r);return e===n}a(lX,"validateHash");function uX(e){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ",r=t.length,n="";for(let s=0;s<e;s++){let i=Math.floor(Math.random()*r);n+=t[i]}return n}a(uX,"generateSalt");function AL(e){return aX.createHash("md5").update(e).digest("hex")}a(AL,"md5");RL.exports={hash:cX,validate:lX}});var bL=N((ORe,yL)=>{var PA=Tt(),Kr={username:{presence:!0,exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function dX(e){return Kr.password.presence=!0,Kr.username.presence=!0,Kr.role.presence=!0,Kr.active.presence=!0,PA.validateObject(e,Kr)}a(dX,"addUserValidation");function _X(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,PA.validateObject(e,Kr)}a(_X,"alterUserValidation");function fX(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,PA.validateObject(e,Kr)}a(fX,"dropUserValidation");yL.exports={addUserValidation:dX,alterUserValidation:_X,dropUserValidation:fX}});var Ct=N((wRe,NL)=>{"use strict";var{platform:IRe}=require("os"),EX="nats-server.zip",LA="nats-server",hX=process.platform==="win32"?`${LA}.exe`:LA,pX=/^[^\s.,*>]+$/,OL="__request__",mX=a(e=>`${e}.${OL}`,"REQUEST_SUBJECT"),SX={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},TX={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},gX={HUB:"hub.pid",LEAF:"leaf.pid"},AX={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},RX={SUCCESS:"success",ERROR:"error"},yX={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},bX={TXN:"txn",MSGID:"msgid"},Bl={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},OX={[Bl.ERR]:1,[Bl.WRN]:2,[Bl.INF]:3,[Bl.DBG]:4,[Bl.TRC]:5},NX={debug:"-D",trace:"-DVV"};NL.exports={NATS_SERVER_ZIP:EX,NATS_SERVER_NAME:LA,NATS_BINARY_NAME:hX,PID_FILES:gX,NATS_CONFIG_FILES:TX,SERVER_SUFFIX:AX,NATS_TERM_CONSTRAINTS_RX:pX,REQUEST_SUFFIX:OL,UPDATE_REMOTE_RESPONSE_STATUSES:RX,CLUSTER_STATUS_STATUSES:yX,REQUEST_SUBJECT:mX,SUBJECT_PREFIXES:bX,MSG_HEADERS:SX,LOG_LEVELS:Bl,LOG_LEVEL_FLAGS:NX,LOG_LEVEL_HIERARCHY:OX}});var wL=N((DRe,IL)=>{"use strict";var Yh=M(),Wh=class{static{a(this,"BaseLicense")}constructor(t=0,r=Yh.RAM_ALLOCATION_ENUM.DEFAULT,n=Yh.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},MA=class extends Wh{static{a(this,"ExtendedLicense")}constructor(t=0,r=Yh.RAM_ALLOCATION_ENUM.DEFAULT,n=Yh.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};IL.exports={BaseLicense:Wh,ExtendedLicense:MA}});var dc=N((LRe,vL)=>{"use strict";var xl=require("fs-extra"),DL=Kh(),PL=require("crypto"),IX=require("moment"),wX=require("uuid").v4,Yr=W(),vA=require("path"),CX=te(),Qo=M(),{totalmem:CL}=require("os"),DX=wL().ExtendedLicense,Hl="invalid license key format",PX="061183",LX="mofi25",MX="aes-256-cbc",UX=16,vX=32,LL=se(),{resolvePath:ML}=wt();LL.initSync();var UA;vL.exports={validateLicense:UL,generateFingerPrint:HX,licenseSearch:xA,getLicense:FX,checkMemoryLimit:GX};function BA(){return vA.join(LL.getHdbBasePath(),Qo.LICENSE_KEY_DIR_NAME,Qo.LICENSE_FILE_NAME)}a(BA,"getLicenseDirPath");function BX(){let e=BA();return ML(vA.join(e,Qo.LICENSE_FILE_NAME))}a(BX,"getLicenseFilePath");function HA(){let e=BA();return ML(vA.join(e,Qo.REG_KEY_FILE_NAME))}a(HA,"getFingerPrintFilePath");async function HX(){let e=HA();try{return await xl.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await xX();throw Yr.error(`Error writing fingerprint file to ${e}`),Yr.error(t),new Error("There was an error generating the fingerprint")}}a(HX,"generateFingerPrint");async function xX(){let e=wX(),t=DL.hash(e),r=HA();try{await xl.mkdirp(BA()),await xl.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw Yr.error(`Error writing fingerprint file to ${r}`),Yr.error(n),new Error("There was an error generating the fingerprint")}return t}a(xX,"writeFingerprint");function UL(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:Qo.RAM_ALLOCATION_ENUM.DEFAULT,version:Qo.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Yr.error("empty license key passed to validate."),r;let n=HA(),s=!1;try{s=xl.statSync(n)}catch(i){Yr.error(i)}if(s){let i;try{i=xl.readFileSync(n,"utf8")}catch{Yr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(LX),c=o[1];c=Buffer.concat([Buffer.from(c)],UX);let l=Buffer.concat([Buffer.from(i)],vX),u=PL.createDecipheriv(MX,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let d=null;try{d=u.update(o[0],"hex","utf8"),d.trim(),d+=u.final("utf8")}catch{let f=kX(o[0],i);if(f)d=f;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Hl),Yr.error(Hl),new Error(Hl)}let _;if(isNaN(d))try{_=JSON.parse(d),r.version=_.version,r.exp_date=_.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),_.ram_allocation&&(r.ram_allocation=_.ram_allocation)}catch{throw console.error(Hl),Yr.error(Hl),new Error(Hl)}else r.exp_date=d;r.exp_date<IX().valueOf()&&(r.valid_date=!1),DL.validate(o[1],`${PX}${i}${t}`)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||Yr.error("Invalid licence"),r}a(UL,"validateLicense");function kX(e,t){try{let r=PL.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{Yr.warn("Check old license failed")}}a(kX,"checkOldLicense");function xA(){let e=new DX,t=[];try{t=xl.readFileSync(BX(),"utf-8").split(Qo.NEW_LINE)}catch(r){r.code==="ENOENT"?Yr.debug("no license file found"):Yr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(CX.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=UL(s.license_key,s.company);i.valid_machine===!0&&i.valid_date===!0&&i.valid_machine===!0&&(e.exp_date=i.exp_date>e.exp_date?i.exp_date:e.exp_date,e.ram_allocation=i.ram_allocation,e.enterprise=!0)}catch(s){Yr.error("There was an error parsing the license string."),Yr.error(s),e.ram_allocation=Qo.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return UA=e,e}a(xA,"licenseSearch");async function FX(){return UA||await xA(),UA}a(FX,"getLicense");function GX(){let e=xA().ram_allocation,t=process.constrainedMemory?.()||CL();if(t=Math.round(Math.min(t,CL())/2**20),t>e)return`This server has more memory (${t}MB) than HarperDB is licensed for (${e}MB), this should only be used for educational and development purposes.`}a(GX,"checkMemoryLimit")});var xn=N((HRe,JL)=>{"use strict";var kL="username is required",FL="nothing to update, must supply active, role or password to update",GL="password cannot be an empty string",qL="If role is specified, it cannot be empty.",$L="active must be true or false";JL.exports={addUser:QX,alterUser:JX,dropUser:ZX,getSuperUser:nZ,userInfo:eZ,listUsers:zh,listUsersExternal:tZ,setUsersToGlobal:Fl,findAndValidateUser:zL,getClusterUser:sZ,USERNAME_REQUIRED:kL,ALTERUSER_NOTHING_TO_UPDATE:FL,EMPTY_PASSWORD:GL,EMPTY_ROLE:qL,ACTIVE_BOOLEAN:$L};var VL=un(),qX=uc(),GA=Kh(),KL=bL(),YL=Vr(),qA=no(),Hn=te(),WL=require("validate.js"),Ke=W(),{promisify:$X}=require("util"),$A=to(),BL=M(),HL=Ct(),VX=wt(),URe=se(),vRe=dc(),KX=Zi(),{table:BRe}=(Pe(),oe(lt)),{handleHDBError:Ai,hdb_errors:YX}=_e(),{HTTP_STATUS_CODES:Ri,AUTHENTICATION_ERROR_MSGS:kA,HDB_ERROR_MSGS:kl}=YX,{UserEventMsg:VA}=qs(),FA=require("lodash"),{server:KA}=(qr(),oe(Qa)),WX=W();KA.getUser=(e,t)=>zL(e,t,t!=null);var jL={username:!0,active:!0,role:!0,password:!0},xL=new Map,jh=YL.searchByValue,jX=YL.searchByHash,zX=$X(qX.delete);async function QX(e){let t=WL.cleanAttributes(e,jL),r=KL.addUserValidation(t);if(r)throw Ai(new Error,r.message,Ri.BAD_REQUEST,void 0,void 0,!0);let n={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]},s;try{s=await jh(n),s=s&&Array.from(s)}catch(l){throw Ke.error("There was an error searching for a role in add user"),Ke.error(l),l}if(!s||s.length<1)throw Ai(new Error,kl.ROLE_NAME_NOT_FOUND(t.role),Ri.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw Ai(new Error,kl.DUP_ROLES_FOUND(t.role),Ri.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=$A.encrypt(t.password)),t.password=GA.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await VL.insert(i)}catch(l){throw Ke.error("There was an error searching for a user."),Ke.error(l),l}Ke.debug(o);try{await Fl()}catch(l){throw Ke.error("Got an error setting users to global"),Ke.error(l),l}if(o.skipped_hashes.length===1)throw Ai(new Error,kl.USER_ALREADY_EXISTS(t.username),Ri.CONFLICT,void 0,void 0,!0);let c={...t};return c.role=s[0],qA.signalUserChange(new VA(process.pid)),`${c.username} successfully added`}a(QX,"addUser");async function JX(e){let t=WL.cleanAttributes(e,jL);if(Hn.isEmptyOrZeroLength(t.username))throw new Error(kL);if(Hn.isEmptyOrZeroLength(t.password)&&Hn.isEmptyOrZeroLength(t.role)&&Hn.isEmptyOrZeroLength(t.active))throw new Error(FL);if(!Hn.isEmpty(t.password)&&Hn.isEmptyOrZeroLength(t.password.trim()))throw new Error(GL);if(!Hn.isEmpty(t.active)&&!Hn.isBoolean(t.active))throw new Error($L);let r=XX(t.username);if(!Hn.isEmpty(t.password)&&!Hn.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=$A.encrypt(t.password)),t.password=GA.hash(t.password)),t.role==="")throw new Error(qL);if(t.role){let i={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]},o;try{o=Array.from(await jh(i)||[])}catch(c){throw Ke.error("Got an error searching for a role."),Ke.error(c),c}if(!o||o.length===0){let c=kl.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Ke.error(c),Ai(new Error,c,Ri.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=kl.ALTER_USER_DUP_ROLES(t.role);throw Ke.error(c),Ai(new Error,c,Ri.CONFLICT,void 0,void 0,!0)}t.role=o[0].id}let n={operation:"update",schema:"system",table:"hdb_user",records:[t]},s;try{s=await VL.update(n)}catch(i){throw Ke.error("Error during update."),Ke.error(i),i}try{await Fl()}catch(i){throw Ke.error("Got an error setting users to global"),Ke.error(i),i}return qA.signalUserChange(new VA(process.pid)),s}a(JX,"alterUser");function XX(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(XX,"isClusterUser");async function ZX(e){try{let t=KL.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(Hn.isEmpty(global.hdb_users.get(e.username)))throw Ai(new Error,kl.USER_NOT_EXIST(e.username),Ri.NOT_FOUND,void 0,void 0,!0);let n;try{n=await zX(r)}catch(s){throw Ke.error("Got an error deleting a user."),Ke.error(s),s}Ke.debug(n);try{await Fl()}catch(s){throw Ke.error("Got an error setting users to global."),Ke.error(s),s}return qA.signalUserChange(new VA(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(ZX,"dropUser");async function eZ(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=FA.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await jX(r)}catch(s){throw Ke.error("Got an error searching for a role."),Ke.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw Ke.error(r),r}return t}a(eZ,"userInfo");async function tZ(){let e;try{e=await zh()}catch(t){throw Ke.error("Got an error listing users."),Ke.error(t),t}try{e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token})}catch{throw new Error("there was an error massaging the user data")}return[...e.values()]}a(tZ,"listUsersExternal");async function zh(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await jh(e)}catch(o){throw Ke.error("Got an error searching for roles."),Ke.error(o),o}let r={};for(let o of t)r[o.id]=FA.cloneDeep(o);if(Object.keys(r).length===0)return null;let n={schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]},s;try{s=await jh(n)}catch(o){throw Ke.error("Got an error searching for users."),Ke.error(o),o}let i=new Map;for(let o of s)o=FA.cloneDeep(o),o.role=r[o.role],rZ(o.role),i.set(o.username,o);return i}catch(e){throw Ke.error("got an error listing users"),Ke.error(e),Hn.errorizeMessage(e)}return null}a(zh,"listUsers");function rZ(e){try{if(!e){Ke.error("invalid user role found.");return}e.permission.system||(e.permission.system={}),e.permission.system.tables||(e.permission.system.tables={});for(let t of Object.keys(KX)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){Ke.error("Got an error trying to set system permissions."),Ke.error(t)}}a(rZ,"appendSystemTablesToRole");async function Fl(){try{let e=await zh();global.hdb_users=e}catch(e){throw Ke.error(e),e}}a(Fl,"setUsersToGlobal");async function zL(e,t,r=!0){global.hdb_users||await Fl();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw Ai(new Error,kA.GENERIC_AUTH_FAIL,Ri.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw Ai(new Error,kA.USER_INACTIVE,Ri.UNAUTHORIZED,void 0,void 0,!0);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(xL.get(t)===n.password)return s;if(GA.validate(n.password,t))xL.set(t,n.password);else throw Ai(new Error,kA.GENERIC_AUTH_FAIL,Ri.UNAUTHORIZED,void 0,void 0,!0)}return s}a(zL,"findAndValidateUser");async function nZ(){global.hdb_users||await Fl();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(nZ,"getSuperUser");async function sZ(){let e=await zh(),t=VX.getConfigFromFile(BL.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!Hn.isEmpty(r)&&r?.role?.role===BL.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=$A.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+HL.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+HL.SERVER_SUFFIX.ADMIN,r}a(sZ,"getClusterUser");var QL=[];KA.invalidateUser=function(e){for(let t of QL)try{t(e)}catch(r){WX.error("Error invalidating user",r)}};KA.onInvalidatedUser=function(e){QL.push(e)}});var S_=N((GRe,tM)=>{"use strict";var _c=W(),kn=M(),iZ=KP(),kRe=ls(),FRe=ro(),oZ=xn(),{validateEvent:XL}=qs(),m_=Bn(),aZ=require("process"),{resetDatabases:cZ}=(Pe(),oe(lt)),lZ={[kn.ITC_EVENT_TYPES.SCHEMA]:uZ,[kn.ITC_EVENT_TYPES.USER]:eM};async function uZ(e){let t=XL(e);if(t){_c.error(t);return}_c.trace("ITC schemaHandler received schema event:",e),await iZ(e.message),await dZ(e.message)}a(uZ,"schemaHandler");async function dZ(e){try{m_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),m_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),m_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=cZ();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){_c.error(t)}}a(dZ,"syncSchemaMetadata");var ZL=[];async function eM(e){try{try{m_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),m_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){_c.warn(r)}let t=XL(e);if(t){_c.error(t);return}_c.trace(`ITC userHandler ${kn.HDB_ITC_CLIENT_PREFIX}${aZ.pid} received user event:`,e),await oZ.setUsersToGlobal();for(let r of ZL)r()}catch(t){_c.error(t)}}a(eM,"userHandler");eM.addListener=function(e){ZL.push(e)};tM.exports=lZ});var qs=N((WRe,nM)=>{"use strict";var $Re=W(),YA=te(),_Z=M(),{ITC_ERRORS:T_}=Dn(),{parentPort:VRe,threadId:fZ,isMainThread:EZ,workerData:KRe}=require("worker_threads"),{onMessageFromWorkers:hZ,broadcast:YRe,broadcastWithAcknowledgement:pZ}=dt();nM.exports={sendItcEvent:mZ,validateEvent:rM,SchemaEventMsg:SZ,UserEventMsg:TZ};var Qh;hZ(async(e,t)=>{Qh=Qh||S_(),rM(e),Qh[e.type]&&await Qh[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function mZ(e){return!EZ&&e.message&&(e.message.originator=fZ),pZ(e)}a(mZ,"sendItcEvent");function rM(e){if(typeof e!="object")return T_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||YA.isEmpty(e.type))return T_.MISSING_TYPE;if(!e.hasOwnProperty("message")||YA.isEmpty(e.message))return T_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||YA.isEmpty(e.message.originator))return T_.MISSING_ORIGIN;if(_Z.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return T_.INVALID_EVENT(e.type)}a(rM,"validateEvent");function SZ(e,t,r,n=void 0,s=void 0){this.originator=e,this.operation=t,this.schema=r,this.table=n,this.attribute=s}a(SZ,"SchemaEventMsg");function TZ(e){this.originator=e}a(TZ,"UserEventMsg")});var no=N((QRe,aM)=>{"use strict";var sM=M(),zRe=te(),Jh=W(),iM=qP(),Gl,{sendItcEvent:oM}=qs();function gZ(e){try{Jh.info("signalSchemaChange called with message:",e),Gl=Gl||S_();let t=new iM(sM.ITC_EVENT_TYPES.SCHEMA,e);return Gl.schema(t),oM(t)}catch(t){Jh.error(t)}}a(gZ,"signalSchemaChange");function AZ(e){try{Jh.trace("signalUserChange called with message:",e),Gl=Gl||S_();let t=new iM(sM.ITC_EVENT_TYPES.USER,e);return Gl.user(t),oM(t)}catch(t){Jh.error(t)}}a(AZ,"signalUserChange");aM.exports={signalSchemaChange:gZ,signalUserChange:AZ}});var Xh=N((XRe,lM)=>{"use strict";var cM=te(),RZ=M(),yZ=W(),bZ=Bh(),OZ=vh(),NZ=no(),{SchemaEventMsg:IZ}=qs(),wZ="already exists in";lM.exports=CZ;async function CZ(e,t,r){if(cM.isEmptyOrZeroLength(r))return r;let n=[];cM.isEmptyOrZeroLength(t.attributes)||t.attributes.forEach(i=>{n.push(i.attribute)});let s=r.filter(i=>n.indexOf(i)<0);return s.length===0||await Promise.all(s.map(async i=>{await DZ(e,t.schema,t.name,i)})),s}a(CZ,"lmdbCheckForNewAttributes");async function DZ(e,t,r,n){let s=new OZ(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await PZ(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(wZ))yZ.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(DZ,"createNewAttribute");async function PZ(e){let t;return t=await bZ(e),NZ.signalSchemaChange(new IZ(process.pid,RZ.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(PZ,"createAttribute")});var ql=N((eye,uM)=>{"use strict";var WA=class{static{a(this,"LMDBTransactionObject")}constructor(t,r,n,s,i=void 0){this.operation=t,this.user_name=r,this.timestamp=n,this.hash_values=s,this.origin=i}};uM.exports=WA});var _M=N((rye,dM)=>{"use strict";var LZ=ql(),MZ=M().OPERATIONS_ENUM,jA=class extends LZ{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(MZ.INSERT,r,n,s,i),this.records=t}};dM.exports=jA});var EM=N((sye,fM)=>{"use strict";var UZ=ql(),vZ=M().OPERATIONS_ENUM,zA=class extends UZ{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(vZ.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};fM.exports=zA});var pM=N((oye,hM)=>{"use strict";var BZ=ql(),HZ=M().OPERATIONS_ENUM,QA=class extends BZ{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(HZ.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};hM.exports=QA});var SM=N((cye,mM)=>{"use strict";var xZ=ql(),kZ=M().OPERATIONS_ENUM,JA=class extends xZ{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(kZ.DELETE,n,s,t,i),this.original_records=r}};mM.exports=JA});var g_=N((dye,RM)=>{"use strict";var uye=require("path"),TM=ht(),FZ=_M(),GZ=EM(),qZ=pM(),$Z=SM(),$l=Ht(),gM=te(),{CONFIG_PARAMS:VZ}=M(),AM=se();AM.initSync();var Zh=M().OPERATIONS_ENUM,{getTransactionAuditStorePath:KZ}=gt();RM.exports=YZ;async function YZ(e,t){if(AM.get(VZ.LOGGING_AUDITLOG)===!1)return;let r=KZ(e.schema,e.table),n=await TM.openEnvironment(r,e.table,!0),s=WZ(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){TM.initializeDBIs(n,$l.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,$l.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[$l.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[$l.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),gM.isEmpty(s.user_name)||n.dbis[$l.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[$l.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(YZ,"writeTransaction");function WZ(e,t){let r=gM.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===Zh.INSERT)return new FZ(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zh.UPDATE)return new GZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zh.UPSERT)return new qZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zh.DELETE)return new $Z(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(WZ,"createTransactionObject")});var XA=N((Eye,yM)=>{"use strict";var jZ=E_(),fye=Jd(),A_=M(),zZ=Xd(),QZ=sc().insertRecords,JZ=ht(),XZ=W(),ZZ=Xh(),{getSchemaPath:e5}=gt(),t5=g_();yM.exports=r5;async function r5(e){try{let{schema_table:t,attributes:r}=jZ(e);zZ(e,r,t.hash_attribute),e.schema!==A_.SYSTEM_SCHEMA_NAME&&(r.includes(A_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(A_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(A_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(A_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await ZZ(e.hdb_auth_header,t,r),s=e5(e.schema,e.table),i=await JZ.openEnvironment(s,e.table),o=await QZ(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await t5(e,o)}catch(c){XZ.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(r5,"lmdbCreateRecords")});var NM=N((pye,OM)=>{"use strict";var bM=M(),n5=XA(),s5=Jd(),i5=require("fs-extra"),{getSchemaPath:o5}=gt();OM.exports=a5;async function a5(e){let t=[{name:e.schema,createddate:Date.now()}],r=new s5(bM.SYSTEM_SCHEMA_NAME,bM.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await n5(r),await i5.mkdirp(o5(e.schema))}a(a5,"lmdbCreateSchema")});var wM=N((Sye,IM)=>{"use strict";var ZA=class{static{a(this,"DeleteRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.deleted=t,this.skipped=r,this.txn_time=n,this.original_records=s}};IM.exports=ZA});var LM=N((yye,PM)=>{"use strict";var CM=ht(),eR=cn(),tR=Dn().LMDB_ERRORS_ENUM,c5=Ht(),DM=W(),gye=te(),l5=require("lmdb"),u5=wM(),d5=M(),{OVERFLOW_MARKER:Aye,MAX_SEARCH_KEY_LENGTH:Rye}=c5,_5=d5.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function f5(e,t,r,n){if(eR.validateEnv(e),t===void 0)throw new Error(tR.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(tR.IDS_REQUIRED):new Error(tR.IDS_MUST_BE_ITERABLE);try{let s=CM.listDBIs(e);CM.initializeDBIs(e,t,s);let i=new u5,o,c=[],l=[];for(let E=0,f=r.length;E<f;E++)try{o=r[E];let h=e.dbis[t].get(o);if(!h||n&&h[_5]>n){i.skipped.push(o);continue}let T=e.dbis[t].ifVersion(o,l5.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let m=0;m<s.length;m++){let g=s[m];if(!h.hasOwnProperty(g)||g===t)continue;let S=e.dbis[g],b=h[g];if(b!=null)try{let I=eR.getIndexedValues(b);if(I)for(let B=0,H=I.length;B<H;B++)S.remove(I[B],o)}catch{DM.warn(`cannot delete from attribute: ${g}, ${b}:${o}`)}}});c.push(T),l.push(o),i.original_records.push(h)}catch(h){DM.warn(h),i.skipped.push(o)}let u=[],d=await Promise.all(c);for(let E=0,f=d.length;E<f;E++)d[E]===!0?i.deleted.push(l[E]):(i.skipped.push(l[E]),u.push(E));let _=0;for(let E=0;E<u.length;E++){let f=u[E];i.original_records.splice(f-_,1),_++}return i.txn_time=eR.getNextMonotonicTime(),i}catch(s){throw s}}a(f5,"deleteRecords");PM.exports={deleteRecords:f5}});var R_=N((Oye,UM)=>{"use strict";var Vl=te(),E5=LM(),h5=ht(),{getSchemaPath:p5}=gt(),m5=g_(),S5=W();UM.exports=T5;async function T5(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Vl.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Vl.isEmptyOrZeroLength(e.hash_values)&&!Vl.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Vl.isEmpty(l)||e.hash_values.push(l)}}if(Vl.isEmptyOrZeroLength(e.hash_values))return MM([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Vl.isEmptyOrZeroLength(e.records)){e.records=[];for(let c=0;c<e.hash_values.length;c++)e.records[c]={[n]:e.hash_values[c]}}let s=p5(e.schema,e.table),i=await h5.openEnvironment(s,e.table),o=await E5.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await m5(e,o)}catch(c){S5.error(`unable to write transaction due to ${c.message}`)}return MM(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(T5,"lmdbDeleteRecords");function MM(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(MM,"createDeleteResponse")});var nR=N((wye,vM)=>{"use strict";var g5=M(),Iye=cn();function rR(e,t){let r=Object.create(null);if(t.length===1&&g5.SEARCH_WILDCARDS.indexOf(t[0])>=0)Object.assign(r,e);else for(let n=0;n<t.length;n++){let s=t[n],i=e[s];r[s]=i===void 0?null:i}return r}a(rR,"parseRow");function A5(e,t,r,n){let s=rR(r,e);n.push(s)}a(A5,"searchAll");function R5(e,t,r,n){let s=rR(r,e);n[t]=s}a(R5,"searchAllToMap");function y5(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(y5,"iterateDBI");function fc(e,t,r,n,s){let i=Object.create(null);i[s]=e;let o;n===s?o=e:(o=t,n!==void 0&&(i[n]=o)),r[0].push(o),r[1].push(i)}a(fc,"pushResults");function b5(e,t,r,n,s,i){t.toString().endsWith(e)&&fc(t,r,n,s,i)}a(b5,"endsWith");function O5(e,t,r,n,s,i){t.toString().includes(e)&&fc(t,r,n,s,i)}a(O5,"contains");function N5(e,t,r,n,s,i){t>e&&fc(t,r,n,s,i)}a(N5,"greaterThanCompare");function I5(e,t,r,n,s,i){t>=e&&fc(t,r,n,s,i)}a(I5,"greaterThanEqualCompare");function w5(e,t,r,n,s,i){t<e&&fc(t,r,n,s,i)}a(w5,"lessThanCompare");function C5(e,t,r,n,s,i){t<=e&&fc(t,r,n,s,i)}a(C5,"lessThanEqualCompare");vM.exports={parseRow:rR,searchAll:A5,searchAllToMap:R5,iterateDBI:y5,endsWith:b5,contains:O5,greaterThanCompare:N5,greaterThanEqualCompare:I5,lessThanCompare:w5,lessThanEqualCompare:C5,pushResults:fc}});var Kl=N((Mye,qM)=>{"use strict";var Jo=ht(),Dye=W(),Fn=cn(),ep=Ht(),zt=Dn().LMDB_ERRORS_ENUM,Pye=te(),D5=M(),tp=nR(),{parseRow:P5}=tp,Lye=require("lmdb"),{OVERFLOW_MARKER:BM,MAX_SEARCH_KEY_LENGTH:L5}=ep;function HM(e,t,r,n=!1,s=void 0,i=void 0){return Ec(e,t,r,(o,c)=>c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}))}a(HM,"iterateFullIndex");function y_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return Ec(e,t,r,(d,_,E,f)=>{let S={transaction:d,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return f===r?(S.values=!1,_.getRange(S).map(b=>({value:b}))):_.getRange(S)})}a(y_,"iterateRangeBetween");function Ec(e,t,r,n){let s=e.database||e,i=Jo.openDBI(s,r);i[ep.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&Jo.openDBI(s,t);let o;e.database?o=e:(o=e.useReadTransaction(),o.database=e);let c=n(o,i,s,t);return c.transaction=o,e.database||(c.onDone=()=>{o.done()}),c}a(Ec,"setupTransaction");function xM(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(BM)){if(!s)if(r)s=Jo.openDBI(e,r);else{let l=Jo.listDBIs(e);for(let u=0,d=l.length;u<d&&(s=Jo.openDBI(e,l[u]),!s[ep.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(xM,"getOverflowCheck");function M5(e,t,r,n=!1,s=void 0,i=void 0){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return Ec(e,t,t,(o,c,l)=>(rp(r),r=b_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>P5(u.value,r))))}a(M5,"searchAll");function U5(e,t,r,n=!1,s=void 0,i=void 0){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);rp(r),r=b_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of HM(e,t,t,n,s,i))o.set(c,tp.parseRow(l,r));return o}a(U5,"searchAllToMap");function v5(e,t,r=!1,n=void 0,s=void 0){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=HM(e,void 0,t,r,n,s),c=o.transaction,l=xM(c.database,c,void 0,t);for(let{key:u,value:d}of o){let _=l(u,d);i[_]===void 0&&(i[_]=[]),i[_].push(d)}return i}a(v5,"iterateDBI");function B5(e,t){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return Jo.statDBI(e,t).entryCount}a(B5,"countAll");function H5(e,t,r,n,s=!1,i=void 0,o=void 0){return Xo(e,r,n),Ec(e,t,r,(c,l,u,d)=>(n=Fn.convertKeyValueToWrite(n),d===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(_=>({key:n,value:_}))))}a(H5,"equals");function x5(e,t,r){return Xo(e,t,r),Jo.openDBI(e,t).getValuesCount(r)}a(x5,"count");function k5(e,t,r,n,s=!1,i=void 0,o=void 0){return Xo(e,r,n),Ec(e,null,r,(c,l)=>{n=Fn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let d;if(s===!0){let _;for(let E of l.getKeys({transaction:c,start:n}))if(!E.startsWith(n)){_=E;break}return _!==void 0&&(Number.isInteger(o)?o++:i++),d=l.getRange({transaction:c,start:_,end:void 0,reverse:s,limit:i,offset:o}).map(E=>{let{key:f}=E;if(f!==_){if(f.toString().startsWith(n))return E;if(u===!0)return d.DONE}}),d.filter(E=>E)}else return d=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(_=>{if(_.key.toString().startsWith(n))return _;if(u===!0)return d.DONE}),u?d:d.filter(_=>_)})}a(k5,"startsWith");function F5(e,t,r,n,s=!1,i=void 0,o=void 0){return kM(e,t,r,n,s,i,o,!0)}a(F5,"endsWith");function kM(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Xo(e,r,n),Ec(e,null,r,(l,u,d,_)=>{let E=xM(d,l,_,r);return o=Number.isInteger(o)?o:0,u.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(f=>{let h=f.toString();return h.endsWith(BM)?u.getValues(f,{transaction:l}).map(T=>{let m=E(f,T);if(c?m.endsWith(n):m.includes(n))return{key:m,value:T}}).filter(T=>T):(c?h.endsWith(n):h.includes(n))?u[ep.DBI_DEFINITION_NAME].is_hash_attribute?{key:f,value:f}:u.getValues(f,{transaction:l}).map(T=>({key:f,value:T})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(kM,"contains");function G5(e,t,r,n,s=!1,i=void 0,o=void 0){Xo(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),y_(e,t,r,n,l,s,i,o,!0,!1)}a(G5,"greaterThan");function q5(e,t,r,n,s=!1,i=void 0,o=void 0){Xo(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),y_(e,t,r,n,l,s,i,o,!1,!1)}a(q5,"greaterThanEqual");function $5(e,t,r,n,s=!1,i=void 0,o=void 0){Xo(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),y_(e,t,r,l,n,s,i,o,!1,!0)}a($5,"lessThan");function V5(e,t,r,n,s=!1,i=void 0,o=void 0){Xo(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),y_(e,t,r,l,n,s,i,o,!1,!1)}a(V5,"lessThanEqual");function K5(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Fn.validateEnv(e),r===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(zt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(zt.END_VALUE_REQUIRED);if(n=Fn.convertKeyValueToWrite(n),s=Fn.convertKeyValueToWrite(s),n>s)throw new Error(zt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return y_(e,t,r,n,s,i,o,c)}a(K5,"between");function Y5(e,t,r,n){Fn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(rp(r),r=b_(s,r),n===void 0)throw new Error(zt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=tp.parseRow(c,r)),o}a(Y5,"searchByHash");function W5(e,t,r){Fn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(W5,"checkHashExists");function j5(e,t,r,n,s=[]){return GM(e,t,r,n,s),FM(e,t,r,n,s).map(i=>i[1])}a(j5,"batchSearchByHash");function z5(e,t,r,n,s=[]){GM(e,t,r,n,s);let i=new Map;for(let[o,c]of FM(e,t,r,n,s))i.set(o,c);return i}a(z5,"batchSearchByHashToMap");function FM(e,t,r,n,s=[]){return Ec(e,t,t,(i,o,c)=>{r=b_(c,r);let l=r.length<3;return n.map(u=>{let d=c.dbis[t].get(u,{transaction:i,lazy:l});if(d)return[u,tp.parseRow(d,r)];s.push(u)}).filter(u=>u)})}a(FM,"batchHashSearch");function GM(e,t,r,n,s){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(rp(r),n==null)throw new Error(zt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(zt.IDS_MUST_BE_ITERABLE)}a(GM,"initializeBatchSearchByHash");function rp(e){if(!Array.isArray(e))throw e===void 0?new Error(zt.FETCH_ATTRIBUTES_REQUIRED):new Error(zt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(rp,"validateFetchAttributes");function Xo(e,t,r){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.SEARCH_VALUE_REQUIRED);if(r?.length>L5)throw new Error(zt.SEARCH_VALUE_TOO_LARGE)}a(Xo,"validateComparisonFunctions");function b_(e,t){return t.length===1&&D5.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=Jo.listDBIs(e)),t}a(b_,"setGetWholeRowAttributes");qM.exports={searchAll:M5,searchAllToMap:U5,count:x5,countAll:B5,equals:H5,startsWith:k5,endsWith:F5,contains:kM,searchByHash:Y5,setGetWholeRowAttributes:b_,batchSearchByHash:j5,batchSearchByHashToMap:z5,checkHashExists:W5,iterateDBI:v5,greaterThan:G5,greaterThanEqual:q5,lessThan:$5,lessThanEqual:V5,between:K5}});var Yl=N((vye,WM)=>{var $M=require("lodash"),VM=Tt(),xe=require("joi"),Q5=te(),{hdb_schema_table:O_,checkValidTable:KM,hdb_table:YM,hdb_database:np}=Ti(),{handleHDBError:J5,hdb_errors:X5}=_e(),{getDatabases:Z5}=(Pe(),oe(lt)),{HTTP_STATUS_CODES:e6}=X5,t6=xe.object({database:np,schema:np,table:YM,search_attribute:O_,search_value:xe.any().required(),get_attributes:xe.array().min(1).items(xe.alternatives(O_,xe.object())).optional(),desc:xe.bool(),limit:xe.number().integer().min(1),offset:xe.number().integer().min(0)}),r6=xe.object({database:np,schema:np,table:YM,operator:xe.string().valid("and","or").default("and").lowercase(),offset:xe.number().integer().min(0),limit:xe.number().integer().min(1),get_attributes:xe.array().min(1).items(xe.alternatives(O_,xe.object())).optional(),sort:xe.object({attribute:xe.alternatives(O_,xe.array().min(1)),descending:xe.bool().optional()}).optional(),conditions:xe.array().min(1).items(xe.alternatives(xe.object({operator:xe.string().valid("and","or").default("and").lowercase(),conditions:xe.array()}),xe.object({search_attribute:xe.alternatives(O_,xe.array().min(1)),search_type:xe.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:xe.when("search_type",{switch:[{is:"equals",then:xe.any()},{is:"between",then:xe.array().items(xe.alternatives([xe.string(),xe.number()])).length(2)}],otherwise:xe.alternatives(xe.string(),xe.number())}).required()}))).required()});WM.exports=function(e,t){let r=null;switch(t){case"value":r=VM.validateBySchema(e,t6);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(KM("database",e.schema)),i(KM("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=VM.validateBySchema(e,r6);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=Q5.checkGlobalSchemaTable(e.schema,e.table);if(s)return J5(new Error,s,e6.NOT_FOUND);let o=Z5()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(d=>{for(let _=0,E=d.conditions.length;_<E;_++){let f=d.conditions[_];f.conditions?l(f):c.push(f.search_attribute)}},"addConditions");t==="conditions"&&l(e);let u=$M.filter(c,d=>d!=="*"&&!d.startsWith?.("$")&&d.attribute!=="*"&&!Array.isArray(d)&&!d.name&&!$M.some(o,_=>_===d||_.attribute===d||_.attribute===d.attribute));if(u&&u.length>0){let d=u.join(", ");return d=d.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${d}'`)}}return r}});var sR=N((Hye,jM)=>{"use strict";var n6=ht(),s6=Yl(),{getSchemaPath:i6}=gt();jM.exports=o6;function o6(e){let t=s6(e,"hashes");if(t)throw t;let r=i6(e.schema,e.table);return n6.openEnvironment(r,e.table)}a(o6,"initialize")});var iR=N((kye,zM)=>{"use strict";var a6=Kl(),c6=sR();zM.exports=l6;async function l6(e){let t=await c6(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return a6.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(l6,"lmdbGetDataByHash")});var Wl=N((Gye,QM)=>{"use strict";var oR=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};QM.exports=oR});var XM=N((Vye,JM)=>{"use strict";var $ye=Wl(),u6=Kl(),d6=sR();JM.exports=_6;async function _6(e){let t=await d6(e),r=global.hdb_schema[e.schema][e.table];return u6.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(_6,"lmdbSearchByHash")});var $s=N((Yye,ZM)=>{"use strict";var aR=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,u=void 0,d=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=u,this.offset=d}};ZM.exports=aR});var sp=N((jye,iU)=>{"use strict";var Wr=Kl(),f6=ht(),E6=te(),ke=Ht(),hc=M(),h6=Zi(),eU=Dn().LMDB_ERRORS_ENUM,{getSchemaPath:p6}=gt(),so=hc.SEARCH_WILDCARDS;async function m6(e,t,r){let n;e.schema===hc.SYSTEM_SCHEMA_NAME?n=h6[e.table]:n=global.hdb_schema[e.schema][e.table];let s=sU(e,n.hash_attribute,r,t);return rU(e,s,n.hash_attribute,r)}a(m6,"prepSearch");async function rU(e,t,r,n){let s=p6(e.schema,e.table),i=await f6.openEnvironment(s,e.table),o=nU(i,e,t,r),c=o.transaction||i;if([ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,ke.SEARCH_TYPES.SEARCH_ALL,ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(S6(e,r)===!1){let d=e.search_attribute;if(d===r)return n?tU(o,()=>!0):o.map(E=>({[r]:E.key}));let _=a(E=>({[r]:E.value,[d]:E.key}),"toObject");return n?tU(o,_):o.map(_)}let u=e.search_attribute===r?o.map(d=>d.key):o.map(d=>d.value);return n===!0?Wr.batchSearchByHashToMap(c,r,e.get_attributes,u):Wr.batchSearchByHash(c,r,e.get_attributes,u)}a(rU,"executeSearch");function nU(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case ke.SEARCH_TYPES.EQUALS:s=Wr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.CONTAINS:s=Wr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.ENDS_WITH:case ke.SEARCH_TYPES._ENDS_WITH:s=Wr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.STARTS_WITH:case ke.SEARCH_TYPES._STARTS_WITH:s=Wr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Wr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Wr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case ke.SEARCH_TYPES.SEARCH_ALL:return Wr.searchAll(e,n,t.get_attributes,o,c,l);case ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Wr.searchAllToMap(e,n,t.get_attributes,o,c,l);case ke.SEARCH_TYPES.BETWEEN:s=Wr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case ke.SEARCH_TYPES.GREATER_THAN:case ke.SEARCH_TYPES._GREATER_THAN:s=Wr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.GREATER_THAN_EQUAL:case ke.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Wr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.LESS_THAN:case ke.SEARCH_TYPES._LESS_THAN:s=Wr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.LESS_THAN_EQUAL:case ke.SEARCH_TYPES._LESS_THAN_EQUAL:s=Wr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(nU,"searchByType");function tU(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(tU,"createMapFromIterable");function S6(e,t){if(e.get_attributes.length===1&&e.get_attributes[0]==="*")return!0;let r=[e.search_attribute];e.get_attributes.indexOf(t)>=0&&r.push(t);let n=!1;for(let s=0;s<e.get_attributes.length;s++)if(r.indexOf(e.get_attributes[s])<0){n=!0;break}return n}a(S6,"checkToFetchMore");function sU(e,t,r,n){if(E6.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),o=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),so.indexOf(s)>-1)return r===!0?ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP:ke.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(so[0])<0&&s.indexOf(so[1])<0)return c===!0?r===!0?ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:ke.SEARCH_TYPES.EQUALS;if(so.indexOf(i)>=0&&so.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),ke.SEARCH_TYPES.CONTAINS;if(so.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),ke.SEARCH_TYPES.ENDS_WITH;if(so.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),ke.SEARCH_TYPES.STARTS_WITH;if(s.includes(so[0])||s.includes(so[1]))return ke.SEARCH_TYPES.EQUALS;throw new Error(eU.UNKNOWN_SEARCH_TYPE)}else switch(n){case hc.VALUE_SEARCH_COMPARATORS.BETWEEN:return ke.SEARCH_TYPES.BETWEEN;case hc.VALUE_SEARCH_COMPARATORS.GREATER:return ke.SEARCH_TYPES.GREATER_THAN;case hc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return ke.SEARCH_TYPES.GREATER_THAN_EQUAL;case hc.VALUE_SEARCH_COMPARATORS.LESS:return ke.SEARCH_TYPES.LESS_THAN;case hc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return ke.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(eU.UNKNOWN_SEARCH_TYPE)}}a(sU,"createSearchTypeFromSearchObject");iU.exports={executeSearch:rU,createSearchTypeFromSearchObject:sU,prepSearch:m6,searchByType:nU}});var aU=N((Jye,oU)=>{"use strict";var Qye=$s(),T6=Yl(),g6=te(),A6=M(),R6=sp();oU.exports=y6;function y6(e,t){if(!g6.isEmpty(t)&&A6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=T6(e,"value");if(n)throw n;return R6.prepSearch(e,t,!0)}a(y6,"lmdbGetDataByValue")});var N_=N((ebe,cU)=>{"use strict";var Zye=$s(),b6=Yl(),O6=te(),N6=M(),I6=sp();cU.exports=w6;async function w6(e,t){if(!O6.isEmpty(t)&&N6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=b6(e,"value");if(n)throw n;return I6.prepSearch(e,t,!1)}a(w6,"lmdbSearchByValue")});var uU=N((nbe,lU)=>{"use strict";var rbe=Ht(),cR=class{static{a(this,"SearchByConditionsObject")}constructor(t,r,n,s,i=void 0,o=void 0,c="and"){this.schema=t,this.table=r,this.get_attributes=n,this.limit=i,this.offset=o,this.conditions=s,this.operator=c}},lR=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},uR=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};lU.exports={SearchByConditionsObject:cR,SearchCondition:lR,SortAttribute:uR}});var hU=N((abe,EU)=>{"use strict";var ibe=uU().SearchByConditionsObject,C6=$s(),D6=Yl(),dR=Kl(),ip=Ht(),{Resource:obe}=(Vs(),oe(_R)),fU=sp(),P6=nR(),L6=require("lodash"),{getSchemaPath:M6}=gt(),dU=ht(),{handleHDBError:U6,hdb_errors:v6}=_e(),{HTTP_STATUS_CODES:B6}=v6,H6=1e8;EU.exports=x6;async function x6(e){let t=D6(e,"conditions");if(t)throw U6(t,t.message,B6.BAD_REQUEST,void 0,void 0,!0);e.operator=e.operator?e.operator.toLowerCase():void 0,e.offset=Number.isInteger(e.offset)?e.offset:0;let r=M6(e.schema,e.table),n=await dU.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)dU.openDBI(n,u.search_attribute);let i=L6.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let d=u.search_type;d===ip.SEARCH_TYPES.EQUALS?u.estimated_count=dR.count(n,u.search_attribute,u.search_value):d===ip.SEARCH_TYPES.CONTAINS||d===ip.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=H6}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await _U(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let u=n.dbis[s.hash_attribute],d=i.slice(1).map(fU.filterByType),_=d.length,E=dR.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(f=>u.get(f,{transaction:o,lazy:!0})),_>0&&(l=l.filter(f=>{for(let h=0;h<_;h++)if(!d[h](f))return!1;return!0})),(e.offset||e.limit!==void 0)&&(l=l.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),l=l.map(f=>P6.parseRow(f,E))}else{for(let _=1;_<i.length;_++){let E=i[_],f=await _U(o,e,E,s.hash_attribute);c=c.concat(f)}let u=new Set,d=e.offset||0;c=c.filter(_=>u.has(_)?!1:(u.add(_),!0)).slice(d,e.limit&&e.limit+d),l=dR.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(x6,"lmdbSearchByConditions");async function _U(e,t,r,n){let s=new C6(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===ip.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,fU.searchByType(e,s,i,n).map(o=>o.value)}a(_U,"executeConditionSearch")});var I_=N((lbe,pU)=>{"use strict";var k6=M().OPERATIONS_ENUM,fR=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=k6.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};pU.exports=fR});var ER=N((dbe,bU)=>{"use strict";var gU=$s(),AU=I_(),RU=N_(),yU=R_(),dn=M(),mU=te(),SU=ht(),{getTransactionAuditStorePath:F6,getSchemaPath:G6}=gt(),TU=W();bU.exports=q6;async function q6(e){try{if(mU.isEmpty(global.hdb_schema[e.schema])||mU.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await $6(e),await V6(e);let t=G6(e.schema,e.table);try{await SU.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")TU.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=F6(e.schema,e.table);await SU.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")TU.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(q6,"lmdbDropTable");async function $6(e){let t=new gU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await RU(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 AU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await yU(s)}a($6,"deleteAttributesFromSystem");async function V6(e){let t=new gU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await RU(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 AU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await yU(s)}catch(i){throw i}}a(V6,"dropTableFromSystem")});var NU=N((fbe,OU)=>{"use strict";var K6=require("fs-extra"),Y6=$s(),W6=Wl(),j6=I_(),z6=ER(),Q6=R_(),J6=iR(),X6=N_(),io=M(),{getSchemaPath:Z6}=gt(),{handleHDBError:e8,hdb_errors:t8}=_e(),{HDB_ERROR_MSGS:r8,HTTP_STATUS_CODES:n8}=t8;OU.exports=s8;async function s8(e){let t;try{t=await i8(e.schema);let r=new Y6(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await X6(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await z6(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new j6(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await Q6(s);let i=Z6(t);await K6.remove(i)}catch(r){throw r}}a(s8,"lmdbDropSchema");async function i8(e){let t=new W6(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await J6(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw e8(new Error,r8.SCHEMA_NOT_FOUND(e),n8.NOT_FOUND,void 0,void 0,!0);return n}a(i8,"validateDropSchema")});var w_=N((hbe,IU)=>{"use strict";var hR=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};IU.exports=hR});var mR=N((Sbe,wU)=>{"use strict";var o8=require("fs-extra"),op=ht(),{getTransactionAuditStorePath:a8}=gt(),pR=Ht(),mbe=w_();wU.exports=c8;async function c8(e){let t;try{let r=a8(e.schema,e.table);await o8.mkdirp(r),t=await op.createEnvironment(r,e.table,!0)}catch(r){throw r.message=`unable to create transactions audit environment for ${e.schema}.${e.table} due to: ${r.message}`,r}try{op.createDBI(t,pR.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),op.createDBI(t,pR.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),op.createDBI(t,pR.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME,!0,!1)}catch(r){throw r.message=`unable to create dbi for ${e.schema}.${e.table} due to: ${r.message}`,r}return t}a(c8,"createTransactionsAuditEnvironment")});var PU=N((Abe,DU)=>{"use strict";var SR=M(),CU=ht(),l8=sc(),{getSystemSchemaPath:u8,getSchemaPath:d8}=gt(),gbe=Zi(),_8=Bh(),TR=vh(),f8=W(),E8=mR();DU.exports=h8;async function h8(e,t){let r=d8(t.schema,t.table),n=new TR(t.schema,t.table,SR.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new TR(t.schema,t.table,SR.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new TR(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await CU.createEnvironment(r,t.table),e!==void 0){let o=await CU.openEnvironment(u8(),SR.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await l8.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_table_attributes,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await gR(n),await gR(s),await gR(i)}await E8(t)}catch(o){throw o}}a(h8,"lmdbCreateTable");async function gR(e){try{await _8(e)}catch(t){f8.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(gR,"createAttribute")});var MU=N((ybe,LU)=>{"use strict";var p8=E_(),m8=Xd(),S8=Xh(),C_=M(),T8=sc().updateRecords,g8=ht(),{getSchemaPath:A8}=gt(),R8=g_(),y8=W();LU.exports=b8;async function b8(e){try{let{schema_table:t,attributes:r}=p8(e);m8(e,r,t.hash_attribute),e.schema!==C_.SYSTEM_SCHEMA_NAME&&(r.includes(C_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(C_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(C_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(C_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await S8(e.hdb_auth_header,t,r),s=A8(e.schema,e.table),i=await g8.openEnvironment(s,e.table),o=await T8(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await R8(e,o)}catch(c){y8.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(b8,"lmdbUpdateRecords")});var vU=N((Obe,UU)=>{"use strict";var O8=M().OPERATIONS_ENUM,AR=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=O8.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};UU.exports=AR});var HU=N((wbe,BU)=>{"use strict";var Ibe=vU(),N8=E_(),I8=Xd(),w8=Xh(),D_=M(),C8=sc().upsertRecords,D8=ht(),{getSchemaPath:P8}=gt(),L8=g_(),M8=W(),{handleHDBError:U8,hdb_errors:v8}=_e();BU.exports=B8;async function B8(e){let t;try{t=N8(e)}catch(l){throw U8(l,l.message,v8.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;I8(e,n,r.hash_attribute),e.schema!==D_.SYSTEM_SCHEMA_NAME&&(n.includes(D_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(D_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(D_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(D_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await w8(e.hdb_auth_header,r,n),i=P8(e.schema,e.table),o=await D8.openEnvironment(i,e.table),c=await C8(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await L8(e,c)}catch(l){M8.error(`unable to write transaction due to ${l.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:s,txn_time:c.txn_time}}a(B8,"lmdbUpsertRecords")});var kU=N((Dbe,xU)=>{"use strict";var RR=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};xU.exports=RR});var GU=N((Lbe,FU)=>{"use strict";var yR=class{static{a(this,"DeleteAuditLogsBeforeResults")}constructor(t=void 0,r=void 0,n=0){this.start_timestamp=t,this.end_timestamp=r,this.transactions_deleted=n}};FU.exports=yR});var VU=N((vbe,$U)=>{"use strict";var bR=ht(),{getTransactionAuditStorePath:H8}=gt(),Ube=kU(),P_=Ht(),x8=te(),qU=GU(),k8=require("util").promisify,F8=k8(setTimeout),G8=1e4,q8=100;$U.exports=$8;async function $8(e){let t=H8(e.schema,e.table),r=await bR.openEnvironment(t,e.table,!0),n=bR.listDBIs(r);bR.initializeDBIs(r,P_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new qU;do s=await V8(r,e.timestamp),i.start_timestamp===void 0&&(i.start_timestamp=s.start_timestamp),s.end_timestamp!==void 0&&(i.end_timestamp=s.end_timestamp),i.transactions_deleted+=s.transactions_deleted,await F8(q8);while(s.transactions_deleted>0);return i}a($8,"deleteAuditLogsBefore");async function V8(e,t){let r=new qU;try{let n=e.dbis[P_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],s;for(let{key:i,value:o}of n.getRange({start:!1})){if(i>=t)break;r.start_timestamp===void 0&&(r.start_timestamp=i),s=n.remove(i);let c=o[P_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];x8.isEmpty(c)||(s=e.dbis[P_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[P_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>G8)break}return await s,r}catch(n){throw n}}a(V8,"deleteTransactions")});var YU=N((Hbe,KU)=>{"use strict";var OR=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};KU.exports=OR});var jU=N((Fbe,WU)=>{"use strict";var K8=$s(),Y8=I_(),kbe=YU(),yi=M(),W8=te(),NR=ht(),j8=Zi(),z8=N_(),Q8=R_(),{getSchemaPath:J8}=gt();WU.exports=X8;async function X8(e,t=!0){let r;e.schema===yi.SYSTEM_SCHEMA_NAME?r=j8[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await e9(e),s=J8(e.schema,e.table),i=await NR.openEnvironment(s,e.table);return t===!0&&await Z8(e,i,r.hash_attribute),NR.dropDBI(i,e.attribute),n}a(X8,"lmdbDropAttribute");async function Z8(e,t,r){let n=NR.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let u={};for(let d in c)d!==i&&(u[d]=c[d]);s=t.dbis[r].put(o,u,l)}await s}a(Z8,"removeAttributeFromAllObjects");async function e9(e){let t=new K8(yi.SYSTEM_SCHEMA_NAME,yi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await z8(t)).filter(o=>o[yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(W8.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new Y8(yi.SYSTEM_SCHEMA_NAME,yi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return Q8(i)}a(e9,"dropAttributeFromSystem")});var ev=N(($be,ZU)=>{"use strict";var IR=ht(),jl=Ht(),qbe=cn(),wR=M(),zU=te(),{getTransactionAuditStorePath:t9}=gt(),r9=Kl(),ap=ql(),n9=W();ZU.exports=s9;async function s9(e){let t=t9(e.schema,e.table),r=await IR.openEnvironment(t,e.table,!0),n=IR.listDBIs(r);IR.initializeDBIs(r,jl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case wR.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return QU(r,e.search_values);case wR.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,o9(r,e.search_values,s);case wR.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return i9(r,e.search_values);default:return QU(r)}}a(s9,"readAuditLog");function QU(e,t=[0,Date.now()]){zU.isEmpty(t[0])&&(t[0]=0),zU.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[jl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let s of r.getKeys({start:t[1]}))if(s!==t[1]){n=s;break}return r.getRange({start:t[0],end:n}).map(({value:s})=>Object.assign(new ap,s))}a(QU,"searchTransactionsByTimestamp");function i9(e,t=[]){let r=new Map;for(let n=0;n<t.length;n++){let s=t[n],i=[];for(let o of e.dbis[jl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,XU(e,i))}return Object.fromEntries(r)}a(i9,"searchTransactionsByUsername");function o9(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],d=r9.equals(e,jl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,jl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:_}of d){let E=Number(_);n.has(E)?n.get(E).push(u.toString()):n.set(E,[u.toString()])}}let s=Array.from(n.keys()),i=XU(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,d=n.get(u);JU(l,"records",r,d,o),JU(l,"original_records",r,d,o)}return Object.fromEntries(o)}a(o9,"searchTransactionsByHashValues");function JU(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let u=s.get(l),d=u[u.length-1];if(d.timestamp===i)d[t]=[c];else{let _=new ap(e.operation,e.user_name,i,void 0);_[t]=[c],u.push(_)}}else{let u=new ap(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}a(JU,"loopRecords");function XU(e,t){let r=[];try{let n=e.dbis[jl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let s=0;s<t.length;s++)try{let i=n.get(t[s]);if(i){let o=Object.assign(new ap,i);r.push(o)}}catch(i){n9.warn(i)}return r}catch(n){throw n}}a(XU,"batchSearchTransactions")});var rv=N((Wbe,tv)=>{"use strict";var{getSchemaPath:Kbe}=gt(),Ybe=ht(),{database:a9}=(Pe(),oe(lt));tv.exports={writeTransaction:c9};async function c9(e,t,r){return a9({database:e,table:t}).transaction(r)}a(c9,"writeTransaction")});var ov=N((zbe,iv)=>{"use strict";var{getSchemaPath:nv}=gt(),sv=ht();iv.exports={flush:l9,resetReadTxn:u9};async function l9(e,t){return(await sv.openEnvironment(nv(e,t),t.toString())).flushed}a(l9,"flush");async function u9(e,t){try{(await sv.openEnvironment(nv(e,t),t.toString())).resetReadTxn()}catch{}}a(u9,"resetReadTxn")});var uv=N((Jbe,lv)=>{"use strict";var{Readable:d9}=require("stream"),{getDatabases:_9}=(Pe(),oe(lt)),{readSync:f9,openSync:E9,createReadStream:av}=require("fs"),{open:h9}=require("lmdb"),cv=a_(),p9=c_(),{AUDIT_STORE_OPTIONS:m9}=(Ji(),oe(dv)),{INTERNAL_DBIS_NAME:S9,AUDIT_STORE_NAME:T9}=Ht();lv.exports=A9;var CR=32768,g9=100;async function A9(e){let t=e.database||e.schema||"data",r=_9()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let u=r[s[0]];if(!u)throw new Error(`Can not find table ${s[0]}`);let d=u.dbisDB,_=h9({noSync:!0,maxDbs:p9.MAX_DBS}),E,f=_.openDB(S9,new cv(!1)),h=d.useReadTransaction(),T=0,m=a(async function(S,b){b.encoding="binary",b.encoder=void 0;let I=_.openDB(S,b),B=d.openDB(S,b);for(let{key:H,version:X,value:Y}of B.getRange({start:null,transaction:h,versions:B.useVersions}))E=I.put(H,Y,X),T++%g9===0&&(await new Promise(V=>setTimeout(V,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:S,value:b}of d.getRange({transaction:h,start:!1}))if(s.some(I=>S.startsWith?.(I+"/"))){f.put(S,b);let[,I]=S.split("/"),B=!I,H=new cv(!B,B);await m(S,H)}e.include_audit&&await m(T9,{...m9}),await E;let g=av(_.path);return g.headers=l(),g.on("close",()=>{h.done(),_.close()}),g}let o=r[Object.keys(r)[0]].primaryStore,c=E9(o.path);return o.transaction(()=>{let u=Buffer.alloc(CR);f9(c,u,0,CR),o.resetReadTxn();let d=o.useReadTransaction();d.renew();let _=av(null,{fd:c,start:CR}),E=new d9.from(async function*(){yield u;for await(let f of _)d.openTimer&&(d.openTimer=0),yield f;d.done()}());return E.headers=l(),E});function l(){let u=new Map;return u.set("content-type","application/octet-stream"),u.set("content-disposition",`attachment; filename="${t}"`),u.set("date",n),u}}a(A9,"getBackup")});var Ev=N((Zbe,fv)=>{"use strict";var R9=W(),{handleHDBError:y9}=_e(),b9=zD(),O9=Bh(),N9=XA(),I9=NM(),w9=R_(),C9=iR(),D9=XM(),P9=aU(),L9=N_(),M9=hU(),U9=NU(),v9=PU(),B9=MU(),H9=HU(),x9=VU(),k9=ER(),F9=jU(),G9=ev(),q9=rv(),_v=ov(),$9=uv(),DR=class extends b9{static{a(this,"LMDBBridge")}async searchByConditions(t){return M9(t)}async getDataByHash(t){return await C9(t)}async searchByHash(t){return await D9(t)}async getDataByValue(t,r){return await P9(t,r)}async searchByValue(t){return await L9(t)}async createSchema(t){return await I9(t)}async dropSchema(t){return await U9(t)}async createTable(t,r){return await v9(t,r)}async dropTable(t){return await k9(t)}async createAttribute(t){return await O9(t)}async createRecords(t){return await N9(t)}async updateRecords(t){return await B9(t)}async upsertRecords(t){try{return await H9(t)}catch(r){throw y9(r,null,null,R9.ERR,r)}}async deleteRecords(t){return await w9(t)}async dropAttribute(t){return await F9(t)}async deleteAuditLogsBefore(t){return await x9(t)}async readAuditLog(t){return await G9(t)}writeTransaction(t,r,n){return q9.writeTransaction(t,r,n)}flush(t,r){return _v.flush(t,r)}resetReadTxn(t,r){return _v.resetReadTxn(t,r)}getBackup(t){return $9(t)}};fv.exports=DR});function Rv(e){LR=e}function W9(){Y9=setInterval(function(){for(let e of PR)if(e.stale){let t=e[Fe]?.url;Sv.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},K9).unref()}var MR,mv,Sv,Tv,gv,Av,hv,PR,V9,L_,pv,LR,pc,cp,K9,Y9,lp=Ie(()=>{MR=L(cn()),mv=L(_e()),Sv=L(W());Vs();Tv=L(se()),gv=L(M()),Av=L(te()),hv=100,PR=new Set,V9=(0,Av.convertToMS)(Tv.get(gv.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(Rv,"replicationConfirmation");pc=class e{static{a(this,"DatabaseTransaction")}writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxnsUsed=1,this.readTxn.openTimer&&(this.readTxn.openTimer=0),PR.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(PR.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(L_&&!this.overloadChecked&&performance.now()-pv>V9)throw new mv.ServerError("Outstanding write transactions have too long of queue, please try again later",503);this.overloadChecked=!0}addWrite(t){if(this.open===0)throw new Error("Can not use a transaction that is no longer open");if(this.open===2){let r=new e;return r.addWrite(t),r.commit({})}else this.writes.push(t)}removeWrite(t){let r=this.writes.indexOf(t);r>-1&&(this.writes[r]=null)}commit(t={}){let r=this.timestamp;r||(r=this.timestamp=t.timestamp||(0,MR.getNextMonotonicTime)()),t.timestamp||(t.timestamp=r);let n=t.retries||0;if(this.validated<this.writes.length)try{let _=this.validated;this.validated=this.writes.length;for(let f=_;f<this.validated;f++)this.writes[f]?.validate?.(this.timestamp);let E;for(let f=_;f<this.validated;f++){let h=this.writes[f];h&&(h.before||h.beforeIntermediate)&&(E=!0)}if(E)return(async()=>{try{for(let f=0;f<2;f++){let h;for(let T=_;T<this.validated;T++){let m=this.writes[T];if(!m)continue;let g=m[f===0?"before":"beforeIntermediate"];if(g){let S=g();h?h.push?h.push(S):h=[h,S]:h=S}}h&&await(h.push?Promise.all(h):h)}}catch(f){throw this.abort(),f}return this.commit(t)})()}catch(_){throw this.abort(),_}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(_=>_);let c=a(_=>{_.commit(r,_.entry,n)},"doWrite"),l=a(()=>{let _=this.writes[o++];if(_)if(_.key){n>0&&(_.entry=_.store.getEntry(_.key));let E=_.store.ifVersion(_.key,_.entry?.version??null,l);s=s||E}else l();else for(let E of this.writes)c(E)},"nextCondition"),u=this.lmdbDb;if(this.writes.length>0&&(u?.retryRisk&&(u.retryRisk*=.99),this.writes.length+(u?.retryRisk||0)<hv>>n?l():s=this.writes[0].store.transaction(()=>{for(let _ of this.writes)_.entry=_.store.getEntry(_.key),c(_);return!0})),s)return L_||(L_=s,pv=performance.now(),L_.then(()=>{L_=null})),s.then(_=>{if(_){if(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.replicatedConfirmation){let E=this.writes[0].store.rootStore.databaseName,f=this.writes[this.writes.length-1];LR&&f&&i.push(LR(E,f.store.getEntry(f.key).localTime,this.replicatedConfirmation))}return this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))}else return u&&(u.retryRisk=(u.retryRisk||0)+hv/2),t?t.retries=n+1:t={retries:1},this.commit(t)});let d={txnTime:r};if(this.next){let _=this.next?.commit(t);if(_?.then)return _?.then(E=>({txnTime:r,next:E}));d.next=_}return d}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},cp=class extends pc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,MR.getNextMonotonicTime)())}getReadTxn(){}},K9=3e4;a(W9,"startMonitoringTxns");W9()});function Dt(e,t,r){if(!t)t=e,e={};else if(!e)e={};else if(e?.transaction?.open===1&&typeof t=="function")return t(e.transaction);if(typeof t!="function")throw new Error("Callback function must be provided to transaction");let n=e.transaction=new pc;e.timestamp&&(n.timestamp=e.timestamp),e.replicatedConfirmation&&(n.replicatedConfirmation=e.replicatedConfirmation),n[Fe]=e,e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var yv,mc=Ie(()=>{yv=L(fi());Vs();lp();a(Dt,"transaction");(0,yv._assignPackageExport)("transaction",Dt);Dt.commit=function(e){let t=(e[Fe]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Dt.abort=function(e){let t=(e[Fe]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var Pv={};je(Pv,{ResourceBridge:()=>BR});function HR({get_attributes:e},t){if(e){if(e[0]==="*"){if(t.schemaDefined)return;e=t.attributes.map(r=>r.name)}return e.forceNulls=!0,e}}function Ov(e,t){let r=bi(e),n=HR(e,r);if(!r)throw new Ks.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache,replicateFrom:e.replicateFrom},o;Dt(i,()=>new Promise(u=>o=u));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let u=c[l++],d;try{d=await r.get({id:u,lazy:s,select:n},i),d=d&&dp(d)}catch(_){d={message:_.toString()}}return t?{value:{key:u,value:d}}:{value:d}}else return o(),{done:!0}},return(u){return o(),{value:u,done:!0}},throw(u){return o(),{done:!0}}}}}}function bi(e){let t=e.database||e.schema||z9,r=ut()[t];if(!r)throw(0,Ks.handleHDBError)(new Error,j9.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function Nv(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*Iv(e,t,r,n){let s,i=0;for await(let o of e.getHistory(t,r)){let c=o.operation??o.type;c==="put"&&(c="upsert");let{id:l,version:u,value:d}=o;if(s?.timestamp===u)s.hash_values.push(l),s.records.push(d);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:u,hash_values:[l],records:[d]}}}s&&(yield s)}var wv,up,Ks,Cv,Ys,UR,vR,Dv,j9,z9,Q9,J9,bv,BR,Lv=Ie(()=>{"use strict";wv=L(Ev()),up=L(Yl()),Ks=L(_e());Pe();Cv=L(E_()),Ys=L(M()),UR=L(no()),vR=L(qs()),Dv=L(te());mc();_p();({HDB_ERROR_MSGS:j9}=Ks.hdb_errors),z9="data",Q9=1e4,J9=10,BR=class extends wv.default{static{a(this,"ResourceBridge")}constructor(t){super(t),bv=this}async searchByConditions(t){t.select!==void 0&&(t.get_attributes=t.select);for(let o of t.conditions||[])o?.attribute!==void 0&&(o.search_attribute=o.attribute),o?.comparator!==void 0&&(o.search_type=o.comparator),o?.value!==void 0&&(o.search_value=o.value);let r=(0,up.default)(t,"conditions");if(r)throw(0,Ks.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=bi(t);if(!n)throw new Ks.ClientError(`Table ${t.table} not found`);let s=t.conditions.map(i);function i(o){return o.conditions?(o.conditions=o.conditions.map(i),o):{attribute:o.search_attribute??o.attribute,comparator:o.search_type??o.comparator,value:o.search_value!==void 0?o.search_value:o.value}}return a(i,"mapCondition"),n.search({conditions:s,operator:t.operator?t.operator.toLowerCase():void 0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:HR(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new Ks.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}Et({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await bi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=bi(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c={...c},delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(u=>{if(!u){let{value:d,version:_}=r.primaryStore.getEntry(o);return i(o,d,_)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(u=>setImmediate(u));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){bi(t).dropTable()}createSchema(t){return zl({database:t.schema,table:null}),UR.signalSchemaChange(new vR.SchemaEventMsg(process.pid,Ys.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await xR(t.schema),UR.signalSchemaChange(new vR.SchemaEventMsg(process.pid,Ys.OPERATIONS_ENUM.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,bv.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,Cv.default)(t),s,i=ut()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(o.replicateTo=t.replicateTo),t.replicatedConfirmation&&(o.replicatedConfirmation=t.replicatedConfirmation),Dt(o,async c=>{if(!i.schemaDefined){s=[];for(let d of n)i.attributes.find(E=>E.name==d)||s.push(d);s.length>0&&await i.addAttributes(s.map(d=>({name:d,indexed:!0})))}let l=[],u=[];for(let d of t.records){let _=d[i.primaryKey],E=_!=null&&await i.get(_,o);if(t.requires_existing&&!E||t.requires_no_existing&&E){u.push(d[i.primaryKey]);continue}E&&(E=dp(E));for(let f in d)if(Object.prototype.hasOwnProperty.call(d,f)){let h=d[f];if(typeof h=="function")try{let T=h([[E]]);Array.isArray(T)&&(h=T[0].func_val,d[f]=h)}catch(T){throw T.message+="Trying to set key "+f+" on object"+JSON.stringify(d),T}}if(E)for(let f in E)Object.prototype.hasOwnProperty.call(d,f)||(d[f]=E[f]);await(_==null?i.create(d,o):i.put(d,o)),l.push(d[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:u}})}async deleteRecords(t){let r=ut()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),Dt(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),o=[],c=[];for(let l of i)await r.delete(l,n)?o.push(l):c.push(l);return Nv(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=ut()[t.schema][t.table];if(!r.createdTimeProperty)throw new Ks.ClientError("Table must have a '__createdtime__' attribute or @createdTime timestamp defined to perform this operation");let n=await r.search({conditions:[{attribute:r.createdTimeProperty.name,value:Date.parse(t.date),comparator:Ys.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,l=[],u=a(async()=>{let d=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...d.deleted_hashes),o.push(...d.skipped_hashes),await(0,Dv.async_set_timeout)(J9),l=[],s=!0},"chunkDelete");for await(let d of n)l.push(d[r.primaryKey]),c++,c%Q9===0&&await u();return l.length>0&&await u(),s?Nv(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,up.default)(t,"hashes");if(r)throw r;return Ov(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of Ov(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Ys.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r]===void 0)throw new Error(`Value search comparator - ${r} - is not valid`);t.select!==void 0&&(t.get_attributes=t.select),t.attribute!==void 0&&(t.search_attribute=condition.attribute),t.value!==void 0&&(t.search_value=condition.value);let n=(0,up.default)(t,"value");if(n)throw n;let s=bi(t);if(!s)throw new Ks.ClientError(`Table ${t.table} not found`);let i=t.search_value;i.includes?.("*")&&(i.startsWith("*")?i.endsWith("*")?i!=="*"&&(r="contains",i=i.slice(1,-1)):(r="ends_with",i=i.slice(1)):i.endsWith("*")&&(r="starts_with",i=i.slice(0,-1))),r===Ys.VALUE_SEARCH_COMPARATORS.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,sort:t.sort,select:HR(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=bi(t);t.get_attributes&&!t.get_attributes.includes(s.primaryKey)&&t.get_attributes[0]!=="*"&&t.get_attributes.push(s.primaryKey);for await(let i of this.searchByValue(t,r))n.set(i[s.primaryKey],i);return n}resetReadTxn(t,r){bi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return bi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=bi(t),n={};switch(t.search_type){case Ys.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.operation??o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case Ys.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of Iv(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return Iv(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(HR,"getSelect");a(Ov,"getRecords");a(bi,"getTable");a(Nv,"createDeleteResponse");a(Iv,"groupRecordsInHistory")});var Bn=N((EOe,Mv)=>{"use strict";var{ResourceBridge:X9}=(Lv(),oe(Pv)),Z9=se();Z9.initSync();var fp;function e7(){return fp||(fp=new X9,fp)}a(e7,"getBridge");Mv.exports=e7()});var Hv=N((pOe,Bv)=>{"use strict";var Uv=require("lodash"),M_=require("mathjs"),t7=require("jsonata"),vv=te();Bv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?Uv.uniqWith(e,Uv.isEqual):e,"distinct_array"),searchJSON:r7,mad:U_.bind(null,M_.mad),mean:U_.bind(null,M_.mean),mode:U_.bind(null,M_.mode),prod:U_.bind(null,M_.prod),median:U_.bind(null,M_.median)};function U_(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(U_,"aggregateFunction");function r7(e,t){if(typeof e!="string"||e.length===0)throw new Error("search json expression must be a non-empty string");let r="__"+e+"__";if(vv.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),vv.isEmpty(this.__ala__.res[r])){let n=t7(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(r7,"searchJSON")});var kv=N((SOe,xv)=>{"use strict";var nr=require("moment"),kR="YYYY-MM-DDTHH:mm:ss.SSSZZ";nr.suppressDeprecationWarnings=!0;xv.exports={current_date:a(()=>nr().utc().format("YYYY-MM-DD"),"current_date"),current_time:a(()=>nr().utc().format("HH:mm:ss.SSS"),"current_time"),extract:a((e,t)=>{switch(t.toLowerCase()){case"year":return nr(e).utc().format("YYYY");case"month":return nr(e).utc().format("MM");case"day":return nr(e).utc().format("DD");case"hour":return nr(e).utc().format("HH");case"minute":return nr(e).utc().format("mm");case"second":return nr(e).utc().format("ss");case"millisecond":return nr(e).utc().format("SSS");default:break}},"extract"),date:a(e=>nr(e).utc().format(kR),"date"),date_format:a((e,t)=>nr(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>nr(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>nr(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=nr(e).utc(),s=nr(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>nr().utc().valueOf(),"now"),get_server_time:a(()=>nr().format(kR),"get_server_time"),offset_utc:a((e,t)=>nr(e).utc().utcOffset(t).format(kR),"offset_utc")}});var $v=N((gOe,qv)=>{"use strict";var n7=require("@turf/area"),s7=require("@turf/length"),i7=require("@turf/circle"),o7=require("@turf/difference"),a7=require("@turf/distance"),c7=require("@turf/boolean-contains"),l7=require("@turf/boolean-equal"),u7=require("@turf/boolean-disjoint"),d7=require("@turf/helpers"),Fv=M(),$e=te(),oo=W();qv.exports={geoArea:_7,geoLength:f7,geoCircle:E7,geoDifference:h7,geoDistance:Gv,geoNear:p7,geoContains:m7,geoEqual:S7,geoCrosses:T7,geoConvert:g7};function _7(e){if($e.isEmpty(e))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return n7.default(e)}catch(t){return oo.trace(t,e),NaN}}a(_7,"geoArea");function f7(e,t){if($e.isEmpty(e))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return s7.default(e,{units:t||"kilometers"})}catch(r){return oo.trace(r,e),NaN}}a(f7,"geoLength");function E7(e,t,r){if($e.isEmpty(e))return NaN;if($e.isEmpty(t))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return i7.default(e,t,{units:r||"kilometers"})}catch(n){return oo.trace(n,e,t),NaN}}a(E7,"geoCircle");function h7(e,t){if($e.isEmpty(e))return NaN;if($e.isEmpty(t))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return o7(e,t)}catch(r){return oo.trace(r,e,t),NaN}}a(h7,"geoDifference");function Gv(e,t,r){if($e.isEmpty(e))return NaN;if($e.isEmpty(t))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return a7.default(e,t,{units:r||"kilometers"})}catch(n){return oo.trace(n,e,t),NaN}}a(Gv,"geoDistance");function p7(e,t,r,n){if($e.isEmpty(e)||$e.isEmpty(t))return!1;if($e.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return Gv(e,t,n)<=r}catch(s){return oo.trace(s,e,t),!1}}a(p7,"geoNear");function m7(e,t){if($e.isEmpty(e)||$e.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return c7.default(e,t)}catch(r){return oo.trace(r,e,t),!1}}a(m7,"geoContains");function S7(e,t){if($e.isEmpty(e)||$e.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return l7.default(e,t)}catch(r){return oo.trace(r,e,t),!1}}a(S7,"geoEqual");function T7(e,t){if($e.isEmpty(e)||$e.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return!u7.default(e,t)}catch(r){return oo.trace(r,e,t),!1}}a(T7,"geoCrosses");function g7(e,t,r){if($e.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if($e.isEmpty(t))throw new Error("geo_type is required");if($e.isEmpty(Fv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(Fv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=$e.autoCastJSON(e)),d7[t](e,r)}a(g7,"geoConvert")});var Ep=N((ROe,Vv)=>{var Sc=Hv(),Gn=kv(),Oi=$v();Vv.exports=e=>{e.aggr.mad=e.aggr.MAD=Sc.mad,e.aggr.mean=e.aggr.MEAN=Sc.mean,e.aggr.mode=e.aggr.MODE=Sc.mode,e.aggr.prod=e.aggr.PROD=Sc.prod,e.aggr.median=e.aggr.MEDIAN=Sc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Sc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Sc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Gn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Gn.current_time,e.fn.extract=e.fn.EXTRACT=Gn.extract,e.fn.date=e.fn.DATE=Gn.date,e.fn.date_format=e.fn.DATE_FORMAT=Gn.date_format,e.fn.date_add=e.fn.DATE_ADD=Gn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Gn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Gn.date_diff,e.fn.now=e.fn.NOW=Gn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Gn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Gn.get_server_time,e.fn.getdate=e.fn.GETDATE=Gn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Gn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Oi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Oi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Oi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Oi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Oi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Oi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Oi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Oi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Oi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Oi.geoNear}});var jv=N((yOe,Wv)=>{"use strict";var v_=require("lodash"),_n=require("alasql");_n.options.cache=!1;var A7=Ep(),Kv=require("clone"),hp=require("recursive-iterator"),Ue=W(),et=te(),Ql=Bn(),R7=M(),{hdb_errors:y7}=_e(),{getDatabases:Yv}=(Pe(),oe(lt)),b7="IS NULL",Ws="There was a problem performing this search. Please check the logs and try again.";A7(_n);var FR=class{static{a(this,"SQLSearch")}constructor(t,r){if(et.isEmpty(t))throw Ue.error("AST statement for SQL select process cannot be empty"),"statement cannot be null";this.statement=t,this.columns={},this.all_table_attributes=r,this.fetch_attributes=[],this.exact_search_values={},this.comparator_search_values={},this.tables=[],this.data={},this.has_aggregator=!1,this.has_ordinal=!1,this.has_outer_join=!1,this._getColumns(),this._getTables(),this._conditionsToFetchAttributeValues(),this._setAliasesForColumns(),et.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!et.isEmptyOrZeroLength(n))return Ue.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw Ue.error("Error thrown from checkEmptySQL in SQLSearch class method search."),Ue.error(n),new Error(Ws)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw Ue.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),Ue.error(n),new Error(Ws)}if(Object.keys(this.data).length===0)return Ue.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw Ue.error("Error thrown from processJoins in SQLSearch class method search."),Ue.error(n),new Error(Ws)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw Ue.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),Ue.error(n),new Error(Ws)}try{return t=await this._finalSQL(),t}catch(n){throw Ue.error("Error thrown from finalSQL in SQLSearch class method search."),Ue.error(n),new Error(Ws)}}_getColumns(){let t=new hp(this.statement);for(let{node:r,path:n}of t)r&&r.columnid&&(this.columns[n[0]]||(this.columns[n[0]]=[]),this.columns[n[0]].push(Kv(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=v_.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=Yv()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(et.isEmpty(this.statement.where)){Ue.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new hp(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!et.isEmpty(r)&&r.right)if(et.isNotEmptyAndHasValue(r.right.value)){let n=et.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new _n.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=et.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new _n.yy.LogicValue({value:i}):n instanceof _n.yy.StringValue&&et.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new _n.yy.NumValue({value:i}))});if(t){Ue.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new hp(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let n=new Set,s=r.left.columnid?r.left:r.right,i=this._findColumn(s);if(!i)continue;let o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!et.isEmpty(R7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(et.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(et.isEmptyOrZeroLength(r.left.columnid)||et.isEmptyOrZeroLength(r.right.value)){this.comparator_search_values[o].ignore=!0,this.comparator_search_values[o].comparators=[];continue}this.comparator_search_values[o].comparators.push({attribute:r.left.columnid,operation:r.op,search_value:r.right.value})}continue}if(et.isEmpty(this.exact_search_values[o])&&(this.exact_search_values[o]={ignore:!1,values:new Set}),!this.exact_search_values[o].ignore){let c=!1;switch(r.op){case"=":!et.isEmpty(r.right.value)||!et.isEmpty(r.left.value)?n.add(et.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let l=Array.isArray(r.right)?r.right:r.left;for(let u=0;u<l.length;u++)if(l[u].value)n.add(l[u].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(et.isEmptyOrZeroLength(this.all_table_attributes)&&et.isEmptyOrZeroLength(this.statement.from)&&et.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((n,s)=>{if(n.columnid==="*"){t.push(s);return}if(n.aggregatorid&&(this.has_aggregator=!0),!n.aggregatorid&&!n.funcid)if(n.as_orig=n.as?n.as:n.columnid,this.statement.joins)if(r[n.as_orig]>=0){let i=r[n.as_orig]+1;n.as=`[${n.as_orig+i}]`,r[n.as_orig]=i}else n.as=`[${n.as_orig}]`,r[n.as_orig]=0;else n.as=`[${n.as_orig}]`;!n.aggregatorid&&n.funcid&&n.args&&(n.as_orig=n.as?n.as:n.toString().replace(/'/g,'"'),n.as=`[${n.as_orig}]`),n.aggregatorid&&n.expression.columnid!=="*"&&(n.as_orig=n.as?n.as:n.expression.tableid?`${n.aggregatorid}(${n.expression.tableid}.${n.expression.columnid})`:`${n.aggregatorid}(${n.expression.columnid})`,n.as=`[${n.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&v_.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(et.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);et.isEmptyOrZeroLength(n)||(r=this.all_table_attributes.filter(s=>s.attribute===n[0].columnid&&n[0].tableid&&n[0].tableid===(s.table.as?s.table.as:s.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(et.isEmptyOrZeroLength(this.all_table_attributes)&&!et.isEmptyOrZeroLength(this.columns.columns))return t;if(et.isEmptyOrZeroLength(this.all_table_attributes)&&et.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await _n.promise(r)}catch(r){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),Ue.error(r),new Error("There was a problem with the SQL statement")}return t}_addFetchColumns(t){t&&t.length>0&&t.forEach(r=>{let n=this._findColumn(r);n&&this.fetch_attributes.push(Kv(n))})}_addColumnToMergedAttributes(t,r){this.data[t].__merged_attributes.push(r),this.data[t].__merged_attr_map[r]=this.data[t].__merged_attributes.length-1}_setMergedHashAttribute(t,r){this.data[t].__merged_data[r].splice(0,1,r)}_updateMergedAttribute(t,r,n,s){let i=this.data[t].__merged_attr_map[n];this.data[t].__merged_data[r].splice(i,1,s)}async _getFetchAttributeValues(){if(et.isEmptyOrZeroLength(Object.keys(this.columns)))return[];this._addFetchColumns(this.columns.joins);let t=null;try{t=this.statement.where?this.statement.where.toString():""}catch{throw new Error("Could not generate proper where clause")}this.columns.where&&this._addFetchColumns(this.columns.where);let r=this._isSimpleSelect();if(r?this._addFetchColumns(this.columns.columns):(!this.columns.where&&this.fetch_attributes.length===0)|t.indexOf(b7)>-1&&this.tables.forEach(s=>{let i={columnid:Yv()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=v_.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,u=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!et.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!et.isEmptyOrZeroLength(this.exact_search_values[u].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[u].values);let d=await Ql.getDataByHash(c);for(let _ of c.hash_values)d.get(_)&&!this.data[i].__merged_data[_]&&(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_))}catch(d){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(d),new Error(Ws)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async d=>{let _={...c};_.search_value=d;let E=await Ql.getDataByValue(_);for(let[f,h]of E)this.data[i].__merged_data[f]?this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]):(this.data[i].__merged_data[f]=[...n[i]],this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,f))}))}catch(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(d),new Error(Ws)}else if(!et.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!et.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let d=this.comparator_search_values[u].comparators;for(let _=0,E=d.length;_<E;_++){let f=d[_];c.search_attribute=f.attribute,c.search_value=f.search_value;let h=await Ql.getDataByValue(c,f.operation);if(l)for(let[T]of h)this.data[i].__merged_data[T]||(this.data[i].__merged_data[T]=[...n[i]],this._setMergedHashAttribute(i,T));else for(let[T,m]of h)this.data[i].__merged_data[T]?this._updateMergedAttribute(i,T,s.attribute,m[s.attribute]):(this.data[i].__merged_data[T]=[...n[i]],this._updateMergedAttribute(i,T,s.attribute,m[s.attribute]),this._setMergedHashAttribute(i,T))}}catch(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),Ue.error(d),new Error(Ws)}else try{c.search_attribute=s.attribute,c.search_value="*";let d=await Ql.getDataByValue(c);if(l)for(let[_]of d)this.data[i].__merged_data[_]||(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_));else for(let[_,E]of d)this.data[i].__merged_data[_]?this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]):(this.data[i].__merged_data[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]),this._setMergedHashAttribute(i,_))}catch(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),Ue.error(d),new Error(Ws)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof _n.yy.Column||(t=!1)}),t)}_updateOrderByToAliases(){this.statement.order.forEach(t=>{if(t.expression.aggregatorid){t.is_aggregator=!0;return}if(t.expression.value){t.is_ordinal=!0,this.has_ordinal=!0;return}else t.is_ordinal=!1;let r=this.statement.columns.filter(s=>{let i=s.aggregatorid?s.expression:s,o=s.aggregatorid?s.as_orig:i.as_orig;return t.expression.tableid?i.columnid_orig===t.expression.columnid_orig&&i.tableid_orig===t.expression.tableid_orig:i.columnid_orig===t.expression.columnid_orig||t.expression.columnid_orig===o});r[0]||r.push(this._findColumn(t.expression));let n=r[0];if(t.is_func=!!n.funcid,t.is_aggregator=!!n.aggregatorid,n.as)if(n.as&&!t.expression.tableid)t.expression.columnid=n.as,t.expression.columnid_orig=n.as_orig;else{let s=new _n.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new _n.yy.Column,t.expression),t.initial_select_column.as=`[${t.expression.columnid_orig}]`,t.expression.columnid=t.initial_select_column.as;return}if(!t.is_aggregator){let s=t.is_func?new _n.yy.FuncValue:new _n.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(f=>{f.joinmode&&f.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(f.table);let h=f.joinmode+" JOIN ? AS "+(f.as?f.as:f.table.tableid);f.on&&(h+=" ON "+f.on.toString()),i.push(h),t.push(Object.values(this.data[`${f.table.databaseid_orig}_${f.table.as?f.table.as_orig:f.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(f=>{let h=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__hash_name,T=f.as?f.as_orig:f.tableid_orig;o.push({key:`'${T}.${h}'`,schema:f.databaseid_orig,table:f.as?f.as_orig:f.tableid_orig,keys:new Set}),r.push(`${f.as?f.as:f.tableid}.\`${h}\` AS "${T}.${h}"`),c[f.as?f.as_orig:f.tableid_orig]=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let u="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(u="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(f=>{f.is_func?r.push(f.initial_select_column.toString()):f.initial_select_column.tableid?r.push(`${f.initial_select_column.tableid}.${f.initial_select_column.columnid} AS ${f.expression.columnid}`):r.push(`${f.initial_select_column.columnid} AS ${f.expression.columnid}`)}));let d="",_="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(d=this.statement.limit?"LIMIT "+this.statement.limit:"",_=this.statement.offset?"OFFSET "+this.statement.offset:"");let E=[];try{let f=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${u} ${d} ${_}`,h=this._convertColumnsToIndexes(f,s);E=await _n.promise(h,t),t=null}catch(f){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),Ue.error(f),new Error("There was a problem processing the data.")}if(E&&E.length>0){for(let f=0,h=E.length;f<h;f++){let T=E[f];o.forEach(m=>{T[m.key]!==null&&T[m.key]!==void 0&&m.keys.add(T[m.key])})}o.forEach(f=>{let h=Object.keys(this.data[`${f.schema}_${f.table}`].__merged_data),T=v_.difference(h,[...f.keys].map(m=>m.toString()));for(let m=0,g=T.length;m<g;m++){let S=T[m];delete this.data[`${f.schema}_${f.table}`].__merged_data[S]}})}return{existing_attributes:c,joined_length:E?E.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new hp(this.columns);for(let{node:i}of s)if(i&&i.columnid){let o=this._findColumn(i);if(o){let c=o.table.as?o.table.as:o.table.tableid;(!t[c]||t[c].indexOf(o.attribute)<0)&&n.push(o)}}n=v_.uniqBy(n,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(n)}catch(i){throw Ue.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),Ue.error(i),new Error(Ws)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__merged_data,o=[];for(let d in i)o.push(i[d][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await Ql.getDataByHash(c),u=s.columns.length;for(let d=0,_=o.length;d<_;d++){let E=o[d],f=l.get(E);for(let h=0;h<u;h++){let T=s.columns[h],m=f[T]===void 0?null:f[T];this.data[n].__merged_data[E].push(m)}}}}catch(r){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getData."),Ue.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__merged_data)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,l=o.aggregatorid?o.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===l}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();Ue.trace(`Final SQL: ${s}`),n=await _n.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),Ue.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),Ue.error(s),new Error("There was a problem running the generated sql.")}return n}_translateUndefinedValues(t){try{let r=[];for(let n of t){let s=Object.create(null);Object.keys(n).forEach(i=>{n[i]===void 0?s[i]=null:s[i]=n[i]}),r.push(s)}return r}catch(r){return Ue.error(y7.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),Ue.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],u=new RegExp(`${l}.\`${o}\``,"g"),d=`${l}.[${c}]`;n=n.replace(u,d)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),u=`[${c}]`;n=n.replace(l,u)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await Ql.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]={...r[s]}),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw Ue.error("There was an error when processing this SQL operation. Check your logs"),Ue.error(o),new Error(Ws)}}return Object.values(Object.values(this.data)[0].__merged_data)}};Wv.exports=FR});var Vr=N((OOe,zv)=>{"use strict";var O7=WD();zv.exports={searchByConditions:I7,searchByHash:w7,searchByValue:C7,search:D7};var GR=Bn(),{transformReq:qR}=te(),N7=jv();async function I7(e){return qR(e),GR.searchByConditions(e)}a(I7,"searchByConditions");async function w7(e){qR(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of GR.searchByHash(e))r&&t.push(r);return t}a(w7,"searchByHash");async function C7(e){qR(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of GR.searchByValue(e))t.push(r);return t}a(C7,"searchByValue");function D7(e,t){try{let r=new O7(e);r.validate(),new N7(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(D7,"search")});var pp=N((IOe,Qv)=>{"use strict";var P7=Bn();Qv.exports={writeTransaction:L7};function L7(e,t,r){return P7.writeTransaction(e,t,r)}a(L7,"writeTransaction")});var e0=N((DOe,Zv)=>{"use strict";var M7=Vr(),U7=ls(),Jv=W(),v7=un(),COe=pp(),B7=require("clone"),VR=require("alasql"),H7=Ep(),Xv=require("util"),x7=Xv.promisify(U7.getTableSchema),k7=Xv.promisify(M7.search),F7=M(),$R=te();H7(VR);Zv.exports={update:q7};var G7="There was a problem performing this update. Please check the logs and try again.";async function q7({statement:e,hdb_user:t}){let r=await x7(e.table.databaseid,e.table.tableid),n=$7(e.columns);$R.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=B7(s),c=$R.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=VR.parse(l).statements[0],d=await k7(u),_=V7(n,d);return K7(o,_,t)}a(q7,"update");function $7(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=VR.compile(`SELECT ${r.expression.toString()} AS [${F7.FUNC_VAL}] FROM ?`)}),t}catch(t){throw Jv.error(t),new Error(G7)}}a($7,"createUpdateRecord");function V7(e,t){return $R.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(V7,"buildUpdateRecords");async function K7(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await v7.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){Jv.error(`Error delete new_attributes from update response: ${i}`)}return s}a(K7,"updateRecords")});var r0=N((UOe,t0)=>{var Y7=require("alasql"),W7=Vr(),j7=W(),z7=Bn(),YR=require("util"),KR=te(),Q7=M(),J7=ls(),LOe=pp(),MOe=un(),X7="record",Z7="successfully deleted",eee=YR.callbackify(see),tee=YR.promisify(W7.search),ree=YR.promisify(J7.getTableSchema);t0.exports={convertDelete:eee};function nee(e){return`${e.deleted_hashes.length} ${X7}${e.deleted_hashes.length===1?"":"s"} ${Z7}`}a(nee,"generateReturnMessage");async function see({statement:e,hdb_user:t}){let r=await ree(e.table.databaseid,e.table.tableid);KR.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=KR.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=Y7.parse(o).statements[0],l={operation:Q7.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await tee(c);let u=await z7.deleteRecords(l);return KR.isEmptyOrZeroLength(u.message)&&(u.message=nee(u)),delete u.txn_time,u}catch(u){throw j7.error(u),u.hdb_code?u.message:u}}a(see,"convertDelete")});var a0=N((BOe,o0)=>{"use strict";var iee=ro(),{hdb_errors:n0}=_e(),{getDatabases:s0}=(Pe(),oe(lt));o0.exports={checkSchemaExists:i0,checkSchemaTableExists:oee,schema_describe:iee};async function i0(e){if(!s0()[e])return n0.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(i0,"checkSchemaExists");async function oee(e,t){let r=await i0(e);if(r)return r;if(!s0()[e][t])return n0.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(oee,"checkSchemaTableExists")});var Jl=N((xOe,aee)=>{aee.exports={name:"harperdb",version:"4.4.18",description:"HarperDB is a distributed database, caching service, streaming broker, and application development platform focused on performance and ease of use.",keywords:["database","nosql","api","distributed","broker","mqtt","real-time","enterprise","Fastify","NATS","HarperDB","Harper","clustering","replication","REST","WebSockets","decentralized","server-sent events","document store"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{"minimum-node":"16.0.0","go-lang":"1.21.7","nats-server":"2.10.11"},exports:{".":"./index.js"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"SEE LICENSE IN LICENSE",scripts:{submodules:"git submodule update --init --recursive","cover:test":"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && nyc --no-clean --reporter=lcovonly npm run test:replication && nyc --no-clean --reporter=lcovonly npm run test:apitests && nyc --no-clean --reporter=lcovonly npm run test:resources && nyc --no-clean --reporter=lcovonly npm run test:logging && nyc --no-clean --reporter=lcovonly npm run test:upgrade && nyc --no-clean --reporter=lcovonly npm run test:nats && nyc --no-clean --reporter=lcovonly npm run test:cfserver && nyc --no-clean --reporter=lcovonly npm run test:hdbserver && nyc --no-clean --reporter=lcovonly npm run test:bin && nyc --no-clean --reporter=lcovonly npm run test:main && nyc --no-clean --reporter=lcovonly npm run test:security && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license",test:"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && npm run test:replication && npm run test:apitests && npm run test:resources && npm run test:logging && npm run test:upgrade && npm run test:nats && npm run test:cfserver && npm run test:hdbserver && npm run test:bin && npm run test:main && npm run test:security && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license","test:resources":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/resources/**/*.js' --config '../unitTests/.mocharc.json'","test:bin":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/bin/**/*.js' --config '../unitTests/.mocharc.json'","test:main":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","test:lmdbbridge":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --config '../unitTests/.mocharc.json'","test:lmdbutility":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --config '../unitTests/.mocharc.json'","test:hdbserver":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --config '../unitTests/.mocharc.json'","test:cfserver":"npm run submodules && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/fastifyRoutes/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","test:nats":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","test:upgrade":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --config '../unitTests/.mocharc.json'","test:apitests":"pm2 kill && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/apiTests/**/*-test.mjs' --config '../unitTests/.mocharc.json'","test:logging":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/logging/*.js' --config '../unitTests/.mocharc.json'","test:ci":" cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --retries 3 --config '../unitTests/.mocharc-main.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter","test:security":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/security/**/*.js' --config '../unitTests/.mocharc.json'","test:replication":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/replication/**/*.js' --config '../unitTests/.mocharc.json'","hdb-check":"./utility/devops/hdb-check.sh","download-prebuilds":"node ./utility/devops/build/download-prebuilds.js",prebuild:"date",postinstall:"node ./launchServiceScripts/launchInstallNATSServer.js",build_nats_dependency:"node ./utility/devops/nats/builder.js",coverage:"nyc --reporter=lcov npm test",format:"prettier .","format:fix":"npm run format -- --write",lint:"eslint .","lint:fix":"npm run lint -- --fix"},dependencies:{"@aws-sdk/client-s3":"3.717.0","@aws-sdk/lib-storage":"3.717.0","@endo/static-module-record":"^1.0.4","@fastify/autoload":"5.10.0","@fastify/compress":"~6.5.0","@fastify/cors":"~9.0.1","@fastify/static":"~7.0.4","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"4.1.10","cbor-x":"1.6.0",chalk:"4.1.2","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.2",fastify:"~4.29.0","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.10.0","gunzip-maybe":"1.4.2","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.12.2","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.7",jsonwebtoken:"9.0.2",lmdb:"3.2.2",lodash:"4.17.21",mathjs:"11.12.0",minimist:"1.2.8",moment:"2.30.1","mqtt-packet":"~9.0.0",msgpackr:"1.11.2",nats:"2.19.0",needle:"3.3.1","node-forge":"^1.3.1","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.3",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.4.1",prompt:"1.3.0","properties-reader":"2.3.0","recursive-iterator":"3.3.0",semver:"7.5.4",send:"^1.1.0","serve-static":"2.1.0",ses:"1.1.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.24.5","tar-fs":"3.0.6",ulidx:"0.5.0",uuid:"10.0.0","validate.js":"0.13.1",ws:"8.18.0",yaml:"2.7.0"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"20.14.8","@typescript-eslint/eslint-plugin":"^7.18.0","@typescript-eslint/parser":"^7.18.0",axios:"1.7.5",chai:"4.4.1","chai-integer":"0.1.0",esbuild:"^0.24.2",eslint:"^9.17.0","eslint-config-prettier":"^9.1.0","eslint-plugin-sonarjs":"^3.0.1",eventsource:"^2.0.2","graphql-http":"^1.22.3","hook-std":"3.0.0","intercept-stdout":"0.1.2",mkcert:"1.5.1",mocha:"^11.0.1","mocha-teamcity-reporter":"^4.2.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.8",newman:"6.1.3","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"3.3.3",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0","source-map-support":"^0.5.21",typescript:"^5.7.2",undici:"^6.19.8","why-is-node-still-running":"^1.0.0"},overrides:{alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","segfault-handler":"^1.3.0","utf-8-validate":"^5.0.10"}}});var F_={};je(F_,{addAnalyticsListener:()=>k_,recordAction:()=>pr,recordActionBinary:()=>qn,setAnalyticsEnabled:()=>cee});function cee(e){p0=e}function pr(e,t,r,n,s){if(!p0)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=Tp.get(i);if(o)if(typeof e=="number"){let c=o.values,l=c.index++;if(l>=c.length){let u=c;o.values=c=new Float32Array(l*2),c.set(u),c.index=l+1}c[l]=e,o.total+=e}else if(typeof e=="boolean")e&&o.total++,o.count++;else if(typeof e=="function")o.count++;else throw new TypeError("Invalid metric value type "+typeof e);else{if(typeof e=="number")o={total:e,values:new Float32Array(4)},o.values.index=1,o.values[0]=e,o.total=e;else if(typeof e=="boolean")o={},o.total=e?1:0,o.count=1;else if(typeof e=="function")o={},o.count=1,o.callback=e;else throw new TypeError("Invalid metric value type "+typeof e);o.description={metric:t,path:r,method:n,type:s},Tp.set(i,o)}mp||lee()}function qn(e,t,r,n,s){pr(!!e,t,r,n,s)}function k_(e){T0.push(e)}function lee(){mp=performance.now(),setTimeout(async()=>{let e=performance.now()-mp;mp=0;let t=[],r={time:Date.now(),period:e,threadId:Tc.threadId,metrics:t};for(let[s,i]of Tp){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,u=[],d;for(let _ of g0){let E=Math.floor(c*_),f=o[E-1];if(E>l){let h=E-l;if(f===d){let T=u[u.length-1];typeof T=="number"?u[u.length-1]={value:T,count:1+h}:T.count+=h}else u.push(h>1?{value:f,count:h}:f),d=f;l=E}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:u,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await A0()}let n=process.memoryUsage();t.push({metric:"memory",threadId:Tc.threadId,byThread:!0,...n});for(let s of T0)s(t);Tp=new Map,Tc.parentPort?Tc.parentPort.postMessage({type:S0,report:r}):b0({report:r})},m0).unref()}async function uee(e,t=6e4){let r=zR(),n=R0(),s=new Promise(T=>{let m=performance.now();setImmediate(()=>{let g=performance.now();g-m>5e3&&(0,B_.warn)("Unusually high event queue latency on the main thread of "+Math.round(g-m)+"ms"),m=performance.now()}),n.primaryStore.prefetch([1],()=>{let g=performance.now();g-m>5e3&&(0,B_.warn)("Unusually high task queue latency on the main thread of "+Math.round(g-m)+"ms"),T(g-m)})}),i;for(let T of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(T.value?.time){i=T.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,u=[],d;for(let{key:T,value:m}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!m)continue;if(o){if(T>o+t)break}else o=T;d=T;let{metrics:g,threadId:S}=m;for(let b of g||[]){let{path:I,method:B,type:H,metric:X,count:Y,total:V,distribution:ne,threads:Q,...de}=b;Y||(Y=1);let j=X+(I?"-"+I:"");B!==void 0&&(j+="-"+B),H!==void 0&&(j+="-"+H);let ae=c.get(j);if(ae){if(ae.threads){let Oe=ae.threads[S];if(Oe)ae=Oe;else{ae.threads[S]={...de};continue}}ae.count||(ae.count=1);let be=ae.count;for(let Oe in de){let Me=de[Oe];typeof Me=="number"&&(ae[Oe]=(ae[Oe]*be+Me*Y)/(be+Y))}ae.count+=Y,V>=0&&(ae.total+=V,ae.ratio=ae.total/ae.count)}else ae={period:t,...b},delete ae.distribution,c.set(j,ae),ae.byThread&&(ae.threads=[],ae.threads[S]={...de},u.push(ae));if(ne){ne=ne.map(Oe=>typeof Oe=="number"?{value:Oe,count:1}:Oe);let be=l.get(j);be?be.push(...ne):l.set(j,ne)}}await A0()}for(let T of u){let{path:m,method:g,type:S,metric:b,count:I,total:B,distribution:H,threads:X,...Y}=T;X=X.filter(V=>V);for(let V in Y){if(typeof T[V]!="number")continue;let ne=0;for(let Q of X){let de=Q[V];typeof de=="number"&&(ne+=de)}T[V]=ne}T.count=X.length,delete T.threads,delete T.byThread}for(let[T,m]of l){let g=c.get(T);m.sort((Oe,Me)=>Oe.value>Me.value?1:-1);let S=g.count-1,b=[],I=0,B=0,H;for(let Oe of g0){let Me=S*Oe;for(;I<Me;)H=m[B++],I+=H.count,B===1&&I--;let Gr=m[B>1?B-2:0];H||(H=m[0]),b.push(H.value-(H.value-Gr.value)*(I-Me)/H.count)}let[X,Y,V,ne,Q,de,j,ae,be]=b;Object.assign(g,{p1:X,p10:Y,p25:V,median:ne,p75:Q,p90:de,p95:j,p99:ae,p999:be})}let _;for(let[T,m]of c)m.id=(0,Sp.getNextMonotonicTime)(),m.time=d,n.primaryStore.put(m.id,m,{append:!0}).then(g=>{g||n.primaryStore.put(m.id,m)}),_=!0;let E=Date.now(),{idle:f,active:h}=performance.eventLoopUtilization();if(_||h*10>f){let T=(0,Sp.getNextMonotonicTime)(),m={id:T,metric:"main-thread-utilization",idle:f-c0,active:h-l0,taskQueueLatency:await s,time:E,...process.memoryUsage()};n.primaryStore.put(T,m,{append:!0}).then(g=>{g||n.primaryStore.put(T,m)})}c0=f,l0=h}async function u0(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function zR(){return d0||(d0=Et({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function R0(){return _0||(_0=Et({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function fee(){y0=!0;let e=(0,x_.get)(jR.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await uee(m0,e),await u0(zR(),dee),await u0(R0(),_ee)},Math.min(e/2,2147483647)).unref()}function b0(e,t){let r=e.report;r.threadId=t?.threadId||Tc.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(f0+=n.mean*n.count);r.totalBytesProcessed=f0,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(E0.get(t))}),E0.set(t,t.performance.eventLoopUtilization())),r.id=(0,Sp.getNextMonotonicTime)(),zR().primaryStore.put(r.id,r),y0||fee(),Eee&&(O0=pee(r))}async function pee(e){if(await O0,!Zo){let r=(0,H_.dirname)((0,B_.getLogFilePath)());try{Zo=await(0,WR.open)((0,H_.join)(r,"analytics.log"),"r+")}catch{Zo=await(0,WR.open)((0,H_.join)(r,"analytics.log"),"w+")}}let t=(await Zo.stat()).size;if(t>hee){let r=Buffer.alloc(t);await Zo.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Zo.write(r,{position:0}),await Zo.truncate(r.length),t=r.length}await Zo.write(JSON.stringify(e)+`
12
+ `,t)}var Tc,h0,B_,H_,WR,Sp,x_,jR,Tp,p0,mp,m0,S0,T0,g0,c0,l0,A0,dee,_ee,d0,_0,y0,f0,E0,Eee,O0,Zo,hee,Ni=Ie(()=>{Tc=require("worker_threads"),h0=L(dt());Pe();B_=L(W()),H_=require("path"),WR=require("fs/promises"),Sp=L(cn()),x_=L(se()),jR=L(M());qr();(0,x_.initSync)();Tp=new Map,p0=(0,x_.get)(jR.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)>-1;a(cee,"setAnalyticsEnabled");a(pr,"recordAction");it.recordAnalytics=pr;a(qn,"recordActionBinary");mp=0,m0=1e3,S0="analytics-report",T0=[];a(k_,"addAnalyticsListener");g0=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(lee,"sendAnalytics");a(uee,"aggregation");c0=0,l0=0,A0=a(()=>new Promise(setImmediate),"rest");a(u0,"cleanup");dee=36e5,_ee=31536e6;a(zR,"getRawAnalyticsTable");a(R0,"getAnalyticsTable");(0,h0.setChildListenerByType)(S0,b0);a(fee,"startScheduledTasks");f0=0,E0=new Map,Eee=!1;a(b0,"recordAnalytics");hee=1e6;a(pee,"logAnalytics")});var ey=N((JOe,H0)=>{"use strict";var{decode:mee}=require("msgpackr"),{isMainThread:jOe,parentPort:zOe,threadId:QOe}=require("worker_threads"),Rp=mr(),Xl=Ct(),XR=M(),jr=W(),JR=se(),See=M(),{onMessageByType:Tee}=dt(),C0=to(),{recordAction:N0,recordActionBinary:gee}=(Ni(),oe(F_)),{publishToStream:Aee}=Rp,{ConsumerEvents:I0}=require("nats"),Ree=Vr(),{promisify:yee}=require("util"),D0=yee(setTimeout),yp=1e4,bp,Ap,bee,Oee,P0,G_=new Map,Zl=new Map;H0.exports={initialize:L0,ingestConsumer:ZR,setSubscription:Nee,setIgnoreOrigin:Cee,getDatabaseSubscriptions:wee,updateConsumer:M0};async function L0(){Tee(XR.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await M0(n)}),P0=!0,jr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await Rp.getNATSReferences();bp=e,Ap=e.info.server_name,bee=t,Oee=r}a(L0,"initialize");async function M0(e){if(e.status==="start"){let{js:t,jsm:r}=await U0(e.node_domain_name);ZR(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=G_.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?.(),G_.set(e.stream_name+e.node_domain_name,"close")),Zl.get(e.node_domain_name)==="failed"&&Zl.set(e.node_domain_name,"close")}}a(M0,"updateConsumer");var Op=new Map;function Nee(e,t,r){let n=Op.get(e);n||Op.set(e,n=new Map),n.set(t,r),P0||L0().then(Iee)}a(Nee,"setSubscription");async function Iee(){let e=await Ree.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+Xl.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions||[])if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await U0(r),!n))break;let{schema:o,table:c}=i,l=C0.createNatsTableStreamName(o,c);ZR(l,n,s,r)}}}a(Iee,"accessConsumers");async function U0(e){let t,r,n=1;for(;!r;)try{t=await bp.jetstream({domain:e}),r=await bp.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(Zl.get(e)==="close")break;Zl.set(e,"failed"),n%10===1&&jr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<yp?n++*100:yp;await D0(i)}return{js:t,jsm:r}}a(U0,"connectToRemoteJS");function wee(){return Op}a(wee,"getDatabaseSubscriptions");var v0;function Cee(e){v0=e}a(Cee,"setIgnoreOrigin");var B0=100,w0=new Array(B0),gp=0;async function ZR(e,t,r,n){let{connection:s}=await Rp.getNATSReferences();bp=s,Ap=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,Ap),jr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(Zl.get(n)==="close")break;o%10===1&&jr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",u.message),u.code==="404"&&(jr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await Rp.createConsumer(r,e,Ap,new Date(Date.now()).toISOString()));let d=o++*100<yp?o++*100:yp;await D0(d)}let c=!1,l;for(;!c;){if(G_.get(e+n)==="close"||Zl.get(n)==="close"){G_.delete(e+n),c=!0;continue}l=await i.consume({max_messages:JR.get(XR.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),G_.set(e+n,l);let u=!1;(async()=>{for await(let d of await l.status())if(d.type===I0.ConsumerDeleted&&(await l.close(),c=!0),d.type===I0.HeartbeatsMissed){let _=d.data;jr.trace(`${_} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),_===100&&(jr.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${l.consumer.stream}`),l.stop(),u=!0)}})();try{for await(let d of l)await w0[gp],w0[gp]=Dee(d).catch(_=>{jr.error(_)}),++gp>=B0&&(gp=0)}catch(d){d.message==="consumer deleted"?(jr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):jr.error("Error consuming clustering ingest, restarting consumer",d)}}}a(ZR,"ingestConsumer");async function Dee(e){let t=mee(e.data);N0(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),jr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=JR.get(XR.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(Xl.MSG_HEADERS.TRANSACTED_NODES)&&r.values(Xl.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(Xl.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!v0),gee(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(Xl.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:u,records:d,hash_values:_,__origin:E,expiresAt:f}=t;jr.trace("processing message:",o,c,u,(d?"records: "+d.map(B=>B?.id):"")+(_?"ids: "+_:""),"with sequence:",e.seq),jr.trace(`messageProcessor nats msg id: ${e.headers.get(Xl.MSG_HEADERS.NATS_MSG_ID)}`);let h;d||(d=_);let T=new Promise(B=>h=B),{timestamp:m,user:g,node_name:S}=E||{},b=Op.get(c)?.get(u);if(!b)throw new Error(`Missing table for replication message: ${u}`);if(o==="define_schema")t.type=o,t.onCommit=h,b.send(t);else if(d.length===1&&!l)b.send({type:QR(o),value:d[0],id:_?.[0],expiresAt:f,timestamp:m,table:u,onCommit:h,user:g,nodeName:S});else{let B=d.map((H,X)=>({type:QR(o),value:H,expiresAt:f,id:_?.[X],table:u}));for(;l;)B.push({type:QR(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;b.send({type:"transaction",writes:B,table:u,timestamp:m,onCommit:h,user:g,nodeName:S})}JR.get(See.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&Aee(e.subject.split(".").slice(0,-1).join("."),C0.createNatsTableStreamName(c,u),e.headers,e.data),await T;let I=Date.now()-m;m&&N0(I,"replication-latency",e.subject,o,"ingest")}catch(o){jr.error(o)}e.ack()}a(Dee,"messageProcessor");function QR(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(QR,"convertOperation")});var mr=N((sNe,eB)=>{"use strict";var br=se();br.initSync();var Pee=require("fs-extra"),Lee=require("semver"),V_=require("path"),{monotonicFactory:Mee}=require("ulidx"),k0=Mee(),Uee=require("util"),F0=require("child_process"),vee=Uee.promisify(F0.exec),Bee=F0.spawn,Dr=Ct(),Je=M(),Np=te(),js=W(),Ip=to(),Hee=pp(),q_=wt(),{broadcast:xee,onMessageByType:kee,getWorkerIndex:Fee}=dt(),{isMainThread:G0}=require("worker_threads"),{Encoder:Gee,decode:sy}=require("msgpackr"),q0=new Gee,{isEmpty:yc}=Np,$0=xn(),ZOe=48*36e11;G0&&kee(Je.ITC_EVENT_TYPES.RESTART,()=>{zr=void 0,Rc=void 0});var{connect:qee,StorageType:$ee,RetentionPolicy:Vee,AckPolicy:iy,DeliverPolicy:oy,DiscardPolicy:Kee,NatsConnection:eNe,JetStreamManager:tNe,JetStreamClient:rNe,StringCodec:nNe,JSONCodec:Yee,createInbox:ay,headers:Wee,ErrorCode:x0}=require("nats"),{PACKAGE_ROOT:jee}=M(),zee=Jl(),{recordAction:Qee}=(Ni(),oe(F_)),V0=Yee(),Jee="clustering",Xee=zee.engines[Dr.NATS_SERVER_NAME],Zee=V_.join(jee,"dependencies"),ny=V_.join(Zee,`${process.platform}-${process.arch}`,Dr.NATS_BINARY_NAME),ty,ry,$_,gc,Ac;eB.exports={runCommand:K0,checkNATSServerInstalled:ete,createConnection:cy,getConnection:K_,getJetStreamManager:Y_,getJetStream:W0,getNATSReferences:Ii,getServerList:rte,createLocalStream:ly,listStreams:j0,deleteLocalStream:nte,getServerConfig:eu,listRemoteStreams:ste,viewStream:ite,viewStreamIterator:ote,publishToStream:ate,request:ute,reloadNATS:uy,reloadNATSHub:dte,reloadNATSLeaf:_te,extractServerName:lte,requestErrorHandler:fte,createLocalTableStream:X0,createTableStreams:pte,purgeTableStream:Z0,purgeSchemaTableStreams:mte,getStreamInfo:Ste,updateLocalStreams:gte,closeConnection:tte,getJsmServerName:wp,addNatsMsgHeader:z0,clearClientCache:Y0,updateRemoteConsumer:Ete,createConsumer:Q0,updateConsumerIterator:hte};async function K0(e,t=void 0){let{stdout:r,stderr:n}=await vee(e,{cwd:t});if(n)throw new Error(n.replace(`
13
13
  `,""));return r.replace(`
14
- `,"")}a(V0,"runCommand");async function Jee(){try{await wee.access(ny)}catch{return!1}let e=await V0(`${ny} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return Cee.eq(t,zee)}a(Jee,"checkNATSServerInstalled");async function cy(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await q0.getClusterUser();if(yc(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}js.trace("create nats connection called");let i=await kee({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:br.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:br.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:br.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),js.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&js.error("Error with Nats client connection, connection closed",o),i===zr&&K0()}),i}a(cy,"createConnection");function K0(){zr=void 0,gc=void 0,Rc=void 0,Ac=void 0}a(K0,"clearClientCache");async function Xee(){zr&&(await zr.drain(),zr=void 0,gc=void 0,Rc=void 0,Ac=void 0)}a(Xee,"closeConnection");var zr,Ac;async function V_(){return Ac||(Ac=cy(br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),zr=await Ac),zr||Ac}a(V_,"getConnection");async function K_(){if(gc)return gc;yc(zr)&&await V_();let{domain:e}=Jl(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(yc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return gc=await zr.jetstreamManager({domain:e,timeout:6e4}),gc}a(K_,"getJetStreamManager");async function Y0(){if(Rc)return Rc;yc(zr)&&await V_();let{domain:e}=Jl(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(yc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Rc=zr.jetstream({domain:e,timeout:6e4}),Rc}a(Y0,"getJetStream");async function Ii(){let e=zr||await V_(),t=gc||await K_(),r=Rc||await Y0();return{connection:e,jsm:t,js:r}}a(Ii,"getNATSReferences");async function Zee(e){let t=br.get(Je.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await q0.getClusterUser(),s=await cy(t,r,n),i=ay(),o=s.subscribe(i),c=[],l,u=(async()=>{for await(let d of o){let _=$0.decode(d.data);_.response_time=Date.now()-l,c.push(_)}})();return l=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await Np.async_set_timeout(e),await o.drain(),await s.close(),await u,c}a(Zee,"getServerList");async function ly(e,t){let{jsm:r}=await Ii(),n=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:Fee.File,retention:Gee.Limits,subjects:t,discard:qee.Old,max_msgs:s,max_bytes:i,max_age:n})}a(ly,"createLocalStream");async function W0(){let{jsm:e}=await Ii(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(W0,"listStreams");async function ete(e){let{jsm:t}=await Ii();await t.streams.delete(e)}a(ete,"deleteLocalStream");async function tte(e){let{connection:t}=await Ii(),r=[],n=ay(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push($0.decode(o.data))})();return await t.publish(`$JS.${e}.API.STREAM.LIST`,void 0,{reply:n}),await t.flush(),await s.drain(),await i,r}a(tte,"listRemoteStreams");async function rte(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ii(),i=x0(),o={durable_name:i,ack_policy:iy.Explicit};t&&(o.deliver_policy=oy.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let u=[];for await(let d of l){let _=sy(d.data),E={nats_timestamp:d.info.timestampNanos,nats_sequence:d.info.streamSequence,entry:_};if(d.headers&&(E.origin=d.headers.get(Dr.MSG_HEADERS.ORIGIN)),u.push(E),d.ack(),d.info.pending===0)break}return await c.delete(),u}a(rte,"viewStream");async function*nte(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ii(),i=x0(),o={durable_name:i,ack_policy:iy.Explicit};t&&(o.deliver_policy=oy.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let u of l){let d=sy(u.data);d[0]||(d=[d]);for(let _ of d){let E={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:_};u.headers&&(E.origin=u.headers.get(Dr.MSG_HEADERS.ORIGIN)),yield E}if(u.ack(),u.info.pending===0)break}await c.delete()}a(nte,"viewStreamIterator");async function ste(e,t,r,n){js.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=j0(n,r);let{js:s}=await Ii(),i=await wp(),o=`${e}.${i}`,c=n instanceof Uint8Array?n:G0.encode(n);try{js.trace(`publishToStream publishing to subject: ${o}`),Wee(c.length,"bytes-sent",e,n.operation,"replication"),await s.publish(o,c,{headers:r})}catch(l){if(l.code&&l.code.toString()==="503")return Q0(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){js.trace(`publishToStream creating stream: ${t}`);let d=o.split(".");d[2]="*",await ly(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(ste,"publishToStream");function j0(e,t){t===void 0&&(t=Vee());let r=br.get(Je.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Dr.MSG_HEADERS.ORIGIN)&&r&&t.append(Dr.MSG_HEADERS.ORIGIN,r),t}a(j0,"addNatsMsgHeader");function Jl(e){e=e.toLowerCase();let t=$_.join(br.get(Je.CONFIG_PARAMS.ROOTPATH),jee);if(e===Je.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return yc(ry)&&(ry={port:G_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:G_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Dr.SERVER_SUFFIX.HUB,config_file:Dr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:$_.join(t,Dr.PID_FILES.HUB),hdb_nats_path:t}),ry;if(e===Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return yc(ty)&&(ty={port:G_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:G_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Dr.SERVER_SUFFIX.LEAF,config_file:Dr.NATS_CONFIG_FILES.LEAF_SERVER,domain:G_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Dr.SERVER_SUFFIX.LEAF,pid_file_path:$_.join(t,Dr.PID_FILES.LEAF),hdb_nats_path:t}),ty;js.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(Jl,"getServerConfig");async function z0(e,t,r,n){try{await e.consumers.add(t,{ack_policy:iy.Explicit,durable_name:r,deliver_policy:oy.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(z0,"createConsumer");async function ite(e,t,r){await e.consumers.delete(t,r)}a(ite,"removeConsumer");function ote(e){return e.split(".")[1]}a(ote,"extractServerName");async function ate(e,t,r=6e4,n=ay()){if(!Np.isObject(t))throw new Error("data param must be an object");let s=G0.encode(t),{connection:i}=await Ii(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return sy(c.data)}a(ate,"request");function uy(e){return new Promise(async(t,r)=>{let n=Mee(ny,["--signal",`reload=${e}`],{cwd:__dirname}),s,i;n.on("error",o=>{r(o)}),n.stdout.on("data",o=>{i+=o.toString()}),n.stderr.on("data",o=>{s+=o.toString()}),n.stderr.on("close",o=>{s&&r(s),t(i)})})}a(uy,"reloadNATS");async function cte(){let{pid_file_path:e}=Jl(Je.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await uy(e)}a(cte,"reloadNATSHub");async function lte(){let{pid_file_path:e}=Jl(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await uy(e)}a(lte,"reloadNATSLeaf");function ute(e,t,r){let n;switch(e.code){case H0.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case H0.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(ute,"requestErrorHandler");async function dte(e,t){let r=t+Dr.SERVER_SUFFIX.LEAF,{connection:n}=await Ii(),{jsm:s}=await Tte(r),{schema:i,table:o}=e,c=Ip.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await Q0(async()=>{if(e.subscribe===!0)await z0(s,c,n.info.server_name,l);else try{await ite(s,c,n.info.server_name)}catch(u){js.trace(u)}})}a(dte,"updateRemoteConsumer");async function _te(e,t,r,n){let s=Ip.createNatsTableStreamName(e,t),i=r+Dr.SERVER_SUFFIX.LEAF,o={type:Je.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!F0&&Hee()<br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=ey();await c(o)}await vee(o),n==="stop"&&await Np.async_set_timeout(1e3)}a(_te,"updateConsumerIterator");function Q0(e){return Uee.writeTransaction(Je.SYSTEM_SCHEMA_NAME,Je.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(Q0,"exclusiveLock");async function J0(e,t){let r=Ip.createNatsTableStreamName(e,t),n=await wp(),s=pte(e,t,n);await ly(r,[s])}a(J0,"createLocalTableStream");async function fte(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await J0(n,s)}}a(fte,"createTableStreams");async function X0(e,t,r=void 0){if(br.get(Je.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=Ip.createNatsTableStreamName(e,t),{domain:s}=Jl(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await V_()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")js.warn(n);else throw n}}a(X0,"purgeTableStream");async function Ete(e,t){if(br.get(Je.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await X0(e,t[r])}a(Ete,"purgeSchemaTableStreams");async function hte(e){return(await K_()).streams.info(e)}a(hte,"getStreamInfo");function pte(e,t,r){return`${Dr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(pte,"createSubjectName");async function wp(){if(q_)return q_;if(q_=(await K_())?.nc?.info?.server_name,q_===void 0)throw new Error("Unable to get jetstream manager server name");return q_}a(wp,"getJsmServerName");async function mte(){let e=await K_(),t=await wp(),r=await W0();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=Ste(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let u=i.split(".");u[u.length-1]=t;let d=u.join(".");js.trace(`Updating stream subject name from: ${i} to: ${d}`),s.subjects[0]=d,await e.streams.update(s.name,s)}}a(mte,"updateLocalStreams");function Ste(e){let{config:t}=e,r=!1,n=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}a(Ste,"updateStreamLimits");async function Tte(e){let t,r;try{t=await zr.jetstream({domain:e}),r=await zr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw js.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(Tte,"connectToRemoteJS")});var bc=N(Dp=>{var Cp=W();for(let e of["trace","debug","info","warn","error","fatal","notify"])Cp.logsAtLevel(e)&&(Dp[e]=Cp[e]);Dp.loggerWithTag=e=>Cp.loggerWithTag(e,!0);Dp.setLogLevel=Cp.setLogLevel});function dy(e){let t=e.get(Pp),r=t?(0,Xl.unpack)(t):null;r||(r={remoteNameToId:{}});let n=ot(),s=!1;r.nodeName=ot();let i=r.remoteNameToId;if(i[n]!==0){let o=0,c;for(let l in i){let u=i[l];u===0?c=l:u>o&&(o=u)}if(c){o++,i[c]=o;let l=[Symbol.for("seq"),o];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:W_(e)??1,nodes:[]})})}i[n]=0,e.putSync(Pp,(0,Xl.pack)(r))}return r}function Y_(e){return dy(e).remoteNameToId}function tB(e,t,r){let n=dy(r),s=n.remoteNameToId,i=new Map,o=!1;for(let c in t){let l=t[c],u=s[c];if(u==null){let d=0;for(let _ in s){let E=s[_];E>d&&(d=E)}u=d+1,s[c]=u,o=!0}i.set(l,u)}return o&&r.putSync(Pp,(0,Xl.pack)(n)),i}function Lp(e,t){let r=dy(t),n=r.remoteNameToId,s=n[e];if(s==null){let i=0;for(let o in n){let c=n[o];c>i&&(i=c)}s=i+1,n[e]=s,t.putSync(Pp,(0,Xl.pack)(r))}return eB.info?.("The remote node name map",e,n,s),s}var eB,Xl,Pp,_y=Oe(()=>{eB=L(bc());us();Xl=require("msgpackr"),Pp=Symbol.for("remote-ids");a(dy,"getIdMappingRecord");a(Y_,"exportIdMapping");a(tB,"remoteToLocalNodeId");a(Lp,"getIdOfRemoteNode")});var ta,fy=Oe(()=>{ta=class{constructor(t){this.error=t}static{a(this,"ErrorResource")}isError=!0;allowRead(){throw this.error}allowUpdate(){throw this.error}allowCreate(){throw this.error}allowDelete(){throw this.error}getId(){throw this.error}getContext(){throw this.error}get(){throw this.error}post(){throw this.error}put(){throw this.error}delete(){throw this.error}connect(){throw this.error}getResource(){return this}publish(){throw this.error}subscribe(){throw this.error}}});var sB={};je(sB,{Resources:()=>Mp,keyArrayToString:()=>Zl,resetResources:()=>gte,resources:()=>wi});function gte(){return wi=new Mp}function Zl(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var rB,nB,Mp,wi,eu=Oe(()=>{mc();fy();rB=L(W()),nB=L(_e()),Mp=class extends Map{static{a(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,exportTypes:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s){let c=new nB.ServerError(`Conflicting paths for ${t}`);rB.default.error(c),i.Resource=new ta(c)}super.set(t,i);for(let[c,l]of this){let u=2;for(;(u=c.indexOf("/",u))>-1;){let d=this.get(c.slice(0,u));d&&(d.hasSubPaths=!0),u+=2}}}getMatch(t,r){let n=2,s;for(;(n=t.indexOf("/",n))>-1;){let c=t.slice(0,n),l=this.get(c);if(!l&&c.indexOf(".")>-1){let u=c.split(".");l=this.get(u[0])}if(l&&(!r||l.exportTypes?.[r]!==!1)){if(l.relativeURL=t.slice(n),!l.hasSubPaths)return l;s=l}n+=2}if(s)return s;let i=t.indexOf("?"),o=i>-1?t.slice(0,i):t;return s=this.get(o),!s&&o.indexOf(".")>-1&&(s=this.get(o.split(".")[0])),s&&(!r||s.exportTypes?.[r]!==!1)?s.relativeURL=i>-1?t.slice(i):"":s||(s=this.get(""),s&&(!r||s.exportTypes?.[r]!==!1)&&(t[0]!=="/"&&(t="/"+t),s.relativeURL=t)),s}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return Dt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(gte,"resetResources");a(Zl,"keyArrayToString")});function py(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=oB,Rte(e.primaryStore,e.auditStore)):(c=iB,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{aB(iB[i])})));let l=c[i]||(c[i]=[]);if(l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now()),s?.scope==="full-database")return;let u=l[o];u||(u=l[o]=new Map,u.envs=l,u.tableId=o,u.store=e.primaryStore),t=Zl(t);let d=new hy(r);d.startTime=n;let _=u.get(t);return _?_.push(d):(u.set(t,_=[d]),_.tables=u,_.key=t),d.subscriptions=_,d}function aB(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),cB(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=Ht(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,l=Zl(c),u=0;do{let d=o.get(l);if(d){for(let E of d)if(!(u>0&&!(E.includeDescendants&&!(E.onlyChildren&&u>1)))){if(E.startTime>=n){(0,Ey.info)("omitting",c,E.startTime,n);continue}try{let f;E.supportsTransactions&&E.txnInProgress!==i.version&&(f=!0,E.txnInProgress||(r?r.push(E):r=[E]),E.txnInProgress=i.version),E.listener(c,i,n,f)}catch(f){console.error(f),(0,Ey.info)(f)}}}if(l==null)break;let _=l.lastIndexOf?.("/",l.length-2);_>-1?l=l.slice(0,_):l=null,u++}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function Rte(e,t){let r=t||e,n=r.env;if(!n.hasAfterCommitListener){n.hasAfterCommitListener=!0;let s=n.path;r.on("aftercommit",({next:i,last:o,txnId:c})=>{let l=oB[s];if(!l)return;let u=a(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),l.txnTime=r.threadLocalWrites[0]||Date.now();try{aB(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function cB(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function lB(e){return e.nextTransaction||(py({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),cB(e)),e.nextTransaction}var Ey,iB,oB,hy,my=Oe(()=>{Ey=L(W());wl();eu();Ji();iB=Object.create(null),oB=Object.create(null);a(py,"addSubscription");hy=class extends Mn{static{a(this,"Subscription")}listener;subscriptions;startTime;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;if(t){let r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};a(aB,"notifyFromTransactionData");a(Rte,"listenToCommits");a(cB,"nextTransaction");a(lB,"whenNextTransaction")});var hB={};je(hB,{commits_awaiting_replication:()=>nu,getHDBNodeTable:()=>Sr,iterateRoutes:()=>z_,shouldReplicateToNode:()=>j_,subscribeToNodeUpdates:()=>su});function Sr(){return uB||(uB=Et({table:"hdb_nodes",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"ca"},{attribute:"ca_info"},{attribute:"replicates"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function su(e){Sr().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;EB.debug?.("adding node",n,"on node",ot()," on process",process.pid),server.nodes=server.nodes.filter(s=>s.name!==n),r.type==="put"&&n!==ot()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r)),(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function j_(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&Sr().primaryStore.get(ot())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function Ate(){su(e=>{ra({},(t,r)=>{let n=e.name,s=dB.get(n);if(s||dB.set(n,s=new Map),s.has(r))return;let i;for(let o in t)if(i=t[o].auditStore,i)break;if(i){let o=new Float64Array(i.getUserSharedBuffer(["replicated",r,n],new ArrayBuffer(8),{callback:a(()=>{let c=o[0],l=o.lastTime;for(let{txnTime:u,onConfirm:d}of nu.get(r)||[])u>l&&u<=c&&d();o.lastTime=c},"callback")}));o.lastTime=0,s.set(r,o)}})})}function*z_(e){for(let t of e.routes||[]){let r=t.url,n;if(typeof t=="string"?t.includes("://")?r=t:n=t:n=t.hostname??t.host,n&&!r){let s=tu.default.get(ru.CONFIG_PARAMS.REPLICATION_SECUREPORT)??(!tu.default.get(ru.CONFIG_PARAMS.REPLICATION_PORT)&&tu.default.get(ru.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||tu.default.get(ru.CONFIG_PARAMS.REPLICATION_PORT)||tu.default.get(ru.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT);let o=i?.lastIndexOf?.(":");o>0&&(i=+i.slice(o+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){_B.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{replicates:!t.subscriptions,url:r,subscription:t.subscriptions,routes:t.routes}}}var _B,fB,tu,ru,EB,uB,dB,nu,iu=Oe(()=>{Pe();us();lp();_B=require("worker_threads"),fB=L(_e()),tu=L(se()),ru=L(M()),EB=L(bc());server.nodes=[];a(Sr,"getHDBNodeTable");a(su,"subscribeToNodeUpdates");a(j_,"shouldReplicateToNode");dB=new Map;Rv((e,t,r)=>{if(r>server.nodes.length)throw new fB.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);nu||(nu=new Map,Ate());let n=nu.get(e);return n||(n=[],nu.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(Ate,"startSubscriptionToReplications");a(z_,"iterateRoutes")});var gB={};je(gB,{connectedToNode:()=>Oc,disconnectedFromNode:()=>cu,ensureNode:()=>co,requestClusterStatus:()=>TB,startOnMainThread:()=>Ty});async function Ty(e){let t=0,r=ut();for(let i of Object.getOwnPropertyNames(r)){let o=r[i];for(let c in o){let l=o[c];if(l.auditStore){Up.set(i,W_(l.auditStore));break}}}Ci.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes.search([]))i.push(o);for(let o of z_(e))try{let c=!o.subscriptions;if(c){let u=ot();Sr().primaryStore.get(u)===void 0&&await co(u,{name:u,url:e.url??na(),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)}su(s)});let n;function s(i,o=i?.name){let c=ot()&&o===ot()||na()&&i?.url===na();if(c){let _=!!i?.replicates;if(n!==void 0&&n!==_)for(let E of Sr().search([]))E.replicates&&E.name!==o&&s(E,E.name);n=_}if(_t.trace("Setting up node replication for",i),!i){for(let[_,E]of ao){let f;for(let[h,{worker:T,nodes:m}]of E){let g=m[0];if(g&&g.name==o){f=!0;for(let[S,{worker:b}]of E)E.delete(S),_t.warn("Node was deleted, unsubscribing from node",o,S,_),b?.postMessage({type:"unsubscribe-from-node",node:o,database:S,url:_});break}}if(f){ao.get(_).iterator.remove(),ao.delete(_);return}}return}if(c)return;if(!i.url){_t.info(`Node ${i.name} is missing url`);return}let l=ao.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(_t.info(`Added node ${i.name} at ${i.url} for process ${ot()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[_,E]of ou)if(i.url===E.url){ou.delete(_);break}ou.set(i.name,i)}let u=ut();if(l||(l=new Map,ao.set(i.url,l)),l.iterator=ra(e,(_,E,f)=>{f?d(E,!0):d(E,!1)}),i.subscriptions)for(let _ of i.subscriptions){let E=_.database||_.schema;u[E]||(_t.warn(`Database ${E} not found for node ${i.name}, making a subscription anyway`),d(E,!1))}function d(_,E){_t.trace("Setting up replication for database",_,"on node",i.name);let f=l.get(_),h,T=[{replicateByDefault:E,...i}];Up.has(_)&&(T.push({replicateByDefault:E,name:ot(),start_time:Up.get(_),end_time:Date.now(),replicates:!0}),Up.delete(_));let m=j_(i,_),g=Ci.workers.filter(S=>S.name==="http");if(f?(h=f.worker,f.nodes=T):m&&(t=t%g.length,h=g[t++],l.set(_,{worker:h,nodes:T,url:i.url}),h?.on("exit",()=>{l.get(_)?.worker===h&&(l.delete(_),d(_,E))})),m)setTimeout(()=>{let S={type:"subscribe-to-node",database:_,nodes:T};h?h.postMessage(S):au(S)},yte);else{_t.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[_],Sr().primaryStore.get(ot())?.replicates),Sr().primaryStore.get(ot())?.replicates||(n=!1);let S={type:"unsubscribe-from-node",database:_,url:i.url,name:i.name};h?h.postMessage(S):Bp(S)}}a(d,"onDatabase")}a(s,"onNodeUpdate"),cu=a(function(i){try{_t.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(ou.keys()),c=o.sort(),l=c.indexOf(i.name||zs(i.url));if(l===-1){_t.warn("Disconnected node not found in node map",i.name,o);return}let u=ao.get(i.url),d=u?.get(i.database);if(!d){_t.warn("Disconnected node not found in replication map",i.database,u);return}if(d.connected=!1,i.finished)return;let _=d.nodes[0];if(!(_.replicates===!0||_.replicates?.sends||_.subscriptions?.length))return;let E=(l+1)%c.length;for(;l!==E;){let f=c[E],h=ou.get(f);u=ao.get(h.url);let T=u?.get(i.database);if(!T){E=(E+1)%c.length;continue}let{worker:m,nodes:g}=T,S=!1;for(let b of d.nodes){if(g.some(I=>I.name===b.name)){_t.info(`Disconnected node is already failing over to ${f} for ${i.database}`);continue}g.push(b),S=!0}if(!S){_t.info(`Disconnected node ${i.name} has no nodes to fail over to ${f}`);return}d.redirectingTo=T,_t.info(`Failing over ${i.database} from ${i.name} to ${f}`),m?m.postMessage({type:"subscribe-to-node",database:i.database,nodes:g}):au({database:i.database,nodes:g});return}_t.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){_t.error("Error failing over node",o)}},"disconnectedFromNode"),Oc=a(function(i){let o=ao.get(i.url),c=o?.get(i.database);if(!c){_t.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,o);return}if(c.connected=!0,c.latency=i.latency,c.catchingUpFrom=i.lastSendTime,c.redirectingTo){let{worker:l,nodes:u}=c.redirectingTo,d=u.find(_=>_.name===i.name);c.redirectingTo=null,d&&(u.splice(u.indexOf(d),1),l?l.postMessage({type:"subscribe-to-node",database:i.database,nodes:u}):au({database:i.database,nodes:u}))}},"connectedToNode"),(0,Ci.onMessageByType)("disconnected-from-node",cu),(0,Ci.onMessageByType)("connected-to-node",Oc),(0,Ci.onMessageByType)("request-cluster-status",TB)}function TB(e,t){let r=[];for(let[n,s]of ou)try{let i=ao.get(s.url);_t.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let o=[];if(i){for(let[l,{worker:u,connected:d,nodes:_,latency:E,catchingUpFrom:f}]of i)o.push({database:l,connected:d,latency:E,catching_up_from:f?new Date(f).toISOString():"up-to-date",thread_id:u?.threadId,nodes:_.map(h=>h.name)});let c=(0,Sy.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){_t.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function co(e,t){let r=Sr();e=e??zs(t.url),t.name=e;try{if(t.ca){let s=new SB.X509Certificate(t.ca);t.ca_info={issuer:s.issuer.replace(/\n/g," "),subject:s.subject.replace(/\n/g," "),subject_alt_name:s.subjectAltName,serial_number:s.serialNumber,valid_from:s.validFrom,valid_to:s.validTo}}}catch(s){_t.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(_t.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.put(t);else{t.replicates&&!pB.default.get(mB.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],o=(0,Sy.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let u of o)if((c.database??c.schema)===(u.database??u.schema)&&c.table===u.table){u.publish=c.publish,u.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...o,...i];break}_t.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Ci,vp,_t,Sy,pB,mB,SB,yte,ao,cu,Oc,ou,Up,Q_=Oe(()=>{Pe();Ci=L(dt());us();vp=require("worker_threads");iu();_t=L(W()),Sy=require("lodash"),pB=L(se()),mB=L(M()),SB=require("crypto"),yte=200,ao=new Map,ou=new Map,Up=new Map;a(Ty,"startOnMainThread");a(TB,"requestClusterStatus");vp.parentPort&&(cu=a(e=>{vp.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),Oc=a(e=>{vp.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Ci.onMessageByType)("subscribe-to-node",e=>{au(e)}),(0,Ci.onMessageByType)("unsubscribe-from-node",e=>{Bp(e)}));a(co,"ensureNode")});var Hp=N((wNe,RB)=>{"use strict";var bte=M().OPERATIONS_ENUM,gy=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=bte.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};RB.exports=gy});var yB=N((DNe,AB)=>{"use strict";var Ote={OPERATION:"operation",REFRESH:"refresh"},Ry=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},Ay=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};AB.exports={JWTTokens:Ry,TOKEN_TYPE_ENUM:Ote,JWTRSAKeys:Ay}});var lu=N((LNe,IB)=>{"use strict";var X_=require("jsonwebtoken"),yy=require("fs-extra"),by=te(),ds=M(),{handleHDBError:fn,hdb_errors:Nte}=_e(),{HTTP_STATUS_CODES:En,AUTHENTICATION_ERROR_MSGS:hn}=Nte,J_=W(),bB=Kh(),Iy=xn(),Ite=un().update,wte=Hp(),Cte=no(),{UserEventMsg:Dte}=qs(),sa=se();sa.initSync();var Oy=require("path"),{JWTTokens:Pte,JWTRSAKeys:Lte,TOKEN_TYPE_ENUM:xp}=yB(),Mte=sa.get(ds.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?sa.get(ds.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",Ute=sa.get(ds.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?sa.get(ds.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",kp="RS256",Ny;IB.exports={createTokens:vte,validateOperationToken:Hte,refreshOperationToken:Bte,validateRefreshToken:NB,getJWTRSAKeys:Z_};async function vte(e){if(by.isEmpty(e)||typeof e!="object")throw fn(new Error,hn.INVALID_AUTH_OBJECT,En.BAD_REQUEST,void 0,void 0,!0);if(by.isEmpty(e.username))throw fn(new Error,hn.USERNAME_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);if(by.isEmpty(e.password))throw fn(new Error,hn.PASSWORD_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await Iy.findAndValidateUser(e.username,e.password),!t)throw fn(new Error,hn.INVALID_CREDENTIALS,En.UNAUTHORIZED,void 0,void 0,!0)}catch(E){throw J_.error(E),fn(new Error,hn.INVALID_CREDENTIALS,En.UNAUTHORIZED,void 0,void 0,!0)}let r=await Z_(),n=!1,s=!1;t.role&&t.role.permission&&(n=t.role.permission.super_user===!0,s=t.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s},o=await OB(i,r.private_key,r.passphrase),c=await X_.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:Ute,algorithm:kp,subject:xp.REFRESH}),l=bB.hash(c),u=new wte(ds.SYSTEM_SCHEMA_NAME,ds.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:l}]),d,_;try{d=await Ite(u)}catch(E){J_.error(E),_=E}if(_!==void 0||d.skipped_hashes.length>0)throw fn(new Error,hn.REFRESH_TOKEN_SAVE_FAILED,En.INTERNAL_SERVER_ERROR);return Cte.signalUserChange(new Dte(process.pid)),new Pte(o,c)}a(vte,"createTokens");async function OB(e,t,r){return await X_.sign(e,{key:t,passphrase:r},{expiresIn:Mte,algorithm:kp,subject:xp.OPERATION})}a(OB,"signOperationToken");async function Z_(){if(Ny===void 0)try{let e=Oy.join(sa.getHdbBasePath(),ds.LICENSE_KEY_DIR_NAME,ds.JWT_ENUM.JWT_PASSPHRASE_NAME),t=Oy.join(sa.getHdbBasePath(),ds.LICENSE_KEY_DIR_NAME,ds.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=Oy.join(sa.getHdbBasePath(),ds.LICENSE_KEY_DIR_NAME,ds.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await yy.readFile(e)).toString(),s=(await yy.readFile(t)).toString(),i=(await yy.readFile(r)).toString();Ny=new Lte(i,s,n)}catch(e){throw J_.error(e),fn(new Error,hn.NO_ENCRYPTION_KEYS,En.INTERNAL_SERVER_ERROR)}return Ny}a(Z_,"getJWTRSAKeys");async function Bte(e){if(!e)throw fn(new Error,hn.INVALID_BODY,En.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw fn(new Error,hn.REFRESH_TOKEN_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);await NB(e.refresh_token);let t=await Z_(),r=await X_.decode(e.refresh_token);return{operation_token:await OB({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(Bte,"refreshOperationToken");async function Hte(e){try{let t=await Z_(),r=await X_.verify(e,t.public_key,{algorithms:kp,subject:xp.OPERATION});return await Iy.findAndValidateUser(r.username,void 0,!1)}catch(t){throw J_.warn(t),t.name&&t.name==="TokenExpiredError"?fn(new Error,hn.TOKEN_EXPIRED,En.FORBIDDEN):fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED)}}a(Hte,"validateOperationToken");async function NB(e){let t;try{let r=await Z_(),n=await X_.verify(e,r.public_key,{algorithms:kp,subject:xp.REFRESH});t=await Iy.findAndValidateUser(n.username,void 0,!1)}catch(r){throw J_.warn(r),r.name&&r.name==="TokenExpiredError"?fn(new Error,hn.TOKEN_EXPIRED,En.FORBIDDEN):fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED)}if(!bB.validate(t.refresh_token,e))throw fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED);return t}a(NB,"validateRefreshToken")});var Xs=N(XB=>{"use strict";var sr=require("path"),pn=require("fs-extra"),uu=require("node-forge"),UB=require("net"),{generateKeyPair:Cy,X509Certificate:uo,createPrivateKey:vB}=require("crypto"),xte=require("util");Cy=xte.promisify(Cy);var yt=uu.pki,Qs=require("joi"),{v4:BB}=require("uuid"),{validateBySchema:My}=Tt(),pt=W(),_s=se(),Es=M(),{CONFIG_PARAMS:du}=Es,Js=Sg(),{ClientError:ia}=_e(),Ic=require("node:tls"),{relative:HB,join:kte}=require("node:path"),{CERT_PREFERENCE_APP:UNe,CERTIFICATE_VALUES:wB}=Js,Fte=Wa(),Dy=wt(),CB=parseInt(process.version.slice(1))<20,{table:Gte,getDatabases:qte,databases:wy}=(Pe(),oe(lt)),{getJWTRSAKeys:DB}=lu();Object.assign(XB,{generateKeys:By,updateConfigCert:KB,createCsr:Qte,signCertificate:Jte,setCertTable:_u,loadCertificates:qB,reviewSelfSignedCert:xy,createTLSSelector:jB,listCertificates:QB,addCertificate:nre,removeCertificate:ire,createNatsCerts:ere,generateCertsKeys:Zte,getReplicationCert:tf,getReplicationCertAuth:zte,renewSelfSigned:tre,hostnamesFromCert:JB,getKey:ore});var{urlToNodeName:xB,getThisNodeUrl:$te,getThisNodeName:Gp,clearThisNodeName:Vte}=(us(),oe(ca)),{readFileSync:Kte,watchFile:Yte,statSync:kB}=require("node:fs"),vNe=se(),{getTicketKeys:Wte,onMessageFromWorkers:jte}=dt(),lo=W(),{isMainThread:FB}=require("worker_threads"),{TLSSocket:GB,createSecureContext:BNe}=require("node:tls"),Uy=3650,ef=["127.0.0.1","localhost","::1"],vy=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];jte(async e=>{e.type===Es.ITC_EVENT_TYPES.RESTART&&(_s.initSync(!0),await xy())});var Pr;function aa(){return Pr||(Pr=qte().system.hdb_certificate,Pr||(Pr=Gte({table:"hdb_certificate",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]}))),Pr}a(aa,"getCertTable");async function tf(){let e=jB("operations-api"),t={secureContexts:null,setSecureContext:a(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(Gp());if(!r)return;let n=new uo(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(tf,"getReplicationCert");async function zte(){aa();let e=(await tf()).options.cert,r=new uo(e).issuer.match(/CN=(.*)/)?.[1];return Pr.get(r)}a(zte,"getReplicationCertAuth");var PB,oa=new Map;function qB(){if(PB)return;PB=!0;let e=[{configKey:du.TLS},{configKey:du.OPERATIONSAPI_TLS}];aa();let t=sr.dirname(Dy.getConfigFilePath()),r;for(let{configKey:n}of e){let s=Dy.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&HB(kte(t,"keys"),o);c&&LB(o,l=>{oa.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&FB){let d;LB(u,_=>{if(wB.cert===_)return;let E=i.hostname??i.hostnames??i.host??i.hosts;E&&!Array.isArray(E)&&(E=[E]);let f=YB(u),h=new uo(f),T;try{T=ky(h)}catch(b){pt.error("error extracting common name from certificate",b);return}if(T==null){pt.error("error extracting common name from certificate");return}if(h.checkIssued(new uo(wB.cert)))return;let m=Pr.primaryStore.get(T),g=kB(u).mtimeMs,S=!m||m.is_self_signed?1:m.file_timestamp??m.__updatedtime__;if(m&&g<=S){g<S&&pt.info(`Certificate ${T} at ${u} is older (${new Date(g)}) than the certificate in the database (${S>1?new Date(S):"only self signed certificate available"})`);return}r=Pr.put({name:T,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:f,private_key_name:c,is_authority:l,hostnames:E,file_timestamp:g,details:{issuer:h.issuer.replace(/\n/g," "),subject:h.subject.replace(/\n/g," "),subject_alt_name:h.subjectAltName,serial_number:h.serialNumber,valid_from:h.validFrom,valid_to:h.validTo}})},l?"certificate authority":"certificate")}}}}}return r}a(qB,"loadCertificates");function LB(e,t,r){let n,s=a((i,o)=>{try{let c=i.mtimeMs;c&&c!==n&&(o&&FB&&pt.warn(`Reloading ${r}:`,e),n=c,t(YB(e)))}catch(c){pt.error(`Error loading ${r}:`,e,c)}},"loadFile");pn.existsSync(e)?s(kB(e)):pt.error(`${r} file not found:`,e),Yte(e,{persistent:!1},s)}a(LB,"loadAndWatch");function Py(){let e=$te();if(e==null){let t=ef[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return xB(e)}a(Py,"getHost");function Fp(){let e=Gp();if(e==null){let t=ef[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(Fp,"getCommonName");async function Qte(){let e=await tf(),t=yt.certificateFromPem(e.options.cert),r=yt.privateKeyFromPem(e.options.key);pt.info("Creating CSR with cert named:",e.name);let n=yt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:Fp()},...vy];pt.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:$B()}];return pt.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),uu.pki.certificationRequestToPem(n)}a(Qte,"createCsr");function $B(){let e=ef.includes(Fp())?ef:[...ef,Fp()];return e.includes(Py())||e.push(Py()),[{name:"basicConstraints",cA:!1,critical:!0},{name:"keyUsage",digitalSignature:!0,keyEncipherment:!0,critical:!0},{name:"extKeyUsage",serverAuth:!0,clientAuth:!0},{name:"nsCertType",client:!0,server:!0},{name:"subjectAltName",altNames:e.map(t=>UB.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a($B,"certExtensions");async function Jte(e){let t={},r=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;aa();for await(let d of Pr.search([]))if(d.is_authority&&!d.details.issuer.includes("HarperDB-Certificate-Authority")){if(oa.has(d.private_key_name)){n=oa.get(d.private_key_name),s=d;break}else if(d.private_key_name&&await pn.exists(sr.join(r,d.private_key_name))){n=pn.readFile(sr.join(r,d.private_key_name)),s=d;break}}if(!n){let d=await Ly();s=d.ca,n=d.private_key}n=yt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=yt.certificateFromPem(s.certificate);pt.info("Signing CSR with cert named",s.name);let o=yt.certificationRequestFromPem(e.csr);try{o.verify()}catch(d){return pt.error(d),new Error("Error verifying CSR: "+d.message)}let c=uu.pki.createCertificate();c.serialNumber=Math.random().toString().slice(2,10),c.validity.notBefore=new Date;let l=new Date;c.validity.notAfter=l,c.validity.notAfter.setDate(l.getDate()+Uy),pt.info("sign cert setting validity:",c.validity),pt.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),pt.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=o.getAttribute({name:"extensionRequest"}).extensions;pt.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=o.publicKey,c.sign(n,uu.md.sha256.create()),t.certificate=yt.certificateToPem(c)}else pt.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(Jte,"signCertificate");async function Xte(e,t){await _u({name:Gp(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await _u({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(Xte,"createCertificateTable");async function _u(e){let t=new uo(e.certificate);e.details={issuer:t.issuer.replace(/\n/g," "),subject:t.subject.replace(/\n/g," "),subject_alt_name:t.subjectAltName,serial_number:t.serialNumber,valid_from:t.validFrom,valid_to:t.validTo},aa(),await Pr.patch(e)}a(_u,"setCertTable");async function By(){let e=await Cy("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:yt.publicKeyFromPem(e.publicKey),private_key:yt.privateKeyFromPem(e.privateKey)}}a(By,"generateKeys");async function Hy(e,t,r){let n=yt.createCertificate();if(!t){let o=await tf();t=yt.certificateFromPem(o.options.cert).publicKey}n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+Uy);let i=[{name:"commonName",value:Fp()},...vy];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions($B()),n.sign(e,uu.md.sha256.create()),yt.certificateToPem(n)}a(Hy,"generateCertificates");async function Ly(){let e=await QB(),t;for(let r of e){if(!r.is_authority)continue;let n=await zB(r.private_key_name);if(r.private_key_name&&n&&new uo(r.certificate).checkPrivateKey(vB(n))){pt.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;pt.trace("No CA found with matching private key")}a(Ly,"getCertAuthority");async function VB(e,t,r=!0){let n=yt.createCertificate();n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+Uy);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${_s.get(du.REPLICATION_HOSTNAME)??xB(_s.get(du.REPLICATION_URL))??BB().split("-")[0]}`},...vy];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,uu.md.sha256.create());let o=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME),c=sr.join(o,Js.PRIVATEKEY_PEM_NAME);return r&&await pn.writeFile(c,yt.privateKeyToPem(e)),n}a(VB,"generateCertAuthority");async function Zte(){let{private_key:e,public_key:t}=await By(),r=await VB(e,t),n=await Hy(e,t,r);await Xte(n,r),KB()}a(Zte,"generateCertsKeys");async function ere(){let e=await Hy(yt.privateKeyFromPem(Js.CERTIFICATE_VALUES.key),void 0,yt.certificateFromPem(Js.CERTIFICATE_VALUES.cert)),t=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME),r=sr.join(t,Js.NATS_CERTIFICATE_PEM_NAME);await pn.exists(r)||await pn.writeFile(r,e);let n=sr.join(t,Js.NATS_CA_PEM_NAME);await pn.exists(n)||await pn.writeFile(n,Js.CERTIFICATE_VALUES.cert)}a(ere,"createNatsCerts");async function tre(){aa();for await(let e of Pr.search([{attribute:"is_self_signed",value:!0}]))await Pr.delete(e.name);await xy()}a(tre,"renewSelfSigned");async function xy(){Vte(),await qB(),aa();let e=await Ly();if(!e){pt.notify("A matching Certificate Authority and key was not found. A new CA will be created in advance, so it's available if needed.");let r=_s.get(du.TLS_PRIVATEKEY),n=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME),s,i=HB(n,r);try{s=yt.privateKeyFromPem(await pn.readFile(r))}catch(c){pt.warn("Unable to parse the TLS key",r,"A new key will be generated and used to create Certificate Authority",c),{private_key:s}=await By(),await pn.exists(sr.join(n,Js.PRIVATEKEY_PEM_NAME))&&(i=`privateKey${BB().split("-")[0]}.pem`),await pn.writeFile(sr.join(n,i),yt.privateKeyToPem(s))}let o=await VB(s,yt.setRsaPublicKey(s.n,s.e),!1);await _u({name:o.subject.getField("CN").value,uses:["https","wss"],certificate:yt.certificateToPem(o),private_key_name:i,is_authority:!0,is_self_signed:!0})}if(!await tf()){let r=Gp();pt.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await Ly();let n=yt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await Hy(yt.privateKeyFromPem(e.private_key),s,n);await _u({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(xy,"reviewSelfSignedCert");function KB(){let e=Fte(Object.keys(Es.CONFIG_PARAM_MAP),!0),t=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME),r=sr.join(t,Js.PRIVATEKEY_PEM_NAME),n=sr.join(t,Js.NATS_CERTIFICATE_PEM_NAME),s=sr.join(t,Js.NATS_CA_PEM_NAME),i=Es.CONFIG_PARAMS,o={[i.TLS_PRIVATEKEY]:e[i.TLS_PRIVATEKEY.toLowerCase()]?e[i.TLS_PRIVATEKEY.toLowerCase()]:r};e[i.TLS_CERTIFICATE.toLowerCase()]&&(o[i.TLS_CERTIFICATE]=e[i.TLS_CERTIFICATE.toLowerCase()]),e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.TLS_CERTIFICATEAUTHORITY]=e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATE]=e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]),e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_PRIVATEKEY]=e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY]=e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]),(e[i.CLUSTERING_ENABLED.toLowerCase()]||e.clustering)&&(o[i.CLUSTERING_TLS_CERTIFICATE]=e[i.CLUSTERING_TLS_CERTIFICATE.toLowerCase()]??n,o[i.CLUSTERING_TLS_CERT_AUTH]=e[i.CLUSTERING_TLS_CERT_AUTH.toLowerCase()]??s,o[i.CLUSTERING_TLS_PRIVATEKEY]=e[i.CLUSTERING_TLS_PRIVATEKEY.toLowerCase()]??r),Dy.updateConfigValue(void 0,void 0,o,!1,!0)}a(KB,"updateConfigCert");function YB(e){return e.startsWith("-----BEGIN")?e:Kte(e,"utf8")}a(YB,"readPEM");var MB=Ic.createSecureContext;Ic.createSecureContext=function(e){if(!e.cert||!e.key)return MB(e);let t={...e};delete t.key,delete t.cert;let r=MB(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var WB=Ic.Server;Ic.Server=function(e,t){return e.ALPNCallback&&(e.ALPNProtocols=null),WB.call(this,e,t)};Ic.Server.prototype=WB.prototype;var rre=GB.prototype._init;GB.prototype._init=function(e,t){rre.call(this,e,t);let r=this;this._handle.oncertcb=function(n){let s=n.servername;r._SNICallback(s,(i,o)=>{this.sni_context=o?.context||o,this.certCbDone()})}};var Nc=new Map;function jB(e,t){let r=new Map,n,s=!1;return i.initialize=o=>i.ready?i.ready:(o&&(o.secureContexts=r,o.secureContextsListeners=[]),i.ready=new Promise((c,l)=>{async function u(){try{r.clear(),Nc.clear();let d=0;for await(let _ of wy.system.hdb_certificate.search([])){if(e!=="operations-api"&&_.uses?.includes?.("operations"))continue;let E=_.certificate,f=new uo(E);_.is_authority&&(f.asString=E,Nc.set(f.subject,E))}for await(let _ of wy.system.hdb_certificate.search([]))try{if(_.is_authority)continue;if(!(e==="operations-api")&&_.uses?.includes?.("operations")){lo.trace("Skipping cert",_.name,"for",e,o.ports||"client","because it is for operations");continue}let f=_.is_self_signed?1:2,h=await zB(_.private_key_name),T=_.certificate,m=new uo(T);if(Nc.has(m.issuer)&&(T+=`
15
- `+Nc.get(m.issuer)),!h||!T)throw new Error("Missing private key or certificate for secure server");let g={ciphers:_.ciphers,ticketKeys:Wte(),availableCAs:Nc,ca:t&&Array.from(Nc.values()),cert:T,key:h,key_file:_.private_key_name,is_self_signed:_.is_self_signed};o&&(g.sessionIdContext=o.sessionIdContext);let S=Ic.createSecureContext(g);S.name=_.name,S.options=g,S.quality=f,S.certificateAuthorities=Array.from(Nc),S.certStart=T.toString().slice(0,100);let b=_.hostnames??JB(m);Array.isArray(b)||(b=[b]);let I;for(let B of b)if(B){B[0]==="*"&&(s=!0,B=B.slice(1)),B===Py()&&(f+=2),UB.isIP(B)&&(I=!0);let H=r.get(B)?.quality??0;f>H&&r.set(B,S)}else lo.error("No hostname found for certificate at",Ic.certificate);lo.trace("Adding TLS",S.name,"for",o.ports||"client","cert named",_.name,"hostnames",b,"quality",f,"best quality",d),f>d&&(i.defaultContext=n=S,d=f,o&&(o.defaultContext=S))}catch(E){lo.error("Error applying TLS for",_.name,E)}o?.secureContextsListeners.forEach(_=>_()),c(n)}catch(d){l(d)}}a(u,"updateTLS"),wy.system.hdb_certificate.subscribe({listener:u,omitCurrent:!0}),u()})),i;function i(o,c){lo.info("TLS requested for",o||"(no SNI)",this.isReplicationConnection);let l=o;for(;;){let d=r.get(l);if(d)return lo.debug("Found certificate for",o,d.certStart),d.replicationContext&&(this.isReplicationConnection||CB)&&(d=d.replicationContext),c(null,d);if(s&&l){let _=l.indexOf(".",1);_<0?l="":l=l.slice(_)}else break}o?lo.debug("No certificate found to match",o,"using the default certificate"):lo.debug("No SNI, using the default certificate",n?.name);let u=n;u?u.replicationContext&&(this.isReplicationConnection||CB)&&(u=u.replicationContext):lo.info("No default certificate found"),c(null,u)}a(i,"SNICallback")}a(jB,"createTLSSelector");async function zB(e){let t=oa.get(e);return!t&&e?await pn.readFile(sr.join(_s.get(du.ROOTPATH),Es.LICENSE_KEY_DIR_NAME,e),"utf8"):t}a(zB,"getPrivateKeyByName");async function QB(){aa();let e=[];for await(let t of Pr.search([]))e.push(t);return e}a(QB,"listCertificates");async function nre(e){let t=My(e,Qs.object({name:Qs.string().required(),certificate:Qs.string().required(),is_authority:Qs.boolean().required(),private_key:Qs.string(),hosts:Qs.array(),uses:Qs.array()}));if(t)throw new ia(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,o=new uo(n),c=!1,l=!1,u;for(let[f,h]of oa)!s&&!c&&o.checkPrivateKey(vB(h))&&(c=!0,u=f),s&&s===h&&(l=!0,u=f);if(!i&&!s&&!c)throw new ia("A suitable private key was not found for this certificate");let d;if(!r){try{d=ky(o)}catch(f){pt.error(f)}if(d==null)throw new ia("Error extracting certificate common name, please provide a name parameter")}let _=sre(r??d);s&&!c&&!l&&(await pn.writeFile(sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME,_+".pem"),s),oa.set(_,s));let E={name:r??d,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&u||i&&s)&&(E.private_key_name=u??_+".pem"),await _u(E),"Successfully added certificate: "+_}a(nre,"addCertificate");function sre(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(sre,"sanitizeName");async function ire(e){let t=My(e,Qs.object({name:Qs.string().required()}));if(t)throw new ia(t.message);let{name:r}=e;aa();let n=await Pr.get(r);if(!n)throw new ia(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await Pr.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(pt.info("Removing private key named",s),await pn.remove(sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME,s)))}return await Pr.delete(r),"Successfully removed "+r}a(ire,"removeCertificate");function ky(e){return e.subject.match(/CN=(.*)/)?.[1]}a(ky,"extractCommonName");function JB(e){return e.subjectAltName?e.subjectAltName.split(",").map(t=>{let r=t.indexOf(":");if(t=t.slice(r+1),t=t.trim(),t[0]==='"')try{t=JSON.parse(t)}catch{}return t.indexOf("=")>-1?t.match(/CN=([^,]*)/)?.[1]:t}).filter(t=>t):[ky(e)]}a(JB,"hostnamesFromCert");async function ore(e){if(e.bypass_auth!==!0)throw new ia("Unauthorized","401");let t=My(e,Qs.object({name:Qs.string().required()}));if(t)throw new ia(t.message);let{name:r}=e;if(r===".jwtPrivate")return(await DB()).private_key;if(r===".jwtPublic")return(await DB()).public_key;if(oa.get(r))return oa.get(e.name);throw new ia("Key not found")}a(ore,"getKey")});async function Ky(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=ot(),i;if(e.includes("wss://")){if(!Gy){let l=(0,fH.createTLSSelector)("operations-api"),u={secureContexts:null};await l.initialize(u),Gy=u.secureContexts}if(i=Gy.get(s),i&&fe.debug?.("Creating web socket for URL",e,"with certificate named:",i.name),!i&&n!==!1)throw new Error("Unable to find a valid certificate to use for replication to connect to "+e)}let o={};r&&(o.Authorization=r);let c={headers:o,localAddress:s?.startsWith("127.0")?s:void 0,servername:(0,hH.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,ALPNProtocols:["http/1.1","harperdb-replication"],rejectUnauthorized:n!==!1,secureContext:void 0};return i&&(c.secureContext=EH.createSecureContext({...i.options,ca:Array.from(ua)})),new dH.WebSocket(e,"harperdb-replication-v1",c)}function Yp(e,t,r){let n=t.port||t.securePort,s=Vy.pid%1e3+"-"+_H.threadId+(n?"s:"+n:"c:"+t.url?.slice(-4))+" "+Math.random().toString().slice(2,3),i=0,o=Buffer.allocUnsafeSlow(1024),c=0,l=new DataView(o.buffer,0,1024),u=t.database,d=t.databaseSubscriptions||wc,_,E,f=!1,h=t.subscription;h?.then&&h.then(ie=>h=ie);let T=t.tables||u&&ut()[u];if(!r){fe.error?.("No authorization provided"),ss(1008,"Unauthorized");return}let m=new Map,g=[],S=r.name;S&&t.connection&&(t.connection.nodeName=S);let b,I,B,H,X,Y,V=1e3,ne,Q=0,de=0,j=0,ae=0;if(t.url){let ie=a(()=>{X&&j===e._socket?.bytesRead&&ae===e._socket?.bytesWritten?e.terminate():(X=performance.now(),e.ping(),j=e._socket?.bytesRead,ae=e._socket?.bytesWritten)},"send_ping");B=setInterval(ie,lH).unref(),ie()}else Ae();function Ae(){clearTimeout(H),j=e._socket?.bytesRead,ae=e._socket?.bytesWritten,H=setTimeout(()=>{j===e._socket?.bytesRead&&ae===e._socket?.bytesWritten&&(fe.warn?.(`Timeout waiting for ping from ${S}, terminating connection and reconnecting`),e.terminate())},lH*2).unref()}a(Ae,"resetPingTimer"),u&&Va(u);let ye,Me,Gr=[],wd=[],ka,wn=[],Cd=[],Al=[],Uw=150,jE=0,vt=0,Fa,Ga,vs,Bs,zE;e.on("message",ie=>{Q=performance.now();try{let Se=ie.dataView=new Cc(ie.buffer,ie.byteOffset,ie.byteLength);if(ie[0]>127){let R=(0,ct.decode)(ie),[w,A,y]=R;switch(w){case eH:{if(A){if(S){if(S!==A){fe.error?.(s,`Node name mismatch, expecting to connect to ${S}, but peer reported name as ${A}, disconnecting`),e.send((0,ct.encode)([fu])),ss(1008,"Node name mismatch");return}}else if(S=A,t.connection?.tentativeNode){let x=t.connection.tentativeNode;x.name=S,t.connection.tentativeNode=null,co(S,x)}if(t.connection&&(t.connection.nodeName=S),fe.debug?.(s,"received node name:",S,"db:",u),!u)try{Va(u=R[2]),u==="system"&&(ye=ra(t,(x,q)=>{$a(q)&&Ir(q)}),e.on("close",()=>{ye?.remove()}))}catch(x){fe.warn?.(s,"Error setting database",x),e.send((0,ct.encode)([fu])),ss(1008,x.message);return}qa()}break}case aH:{fe.debug?.(s,"Received table definitions for",A.map(x=>x.table));for(let x of A){let q=R[2];x.database=q;let ee;$a(q)&&(q==="system"?We[q]?.[x.table]||(ee=qy(x,We[q]?.[x.table])):ee=qy(x,We[q]?.[x.table]),_||(_=ee?.auditStore),T||(T=ut()?.[q]))}break}case fu:ss();break;case sH:try{let x=r?.replicates||r?.subscribers||r?.name;server.operation(A,{user:r},!x).then(q=>{Array.isArray(q)&&(q={results:q}),q.requestId=A.requestId,e.send((0,ct.encode)([$p,q]))},q=>{e.send((0,ct.encode)([$p,{requestId:A.requestId,error:q instanceof Error?q.toString():q}]))})}catch(x){e.send((0,ct.encode)([$p,{requestId:A.requestId,error:x instanceof Error?x.toString():x}]))}break;case $p:let{resolve:D,reject:O}=m.get(A.requestId);A.error?O(new Error(A.error)):D(A),m.delete(A.requestId);break;case Fy:let v=R[3];T||(u?fe.error?.(s,"No tables found for",u):fe.error?.(s,"Database name never received"));let k=T[v];k=qy({table:v,database:u,attributes:A.attributes,schemaDefined:A.schemaDefined},k),Gr[y]={name:v,decoder:new ct.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:A.typedStructs,structures:A.structures}),getEntry(x){return k.primaryStore.getEntry(x)},rootStore:k.primaryStore.rootStore};break;case tH:zE=_?tB(S,A,_):new Map,ka=R[2],fe.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${ka}`);break;case rH:let C=y;Al[C]=A;break;case oH:let F=["replicated",u,S];E||(E=new Float64Array(_.getUserSharedBuffer(F,new ArrayBuffer(8)))),E[0]=A,fe.trace?.(s,"received and broadcasting committed update",A),E.buffer.notify();break;case iH:b=A,h.send({type:"end_txn",localTime:b,remoteNodeIds:g});break;case nH:{let x=A,q;try{let ee=R[3],G=wd[y]||(wd[y]=T[R[4]]);if(!G)return fe.warn?.("Unknown table id trying to handle record request",y);let be=G.primaryStore.getBinaryFast(Symbol.for("structures")),Ee=be.length;if(Ee!==vt){vt=Ee;let re=(0,ct.decode)(be);e.send((0,ct.encode)([Fy,{typedStructs:re.typed,structures:re.named},y,G.tableName]))}let Re=G.primaryStore.getBinaryFast(ee);if(Re){let re=G.primaryStore.decoder.decode(Re,{valueAsBuffer:!0});q=(0,ct.encode)([qp,x,{value:re.value,expiresAt:re.expiresAt,version:re.version,residencyId:re.residencyId,nodeId:re.nodeId,user:re.user}])}else q=(0,ct.encode)([qp,x])}catch(ee){q=(0,ct.encode)([qp,x,{error:ee.message}])}e.send(q);break}case qp:{let{resolve:x,reject:q,tableId:ee,key:G}=m.get(R[1]),be=R[2];if(be?.error)q(new Error(be.error));else if(be){let Ee=Gr[ee].decoder.decode(be.value);be.value=Ee,be.key=G,x(be)}else x();m.delete(R[1]);break}case ZB:{Bs=A;let x,q,ee=!1;if(h){if(u!==h.databaseName&&!h.then){fe.error?.("Subscription request for wrong database",u,h.databaseName);return}}else h=d.get(u);if(fe.debug?.(s,"received subscription request for",u,"at",Bs),!h){let ce;h=new Promise(Ye=>{fe.debug?.("Waiting for subscription to database "+u),ce=Ye}),h.ready=ce,wc.set(u,h)}if(r.name)q=Sr().subscribe(r.name),q.then(async ce=>{x=ce;for await(let Ye of x){let rt=Ye.value;if(!(rt?.replicates===!0||rt?.replicates?.receives||rt?.subscriptions?.some(Ze=>(Ze.database||Ze.schema)===u&&Ze.publish!==!1))){ee=!0,e.send((0,ct.encode)([fu])),ss(1008,`Unauthorized database subscription to ${u}`);return}}},ce=>{fe.error?.(s,"Error subscribing to HDB nodes",ce)});else if(!(r?.role?.permission?.super_user||r.replicates)){e.send((0,ct.encode)([fu])),ss(1008,`Unauthorized database subscription to ${u}`);return}if(vs&&(fe.debug?.(s,"stopping previous subscription",u),vs.emit("close")),Bs.length===0)return;let G=Bs[0],be=a(ce=>{if(ce&&(G.replicateByDefault?!G.tables.includes(ce.tableName):G.tables.includes(ce.tableName)))return{table:ce}},"tableToTableEntry"),Ee={txnTime:0},Re,re,K=1/0,Te,Be=a((ce,Ye)=>{if(K=Ye,ce.type==="end_txn"){Ee.txnTime&&(o[i]!==66&&fe.error?.("Invalid encoding of message"),di(9),di(Kp),Ka(Te=Ye),Ie()),i=c,Ee.txnTime=0;return}let rt=ce.nodeId,Ze=ce.tableId,st=re[Ze];if(!st&&(st=re[Ze]=be(h.tableById[Ze]),!st))return fe.debug?.("Not subscribed to table",Ze);let Kt=st.table,Fo=Kt.primaryStore,Yt=Fo.encoder;(ce.extendedType&Oh||!Yt.typedStructs)&&(Yt._mergeStructures(Yt.getStructures()),Yt.typedStructs&&(Yt.lastTypedStructuresLength=Yt.typedStructs.length));let QE=Re[rt];if(!(QE&&QE.startTime<Ye&&(!QE.endTime||QE.endTime>Ye)))return rf&&fe.trace?.(s,"skipping replication update",ce.recordId,"to:",S,"from:",rt,"subscribed:",Re),vw();rf&&fe.trace?.(s,"sending replication update",ce.recordId,"to:",S,"from:",rt,"subscribed:",Re);let ZT=ce.version;Ee.txnTime!==ZT&&(Ee.txnTime&&(rf&&fe.trace?.(s,"new txn time, sending queued txn",Ee.txnTime),o[i]!==66&&fe.error?.("Invalid encoding of message"),Ie()),Ee.txnTime=ZT,i=c,Ka(ZT));let Ya=ce.residencyId,eg=ji(Ya,Kt),JE;if(eg&&!eg.includes(S)){let bl=ji(ce.previousResidencyId,Kt);if(bl&&!bl.includes(S)&&(ce.type==="put"||ce.type==="patch")||Kt.getResidencyById)return vw();let Md=ce.recordId;fe.trace?.(s,"sending invalidation",Md,S,"from",rt);let ng=0;Ya&&(ng|=tc),ce.previousResidencyId&&(ng|=rc);let sg,XE=null;for(let Bw in Kt.indices){if(!XE){if(sg=ce.getValue(Fo,!0),!sg)break;XE={}}XE[Bw]=sg[Bw]}JE=Dl(ce.version,Ze,Md,null,rt,ce.user,ce.type==="put"||ce.type==="patch"?"invalidate":ce.type,Yt.encode(XE),ng,Ya,ce.previousResidencyId,ce.expiresAt)}function vw(){fe.trace?.(s,"skipping audit record",ce.recordId),Y||(Y=setTimeout(()=>{Y=null,(Te||0)+cH/2<K&&(rf&&fe.trace?.(s,"sending skipped sequence update",K),e.send((0,ct.encode)([iH,K])))},cH).unref())}a(vw,"skipAuditRecord");let tg=Yt.typedStructs,rg=Yt.structures;if((tg?.length!=st.typed_length||rg?.length!=st.structure_length)&&(st.typed_length=tg?.length,st.structure_length=rg.length,fe.debug?.(s,"send table struct",st.typed_length,st.structure_length),st.sentName||(st.sentName=!0),e.send((0,ct.encode)([Fy,{typedStructs:tg,structures:rg,attributes:Kt.attributes,schemaDefined:Kt.schemaDefined},Ze,st.table.tableName]))),Ya&&!Cd[Ya]&&(e.send((0,ct.encode)([rH,eg,Ya])),Cd[Ya]=!0),JE)di(JE.length),Ld(JE);else{let bl=ce.encoded,Md=bl[0]===66?8:0;di(bl.length-Md),Ld(bl,Md)}},"sendAuditRecord"),Ie=a(()=>{c-i>8?(e.send(o.subarray(i,c)),fe.debug?.(s,"Sent message, size:",c-i)):fe.debug?.(s,"skipping empty transaction")},"sendQueuedData");vs=new $y.EventEmitter,vs.once("close",()=>{ee=!0,x?.end()});for(let{startTime:ce}of Bs)ce<K&&(K=ce);(q||Promise.resolve()).then(async()=>{h=await h,_=h.auditStore,re=h.tableById.map(be),Re=[];for(let{name:Ye,startTime:rt,endTime:Ze}of Bs){let st=Lp(Ye,_);fe.debug?.("subscription to",Ye,"using local id",st,"starting",rt),Re[st]={startTime:rt,endTime:Ze}}Ir(u),ye||(ye=Dc(Ye=>{Ye.databaseName===u&&Ir(u)}),Me=nf(Ye=>{Ye===u&&(e.send((0,ct.encode)([fu])),ss())}),e.on("close",()=>{ye?.remove(),Me?.remove()})),e.send((0,ct.encode)([tH,Y_(h.auditStore),Bs.map(({name:Ye})=>Ye)]));let ce=!0;do{isFinite(K)||(fe.warn?.("Invalid sequence id "+K),ss(1008,"Invalid sequence id"+K));let Ye;if(ce&&!ee&&(ce=!1,!(Yy(_)<=K)&&server.nodes[0]?.name===S)){fe.info?.("Replicating all tables to",S);let Ze=K,st=Wp(_);for(let Kt in T){let Fo=T[Kt];for(let Yt of Fo.primaryStore.getRange({snapshot:!1})){if(ee)return;Yt.localTime>=K&&(fe.trace?.(s,"Copying record from",u,Kt,Yt.key,Yt.localTime),Ze=Math.max(Yt.localTime,Ze),Ye=!0,Be({recordId:Yt.key,tableId:Fo.tableId,type:"put",getValue(){return Yt.value},encoded:Fo.primaryStore.getBinary(Yt.key),version:Yt.version,residencyId:Yt.residencyId,nodeId:st},Yt.localTime))}}K=Ze}for(let{key:rt,value:Ze}of _.getRange({start:K||1,exclusiveStart:!0,snapshot:!1})){if(ee)return;de=rt;let st=Ht(Ze);Be(st,rt),e._socket.writableNeedDrain?await new Promise(Kt=>e._socket.once("drain",Kt)):await new Promise(setImmediate),vs.startTime=rt,Ye=!0}Ye&&Be({type:"end_txn"},K),de=0,await lB(_)}while(!ee)}).catch(ce=>{fe.error?.(s,"Error handling subscription to node",ce),ss(1008,"Error handling subscription to node")});break}}return}Se.position=8;let tt=!0,U,p;do{let R=Se.readInt();if(R===9&&Se.getUint8(Se.position)==Kp){Se.position++,b=p=Se.readFloat64(),fe.trace?.("received remote sequence update",b,u);break}let w=Se.position,A=Ht(ie,w,w+R),y=Gr[A.tableId];y||fe.error?.(`No table found with an id of ${A.tableId}`);let D;A.residencyId&&(D=Al[A.residencyId],fe.trace?.(s,"received residency list",D,A.type,A.recordId));try{U={table:y.name,id:A.recordId,type:A.type,nodeId:zE.get(A.nodeId),residencyList:D,timestamp:A.version,value:A.getValue(y),user:A.user,beginTxn:tt,expiresAt:A.expiresAt}}catch(O){throw O.message+="typed structures for current decoder"+JSON.stringify(y.decoder.typedStructs),O}tt=!1,rf&&fe.trace?.(s,"received replication message",A.type,"id",U.id,"version",A.version,"nodeId",U.nodeId,"value",U.value),h.send(U),Se.position=w+R}while(Se.position<ie.byteLength);jE++,pr(ie.byteLength,"bytes-received",S+"."+u+"."+U.table,"replication","ingest"),jE>Uw&&!Fa&&(Fa=!0,e.pause()),h.send({type:"end_txn",localTime:b,remoteNodeIds:g,onCommit(){if(U){let R=Date.now()-U.timestamp;pr(R,"replication-latency",S+"."+u+"."+U.table,U.type,"ingest")}jE--,Fa&&(Fa=!1,e.resume()),!I&&p&&(fe.trace?.(s,"queuing confirmation of a commit at",p),setTimeout(()=>{e.send((0,ct.encode)([oH,I])),fe.trace?.(s,"sent confirmation of a commit at",I),I=null},are)),I=p}})}catch(Se){fe.error?.(s,"Error handling incoming replication message",Se)}}),e.on("ping",Ae),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-X,Oc({name:S,database:u,url:t.url,lastSendTime:de,latency:t.connection.latency})),X=null}),e.on("close",(ie,Se)=>{clearInterval(B),clearTimeout(H),vs&&vs.emit("close"),Ga&&Ga.end();for(let[tt,{reject:U}]of m)U(new Error(`Connection closed ${Se?.toString()} ${ie}`));fe.debug?.(s,"closed",ie,Se?.toString())});function Ve(){}a(Ve,"recordRemoteNodeSequence");function ss(ie,Se){e.isFinished=!0,e.close(ie,Se)}a(ss,"close");function qa(){if(f||(f=!0,t.connection?.on("subscriptions-updated",qa)),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let ie=new Map;try{for(let U of h?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let p of U.value.nodes||[])p.lastTxnTime>(ie.get(p.id)??0)&&ie.set(p.id,p.lastTxnTime)}catch(U){if(!U.message.includes("Can not re"))throw U}let Se=t.connection?.nodeSubscriptions?.[0];g=[];let tt=t.connection?.nodeSubscriptions.map((U,p)=>{let R=[],{replicateByDefault:w}=U;if(U.subscriptions){for(let O of U.subscriptions)if(O.subscribe&&(O.schema||O.database)===u){let v=O.table;T?.[v]?.replicate!==!1&&R.push(v)}w=!1}else for(let O in T)(w?T[O].replicate===!1:T[O].replicate)&&R.push(O);let A=_&&Lp(U.name,_),y=h?.dbisDB?.get([Symbol.for("seq"),A])??1,D=Math.max(y?.seqId??1,(typeof U.start_time=="string"?new Date(U.start_time).getTime():U.start_time)??1);if(fe.debug?.("Starting time recorded in db",U.name,A,u,y?.seqId,"start time:",D),Se!==U){D>5e3&&(D-=5e3);let O=_&&Lp(Se.name,_),v=h?.dbisDB?.get([Symbol.for("seq"),O])??1;for(let k of v?.nodes||[])k.name===U.name&&(D=k.seqId,fe.debug?.("Using sequence id from proxy node",Se.name,D))}return g.push(A),ie.get(A)>D&&(D=ie.get(A),fe.debug?.("Updating start time from more recent txn recorded",Se.name,D)),{name:U.name,replicateByDefault:w,tables:R,startTime:D,endTime:U.end_time}});if(tt)if(fe.debug?.(s,"sending subscription request",tt,h?.dbisDB?.path),clearTimeout(ne),tt.length>0)e.send((0,ct.encode)([ZB,tt]));else{let U=a(()=>{let p=performance.now();ne=setTimeout(()=>{Q<=p?ss(1008,"No nodes to subscribe to"):U()},V)},"schedule_close");U()}}a(qa,"sendSubscriptionRequestUpdate");function ji(ie,Se){if(!ie)return;let tt=wn[ie];return tt||(tt=Se.getResidencyRecord(ie),wn[ie]=tt),tt}a(ji,"getResidence");function $a(ie){return!(la&&la!="*"&&!la[ie]&&!la.includes?.(ie)&&!la.some?.(Se=>Se.name===ie))}a($a,"checkDatabaseAccess");function Va(ie){if(h=h||d.get(ie),!$a(ie))throw new Error(`Access to database "${ie}" is not permitted`);h||fe.warn?.(`No database named "${ie}" was declared and registered`),_=h?.auditStore,T||(T=ut()?.[ie]);let Se=ot();if(Se===S)throw Se?new Error("Should not connect to self",Se):new Error("Node name not defined");return Dd(Se,ie),!0}a(Va,"setDatabase");function Dd(ie,Se){let tt=ut()?.[Se],U=[];for(let p in tt){let R=tt[p];U.push({table:p,schemaDefined:R.schemaDefined,attributes:R.attributes.map(w=>({name:w.name,type:w.type,isPrimaryKey:w.isPrimaryKey}))})}fe.trace?.("Sending database info for node",ie,"database name",Se),e.send((0,ct.encode)([eH,ie,Se,U]))}a(Dd,"sendNodeDBName");function Ir(ie){let Se=ut()?.[ie],tt=[];for(let U in Se){if(Bs&&!Bs.some(R=>R.replicateByDefault?!R.tables.includes(U):R.tables.includes(U)))continue;let p=Se[U];tt.push({table:U,schemaDefined:p.schemaDefined,attributes:p.attributes.map(R=>({name:R.name,type:R.type,isPrimaryKey:R.isPrimaryKey}))})}e.send((0,ct.encode)([aH,tt,ie]))}a(Ir,"sendDBSchema");let yl=1,Pd=[];return{end(){Ga&&Ga.end(),vs&&vs.emit("close")},getRecord(ie){let Se=yl++;return new Promise((tt,U)=>{let p=[nH,Se,ie.table.tableId,ie.id];Pd[ie.table.tableId]||(p.push(ie.table.tableName),Pd[ie.table.tableId]=!0),e.send((0,ct.encode)(p)),m.set(Se,{tableId:ie.table.tableId,key:ie.id,resolve(R){let{table:w,entry:A}=ie;tt(R),R&&w._recordRelocate(A,R)},reject:U})})},sendOperation(ie){let Se=yl++;return ie.requestId=Se,e.send((0,ct.encode)([sH,ie])),new Promise((tt,U)=>{m.set(Se,{resolve:tt,reject:U})})}};function di(ie){ko(5),ie<128?o[c++]=ie:ie<16384?(l.setUint16(c,ie|32768),c+=2):ie<1056964608?(l.setUint32(c,ie|3221225472),c+=4):(o[c]=255,l.setUint32(c+1,ie),c+=5)}function Ld(ie,Se=0,tt=ie.length){let U=tt-Se;ko(U),ie.copy(o,c,Se,tt),c+=U}function Ka(ie){ko(8),l.setFloat64(c,ie),c+=8}function ko(ie){if(ie+16>o.length-c){let Se=Buffer.allocUnsafeSlow(c+ie-i+65536>>10<<11);o.copy(Se,0,i,c),c=c-i,i=0,o=Se,l=new DataView(o.buffer,0,o.length)}}}function qy(e,t){let r=e.database??"data";if(r!=="data"&&!We[r]){fe.warn?.("Database not found",e.database);return}t||(t={});let n=!1,s=e.schemaDefined,i=t.attributes||[];for(let o=0;o<e.attributes?.length;o++){let c=e.attributes[o],l=i[o];(!l||l.name!==c.name||l.type!==c.type)&&(n=!0,s||(c.indexed=!0),i[o]=c)}return n?(fe.debug?.("(Re)creating",e),Et({table:e.table,database:e.database,schemaDefined:e.schemaDefined,attributes:i,...t})):t}var ct,dH,_H,fe,$y,fH,EH,Vy,hH,ZB,eH,tH,fu,rH,Fy,nH,qp,sH,$p,iH,oH,aH,pH,wc,rf,cH,are,lH,Gy,uH,Vp,mH=Oe(()=>{Pe();Ji();_y();my();us();Pl();ct=require("msgpackr"),dH=require("ws"),_H=require("worker_threads"),fe=L(bc());Q_();$y=require("events"),fH=L(Xs()),EH=L(require("node:tls"));iu();Vy=L(require("node:process")),hH=require("node:net");Ni();ZB=129,eH=140,tH=141,fu=142,rH=130,Fy=132,nH=133,qp=134,sH=136,$p=137,iH=143,oH=144,aH=145,pH=new Map,wc=new Map,rf=!0,cH=300,are=2,lH=3e4;a(Ky,"createWebSocket");uH=1e3,Vp=class extends $y.EventEmitter{constructor(r,n,s,i,o){super();this.url=r;this.subscription=n;this.databaseName=s;this.nodeName=i;this.authorization=o;this.nodeName=this.nodeName??zs(r)}static{a(this,"NodeReplicationConnection")}socket;startTime;retryTime=uH;retries=0;isConnected=!0;isFinished=!1;nodeSubscriptions=[];latency=0;replicateTablesByDefault;session;sessionResolve;sessionReject;async connect(){this.session||this.resetSession();let r=[];this.socket=await Ky(this.url,{serverName:this.nodeName,authorization:this.authorization});let n;fe.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${Vy.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),fe.info?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=uH,Oc({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=Yp(this.socket,{database:this.databaseName,subscription:this.subscription,url:this.url,connection:this},{replicates:!0}),this.sessionResolve(n)}),this.socket.on("error",s=>{s.code==="SELF_SIGNED_CERT_IN_CHAIN"?(fe.warn?.(`Can not connect to ${this.url}, this server does not have a certificate authority for the certificate provided by ${this.url}`),s.isHandled=!0):s.code!=="ECONNREFUSED"&&(s.code==="UNABLE_TO_VERIFY_LEAF_SIGNATURE"?fe.error?.(`Can not connect to ${this.url}, the certificate provided by ${this.url} is not trusted, this node needs to be added to the cluster, or a certificate authority needs to be added`):fe.error?.(`Error in connection to ${this.url} due to ${s.message}`)),this.sessionReject(s)}),this.socket.on("close",(s,i)=>{if(this.isConnected&&(cu({name:this.nodeName,database:this.databaseName,url:this.url,finished:this.socket.isFinished}),this.isConnected=!1),this.socket.isFinished){this.isFinished=!0,n?.end(),this.emit("finished");return}if(++this.retries%20===1){let o=i?.toString();fe.warn?.(`${n?"Disconnected from":"Failed to connect to"} ${this.url} (db: "${this.databaseName}"), due to ${o?'"'+o+'" ':""}(code: ${s})`)}n=null,this.resetSession(),setTimeout(()=>{this.connect()},this.retryTime).unref(),this.retryTime+=this.retryTime>>3})}resetSession(){this.session=new Promise((r,n)=>{this.sessionResolve=r,this.sessionReject=n})}subscribe(r,n){this.nodeSubscriptions=r,this.replicateTablesByDefault=n,this.emit("subscriptions-updated",r)}unsubscribe(){this.socket.isFinished=!0,this.socket.close(1008,"No longer subscribed")}getRecord(r){return this.session.then(n=>n.getRecord(r))}};a(Yp,"replicateOverWS");a(qy,"ensureTableIfChanged")});var ca={};je(ca,{clearThisNodeName:()=>hre,disableReplication:()=>dre,enabled_databases:()=>la,forEachReplicatedDatabase:()=>ra,getThisNodeId:()=>Wp,getThisNodeName:()=>ot,getThisNodeUrl:()=>na,hostnameToUrl:()=>Qp,lastTimeInAuditStore:()=>W_,monitorNodeCAs:()=>OH,replicateOperation:()=>mre,replication_certificate_authorities:()=>ua,sendOperationToNode:()=>af,servers:()=>lre,setReplicator:()=>IH,start:()=>ure,startOnMainThread:()=>Ty,subscribeToNode:()=>au,unsubscribeFromNode:()=>Bp,urlToNodeName:()=>zs});function ure(e){if(e.port||(e.port=hs.default.get(Pc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=hs.default.get(Pc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),!ot())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let n of z_(e))t.set(zs(n.url),n);_re(e),e={mtls:!0,isOperationsServer:!0,maxPayload:10*1024*1024*1024,...e};let r=it.ws(async(n,s,i,o)=>{if(s.headers.get("sec-websocket-protocol")!=="harperdb-replication-v1")return o(n,s,i);await i,n._socket.unref(),Yp(n,e,s?.user),n.on("error",c=>{c.code!=="ECONNREFUSED"&&Tr.error("Error in connection to "+this.url,c.message)})},e);e.runFirst=!0,it.http((n,s)=>{if(n.isWebSocket&&n.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){!n.authorized&&n._nodeRequest.socket.authorizationError&&Tr.error(`Incoming client connection from ${n.ip} did not have valid certificate, you may need turn on enableRootCAs in the config if you are using a publicly signed certificate, or add the CA to the server's trusted CAs`,n._nodeRequest.socket.authorizationError);let i=Sr().primaryStore;if(n.authorized&&n.peerCertificate.subject){let o=n.peerCertificate.subject,c=o&&(i.get(o.CN)||t.get(o.CN));c?n.user=c:Tr.warn(`No node found for certificate common name ${o.CN}, available nodes are ${Array.from(i.getRange({}).filter(({value:l})=>l).map(({key:l})=>l)).join(", ")} and routes ${Array.from(t.keys()).join(", ")}, connection will require credentials.`)}else{let o=i.get(n.ip)||t.get(n.ip);o?n.user=o:Tr.warn(`No node found for IP address ${n.ip}, available nodes are ${Array.from(new Set([...i.getKeys(),...t.keys()])).join(", ")}, connection will require credentials.`)}}return s(n)},e);for(let n of r)if(n.secureContexts){let s=a(()=>{let i=new Set(n.secureContexts.values());n.defaultContext&&i.add(n.defaultContext);for(let o of i)try{let c=Array.from(ua);o.options.availableCAs&&c.push(...o.options.availableCAs.values());let l={...o.options,ca:c};o.replicationContext=of.createSecureContext(l)}catch(c){Tr.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),OH(s)}}function OH(e){let t=0;su(r=>{if(r?.ca){if(ua.add(r.ca),ua.size!==t)t=ua.size,e?.();else if(hs.default.get(Pc.CONFIG_PARAMS.REPLICATION_ENABLEROOTCAS)!==!1)for(let n of of.rootCertificates)ua.add(n)}})}function dre(e=!0){bH=e}function _re(e){bH||(ut(),la=e.databases,ra(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||wc;for(let[s,i]of sf){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];IH(r,s,e),pH.get(s)?.forEach(i=>i(s))}}))}function IH(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 NH extends Lr{static{a(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||wc,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(Tr.trace("Setting up replicator subscription to database",e),!o?.auditStore)return this.subscription=o=new Mn,i.set(e,o),o.tableById=c,o.auditStore=t.auditStore,o.dbisDB=t.dbisDB,o.databaseName=e,l&&l(o),o;this.subscription=o}static subscribeOnThisThread(i,o){return!0}static async load(i){if(i){let o=i.residencyId,c=i.residency||t.dbisDB.get([Symbol.for("residency_by_id"),o]);if(c){let l,u=new Set;do{let d;for(let E of c){let f=fre(E,NH.subscription,e);f?.isConnected&&!u.has(f)&&(!d||f.latency<d.latency)&&(d=f)}if(!d)throw l||new AH.ServerError("No connection to any other nodes are available",502);let _={requestId:cre++,table:t,entry:i,id:i.key};u.add(d);try{return await d.getRecord(_)}catch(E){if(d.isConnected)throw E;Tr.warn("Error in load from node",zp,E),l||(l=E)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function wH(e,t,r,n,s){let i=sf.get(e);i||sf.set(e,i=new Map);let o=i.get(r);if(o)return o;if(t)return i.set(r,o=new Vp(e,t,r,n,s)),o.connect(),o.once("finished",()=>i.delete(r)),o}function fre(e,t,r){let n=SH.get(e)?.get(r);if(n)return n;let s=Sr().primaryStore.get(e);return s?.url&&(n=wH(s.url,t,r,e,s.authorization),SH.set(e,sf.get(s.url))),n}async function af(e,t,r){r||(r={}),r.serverName=e.name;let n=await Ky(e.url,r),s=Yp(n,{},{});return new Promise((i,o)=>{n.on("open",()=>{i(s.sendOperation(t))}),n.on("error",c=>{o(c)}),n.on("close",c=>{Tr.info("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function au(e){try{yH.isMainThread&&Tr.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=wc.get(e.database);if(!t){let n;t=new Promise(s=>{Tr.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,wc.set(e.database,t)}let r=wH(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=>j_(n,e.database)),e.replicateByDefault)}catch(t){Tr.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function Bp({name:e,url:t,database:r}){Tr.trace("Unsubscribing from node",e,t,r,"nodes",Array.from(Sr().primaryStore.getRange({})));let n=sf.get(t);if(n){let s=n.get(r);s&&(s.unsubscribe(),n.delete(r))}}function Ere(){if(Wy!==void 0)return Wy;let e=hs.default.get(Pc.CONFIG_PARAMS.OPERATIONSAPI_TLS_CERTIFICATE)||hs.default.get(Pc.CONFIG_PARAMS.TLS_CERTIFICATE);if(e)return Wy=new gH.X509Certificate((0,RH.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function ot(){return zp||(zp=hs.default.get("replication_hostname")??zs(hs.default.get("replication_url"))??Ere()??TH("operationsapi_network_secureport")??TH("operationsapi_network_port")??"127.0.0.1")}function hre(){zp=void 0}function TH(e){let t=hs.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function jp(e){let t=hs.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function Wp(e){return Y_(e)?.[ot()]}function na(){let e=hs.default.get("replication_url");return e||Qp(ot())}function Qp(e){let t=jp("replication_port");if(t)return`ws://${e}:${t}`;if(t=jp("replication_secureport"),t)return`wss://${e}:${t}`;if(t=jp("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=jp("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function zs(e){if(e)return new URL(e).hostname}function ra(e,t){for(let n of Object.getOwnPropertyNames(We))r(n);return nf(n=>{r(n)}),Dc((n,s)=>{r(n.databaseName)});function r(n){let s=We[n];Tr.trace("Checking replication status of ",n,e?.databases),e?.databases===void 0||e.databases==="*"||e.databases.includes(n)||e.databases.some?.(i=>i.name===n)||!s?t(s,n,!0):pre(n)&&t(s,n,!1)}a(r,"forDatabase")}function pre(e){let t=We[e];for(let r in t)if(t[r].replicate)return!0}function W_(e){for(let t of e.getKeys({limit:1,reverse:!0}))return t}async function mre(e){let t={message:""};if(e.replicated){e.replicated=!1,Tr.trace?.("Replicating operation",e.operation,"to nodes",it.nodes.map(n=>n.name));let r=await Promise.allSettled(it.nodes.map(n=>af(n,e)));t.replicated=r.map((n,s)=>{let i=n.status==="rejected"?{status:"failed",reason:n.reason.toString()}:n.value;return i.node=it.nodes[s]?.name,i})}return t}var hs,Tr,gH,RH,Pc,of,AH,yH,bH,cre,lre,ua,la,sf,SH,Wy,zp,us=Oe(()=>{Pe();Vs();wl();mH();qr();hs=L(se()),Tr=L(W()),gH=require("crypto"),RH=require("fs");Q_();iu();Pc=L(M());_y();of=L(require("node:tls")),AH=L(_e()),yH=require("worker_threads"),cre=1,lre=[],ua=hs.default.get(Pc.CONFIG_PARAMS.REPLICATION_ENABLEROOTCAS)!==!1?new Set(of.rootCertificates):new Set;a(ure,"start");a(OH,"monitorNodeCAs");a(dre,"disableReplication");a(_re,"assignReplicationSource");a(IH,"setReplicator");sf=new Map;a(wH,"getConnection");SH=new Map;a(fre,"getConnectionByName");a(af,"sendOperationToNode");a(au,"subscribeToNode");a(Bp,"unsubscribeFromNode");a(Ere,"getCommonNameFromCert");a(ot,"getThisNodeName");a(hre,"clearThisNodeName");Object.defineProperty(it,"hostname",{get(){return ot()}});a(TH,"getHostFromListeningPort");a(jp,"getPortFromListeningPort");a(Wp,"getThisNodeId");it.replication={getThisNodeId:Wp,exportIdMapping:Y_};a(na,"getThisNodeUrl");a(Qp,"hostnameToUrl");a(zs,"urlToNodeName");a(ra,"forEachReplicatedDatabase");a(pre,"hasExplicitlyReplicatedTable");a(W_,"lastTimeInAuditStore");a(mre,"replicateOperation")});var em=N((dIe,MH)=>{"use strict";var Eu=Uh(),hu=o0(),Sre=W(),Tre=require("uuid").v4,uIe=require("clone"),Xp=no(),pu=M(),gre=require("util"),da=Bn(),{handleHDBError:mn,hdb_errors:Rre}=_e(),{HDB_ERROR_MSGS:Jp,HTTP_STATUS_CODES:Sn}=Rre,{SchemaEventMsg:Zp}=qs(),CH=mr(),{getDatabases:Are}=(Pe(),oe(lt)),{transformReq:mu}=te(),{replicateOperation:DH}=(us(),oe(ca));MH.exports={createSchema:yre,createSchemaStructure:PH,createTable:bre,createTableStructure:LH,createAttribute:Cre,dropSchema:Ore,dropTable:Nre,dropAttribute:Ire,getBackup:Dre};async function yre(e){let t=await PH(e);return Xp.signalSchemaChange(new Zp(process.pid,e.operation,e.schema)),t}a(yre,"createSchema");async function PH(e){let t=Eu.schema_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);if(mu(e),!await hu.checkSchemaExists(e.schema))throw mn(new Error,Jp.SCHEMA_EXISTS_ERR(e.schema),Sn.BAD_REQUEST,pu.LOG_LEVELS.ERROR,Jp.SCHEMA_EXISTS_ERR(e.schema),!0);return await da.createSchema(e),`database '${e.schema}' successfully created`}a(PH,"createSchemaStructure");async function bre(e){return mu(e),e.hash_attribute=e.primary_key??e.hash_attribute,await LH(e)}a(bre,"createTable");async function LH(e){let t=Eu.create_table_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);if(Eu.validateTableResidence(e.residence),!await hu.checkSchemaTableExists(e.schema,e.table))throw mn(new Error,Jp.TABLE_EXISTS_ERR(e.schema,e.table),Sn.BAD_REQUEST,pu.LOG_LEVELS.ERROR,Jp.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:Tre(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await da.createTable(n,e);else throw mn(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Sn.BAD_REQUEST);else await da.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(LH,"createTableStructure");async function Ore(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=Eu.schema_object(e),n=t??r;if(n)throw mn(n,n.message,Sn.BAD_REQUEST,void 0,void 0,!0);mu(e);let s=await hu.checkSchemaExists(e.schema);if(s)throw mn(new Error,s,Sn.NOT_FOUND,pu.LOG_LEVELS.ERROR,s,!0);let i=await hu.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);await da.dropSchema(e),Xp.signalSchemaChange(new Zp(process.pid,e.operation,e.schema)),await CH.purgeSchemaTableStreams(e.schema,o);let c=await DH(e);return c.message=`successfully deleted '${e.schema}'`,c}a(Ore,"dropSchema");async function Nre(e){let t=Eu.table_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);mu(e);let r=await hu.checkSchemaTableExists(e.schema,e.table);if(r)throw mn(new Error,r,Sn.NOT_FOUND,pu.LOG_LEVELS.ERROR,r,!0);await da.dropTable(e),await CH.purgeTableStream(e.schema,e.table);let n=await DH(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}a(Nre,"dropTable");async function Ire(e){let t=Eu.attribute_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);mu(e);let r=await hu.checkSchemaTableExists(e.schema,e.table);if(r)throw mn(new Error,r,Sn.NOT_FOUND,pu.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw mn(new Error,"You cannot drop a hash attribute",Sn.BAD_REQUEST,void 0,void 0,!0);if(pu.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw mn(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Sn.BAD_REQUEST,void 0,void 0,!0);try{return await da.dropAttribute(e),wre(e),Xp.signalSchemaChange(new Zp(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw Sre.error(`Got an error deleting attribute ${gre.inspect(e)}.`),n}}a(Ire,"dropAttribute");function wre(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(wre,"dropAttributeFromGlobal");async function Cre(e){mu(e);let t=Are()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw mn(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Sn.BAD_REQUEST,void 0,void 0,!0);return await da.createAttribute(e),Xp.signalSchemaChange(new Zp(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(Cre,"createAttribute");function Dre(e){return da.getBackup(e)}a(Dre,"getBackup")});var vH=N((fIe,UH)=>{"use strict";var{OPERATIONS_ENUM:Pre}=M(),jy=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Pre.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};UH.exports=jy});var zy=N((pIe,FH)=>{"use strict";var Lre=Bn(),hIe=vH(),tm=te(),rm=M(),Mre=se(),{handleHDBError:BH,hdb_errors:Ure}=_e(),{HDB_ERROR_MSGS:HH,HTTP_STATUS_CODES:xH}=Ure,vre=Object.values(rm.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),kH="To use this operation audit log must be enabled in harperdb-config.yaml";FH.exports=Bre;async function Bre(e){if(tm.isEmpty(e.schema))throw new Error(HH.SCHEMA_REQUIRED_ERR);if(tm.isEmpty(e.table))throw new Error(HH.TABLE_REQUIRED_ERR);if(!Mre.get(rm.CONFIG_PARAMS.LOGGING_AUDITLOG))throw BH(new Error,kH,xH.BAD_REQUEST,rm.LOG_LEVELS.ERROR,kH,!0);let t=tm.checkSchemaTableExist(e.schema,e.table);if(t)throw BH(new Error,t,xH.NOT_FOUND,rm.LOG_LEVELS.ERROR,t,!0);if(!tm.isEmpty(e.search_type)&&vre.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await Lre.readAuditLog(e)}a(Bre,"readAuditLog")});var qH=N((SIe,GH)=>{"use strict";var{OPERATIONS_ENUM:Hre}=M(),Qy=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Hre.GET_BACKUP,this.schema=t,this.table=r}};GH.exports=Qy});var KH=N((AIe,VH)=>{"use strict";var xre=Bn(),gIe=qH(),Jy=te(),kre=M(),RIe=se(),{handleHDBError:Fre,hdb_errors:Gre}=_e(),{HDB_ERROR_MSGS:$H,HTTP_STATUS_CODES:qre}=Gre;VH.exports=$re;async function $re(e){if(Jy.isEmpty(e.schema))throw new Error($H.SCHEMA_REQUIRED_ERR);if(Jy.isEmpty(e.table))throw new Error($H.TABLE_REQUIRED_ERR);let t=Jy.checkSchemaTableExist(e.schema,e.table);if(t)throw Fre(new Error,t,qre.NOT_FOUND,kre.LOG_LEVELS.ERROR,t,!0);return await xre.getBackup(read_audit_log_object)}a($re,"getBackup")});var JH=N((bIe,QH)=>{var Su=require("validate.js"),WH=Tt(),Tu=M(),{handleHDBError:Vre,hdb_errors:Kre}=_e(),{HDB_ERROR_MSGS:Qt,HTTP_STATUS_CODES:Yre}=Kre,Xy=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Wre={STRUCTURE_USER:"structure_user"},YH=Object.values(Tu.ROLE_TYPES_ENUM),jre="attribute_permissions",zre="attribute_name",{PERMS_CRUD_ENUM:gu}=Tu,Qre=[jre,...Object.values(gu)],jH=[gu.READ,gu.INSERT,gu.UPDATE],Jre=[zre,...jH];function Xre(e){let t=Xy();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,zH(e,t)}a(Xre,"addRoleValidation");function Zre(e){let t=Xy();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,zH(e,t)}a(Zre,"alterRoleValidation");function ene(e){let t=Xy();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,WH.validateObject(e,t)}a(ene,"dropRoleValidation");var tne=["operation","role","id","permission","hdb_user","hdb_auth_header","access"];function zH(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)tne.includes(n[o])||s.push(n[o]);s.length>0&&ir(Qt.INVALID_ROLE_JSON_KEYS(s),r);let i=WH.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{ir(o,r)}),e.permission){let o=rne(e);o&&ir(o,r),YH.forEach(c=>{e.permission[c]&&!Su.isBoolean(e.permission[c])&&ir(Qt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(YH.indexOf(o)<0){if(o===Wre.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let u=0,d=l.length;u<d;u++){let _=l[u];global.hdb_schema[_]||ir(Qt.SCHEMA_NOT_FOUND(_),r)}continue}ir(Qt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){ir(Qt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let u=c.tables[l];if(!l||!global.hdb_schema[o][l]){ir(Qt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(d=>{Qre.includes(d)||ir(Qt.INVALID_PERM_KEY(d),r,o,l)}),Object.values(gu).forEach(d=>{Su.isDefined(u[d])?Su.isBoolean(u[d])||ir(Qt.TABLE_PERM_NOT_BOOLEAN(d),r,o,l):ir(Qt.TABLE_PERM_MISSING(d),r,o,l)}),u.attribute_permissions===void 0){ir(Qt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){ir(Qt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}if(u.attribute_permissions){let d=global.hdb_schema[o][l].attributes.map(({attribute:E})=>E),_={read:!1,insert:!1,update:!1};for(let E in u.attribute_permissions){let f=u.attribute_permissions[E];if(Object.keys(f).forEach(T=>{!Jre.includes(T)&&T!==gu.DELETE&&ir(Qt.INVALID_ATTR_PERM_KEY(T),r,o,l)}),!Su.isDefined(f.attribute_name)){ir(Qt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=f.attribute_name;if(!d.includes(h)){ir(Qt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}jH.forEach(T=>{Su.isDefined(f[T])?Su.isBoolean(f[T])||ir(Qt.ATTR_PERM_NOT_BOOLEAN(T,h),r,o,l):ir(Qt.ATTR_PERM_MISSING(T,h),r,o,l)}),!_.read&&f.read===!0&&(_.read=!0),!_.insert&&f.insert===!0&&(_.insert=!0),!_.update&&f.update===!0&&(_.update=!0)}if(u.read===!1&&_.read===!0||u.insert===!1&&_.insert===!0||u.update===!1&&_.update===!0){let E=`${o}.${l}`;ir(Qt.MISMATCHED_TABLE_ATTR_PERMS(E),r,o,l)}}}}return nne(r)}a(zH,"customValidate");QH.exports={addRoleValidation:Xre,alterRoleValidation:Zre,dropRoleValidation:ene};function rne(e){let{operation:t,permission:r}=e;if(t===Tu.OPERATIONS_ENUM.ADD_ROLE||t===Tu.OPERATIONS_ENUM.ALTER_ROLE){let n=r.super_user===!0,s=r.cluster_user===!0;if(Object.keys(r).length>1&&(n||s)){if(s&&n)return Qt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?Tu.ROLE_TYPES_ENUM.SUPER_USER:Tu.ROLE_TYPES_ENUM.CLUSTER_USER;return Qt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(rne,"validateNoSUPerms");function nne(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:Qt.ROLE_PERMS_ERROR,...e};return Vre(new Error,n,Yre.BAD_REQUEST)}else return null}a(nne,"generateRolePermResponse");function ir(e,t,r,n){if(!r)t.main_permissions.push(e);else{let s=n?r+"_"+n:r;t.schema_permissions[s]?t.schema_permissions[s].push(e):t.schema_permissions[s]=[e]}}a(ir,"addPermError")});var lf=N((IIe,tx)=>{"use strict";var XH=un(),ZH=Vr(),sne=uc(),eb=JH(),tb=no(),NIe=require("uuid").v4,ine=require("util"),nm=M(),one=te(),rb=ZH.searchByValue,ane=ZH.searchByHash,cne=ine.promisify(sne.delete),lne=$s(),une=Vl(),{hdb_errors:dne,handleHDBError:Lc}=_e(),{HDB_ERROR_MSGS:ex,HTTP_STATUS_CODES:cf}=dne,{UserEventMsg:nb}=qs();tx.exports={addRole:_ne,alterRole:fne,dropRole:Ene,listRoles:hne};function Zy(e){try{e.hdb_auth_header&&delete e.hdb_auth_header,e.HDB_INTERNAL_PATH&&delete e.HDB_INTERNAL_PATH,e.operation&&delete e.operation,e.hdb_user&&delete e.hdb_user}catch{}return e}a(Zy,"scrubRoleDetails");async function _ne(e){let t=eb.addRoleValidation(e);if(t)throw t;e=Zy(e);let r={schema:"system",table:"hdb_role",search_attribute:"role",search_value:e.role,hash_attribute:"id",get_attributes:["*"]},n;try{n=Array.from(await rb(r)||[])}catch(i){throw Lc(i)}if(n&&n.length>0)throw Lc(new Error,ex.ROLE_ALREADY_EXISTS(e.role),cf.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 XH.insert(s),tb.signalUserChange(new nb(process.pid)),e=Zy(e),e}a(_ne,"addRole");async function fne(e){let t=eb.alterRoleValidation(e);if(t)throw t;e=Zy(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await XH.update(r)}catch(s){throw Lc(s)}if(n&&n?.message==="updated 0 of 1 records")throw Lc(new Error,"Invalid role id",cf.BAD_REQUEST,void 0,void 0,!0);return await tb.signalUserChange(new nb(process.pid)),e}a(fne,"alterRole");async function Ene(e){let t=eb.dropRoleValidation(e);if(t)throw Lc(new Error,t,cf.BAD_REQUEST,void 0,void 0,!0);let r=new une(nm.SYSTEM_SCHEMA_NAME,nm.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await ane(r));if(n.length===0)throw Lc(new Error,ex.ROLE_NOT_FOUND,cf.NOT_FOUND,void 0,void 0,!0);let s=new lne(nm.SYSTEM_SCHEMA_NAME,nm.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await rb(s)),o=!1;if(one.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw Lc(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,cf.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await cne(c),tb.signalUserChange(new nb(process.pid)),`${n[0].role} successfully deleted`}a(Ene,"dropRole");async function hne(){return rb({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(hne,"listRoles")});var ix=N((CIe,sx)=>{"use strict";var pne=se(),_a=require("joi"),mne=Tt(),rx=require("moment"),Sne=require("fs-extra"),sb=require("path"),Tne=require("lodash"),uf=M(),{LOG_LEVELS:Mc}=M(),gne="YYYY-MM-DD hh:mm:ss",Rne=sb.resolve(__dirname,"../logs");sx.exports=function(e){return mne.validateBySchema(e,Ane)};var Ane=_a.object({from:_a.custom(nx),until:_a.custom(nx),level:_a.valid(Mc.NOTIFY,Mc.FATAL,Mc.ERROR,Mc.WARN,Mc.INFO,Mc.DEBUG,Mc.TRACE),order:_a.valid("asc","desc"),limit:_a.number().min(1),start:_a.number().min(0),log_name:_a.custom(yne)});function nx(e,t){if(rx(e,rx.ISO_8601).format(gne)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(nx,"validateDatetime");function yne(e,t){if(Tne.invert(uf.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=pne.get(uf.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?uf.LOG_NAMES.HDB:e,i=s===uf.LOG_NAMES.INSTALL?sb.join(Rne,uf.LOG_NAMES.INSTALL):sb.join(n,s);return Sne.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(yne,"validateReadLogPath")});var ob=N((PIe,ax)=>{"use strict";var sm=M(),bne=W(),One=se(),Nne=ix(),ib=require("path"),ox=require("fs-extra"),{once:Ine}=require("events"),{handleHDBError:wne,hdb_errors:Cne}=_e(),{PACKAGE_ROOT:Dne}=M(),Pne=ib.join(Dne,"logs"),Lne=1e3,Mne=200;ax.exports=Une;async function Une(e){let t=Nne(e);if(t)throw wne(t,t.message,Cne.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=One.get(sm.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?sm.LOG_NAMES.HDB:e.log_name,s=n===sm.LOG_NAMES.INSTALL?ib.join(Pne,sm.LOG_NAMES.INSTALL):ib.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,l=c?new Date(e.from):void 0,u=e.until!==void 0,d=u?new Date(e.until):void 0,_=e.limit===void 0?Lne:e.limit,E=e.order===void 0?void 0:e.order,f=e.start===void 0?0:e.start,h=f+_,T=0;E==="desc"&&!l&&!d&&(T=Math.max(ox.statSync(s).size-(h+5)*Mne,0));let m=ox.createReadStream(s,{start:T});m.on("error",H=>{bne.error(H)});let g=0,S=[],b="",I;m.on("data",H=>{let X=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;H=b+H;let Y=0,V;for(;(V=X.exec(H))&&!m.destroyed;){I&&(I.message=H.slice(Y,V.index),B(I));let[ne,Q,de]=V,j=de.split("] ["),ae=j[0],Ae=j[1];j.splice(0,2),I={timestamp:Q,thread:ae,level:Ae,tags:j,message:""},Y=V.index+ne.length}b=H.slice(Y)}),m.on("end",H=>{m.destroyed||I&&(I.message=b.trim(),B(I))}),m.resume();function B(H){let X,Y,V;switch(!0){case(i&&c&&u):X=new Date(H.timestamp),Y=new Date(l),V=new Date(d),H.level===o&&X>=Y&&X<=V&&g<f?g++:H.level===o&&X>=Y&&X<=V&&(fa(H,E,S),g++,g===h&&m.destroy());break;case(i&&c):X=new Date(H.timestamp),Y=new Date(l),H.level===o&&X>=Y&&g<f?g++:H.level===o&&X>=Y&&(fa(H,E,S),g++,g===h&&m.destroy());break;case(i&&u):X=new Date(H.timestamp),V=new Date(d),H.level===o&&X<=V&&g<f?g++:H.level===o&&X<=V&&(fa(H,E,S),g++,g===h&&m.destroy());break;case(c&&u):X=new Date(H.timestamp),Y=new Date(l),V=new Date(d),X>=Y&&X<=V&&g<f?g++:X>=Y&&X<=V&&(fa(H,E,S),g++,g===h&&m.destroy());break;case i:H.level===o&&g<f?g++:H.level===o&&(fa(H,E,S),g++,g===h&&m.destroy());break;case c:X=new Date(H.timestamp),Y=new Date(l),X>=Y&&g<f?g++:X>=Y&&g>=f&&(fa(H,E,S),g++,g===h&&m.destroy());break;case u:X=new Date(H.timestamp),V=new Date(d),X<=V&&g<f?g++:X<=V&&g>=f&&(fa(H,E,S),g++,g===h&&m.destroy());break;default:g<f?g++:(fa(H,E,S),g++,g===h&&m.destroy())}}return a(B,"onLogMessage"),await Ine(m,"close"),S}a(Une,"readLog");function fa(e,t,r){t==="desc"?vne(e,r):t==="asc"?Bne(e,r):r.push(e)}a(fa,"pushLineToResult");function vne(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(vne,"insertDescending");function Bne(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(Bne,"insertAscending")});var im=N((HIe,dx)=>{"use strict";var ab=require("joi"),{string:Ru,boolean:cx,date:Hne}=ab.types(),xne=Tt(),{validateSchemaExists:MIe,validateTableExists:UIe,validateSchemaName:vIe}=Ti(),kne=M(),Fne=Ct(),lx=se();lx.initSync();var BIe=Ru.invalid(lx.get(kne.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(Fne.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),ux={operation:Ru.valid("add_node","update_node","set_node_replication"),node_name:Ru.optional(),subscriptions:ab.array().items({table:Ru.optional(),schema:Ru.optional(),database:Ru.optional(),subscribe:cx.required(),publish:cx.required().custom(qne),start_time:Hne.iso()})};function Gne(e){return xne.validateBySchema(e,ab.object(ux))}a(Gne,"addUpdateNodeValidator");function qne(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(qne,"checkForFalsy");dx.exports={addUpdateNodeValidator:Gne,validation_schema:ux}});var fx=N((kIe,_x)=>{var $ne=Tt(),Vne={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};_x.exports=function(e){return $ne.validateObject(e,Vne)}});var cb=N((GIe,px)=>{"use strict";var Kne=fx(),Au=require("passport"),Yne=require("passport-local").Strategy,Wne=require("passport-http").BasicStrategy,jne=require("util"),zne=xn(),hx=jne.callbackify(zne.findAndValidateUser),FIe=Dn(),Qne=M(),Ex=lu();Au.use(new Yne(function(e,t,r){hx(e,t,r)}));Au.use(new Wne(function(e,t,r){hx(e,t,r)}));Au.serializeUser(function(e,t){t(null,e)});Au.deserializeUser(function(e,t){t(null,e)});function Jne(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":Au.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===Qne.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?Ex.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):Ex.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:Au.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(Jne,"authorize");function Xne(e,t){let r=Kne(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(Xne,"checkPermissions");px.exports={authorize:Jne,checkPermissions:Xne}});var yu=N(($Ie,mx)=>{"use strict";var lb=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},ub=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};mx.exports={Node:lb,NodeSubscription:ub}});var Tx=N((KIe,Sx)=>{"use strict";var Zne=M().OPERATIONS_ENUM,db=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Zne.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Sx.exports=db});var df=N((WIe,gx)=>{"use strict";var _b=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},fb=class{static{a(this,"RemotePayloadSubscription")}constructor(t,r,n,s,i,o,c){this.schema=t,this.table=r,this.hash_attribute=n,this.publish=s,this.subscribe=i,this.start_time=o,c!==void 0&&(this.attributes=c)}};gx.exports={RemotePayloadObject:_b,RemotePayloadSubscription:fb}});var Ax=N((zIe,Rx)=>{"use strict";var Eb=class{static{a(this,"TableSizeObject")}constructor(t,r,n=0,s=0,i=0,o=0){this.schema=t,this.table=r,this.table_size=n,this.record_count=s,this.transaction_log_size=i,this.transaction_log_record_count=o}};Rx.exports=Eb});var bx=N((twe,yx)=>{"use strict";var ese=Ax(),JIe=Bt(),XIe=ht(),tse=W(),{getSchemaPath:ZIe,getTransactionAuditStorePath:ewe}=gt(),{getDatabases:rse}=(Pe(),oe(lt));yx.exports=nse;async function nse(e){let t=new ese;try{let r=rse()[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){tse.warn(`unable to stat table dbi due to ${r}`)}return t}a(nse,"lmdbGetTableSize")});var Nx=N((nwe,Ox)=>{"use strict";var hb=class{static{a(this,"SystemInformationObject")}constructor(t,r,n,s,i,o,c){this.system=t,this.time=r,this.cpu=n,this.memory=s,this.disk=i,this.network=o,this.harperdb_processes=c}};Ox.exports=hb});var Ou=N((lwe,Dx)=>{"use strict";var sse=require("fs-extra"),ise=require("path"),Qr=require("systeminformation"),Ea=W(),Ix=mr(),iwe=Ct(),bu=M(),ose=bx(),ase=ro(),{getThreadInfo:wx}=dt(),_f=se();_f.initSync();var cse=Nx(),{openEnvironment:owe}=ht(),{getSchemaPath:awe}=gt(),{database:cwe,databases:pb}=(Pe(),oe(lt)),om;Dx.exports={getHDBProcessInfo:gb,getNetworkInfo:Ab,getDiskInfo:Rb,getMemoryInfo:Tb,getCPUInfo:Sb,getTimeInfo:mb,getSystemInformation:yb,systemInformation:lse,getTableSize:bb,getMetrics:Ob};function mb(){return Qr.time()}a(mb,"getTimeInfo");async function Sb(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:u,...d}=await Qr.cpu();d.cpu_speed=await Qr.cpuCurrentSpeed();let{raw_currentload:_,raw_currentload_idle:E,raw_currentload_irq:f,raw_currentload_nice:h,raw_currentload_system:T,raw_currentload_user:m,cpus:g,...S}=await Qr.currentLoad();return S.cpus=[],g.forEach(b=>{let{raw_load:I,raw_load_idle:B,raw_load_irq:H,raw_load_nice:X,raw_load_system:Y,raw_load_user:V,...ne}=b;S.cpus.push(ne)}),d.current_load=S,d}catch(e){return Ea.error(`error in getCPUInfo: ${e}`),{}}}a(Sb,"getCPUInfo");async function Tb(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Qr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return Ea.error(`error in getMemoryInfo: ${e}`),{}}}a(Tb,"getMemoryInfo");async function gb(){let e={core:[],clustering:[]};try{let t=await Qr.processes(),r;try{r=Number.parseInt(await sse.readFile(ise.join(_f.get(bu.CONFIG_PARAMS.ROOTPATH),bu.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===bu.NODE_ERROR_CODES.ENOENT)Ea.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 Ea.error(`error in getHDBProcessInfo: ${t}`),e}}a(gb,"getHDBProcessInfo");async function Rb(){let e={};try{if(!_f.get(bu.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Qr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...u}=await Qr.fsStats();return e.read_write=u,e.size=await Qr.fsSize(),e}catch(t){return Ea.error(`error in getDiskInfo: ${t}`),e}}a(Rb,"getDiskInfo");async function Ab(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return _f.get(bu.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await Qr.networkInterfaceDefault(),e.latency=await Qr.inetChecksite("google.com"),(await Qr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:u,ieee8021xState:d,carrier_changes:_,...E}=n;e.interfaces.push(E)}),(await Qr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)})),e}catch(t){return Ea.error(`error in getNetworkInfo: ${t}`),e}}a(Ab,"getNetworkInfo");async function yb(){if(om!==void 0)return om;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Qr.osInfo();e=c;let l=await Qr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,om=e,om}catch(t){return Ea.error(`error in getSystemInformation: ${t}`),e}}a(yb,"getSystemInformation");async function bb(){let e=[],t=await ase.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await ose(n));return e}a(bb,"getTableSize");async function Ob(){let e={};for(let t in pb){let r=e[t]={},n=r.tables={};for(let s in pb[t])try{let i=pb[t][s];r.readers||(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[u,d,_]=l.trim().split(" ");return{pid:u,thread:d,txnid:_}}),i.primaryStore.auditStore&&(r.audit=i.auditStore.getStats()));let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){Ea.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(Ob,"getMetrics");async function Cx(){if(_f.get(bu.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await Ix.getNATSReferences(),t=await Ix.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(Cx,"getNatsStreamInfo");async function lse(e){let t=new cse;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await yb(),t.time=mb(),t.cpu=await Sb(),t.memory=await Tb(),t.disk=await Rb(),t.network=await Ab(),t.harperdb_processes=await gb(),t.table_size=await bb(),t.metrics=await Ob(),t.threads=await wx(),t.replication=await Cx(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await yb();break;case"time":t.time=mb();break;case"cpu":t.cpu=await Sb();break;case"memory":t.memory=await Tb();break;case"disk":t.disk=await Rb();break;case"network":t.network=await Ab();break;case"harperdb_processes":t.harperdb_processes=await gb();break;case"table_size":t.table_size=await bb();break;case"database_metrics":case"metrics":t.metrics=await Ob();break;case"threads":t.threads=await wx();break;case"replication":t.replication=await Cx();break;default:break}return t}a(lse,"systemInformation")});var Uc=N((dwe,Px)=>{"use strict";Px.exports={version:use,printVersion:dse};var am=jl();function use(){if(am)return am.version}a(use,"version");function dse(){am&&console.log(`HarperDB Version ${am.version}`)}a(dse,"printVersion")});var Di=N((hwe,vx)=>{"use strict";var _se=un(),Nb=te(),fse=require("util"),vc=M(),Lx=se();Lx.initSync();var Ese=cb(),Mx=Vr(),{Node:fwe,NodeSubscription:Ewe}=yu(),hse=Vl(),pse=Tx(),{RemotePayloadObject:mse,RemotePayloadSubscription:Sse}=df(),{handleHDBError:Tse,hdb_errors:gse}=_e(),{HTTP_STATUS_CODES:Rse,HDB_ERROR_MSGS:Ase}=gse,yse=$s(),bse=Ou(),Ose=Uc(),{getDatabases:Nse}=(Pe(),oe(lt)),Ise=fse.promisify(Ese.authorize),wse=Mx.searchByHash,Cse=Mx.searchByValue;vx.exports={authHeaderToUser:Dse,isEmpty:Pse,getNodeRecord:Lse,upsertNodeRecord:Mse,buildNodePayloads:Use,checkClusteringEnabled:vse,getAllNodeRecords:Bse,getSystemInfo:Hse,reverseSubscription:Ux};async function Dse(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await Ise(t,null),e}a(Dse,"authHeaderToUser");function Pse(e){return e==null}a(Pse,"isEmpty");async function Lse(e){let t=new hse(vc.SYSTEM_SCHEMA_NAME,vc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return wse(t)}a(Lse,"getNodeRecord");async function Mse(e){let t=new pse(vc.SYSTEM_SCHEMA_NAME,vc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return _se.upsert(t)}a(Mse,"upsertNodeRecord");function Ux(e){if(Nb.isEmpty(e.subscribe)||Nb.isEmpty(e.publish))throw new Error("Received invalid subscription object");let{schema:t,table:r,hash_attribute:n}=e,s={schema:t,table:r,hash_attribute:n};return e.subscribe===!0&&e.publish===!1?(s.subscribe=!1,s.publish=!0):e.subscribe===!1&&e.publish===!0?(s.subscribe=!0,s.publish=!1):(s.subscribe=e.subscribe,s.publish=e.publish),s}a(Ux,"reverseSubscription");function Use(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:u}=c,d=Nb.getTableHashAttribute(l,u),{subscribe:_,publish:E}=Ux(c),f=Nse()[l]?.[u],h=new Sse(l,u,d,E,_,c.start_time,f.schemaDefined?f.attributes:void 0);s.push(h)}return new mse(r,t,s,n)}a(Use,"buildNodePayloads");function vse(){if(!Lx.get(vc.CONFIG_PARAMS.CLUSTERING_ENABLED))throw Tse(new Error,Ase.CLUSTERING_NOT_ENABLED,Rse.BAD_REQUEST,void 0,void 0,!0)}a(vse,"checkClusteringEnabled");async function Bse(){let e=new yse(vc.SYSTEM_SCHEMA_NAME,vc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await Cse(e))}a(Bse,"getAllNodeRecords");async function Hse(){let e=await bse.getSystemInformation();return{hdb_version:Ose.version(),node_version:e.node_version,platform:e.platform}}a(Hse,"getSystemInfo")});var Ib=N((mwe,$x)=>{"use strict";var cm=mr(),Bx=te(),Hx=Ct(),xx=M(),lm=W(),kx=em(),xse=I_(),{RemotePayloadObject:kse}=df(),{handleHDBError:Fx,hdb_errors:Fse}=_e(),{HTTP_STATUS_CODES:Gx}=Fse,{NodeSubscription:qx}=yu();$x.exports=Gse;async function Gse(e,t){let r;try{r=await cm.request(`${t}.${Hx.REQUEST_SUFFIX}`,new kse(xx.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),lm.trace("Response from remote describe all request:",r)}catch(o){lm.error(`addNode received error from describe all request to remote node: ${o}`);let c=cm.requestErrorHandler(o,"add_node",t);throw Fx(new Error,c,Gx.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===Hx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw Fx(new Error,o,Gx.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===xx.SYSTEM_SCHEMA_NAME){await cm.createLocalTableStream(l,c);let h=new qx(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let u=Bx.doesSchemaExist(l),d=n[l]!==void 0,_=c?Bx.doesTableExist(l,c):!0,E=c?n?.[l]?.[c]!==void 0:!0;if(!u&&!d||!_&&!E){s.push(o);continue}if(!u&&d&&(lm.trace(`addNode creating schema: ${l}`),await kx.createSchema({operation:"create_schema",schema:l})),!_&&E){lm.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new xse(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await kx.createTable(h)}await cm.createLocalTableStream(l,c);let f=new qx(l,c,o.publish,o.subscribe);f.start_time=o.start_time,i.push(f)}return{added:i,skipped:s}}a(Gse,"reviewSubscriptions")});var Bc={};je(Bc,{addNodeBack:()=>Yse,removeNodeBack:()=>Wse,setNode:()=>Kse});async function Kse(e){e.node_name&&!e.hostname&&(e.hostname=e.node_name),e.verify_tls!==void 0&&(e.rejectUnauthorized=e.verify_tls);let{url:t,hostname:r}=e;t?r||(r=e.hostname=zs(t)):t=Qp(r);let n=(0,Kx.validateBySchema)(e,Vse);if(n)throw(0,_o.handleHDBError)(n,n.message,$se.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new _o.ClientError("url or hostname is required for remove_node operation");let f=r,h=Sr(),T=await h.get(f);if(!T)throw new _o.ClientError(f+" does not exist");try{await af({url:T.url},{operation:ff.OPERATIONS_ENUM.REMOVE_NODE_BACK,name:T?.subscriptions?.length>0?ot():f},void 0)}catch(m){$n.warn(`Error removing node from target node ${f}, if it is offline and we be online in the future, you may need to clean up this node manually, or retry:`,m)}return await h.delete(f),`Successfully removed '${f}' from cluster`}if(!t)throw new _o.ClientError("url required for this operation");let s=na();if(s==null)throw new _o.ClientError("replication url is missing from harperdb-config.yaml");let i,o,c;if(t?.startsWith("wss:")){i=await(0,ps.getReplicationCert)();let f=await(0,ps.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,ps.createCsr)(),$n.info("Sending CSR to target node:",t)):f&&(c=f.certificate,$n.info("Sending CA named",f.name,"to target node",t))}let l={operation:ff.OPERATIONS_ENUM.ADD_NODE_BACK,hostname:(0,Yx.get)(ff.CONFIG_PARAMS.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:o,cert_auth:c,authorization:e.retain_authorization?e.authorization:null};if(e.subscriptions?l.subscriptions=e.subscriptions.map(Vx):l.subscriptions=null,e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let f=Vx(e);l.subscribe=f.subscribe,l.publish=f.publish}e?.authorization?.username&&e?.authorization?.password&&(e.authorization="Basic "+Buffer.from(e.authorization.username+":"+e.authorization.password).toString("base64"));let u,d;try{u=await af({url:t},l,e)}catch(f){f.message=`Error returned from ${t}: `+f.message,$n.warn("Error adding node:",t,"to cluster:",f),d=f}if(o&&(!u?.certificate||!u?.certificate?.includes?.("BEGIN CERTIFICATE")))throw d?(d.message+=" and connection was required to sign certificate",d):new Error(`Unexpected certificate signature response from node ${t} response: ${JSON.stringify(u)}`);o&&($n.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,ps.setCertTable)({name:qse.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,ps.setCertTable)({name:ot(),uses:["https","operations","wss"],certificate:u.certificate,private_key_name:i?.options?.key_file,is_authority:!1,is_self_signed:!1}),c=u.signingCA);let _={url:t,ca:u?.usingCA};if(e.hostname&&(_.name=e.hostname),e.subscriptions?_.subscriptions=e.subscriptions:_.replicates=!0,e.start_time&&(_.start_time=typeof e.start_time=="string"?new Date(e.start_time).getTime():e.start_time),e.retain_authorization&&(_.authorization=e.authorization),_.replicates){let f={url:s,ca:c,replicates:!0,subscriptions:null};e.retain_authorization&&(f.authorization=e.authorization),e.start_time&&(f.start_time=e.start_time),await co(ot(),f)}await co(u?u.nodeName:_.name??zs(t),_);let E;return e.operation==="update_node"?E=`Successfully updated '${t}'`:E=`Successfully added '${t}' to cluster`,d&&(E+=" but there was an error updating target node: "+d.message),E}async function Yse(e){$n.trace("addNodeBack received request:",e);let t=await(0,ps.signCertificate)(e),r;e.csr?(r=t.signingCA,$n.info("addNodeBack received CSR from node:",e.url,"this node will use and respond with CA that was used to issue CSR")):(r=e?.cert_auth,$n.info("addNodeBack received CA from node:",e.url));let n={url:e.url,ca:r};e.subscriptions?n.subscriptions=e.subscriptions:(n.replicates=!0,n.subscriptions=null),e.start_time&&(n.start_time=e.start_time),e.authorization&&(n.authorization=e.authorization);let s=await(0,ps.getReplicationCertAuth)();if(n.replicates){let i={url:na(),ca:s?.certificate,replicates:!0,subscriptions:null};e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await co(ot(),i)}return await co(e.hostname,n),t.nodeName=ot(),t.usingCA=s?.certificate,$n.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function Wse(e){$n.trace("removeNodeBack received request:",e),await Sr().delete(e.name)}function Vx(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var ps,Kx,Nu,Yx,ff,$n,_o,qse,$se,Vse,Hc=Oe(()=>{ps=L(Xs()),Kx=L(Tt()),Nu=L(require("joi")),Yx=L(se()),ff=L(M());Q_();iu();us();$n=L(W()),_o=L(_e()),{pki:qse}=require("node-forge"),{HTTP_STATUS_CODES:$se}=_o.hdb_errors,Vse=Nu.default.object({hostname:Nu.default.string(),verify_tls:Nu.default.boolean(),replicates:Nu.default.boolean(),subscriptions:Nu.default.array()});a(Kse,"setNode");a(Yse,"addNodeBack");a(Wse,"removeNodeBack");a(Vx,"reverseSubscription")});var pf=N((Owe,jx)=>{"use strict";var{handleHDBError:um,hdb_errors:jse}=_e(),{HTTP_STATUS_CODES:dm}=jse,{addUpdateNodeValidator:zse}=im(),_m=W(),fm=M(),Wx=Ct(),Qse=te(),Ef=mr(),hf=Di(),wb=se(),Jse=Ib(),{Node:Xse,NodeSubscription:Zse}=yu(),{broadcast:eie}=dt(),{setNode:tie}=(Hc(),oe(Bc)),ywe=se(),bwe=M(),rie="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",nie="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",sie=wb.get(fm.CONFIG_PARAMS.CLUSTERING_NODENAME);jx.exports=iie;async function iie(e,t=!1){if(_m.trace("addNode called with:",e),wb.get(fm.CONFIG_PARAMS.REPLICATION_URL)||wb.get(fm.CONFIG_PARAMS.REPLICATION_HOSTNAME))return tie(e);hf.checkClusteringEnabled();let r=zse(e);if(r)throw um(r,r.message,dm.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let _=await hf.getNodeRecord(n);if(!Qse.isEmptyOrZeroLength(_))throw um(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,dm.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await Jse(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=rie,o;let c=hf.buildNodePayloads(s,sie,fm.OPERATIONS_ENUM.ADD_NODE,await hf.getSystemInfo()),l=[];for(let _=0,E=s.length;_<E;_++){let f=s[_];s[_].start_time===void 0&&delete s[_].start_time,l.push(new Zse(f.schema,f.table,f.publish,f.subscribe))}_m.trace("addNode sending remote payload:",c);let u;try{u=await Ef.request(`${n}.${Wx.REQUEST_SUFFIX}`,c)}catch(_){_m.error(`addNode received error from request: ${_}`);for(let f=0,h=s.length;f<h;f++){let T=s[f];T.publish=!1,T.subscribe=!1,await Ef.updateRemoteConsumer(T,n)}let E=Ef.requestErrorHandler(_,"add_node",n);throw um(new Error,E,dm.INTERNAL_SERVER_ERROR,"error",E)}if(u.status===Wx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let _=`Error returned from remote node ${n}: ${u.message}`;throw um(new Error,_,dm.INTERNAL_SERVER_ERROR,"error",_)}_m.trace(u);for(let _=0,E=s.length;_<E;_++){let f=s[_];await Ef.updateRemoteConsumer(f,n),f.subscribe===!0&&await Ef.updateConsumerIterator(f.schema,f.table,n,"start")}let d=new Xse(n,l,u.system_info);return await hf.upsertNodeRecord(d),eie({type:"nats_update"}),i.length>0?o.message=nie:o.message=`Successfully added '${n}' to manifest`,o}a(iie,"addNode")});var Lb=N((wwe,Qx)=>{"use strict";var{handleHDBError:Cb,hdb_errors:oie}=_e(),{HTTP_STATUS_CODES:Db}=oie,{addUpdateNodeValidator:aie}=im(),mf=W(),Em=M(),zx=Ct(),Iwe=te(),Sf=mr(),Tf=Di(),Pb=se(),{cloneDeep:cie}=require("lodash"),lie=Ib(),{Node:uie,NodeSubscription:die}=yu(),{broadcast:_ie}=dt(),{setNode:fie}=(Hc(),oe(Bc)),Eie="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",hie="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",pie=Pb.get(Em.CONFIG_PARAMS.CLUSTERING_NODENAME);Qx.exports=mie;async function mie(e){if(mf.trace("updateNode called with:",e),Pb.get(Em.CONFIG_PARAMS.REPLICATION_URL)??Pb.get(Em.CONFIG_PARAMS.REPLICATION_HOSTNAME))return fie(e);Tf.checkClusteringEnabled();let t=aie(e);if(t)throw Cb(t,t.message,Db.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Tf.getNodeRecord(r);s.length>0&&(n=cie(s));let{added:i,skipped:o}=await lie(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=Eie,c;let l=Tf.buildNodePayloads(i,pie,Em.OPERATIONS_ENUM.UPDATE_NODE,await Tf.getSystemInfo());for(let d=0,_=i.length;d<_;d++){let E=i[d];mf.trace(`updateNode updating work stream for node: ${r} subscription:`,E),i[d].start_time===void 0&&delete i[d].start_time}mf.trace("updateNode sending remote payload:",l);let u;try{u=await Sf.request(`${r}.${zx.REQUEST_SUFFIX}`,l)}catch(d){mf.error(`updateNode received error from request: ${d}`);let _=Sf.requestErrorHandler(d,"update_node",r);throw Cb(new Error,_,Db.INTERNAL_SERVER_ERROR,"error",_)}if(u.status===zx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${r}: ${u.message}`;throw Cb(new Error,d,Db.INTERNAL_SERVER_ERROR,"error",d)}mf.trace(u);for(let d=0,_=i.length;d<_;d++){let E=i[d];await Sf.updateRemoteConsumer(E,r),E.subscribe===!0?await Sf.updateConsumerIterator(E.schema,E.table,r,"start"):await Sf.updateConsumerIterator(E.schema,E.table,r,"stop")}return n||(n=[new uie(r,[],u.system_info)]),await Sie(n[0],i,u.system_info),o.length>0?c.message=hie:c.message=`Successfully updated '${r}'`,c}a(mie,"updateNode");async function Sie(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let l=0,u=e.subscriptions.length;l<u;l++){let d=n.subscriptions[l];if(d.schema===o.schema&&d.table===o.table){d.publish=o.publish,d.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new die(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await Tf.upsertNodeRecord(n),_ie({type:"nats_update"})}a(Sie,"updateNodeTable")});var tk=N((Dwe,ek)=>{"use strict";var Zx=require("joi"),{string:Jx}=Zx.types(),Tie=Tt(),Xx=M(),gie=se(),Rie=Ct();ek.exports=Aie;function Aie(e){let t=Jx.invalid(gie.get(Xx.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(Rie.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=Zx.object({operation:Jx.valid(Xx.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return Tie.validateBySchema(e,r)}a(Aie,"removeNodeValidator")});var Rf=N((Lwe,ok)=>{"use strict";var{handleHDBError:rk,hdb_errors:yie}=_e(),{HTTP_STATUS_CODES:nk}=yie,bie=tk(),gf=W(),sk=Di(),Oie=te(),Iu=M(),ik=Ct(),Mb=mr(),Ub=se(),{RemotePayloadObject:Nie}=df(),{NodeSubscription:Iie}=yu(),wie=N_(),Cie=uc(),{broadcast:Die}=dt(),{setNode:Pie}=(Hc(),oe(Bc)),Lie=Ub.get(Iu.CONFIG_PARAMS.CLUSTERING_NODENAME);ok.exports=Mie;async function Mie(e){if(gf.trace("removeNode called with:",e),Ub.get(Iu.CONFIG_PARAMS.REPLICATION_URL)??Ub.get(Iu.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Pie(e);sk.checkClusteringEnabled();let t=bie(e);if(t)throw rk(t,t.message,nk.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await sk.getNodeRecord(r);if(Oie.isEmptyOrZeroLength(n))throw rk(new Error,`Node '${r}' was not found.`,nk.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new Nie(Iu.OPERATIONS_ENUM.REMOVE_NODE,Lie,[]),i,o=!1;for(let l=0,u=n.subscriptions.length;l<u;l++){let d=n.subscriptions[l];d.subscribe===!0&&await Mb.updateConsumerIterator(d.schema,d.table,r,"stop");try{await Mb.updateRemoteConsumer(new Iie(d.schema,d.table,!1,!1),r)}catch(_){gf.error(_)}}try{i=await Mb.request(`${r}.${ik.REQUEST_SUFFIX}`,s),gf.trace("Remove node reply from remote node:",r,i)}catch(l){gf.error("removeNode received error from request:",l),o=!0}let c=new wie(Iu.SYSTEM_SCHEMA_NAME,Iu.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Cie.deleteRecord(c),Die({type:"nats_update"}),i?.status===ik.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(gf.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(Mie,"removeNode")});var lk=N((Uwe,ck)=>{"use strict";var ak=require("joi"),{string:Uie,array:vie}=ak.types(),Bie=Tt(),Hie=im();ck.exports=xie;function xie(e){let t=ak.object({operation:Uie.valid("configure_cluster").required(),connections:vie.items(Hie.validation_schema).required()});return Bie.validateBySchema(e,t)}a(xie,"configureClusterValidator")});var vb=N((Bwe,Ek)=>{"use strict";var uk=M(),hm=W(),kie=te(),Fie=se(),Gie=Rf(),qie=pf(),$ie=Di(),Vie=lk(),{handleHDBError:dk,hdb_errors:Kie}=_e(),{HTTP_STATUS_CODES:_k}=Kie,Yie="Configure cluster complete.",Wie="Failed to configure the cluster. Check the logs for more details.",jie="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";Ek.exports=zie;async function zie(e){hm.trace("configure cluster called with:",e);let t=Vie(e);if(t)throw dk(t,t.message,_k.BAD_REQUEST,void 0,void 0,!0);let r=await $ie.getAllNodeRecords(),n=[];if(Fie.get(uk.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let d=0,_=r.length;d<_;d++){let E=await fk(Gie,{operation:uk.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[d].name},r[d].name);n.push(E)}hm.trace("All results from configure_cluster remove node:",n)}let s=[],i=e.connections.length;for(let d=0;d<i;d++){let _=e.connections[d],E=await fk(qie,_,_.node_name);s.push(E)}hm.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,u=n.concat(s);for(let d=0,_=u.length;d<_;d++){let E=u[d];E.status==="rejected"&&(hm.error(E.node_name,E?.error?.message,E?.error?.stack),o.includes(E.node_name)||o.push(E.node_name)),(E?.result?.message?.includes?.("Successfully")||E?.result?.includes?.("Successfully"))&&(l=!0),!(typeof E.result=="string"&&E.result.includes("Successfully removed")||E.status==="rejected")&&c.push({node_name:E?.node_name,response:E?.result})}if(kie.isEmptyOrZeroLength(o))return{message:Yie,connections:c};if(l)return{message:jie,failed_nodes:o,connections:c};throw dk(new Error,Wie,_k.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(zie,"configureCluster");async function fk(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(fk,"functionWrapper")});var Sk=N((xwe,mk)=>{"use strict";var Af=require("joi"),Qie=Tt(),{validateSchemaExists:hk,validateTableExists:Jie,validateSchemaName:pk}=Ti(),Xie=Af.object({operation:Af.string().valid("purge_stream"),schema:Af.string().custom(hk).custom(pk).optional(),database:Af.string().custom(hk).custom(pk).optional(),table:Af.string().custom(Jie).required()});function Zie(e){return Qie.validateBySchema(e,Xie)}a(Zie,"purgeStreamValidator");mk.exports=Zie});var Bb=N((Fwe,Tk)=>{"use strict";var{handleHDBError:eoe,hdb_errors:toe}=_e(),{HTTP_STATUS_CODES:roe}=toe,noe=Sk(),soe=mr(),ioe=Di();Tk.exports=ooe;async function ooe(e){e.schema=e.schema??e.database;let t=noe(e);if(t)throw eoe(t,t.message,roe.BAD_REQUEST,void 0,void 0,!0);ioe.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await soe.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(ooe,"purgeStream")});var mm=N((qwe,Nk)=>{"use strict";var xb=Di(),aoe=mr(),pm=se(),wu=M(),xc=Ct(),coe=te(),Hb=W(),{RemotePayloadObject:loe}=df(),{ErrorCode:gk}=require("nats"),{parentPort:Rk}=require("worker_threads"),{onMessageByType:uoe}=dt(),{getThisNodeName:doe}=(us(),oe(ca)),{requestClusterStatus:_oe}=(Q_(),oe(gB)),Ak=pm.get(wu.CONFIG_PARAMS.CLUSTERING_ENABLED),yk=pm.get(wu.CONFIG_PARAMS.CLUSTERING_NODENAME);Nk.exports={clusterStatus:foe,buildNodeStatus:Ok};var bk;uoe("cluster-status",async e=>{bk(e)});async function foe(){if(pm.get(wu.CONFIG_PARAMS.REPLICATION_URL)||pm.get(wu.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;return Rk?(Rk.postMessage({type:"request-cluster-status"}),n=await new Promise(s=>{bk=s})):n=_oe(),n.node_name=doe(),n.is_enabled=!0,n}let e={node_name:yk,is_enabled:Ak,connections:[]};if(!Ak)return e;let t=await xb.getAllNodeRecords();if(coe.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(Ok(t[n],e.connections));return await Promise.allSettled(r),e}a(foe,"clusterStatus");async function Ok(e,t){let r=e.name,n=new loe(wu.OPERATIONS_ENUM.CLUSTER_STATUS,yk,void 0,await xb.getSystemInfo()),s,i,o=xc.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await aoe.request(xc.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===xc.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=xc.CLUSTER_STATUS_STATUSES.CLOSED,Hb.error(`Error getting node status from ${r} `,s))}catch(l){Hb.warn(`Error getting node status from ${r}`,l),l.code===gk.NoResponders?o=xc.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===gk.Timeout?o=xc.CLUSTER_STATUS_STATUSES.TIMEOUT:o=xc.CLUSTER_STATUS_STATUSES.CLOSED}let c=new Eoe(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!==wu.PRE_4_0_0_VERSION&&await xb.upsertNodeRecord(l)}catch(l){Hb.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(Ok,"buildNodeStatus");function Eoe(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(Eoe,"NodeStatusObject")});var Fb=N((Vwe,Ik)=>{"use strict";var{handleHDBError:hoe,hdb_errors:poe}=_e(),{HTTP_STATUS_CODES:moe}=poe,Soe=mr(),Toe=Di(),kb=te(),Sm=require("joi"),goe=Tt(),Roe=2e3,Aoe=Sm.object({timeout:Sm.number().min(1),connected_nodes:Sm.boolean(),routes:Sm.boolean()});Ik.exports=yoe;async function yoe(e){Toe.checkClusteringEnabled();let t=goe.validateBySchema(e,Aoe);if(t)throw hoe(t,t.message,moe.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||kb.autoCastBoolean(n),o=s===void 0||kb.autoCastBoolean(s),c={nodes:[]},l=await Soe.getServerList(r??Roe),u={};if(i)for(let d=0,_=l.length;d<_;d++){let E=l[d].statsz;E&&(u[l[d].server.name]=E.routes)}for(let d=0,_=l.length;d<_;d++){if(l[d].statsz)continue;let E=l[d].server,f=l[d].data;if(E.name.endsWith("-hub")){let h={name:E.name.slice(0,-4),response_time:l[d].response_time};i&&(h.connected_nodes=[],u[E.name]&&u[E.name].forEach(T=>{h.connected_nodes.includes(T.name.slice(0,-4))||h.connected_nodes.push(T.name.slice(0,-4))})),o&&(h.routes=f.cluster?.urls?f.cluster?.urls.map(T=>({host:T.split(":")[0],port:kb.autoCast(T.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(yoe,"clusterNetwork")});var Pk=N((Ywe,Dk)=>{"use strict";var Gb=require("joi"),wk=Tt(),{route_constraints:Ck}=gg();Dk.exports={setRoutesValidator:boe,deleteRoutesValidator:Ooe};function boe(e){let t=Gb.object({server:Gb.valid("hub","leaf"),routes:Ck.required()});return wk.validateBySchema(e,t)}a(boe,"setRoutesValidator");function Ooe(e){let t=Gb.object({routes:Ck.required()});return wk.validateBySchema(e,t)}a(Ooe,"deleteRoutesValidator")});var Tm=N((jwe,xk)=>{"use strict";var fo=wt(),qb=te(),ms=M(),Cu=se(),Lk=Pk(),{handleHDBError:Mk,hdb_errors:Noe}=_e(),{HTTP_STATUS_CODES:Uk}=Noe,vk="cluster routes successfully set",Bk="cluster routes successfully deleted";xk.exports={setRoutes:woe,getRoutes:Coe,deleteRoutes:Doe};function Ioe(e){let t=fo.getClusteringRoutes(),r=e.server==="hub"?t.hub_routes:t.leaf_routes,n=e.server==="hub"?t.leaf_routes:t.hub_routes,s=[],i=[];for(let o=0,c=e.routes.length;o<c;o++){let l=e.routes[o];l.port=qb.autoCast(l.port);let u=r.some(_=>_.host===l.host&&_.port===l.port),d=n.some(_=>_.host===l.host&&_.port===l.port);u||d?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?fo.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):fo.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:vk,set:i,skipped:s}}a(Ioe,"setRoutesNats");function woe(e){let t=Lk.setRoutesValidator(e);if(t)throw Mk(t,t.message,Uk.BAD_REQUEST,void 0,void 0,!0);if(Cu.get(ms.CONFIG_PARAMS.CLUSTERING_ENABLED))return Ioe(e);let r=[],n=[],s=Cu.get(ms.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{Hk(s,i)?n.push(i):(s.push(i),r.push(i))}),fo.updateConfigValue(ms.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:vk,set:r,skipped:n}}a(woe,"setRoutes");function Hk(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(Hk,"existsInArray");function Coe(){if(Cu.get(ms.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=fo.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return Cu.get(ms.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(Coe,"getRoutes");function Doe(e){let t=Lk.deleteRoutesValidator(e);if(t)throw Mk(t,t.message,Uk.BAD_REQUEST,void 0,void 0,!0);if(Cu.get(ms.CONFIG_PARAMS.CLUSTERING_ENABLED))return Poe(e);let r=[],n=[],s=Cu.get(ms.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{Hk(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),fo.updateConfigValue(ms.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:Bk,deleted:r,skipped:n}}a(Doe,"deleteRoutes");function Poe(e){let t=fo.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],o=!1,c=!1;for(let l=0,u=e.routes.length;l<u;l++){let d=e.routes[l],_=!1;for(let E=0,f=r.length;E<f;E++){let h=r[E];if(d.host===h.host&&d.port===h.port){r.splice(E,1),_=!0,o=!0,s.push(d);break}}if(!_){let E=!0;for(let f=0,h=n.length;f<h;f++){let T=n[f];if(d.host===T.host&&d.port===T.port){n.splice(f,1),c=!0,E=!1,s.push(d);break}}E&&i.push(d)}}return o&&(r=qb.isEmptyOrZeroLength(r)?null:r,fo.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=qb.isEmptyOrZeroLength(n)?null:n,fo.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:Bk,deleted:s,skipped:i}}a(Poe,"deleteRoutesNats")});var Fk=N((Qwe,kk)=>{"use strict";var yf=require("alasql"),kc=require("recursive-iterator"),Zs=W(),Loe=te(),bf=M(),$b=class{static{a(this,"sql_statement_bucket")}constructor(t){this.ast=t,this.affected_attributes=new Map,this.table_lookup=new Map,this.schema_lookup=new Map,this.table_to_schema_lookup=new Map,Uoe(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=>bf.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=>!bf.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][bf.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=Moe(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=>!bf.SEARCH_WILDCARDS.includes(u));c.forEach(({attribute_name:u})=>{let d=new yf.yy.Column({columnid:u});s.tableid&&(d.tableid=s.tableid),this.ast.columns.push(d),l.includes(u)||l.push(u)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function Moe(e){return e.filter(t=>t[bf.PERMS_CRUD_ENUM.READ])}a(Moe,"filterReadRestrictedAttrs");function Uoe(e,t,r,n,s){voe(e,t,r,n,s)}a(Uoe,"interpretAST");function Of(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(Of,"addSchemaTableToMap");function voe(e,t,r,n,s){if(!e){Zs.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof yf.yy.Insert?koe(e,t,r):e instanceof yf.yy.Select?Boe(e,t,r,n,s):e instanceof yf.yy.Update?Hoe(e,t,r):e instanceof yf.yy.Delete?xoe(e,t,r):Zs.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(voe,"getRecordAttributesAST");function Boe(e,t,r,n,s){if(!e){Zs.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(Loe.isEmptyOrZeroLength(i)){Zs.error("No schema specified");return}e.from.forEach(c=>{Of(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),Of(c.table,t,r,n,s)});let o=new kc(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,u=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(u).has(l))if(r.has(l))l=r.get(l);else{Zs.info(`table specified as ${l} not found.`);return}t.get(u).get(l).indexOf(c.columnid)<0&&t.get(u).get(l).push(c.columnid)}if(e.where){let c=new kc(e.where),l=e.from[0].tableid;for(let{node:u}of c)if(u&&u.columnid){let d=u.tableid?u.tableid:l;if(!t.get(i).has(d))if(r.has(d))d=r.get(d);else{Zs.info(`table specified as ${d} not found.`);continue}t.get(i).get(d).indexOf(u.columnid)<0&&t.get(i).get(d).push(u.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new kc(c.on);for(let{node:u}of l)if(u&&u.columnid){let d=u.tableid,_=s.get(d);if(!t.get(_).has(d))if(r.has(d))d=r.get(d);else{Zs.info(`table specified as ${d} not found.`);continue}t.get(_).get(d).indexOf(u.columnid)<0&&t.get(_).get(d).push(u.columnid)}}),e.order){let c=new kc(e.order);for(let{node:l}of c)if(l&&l.columnid){let u=l.tableid,d=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(d).has(u))if(r.has(u))u=r.get(u);else{Zs.info(`table specified as ${u} not found.`);return}t.get(d).get(u).indexOf(l.columnid)<0&&t.get(d).get(u).push(l.columnid)}}}a(Boe,"getSelectAttributes");function Hoe(e,t,r){if(!e){Zs.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new kc(e.columns),s=e.table.databaseid;Of(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&Vb(e.table.tableid,s,i.columnid,t,r)}a(Hoe,"getUpdateAttributes");function xoe(e,t,r){if(!e){Zs.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new kc(e.where),s=e.table.databaseid;Of(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&Vb(e.table.tableid,s,i.columnid,t,r)}a(xoe,"getDeleteAttributes");function koe(e,t,r){if(!e){Zs.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new kc(e.columns),s=e.into.databaseid;Of(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&Vb(e.into.tableid,s,i.columnid,t,r)}a(koe,"getInsertAttributes");function Vb(e,t,r,n,s){if(!n.get(t))return;let i=e;n.get(t).has(i)||(i=s.get(i)),n.get(t).get(i).push(r)}a(Vb,"pushAttribute");kk.exports=$b});var Wb=N((Xwe,Vk)=>{var gm=dc(),Gk=require("chalk"),Vn=W(),qk=require("prompt"),{promisify:Foe}=require("util"),Kb=M(),Goe=require("fs-extra"),qoe=require("path"),$oe=te(),Voe=Uc(),$k=se();$k.initSync();var Koe=require("moment"),Yoe=Foe(qk.get),Woe=qoe.join($k.getHdbBasePath(),Kb.LICENSE_KEY_DIR_NAME,Kb.LICENSE_FILE_NAME,Kb.LICENSE_FILE_NAME);Vk.exports={getFingerprint:zoe,setLicense:joe,parseLicense:Yb,register:Qoe,getRegistrationInfo:Xoe};async function joe(e){if(e&&e.key&&e.company){try{Vn.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await Yb(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw Vn.error(r),Vn.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(joe,"setLicense");async function zoe(){let e={};try{e=await gm.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw Vn.error(r),Vn.error(t),new Error(r)}return e}a(zoe,"getFingerprint");async function Yb(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");Vn.info("Validating license input...");let r=gm.validateLicense(e,t);if(Vn.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(Vn.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(Vn.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{Vn.info("writing license to disk"),await Goe.writeFile(Woe,JSON.stringify({license_key:e,company:t}))}catch(n){throw Vn.error("Failed to write License"),n}return"Registration successful."}a(Yb,"parseLicense");async function Qoe(){let e=await Joe();return Yb(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(Qoe,"register");async function Joe(){let e=await gm.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:Gk.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:Gk.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{qk.start()}catch(n){Vn.error(n)}let r;try{r=await Yoe(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(Joe,"promptForRegistration");async function Xoe(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await gm.getLicense()}catch(r){throw Vn.error(`There was an error when searching licenses due to: ${r.message}`),r}if($oe.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=Voe.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=Koe.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(Xoe,"getRegistrationInfo")});var Yk=N((eCe,Kk)=>{"use strict";var Zoe=Ct(),jb=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,u,d,_,E,f,h){this.port=t,o===null&&(o=void 0),this.server_name=r+Zoe.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.reconnect_error_reports=100,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l},this.leafnodes={port:u,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:d,port:_,routes:E,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:f},HDB:{users:h}},this.system_account="SYS"}};Kk.exports=jb});var zk=N((rCe,jk)=>{"use strict";var Wk=Ct(),zb=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,u,d,_){this.port=t,_===null&&(_=void 0),this.server_name=r+Wk.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+Wk.SERVER_SUFFIX.LEAF},this.tls={cert_file:u,key_file:d,ca_file:_,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:_,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:_,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:l,jetstream:"enabled"}},this.system_account="SYS"}};jk.exports=zb});var Jk=N((sCe,Qk)=>{"use strict";var Qb=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};Qk.exports=Qb});var Zk=N((oCe,Xk)=>{"use strict";var eae=Ct(),Jb=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+eae.SERVER_SUFFIX.ADMIN,this.password=r}};Xk.exports=Jb});var bm=N((cCe,rF)=>{"use strict";var Fc=require("path"),Gc=require("fs-extra"),tae=Yk(),rae=zk(),nae=Jk(),sae=Zk(),Xb=xn(),Pu=te(),Tn=wt(),Am=M(),Nf=Ct(),{CONFIG_PARAMS:Jt}=Am,Lu=W(),If=se(),eF=to(),Zb=mr(),iae=Xs(),Du="clustering",oae=1e4,tF=50;rF.exports={generateNatsConfig:cae,removeNatsConfig:lae,getHubConfigPath:aae};function aae(){let e=If.get(Jt.ROOTPATH);return Fc.join(e,Du,Nf.NATS_CONFIG_FILES.HUB_SERVER)}a(aae,"getHubConfigPath");async function cae(e=!1,t=void 0){let r=If.get(Jt.ROOTPATH);Gc.ensureDirSync(Fc.join(r,"clustering","leaf")),If.initSync();let n=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_CERT_AUTH),s=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_PRIVATEKEY),i=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_CERTIFICATE);!await Gc.exists(i)&&!await Gc.exists(!n)&&await iae.createNatsCerts();let o=Fc.join(r,Du,Nf.PID_FILES.HUB),c=Fc.join(r,Du,Nf.PID_FILES.LEAF),l=Tn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=Fc.join(r,Du,Nf.NATS_CONFIG_FILES.HUB_SERVER),d=Fc.join(r,Du,Nf.NATS_CONFIG_FILES.LEAF_SERVER),_=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_INSECURE),E=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_VERIFY),f=Tn.getConfigFromFile(Jt.CLUSTERING_NODENAME),h=Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await Zb.checkNATSServerInstalled()||ym("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let T=await Xb.listUsers(),m=Tn.getConfigFromFile(Jt.CLUSTERING_USER),g=await Xb.getClusterUser();(Pu.isEmpty(g)||g.active!==!0)&&ym(`Invalid cluster user '${m}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await Rm(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await Rm(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await Rm(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),await Rm(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let S=[],b=[];for(let[ne,Q]of T.entries())Q.role?.role===Am.ROLE_TYPES_ENUM.CLUSTER_USER&&Q.active&&(S.push(new sae(Q.username,eF.decrypt(Q.hash))),b.push(new nae(Q.username,eF.decrypt(Q.hash))));let I=[],{hub_routes:B}=Tn.getClusteringRoutes();if(!Pu.isEmptyOrZeroLength(B))for(let ne of B)I.push(`tls://${g.sys_name_encoded}:${g.uri_encoded_d_hash}@${ne.host}:${ne.port}`);let H=new tae(Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),f,o,i,s,n,_,E,h,Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NAME),Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),I,S,b);n==null&&(delete H.tls.ca_file,delete H.leafnodes.tls.ca_file),t=Pu.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===Am.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Gc.writeJson(u,H),Lu.trace(`Hub server config written to ${u}`));let X=`tls://${g.sys_name_encoded}:${g.uri_encoded_d_hash}@0.0.0.0:${h}`,Y=`tls://${g.uri_encoded_name}:${g.uri_encoded_d_hash}@0.0.0.0:${h}`,V=new rae(Tn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT),f,c,l,[X],[Y],S,b,i,s,n,_);n==null&&delete V.tls.ca_file,(t===void 0||t===Am.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Gc.writeJson(d,V),Lu.trace(`Leaf server config written to ${d}`))}a(cae,"generateNatsConfig");async function Rm(e){let t=If.get(e);return Pu.isEmpty(t)&&ym(`port undefined for '${e}'`),await Pu.isPortTaken(t)&&ym(`'${e}' port '${t}' is is in use by another process, check to see if HarperDB is already running or another process is using this port.`),!0}a(Rm,"isPortAvailable");function ym(e){let t=`Error generating clustering config: ${e}`;Lu.error(t),console.error(t),process.exit(1)}a(ym,"generateNatsConfigError");async function lae(e){let{port:t,config_file:r}=Zb.getServerConfig(e),{username:n,decrypt_hash:s}=await Xb.getClusterUser(),i=0,o=2e3;for(;i<tF;){try{let d=await Zb.createConnection(t,n,s,!1);if(d.protocol.connected===!0){d.close();break}}catch(d){Lu.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${d}`)}if(i++,i>=tF)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&&Lu.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await Pu.async_set_timeout(u)}let c="0".repeat(oae),l=Fc.join(If.get(Jt.ROOTPATH),Du,r);await Gc.writeFile(l,c),await Gc.remove(l),Lu.notify(e,"started.")}a(lae,"removeNatsConfig")});var cF=N((uCe,aF)=>{"use strict";var Kn=se(),uae=dc(),Fe=M(),wf=Ct(),Eo=require("path"),{PACKAGE_ROOT:Nm}=M(),nF=se(),Om=te(),Mu="/dev/null",dae=Eo.join(Nm,"launchServiceScripts"),sF=Eo.join(Nm,"utility/scripts"),_ae=Eo.join(sF,Fe.HDB_RESTART_SCRIPT),iF=Eo.resolve(Nm,"dependencies",`${process.platform}-${process.arch}`,wf.NATS_BINARY_NAME);function oF(){let t=uae.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 Om.noBootFile()&&(n[Fe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Om.getEnvCliRootPath()),{name:Fe.PROCESS_DESCRIPTORS.HDB,script:Fe.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:Nm}}a(oF,"generateMainServerConfig");var fae=9930;function Eae(){Kn.initSync(!0);let e=Kn.get(Fe.CONFIG_PARAMS.ROOTPATH),t=Eo.join(e,"clustering",wf.NATS_CONFIG_FILES.HUB_SERVER),r=Eo.join(Kn.get(Fe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Fe.LOG_NAMES.HDB),n=nF.get(Fe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=wf.LOG_LEVEL_FLAGS[Kn.get(Fe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==fae?"-"+n:""),script:iF,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 Kn.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Mu,i.error_file=Mu),i}a(Eae,"generateNatsHubServerConfig");var hae=9940;function pae(){Kn.initSync(!0);let e=Kn.get(Fe.CONFIG_PARAMS.ROOTPATH),t=Eo.join(e,"clustering",wf.NATS_CONFIG_FILES.LEAF_SERVER),r=Eo.join(Kn.get(Fe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Fe.LOG_NAMES.HDB),n=nF.get(Fe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=wf.LOG_LEVEL_FLAGS[Kn.get(Fe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==hae?"-"+n:""),script:iF,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 Kn.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Mu,i.error_file=Mu),i}a(pae,"generateNatsLeafServerConfig");function mae(){Kn.initSync();let e=Eo.join(Kn.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:dae,autorestart:!1};return Kn.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=Mu,t.error_file=Mu),t}a(mae,"generateClusteringUpgradeV4ServiceConfig");function Sae(){let e={[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.RESTART_HDB};return Om.noBootFile()&&(e[Fe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Om.getEnvCliRootPath()),{...{name:Fe.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:sF},script:_ae}}a(Sae,"generateRestart");function Tae(){return{apps:[oF()]}}a(Tae,"generateAllServiceConfigs");aF.exports={generateAllServiceConfigs:Tae,generateMainServerConfig:oF,generateRestart:Sae,generateNatsHubServerConfig:Eae,generateNatsLeafServerConfig:pae,generateClusteringUpgradeV4ServiceConfig:mae}});var Uu=N((fCe,AF)=>{"use strict";var at=M(),gae=te(),po=bm(),Im=mr(),ho=Ct(),ha=cF(),wm=se(),qc=W(),Rae=Di(),{startWorker:lF,onMessageFromWorkers:Aae}=dt(),yae=Ou(),_Ce=require("util"),bae=require("child_process"),Oae=require("fs"),{execFile:Nae}=bae,Xe;AF.exports={enterPM2Mode:Iae,start:pa,stop:eO,reload:dF,restart:_F,list:tO,describe:hF,connect:mo,kill:Lae,startAllServices:Mae,startService:rO,getUniqueServicesList:pF,restartAllServices:Uae,isServiceRegistered:mF,reloadStopStart:SF,restartHdb:EF,deleteProcess:Dae,startClusteringProcesses:gF,startClusteringThreads:RF,isHdbRestartRunning:Pae,isClusteringRunning:Bae,stopClustering:vae,reloadClustering:Hae,expectedRestartOfChildren:fF};var Cf=!1;Aae(e=>{e.type==="restart"&&wm.initSync(!0)});function Iae(){Cf=!0}a(Iae,"enterPM2Mode");function mo(){return Xe||(Xe=require("pm2")),new Promise((e,t)=>{Xe.connect((r,n)=>{r&&t(r),e(n)})})}a(mo,"connect");var Jr,wae=10,uF;function pa(e,t=!1){if(Cf)return Cae(e);let r=Nae(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let o=Jr.indexOf(r);o>-1&&Jr.splice(o,1),!uF&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<wae&&(Oae.existsSync(po.getHubConfigPath())?pa(e):(await po.generateNatsConfig(!0),pa(e),await new Promise(c=>setTimeout(c,3e3)),await po.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await po.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=wm.get(at.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,u=0,d;for(;l=c.exec(i);){if(l.index&&ho.LOG_LEVEL_HIERARCHY[o]>=ho.LOG_LEVEL_HIERARCHY[d||"info"]){let f=d===ho.LOG_LEVELS.ERR||d===ho.LOG_LEVELS.WRN?qc.OUTPUTS.STDERR:qc.OUTPUTS.STDOUT;qc.logCustomLevel(d||"info",f,n,i.slice(u,l.index).trim())}let[_,E]=l;u=l.index+_.length,d=ho.LOG_LEVELS[E]}if(ho.LOG_LEVEL_HIERARCHY[o]>=ho.LOG_LEVEL_HIERARCHY[d||"info"]){let _=d===ho.LOG_LEVELS.ERR||d===ho.LOG_LEVELS.WRN?qc.OUTPUTS.STDERR:qc.OUTPUTS.STDOUT;qc.logCustomLevel(d||"info",_,n,i.slice(u).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!Jr&&(Jr=[],!t)){let i=a(()=>{uF=!0,Jr&&(Jr.map(o=>o.kill()),process.exit(0))},"kill_children");process.on("exit",i),process.on("SIGINT",i),process.on("SIGQUIT",i),process.on("SIGTERM",i)}Jr.push(r)}a(pa,"start");function Cae(e){return new Promise(async(t,r)=>{try{await mo()}catch(n){r(n)}Xe.start(e,(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(s)})})}a(Cae,"startWithPM2");function eO(e){if(!Cf){for(let t of Jr||[])t.name===e&&(Jr.splice(Jr.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await mo()}catch(n){r(n)}Xe.stop(e,async(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.delete(e,(i,o)=>{i&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(o)})})})}a(eO,"stop");function dF(e){return new Promise(async(t,r)=>{try{await mo()}catch(n){r(n)}Xe.reload(e,(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(s)})})}a(dF,"reload");function _F(e){if(!Cf){fF();for(let t of Jr||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await mo()}catch(n){r(n)}Xe.restart(e,(n,s)=>{Xe.disconnect(),t(s)})})}a(_F,"restart");function fF(){for(let e of Jr||[])e.config&&(e.config.restarts=0)}a(fF,"expectedRestartOfChildren");function Dae(e){return new Promise(async(t,r)=>{try{await mo()}catch(n){r(n)}Xe.delete(e,(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(s)})})}a(Dae,"deleteProcess");async function EF(){await pa(ha.generateRestart())}a(EF,"restartHdb");async function Pae(){let e=await tO();for(let t in e)if(e[t].name===at.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(Pae,"isHdbRestartRunning");function tO(){return new Promise(async(e,t)=>{try{await mo()}catch(r){t(r)}Xe.list((r,n)=>{r&&(Xe.disconnect(),t(r)),Xe.disconnect(),e(n)})})}a(tO,"list");function hF(e){return new Promise(async(t,r)=>{try{await mo()}catch(n){r(n)}Xe.describe(e,(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(s)})})}a(hF,"describe");function Lae(){if(!Cf){for(let e of Jr||[])e.kill();Jr=[];return}return new Promise(async(e,t)=>{try{await mo()}catch(r){t(r)}Xe.killDaemon((r,n)=>{r&&(Xe.disconnect(),t(r)),Xe.disconnect(),e(n)})})}a(Lae,"kill");async function Mae(){try{await gF(),await RF(),await pa(ha.generateAllServiceConfigs())}catch(e){throw Xe?.disconnect(),e}}a(Mae,"startAllServices");async function rO(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case at.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=ha.generateMainServerConfig();break;case at.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=ha.generateNatsIngestServiceConfig();break;case at.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=ha.generateNatsReplyServiceConfig();break;case at.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=ha.generateNatsHubServerConfig(),await pa(r,t),await po.removeNatsConfig(e);return;case at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=ha.generateNatsLeafServerConfig(),await pa(r,t),await po.removeNatsConfig(e);return;case at.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=ha.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await pa(r)}catch(r){throw Xe?.disconnect(),r}}a(rO,"startService");async function pF(){try{let e=await tO(),t={};for(let r=0,n=e.length;r<n;r++){let s=e[r];t[s.name]===void 0&&(t[s.name]={name:s.name,exec_mode:s.pm2_env.exec_mode})}return t}catch(e){throw Xe?.disconnect(),e}}a(pF,"getUniqueServicesList");async function Uae(e=[]){try{let t=!1,r=await pF();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===at.PROCESS_DESCRIPTORS.HDB?t=!0:await _F(o))}t&&await SF(at.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Xe?.disconnect(),t}}a(Uae,"restartAllServices");async function mF(e){if(Jr?.find(r=>r.name===e))return!0;let t=await yae.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(mF,"isServiceRegistered");async function SF(e){let t=wm.get(at.CONFIG_PARAMS.THREADS_COUNT)??wm.get(at.CONFIG_PARAMS.THREADS),r=await hF(e),n=gae.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await eO(e),await rO(e)):e===at.PROCESS_DESCRIPTORS.HDB?await EF():await dF(e)}a(SF,"reloadStopStart");var TF;async function gF(e=!1){for(let t in at.CLUSTERING_PROCESSES){let r=at.CLUSTERING_PROCESSES[t];await rO(r,e)}}a(gF,"startClusteringProcesses");async function RF(){TF=lF(at.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:at.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await Im.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await Im.updateLocalStreams();let e=await Rae.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===at.PRE_4_0_0_VERSION){qc.info("Starting clustering upgrade 4.0.0 process"),lF(at.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(RF,"startClusteringThreads");async function vae(){for(let e in at.CLUSTERING_PROCESSES)if(e!==at.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===at.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await TF.terminate();else{let t=at.CLUSTERING_PROCESSES[e];await eO(t)}}a(vae,"stopClustering");async function Bae(){for(let e in at.CLUSTERING_PROCESSES){let t=at.CLUSTERING_PROCESSES[e];if(await mF(t)===!1)return!1}return!0}a(Bae,"isClusteringRunning");async function Hae(){await po.generateNatsConfig(!0),await Im.reloadNATSHub(),await Im.reloadNATSLeaf(),await po.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await po.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(Hae,"reloadClustering")});var iO={};je(iO,{compactOnStart:()=>xae,copyDb:()=>wF});async function xae(){Df.notify("Running compact on start"),console.log("Running compact on start");let e=(0,nO.get)(ma.CONFIG_PARAMS.ROOTPATH),t=new Map,r=ut();try{for(let n in r){if(n==="system")continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,Cm.join)(e,"backup",n+".mdb"),o=(0,Cm.join)(e,ma.DATABASES_DIR_NAME,n+"-copy.mdb"),c=await yF(n);console.log("Database",n,"before compact has a total record count of",c),t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await wF(n,o),console.log("Backing up",n,"to",i),await(0,$c.move)(s,i,{overwrite:!0})}vu();for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,$c.move)(i,s,{overwrite:!0}),await(0,$c.remove)((0,Cm.join)(e,ma.DATABASES_DIR_NAME,`${n}-copy.mdb-lock`));vu()}catch(n){Df.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,sO.updateConfigValue)(ma.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1);for(let[s,{db_path:i,backup_dest:o}]of t){console.error("Moving backup database",o,"back to",i);try{await(0,$c.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw vu(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await yF(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}.
14
+ `,"")}a(K0,"runCommand");async function ete(){try{await Pee.access(ny)}catch{return!1}let e=await K0(`${ny} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return Lee.eq(t,Xee)}a(ete,"checkNATSServerInstalled");async function cy(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await $0.getClusterUser();if(yc(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}js.trace("create nats connection called");let i=await qee({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:br.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:br.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:br.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),js.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&js.error("Error with Nats client connection, connection closed",o),i===zr&&Y0()}),i}a(cy,"createConnection");function Y0(){zr=void 0,gc=void 0,Ac=void 0,Rc=void 0}a(Y0,"clearClientCache");async function tte(){zr&&(await zr.drain(),zr=void 0,gc=void 0,Ac=void 0,Rc=void 0)}a(tte,"closeConnection");var zr,Rc;async function K_(){return Rc||(Rc=cy(br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),zr=await Rc),zr||Rc}a(K_,"getConnection");async function Y_(){if(gc)return gc;yc(zr)&&await K_();let{domain:e}=eu(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(yc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return gc=await zr.jetstreamManager({domain:e,timeout:6e4}),gc}a(Y_,"getJetStreamManager");async function W0(){if(Ac)return Ac;yc(zr)&&await K_();let{domain:e}=eu(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(yc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Ac=zr.jetstream({domain:e,timeout:6e4}),Ac}a(W0,"getJetStream");async function Ii(){let e=zr||await K_(),t=gc||await Y_(),r=Ac||await W0();return{connection:e,jsm:t,js:r}}a(Ii,"getNATSReferences");async function rte(e){let t=br.get(Je.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await $0.getClusterUser(),s=await cy(t,r,n),i=ay(),o=s.subscribe(i),c=[],l,u=(async()=>{for await(let d of o){let _=V0.decode(d.data);_.response_time=Date.now()-l,c.push(_)}})();return l=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await Np.async_set_timeout(e),await o.drain(),await s.close(),await u,c}a(rte,"getServerList");async function ly(e,t){let{jsm:r}=await Ii(),n=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:$ee.File,retention:Vee.Limits,subjects:t,discard:Kee.Old,max_msgs:s,max_bytes:i,max_age:n})}a(ly,"createLocalStream");async function j0(){let{jsm:e}=await Ii(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(j0,"listStreams");async function nte(e){let{jsm:t}=await Ii();await t.streams.delete(e)}a(nte,"deleteLocalStream");async function ste(e){let{connection:t}=await Ii(),r=[],n=ay(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(V0.decode(o.data))})();return await t.publish(`$JS.${e}.API.STREAM.LIST`,void 0,{reply:n}),await t.flush(),await s.drain(),await i,r}a(ste,"listRemoteStreams");async function ite(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ii(),i=k0(),o={durable_name:i,ack_policy:iy.Explicit};t&&(o.deliver_policy=oy.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let u=[];for await(let d of l){let _=sy(d.data),E={nats_timestamp:d.info.timestampNanos,nats_sequence:d.info.streamSequence,entry:_};if(d.headers&&(E.origin=d.headers.get(Dr.MSG_HEADERS.ORIGIN)),u.push(E),d.ack(),d.info.pending===0)break}return await c.delete(),u}a(ite,"viewStream");async function*ote(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ii(),i=k0(),o={durable_name:i,ack_policy:iy.Explicit};t&&(o.deliver_policy=oy.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let u of l){let d=sy(u.data);d[0]||(d=[d]);for(let _ of d){let E={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:_};u.headers&&(E.origin=u.headers.get(Dr.MSG_HEADERS.ORIGIN)),yield E}if(u.ack(),u.info.pending===0)break}await c.delete()}a(ote,"viewStreamIterator");async function ate(e,t,r,n){js.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=z0(n,r);let{js:s}=await Ii(),i=await wp(),o=`${e}.${i}`,c=n instanceof Uint8Array?n:q0.encode(n);try{js.trace(`publishToStream publishing to subject: ${o}`),Qee(c.length,"bytes-sent",e,n.operation,"replication"),await s.publish(o,c,{headers:r})}catch(l){if(l.code&&l.code.toString()==="503")return J0(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){js.trace(`publishToStream creating stream: ${t}`);let d=o.split(".");d[2]="*",await ly(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(ate,"publishToStream");function z0(e,t){t===void 0&&(t=Wee());let r=br.get(Je.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Dr.MSG_HEADERS.ORIGIN)&&r&&t.append(Dr.MSG_HEADERS.ORIGIN,r),t}a(z0,"addNatsMsgHeader");function eu(e){e=e.toLowerCase();let t=V_.join(br.get(Je.CONFIG_PARAMS.ROOTPATH),Jee);if(e===Je.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return yc(ry)&&(ry={port:q_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:q_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Dr.SERVER_SUFFIX.HUB,config_file:Dr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:V_.join(t,Dr.PID_FILES.HUB),hdb_nats_path:t}),ry;if(e===Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return yc(ty)&&(ty={port:q_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:q_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Dr.SERVER_SUFFIX.LEAF,config_file:Dr.NATS_CONFIG_FILES.LEAF_SERVER,domain:q_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Dr.SERVER_SUFFIX.LEAF,pid_file_path:V_.join(t,Dr.PID_FILES.LEAF),hdb_nats_path:t}),ty;js.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(eu,"getServerConfig");async function Q0(e,t,r,n){try{await e.consumers.add(t,{ack_policy:iy.Explicit,durable_name:r,deliver_policy:oy.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(Q0,"createConsumer");async function cte(e,t,r){await e.consumers.delete(t,r)}a(cte,"removeConsumer");function lte(e){return e.split(".")[1]}a(lte,"extractServerName");async function ute(e,t,r=6e4,n=ay()){if(!Np.isObject(t))throw new Error("data param must be an object");let s=q0.encode(t),{connection:i}=await Ii(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return sy(c.data)}a(ute,"request");function uy(e){return new Promise(async(t,r)=>{let n=Bee(ny,["--signal",`reload=${e}`],{cwd:__dirname}),s,i;n.on("error",o=>{r(o)}),n.stdout.on("data",o=>{i+=o.toString()}),n.stderr.on("data",o=>{s+=o.toString()}),n.stderr.on("close",o=>{s&&r(s),t(i)})})}a(uy,"reloadNATS");async function dte(){let{pid_file_path:e}=eu(Je.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await uy(e)}a(dte,"reloadNATSHub");async function _te(){let{pid_file_path:e}=eu(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await uy(e)}a(_te,"reloadNATSLeaf");function fte(e,t,r){let n;switch(e.code){case x0.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case x0.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(fte,"requestErrorHandler");async function Ete(e,t){let r=t+Dr.SERVER_SUFFIX.LEAF,{connection:n}=await Ii(),{jsm:s}=await Rte(r),{schema:i,table:o}=e,c=Ip.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await J0(async()=>{if(e.subscribe===!0)await Q0(s,c,n.info.server_name,l);else try{await cte(s,c,n.info.server_name)}catch(u){js.trace(u)}})}a(Ete,"updateRemoteConsumer");async function hte(e,t,r,n){let s=Ip.createNatsTableStreamName(e,t),i=r+Dr.SERVER_SUFFIX.LEAF,o={type:Je.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!G0&&Fee()<br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=ey();await c(o)}await xee(o),n==="stop"&&await Np.async_set_timeout(1e3)}a(hte,"updateConsumerIterator");function J0(e){return Hee.writeTransaction(Je.SYSTEM_SCHEMA_NAME,Je.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(J0,"exclusiveLock");async function X0(e,t){let r=Ip.createNatsTableStreamName(e,t),n=await wp(),s=Tte(e,t,n);await ly(r,[s])}a(X0,"createLocalTableStream");async function pte(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await X0(n,s)}}a(pte,"createTableStreams");async function Z0(e,t,r=void 0){if(br.get(Je.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=Ip.createNatsTableStreamName(e,t),{domain:s}=eu(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await K_()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")js.warn(n);else throw n}}a(Z0,"purgeTableStream");async function mte(e,t){if(br.get(Je.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await Z0(e,t[r])}a(mte,"purgeSchemaTableStreams");async function Ste(e){return(await Y_()).streams.info(e)}a(Ste,"getStreamInfo");function Tte(e,t,r){return`${Dr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(Tte,"createSubjectName");async function wp(){if($_)return $_;if($_=(await Y_())?.nc?.info?.server_name,$_===void 0)throw new Error("Unable to get jetstream manager server name");return $_}a(wp,"getJsmServerName");async function gte(){let e=await Y_(),t=await wp(),r=await j0();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=Ate(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let u=i.split(".");u[u.length-1]=t;let d=u.join(".");js.trace(`Updating stream subject name from: ${i} to: ${d}`),s.subjects[0]=d,await e.streams.update(s.name,s)}}a(gte,"updateLocalStreams");function Ate(e){let{config:t}=e,r=!1,n=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}a(Ate,"updateStreamLimits");async function Rte(e){let t,r;try{t=await zr.jetstream({domain:e}),r=await zr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw js.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(Rte,"connectToRemoteJS")});var bc=N(Dp=>{var Cp=W();for(let e of["trace","debug","info","warn","error","fatal","notify"])Cp.logsAtLevel(e)&&(Dp[e]=Cp[e]);Dp.loggerWithTag=e=>Cp.loggerWithTag(e,!0);Dp.setLogLevel=Cp.setLogLevel});function dy(e){let t=e.get(Pp),r=t?(0,tu.unpack)(t):null;r||(r={remoteNameToId:{}});let n=ot(),s=!1;r.nodeName=ot();let i=r.remoteNameToId;if(i[n]!==0){let o=0,c;for(let l in i){let u=i[l];u===0?c=l:u>o&&(o=u)}if(c){o++,i[c]=o;let l=[Symbol.for("seq"),o];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:j_(e)??1,nodes:[]})})}i[n]=0,e.putSync(Pp,(0,tu.pack)(r))}return r}function W_(e){return dy(e).remoteNameToId}function rB(e,t,r){let n=dy(r),s=n.remoteNameToId,i=new Map,o=!1;for(let c in t){let l=t[c],u=s[c];if(u==null){let d=0;for(let _ in s){let E=s[_];E>d&&(d=E)}u=d+1,s[c]=u,o=!0}i.set(l,u)}return o&&r.putSync(Pp,(0,tu.pack)(n)),i}function Lp(e,t){let r=dy(t),n=r.remoteNameToId,s=n[e];if(s==null){let i=0;for(let o in n){let c=n[o];c>i&&(i=c)}s=i+1,n[e]=s,t.putSync(Pp,(0,tu.pack)(r))}return tB.info?.("The remote node name map",e,n,s),s}var tB,tu,Pp,_y=Ie(()=>{tB=L(bc());us();tu=require("msgpackr"),Pp=Symbol.for("remote-ids");a(dy,"getIdMappingRecord");a(W_,"exportIdMapping");a(rB,"remoteToLocalNodeId");a(Lp,"getIdOfRemoteNode")});var ea,fy=Ie(()=>{ea=class{constructor(t){this.error=t}static{a(this,"ErrorResource")}isError=!0;allowRead(){throw this.error}allowUpdate(){throw this.error}allowCreate(){throw this.error}allowDelete(){throw this.error}getId(){throw this.error}getContext(){throw this.error}get(){throw this.error}post(){throw this.error}put(){throw this.error}delete(){throw this.error}connect(){throw this.error}getResource(){return this}publish(){throw this.error}subscribe(){throw this.error}}});var iB={};je(iB,{Resources:()=>Mp,keyArrayToString:()=>ru,resetResources:()=>yte,resources:()=>wi});function yte(){return wi=new Mp}function ru(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var nB,sB,Mp,wi,nu=Ie(()=>{mc();fy();nB=L(W()),sB=L(_e()),Mp=class extends Map{static{a(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,exportTypes:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s){let c=new sB.ServerError(`Conflicting paths for ${t}`);nB.default.error(c),i.Resource=new ea(c)}super.set(t,i);for(let[c,l]of this){let u=2;for(;(u=c.indexOf("/",u))>-1;){let d=this.get(c.slice(0,u));d&&(d.hasSubPaths=!0),u+=2}}}getMatch(t,r){let n=2,s;for(;(n=t.indexOf("/",n))>-1;){let c=t.slice(0,n),l=this.get(c);if(!l&&c.indexOf(".")>-1){let u=c.split(".");l=this.get(u[0])}if(l&&(!r||l.exportTypes?.[r]!==!1)){if(l.relativeURL=t.slice(n),!l.hasSubPaths)return l;s=l}n+=2}if(s)return s;let i=t.indexOf("?"),o=i>-1?t.slice(0,i):t;return s=this.get(o),!s&&o.indexOf(".")>-1&&(s=this.get(o.split(".")[0])),s&&(!r||s.exportTypes?.[r]!==!1)?s.relativeURL=i>-1?t.slice(i):"":s||(s=this.get(""),s&&(!r||s.exportTypes?.[r]!==!1)&&(t[0]!=="/"&&(t="/"+t),s.relativeURL=t)),s}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return Dt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(yte,"resetResources");a(ru,"keyArrayToString")});function py(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=aB,bte(e.primaryStore,e.auditStore)):(c=oB,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{cB(oB[i])})));let l=c[i]||(c[i]=[]);if(l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now()),s?.scope==="full-database")return;let u=l[o];u||(u=l[o]=new Map,u.envs=l,u.tableId=o,u.store=e.primaryStore),t=ru(t);let d=new hy(r);d.startTime=n;let _=u.get(t);return _?_.push(d):(u.set(t,_=[d]),_.tables=u,_.key=t),d.subscriptions=_,d}function cB(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),lB(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=xt(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,l=ru(c),u=0;do{let d=o.get(l);if(d){for(let E of d)if(!(u>0&&!(E.includeDescendants&&!(E.onlyChildren&&u>1)))){if(E.startTime>=n){(0,Ey.info)("omitting",c,E.startTime,n);continue}try{let f;E.supportsTransactions&&E.txnInProgress!==i.version&&(f=!0,E.txnInProgress||(r?r.push(E):r=[E]),E.txnInProgress=i.version),E.listener(c,i,n,f)}catch(f){console.error(f),(0,Ey.info)(f)}}}if(l==null)break;let _=l.lastIndexOf?.("/",l.length-2);_>-1?l=l.slice(0,_):l=null,u++}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function bte(e,t){let r=t||e,n=r.env;if(!n.hasAfterCommitListener){n.hasAfterCommitListener=!0;let s=n.path;r.on("aftercommit",({next:i,last:o,txnId:c})=>{let l=aB[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{cB(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function lB(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function uB(e){return e.nextTransaction||(py({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),lB(e)),e.nextTransaction}var Ey,oB,aB,hy,my=Ie(()=>{Ey=L(W());Pl();nu();Ji();oB=Object.create(null),aB=Object.create(null);a(py,"addSubscription");hy=class extends Mn{static{a(this,"Subscription")}listener;subscriptions;startTime;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;if(t){let r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};a(cB,"notifyFromTransactionData");a(bte,"listenToCommits");a(lB,"nextTransaction");a(uB,"whenNextTransaction")});var pB={};je(pB,{commits_awaiting_replication:()=>ou,getHDBNodeTable:()=>Sr,iterateRoutes:()=>Q_,shouldReplicateToNode:()=>z_,subscribeToNodeUpdates:()=>au});function Sr(){return dB||(dB=Et({table:"hdb_nodes",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"ca"},{attribute:"ca_info"},{attribute:"replicates"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function au(e){Sr().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;hB.debug?.("adding node",n,"on node",ot()," on process",process.pid),server.nodes=server.nodes.filter(s=>s.name!==n),r.type==="put"&&n!==ot()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r)),(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function z_(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&Sr().primaryStore.get(ot())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function Ote(){au(e=>{ta({},(t,r)=>{let n=e.name,s=_B.get(n);if(s||_B.set(n,s=new Map),s.has(r))return;let i;for(let o in t)if(i=t[o].auditStore,i)break;if(i){let o=new Float64Array(i.getUserSharedBuffer(["replicated",r,n],new ArrayBuffer(8),{callback:a(()=>{let c=o[0],l=o.lastTime;for(let{txnTime:u,onConfirm:d}of ou.get(r)||[])u>l&&u<=c&&d();o.lastTime=c},"callback")}));o.lastTime=0,s.set(r,o)}})})}function*Q_(e){for(let t of e.routes||[]){let r=t.url,n;if(typeof t=="string"?t.includes("://")?r=t:n=t:n=t.hostname??t.host,n&&!r){let s=su.default.get(iu.CONFIG_PARAMS.REPLICATION_SECUREPORT)??(!su.default.get(iu.CONFIG_PARAMS.REPLICATION_PORT)&&su.default.get(iu.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||su.default.get(iu.CONFIG_PARAMS.REPLICATION_PORT)||su.default.get(iu.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT);let o=i?.lastIndexOf?.(":");o>0&&(i=+i.slice(o+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){fB.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{replicates:!t.subscriptions,url:r,subscription:t.subscriptions,routes:t.routes,start_time:t.startTime}}}var fB,EB,su,iu,hB,dB,_B,ou,cu=Ie(()=>{Pe();us();lp();fB=require("worker_threads"),EB=L(_e()),su=L(se()),iu=L(M()),hB=L(bc());server.nodes=[];a(Sr,"getHDBNodeTable");a(au,"subscribeToNodeUpdates");a(z_,"shouldReplicateToNode");_B=new Map;Rv((e,t,r)=>{if(r>server.nodes.length)throw new EB.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);ou||(ou=new Map,Ote());let n=ou.get(e);return n||(n=[],ou.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(Ote,"startSubscriptionToReplications");a(Q_,"iterateRoutes")});var AB={};je(AB,{connectedToNode:()=>Oc,disconnectedFromNode:()=>du,ensureNode:()=>co,requestClusterStatus:()=>gB,startOnMainThread:()=>Ty});async function Ty(e){let t=0,r=ut();for(let i of Object.getOwnPropertyNames(r)){let o=r[i];for(let c in o){let l=o[c];if(l.auditStore){Up.set(i,j_(l.auditStore));break}}}Ci.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes.search([]))i.push(o);for(let o of Q_(e))try{let c=!o.subscriptions;if(c){let u=ot();Sr().primaryStore.get(u)===void 0&&await co(u,{name:u,url:e.url??ra(),replicates:!0})}let l=o.trusted!==!1;if(c&&o.replicates==null&&(o.replicates=!0),i.find(u=>u.url===o.url))continue;s(o)}catch(c){console.error(c)}au(s)});let n;function s(i,o=i?.name){let c=ot()&&o===ot()||ra()&&i?.url===ra();if(c){let _=!!i?.replicates;if(n!==void 0&&n!==_)for(let E of Sr().search([]))E.replicates&&E.name!==o&&s(E,E.name);n=_}if(_t.trace("Setting up node replication for",i),!i){for(let[_,E]of ao){let f;for(let[h,{worker:T,nodes:m}]of E){let g=m[0];if(g&&g.name==o){f=!0;for(let[S,{worker:b}]of E)E.delete(S),_t.warn("Node was deleted, unsubscribing from node",o,S,_),b?.postMessage({type:"unsubscribe-from-node",node:o,database:S,url:_});break}}if(f){ao.get(_).iterator.remove(),ao.delete(_);return}}return}if(c)return;if(!i.url){_t.info(`Node ${i.name} is missing url`);return}let l=ao.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(_t.info(`Added node ${i.name} at ${i.url} for process ${ot()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[_,E]of lu)if(i.url===E.url){lu.delete(_);break}lu.set(i.name,i)}let u=ut();if(l||(l=new Map,ao.set(i.url,l)),l.iterator=ta(e,(_,E,f)=>{f?d(E,!0):d(E,!1)}),i.subscriptions)for(let _ of i.subscriptions){let E=_.database||_.schema;u[E]||(_t.warn(`Database ${E} not found for node ${i.name}, making a subscription anyway`),d(E,!1))}function d(_,E){_t.trace("Setting up replication for database",_,"on node",i.name);let f=l.get(_),h,T=[{replicateByDefault:E,...i}];Up.has(_)&&(T.push({replicateByDefault:E,name:ot(),start_time:Up.get(_),end_time:Date.now(),replicates:!0}),Up.delete(_));let m=z_(i,_),g=Ci.workers.filter(S=>S.name==="http");if(f?(h=f.worker,f.nodes=T):m&&(t=t%g.length,h=g[t++],l.set(_,{worker:h,nodes:T,url:i.url}),h?.on("exit",()=>{l.get(_)?.worker===h&&(l.delete(_),d(_,E))})),m)setTimeout(()=>{let S={type:"subscribe-to-node",database:_,nodes:T};h?h.postMessage(S):uu(S)},Nte);else{_t.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[_],Sr().primaryStore.get(ot())?.replicates),Sr().primaryStore.get(ot())?.replicates||(n=!1);let S={type:"unsubscribe-from-node",database:_,url:i.url,name:i.name};h?h.postMessage(S):Bp(S)}}a(d,"onDatabase")}a(s,"onNodeUpdate"),du=a(function(i){try{_t.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(lu.keys()),c=o.sort(),l=c.indexOf(i.name||zs(i.url));if(l===-1){_t.warn("Disconnected node not found in node map",i.name,o);return}let u=ao.get(i.url),d=u?.get(i.database);if(!d){_t.warn("Disconnected node not found in replication map",i.database,u);return}if(d.connected=!1,i.finished)return;let _=d.nodes[0];if(!(_.replicates===!0||_.replicates?.sends||_.subscriptions?.length))return;let E=(l+1)%c.length;for(;l!==E;){let f=c[E],h=lu.get(f);u=ao.get(h.url);let T=u?.get(i.database);if(!T){E=(E+1)%c.length;continue}let{worker:m,nodes:g}=T,S=!1;for(let b of d.nodes){if(g.some(I=>I.name===b.name)){_t.info(`Disconnected node is already failing over to ${f} for ${i.database}`);continue}g.push(b),S=!0}if(!S){_t.info(`Disconnected node ${i.name} has no nodes to fail over to ${f}`);return}d.redirectingTo=T,_t.info(`Failing over ${i.database} from ${i.name} to ${f}`),m?m.postMessage({type:"subscribe-to-node",database:i.database,nodes:g}):uu({database:i.database,nodes:g});return}_t.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){_t.error("Error failing over node",o)}},"disconnectedFromNode"),Oc=a(function(i){let o=ao.get(i.url),c=o?.get(i.database);if(!c){_t.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,o);return}if(c.connected=!0,c.latency=i.latency,c.catchingUpFrom=i.lastSendTime,c.redirectingTo){let{worker:l,nodes:u}=c.redirectingTo,d=u.find(_=>_.name===i.name);c.redirectingTo=null,d&&(u.splice(u.indexOf(d),1),l?l.postMessage({type:"subscribe-to-node",database:i.database,nodes:u}):uu({database:i.database,nodes:u}))}},"connectedToNode"),(0,Ci.onMessageByType)("disconnected-from-node",du),(0,Ci.onMessageByType)("connected-to-node",Oc),(0,Ci.onMessageByType)("request-cluster-status",gB)}function gB(e,t){let r=[];for(let[n,s]of lu)try{let i=ao.get(s.url);_t.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let o=[];if(i){for(let[l,{worker:u,connected:d,nodes:_,latency:E,catchingUpFrom:f}]of i)o.push({database:l,connected:d,latency:E,catching_up_from:f?new Date(f).toISOString():"up-to-date",thread_id:u?.threadId,nodes:_.map(h=>h.name)});let c=(0,Sy.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){_t.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function co(e,t){let r=Sr();e=e??zs(t.url),t.name=e;try{if(t.ca){let s=new TB.X509Certificate(t.ca);t.ca_info={issuer:s.issuer.replace(/\n/g," "),subject:s.subject.replace(/\n/g," "),subject_alt_name:s.subjectAltName,serial_number:s.serialNumber,valid_from:s.validFrom,valid_to:s.validTo}}}catch(s){_t.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(_t.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.put(t);else{t.replicates&&!mB.default.get(SB.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],o=(0,Sy.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let u of o)if((c.database??c.schema)===(u.database??u.schema)&&c.table===u.table){u.publish=c.publish,u.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...o,...i];break}_t.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Ci,vp,_t,Sy,mB,SB,TB,Nte,ao,du,Oc,lu,Up,J_=Ie(()=>{Pe();Ci=L(dt());us();vp=require("worker_threads");cu();_t=L(W()),Sy=require("lodash"),mB=L(se()),SB=L(M()),TB=require("crypto"),Nte=200,ao=new Map,lu=new Map,Up=new Map;a(Ty,"startOnMainThread");a(gB,"requestClusterStatus");vp.parentPort&&(du=a(e=>{vp.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),Oc=a(e=>{vp.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Ci.onMessageByType)("subscribe-to-node",e=>{uu(e)}),(0,Ci.onMessageByType)("unsubscribe-from-node",e=>{Bp(e)}));a(co,"ensureNode")});var Hp=N((LNe,RB)=>{"use strict";var Ite=M().OPERATIONS_ENUM,gy=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=Ite.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};RB.exports=gy});var bB=N((UNe,yB)=>{"use strict";var wte={OPERATION:"operation",REFRESH:"refresh"},Ay=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},Ry=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};yB.exports={JWTTokens:Ay,TOKEN_TYPE_ENUM:wte,JWTRSAKeys:Ry}});var _u=N((BNe,wB)=>{"use strict";var Z_=require("jsonwebtoken"),yy=require("fs-extra"),by=te(),ds=M(),{handleHDBError:fn,hdb_errors:Cte}=_e(),{HTTP_STATUS_CODES:En,AUTHENTICATION_ERROR_MSGS:hn}=Cte,X_=W(),OB=Kh(),Iy=xn(),Dte=un().update,Pte=Hp(),Lte=no(),{UserEventMsg:Mte}=qs(),na=se();na.initSync();var Oy=require("path"),{JWTTokens:Ute,JWTRSAKeys:vte,TOKEN_TYPE_ENUM:xp}=bB(),Bte=na.get(ds.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?na.get(ds.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",Hte=na.get(ds.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?na.get(ds.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",kp="RS256",Ny;wB.exports={createTokens:xte,validateOperationToken:Fte,refreshOperationToken:kte,validateRefreshToken:IB,getJWTRSAKeys:ef};async function xte(e){if(by.isEmpty(e)||typeof e!="object")throw fn(new Error,hn.INVALID_AUTH_OBJECT,En.BAD_REQUEST,void 0,void 0,!0);if(by.isEmpty(e.username))throw fn(new Error,hn.USERNAME_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);if(by.isEmpty(e.password))throw fn(new Error,hn.PASSWORD_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await Iy.findAndValidateUser(e.username,e.password),!t)throw fn(new Error,hn.INVALID_CREDENTIALS,En.UNAUTHORIZED,void 0,void 0,!0)}catch(E){throw X_.error(E),fn(new Error,hn.INVALID_CREDENTIALS,En.UNAUTHORIZED,void 0,void 0,!0)}let r=await ef(),n=!1,s=!1;t.role&&t.role.permission&&(n=t.role.permission.super_user===!0,s=t.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s},o=await NB(i,r.private_key,r.passphrase),c=await Z_.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:Hte,algorithm:kp,subject:xp.REFRESH}),l=OB.hash(c),u=new Pte(ds.SYSTEM_SCHEMA_NAME,ds.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:l}]),d,_;try{d=await Dte(u)}catch(E){X_.error(E),_=E}if(_!==void 0||d.skipped_hashes.length>0)throw fn(new Error,hn.REFRESH_TOKEN_SAVE_FAILED,En.INTERNAL_SERVER_ERROR);return Lte.signalUserChange(new Mte(process.pid)),new Ute(o,c)}a(xte,"createTokens");async function NB(e,t,r){return await Z_.sign(e,{key:t,passphrase:r},{expiresIn:Bte,algorithm:kp,subject:xp.OPERATION})}a(NB,"signOperationToken");async function ef(){if(Ny===void 0)try{let e=Oy.join(na.getHdbBasePath(),ds.LICENSE_KEY_DIR_NAME,ds.JWT_ENUM.JWT_PASSPHRASE_NAME),t=Oy.join(na.getHdbBasePath(),ds.LICENSE_KEY_DIR_NAME,ds.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=Oy.join(na.getHdbBasePath(),ds.LICENSE_KEY_DIR_NAME,ds.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await yy.readFile(e)).toString(),s=(await yy.readFile(t)).toString(),i=(await yy.readFile(r)).toString();Ny=new vte(i,s,n)}catch(e){throw X_.error(e),fn(new Error,hn.NO_ENCRYPTION_KEYS,En.INTERNAL_SERVER_ERROR)}return Ny}a(ef,"getJWTRSAKeys");async function kte(e){if(!e)throw fn(new Error,hn.INVALID_BODY,En.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw fn(new Error,hn.REFRESH_TOKEN_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);await IB(e.refresh_token);let t=await ef(),r=await Z_.decode(e.refresh_token);return{operation_token:await NB({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(kte,"refreshOperationToken");async function Fte(e){try{let t=await ef(),r=await Z_.verify(e,t.public_key,{algorithms:kp,subject:xp.OPERATION});return await Iy.findAndValidateUser(r.username,void 0,!1)}catch(t){throw X_.warn(t),t.name&&t.name==="TokenExpiredError"?fn(new Error,hn.TOKEN_EXPIRED,En.FORBIDDEN):fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED)}}a(Fte,"validateOperationToken");async function IB(e){let t;try{let r=await ef(),n=await Z_.verify(e,r.public_key,{algorithms:kp,subject:xp.REFRESH});t=await Iy.findAndValidateUser(n.username,void 0,!1)}catch(r){throw X_.warn(r),r.name&&r.name==="TokenExpiredError"?fn(new Error,hn.TOKEN_EXPIRED,En.FORBIDDEN):fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED)}if(!OB.validate(t.refresh_token,e))throw fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED);return t}a(IB,"validateRefreshToken")});var Xs=N(ZB=>{"use strict";var sr=require("path"),pn=require("fs-extra"),fu=require("node-forge"),vB=require("net"),{generateKeyPair:Cy,X509Certificate:lo,createPrivateKey:BB}=require("crypto"),Gte=require("util");Cy=Gte.promisify(Cy);var yt=fu.pki,Qs=require("joi"),{v4:HB}=require("uuid"),{validateBySchema:My}=Tt(),pt=W(),_s=se(),Es=M(),{CONFIG_PARAMS:Eu}=Es,Js=Sg(),{ClientError:ia}=_e(),Ic=require("node:tls"),{relative:xB,join:qte}=require("node:path"),{CERT_PREFERENCE_APP:xNe,CERTIFICATE_VALUES:CB}=Js,$te=Wa(),Dy=wt(),DB=parseInt(process.version.slice(1))<20,{table:Vte,getDatabases:Kte,databases:wy}=(Pe(),oe(lt)),{getJWTRSAKeys:PB}=_u();Object.assign(ZB,{generateKeys:By,updateConfigCert:YB,createCsr:Zte,signCertificate:ere,setCertTable:hu,loadCertificates:$B,reviewSelfSignedCert:xy,createTLSSelector:zB,listCertificates:JB,addCertificate:ore,removeCertificate:cre,createNatsCerts:nre,generateCertsKeys:rre,getReplicationCert:rf,getReplicationCertAuth:Xte,renewSelfSigned:sre,hostnamesFromCert:XB,getKey:lre});var{urlToNodeName:kB,getThisNodeUrl:Yte,getThisNodeName:Gp,clearThisNodeName:Wte}=(us(),oe(ca)),{readFileSync:jte,watchFile:zte,statSync:FB}=require("node:fs"),kNe=se(),{getTicketKeys:Qte,onMessageFromWorkers:Jte}=dt(),sa=W(),{isMainThread:GB}=require("worker_threads"),{TLSSocket:qB,createSecureContext:FNe}=require("node:tls"),Uy=3650,tf=["127.0.0.1","localhost","::1"],vy=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];Jte(async e=>{e.type===Es.ITC_EVENT_TYPES.RESTART&&(_s.initSync(!0),await xy())});var Pr;function aa(){return Pr||(Pr=Kte().system.hdb_certificate,Pr||(Pr=Vte({table:"hdb_certificate",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]}))),Pr}a(aa,"getCertTable");async function rf(){let e=zB("operations-api"),t={secureContexts:null,setSecureContext:a(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(Gp());if(!r)return;let n=new lo(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(rf,"getReplicationCert");async function Xte(){aa();let e=(await rf()).options.cert,r=new lo(e).issuer.match(/CN=(.*)/)?.[1];return Pr.get(r)}a(Xte,"getReplicationCertAuth");var LB,oa=new Map;function $B(){if(LB)return;LB=!0;let e=[{configKey:Eu.TLS},{configKey:Eu.OPERATIONSAPI_TLS}];aa();let t=sr.dirname(Dy.getConfigFilePath()),r;for(let{configKey:n}of e){let s=Dy.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&xB(qte(t,"keys"),o);c&&MB(o,l=>{oa.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&GB){let d;MB(u,_=>{if(CB.cert===_)return;let E=i.hostname??i.hostnames??i.host??i.hosts;E&&!Array.isArray(E)&&(E=[E]);let f=WB(u),h=new lo(f),T;try{T=ky(h)}catch(b){pt.error("error extracting common name from certificate",b);return}if(T==null){pt.error("error extracting common name from certificate");return}if(h.checkIssued(new lo(CB.cert)))return;let m=Pr.primaryStore.get(T),g=FB(u).mtimeMs,S=!m||m.is_self_signed?1:m.file_timestamp??m.__updatedtime__;if(m&&g<=S){g<S&&pt.info(`Certificate ${T} at ${u} is older (${new Date(g)}) than the certificate in the database (${S>1?new Date(S):"only self signed certificate available"})`);return}r=Pr.put({name:T,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:f,private_key_name:c,is_authority:l,hostnames:E,file_timestamp:g,details:{issuer:h.issuer.replace(/\n/g," "),subject:h.subject.replace(/\n/g," "),subject_alt_name:h.subjectAltName,serial_number:h.serialNumber,valid_from:h.validFrom,valid_to:h.validTo}})},l?"certificate authority":"certificate")}}}}}return r}a($B,"loadCertificates");function MB(e,t,r){let n,s=a((i,o)=>{try{let c=i.mtimeMs;c&&c!==n&&(o&&GB&&pt.warn(`Reloading ${r}:`,e),n=c,t(WB(e)))}catch(c){pt.error(`Error loading ${r}:`,e,c)}},"loadFile");pn.existsSync(e)?s(FB(e)):pt.error(`${r} file not found:`,e),zte(e,{persistent:!1},s)}a(MB,"loadAndWatch");function Py(){let e=Yte();if(e==null){let t=tf[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return kB(e)}a(Py,"getHost");function Fp(){let e=Gp();if(e==null){let t=tf[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(Fp,"getCommonName");async function Zte(){let e=await rf(),t=yt.certificateFromPem(e.options.cert),r=yt.privateKeyFromPem(e.options.key);pt.info("Creating CSR with cert named:",e.name);let n=yt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:Fp()},...vy];pt.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:VB()}];return pt.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),fu.pki.certificationRequestToPem(n)}a(Zte,"createCsr");function VB(){let e=tf.includes(Fp())?tf:[...tf,Fp()];return e.includes(Py())||e.push(Py()),[{name:"basicConstraints",cA:!1,critical:!0},{name:"keyUsage",digitalSignature:!0,keyEncipherment:!0,critical:!0},{name:"extKeyUsage",serverAuth:!0,clientAuth:!0},{name:"nsCertType",client:!0,server:!0},{name:"subjectAltName",altNames:e.map(t=>vB.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a(VB,"certExtensions");async function ere(e){let t={},r=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;aa();for await(let d of Pr.search([]))if(d.is_authority&&!d.details.issuer.includes("HarperDB-Certificate-Authority")){if(oa.has(d.private_key_name)){n=oa.get(d.private_key_name),s=d;break}else if(d.private_key_name&&await pn.exists(sr.join(r,d.private_key_name))){n=pn.readFile(sr.join(r,d.private_key_name)),s=d;break}}if(!n){let d=await Ly();s=d.ca,n=d.private_key}n=yt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=yt.certificateFromPem(s.certificate);pt.info("Signing CSR with cert named",s.name);let o=yt.certificationRequestFromPem(e.csr);try{o.verify()}catch(d){return pt.error(d),new Error("Error verifying CSR: "+d.message)}let c=fu.pki.createCertificate();c.serialNumber=Math.random().toString().slice(2,10),c.validity.notBefore=new Date;let l=new Date;c.validity.notAfter=l,c.validity.notAfter.setDate(l.getDate()+Uy),pt.info("sign cert setting validity:",c.validity),pt.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),pt.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=o.getAttribute({name:"extensionRequest"}).extensions;pt.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=o.publicKey,c.sign(n,fu.md.sha256.create()),t.certificate=yt.certificateToPem(c)}else pt.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(ere,"signCertificate");async function tre(e,t){await hu({name:Gp(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await hu({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:yt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(tre,"createCertificateTable");async function hu(e){let t=new lo(e.certificate);e.details={issuer:t.issuer.replace(/\n/g," "),subject:t.subject.replace(/\n/g," "),subject_alt_name:t.subjectAltName,serial_number:t.serialNumber,valid_from:t.validFrom,valid_to:t.validTo},aa(),await Pr.patch(e)}a(hu,"setCertTable");async function By(){let e=await Cy("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:yt.publicKeyFromPem(e.publicKey),private_key:yt.privateKeyFromPem(e.privateKey)}}a(By,"generateKeys");async function Hy(e,t,r){let n=yt.createCertificate();if(!t){let o=await rf();t=yt.certificateFromPem(o.options.cert).publicKey}n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+Uy);let i=[{name:"commonName",value:Fp()},...vy];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(VB()),n.sign(e,fu.md.sha256.create()),yt.certificateToPem(n)}a(Hy,"generateCertificates");async function Ly(){let e=await JB(),t;for(let r of e){if(!r.is_authority)continue;let n=await QB(r.private_key_name);if(r.private_key_name&&n&&new lo(r.certificate).checkPrivateKey(BB(n))){pt.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;pt.trace("No CA found with matching private key")}a(Ly,"getCertAuthority");async function KB(e,t,r=!0){let n=yt.createCertificate();n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+Uy);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${_s.get(Eu.REPLICATION_HOSTNAME)??kB(_s.get(Eu.REPLICATION_URL))??HB().split("-")[0]}`},...vy];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,fu.md.sha256.create());let o=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME),c=sr.join(o,Js.PRIVATEKEY_PEM_NAME);return r&&await pn.writeFile(c,yt.privateKeyToPem(e)),n}a(KB,"generateCertAuthority");async function rre(){let{private_key:e,public_key:t}=await By(),r=await KB(e,t),n=await Hy(e,t,r);await tre(n,r),YB()}a(rre,"generateCertsKeys");async function nre(){let e=await Hy(yt.privateKeyFromPem(Js.CERTIFICATE_VALUES.key),void 0,yt.certificateFromPem(Js.CERTIFICATE_VALUES.cert)),t=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME),r=sr.join(t,Js.NATS_CERTIFICATE_PEM_NAME);await pn.exists(r)||await pn.writeFile(r,e);let n=sr.join(t,Js.NATS_CA_PEM_NAME);await pn.exists(n)||await pn.writeFile(n,Js.CERTIFICATE_VALUES.cert)}a(nre,"createNatsCerts");async function sre(){aa();for await(let e of Pr.search([{attribute:"is_self_signed",value:!0}]))await Pr.delete(e.name);await xy()}a(sre,"renewSelfSigned");async function xy(){Wte(),await $B(),aa();let e=await Ly();if(!e){pt.notify("A matching Certificate Authority and key was not found. A new CA will be created in advance, so it's available if needed.");let r=_s.get(Eu.TLS_PRIVATEKEY),n=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME),s,i=xB(n,r);try{s=yt.privateKeyFromPem(await pn.readFile(r))}catch(c){pt.warn("Unable to parse the TLS key",r,"A new key will be generated and used to create Certificate Authority",c),{private_key:s}=await By(),await pn.exists(sr.join(n,Js.PRIVATEKEY_PEM_NAME))&&(i=`privateKey${HB().split("-")[0]}.pem`),await pn.writeFile(sr.join(n,i),yt.privateKeyToPem(s))}let o=await KB(s,yt.setRsaPublicKey(s.n,s.e),!1);await hu({name:o.subject.getField("CN").value,uses:["https"],certificate:yt.certificateToPem(o),private_key_name:i,is_authority:!0,is_self_signed:!0})}if(!await rf()){let r=Gp();pt.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await Ly();let n=yt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await Hy(yt.privateKeyFromPem(e.private_key),s,n);await hu({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(xy,"reviewSelfSignedCert");function YB(){let e=$te(Object.keys(Es.CONFIG_PARAM_MAP),!0),t=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME),r=sr.join(t,Js.PRIVATEKEY_PEM_NAME),n=sr.join(t,Js.NATS_CERTIFICATE_PEM_NAME),s=sr.join(t,Js.NATS_CA_PEM_NAME),i=Es.CONFIG_PARAMS,o={[i.TLS_PRIVATEKEY]:e[i.TLS_PRIVATEKEY.toLowerCase()]?e[i.TLS_PRIVATEKEY.toLowerCase()]:r};e[i.TLS_CERTIFICATE.toLowerCase()]&&(o[i.TLS_CERTIFICATE]=e[i.TLS_CERTIFICATE.toLowerCase()]),e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.TLS_CERTIFICATEAUTHORITY]=e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATE]=e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]),e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_PRIVATEKEY]=e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY]=e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]),(e[i.CLUSTERING_ENABLED.toLowerCase()]||e.clustering)&&(o[i.CLUSTERING_TLS_CERTIFICATE]=e[i.CLUSTERING_TLS_CERTIFICATE.toLowerCase()]??n,o[i.CLUSTERING_TLS_CERT_AUTH]=e[i.CLUSTERING_TLS_CERT_AUTH.toLowerCase()]??s,o[i.CLUSTERING_TLS_PRIVATEKEY]=e[i.CLUSTERING_TLS_PRIVATEKEY.toLowerCase()]??r),Dy.updateConfigValue(void 0,void 0,o,!1,!0)}a(YB,"updateConfigCert");function WB(e){return e.startsWith("-----BEGIN")?e:jte(e,"utf8")}a(WB,"readPEM");var UB=Ic.createSecureContext;Ic.createSecureContext=function(e){if(!e.cert||!e.key)return UB(e);let t={...e};delete t.key,delete t.cert;let r=UB(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var jB=Ic.Server;Ic.Server=function(e,t){return e.ALPNCallback&&(e.ALPNProtocols=null),jB.call(this,e,t)};Ic.Server.prototype=jB.prototype;var ire=qB.prototype._init;qB.prototype._init=function(e,t){ire.call(this,e,t);let r=this;this._handle.oncertcb=function(n){let s=n.servername;r._SNICallback(s,(i,o)=>{this.sni_context=o?.context||o,this.certCbDone()})}};var Nc=new Map;function zB(e,t){let r=new Map,n,s=!1;return i.initialize=o=>i.ready?i.ready:(o&&(o.secureContexts=r,o.secureContextsListeners=[]),i.ready=new Promise((c,l)=>{async function u(){try{r.clear(),Nc.clear();let d=0;for await(let _ of wy.system.hdb_certificate.search([])){let E=_.certificate,f=new lo(E);_.is_authority&&(f.asString=E,Nc.set(f.subject,E))}for await(let _ of wy.system.hdb_certificate.search([]))try{if(_.is_authority)continue;let E=e==="operations-api",f=_.is_self_signed?1:2;E&&_.uses?.includes?.("operations")&&(f+=1);let h=await QB(_.private_key_name),T=_.certificate,m=new lo(T);if(Nc.has(m.issuer)&&(T+=`
15
+ `+Nc.get(m.issuer)),!h||!T)throw new Error("Missing private key or certificate for secure server");let g={ciphers:_.ciphers,ticketKeys:Qte(),availableCAs:Nc,ca:t&&Array.from(Nc.values()),cert:T,key:h,key_file:_.private_key_name,is_self_signed:_.is_self_signed};o&&(g.sessionIdContext=o.sessionIdContext);let S=Ic.createSecureContext(g);S.name=_.name,S.options=g,S.quality=f,S.certificateAuthorities=Array.from(Nc),S.certStart=T.toString().slice(0,100);let b=_.hostnames??XB(m);Array.isArray(b)||(b=[b]);let I;for(let B of b)if(B){B[0]==="*"&&(s=!0,B=B.slice(1)),B===Py()&&(f+=2),vB.isIP(B)&&(I=!0);let H=r.get(B)?.quality??0;f>H&&r.set(B,S)}else sa.error("No hostname found for certificate at",Ic.certificate);sa.trace("Adding TLS",S.name,"for",o.ports||"client","cert named",_.name,"hostnames",b,"quality",f,"best quality",d),f>d&&(i.defaultContext=n=S,d=f,o&&(o.defaultContext=S))}catch(E){sa.error("Error applying TLS for",_.name,E)}o?.secureContextsListeners.forEach(_=>_()),c(n)}catch(d){l(d)}}a(u,"updateTLS"),wy.system.hdb_certificate.subscribe({listener:u,omitCurrent:!0}),u()})),i;function i(o,c){sa.info("TLS requested for",o||"(no SNI)",this.isReplicationConnection);let l=o;for(;;){let d=r.get(l);if(d)return sa.debug("Found certificate for",o,d.certStart),d.replicationContext&&(this.isReplicationConnection||DB)&&(d=d.replicationContext),c(null,d);if(s&&l){let _=l.indexOf(".",1);_<0?l="":l=l.slice(_)}else break}o?sa.debug("No certificate found to match",o,"using the default certificate"):sa.debug("No SNI, using the default certificate",n?.name);let u=n;u?u.replicationContext&&(this.isReplicationConnection||DB)&&(u=u.replicationContext):sa.info("No default certificate found"),c(null,u)}a(i,"SNICallback")}a(zB,"createTLSSelector");async function QB(e){let t=oa.get(e);return!t&&e?await pn.readFile(sr.join(_s.get(Eu.ROOTPATH),Es.LICENSE_KEY_DIR_NAME,e),"utf8"):t}a(QB,"getPrivateKeyByName");async function JB(){aa();let e=[];for await(let t of Pr.search([]))e.push(t);return e}a(JB,"listCertificates");async function ore(e){let t=My(e,Qs.object({name:Qs.string().required(),certificate:Qs.string().required(),is_authority:Qs.boolean().required(),private_key:Qs.string(),hosts:Qs.array(),uses:Qs.array()}));if(t)throw new ia(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,o=new lo(n),c=!1,l=!1,u;for(let[f,h]of oa)!s&&!c&&o.checkPrivateKey(BB(h))&&(c=!0,u=f),s&&s===h&&(l=!0,u=f);if(!i&&!s&&!c)throw new ia("A suitable private key was not found for this certificate");let d;if(!r){try{d=ky(o)}catch(f){pt.error(f)}if(d==null)throw new ia("Error extracting certificate common name, please provide a name parameter")}let _=are(r??d);s&&!c&&!l&&(await pn.writeFile(sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME,_+".pem"),s),oa.set(_,s));let E={name:r??d,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&u||i&&s)&&(E.private_key_name=u??_+".pem"),await hu(E),"Successfully added certificate: "+_}a(ore,"addCertificate");function are(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(are,"sanitizeName");async function cre(e){let t=My(e,Qs.object({name:Qs.string().required()}));if(t)throw new ia(t.message);let{name:r}=e;aa();let n=await Pr.get(r);if(!n)throw new ia(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await Pr.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(pt.info("Removing private key named",s),await pn.remove(sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME,s)))}return await Pr.delete(r),"Successfully removed "+r}a(cre,"removeCertificate");function ky(e){return e.subject.match(/CN=(.*)/)?.[1]}a(ky,"extractCommonName");function XB(e){return e.subjectAltName?e.subjectAltName.split(",").map(t=>{let r=t.indexOf(":");if(t=t.slice(r+1),t=t.trim(),t[0]==='"')try{t=JSON.parse(t)}catch{}return t.indexOf("=")>-1?t.match(/CN=([^,]*)/)?.[1]:t}).filter(t=>t):[ky(e)]}a(XB,"hostnamesFromCert");async function lre(e){if(e.bypass_auth!==!0)throw new ia("Unauthorized","401");let t=My(e,Qs.object({name:Qs.string().required()}));if(t)throw new ia(t.message);let{name:r}=e;if(r===".jwtPrivate")return(await PB()).private_key;if(r===".jwtPublic")return(await PB()).public_key;if(oa.get(r))return oa.get(e.name);throw new ia("Key not found")}a(lre,"getKey")});async function Ky(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=ot(),i;if(e.includes("wss://")){if(!Gy){let l=(0,pH.createTLSSelector)("operations-api"),u={secureContexts:null};await l.initialize(u),Gy=u.secureContexts}if(i=Gy.get(s),i&&fe.debug?.("Creating web socket for URL",e,"with certificate named:",i.name),!i&&n!==!1)throw new Error("Unable to find a valid certificate to use for replication to connect to "+e)}let o={};r&&(o.Authorization=r);let c={headers:o,localAddress:s?.startsWith("127.0")?s:void 0,servername:(0,SH.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,ALPNProtocols:["http/1.1","harperdb-replication"],rejectUnauthorized:n!==!1,secureContext:void 0};return i&&(c.secureContext=mH.createSecureContext({...i.options,ca:Array.from(Cc)})),new EH.WebSocket(e,"harperdb-replication-v1",c)}function Yp(e,t,r){let n=t.port||t.securePort,s=Vy.pid%1e3+"-"+hH.threadId+(n?"s:"+n:"c:"+t.url?.slice(-4))+" "+Math.random().toString().slice(2,3),i=0,o=Buffer.allocUnsafeSlow(1024),c=0,l=new DataView(o.buffer,0,1024),u=t.database,d=t.databaseSubscriptions||wc,_,E,f=!1,h=t.subscription;h?.then&&h.then(ie=>h=ie);let T=t.tables||u&&ut()[u];if(!r){fe.error?.("No authorization provided"),ss(1008,"Unauthorized");return}let m=new Map,g=[],S=r.name;S&&t.connection&&(t.connection.nodeName=S);let b,I,B,H,X,Y,V=1e3,ne,Q=0,de=0,j=0,ae=0;if(t.url){let ie=a(()=>{X&&j===e._socket?.bytesRead&&ae===e._socket?.bytesWritten?e.terminate():(X=performance.now(),e.ping(),j=e._socket?.bytesRead,ae=e._socket?.bytesWritten)},"send_ping");B=setInterval(ie,uH).unref(),ie()}else be();function be(){clearTimeout(H),j=e._socket?.bytesRead,ae=e._socket?.bytesWritten,H=setTimeout(()=>{j===e._socket?.bytesRead&&ae===e._socket?.bytesWritten&&(fe.warn?.(`Timeout waiting for ping from ${S}, terminating connection and reconnecting`),e.terminate())},uH*2).unref()}a(be,"resetPingTimer"),u&&Va(u);let Oe,Me,Gr=[],Cd=[],ka,wn=[],Dd=[],Ol=[],vw=150,jE=0,vt=0,Fa,Ga,vs,Bs,zE;e.on("message",ie=>{Q=performance.now();try{let Se=ie.dataView=new Dc(ie.buffer,ie.byteOffset,ie.byteLength);if(ie[0]>127){let A=(0,ct.decode)(ie),[w,R,y]=A;switch(w){case tH:{if(R){if(S){if(S!==R){fe.error?.(s,`Node name mismatch, expecting to connect to ${S}, but peer reported name as ${R}, disconnecting`),e.send((0,ct.encode)([pu])),ss(1008,"Node name mismatch");return}}else if(S=R,t.connection?.tentativeNode){let x=t.connection.tentativeNode;x.name=S,t.connection.tentativeNode=null,co(S,x)}if(t.connection&&(t.connection.nodeName=S),fe.debug?.(s,"received node name:",S,"db:",u),!u)try{Va(u=A[2]),u==="system"&&(Oe=ta(t,(x,q)=>{$a(q)&&Ir(q)}),e.on("close",()=>{Oe?.remove()}))}catch(x){fe.warn?.(s,"Error setting database",x),e.send((0,ct.encode)([pu])),ss(1008,x.message);return}qa()}break}case cH:{fe.debug?.(s,"Received table definitions for",R.map(x=>x.table));for(let x of R){let q=A[2];x.database=q;let ee;$a(q)&&(q==="system"?We[q]?.[x.table]||(ee=qy(x,We[q]?.[x.table])):ee=qy(x,We[q]?.[x.table]),_||(_=ee?.auditStore),T||(T=ut()?.[q]))}break}case pu:ss();break;case iH:try{let x=r?.replicates||r?.subscribers||r?.name;server.operation(R,{user:r},!x).then(q=>{Array.isArray(q)&&(q={results:q}),q.requestId=R.requestId,e.send((0,ct.encode)([$p,q]))},q=>{e.send((0,ct.encode)([$p,{requestId:R.requestId,error:q instanceof Error?q.toString():q}]))})}catch(x){e.send((0,ct.encode)([$p,{requestId:R.requestId,error:x instanceof Error?x.toString():x}]))}break;case $p:let{resolve:D,reject:O}=m.get(R.requestId);R.error?O(new Error(R.error)):D(R),m.delete(R.requestId);break;case Fy:let v=A[3];T||(u?fe.error?.(s,"No tables found for",u):fe.error?.(s,"Database name never received"));let k=T[v];k=qy({table:v,database:u,attributes:R.attributes,schemaDefined:R.schemaDefined},k),Gr[y]={name:v,decoder:new ct.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:R.typedStructs,structures:R.structures}),getEntry(x){return k.primaryStore.getEntry(x)},rootStore:k.primaryStore.rootStore};break;case rH:zE=_?rB(S,R,_):new Map,ka=A[2],fe.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${ka}`);break;case nH:let C=y;Ol[C]=R;break;case aH:let F=["replicated",u,S];E||(E=new Float64Array(_.getUserSharedBuffer(F,new ArrayBuffer(8)))),E[0]=R,fe.trace?.(s,"received and broadcasting committed update",R),E.buffer.notify();break;case oH:b=R,h.send({type:"end_txn",localTime:b,remoteNodeIds:g});break;case sH:{let x=R,q;try{let ee=A[3],G=Cd[y]||(Cd[y]=T[A[4]]);if(!G)return fe.warn?.("Unknown table id trying to handle record request",y);let Re=G.primaryStore.getBinaryFast(Symbol.for("structures")),Ee=Re.length;if(Ee!==vt){vt=Ee;let re=(0,ct.decode)(Re);e.send((0,ct.encode)([Fy,{typedStructs:re.typed,structures:re.named},y,G.tableName]))}let Ae=G.primaryStore.getBinaryFast(ee);if(Ae){let re=G.primaryStore.decoder.decode(Ae,{valueAsBuffer:!0});q=(0,ct.encode)([qp,x,{value:re.value,expiresAt:re.expiresAt,version:re.version,residencyId:re.residencyId,nodeId:re.nodeId,user:re.user}])}else q=(0,ct.encode)([qp,x])}catch(ee){q=(0,ct.encode)([qp,x,{error:ee.message}])}e.send(q);break}case qp:{let{resolve:x,reject:q,tableId:ee,key:G}=m.get(A[1]),Re=A[2];if(Re?.error)q(new Error(Re.error));else if(Re){let Ee=Gr[ee].decoder.decode(Re.value);Re.value=Ee,Re.key=G,x(Re)}else x();m.delete(A[1]);break}case eH:{Bs=R;let x,q,ee=!1;if(h){if(u!==h.databaseName&&!h.then){fe.error?.("Subscription request for wrong database",u,h.databaseName);return}}else h=d.get(u);if(fe.debug?.(s,"received subscription request for",u,"at",Bs),!h){let ce;h=new Promise(Ye=>{fe.debug?.("Waiting for subscription to database "+u),ce=Ye}),h.ready=ce,wc.set(u,h)}if(r.name)q=Sr().subscribe(r.name),q.then(async ce=>{x=ce;for await(let Ye of x){let rt=Ye.value;if(!(rt?.replicates===!0||rt?.replicates?.receives||rt?.subscriptions?.some(Ze=>(Ze.database||Ze.schema)===u&&Ze.publish!==!1))){ee=!0,e.send((0,ct.encode)([pu])),ss(1008,`Unauthorized database subscription to ${u}`);return}}},ce=>{fe.error?.(s,"Error subscribing to HDB nodes",ce)});else if(!(r?.role?.permission?.super_user||r.replicates)){e.send((0,ct.encode)([pu])),ss(1008,`Unauthorized database subscription to ${u}`);return}if(vs&&(fe.debug?.(s,"stopping previous subscription",u),vs.emit("close")),Bs.length===0)return;let G=Bs[0],Re=a(ce=>{if(ce&&(G.replicateByDefault?!G.tables.includes(ce.tableName):G.tables.includes(ce.tableName)))return{table:ce}},"tableToTableEntry"),Ee={txnTime:0},Ae,re,K=1/0,ge,Be=a((ce,Ye)=>{if(K=Ye,ce.type==="end_txn"){Ee.txnTime&&(o[i]!==66&&fe.error?.("Invalid encoding of message"),di(9),di(Kp),Ka(ge=Ye),we()),i=c,Ee.txnTime=0;return}let rt=ce.nodeId,Ze=ce.tableId,st=re[Ze];if(!st&&(st=re[Ze]=Re(h.tableById[Ze]),!st))return fe.debug?.("Not subscribed to table",Ze);let Bt=st.table,ko=Bt.primaryStore,Yt=ko.encoder;(ce.extendedType&Oh||!Yt.typedStructs)&&(Yt._mergeStructures(Yt.getStructures()),Yt.typedStructs&&(Yt.lastTypedStructuresLength=Yt.typedStructs.length));let QE=Ae[rt];if(!(QE&&QE.startTime<Ye&&(!QE.endTime||QE.endTime>Ye)))return nf&&fe.trace?.(s,"skipping replication update",ce.recordId,"to:",S,"from:",rt,"subscribed:",Ae),Bw();nf&&fe.trace?.(s,"sending replication update",ce.recordId,"to:",S,"from:",rt,"subscribed:",Ae);let ZT=ce.version;Ee.txnTime!==ZT&&(Ee.txnTime&&(nf&&fe.trace?.(s,"new txn time, sending queued txn",Ee.txnTime),o[i]!==66&&fe.error?.("Invalid encoding of message"),we()),Ee.txnTime=ZT,i=c,Ka(ZT));let Ya=ce.residencyId,eg=ji(Ya,Bt),JE;if(eg&&!eg.includes(S)){let Il=ji(ce.previousResidencyId,Bt);if(Il&&!Il.includes(S)&&(ce.type==="put"||ce.type==="patch")||Bt.getResidencyById)return Bw();let Ud=ce.recordId;fe.trace?.(s,"sending invalidation",Ud,S,"from",rt);let ng=0;Ya&&(ng|=tc),ce.previousResidencyId&&(ng|=rc);let sg,XE=null;for(let Hw in Bt.indices){if(!XE){if(sg=ce.getValue(ko,!0),!sg)break;XE={}}XE[Hw]=sg[Hw]}JE=Ml(ce.version,Ze,Ud,null,rt,ce.user,ce.type==="put"||ce.type==="patch"?"invalidate":ce.type,Yt.encode(XE),ng,Ya,ce.previousResidencyId,ce.expiresAt)}function Bw(){fe.trace?.(s,"skipping audit record",ce.recordId),Y||(Y=setTimeout(()=>{Y=null,(ge||0)+lH/2<K&&(nf&&fe.trace?.(s,"sending skipped sequence update",K),e.send((0,ct.encode)([oH,K])))},lH).unref())}a(Bw,"skipAuditRecord");let tg=Yt.typedStructs,rg=Yt.structures;if((tg?.length!=st.typed_length||rg?.length!=st.structure_length)&&(st.typed_length=tg?.length,st.structure_length=rg.length,fe.debug?.(s,"send table struct",st.typed_length,st.structure_length),st.sentName||(st.sentName=!0),e.send((0,ct.encode)([Fy,{typedStructs:tg,structures:rg,attributes:Bt.attributes,schemaDefined:Bt.schemaDefined},Ze,st.table.tableName]))),Ya&&!Dd[Ya]&&(e.send((0,ct.encode)([nH,eg,Ya])),Dd[Ya]=!0),JE)di(JE.length),Md(JE);else{let Il=ce.encoded,Ud=Il[0]===66?8:0;di(Il.length-Ud),Md(Il,Ud)}},"sendAuditRecord"),we=a(()=>{c-i>8?(e.send(o.subarray(i,c)),fe.debug?.(s,"Sent message, size:",c-i)):fe.debug?.(s,"skipping empty transaction")},"sendQueuedData");vs=new $y.EventEmitter,vs.once("close",()=>{ee=!0,x?.end()});for(let{startTime:ce}of Bs)ce<K&&(K=ce);(q||Promise.resolve()).then(async()=>{h=await h,_=h.auditStore,re=h.tableById.map(Re),Ae=[];for(let{name:Ye,startTime:rt,endTime:Ze}of Bs){let st=Lp(Ye,_);fe.debug?.("subscription to",Ye,"using local id",st,"starting",rt),Ae[st]={startTime:rt,endTime:Ze}}Ir(u),Oe||(Oe=Pc(Ye=>{Ye.databaseName===u&&Ir(u)}),Me=sf(Ye=>{Ye===u&&(e.send((0,ct.encode)([pu])),ss())}),e.on("close",()=>{Oe?.remove(),Me?.remove()})),e.send((0,ct.encode)([rH,W_(h.auditStore),Bs.map(({name:Ye})=>Ye)]));let ce=!0;do{isFinite(K)||(fe.warn?.("Invalid sequence id "+K),ss(1008,"Invalid sequence id"+K));let Ye;if(ce&&!ee&&(ce=!1,!(Yy(_)<=K)&&_H.default.get(fH.CONFIG_PARAMS.REPLICATION_COPY_TABLES_TO_CATCHUP)!==!1&&server.nodes[0]?.name===S)){fe.info?.("Replicating all tables to",S);let Ze=K,st=Wp(_);for(let Bt in T){if(!Re(Bt))continue;let ko=T[Bt];for(let Yt of ko.primaryStore.getRange({snapshot:!1})){if(ee)return;Yt.localTime>=K&&(fe.trace?.(s,"Copying record from",u,Bt,Yt.key,Yt.localTime),Ze=Math.max(Yt.localTime,Ze),Ye=!0,Be({recordId:Yt.key,tableId:ko.tableId,type:"put",getValue(){return Yt.value},encoded:ko.primaryStore.getBinary(Yt.key),version:Yt.version,residencyId:Yt.residencyId,nodeId:st},Yt.localTime))}}K=Ze}for(let{key:rt,value:Ze}of _.getRange({start:K||1,exclusiveStart:!0,snapshot:!1})){if(ee)return;de=rt;let st=xt(Ze);Be(st,rt),e._socket.writableNeedDrain?await new Promise(Bt=>e._socket.once("drain",Bt)):await new Promise(setImmediate),vs.startTime=rt,Ye=!0}Ye&&Be({type:"end_txn"},K),de=0,await uB(_)}while(!ee)}).catch(ce=>{fe.error?.(s,"Error handling subscription to node",ce),ss(1008,"Error handling subscription to node")});break}}return}Se.position=8;let tt=!0,U,p;do{let A=Se.readInt();if(A===9&&Se.getUint8(Se.position)==Kp){Se.position++,b=p=Se.readFloat64(),fe.trace?.("received remote sequence update",b,u);break}let w=Se.position,R=xt(ie,w,w+A),y=Gr[R.tableId];y||fe.error?.(`No table found with an id of ${R.tableId}`);let D;R.residencyId&&(D=Ol[R.residencyId],fe.trace?.(s,"received residency list",D,R.type,R.recordId));try{U={table:y.name,id:R.recordId,type:R.type,nodeId:zE.get(R.nodeId),residencyList:D,timestamp:R.version,value:R.getValue(y),user:R.user,beginTxn:tt,expiresAt:R.expiresAt}}catch(O){throw O.message+="typed structures for current decoder"+JSON.stringify(y.decoder.typedStructs),O}tt=!1,nf&&fe.trace?.(s,"received replication message",R.type,"id",U.id,"version",R.version,"nodeId",U.nodeId,"value",U.value),h.send(U),Se.position=w+A}while(Se.position<ie.byteLength);jE++,pr(ie.byteLength,"bytes-received",S+"."+u+"."+U.table,"replication","ingest"),jE>vw&&!Fa&&(Fa=!0,e.pause()),h.send({type:"end_txn",localTime:b,remoteNodeIds:g,onCommit(){if(U){let A=Date.now()-U.timestamp;pr(A,"replication-latency",S+"."+u+"."+U.table,U.type,"ingest")}jE--,Fa&&(Fa=!1,e.resume()),!I&&p&&(fe.trace?.(s,"queuing confirmation of a commit at",p),setTimeout(()=>{e.send((0,ct.encode)([aH,I])),fe.trace?.(s,"sent confirmation of a commit at",I),I=null},ure)),I=p}})}catch(Se){fe.error?.(s,"Error handling incoming replication message",Se)}}),e.on("ping",be),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-X,Oc({name:S,database:u,url:t.url,lastSendTime:de,latency:t.connection.latency})),X=null}),e.on("close",(ie,Se)=>{clearInterval(B),clearTimeout(H),vs&&vs.emit("close"),Ga&&Ga.end();for(let[tt,{reject:U}]of m)U(new Error(`Connection closed ${Se?.toString()} ${ie}`));fe.debug?.(s,"closed",ie,Se?.toString())});function Ve(){}a(Ve,"recordRemoteNodeSequence");function ss(ie,Se){e.isFinished=!0,e.close(ie,Se)}a(ss,"close");function qa(){if(f||(f=!0,t.connection?.on("subscriptions-updated",qa)),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let ie=new Map;try{for(let U of h?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let p of U.value.nodes||[])p.lastTxnTime>(ie.get(p.id)??0)&&ie.set(p.id,p.lastTxnTime)}catch(U){if(!U.message.includes("Can not re"))throw U}let Se=t.connection?.nodeSubscriptions?.[0];g=[];let tt=t.connection?.nodeSubscriptions.map((U,p)=>{let A=[],{replicateByDefault:w}=U;if(U.subscriptions){for(let O of U.subscriptions)if(O.subscribe&&(O.schema||O.database)===u){let v=O.table;T?.[v]?.replicate!==!1&&A.push(v)}w=!1}else for(let O in T)(w?T[O].replicate===!1:T[O].replicate)&&A.push(O);let R=_&&Lp(U.name,_),y=h?.dbisDB?.get([Symbol.for("seq"),R])??1,D=Math.max(y?.seqId??1,(typeof U.start_time=="string"?new Date(U.start_time).getTime():U.start_time)??1);if(fe.debug?.("Starting time recorded in db",U.name,R,u,y?.seqId,"start time:",D),Se!==U){D>5e3&&(D-=5e3);let O=_&&Lp(Se.name,_),v=h?.dbisDB?.get([Symbol.for("seq"),O])??1;for(let k of v?.nodes||[])k.name===U.name&&(D=k.seqId,fe.debug?.("Using sequence id from proxy node",Se.name,D))}return g.push(R),ie.get(R)>D&&(D=ie.get(R),fe.debug?.("Updating start time from more recent txn recorded",Se.name,D)),{name:U.name,replicateByDefault:w,tables:A,startTime:D,endTime:U.end_time}});if(tt)if(fe.debug?.(s,"sending subscription request",tt,h?.dbisDB?.path),clearTimeout(ne),tt.length>0)e.send((0,ct.encode)([eH,tt]));else{let U=a(()=>{let p=performance.now();ne=setTimeout(()=>{Q<=p?ss(1008,"No nodes to subscribe to"):U()},V)},"schedule_close");U()}}a(qa,"sendSubscriptionRequestUpdate");function ji(ie,Se){if(!ie)return;let tt=wn[ie];return tt||(tt=Se.getResidencyRecord(ie),wn[ie]=tt),tt}a(ji,"getResidence");function $a(ie){return!(la&&la!="*"&&!la[ie]&&!la.includes?.(ie)&&!la.some?.(Se=>Se.name===ie))}a($a,"checkDatabaseAccess");function Va(ie){if(h=h||d.get(ie),!$a(ie))throw new Error(`Access to database "${ie}" is not permitted`);h||fe.warn?.(`No database named "${ie}" was declared and registered`),_=h?.auditStore,T||(T=ut()?.[ie]);let Se=ot();if(Se===S)throw Se?new Error("Should not connect to self",Se):new Error("Node name not defined");return Pd(Se,ie),!0}a(Va,"setDatabase");function Pd(ie,Se){let tt=ut()?.[Se],U=[];for(let p in tt){let A=tt[p];U.push({table:p,schemaDefined:A.schemaDefined,attributes:A.attributes.map(w=>({name:w.name,type:w.type,isPrimaryKey:w.isPrimaryKey}))})}fe.trace?.("Sending database info for node",ie,"database name",Se),e.send((0,ct.encode)([tH,ie,Se,U]))}a(Pd,"sendNodeDBName");function Ir(ie){let Se=ut()?.[ie],tt=[];for(let U in Se){if(Bs&&!Bs.some(A=>A.replicateByDefault?!A.tables.includes(U):A.tables.includes(U)))continue;let p=Se[U];tt.push({table:U,schemaDefined:p.schemaDefined,attributes:p.attributes.map(A=>({name:A.name,type:A.type,isPrimaryKey:A.isPrimaryKey}))})}e.send((0,ct.encode)([cH,tt,ie]))}a(Ir,"sendDBSchema");let Nl=1,Ld=[];return{end(){Ga&&Ga.end(),vs&&vs.emit("close")},getRecord(ie){let Se=Nl++;return new Promise((tt,U)=>{let p=[sH,Se,ie.table.tableId,ie.id];Ld[ie.table.tableId]||(p.push(ie.table.tableName),Ld[ie.table.tableId]=!0),e.send((0,ct.encode)(p)),m.set(Se,{tableId:ie.table.tableId,key:ie.id,resolve(A){let{table:w,entry:R}=ie;tt(A),A&&w._recordRelocate(R,A)},reject:U})})},sendOperation(ie){let Se=Nl++;return ie.requestId=Se,e.send((0,ct.encode)([iH,ie])),new Promise((tt,U)=>{m.set(Se,{resolve:tt,reject:U})})}};function di(ie){xo(5),ie<128?o[c++]=ie:ie<16384?(l.setUint16(c,ie|32768),c+=2):ie<1056964608?(l.setUint32(c,ie|3221225472),c+=4):(o[c]=255,l.setUint32(c+1,ie),c+=5)}function Md(ie,Se=0,tt=ie.length){let U=tt-Se;xo(U),ie.copy(o,c,Se,tt),c+=U}function Ka(ie){xo(8),l.setFloat64(c,ie),c+=8}function xo(ie){if(ie+16>o.length-c){let Se=Buffer.allocUnsafeSlow(c+ie-i+65536>>10<<11);o.copy(Se,0,i,c),c=c-i,i=0,o=Se,l=new DataView(o.buffer,0,o.length)}}}function qy(e,t){let r=e.database??"data";if(r!=="data"&&!We[r]){fe.warn?.("Database not found",e.database);return}t||(t={});let n=!1,s=e.schemaDefined,i=t.attributes||[];for(let o=0;o<e.attributes?.length;o++){let c=e.attributes[o],l=i[o];(!l||l.name!==c.name||l.type!==c.type)&&(n=!0,s||(c.indexed=!0),i[o]=c)}return n?(fe.debug?.("(Re)creating",e),Et({table:e.table,database:e.database,schemaDefined:e.schemaDefined,attributes:i,...t})):t}var _H,fH,ct,EH,hH,fe,$y,pH,mH,Vy,SH,eH,tH,rH,pu,nH,Fy,sH,qp,iH,$p,oH,aH,cH,TH,wc,nf,lH,ure,uH,Gy,dH,Vp,gH=Ie(()=>{Pe();Ji();_y();my();us();_H=L(se()),fH=L(M());Ul();ct=require("msgpackr"),EH=require("ws"),hH=require("worker_threads"),fe=L(bc());J_();$y=require("events"),pH=L(Xs()),mH=L(require("node:tls"));cu();Vy=L(require("node:process")),SH=require("node:net");Ni();eH=129,tH=140,rH=141,pu=142,nH=130,Fy=132,sH=133,qp=134,iH=136,$p=137,oH=143,aH=144,cH=145,TH=new Map,wc=new Map,nf=!0,lH=300,ure=2,uH=3e4;a(Ky,"createWebSocket");dH=1e3,Vp=class extends $y.EventEmitter{constructor(r,n,s,i,o){super();this.url=r;this.subscription=n;this.databaseName=s;this.nodeName=i;this.authorization=o;this.nodeName=this.nodeName??zs(r)}static{a(this,"NodeReplicationConnection")}socket;startTime;retryTime=dH;retries=0;isConnected=!0;isFinished=!1;nodeSubscriptions=[];latency=0;replicateTablesByDefault;session;sessionResolve;sessionReject;async connect(){this.session||this.resetSession();let r=[];this.socket=await Ky(this.url,{serverName:this.nodeName,authorization:this.authorization});let n;fe.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${Vy.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),fe.info?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=dH,Oc({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=Yp(this.socket,{database:this.databaseName,subscription:this.subscription,url:this.url,connection:this},{replicates:!0}),this.sessionResolve(n)}),this.socket.on("error",s=>{s.code==="SELF_SIGNED_CERT_IN_CHAIN"?(fe.warn?.(`Can not connect to ${this.url}, this server does not have a certificate authority for the certificate provided by ${this.url}`),s.isHandled=!0):s.code!=="ECONNREFUSED"&&(s.code==="UNABLE_TO_VERIFY_LEAF_SIGNATURE"?fe.error?.(`Can not connect to ${this.url}, the certificate provided by ${this.url} is not trusted, this node needs to be added to the cluster, or a certificate authority needs to be added`):fe.error?.(`Error in connection to ${this.url} due to ${s.message}`)),this.sessionReject(s)}),this.socket.on("close",(s,i)=>{if(this.isConnected&&(du({name:this.nodeName,database:this.databaseName,url:this.url,finished:this.socket.isFinished}),this.isConnected=!1),this.socket.isFinished){this.isFinished=!0,n?.end(),this.emit("finished");return}if(++this.retries%20===1){let o=i?.toString();fe.warn?.(`${n?"Disconnected from":"Failed to connect to"} ${this.url} (db: "${this.databaseName}"), due to ${o?'"'+o+'" ':""}(code: ${s})`)}n=null,this.resetSession(),setTimeout(()=>{this.connect()},this.retryTime).unref(),this.retryTime+=this.retryTime>>3})}resetSession(){this.session=new Promise((r,n)=>{this.sessionResolve=r,this.sessionReject=n})}subscribe(r,n){this.nodeSubscriptions=r,this.replicateTablesByDefault=n,this.emit("subscriptions-updated",r)}unsubscribe(){this.socket.isFinished=!0,this.socket.close(1008,"No longer subscribed")}getRecord(r){return this.session.then(n=>n.getRecord(r))}};a(Yp,"replicateOverWS");a(qy,"ensureTableIfChanged")});var ca={};je(ca,{clearThisNodeName:()=>Sre,disableReplication:()=>Ere,enabled_databases:()=>la,forEachReplicatedDatabase:()=>ta,getThisNodeId:()=>Wp,getThisNodeName:()=>ot,getThisNodeUrl:()=>ra,hostnameToUrl:()=>Jp,lastTimeInAuditStore:()=>j_,monitorNodeCAs:()=>wH,replicateOperation:()=>gre,replication_certificate_authorities:()=>Cc,sendOperationToNode:()=>af,servers:()=>_re,setReplicator:()=>DH,start:()=>fre,startOnMainThread:()=>Ty,subscribeToNode:()=>uu,unsubscribeFromNode:()=>Bp,urlToNodeName:()=>zs});function fre(e){if(e.port||(e.port=hs.default.get(Lc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=hs.default.get(Lc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),!ot())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let n of Q_(e))t.set(zs(n.url),n);hre(e),e={mtls:!0,isOperationsServer:!0,maxPayload:10*1024*1024*1024,...e};let r=it.ws(async(n,s,i,o)=>{if(s.headers.get("sec-websocket-protocol")!=="harperdb-replication-v1")return o(n,s,i);await i,n._socket.unref(),Yp(n,e,s?.user),n.on("error",c=>{c.code!=="ECONNREFUSED"&&Tr.error("Error in connection to "+this.url,c.message)})},e);e.runFirst=!0,it.http((n,s)=>{if(n.isWebSocket&&n.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){!n.authorized&&n._nodeRequest.socket.authorizationError&&Tr.error(`Incoming client connection from ${n.ip} did not have valid certificate, you may need turn on enableRootCAs in the config if you are using a publicly signed certificate, or add the CA to the server's trusted CAs`,n._nodeRequest.socket.authorizationError);let i=Sr().primaryStore;if(n.authorized&&n.peerCertificate.subject){let o=n.peerCertificate.subject,c=o&&(i.get(o.CN)||t.get(o.CN));c?n.user=c:Tr.warn(`No node found for certificate common name ${o.CN}, available nodes are ${Array.from(i.getRange({}).filter(({value:l})=>l).map(({key:l})=>l)).join(", ")} and routes ${Array.from(t.keys()).join(", ")}, connection will require credentials.`)}else{let o=i.get(n.ip)||t.get(n.ip);o?n.user=o:Tr.warn(`No node found for IP address ${n.ip}, available nodes are ${Array.from(new Set([...i.getKeys(),...t.keys()])).join(", ")}, connection will require credentials.`)}}return s(n)},e);for(let n of r)if(n.secureContexts){let s=a(()=>{let i=new Set(n.secureContexts.values());n.defaultContext&&i.add(n.defaultContext);for(let o of i)try{let c=Array.from(Cc);o.options.availableCAs&&c.push(...o.options.availableCAs.values());let l={...o.options,ca:c};o.replicationContext=Qp.createSecureContext(l)}catch(c){Tr.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),wH(s),hs.default.get(Lc.CONFIG_PARAMS.REPLICATION_ENABLEROOTCAS)!==!1&&s()}}function wH(e){let t=0;au(r=>{r?.ca&&(Cc.add(r.ca),Cc.size!==t&&(t=Cc.size,e?.()))})}function Ere(e=!0){IH=e}function hre(e){IH||(ut(),la=e.databases,ta(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||wc;for(let[s,i]of of){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];DH(r,s,e),TH.get(s)?.forEach(i=>i(s))}}))}function DH(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 CH extends Lr{static{a(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||wc,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(Tr.trace("Setting up replicator subscription to database",e),!o?.auditStore)return this.subscription=o=new Mn,i.set(e,o),o.tableById=c,o.auditStore=t.auditStore,o.dbisDB=t.dbisDB,o.databaseName=e,l&&l(o),o;this.subscription=o}static subscribeOnThisThread(i,o){return!0}static async load(i){if(i){let o=i.residencyId,c=i.residency||t.dbisDB.get([Symbol.for("residency_by_id"),o]);if(c){let l,u=new Set;do{let d;for(let E of c){let f=pre(E,CH.subscription,e);f?.isConnected&&!u.has(f)&&(!d||f.latency<d.latency)&&(d=f)}if(!d)throw l||new OH.ServerError("No connection to any other nodes are available",502);let _={requestId:dre++,table:t,entry:i,id:i.key};u.add(d);try{return await d.getRecord(_)}catch(E){if(d.isConnected)throw E;Tr.warn("Error in load from node",zp,E),l||(l=E)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function PH(e,t,r,n,s){let i=of.get(e);i||of.set(e,i=new Map);let o=i.get(r);if(o)return o;if(t)return i.set(r,o=new Vp(e,t,r,n,s)),o.connect(),o.once("finished",()=>i.delete(r)),o}function pre(e,t,r){let n=AH.get(e)?.get(r);if(n)return n;let s=Sr().primaryStore.get(e);return s?.url&&(n=PH(s.url,t,r,e,s.authorization),AH.set(e,of.get(s.url))),n}async function af(e,t,r){r||(r={}),r.serverName=e.name;let n=await Ky(e.url,r),s=Yp(n,{},{});return new Promise((i,o)=>{n.on("open",()=>{i(s.sendOperation(t))}),n.on("error",c=>{o(c)}),n.on("close",c=>{Tr.info("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function uu(e){try{NH.isMainThread&&Tr.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=wc.get(e.database);if(!t){let n;t=new Promise(s=>{Tr.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,wc.set(e.database,t)}let r=PH(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=>z_(n,e.database)),e.replicateByDefault)}catch(t){Tr.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function Bp({name:e,url:t,database:r}){Tr.trace("Unsubscribing from node",e,t,r,"nodes",Array.from(Sr().primaryStore.getRange({})));let n=of.get(t);if(n){let s=n.get(r);s&&(s.unsubscribe(),n.delete(r))}}function mre(){if(Wy!==void 0)return Wy;let e=hs.default.get(Lc.CONFIG_PARAMS.OPERATIONSAPI_TLS_CERTIFICATE)||hs.default.get(Lc.CONFIG_PARAMS.TLS_CERTIFICATE);if(e)return Wy=new yH.X509Certificate((0,bH.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function ot(){return zp||(zp=hs.default.get("replication_hostname")??zs(hs.default.get("replication_url"))??mre()??RH("operationsapi_network_secureport")??RH("operationsapi_network_port")??"127.0.0.1")}function Sre(){zp=void 0}function RH(e){let t=hs.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function jp(e){let t=hs.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function Wp(e){return W_(e)?.[ot()]}function ra(){let e=hs.default.get("replication_url");return e||Jp(ot())}function Jp(e){let t=jp("replication_port");if(t)return`ws://${e}:${t}`;if(t=jp("replication_secureport"),t)return`wss://${e}:${t}`;if(t=jp("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=jp("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function zs(e){if(e)return new URL(e).hostname}function ta(e,t){for(let n of Object.getOwnPropertyNames(We))r(n);return sf(n=>{r(n)}),Pc((n,s)=>{r(n.databaseName)});function r(n){let s=We[n];Tr.trace("Checking replication status of ",n,e?.databases),e?.databases===void 0||e.databases==="*"||e.databases.includes(n)||e.databases.some?.(i=>i.name===n)||!s?t(s,n,!0):Tre(n)&&t(s,n,!1)}a(r,"forDatabase")}function Tre(e){let t=We[e];for(let r in t)if(t[r].replicate)return!0}function j_(e){for(let t of e.getKeys({limit:1,reverse:!0}))return t}async function gre(e){let t={message:""};if(e.replicated){e.replicated=!1,Tr.trace?.("Replicating operation",e.operation,"to nodes",it.nodes.map(n=>n.name));let r=await Promise.allSettled(it.nodes.map(n=>af(n,e)));t.replicated=r.map((n,s)=>{let i=n.status==="rejected"?{status:"failed",reason:n.reason.toString()}:n.value;return i.node=it.nodes[s]?.name,i})}return t}var hs,Tr,yH,bH,Lc,Qp,OH,NH,IH,dre,_re,Cc,la,of,AH,Wy,zp,us=Ie(()=>{Pe();Vs();Pl();gH();qr();hs=L(se()),Tr=L(W()),yH=require("crypto"),bH=require("fs");J_();cu();Lc=L(M());_y();Qp=L(require("node:tls")),OH=L(_e()),NH=require("worker_threads"),dre=1,_re=[],Cc=hs.default.get(Lc.CONFIG_PARAMS.REPLICATION_ENABLEROOTCAS)!==!1?new Set(Qp.rootCertificates):new Set;a(fre,"start");a(wH,"monitorNodeCAs");a(Ere,"disableReplication");a(hre,"assignReplicationSource");a(DH,"setReplicator");of=new Map;a(PH,"getConnection");AH=new Map;a(pre,"getConnectionByName");a(af,"sendOperationToNode");a(uu,"subscribeToNode");a(Bp,"unsubscribeFromNode");a(mre,"getCommonNameFromCert");a(ot,"getThisNodeName");a(Sre,"clearThisNodeName");Object.defineProperty(it,"hostname",{get(){return ot()}});a(RH,"getHostFromListeningPort");a(jp,"getPortFromListeningPort");a(Wp,"getThisNodeId");it.replication={getThisNodeId:Wp,exportIdMapping:W_};a(ra,"getThisNodeUrl");a(Jp,"hostnameToUrl");a(zs,"urlToNodeName");a(ta,"forEachReplicatedDatabase");a(Tre,"hasExplicitlyReplicatedTable");a(j_,"lastTimeInAuditStore");a(gre,"replicateOperation")});var tm=N((hIe,BH)=>{"use strict";var mu=Uh(),Su=a0(),Are=W(),Rre=require("uuid").v4,EIe=require("clone"),Zp=no(),Tu=M(),yre=require("util"),ua=Bn(),{handleHDBError:mn,hdb_errors:bre}=_e(),{HDB_ERROR_MSGS:Xp,HTTP_STATUS_CODES:Sn}=bre,{SchemaEventMsg:em}=qs(),LH=mr(),{getDatabases:Ore}=(Pe(),oe(lt)),{transformReq:gu}=te(),{replicateOperation:MH}=(us(),oe(ca));BH.exports={createSchema:Nre,createSchemaStructure:UH,createTable:Ire,createTableStructure:vH,createAttribute:Lre,dropSchema:wre,dropTable:Cre,dropAttribute:Dre,getBackup:Mre};async function Nre(e){let t=await UH(e);return Zp.signalSchemaChange(new em(process.pid,e.operation,e.schema)),t}a(Nre,"createSchema");async function UH(e){let t=mu.schema_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);if(gu(e),!await Su.checkSchemaExists(e.schema))throw mn(new Error,Xp.SCHEMA_EXISTS_ERR(e.schema),Sn.BAD_REQUEST,Tu.LOG_LEVELS.ERROR,Xp.SCHEMA_EXISTS_ERR(e.schema),!0);return await ua.createSchema(e),`database '${e.schema}' successfully created`}a(UH,"createSchemaStructure");async function Ire(e){return gu(e),e.hash_attribute=e.primary_key??e.hash_attribute,await vH(e)}a(Ire,"createTable");async function vH(e){let t=mu.create_table_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);if(mu.validateTableResidence(e.residence),!await Su.checkSchemaTableExists(e.schema,e.table))throw mn(new Error,Xp.TABLE_EXISTS_ERR(e.schema,e.table),Sn.BAD_REQUEST,Tu.LOG_LEVELS.ERROR,Xp.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:Rre(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await ua.createTable(n,e);else throw mn(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Sn.BAD_REQUEST);else await ua.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(vH,"createTableStructure");async function wre(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=mu.schema_object(e),n=t??r;if(n)throw mn(n,n.message,Sn.BAD_REQUEST,void 0,void 0,!0);gu(e);let s=await Su.checkSchemaExists(e.schema);if(s)throw mn(new Error,s,Sn.NOT_FOUND,Tu.LOG_LEVELS.ERROR,s,!0);let i=await Su.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);await ua.dropSchema(e),Zp.signalSchemaChange(new em(process.pid,e.operation,e.schema)),await LH.purgeSchemaTableStreams(e.schema,o);let c=await MH(e);return c.message=`successfully deleted '${e.schema}'`,c}a(wre,"dropSchema");async function Cre(e){let t=mu.table_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);gu(e);let r=await Su.checkSchemaTableExists(e.schema,e.table);if(r)throw mn(new Error,r,Sn.NOT_FOUND,Tu.LOG_LEVELS.ERROR,r,!0);await ua.dropTable(e),await LH.purgeTableStream(e.schema,e.table);let n=await MH(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}a(Cre,"dropTable");async function Dre(e){let t=mu.attribute_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);gu(e);let r=await Su.checkSchemaTableExists(e.schema,e.table);if(r)throw mn(new Error,r,Sn.NOT_FOUND,Tu.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw mn(new Error,"You cannot drop a hash attribute",Sn.BAD_REQUEST,void 0,void 0,!0);if(Tu.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw mn(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Sn.BAD_REQUEST,void 0,void 0,!0);try{return await ua.dropAttribute(e),Pre(e),Zp.signalSchemaChange(new em(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw Are.error(`Got an error deleting attribute ${yre.inspect(e)}.`),n}}a(Dre,"dropAttribute");function Pre(e){let t=Object.values(global.hdb_schema[e.schema][e.table].attributes);for(let r=0;r<t.length;r++)t[r].attribute===e.attribute&&global.hdb_schema[e.schema][e.table].attributes.splice(r,1)}a(Pre,"dropAttributeFromGlobal");async function Lre(e){gu(e);let t=Ore()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw mn(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Sn.BAD_REQUEST,void 0,void 0,!0);return await ua.createAttribute(e),Zp.signalSchemaChange(new em(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(Lre,"createAttribute");function Mre(e){return ua.getBackup(e)}a(Mre,"getBackup")});var xH=N((mIe,HH)=>{"use strict";var{OPERATIONS_ENUM:Ure}=M(),jy=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Ure.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};HH.exports=jy});var zy=N((gIe,$H)=>{"use strict";var vre=Bn(),TIe=xH(),rm=te(),nm=M(),Bre=se(),{handleHDBError:kH,hdb_errors:Hre}=_e(),{HDB_ERROR_MSGS:FH,HTTP_STATUS_CODES:GH}=Hre,xre=Object.values(nm.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),qH="To use this operation audit log must be enabled in harperdb-config.yaml";$H.exports=kre;async function kre(e){if(rm.isEmpty(e.schema))throw new Error(FH.SCHEMA_REQUIRED_ERR);if(rm.isEmpty(e.table))throw new Error(FH.TABLE_REQUIRED_ERR);if(!Bre.get(nm.CONFIG_PARAMS.LOGGING_AUDITLOG))throw kH(new Error,qH,GH.BAD_REQUEST,nm.LOG_LEVELS.ERROR,qH,!0);let t=rm.checkSchemaTableExist(e.schema,e.table);if(t)throw kH(new Error,t,GH.NOT_FOUND,nm.LOG_LEVELS.ERROR,t,!0);if(!rm.isEmpty(e.search_type)&&xre.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await vre.readAuditLog(e)}a(kre,"readAuditLog")});var KH=N((RIe,VH)=>{"use strict";var{OPERATIONS_ENUM:Fre}=M(),Qy=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Fre.GET_BACKUP,this.schema=t,this.table=r}};VH.exports=Qy});var jH=N((NIe,WH)=>{"use strict";var Gre=Bn(),bIe=KH(),Jy=te(),qre=M(),OIe=se(),{handleHDBError:$re,hdb_errors:Vre}=_e(),{HDB_ERROR_MSGS:YH,HTTP_STATUS_CODES:Kre}=Vre;WH.exports=Yre;async function Yre(e){if(Jy.isEmpty(e.schema))throw new Error(YH.SCHEMA_REQUIRED_ERR);if(Jy.isEmpty(e.table))throw new Error(YH.TABLE_REQUIRED_ERR);let t=Jy.checkSchemaTableExist(e.schema,e.table);if(t)throw $re(new Error,t,Kre.NOT_FOUND,qre.LOG_LEVELS.ERROR,t,!0);return await Gre.getBackup(read_audit_log_object)}a(Yre,"getBackup")});var ex=N((wIe,ZH)=>{var Au=require("validate.js"),QH=Tt(),Ru=M(),{handleHDBError:Wre,hdb_errors:jre}=_e(),{HDB_ERROR_MSGS:Qt,HTTP_STATUS_CODES:zre}=jre,Xy=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Qre={STRUCTURE_USER:"structure_user"},zH=Object.values(Ru.ROLE_TYPES_ENUM),Jre="attribute_permissions",Xre="attribute_name",{PERMS_CRUD_ENUM:yu}=Ru,Zre=[Jre,...Object.values(yu)],JH=[yu.READ,yu.INSERT,yu.UPDATE],ene=[Xre,...JH];function tne(e){let t=Xy();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,XH(e,t)}a(tne,"addRoleValidation");function rne(e){let t=Xy();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,XH(e,t)}a(rne,"alterRoleValidation");function nne(e){let t=Xy();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,QH.validateObject(e,t)}a(nne,"dropRoleValidation");var sne=["operation","role","id","permission","hdb_user","hdb_auth_header","access"];function XH(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)sne.includes(n[o])||s.push(n[o]);s.length>0&&ir(Qt.INVALID_ROLE_JSON_KEYS(s),r);let i=QH.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{ir(o,r)}),e.permission){let o=ine(e);o&&ir(o,r),zH.forEach(c=>{e.permission[c]&&!Au.isBoolean(e.permission[c])&&ir(Qt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(zH.indexOf(o)<0){if(o===Qre.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let u=0,d=l.length;u<d;u++){let _=l[u];global.hdb_schema[_]||ir(Qt.SCHEMA_NOT_FOUND(_),r)}continue}ir(Qt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){ir(Qt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let u=c.tables[l];if(!l||!global.hdb_schema[o][l]){ir(Qt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(d=>{Zre.includes(d)||ir(Qt.INVALID_PERM_KEY(d),r,o,l)}),Object.values(yu).forEach(d=>{Au.isDefined(u[d])?Au.isBoolean(u[d])||ir(Qt.TABLE_PERM_NOT_BOOLEAN(d),r,o,l):ir(Qt.TABLE_PERM_MISSING(d),r,o,l)}),u.attribute_permissions===void 0){ir(Qt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){ir(Qt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}if(u.attribute_permissions){let d=global.hdb_schema[o][l].attributes.map(({attribute:E})=>E),_={read:!1,insert:!1,update:!1};for(let E in u.attribute_permissions){let f=u.attribute_permissions[E];if(Object.keys(f).forEach(T=>{!ene.includes(T)&&T!==yu.DELETE&&ir(Qt.INVALID_ATTR_PERM_KEY(T),r,o,l)}),!Au.isDefined(f.attribute_name)){ir(Qt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=f.attribute_name;if(!d.includes(h)){ir(Qt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}JH.forEach(T=>{Au.isDefined(f[T])?Au.isBoolean(f[T])||ir(Qt.ATTR_PERM_NOT_BOOLEAN(T,h),r,o,l):ir(Qt.ATTR_PERM_MISSING(T,h),r,o,l)}),!_.read&&f.read===!0&&(_.read=!0),!_.insert&&f.insert===!0&&(_.insert=!0),!_.update&&f.update===!0&&(_.update=!0)}if(u.read===!1&&_.read===!0||u.insert===!1&&_.insert===!0||u.update===!1&&_.update===!0){let E=`${o}.${l}`;ir(Qt.MISMATCHED_TABLE_ATTR_PERMS(E),r,o,l)}}}}return one(r)}a(XH,"customValidate");ZH.exports={addRoleValidation:tne,alterRoleValidation:rne,dropRoleValidation:nne};function ine(e){let{operation:t,permission:r}=e;if(t===Ru.OPERATIONS_ENUM.ADD_ROLE||t===Ru.OPERATIONS_ENUM.ALTER_ROLE){let n=r.super_user===!0,s=r.cluster_user===!0;if(Object.keys(r).length>1&&(n||s)){if(s&&n)return Qt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?Ru.ROLE_TYPES_ENUM.SUPER_USER:Ru.ROLE_TYPES_ENUM.CLUSTER_USER;return Qt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(ine,"validateNoSUPerms");function one(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:Qt.ROLE_PERMS_ERROR,...e};return Wre(new Error,n,zre.BAD_REQUEST)}else return null}a(one,"generateRolePermResponse");function ir(e,t,r,n){if(!r)t.main_permissions.push(e);else{let s=n?r+"_"+n:r;t.schema_permissions[s]?t.schema_permissions[s].push(e):t.schema_permissions[s]=[e]}}a(ir,"addPermError")});var lf=N((PIe,sx)=>{"use strict";var tx=un(),rx=Vr(),ane=uc(),eb=ex(),tb=no(),DIe=require("uuid").v4,cne=require("util"),sm=M(),lne=te(),rb=rx.searchByValue,une=rx.searchByHash,dne=cne.promisify(ane.delete),_ne=$s(),fne=Wl(),{hdb_errors:Ene,handleHDBError:Mc}=_e(),{HDB_ERROR_MSGS:nx,HTTP_STATUS_CODES:cf}=Ene,{UserEventMsg:nb}=qs();sx.exports={addRole:hne,alterRole:pne,dropRole:mne,listRoles:Sne};function Zy(e){try{e.hdb_auth_header&&delete e.hdb_auth_header,e.HDB_INTERNAL_PATH&&delete e.HDB_INTERNAL_PATH,e.operation&&delete e.operation,e.hdb_user&&delete e.hdb_user}catch{}return e}a(Zy,"scrubRoleDetails");async function hne(e){let t=eb.addRoleValidation(e);if(t)throw t;e=Zy(e);let r={schema:"system",table:"hdb_role",search_attribute:"role",search_value:e.role,hash_attribute:"id",get_attributes:["*"]},n;try{n=Array.from(await rb(r)||[])}catch(i){throw Mc(i)}if(n&&n.length>0)throw Mc(new Error,nx.ROLE_ALREADY_EXISTS(e.role),cf.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 tx.insert(s),tb.signalUserChange(new nb(process.pid)),e=Zy(e),e}a(hne,"addRole");async function pne(e){let t=eb.alterRoleValidation(e);if(t)throw t;e=Zy(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await tx.update(r)}catch(s){throw Mc(s)}if(n&&n?.message==="updated 0 of 1 records")throw Mc(new Error,"Invalid role id",cf.BAD_REQUEST,void 0,void 0,!0);return await tb.signalUserChange(new nb(process.pid)),e}a(pne,"alterRole");async function mne(e){let t=eb.dropRoleValidation(e);if(t)throw Mc(new Error,t,cf.BAD_REQUEST,void 0,void 0,!0);let r=new fne(sm.SYSTEM_SCHEMA_NAME,sm.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await une(r));if(n.length===0)throw Mc(new Error,nx.ROLE_NOT_FOUND,cf.NOT_FOUND,void 0,void 0,!0);let s=new _ne(sm.SYSTEM_SCHEMA_NAME,sm.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await rb(s)),o=!1;if(lne.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw Mc(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,cf.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await dne(c),tb.signalUserChange(new nb(process.pid)),`${n[0].role} successfully deleted`}a(mne,"dropRole");async function Sne(){return rb({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Sne,"listRoles")});var cx=N((MIe,ax)=>{"use strict";var Tne=se(),da=require("joi"),gne=Tt(),ix=require("moment"),Ane=require("fs-extra"),sb=require("path"),Rne=require("lodash"),uf=M(),{LOG_LEVELS:Uc}=M(),yne="YYYY-MM-DD hh:mm:ss",bne=sb.resolve(__dirname,"../logs");ax.exports=function(e){return gne.validateBySchema(e,One)};var One=da.object({from:da.custom(ox),until:da.custom(ox),level:da.valid(Uc.NOTIFY,Uc.FATAL,Uc.ERROR,Uc.WARN,Uc.INFO,Uc.DEBUG,Uc.TRACE),order:da.valid("asc","desc"),limit:da.number().min(1),start:da.number().min(0),log_name:da.custom(Nne)});function ox(e,t){if(ix(e,ix.ISO_8601).format(yne)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(ox,"validateDatetime");function Nne(e,t){if(Rne.invert(uf.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=Tne.get(uf.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?uf.LOG_NAMES.HDB:e,i=s===uf.LOG_NAMES.INSTALL?sb.join(bne,uf.LOG_NAMES.INSTALL):sb.join(n,s);return Ane.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(Nne,"validateReadLogPath")});var ob=N((vIe,ux)=>{"use strict";var im=M(),Ine=W(),wne=se(),Cne=cx(),ib=require("path"),lx=require("fs-extra"),{once:Dne}=require("events"),{handleHDBError:Pne,hdb_errors:Lne}=_e(),{PACKAGE_ROOT:Mne}=M(),Une=ib.join(Mne,"logs"),vne=1e3,Bne=200;ux.exports=Hne;async function Hne(e){let t=Cne(e);if(t)throw Pne(t,t.message,Lne.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=wne.get(im.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?im.LOG_NAMES.HDB:e.log_name,s=n===im.LOG_NAMES.INSTALL?ib.join(Une,im.LOG_NAMES.INSTALL):ib.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,l=c?new Date(e.from):void 0,u=e.until!==void 0,d=u?new Date(e.until):void 0,_=e.limit===void 0?vne:e.limit,E=e.order===void 0?void 0:e.order,f=e.start===void 0?0:e.start,h=f+_,T=0;E==="desc"&&!l&&!d&&(T=Math.max(lx.statSync(s).size-(h+5)*Bne,0));let m=lx.createReadStream(s,{start:T});m.on("error",H=>{Ine.error(H)});let g=0,S=[],b="",I;m.on("data",H=>{let X=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;H=b+H;let Y=0,V;for(;(V=X.exec(H))&&!m.destroyed;){I&&(I.message=H.slice(Y,V.index),B(I));let[ne,Q,de]=V,j=de.split("] ["),ae=j[0],be=j[1];j.splice(0,2),I={timestamp:Q,thread:ae,level:be,tags:j,message:""},Y=V.index+ne.length}b=H.slice(Y)}),m.on("end",H=>{m.destroyed||I&&(I.message=b.trim(),B(I))}),m.resume();function B(H){let X,Y,V;switch(!0){case(i&&c&&u):X=new Date(H.timestamp),Y=new Date(l),V=new Date(d),H.level===o&&X>=Y&&X<=V&&g<f?g++:H.level===o&&X>=Y&&X<=V&&(_a(H,E,S),g++,g===h&&m.destroy());break;case(i&&c):X=new Date(H.timestamp),Y=new Date(l),H.level===o&&X>=Y&&g<f?g++:H.level===o&&X>=Y&&(_a(H,E,S),g++,g===h&&m.destroy());break;case(i&&u):X=new Date(H.timestamp),V=new Date(d),H.level===o&&X<=V&&g<f?g++:H.level===o&&X<=V&&(_a(H,E,S),g++,g===h&&m.destroy());break;case(c&&u):X=new Date(H.timestamp),Y=new Date(l),V=new Date(d),X>=Y&&X<=V&&g<f?g++:X>=Y&&X<=V&&(_a(H,E,S),g++,g===h&&m.destroy());break;case i:H.level===o&&g<f?g++:H.level===o&&(_a(H,E,S),g++,g===h&&m.destroy());break;case c:X=new Date(H.timestamp),Y=new Date(l),X>=Y&&g<f?g++:X>=Y&&g>=f&&(_a(H,E,S),g++,g===h&&m.destroy());break;case u:X=new Date(H.timestamp),V=new Date(d),X<=V&&g<f?g++:X<=V&&g>=f&&(_a(H,E,S),g++,g===h&&m.destroy());break;default:g<f?g++:(_a(H,E,S),g++,g===h&&m.destroy())}}return a(B,"onLogMessage"),await Dne(m,"close"),S}a(Hne,"readLog");function _a(e,t,r){t==="desc"?xne(e,r):t==="asc"?kne(e,r):r.push(e)}a(_a,"pushLineToResult");function xne(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)>r?n=i+1:s=i}t.splice(n,0,e)}a(xne,"insertDescending");function kne(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)<r?n=i+1:s=i}t.splice(n,0,e)}a(kne,"insertAscending")});var om=N((GIe,Ex)=>{"use strict";var ab=require("joi"),{string:bu,boolean:dx,date:Fne}=ab.types(),Gne=Tt(),{validateSchemaExists:HIe,validateTableExists:xIe,validateSchemaName:kIe}=Ti(),qne=M(),$ne=Ct(),_x=se();_x.initSync();var FIe=bu.invalid(_x.get(qne.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern($ne.NATS_TERM_CONSTRAINTS_RX).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >","any.invalid":"'node_name' cannot be this nodes name"}).empty(null),fx={operation:bu.valid("add_node","update_node","set_node_replication"),node_name:bu.optional(),subscriptions:ab.array().items({table:bu.optional(),schema:bu.optional(),database:bu.optional(),subscribe:dx.required(),publish:dx.required().custom(Kne),start_time:Fne.iso()})};function Vne(e){return Gne.validateBySchema(e,ab.object(fx))}a(Vne,"addUpdateNodeValidator");function Kne(e,t){if(t.state.ancestors[2].operation==="add_node"&&e===!1&&t.state.ancestors[0].subscribe===!1)return t.message(`'subscriptions[${t.state.path[1]}]' subscribe and/or publish must be set to true when adding a node`)}a(Kne,"checkForFalsy");Ex.exports={addUpdateNodeValidator:Vne,validation_schema:fx}});var px=N(($Ie,hx)=>{var Yne=Tt(),Wne={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};hx.exports=function(e){return Yne.validateObject(e,Wne)}});var cb=N((KIe,Tx)=>{"use strict";var jne=px(),Ou=require("passport"),zne=require("passport-local").Strategy,Qne=require("passport-http").BasicStrategy,Jne=require("util"),Xne=xn(),Sx=Jne.callbackify(Xne.findAndValidateUser),VIe=Dn(),Zne=M(),mx=_u();Ou.use(new zne(function(e,t,r){Sx(e,t,r)}));Ou.use(new Qne(function(e,t,r){Sx(e,t,r)}));Ou.serializeUser(function(e,t){t(null,e)});Ou.deserializeUser(function(e,t){t(null,e)});function ese(e,t,r){if(e.raw?.user!==void 0)return r(null,e.raw.user);let n,s;if(e.headers?.authorization){let o=e.headers.authorization.split(" ");n=o[0],s=o[1]}function i(o,c){return o?r(o):c?r(null,c):r("Must login")}switch(a(i,"handleResponse"),n){case"Basic":Ou.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===Zne.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?mx.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):mx.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:Ou.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(ese,"authorize");function tse(e,t){let r=jne(e);if(r){t(r);return}let n={authorized:!0,messages:[]},s=e.user.role;if(!s?.permission)return t("Invalid role");let i=JSON.parse(s.permission);if(i.super_user)return t(null,n);if(!i[e.schema])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.schema} schema`),t(null,n);if(!i[e.schema].tables[e.table])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.table} table`),t(null,n);if(!i[e.schema].tables[e.table][e.operation])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.operation} on ${e.table} table`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&!e.attributes)return n.authorized=!1,n.messages.push(`${e.schema}.${e.table} has attribute permissions. Missing attributes to validate`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&e.attributes){let o=i[e.schema].tables[e.table].attribute_permissions;for(let c in o)e.attributes.indexOf(o[c].attribute_name)>-1&&!o[c][e.operation]&&(n.authorized=!1,n.messages.push(`Not authorized to ${e.operation} ${o[c].attribute_name} `))}return t(null,n)}a(tse,"checkPermissions");Tx.exports={authorize:ese,checkPermissions:tse}});var Nu=N((WIe,gx)=>{"use strict";var lb=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},ub=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};gx.exports={Node:lb,NodeSubscription:ub}});var Rx=N((zIe,Ax)=>{"use strict";var rse=M().OPERATIONS_ENUM,db=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=rse.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Ax.exports=db});var df=N((JIe,yx)=>{"use strict";var _b=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},fb=class{static{a(this,"RemotePayloadSubscription")}constructor(t,r,n,s,i,o,c){this.schema=t,this.table=r,this.hash_attribute=n,this.publish=s,this.subscribe=i,this.start_time=o,c!==void 0&&(this.attributes=c)}};yx.exports={RemotePayloadObject:_b,RemotePayloadSubscription:fb}});var Ox=N((ZIe,bx)=>{"use strict";var Eb=class{static{a(this,"TableSizeObject")}constructor(t,r,n=0,s=0,i=0,o=0){this.schema=t,this.table=r,this.table_size=n,this.record_count=s,this.transaction_log_size=i,this.transaction_log_record_count=o}};bx.exports=Eb});var Ix=N((iwe,Nx)=>{"use strict";var nse=Ox(),twe=Ht(),rwe=ht(),sse=W(),{getSchemaPath:nwe,getTransactionAuditStorePath:swe}=gt(),{getDatabases:ise}=(Pe(),oe(lt));Nx.exports=ose;async function ose(e){let t=new nse;try{let r=ise()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats();t.schema=e.schema,t.table=e.name,t.record_count=n.entryCount,t.transaction_log_record_count=s.entryCount}catch(r){sse.warn(`unable to stat table dbi due to ${r}`)}return t}a(ose,"lmdbGetTableSize")});var Cx=N((awe,wx)=>{"use strict";var hb=class{static{a(this,"SystemInformationObject")}constructor(t,r,n,s,i,o,c){this.system=t,this.time=r,this.cpu=n,this.memory=s,this.disk=i,this.network=o,this.harperdb_processes=c}};wx.exports=hb});var wu=N((fwe,Mx)=>{"use strict";var ase=require("fs-extra"),cse=require("path"),Qr=require("systeminformation"),fa=W(),Dx=mr(),lwe=Ct(),Iu=M(),lse=Ix(),use=ro(),{getThreadInfo:Px}=dt(),_f=se();_f.initSync();var dse=Cx(),{openEnvironment:uwe}=ht(),{getSchemaPath:dwe}=gt(),{database:_we,databases:pb}=(Pe(),oe(lt)),am;Mx.exports={getHDBProcessInfo:gb,getNetworkInfo:Rb,getDiskInfo:Ab,getMemoryInfo:Tb,getCPUInfo:Sb,getTimeInfo:mb,getSystemInformation:yb,systemInformation:_se,getTableSize:bb,getMetrics:Ob};function mb(){return Qr.time()}a(mb,"getTimeInfo");async function Sb(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:u,...d}=await Qr.cpu();d.cpu_speed=await Qr.cpuCurrentSpeed();let{raw_currentload:_,raw_currentload_idle:E,raw_currentload_irq:f,raw_currentload_nice:h,raw_currentload_system:T,raw_currentload_user:m,cpus:g,...S}=await Qr.currentLoad();return S.cpus=[],g.forEach(b=>{let{raw_load:I,raw_load_idle:B,raw_load_irq:H,raw_load_nice:X,raw_load_system:Y,raw_load_user:V,...ne}=b;S.cpus.push(ne)}),d.current_load=S,d}catch(e){return fa.error(`error in getCPUInfo: ${e}`),{}}}a(Sb,"getCPUInfo");async function Tb(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Qr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return fa.error(`error in getMemoryInfo: ${e}`),{}}}a(Tb,"getMemoryInfo");async function gb(){let e={core:[],clustering:[]};try{let t=await Qr.processes(),r;try{r=Number.parseInt(await ase.readFile(cse.join(_f.get(Iu.CONFIG_PARAMS.ROOTPATH),Iu.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Iu.NODE_ERROR_CODES.ENOENT)fa.warn("Unable to locate 'hdb.pid' file, try stopping and starting HarperDB. This could be because HarperDB is not running.");else throw n}t.list.forEach(n=>{n.pid===r?e.core.push(n):n.name==="nats-server"&&e.clustering.push(n)});for(let n of e.core)for(let s of t.list)s.pid===n.parentPid&&(s.name==="PM2"||s.command==="PM2")&&(n.parent="PM2");return e}catch(t){return fa.error(`error in getHDBProcessInfo: ${t}`),e}}a(gb,"getHDBProcessInfo");async function Ab(){let e={};try{if(!_f.get(Iu.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Qr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...u}=await Qr.fsStats();return e.read_write=u,e.size=await Qr.fsSize(),e}catch(t){return fa.error(`error in getDiskInfo: ${t}`),e}}a(Ab,"getDiskInfo");async function Rb(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return _f.get(Iu.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await Qr.networkInterfaceDefault(),e.latency=await Qr.inetChecksite("google.com"),(await Qr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:u,ieee8021xState:d,carrier_changes:_,...E}=n;e.interfaces.push(E)}),(await Qr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)})),e}catch(t){return fa.error(`error in getNetworkInfo: ${t}`),e}}a(Rb,"getNetworkInfo");async function yb(){if(am!==void 0)return am;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Qr.osInfo();e=c;let l=await Qr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,am=e,am}catch(t){return fa.error(`error in getSystemInformation: ${t}`),e}}a(yb,"getSystemInformation");async function bb(){let e=[],t=await use.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await lse(n));return e}a(bb,"getTableSize");async function Ob(){let e={};for(let t in pb){let r=e[t]={},n=r.tables={};for(let s in pb[t])try{let i=pb[t][s];if(!r.readers&&(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[u,d,_]=l.trim().split(" ");return{pid:u,thread:d,txnid:_}}),i.auditStore)){let{treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:d,entryCount:_,overflowPages:E}=i.auditStore.getStats();r.audit={treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:d,entryCount:_,overflowPages:E}}let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){fa.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(Ob,"getMetrics");async function Lx(){if(_f.get(Iu.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await Dx.getNATSReferences(),t=await Dx.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(Lx,"getNatsStreamInfo");async function _se(e){let t=new dse;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await yb(),t.time=mb(),t.cpu=await Sb(),t.memory=await Tb(),t.disk=await Ab(),t.network=await Rb(),t.harperdb_processes=await gb(),t.table_size=await bb(),t.metrics=await Ob(),t.threads=await Px(),t.replication=await Lx(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await yb();break;case"time":t.time=mb();break;case"cpu":t.cpu=await Sb();break;case"memory":t.memory=await Tb();break;case"disk":t.disk=await Ab();break;case"network":t.network=await Rb();break;case"harperdb_processes":t.harperdb_processes=await gb();break;case"table_size":t.table_size=await bb();break;case"database_metrics":case"metrics":t.metrics=await Ob();break;case"threads":t.threads=await Px();break;case"replication":t.replication=await Lx();break;default:break}return t}a(_se,"systemInformation")});var vc=N((hwe,Ux)=>{"use strict";Ux.exports={version:fse,printVersion:Ese};var cm=Jl();function fse(){if(cm)return cm.version}a(fse,"version");function Ese(){cm&&console.log(`HarperDB Version ${cm.version}`)}a(Ese,"printVersion")});var Di=N((Twe,xx)=>{"use strict";var hse=un(),Nb=te(),pse=require("util"),Bc=M(),vx=se();vx.initSync();var mse=cb(),Bx=Vr(),{Node:mwe,NodeSubscription:Swe}=Nu(),Sse=Wl(),Tse=Rx(),{RemotePayloadObject:gse,RemotePayloadSubscription:Ase}=df(),{handleHDBError:Rse,hdb_errors:yse}=_e(),{HTTP_STATUS_CODES:bse,HDB_ERROR_MSGS:Ose}=yse,Nse=$s(),Ise=wu(),wse=vc(),{getDatabases:Cse}=(Pe(),oe(lt)),Dse=pse.promisify(mse.authorize),Pse=Bx.searchByHash,Lse=Bx.searchByValue;xx.exports={authHeaderToUser:Mse,isEmpty:Use,getNodeRecord:vse,upsertNodeRecord:Bse,buildNodePayloads:Hse,checkClusteringEnabled:xse,getAllNodeRecords:kse,getSystemInfo:Fse,reverseSubscription:Hx};async function Mse(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await Dse(t,null),e}a(Mse,"authHeaderToUser");function Use(e){return e==null}a(Use,"isEmpty");async function vse(e){let t=new Sse(Bc.SYSTEM_SCHEMA_NAME,Bc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return Pse(t)}a(vse,"getNodeRecord");async function Bse(e){let t=new Tse(Bc.SYSTEM_SCHEMA_NAME,Bc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return hse.upsert(t)}a(Bse,"upsertNodeRecord");function Hx(e){if(Nb.isEmpty(e.subscribe)||Nb.isEmpty(e.publish))throw new Error("Received invalid subscription object");let{schema:t,table:r,hash_attribute:n}=e,s={schema:t,table:r,hash_attribute:n};return e.subscribe===!0&&e.publish===!1?(s.subscribe=!1,s.publish=!0):e.subscribe===!1&&e.publish===!0?(s.subscribe=!0,s.publish=!1):(s.subscribe=e.subscribe,s.publish=e.publish),s}a(Hx,"reverseSubscription");function Hse(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:u}=c,d=Nb.getTableHashAttribute(l,u),{subscribe:_,publish:E}=Hx(c),f=Cse()[l]?.[u],h=new Ase(l,u,d,E,_,c.start_time,f.schemaDefined?f.attributes:void 0);s.push(h)}return new gse(r,t,s,n)}a(Hse,"buildNodePayloads");function xse(){if(!vx.get(Bc.CONFIG_PARAMS.CLUSTERING_ENABLED))throw Rse(new Error,Ose.CLUSTERING_NOT_ENABLED,bse.BAD_REQUEST,void 0,void 0,!0)}a(xse,"checkClusteringEnabled");async function kse(){let e=new Nse(Bc.SYSTEM_SCHEMA_NAME,Bc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await Lse(e))}a(kse,"getAllNodeRecords");async function Fse(){let e=await Ise.getSystemInformation();return{hdb_version:wse.version(),node_version:e.node_version,platform:e.platform}}a(Fse,"getSystemInfo")});var Ib=N((Awe,Yx)=>{"use strict";var lm=mr(),kx=te(),Fx=Ct(),Gx=M(),um=W(),qx=tm(),Gse=w_(),{RemotePayloadObject:qse}=df(),{handleHDBError:$x,hdb_errors:$se}=_e(),{HTTP_STATUS_CODES:Vx}=$se,{NodeSubscription:Kx}=Nu();Yx.exports=Vse;async function Vse(e,t){let r;try{r=await lm.request(`${t}.${Fx.REQUEST_SUFFIX}`,new qse(Gx.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),um.trace("Response from remote describe all request:",r)}catch(o){um.error(`addNode received error from describe all request to remote node: ${o}`);let c=lm.requestErrorHandler(o,"add_node",t);throw $x(new Error,c,Vx.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===Fx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw $x(new Error,o,Vx.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===Gx.SYSTEM_SCHEMA_NAME){await lm.createLocalTableStream(l,c);let h=new Kx(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let u=kx.doesSchemaExist(l),d=n[l]!==void 0,_=c?kx.doesTableExist(l,c):!0,E=c?n?.[l]?.[c]!==void 0:!0;if(!u&&!d||!_&&!E){s.push(o);continue}if(!u&&d&&(um.trace(`addNode creating schema: ${l}`),await qx.createSchema({operation:"create_schema",schema:l})),!_&&E){um.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new Gse(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await qx.createTable(h)}await lm.createLocalTableStream(l,c);let f=new Kx(l,c,o.publish,o.subscribe);f.start_time=o.start_time,i.push(f)}return{added:i,skipped:s}}a(Vse,"reviewSubscriptions")});var Hc={};je(Hc,{addNodeBack:()=>zse,removeNodeBack:()=>Qse,setNode:()=>jse});async function jse(e){e.node_name&&!e.hostname&&(e.hostname=e.node_name),e.verify_tls!==void 0&&(e.rejectUnauthorized=e.verify_tls);let{url:t,hostname:r}=e;t?r||(r=e.hostname=zs(t)):t=Jp(r);let n=(0,jx.validateBySchema)(e,Wse);if(n)throw(0,uo.handleHDBError)(n,n.message,Yse.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new uo.ClientError("url or hostname is required for remove_node operation");let f=r,h=Sr(),T=await h.get(f);if(!T)throw new uo.ClientError(f+" does not exist");try{await af({url:T.url},{operation:ff.OPERATIONS_ENUM.REMOVE_NODE_BACK,name:T?.subscriptions?.length>0?ot():f},void 0)}catch(m){$n.warn(`Error removing node from target node ${f}, if it is offline and we be online in the future, you may need to clean up this node manually, or retry:`,m)}return await h.delete(f),`Successfully removed '${f}' from cluster`}if(!t)throw new uo.ClientError("url required for this operation");let s=ra();if(s==null)throw new uo.ClientError("replication url is missing from harperdb-config.yaml");let i,o,c;if(t?.startsWith("wss:")){i=await(0,ps.getReplicationCert)();let f=await(0,ps.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,ps.createCsr)(),$n.info("Sending CSR to target node:",t)):f&&(c=f.certificate,$n.info("Sending CA named",f.name,"to target node",t))}let l={operation:ff.OPERATIONS_ENUM.ADD_NODE_BACK,hostname:(0,zx.get)(ff.CONFIG_PARAMS.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:o,cert_auth:c,authorization:e.retain_authorization?e.authorization:null};if(e.subscriptions?l.subscriptions=e.subscriptions.map(Wx):l.subscriptions=null,e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let f=Wx(e);l.subscribe=f.subscribe,l.publish=f.publish}e?.authorization?.username&&e?.authorization?.password&&(e.authorization="Basic "+Buffer.from(e.authorization.username+":"+e.authorization.password).toString("base64"));let u,d;try{u=await af({url:t},l,e)}catch(f){f.message=`Error returned from ${t}: `+f.message,$n.warn("Error adding node:",t,"to cluster:",f),d=f}if(o&&(!u?.certificate||!u?.certificate?.includes?.("BEGIN CERTIFICATE")))throw d?(d.message+=" and connection was required to sign certificate",d):new Error(`Unexpected certificate signature response from node ${t} response: ${JSON.stringify(u)}`);o&&($n.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,ps.setCertTable)({name:Kse.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,ps.setCertTable)({name:ot(),uses:["https","operations","wss"],certificate:u.certificate,private_key_name:i?.options?.key_file,is_authority:!1,is_self_signed:!1}),c=u.signingCA);let _={url:t,ca:u?.usingCA};if(e.hostname&&(_.name=e.hostname),e.subscriptions?_.subscriptions=e.subscriptions:_.replicates=!0,e.start_time&&(_.start_time=typeof e.start_time=="string"?new Date(e.start_time).getTime():e.start_time),e.retain_authorization&&(_.authorization=e.authorization),_.replicates){let f={url:s,ca:c,replicates:!0,subscriptions:null};e.retain_authorization&&(f.authorization=e.authorization),e.start_time&&(f.start_time=e.start_time),await co(ot(),f)}await co(u?u.nodeName:_.name??zs(t),_);let E;return e.operation==="update_node"?E=`Successfully updated '${t}'`:E=`Successfully added '${t}' to cluster`,d&&(E+=" but there was an error updating target node: "+d.message),E}async function zse(e){$n.trace("addNodeBack received request:",e);let t=await(0,ps.signCertificate)(e),r;e.csr?(r=t.signingCA,$n.info("addNodeBack received CSR from node:",e.url,"this node will use and respond with CA that was used to issue CSR")):(r=e?.cert_auth,$n.info("addNodeBack received CA from node:",e.url));let n={url:e.url,ca:r};e.subscriptions?n.subscriptions=e.subscriptions:(n.replicates=!0,n.subscriptions=null),e.start_time&&(n.start_time=e.start_time),e.authorization&&(n.authorization=e.authorization);let s=await(0,ps.getReplicationCertAuth)();if(n.replicates){let i={url:ra(),ca:s?.certificate,replicates:!0,subscriptions:null};e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await co(ot(),i)}return await co(e.hostname,n),t.nodeName=ot(),t.usingCA=s?.certificate,$n.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function Qse(e){$n.trace("removeNodeBack received request:",e),await Sr().delete(e.name)}function Wx(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var ps,jx,Cu,zx,ff,$n,uo,Kse,Yse,Wse,xc=Ie(()=>{ps=L(Xs()),jx=L(Tt()),Cu=L(require("joi")),zx=L(se()),ff=L(M());J_();cu();us();$n=L(W()),uo=L(_e()),{pki:Kse}=require("node-forge"),{HTTP_STATUS_CODES:Yse}=uo.hdb_errors,Wse=Cu.default.object({hostname:Cu.default.string(),verify_tls:Cu.default.boolean(),replicates:Cu.default.boolean(),subscriptions:Cu.default.array()});a(jse,"setNode");a(zse,"addNodeBack");a(Qse,"removeNodeBack");a(Wx,"reverseSubscription")});var pf=N((Cwe,Jx)=>{"use strict";var{handleHDBError:dm,hdb_errors:Jse}=_e(),{HTTP_STATUS_CODES:_m}=Jse,{addUpdateNodeValidator:Xse}=om(),fm=W(),Em=M(),Qx=Ct(),Zse=te(),Ef=mr(),hf=Di(),wb=se(),eie=Ib(),{Node:tie,NodeSubscription:rie}=Nu(),{broadcast:nie}=dt(),{setNode:sie}=(xc(),oe(Hc)),Iwe=se(),wwe=M(),iie="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",oie="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",aie=wb.get(Em.CONFIG_PARAMS.CLUSTERING_NODENAME);Jx.exports=cie;async function cie(e,t=!1){if(fm.trace("addNode called with:",e),wb.get(Em.CONFIG_PARAMS.REPLICATION_URL)||wb.get(Em.CONFIG_PARAMS.REPLICATION_HOSTNAME))return sie(e);hf.checkClusteringEnabled();let r=Xse(e);if(r)throw dm(r,r.message,_m.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let _=await hf.getNodeRecord(n);if(!Zse.isEmptyOrZeroLength(_))throw dm(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,_m.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await eie(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=iie,o;let c=hf.buildNodePayloads(s,aie,Em.OPERATIONS_ENUM.ADD_NODE,await hf.getSystemInfo()),l=[];for(let _=0,E=s.length;_<E;_++){let f=s[_];s[_].start_time===void 0&&delete s[_].start_time,l.push(new rie(f.schema,f.table,f.publish,f.subscribe))}fm.trace("addNode sending remote payload:",c);let u;try{u=await Ef.request(`${n}.${Qx.REQUEST_SUFFIX}`,c)}catch(_){fm.error(`addNode received error from request: ${_}`);for(let f=0,h=s.length;f<h;f++){let T=s[f];T.publish=!1,T.subscribe=!1,await Ef.updateRemoteConsumer(T,n)}let E=Ef.requestErrorHandler(_,"add_node",n);throw dm(new Error,E,_m.INTERNAL_SERVER_ERROR,"error",E)}if(u.status===Qx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let _=`Error returned from remote node ${n}: ${u.message}`;throw dm(new Error,_,_m.INTERNAL_SERVER_ERROR,"error",_)}fm.trace(u);for(let _=0,E=s.length;_<E;_++){let f=s[_];await Ef.updateRemoteConsumer(f,n),f.subscribe===!0&&await Ef.updateConsumerIterator(f.schema,f.table,n,"start")}let d=new tie(n,l,u.system_info);return await hf.upsertNodeRecord(d),nie({type:"nats_update"}),i.length>0?o.message=oie:o.message=`Successfully added '${n}' to manifest`,o}a(cie,"addNode")});var Lb=N((Lwe,Zx)=>{"use strict";var{handleHDBError:Cb,hdb_errors:lie}=_e(),{HTTP_STATUS_CODES:Db}=lie,{addUpdateNodeValidator:uie}=om(),mf=W(),hm=M(),Xx=Ct(),Pwe=te(),Sf=mr(),Tf=Di(),Pb=se(),{cloneDeep:die}=require("lodash"),_ie=Ib(),{Node:fie,NodeSubscription:Eie}=Nu(),{broadcast:hie}=dt(),{setNode:pie}=(xc(),oe(Hc)),mie="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",Sie="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Tie=Pb.get(hm.CONFIG_PARAMS.CLUSTERING_NODENAME);Zx.exports=gie;async function gie(e){if(mf.trace("updateNode called with:",e),Pb.get(hm.CONFIG_PARAMS.REPLICATION_URL)??Pb.get(hm.CONFIG_PARAMS.REPLICATION_HOSTNAME))return pie(e);Tf.checkClusteringEnabled();let t=uie(e);if(t)throw Cb(t,t.message,Db.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Tf.getNodeRecord(r);s.length>0&&(n=die(s));let{added:i,skipped:o}=await _ie(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=mie,c;let l=Tf.buildNodePayloads(i,Tie,hm.OPERATIONS_ENUM.UPDATE_NODE,await Tf.getSystemInfo());for(let d=0,_=i.length;d<_;d++){let E=i[d];mf.trace(`updateNode updating work stream for node: ${r} subscription:`,E),i[d].start_time===void 0&&delete i[d].start_time}mf.trace("updateNode sending remote payload:",l);let u;try{u=await Sf.request(`${r}.${Xx.REQUEST_SUFFIX}`,l)}catch(d){mf.error(`updateNode received error from request: ${d}`);let _=Sf.requestErrorHandler(d,"update_node",r);throw Cb(new Error,_,Db.INTERNAL_SERVER_ERROR,"error",_)}if(u.status===Xx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${r}: ${u.message}`;throw Cb(new Error,d,Db.INTERNAL_SERVER_ERROR,"error",d)}mf.trace(u);for(let d=0,_=i.length;d<_;d++){let E=i[d];await Sf.updateRemoteConsumer(E,r),E.subscribe===!0?await Sf.updateConsumerIterator(E.schema,E.table,r,"start"):await Sf.updateConsumerIterator(E.schema,E.table,r,"stop")}return n||(n=[new fie(r,[],u.system_info)]),await Aie(n[0],i,u.system_info),o.length>0?c.message=Sie:c.message=`Successfully updated '${r}'`,c}a(gie,"updateNode");async function Aie(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let l=0,u=e.subscriptions.length;l<u;l++){let d=n.subscriptions[l];if(d.schema===o.schema&&d.table===o.table){d.publish=o.publish,d.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new Eie(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await Tf.upsertNodeRecord(n),hie({type:"nats_update"})}a(Aie,"updateNodeTable")});var sk=N((Uwe,nk)=>{"use strict";var rk=require("joi"),{string:ek}=rk.types(),Rie=Tt(),tk=M(),yie=se(),bie=Ct();nk.exports=Oie;function Oie(e){let t=ek.invalid(yie.get(tk.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(bie.NATS_TERM_CONSTRAINTS_RX).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >","any.invalid":"'node_name' cannot be this nodes name"}).empty(null),r=rk.object({operation:ek.valid(tk.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return Rie.validateBySchema(e,r)}a(Oie,"removeNodeValidator")});var Af=N((Bwe,lk)=>{"use strict";var{handleHDBError:ik,hdb_errors:Nie}=_e(),{HTTP_STATUS_CODES:ok}=Nie,Iie=sk(),gf=W(),ak=Di(),wie=te(),Du=M(),ck=Ct(),Mb=mr(),Ub=se(),{RemotePayloadObject:Cie}=df(),{NodeSubscription:Die}=Nu(),Pie=I_(),Lie=uc(),{broadcast:Mie}=dt(),{setNode:Uie}=(xc(),oe(Hc)),vie=Ub.get(Du.CONFIG_PARAMS.CLUSTERING_NODENAME);lk.exports=Bie;async function Bie(e){if(gf.trace("removeNode called with:",e),Ub.get(Du.CONFIG_PARAMS.REPLICATION_URL)??Ub.get(Du.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Uie(e);ak.checkClusteringEnabled();let t=Iie(e);if(t)throw ik(t,t.message,ok.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await ak.getNodeRecord(r);if(wie.isEmptyOrZeroLength(n))throw ik(new Error,`Node '${r}' was not found.`,ok.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new Cie(Du.OPERATIONS_ENUM.REMOVE_NODE,vie,[]),i,o=!1;for(let l=0,u=n.subscriptions.length;l<u;l++){let d=n.subscriptions[l];d.subscribe===!0&&await Mb.updateConsumerIterator(d.schema,d.table,r,"stop");try{await Mb.updateRemoteConsumer(new Die(d.schema,d.table,!1,!1),r)}catch(_){gf.error(_)}}try{i=await Mb.request(`${r}.${ck.REQUEST_SUFFIX}`,s),gf.trace("Remove node reply from remote node:",r,i)}catch(l){gf.error("removeNode received error from request:",l),o=!0}let c=new Pie(Du.SYSTEM_SCHEMA_NAME,Du.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Lie.deleteRecord(c),Mie({type:"nats_update"}),i?.status===ck.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(gf.error("Error returned from remote node:",r,i?.message),`Successfully removed '${r}' from local manifest, however there was an error reaching remote node. Check the logs for more details.`):`Successfully removed '${r}' from manifest`}a(Bie,"removeNode")});var _k=N((xwe,dk)=>{"use strict";var uk=require("joi"),{string:Hie,array:xie}=uk.types(),kie=Tt(),Fie=om();dk.exports=Gie;function Gie(e){let t=uk.object({operation:Hie.valid("configure_cluster").required(),connections:xie.items(Fie.validation_schema).required()});return kie.validateBySchema(e,t)}a(Gie,"configureClusterValidator")});var vb=N((Fwe,mk)=>{"use strict";var fk=M(),pm=W(),qie=te(),$ie=se(),Vie=Af(),Kie=pf(),Yie=Di(),Wie=_k(),{handleHDBError:Ek,hdb_errors:jie}=_e(),{HTTP_STATUS_CODES:hk}=jie,zie="Configure cluster complete.",Qie="Failed to configure the cluster. Check the logs for more details.",Jie="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";mk.exports=Xie;async function Xie(e){pm.trace("configure cluster called with:",e);let t=Wie(e);if(t)throw Ek(t,t.message,hk.BAD_REQUEST,void 0,void 0,!0);let r=await Yie.getAllNodeRecords(),n=[];if($ie.get(fk.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let d=0,_=r.length;d<_;d++){let E=await pk(Vie,{operation:fk.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[d].name},r[d].name);n.push(E)}pm.trace("All results from configure_cluster remove node:",n)}let s=[],i=e.connections.length;for(let d=0;d<i;d++){let _=e.connections[d],E=await pk(Kie,_,_.node_name);s.push(E)}pm.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,u=n.concat(s);for(let d=0,_=u.length;d<_;d++){let E=u[d];E.status==="rejected"&&(pm.error(E.node_name,E?.error?.message,E?.error?.stack),o.includes(E.node_name)||o.push(E.node_name)),(E?.result?.message?.includes?.("Successfully")||E?.result?.includes?.("Successfully"))&&(l=!0),!(typeof E.result=="string"&&E.result.includes("Successfully removed")||E.status==="rejected")&&c.push({node_name:E?.node_name,response:E?.result})}if(qie.isEmptyOrZeroLength(o))return{message:zie,connections:c};if(l)return{message:Jie,failed_nodes:o,connections:c};throw Ek(new Error,Qie,hk.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(Xie,"configureCluster");async function pk(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(pk,"functionWrapper")});var Ak=N((qwe,gk)=>{"use strict";var Rf=require("joi"),Zie=Tt(),{validateSchemaExists:Sk,validateTableExists:eoe,validateSchemaName:Tk}=Ti(),toe=Rf.object({operation:Rf.string().valid("purge_stream"),schema:Rf.string().custom(Sk).custom(Tk).optional(),database:Rf.string().custom(Sk).custom(Tk).optional(),table:Rf.string().custom(eoe).required()});function roe(e){return Zie.validateBySchema(e,toe)}a(roe,"purgeStreamValidator");gk.exports=roe});var Bb=N((Vwe,Rk)=>{"use strict";var{handleHDBError:noe,hdb_errors:soe}=_e(),{HTTP_STATUS_CODES:ioe}=soe,ooe=Ak(),aoe=mr(),coe=Di();Rk.exports=loe;async function loe(e){e.schema=e.schema??e.database;let t=ooe(e);if(t)throw noe(t,t.message,ioe.BAD_REQUEST,void 0,void 0,!0);coe.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await aoe.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(loe,"purgeStream")});var Sm=N((Ywe,Ck)=>{"use strict";var xb=Di(),uoe=mr(),mm=se(),Pu=M(),kc=Ct(),doe=te(),Hb=W(),{RemotePayloadObject:_oe}=df(),{ErrorCode:yk}=require("nats"),{parentPort:bk}=require("worker_threads"),{onMessageByType:foe}=dt(),{getThisNodeName:Eoe}=(us(),oe(ca)),{requestClusterStatus:hoe}=(J_(),oe(AB)),Ok=mm.get(Pu.CONFIG_PARAMS.CLUSTERING_ENABLED),Nk=mm.get(Pu.CONFIG_PARAMS.CLUSTERING_NODENAME);Ck.exports={clusterStatus:poe,buildNodeStatus:wk};var Ik;foe("cluster-status",async e=>{Ik(e)});async function poe(){if(mm.get(Pu.CONFIG_PARAMS.REPLICATION_URL)||mm.get(Pu.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;return bk?(bk.postMessage({type:"request-cluster-status"}),n=await new Promise(s=>{Ik=s})):n=hoe(),n.node_name=Eoe(),n.is_enabled=!0,n}let e={node_name:Nk,is_enabled:Ok,connections:[]};if(!Ok)return e;let t=await xb.getAllNodeRecords();if(doe.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(wk(t[n],e.connections));return await Promise.allSettled(r),e}a(poe,"clusterStatus");async function wk(e,t){let r=e.name,n=new _oe(Pu.OPERATIONS_ENUM.CLUSTER_STATUS,Nk,void 0,await xb.getSystemInfo()),s,i,o=kc.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await uoe.request(kc.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===kc.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=kc.CLUSTER_STATUS_STATUSES.CLOSED,Hb.error(`Error getting node status from ${r} `,s))}catch(l){Hb.warn(`Error getting node status from ${r}`,l),l.code===yk.NoResponders?o=kc.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===yk.Timeout?o=kc.CLUSTER_STATUS_STATUSES.TIMEOUT:o=kc.CLUSTER_STATUS_STATUSES.CLOSED}let c=new moe(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let l={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==Pu.PRE_4_0_0_VERSION&&await xb.upsertNodeRecord(l)}catch(l){Hb.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(wk,"buildNodeStatus");function moe(e,t,r,n,s,i,o,c){this.node_name=e,this.status=t,this.ports={clustering:r,operations_api:n},this.latency_ms=s,this.uptime=i,this.subscriptions=o,this.system_info=c}a(moe,"NodeStatusObject")});var Fb=N((jwe,Dk)=>{"use strict";var{handleHDBError:Soe,hdb_errors:Toe}=_e(),{HTTP_STATUS_CODES:goe}=Toe,Aoe=mr(),Roe=Di(),kb=te(),Tm=require("joi"),yoe=Tt(),boe=2e3,Ooe=Tm.object({timeout:Tm.number().min(1),connected_nodes:Tm.boolean(),routes:Tm.boolean()});Dk.exports=Noe;async function Noe(e){Roe.checkClusteringEnabled();let t=yoe.validateBySchema(e,Ooe);if(t)throw Soe(t,t.message,goe.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||kb.autoCastBoolean(n),o=s===void 0||kb.autoCastBoolean(s),c={nodes:[]},l=await Aoe.getServerList(r??boe),u={};if(i)for(let d=0,_=l.length;d<_;d++){let E=l[d].statsz;E&&(u[l[d].server.name]=E.routes)}for(let d=0,_=l.length;d<_;d++){if(l[d].statsz)continue;let E=l[d].server,f=l[d].data;if(E.name.endsWith("-hub")){let h={name:E.name.slice(0,-4),response_time:l[d].response_time};i&&(h.connected_nodes=[],u[E.name]&&u[E.name].forEach(T=>{h.connected_nodes.includes(T.name.slice(0,-4))||h.connected_nodes.push(T.name.slice(0,-4))})),o&&(h.routes=f.cluster?.urls?f.cluster?.urls.map(T=>({host:T.split(":")[0],port:kb.autoCast(T.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(Noe,"clusterNetwork")});var Uk=N((Qwe,Mk)=>{"use strict";var Gb=require("joi"),Pk=Tt(),{route_constraints:Lk}=gg();Mk.exports={setRoutesValidator:Ioe,deleteRoutesValidator:woe};function Ioe(e){let t=Gb.object({server:Gb.valid("hub","leaf"),routes:Lk.required()});return Pk.validateBySchema(e,t)}a(Ioe,"setRoutesValidator");function woe(e){let t=Gb.object({routes:Lk.required()});return Pk.validateBySchema(e,t)}a(woe,"deleteRoutesValidator")});var gm=N((Xwe,Gk)=>{"use strict";var _o=wt(),qb=te(),ms=M(),Lu=se(),vk=Uk(),{handleHDBError:Bk,hdb_errors:Coe}=_e(),{HTTP_STATUS_CODES:Hk}=Coe,xk="cluster routes successfully set",kk="cluster routes successfully deleted";Gk.exports={setRoutes:Poe,getRoutes:Loe,deleteRoutes:Moe};function Doe(e){let t=_o.getClusteringRoutes(),r=e.server==="hub"?t.hub_routes:t.leaf_routes,n=e.server==="hub"?t.leaf_routes:t.hub_routes,s=[],i=[];for(let o=0,c=e.routes.length;o<c;o++){let l=e.routes[o];l.port=qb.autoCast(l.port);let u=r.some(_=>_.host===l.host&&_.port===l.port),d=n.some(_=>_.host===l.host&&_.port===l.port);u||d?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?_o.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):_o.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:xk,set:i,skipped:s}}a(Doe,"setRoutesNats");function Poe(e){let t=vk.setRoutesValidator(e);if(t)throw Bk(t,t.message,Hk.BAD_REQUEST,void 0,void 0,!0);if(Lu.get(ms.CONFIG_PARAMS.CLUSTERING_ENABLED))return Doe(e);let r=[],n=[],s=Lu.get(ms.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{Fk(s,i)?n.push(i):(s.push(i),r.push(i))}),_o.updateConfigValue(ms.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:xk,set:r,skipped:n}}a(Poe,"setRoutes");function Fk(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(Fk,"existsInArray");function Loe(){if(Lu.get(ms.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=_o.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return Lu.get(ms.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(Loe,"getRoutes");function Moe(e){let t=vk.deleteRoutesValidator(e);if(t)throw Bk(t,t.message,Hk.BAD_REQUEST,void 0,void 0,!0);if(Lu.get(ms.CONFIG_PARAMS.CLUSTERING_ENABLED))return Uoe(e);let r=[],n=[],s=Lu.get(ms.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{Fk(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),_o.updateConfigValue(ms.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:kk,deleted:r,skipped:n}}a(Moe,"deleteRoutes");function Uoe(e){let t=_o.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],o=!1,c=!1;for(let l=0,u=e.routes.length;l<u;l++){let d=e.routes[l],_=!1;for(let E=0,f=r.length;E<f;E++){let h=r[E];if(d.host===h.host&&d.port===h.port){r.splice(E,1),_=!0,o=!0,s.push(d);break}}if(!_){let E=!0;for(let f=0,h=n.length;f<h;f++){let T=n[f];if(d.host===T.host&&d.port===T.port){n.splice(f,1),c=!0,E=!1,s.push(d);break}}E&&i.push(d)}}return o&&(r=qb.isEmptyOrZeroLength(r)?null:r,_o.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=qb.isEmptyOrZeroLength(n)?null:n,_o.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:kk,deleted:s,skipped:i}}a(Uoe,"deleteRoutesNats")});var $k=N((eCe,qk)=>{"use strict";var yf=require("alasql"),Fc=require("recursive-iterator"),Zs=W(),voe=te(),bf=M(),$b=class{static{a(this,"sql_statement_bucket")}constructor(t){this.ast=t,this.affected_attributes=new Map,this.table_lookup=new Map,this.schema_lookup=new Map,this.table_to_schema_lookup=new Map,Hoe(this.ast,this.affected_attributes,this.table_lookup,this.schema_lookup,this.table_to_schema_lookup)}getAttributesBySchemaTableName(t,r){if(!t||!r||!this.affected_attributes)return[];if(this.affected_attributes.has(t))return!this.affected_attributes.get(t).has(r)&&(r=this.table_lookup.get(r),!r)?[]:this.affected_attributes.get(t).get(r)}getAllTables(){let t=[];if(!this.affected_attributes)return t;for(let r of this.affected_attributes.keys())t.push(Array.from(this.affected_attributes.get(r).keys()));return t}getTablesBySchemaName(t){return!t||!this.affected_attributes?[]:Array.from(this.affected_attributes.get(t).keys())}getSchemas(){return this.affected_attributes?Array.from(this.affected_attributes.keys()):[]}getAst(){return this.ast}updateAttributeWildcardsForRolePerms(t){let r=this.ast.columns.filter(s=>bf.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=>!bf.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][bf.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=Boe(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(u=>({attribute_name:u.attribute}));let l=this.affected_attributes.get(i).get(o).filter(u=>!bf.SEARCH_WILDCARDS.includes(u));c.forEach(({attribute_name:u})=>{let d=new yf.yy.Column({columnid:u});s.tableid&&(d.tableid=s.tableid),this.ast.columns.push(d),l.includes(u)||l.push(u)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function Boe(e){return e.filter(t=>t[bf.PERMS_CRUD_ENUM.READ])}a(Boe,"filterReadRestrictedAttrs");function Hoe(e,t,r,n,s){xoe(e,t,r,n,s)}a(Hoe,"interpretAST");function Of(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(Of,"addSchemaTableToMap");function xoe(e,t,r,n,s){if(!e){Zs.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof yf.yy.Insert?qoe(e,t,r):e instanceof yf.yy.Select?koe(e,t,r,n,s):e instanceof yf.yy.Update?Foe(e,t,r):e instanceof yf.yy.Delete?Goe(e,t,r):Zs.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(xoe,"getRecordAttributesAST");function koe(e,t,r,n,s){if(!e){Zs.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(voe.isEmptyOrZeroLength(i)){Zs.error("No schema specified");return}e.from.forEach(c=>{Of(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),Of(c.table,t,r,n,s)});let o=new Fc(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,u=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(u).has(l))if(r.has(l))l=r.get(l);else{Zs.info(`table specified as ${l} not found.`);return}t.get(u).get(l).indexOf(c.columnid)<0&&t.get(u).get(l).push(c.columnid)}if(e.where){let c=new Fc(e.where),l=e.from[0].tableid;for(let{node:u}of c)if(u&&u.columnid){let d=u.tableid?u.tableid:l;if(!t.get(i).has(d))if(r.has(d))d=r.get(d);else{Zs.info(`table specified as ${d} not found.`);continue}t.get(i).get(d).indexOf(u.columnid)<0&&t.get(i).get(d).push(u.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new Fc(c.on);for(let{node:u}of l)if(u&&u.columnid){let d=u.tableid,_=s.get(d);if(!t.get(_).has(d))if(r.has(d))d=r.get(d);else{Zs.info(`table specified as ${d} not found.`);continue}t.get(_).get(d).indexOf(u.columnid)<0&&t.get(_).get(d).push(u.columnid)}}),e.order){let c=new Fc(e.order);for(let{node:l}of c)if(l&&l.columnid){let u=l.tableid,d=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(d).has(u))if(r.has(u))u=r.get(u);else{Zs.info(`table specified as ${u} not found.`);return}t.get(d).get(u).indexOf(l.columnid)<0&&t.get(d).get(u).push(l.columnid)}}}a(koe,"getSelectAttributes");function Foe(e,t,r){if(!e){Zs.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new Fc(e.columns),s=e.table.databaseid;Of(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&Vb(e.table.tableid,s,i.columnid,t,r)}a(Foe,"getUpdateAttributes");function Goe(e,t,r){if(!e){Zs.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new Fc(e.where),s=e.table.databaseid;Of(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&Vb(e.table.tableid,s,i.columnid,t,r)}a(Goe,"getDeleteAttributes");function qoe(e,t,r){if(!e){Zs.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new Fc(e.columns),s=e.into.databaseid;Of(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&Vb(e.into.tableid,s,i.columnid,t,r)}a(qoe,"getInsertAttributes");function Vb(e,t,r,n,s){if(!n.get(t))return;let i=e;n.get(t).has(i)||(i=s.get(i)),n.get(t).get(i).push(r)}a(Vb,"pushAttribute");qk.exports=$b});var Wb=N((rCe,Wk)=>{var Am=dc(),Vk=require("chalk"),Vn=W(),Kk=require("prompt"),{promisify:$oe}=require("util"),Kb=M(),Voe=require("fs-extra"),Koe=require("path"),Yoe=te(),Woe=vc(),Yk=se();Yk.initSync();var joe=require("moment"),zoe=$oe(Kk.get),Qoe=Koe.join(Yk.getHdbBasePath(),Kb.LICENSE_KEY_DIR_NAME,Kb.LICENSE_FILE_NAME,Kb.LICENSE_FILE_NAME);Wk.exports={getFingerprint:Xoe,setLicense:Joe,parseLicense:Yb,register:Zoe,getRegistrationInfo:tae};async function Joe(e){if(e&&e.key&&e.company){try{Vn.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await Yb(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw Vn.error(r),Vn.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(Joe,"setLicense");async function Xoe(){let e={};try{e=await Am.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw Vn.error(r),Vn.error(t),new Error(r)}return e}a(Xoe,"getFingerprint");async function Yb(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");Vn.info("Validating license input...");let r=Am.validateLicense(e,t);if(Vn.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(Vn.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(Vn.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{Vn.info("writing license to disk"),await Voe.writeFile(Qoe,JSON.stringify({license_key:e,company:t}))}catch(n){throw Vn.error("Failed to write License"),n}return"Registration successful."}a(Yb,"parseLicense");async function Zoe(){let e=await eae();return Yb(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(Zoe,"register");async function eae(){let e=await Am.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:Vk.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:Vk.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{Kk.start()}catch(n){Vn.error(n)}let r;try{r=await zoe(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(eae,"promptForRegistration");async function tae(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await Am.getLicense()}catch(r){throw Vn.error(`There was an error when searching licenses due to: ${r.message}`),r}if(Yoe.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=Woe.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=joe.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(tae,"getRegistrationInfo")});var zk=N((sCe,jk)=>{"use strict";var rae=Ct(),jb=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,u,d,_,E,f,h){this.port=t,o===null&&(o=void 0),this.server_name=r+rae.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.reconnect_error_reports=100,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l},this.leafnodes={port:u,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:d,port:_,routes:E,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:f},HDB:{users:h}},this.system_account="SYS"}};jk.exports=jb});var Xk=N((oCe,Jk)=>{"use strict";var Qk=Ct(),zb=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,u,d,_){this.port=t,_===null&&(_=void 0),this.server_name=r+Qk.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+Qk.SERVER_SUFFIX.LEAF},this.tls={cert_file:u,key_file:d,ca_file:_,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:_,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:_,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:l,jetstream:"enabled"}},this.system_account="SYS"}};Jk.exports=zb});var eF=N((cCe,Zk)=>{"use strict";var Qb=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};Zk.exports=Qb});var rF=N((uCe,tF)=>{"use strict";var nae=Ct(),Jb=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+nae.SERVER_SUFFIX.ADMIN,this.password=r}};tF.exports=Jb});var Om=N((_Ce,iF)=>{"use strict";var Gc=require("path"),qc=require("fs-extra"),sae=zk(),iae=Xk(),oae=eF(),aae=rF(),Xb=xn(),Uu=te(),Tn=wt(),ym=M(),Nf=Ct(),{CONFIG_PARAMS:Jt}=ym,vu=W(),If=se(),nF=to(),Zb=mr(),cae=Xs(),Mu="clustering",lae=1e4,sF=50;iF.exports={generateNatsConfig:dae,removeNatsConfig:_ae,getHubConfigPath:uae};function uae(){let e=If.get(Jt.ROOTPATH);return Gc.join(e,Mu,Nf.NATS_CONFIG_FILES.HUB_SERVER)}a(uae,"getHubConfigPath");async function dae(e=!1,t=void 0){let r=If.get(Jt.ROOTPATH);qc.ensureDirSync(Gc.join(r,"clustering","leaf")),If.initSync();let n=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_CERT_AUTH),s=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_PRIVATEKEY),i=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_CERTIFICATE);!await qc.exists(i)&&!await qc.exists(!n)&&await cae.createNatsCerts();let o=Gc.join(r,Mu,Nf.PID_FILES.HUB),c=Gc.join(r,Mu,Nf.PID_FILES.LEAF),l=Tn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=Gc.join(r,Mu,Nf.NATS_CONFIG_FILES.HUB_SERVER),d=Gc.join(r,Mu,Nf.NATS_CONFIG_FILES.LEAF_SERVER),_=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_INSECURE),E=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_VERIFY),f=Tn.getConfigFromFile(Jt.CLUSTERING_NODENAME),h=Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await Zb.checkNATSServerInstalled()||bm("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let T=await Xb.listUsers(),m=Tn.getConfigFromFile(Jt.CLUSTERING_USER),g=await Xb.getClusterUser();(Uu.isEmpty(g)||g.active!==!0)&&bm(`Invalid cluster user '${m}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await Rm(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await Rm(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await Rm(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),await Rm(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let S=[],b=[];for(let[ne,Q]of T.entries())Q.role?.role===ym.ROLE_TYPES_ENUM.CLUSTER_USER&&Q.active&&(S.push(new aae(Q.username,nF.decrypt(Q.hash))),b.push(new oae(Q.username,nF.decrypt(Q.hash))));let I=[],{hub_routes:B}=Tn.getClusteringRoutes();if(!Uu.isEmptyOrZeroLength(B))for(let ne of B)I.push(`tls://${g.sys_name_encoded}:${g.uri_encoded_d_hash}@${ne.host}:${ne.port}`);let H=new sae(Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),f,o,i,s,n,_,E,h,Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NAME),Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),I,S,b);n==null&&(delete H.tls.ca_file,delete H.leafnodes.tls.ca_file),t=Uu.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===ym.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await qc.writeJson(u,H),vu.trace(`Hub server config written to ${u}`));let X=`tls://${g.sys_name_encoded}:${g.uri_encoded_d_hash}@0.0.0.0:${h}`,Y=`tls://${g.uri_encoded_name}:${g.uri_encoded_d_hash}@0.0.0.0:${h}`,V=new iae(Tn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT),f,c,l,[X],[Y],S,b,i,s,n,_);n==null&&delete V.tls.ca_file,(t===void 0||t===ym.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await qc.writeJson(d,V),vu.trace(`Leaf server config written to ${d}`))}a(dae,"generateNatsConfig");async function Rm(e){let t=If.get(e);return Uu.isEmpty(t)&&bm(`port undefined for '${e}'`),await Uu.isPortTaken(t)&&bm(`'${e}' port '${t}' is is in use by another process, check to see if HarperDB is already running or another process is using this port.`),!0}a(Rm,"isPortAvailable");function bm(e){let t=`Error generating clustering config: ${e}`;vu.error(t),console.error(t),process.exit(1)}a(bm,"generateNatsConfigError");async function _ae(e){let{port:t,config_file:r}=Zb.getServerConfig(e),{username:n,decrypt_hash:s}=await Xb.getClusterUser(),i=0,o=2e3;for(;i<sF;){try{let d=await Zb.createConnection(t,n,s,!1);if(d.protocol.connected===!0){d.close();break}}catch(d){vu.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${d}`)}if(i++,i>=sF)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&&vu.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await Uu.async_set_timeout(u)}let c="0".repeat(lae),l=Gc.join(If.get(Jt.ROOTPATH),Mu,r);await qc.writeFile(l,c),await qc.remove(l),vu.notify(e,"started.")}a(_ae,"removeNatsConfig")});var dF=N((ECe,uF)=>{"use strict";var Kn=se(),fae=dc(),Ge=M(),wf=Ct(),fo=require("path"),{PACKAGE_ROOT:Im}=M(),oF=se(),Nm=te(),Bu="/dev/null",Eae=fo.join(Im,"launchServiceScripts"),aF=fo.join(Im,"utility/scripts"),hae=fo.join(aF,Ge.HDB_RESTART_SCRIPT),cF=fo.resolve(Im,"dependencies",`${process.platform}-${process.arch}`,wf.NATS_BINARY_NAME);function lF(){let t=fae.licenseSearch().ram_allocation||Ge.RAM_ALLOCATION_ENUM.DEFAULT,r=Ge.MEM_SETTING_KEY+t,n={[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return Nm.noBootFile()&&(n[Ge.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Nm.getEnvCliRootPath()),{name:Ge.PROCESS_DESCRIPTORS.HDB,script:Ge.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:Im}}a(lF,"generateMainServerConfig");var pae=9930;function mae(){Kn.initSync(!0);let e=Kn.get(Ge.CONFIG_PARAMS.ROOTPATH),t=fo.join(e,"clustering",wf.NATS_CONFIG_FILES.HUB_SERVER),r=fo.join(Kn.get(Ge.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ge.LOG_NAMES.HDB),n=oF.get(Ge.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=wf.LOG_LEVEL_FLAGS[Kn.get(Ge.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==pae?"-"+n:""),script:cF,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return Kn.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Bu,i.error_file=Bu),i}a(mae,"generateNatsHubServerConfig");var Sae=9940;function Tae(){Kn.initSync(!0);let e=Kn.get(Ge.CONFIG_PARAMS.ROOTPATH),t=fo.join(e,"clustering",wf.NATS_CONFIG_FILES.LEAF_SERVER),r=fo.join(Kn.get(Ge.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ge.LOG_NAMES.HDB),n=oF.get(Ge.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=wf.LOG_LEVEL_FLAGS[Kn.get(Ge.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==Sae?"-"+n:""),script:cF,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return Kn.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Bu,i.error_file=Bu),i}a(Tae,"generateNatsLeafServerConfig");function gae(){Kn.initSync();let e=fo.join(Kn.get(Ge.CONFIG_PARAMS.LOGGING_ROOT),Ge.LOG_NAMES.HDB),t={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:Ge.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:Eae,autorestart:!1};return Kn.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=Bu,t.error_file=Bu),t}a(gae,"generateClusteringUpgradeV4ServiceConfig");function Aae(){let e={[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.RESTART_HDB};return Nm.noBootFile()&&(e[Ge.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Nm.getEnvCliRootPath()),{...{name:Ge.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:aF},script:hae}}a(Aae,"generateRestart");function Rae(){return{apps:[lF()]}}a(Rae,"generateAllServiceConfigs");uF.exports={generateAllServiceConfigs:Rae,generateMainServerConfig:lF,generateRestart:Aae,generateNatsHubServerConfig:mae,generateNatsLeafServerConfig:Tae,generateClusteringUpgradeV4ServiceConfig:gae}});var Hu=N((mCe,OF)=>{"use strict";var at=M(),yae=te(),ho=Om(),wm=mr(),Eo=Ct(),Ea=dF(),Cm=se(),$c=W(),bae=Di(),{startWorker:_F,onMessageFromWorkers:Oae}=dt(),Nae=wu(),pCe=require("util"),Iae=require("child_process"),wae=require("fs"),{execFile:Cae}=Iae,Xe;OF.exports={enterPM2Mode:Dae,start:ha,stop:eO,reload:EF,restart:hF,list:tO,describe:SF,connect:po,kill:vae,startAllServices:Bae,startService:rO,getUniqueServicesList:TF,restartAllServices:Hae,isServiceRegistered:gF,reloadStopStart:AF,restartHdb:mF,deleteProcess:Mae,startClusteringProcesses:yF,startClusteringThreads:bF,isHdbRestartRunning:Uae,isClusteringRunning:kae,stopClustering:xae,reloadClustering:Fae,expectedRestartOfChildren:pF};var Cf=!1;Oae(e=>{e.type==="restart"&&Cm.initSync(!0)});function Dae(){Cf=!0}a(Dae,"enterPM2Mode");function po(){return Xe||(Xe=require("pm2")),new Promise((e,t)=>{Xe.connect((r,n)=>{r&&t(r),e(n)})})}a(po,"connect");var Jr,Pae=10,fF;function ha(e,t=!1){if(Cf)return Lae(e);let r=Cae(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let o=Jr.indexOf(r);o>-1&&Jr.splice(o,1),!fF&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<Pae&&(wae.existsSync(ho.getHubConfigPath())?ha(e):(await ho.generateNatsConfig(!0),ha(e),await new Promise(c=>setTimeout(c,3e3)),await ho.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await ho.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=Cm.get(at.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,u=0,d;for(;l=c.exec(i);){if(l.index&&Eo.LOG_LEVEL_HIERARCHY[o]>=Eo.LOG_LEVEL_HIERARCHY[d||"info"]){let f=d===Eo.LOG_LEVELS.ERR||d===Eo.LOG_LEVELS.WRN?$c.OUTPUTS.STDERR:$c.OUTPUTS.STDOUT;$c.logCustomLevel(d||"info",f,n,i.slice(u,l.index).trim())}let[_,E]=l;u=l.index+_.length,d=Eo.LOG_LEVELS[E]}if(Eo.LOG_LEVEL_HIERARCHY[o]>=Eo.LOG_LEVEL_HIERARCHY[d||"info"]){let _=d===Eo.LOG_LEVELS.ERR||d===Eo.LOG_LEVELS.WRN?$c.OUTPUTS.STDERR:$c.OUTPUTS.STDOUT;$c.logCustomLevel(d||"info",_,n,i.slice(u).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!Jr&&(Jr=[],!t)){let i=a(()=>{fF=!0,Jr&&(Jr.map(o=>o.kill()),process.exit(0))},"kill_children");process.on("exit",i),process.on("SIGINT",i),process.on("SIGQUIT",i),process.on("SIGTERM",i)}Jr.push(r)}a(ha,"start");function Lae(e){return new Promise(async(t,r)=>{try{await po()}catch(n){r(n)}Xe.start(e,(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(s)})})}a(Lae,"startWithPM2");function eO(e){if(!Cf){for(let t of Jr||[])t.name===e&&(Jr.splice(Jr.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await po()}catch(n){r(n)}Xe.stop(e,async(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.delete(e,(i,o)=>{i&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(o)})})})}a(eO,"stop");function EF(e){return new Promise(async(t,r)=>{try{await po()}catch(n){r(n)}Xe.reload(e,(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(s)})})}a(EF,"reload");function hF(e){if(!Cf){pF();for(let t of Jr||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await po()}catch(n){r(n)}Xe.restart(e,(n,s)=>{Xe.disconnect(),t(s)})})}a(hF,"restart");function pF(){for(let e of Jr||[])e.config&&(e.config.restarts=0)}a(pF,"expectedRestartOfChildren");function Mae(e){return new Promise(async(t,r)=>{try{await po()}catch(n){r(n)}Xe.delete(e,(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(s)})})}a(Mae,"deleteProcess");async function mF(){await ha(Ea.generateRestart())}a(mF,"restartHdb");async function Uae(){let e=await tO();for(let t in e)if(e[t].name===at.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(Uae,"isHdbRestartRunning");function tO(){return new Promise(async(e,t)=>{try{await po()}catch(r){t(r)}Xe.list((r,n)=>{r&&(Xe.disconnect(),t(r)),Xe.disconnect(),e(n)})})}a(tO,"list");function SF(e){return new Promise(async(t,r)=>{try{await po()}catch(n){r(n)}Xe.describe(e,(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(s)})})}a(SF,"describe");function vae(){if(!Cf){for(let e of Jr||[])e.kill();Jr=[];return}return new Promise(async(e,t)=>{try{await po()}catch(r){t(r)}Xe.killDaemon((r,n)=>{r&&(Xe.disconnect(),t(r)),Xe.disconnect(),e(n)})})}a(vae,"kill");async function Bae(){try{await yF(),await bF(),await ha(Ea.generateAllServiceConfigs())}catch(e){throw Xe?.disconnect(),e}}a(Bae,"startAllServices");async function rO(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case at.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Ea.generateMainServerConfig();break;case at.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Ea.generateNatsIngestServiceConfig();break;case at.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Ea.generateNatsReplyServiceConfig();break;case at.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Ea.generateNatsHubServerConfig(),await ha(r,t),await ho.removeNatsConfig(e);return;case at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Ea.generateNatsLeafServerConfig(),await ha(r,t),await ho.removeNatsConfig(e);return;case at.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Ea.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await ha(r)}catch(r){throw Xe?.disconnect(),r}}a(rO,"startService");async function TF(){try{let e=await tO(),t={};for(let r=0,n=e.length;r<n;r++){let s=e[r];t[s.name]===void 0&&(t[s.name]={name:s.name,exec_mode:s.pm2_env.exec_mode})}return t}catch(e){throw Xe?.disconnect(),e}}a(TF,"getUniqueServicesList");async function Hae(e=[]){try{let t=!1,r=await TF();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===at.PROCESS_DESCRIPTORS.HDB?t=!0:await hF(o))}t&&await AF(at.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Xe?.disconnect(),t}}a(Hae,"restartAllServices");async function gF(e){if(Jr?.find(r=>r.name===e))return!0;let t=await Nae.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(gF,"isServiceRegistered");async function AF(e){let t=Cm.get(at.CONFIG_PARAMS.THREADS_COUNT)??Cm.get(at.CONFIG_PARAMS.THREADS),r=await SF(e),n=yae.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await eO(e),await rO(e)):e===at.PROCESS_DESCRIPTORS.HDB?await mF():await EF(e)}a(AF,"reloadStopStart");var RF;async function yF(e=!1){for(let t in at.CLUSTERING_PROCESSES){let r=at.CLUSTERING_PROCESSES[t];await rO(r,e)}}a(yF,"startClusteringProcesses");async function bF(){RF=_F(at.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:at.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await wm.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await wm.updateLocalStreams();let e=await bae.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===at.PRE_4_0_0_VERSION){$c.info("Starting clustering upgrade 4.0.0 process"),_F(at.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(bF,"startClusteringThreads");async function xae(){for(let e in at.CLUSTERING_PROCESSES)if(e!==at.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===at.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await RF.terminate();else{let t=at.CLUSTERING_PROCESSES[e];await eO(t)}}a(xae,"stopClustering");async function kae(){for(let e in at.CLUSTERING_PROCESSES){let t=at.CLUSTERING_PROCESSES[e];if(await gF(t)===!1)return!1}return!0}a(kae,"isClusteringRunning");async function Fae(){await ho.generateNatsConfig(!0),await wm.reloadNATSHub(),await wm.reloadNATSLeaf(),await ho.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await ho.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(Fae,"reloadClustering")});var iO={};je(iO,{compactOnStart:()=>Gae,copyDb:()=>PF});async function Gae(){Df.notify("Running compact on start"),console.log("Running compact on start");let e=(0,nO.get)(pa.CONFIG_PARAMS.ROOTPATH),t=new Map,r=ut();try{for(let n in r){if(n==="system")continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,Dm.join)(e,"backup",n+".mdb"),o=(0,Dm.join)(e,pa.DATABASES_DIR_NAME,n+"-copy.mdb"),c=await NF(n);console.log("Database",n,"before compact has a total record count of",c),t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await PF(n,o),console.log("Backing up",n,"to",i),await(0,Vc.move)(s,i,{overwrite:!0})}xu();for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,Vc.move)(i,s,{overwrite:!0}),await(0,Vc.remove)((0,Dm.join)(e,pa.DATABASES_DIR_NAME,`${n}-copy.mdb-lock`));xu()}catch(n){Df.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,sO.updateConfigValue)(pa.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1);for(let[s,{db_path:i,backup_dest:o}]of t){console.error("Moving backup database",o,"back to",i);try{await(0,Vc.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw xu(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await NF(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){o=!1;let l=`There is a discrepancy between pre and post compact record count for database ${n}.
16
16
  Total record count before compaction: ${i}, total after: ${c}.
17
- Database backup has not been removed and can be found here: ${s}`;Df.error(l),console.error(l)}(0,nO.get)(ma.CONFIG_PARAMS.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||o===!1||(console.log("Removing backup",s),await(0,$c.remove)(s))}(0,sO.updateConfigValue)(ma.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1)}async function yF(e){let t=await(0,IF.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}async function wF(e,t){console.log("copyDb start");let r=ut()[e],n;for(let _ in r){n=r[_].primaryStore.rootStore;break}let s=n.dbisDb,i=n.auditStore,o=(0,bF.open)(new OF.default(t)),c=o.openDB(Dm.INTERNAL_DBIS_NAME),l,u=0,d=s.useReadTransaction();try{for(let{key:E,value:f}of s.getRange({transaction:d})){let h=f.is_hash_attribute||f.isPrimaryKey,T,m;if(h&&(T=f.compression,m=Pm(),m?f.compression=m:delete f.compression,T?.dictionary?.toString()===m?.dictionary?.toString()&&(T=null,m=null)),c.put(E,f),!(h||f.indexed))continue;let g=new NF.default(!h,h);g.encoding="binary",g.compression=T;let S=n.openDB(E,g);S.decoder=null,g.compression=m;let b=o.openDB(E,g);b.encoder=null,console.log("copying",E,"from",e,"to",t),await _(S,b,h,d)}if(i){let E=n.openDB(Dm.AUDIT_STORE_NAME,Pf);console.log("copying audit log for",e,"to",t),_(i,E,!1,d)}async function _(E,f,h,T){let m=0,g=0;for(let{key:S,value:b,version:I}of E.getRange({start:null,versions:h,transaction:T}))l=f.put(S,b,I),m++,T.openTimer&&(T.openTimer=0),g+=(S?.length||10)+b.length,u++>5e3&&(await l,console.log("copied",m,"entries",g,"bytes"),u=0);console.log("finish copying, copied",m,"entries",g,"bytes")}a(_,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{d.done(),o.close()}}var bF,Cm,$c,nO,OF,NF,Dm,ma,IF,sO,Df,oO=Oe(()=>{Pe();bF=require("lmdb"),Cm=require("path"),$c=require("fs-extra"),nO=L(se()),OF=L(a_()),NF=L(o_()),Dm=L(Bt()),ma=L(M());Ji();IF=L(ro()),sO=L(wt()),Df=L(W());a(xae,"compactOnStart");a(yF,"getTotalDBRecordCount");a(wF,"copyDb")});var xu=N((RCe,vF)=>{"use strict";var kae=require("minimist"),{isMainThread:cO,parentPort:Mf,threadId:SCe}=require("worker_threads"),Pt=M(),{PROCESS_DESCRIPTORS_VALIDATE:Bu}=Pt,Pi=W(),lO=te(),Mm=bm(),Lm=mr(),TCe=Ct(),LF=wt(),ei=Uu(),CF=Ou(),{compactOnStart:Fae}=(oO(),oe(iO)),Gae=Wa(),{restartWorkers:Um,onMessageByType:qae}=dt(),{handleHDBError:$ae,hdb_errors:Vae}=_e(),{HTTP_STATUS_CODES:Kae}=Vae,Uf=se(),{sendOperationToNode:DF,getThisNodeName:Yae,monitorNodeCAs:Wae}=(us(),oe(ca)),{getHDBNodeTable:gCe}=(iu(),oe(hB));Uf.initSync();var Lf=`Restarting HarperDB. This may take up to ${Pt.RESTART_TIMEOUT_MS/1e3} seconds.`,jae="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",PF="Clustering is not enabled so cannot be restarted",zae="Invalid service",Hu,Ss;vF.exports={restart:MF,restartService:uO};cO&&qae(Pt.ITC_EVENT_TYPES.RESTART,async(e,t)=>{e.workerType?await uO({service:e.workerType}):MF({operation:"restart"}),t.postMessage({type:"restart-complete"})});async function MF(e){Ss=Object.keys(e).length===0,Hu=await ei.isServiceRegistered(Pt.HDB_PROC_DESCRIPTOR);let t=kae(process.argv);if(t.service){await uO(t);return}if(Ss&&!Hu){console.error(jae);return}if(Ss&&console.log(Lf),Hu){ei.enterPM2Mode(),Pi.notify(Lf);let r=Gae(Object.keys(Pt.CONFIG_PARAM_MAP),!0);return lO.isEmptyOrZeroLength(Object.keys(r))||LF.updateConfigValue(void 0,void 0,r,!0,!0),Qae(),Lf}return cO?(Pi.notify(Lf),Uf.get(Pt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await Fae(),setTimeout(()=>{Um()},50)):Mf.postMessage({type:Pt.ITC_EVENT_TYPES.RESTART}),Lf}a(MF,"restart");async function uO(e){let{service:t}=e;if(Pt.PROCESS_DESCRIPTORS_VALIDATE[t]===void 0)throw $ae(new Error,zae,Kae.BAD_REQUEST,void 0,void 0,!0);if(ei.expectedRestartOfChildren(),Hu=await ei.isServiceRegistered(Pt.HDB_PROC_DESCRIPTOR),!cO){e.replicated&&Wae(),Mf.postMessage({type:Pt.ITC_EVENT_TYPES.RESTART,workerType:t}),Mf.ref(),await new Promise(s=>{Mf.on("message",i=>{i.type==="restart-complete"&&(s(),Mf.unref())})});let n;if(e.replicated){e.replicated=!1,n=[];for(let s of server.nodes){if(s.name===Yae())continue;let{job_id:i}=await DF(s,e);n.push(await new Promise((o,c)=>{let u=2400,d=setInterval(async()=>{if(u--<=0){clearInterval(d);let f=new Error("Timed out waiting for restart job to complete");f.replicated=n,c(f)}let E=(await DF(s,{operation:"get_job",id:i})).results[0];if(E.status==="COMPLETE"&&(clearInterval(d),o({node:s.name,message:E.message})),E.status==="ERROR"){clearInterval(d);let f=new Error(E.message);f.replicated=n,c(f)}},250)}))}return{replicated:n}}return}let r;switch(t){case Bu.clustering:if(!Uf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=PF;break}Ss&&console.log("Restarting clustering"),Pi.notify("Restarting clustering"),await UF();break;case Bu.clustering_config:case Bu["clustering config"]:if(!Uf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=PF;break}Ss&&console.log("Restarting clustering_config"),Pi.notify("Restarting clustering_config"),await ei.reloadClustering();break;case"custom_functions":case"custom functions":case Bu.harperdb:case Bu.http_workers:case Bu.http:if(Ss&&!Hu){r=`Restart ${t} is not available from the CLI when running in non-pm2 mode. Either call restart ${t} from the API or stop and start HarperDB.`;break}Ss&&console.log("Restarting http_workers"),Pi.notify("Restarting http_workers"),Ss?await ei.restart(Pt.HDB_PROC_DESCRIPTOR):await Um("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(Pi.error(r),Ss&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(uO,"restartService");async function Qae(){await UF(),await ei.restart(Pt.HDB_PROC_DESCRIPTOR),await lO.async_set_timeout(2e3),Uf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await aO(),Ss&&(await Lm.closeConnection(),process.exit(0))}a(Qae,"restartPM2Mode");async function UF(){if(!LF.getConfigFromFile(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await CF.getHDBProcessInfo()).clustering.length===0)Pi.trace("Clustering not running, restart will start clustering services"),await Mm.generateNatsConfig(!0),await ei.startClusteringProcesses(),await ei.startClusteringThreads(),await aO(),Ss&&await Lm.closeConnection();else{await Mm.generateNatsConfig(!0),Hu?(Pi.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await ei.restart(Pt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await ei.restart(Pt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await CF.getHDBProcessInfo()).clustering.forEach(s=>{Pi.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await lO.async_set_timeout(3e3),await aO(),await Lm.updateLocalStreams(),Ss&&await Lm.closeConnection(),Pi.trace("Restart clustering restarting ingest and reply service threads");let t=Um(Pt.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=Um(Pt.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(UF,"restartClustering");async function aO(){await Mm.removeNatsConfig(Pt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Mm.removeNatsConfig(Pt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(aO,"removeNatsConfig")});var YF=N((bCe,KF)=>{"use strict";var yCe=require("lodash"),gn=M(),{handleHDBError:BF,hdb_errors:Jae}=_e(),{HDB_ERROR_MSGS:Xae,HTTP_STATUS_CODES:Zae}=Jae,dO=W();KF.exports={getRolePermissions:tce};var Vc=Object.create(null),ece=a(e=>({key:e,perms:{}}),"perms_template_obj"),FF=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),GF=a((e=!1,t=!1,r=!1,n=!1)=>({[gn.PERMS_CRUD_ENUM.READ]:e,[gn.PERMS_CRUD_ENUM.INSERT]:t,[gn.PERMS_CRUD_ENUM.UPDATE]:r,[gn.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),_O=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...GF(t,r,n,s)}),"table_perms_template"),HF=a((e,t=GF())=>({attribute_name:e,describe:VF(t),[vf]:t[vf],[fO]:t[fO],[EO]:t[EO]}),"attr_perms_template"),xF=a((e,t=!1)=>({attribute_name:e,describe:t,[vf]:t}),"timestamp_attr_perms_template"),{READ:vf,INSERT:fO,UPDATE:EO}=gn.PERMS_CRUD_ENUM,qF=Object.values(gn.PERMS_CRUD_ENUM),$F=[vf,fO,EO];function tce(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r={...global.hdb_schema};delete r[gn.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(Vc[t]&&Vc[t].key===n)return Vc[t].perms;let s=rce(e,r);return Vc[t]?Vc[t].key=n:Vc[t]=ece(n),Vc[t].perms=s,s}catch(r){if(!e[gn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[gn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<gn.PERMS_UPDATE_RELEASE_TIMESTAMP){let n=`Role permissions for role '${t}' must be updated to align with new structure from the 2.2.0 release.`;throw dO.error(n),dO.debug(r),BF(new Error,Xae.OUTDATED_PERMS_TRANSLATION_ERROR,Zae.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
18
- ${r.stack}`;throw dO.error(n),BF(new Error)}}}a(tce,"getRolePermissions");function rce(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[gn.SYSTEM_SCHEMA_NAME]=n[gn.SYSTEM_SCHEMA_NAME],r.structure_user=n.structure_user;let s=Array.isArray(e.permission.structure_user)||e.permission.structure_user===!0?e.permission.structure_user:[];return Object.keys(t).forEach(i=>{if(s===!0||s.indexOf(i)>-1){r[i]=nce(t[i]);return}r[i]=FF(),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=sce(c,l);r[i].describe||qF.forEach(d=>{u[d]&&(r[i].describe=!0)}),r[i].tables[o]=u}else r[i].tables[o]=_O()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=_O()})}),r}a(rce,"translateRolePermissions");function nce(e){let t=FF(!0);return Object.keys(e).forEach(r=>{t.tables[r]=_O(!0,!0,!0,!0,!0)}),t}a(nce,"createStructureUserPermissions");function sce(e,t){let{attribute_permissions:r}=e;if(r?.length>0){let s={...e};s.attribute_permissions=[];let i=r.reduce((u,d)=>{let{attribute_name:_}=d,E=d;return gn.TIME_STAMP_NAMES.includes(_)&&(E=xF(_,d[vf])),u[_]=E,u},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=HF(o);return t.attributes.forEach(({attribute:u})=>{if(i[u]){let d=i[u];d.describe=VF(d),s.attribute_permissions.push(d),c||ice(d,l)}else if(u!==o){let d;gn.TIME_STAMP_NAMES.includes(u)?d=xF(u):d=HF(u),s.attribute_permissions.push(d)}}),c||s.attribute_permissions.push(l),s.describe=kF(s),s}else return e.describe=kF(e),e}a(sce,"getTableAttrPerms");function kF(e){return qF.filter(t=>e[t]).length>0}a(kF,"getSchemaTableDescribePerm");function VF(e){return $F.filter(t=>e[t]).length>0}a(VF,"getAttributeDescribePerm");function ice(e,t){$F.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(ice,"checkForHashPerms")});var WF={};je(WF,{Headers:()=>So,appendHeader:()=>vm,mergeHeaders:()=>hO});function vm(e,t,r,n){if(e.append)e.append(t,r,n);else if(e.set){let s=e.get(t);if(s)if(n)r=(typeof s=="string"?s:s.join(", "))+", "+r;else if(typeof s=="string")r=[s,r];else{s.push(r);return}return e.set(t,r)}else e[t]=(e[t]?e[t]+", ":"")+r}function hO(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new So(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 So,Bf=Oe(()=>{So=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(vm,"appendHeader");a(hO,"mergeHeaders")});var Hf={};je(Hf,{authentication:()=>eG,bypassAuth:()=>_ce,login:()=>Ece,logout:()=>hce,start:()=>fce});function _ce(){ZF=!0}async function eG(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let f=e.isOperationsServer?lce?cce:[]:ace?oce:[];if(f.includes(i)||f.includes("*")){if(e.method==="OPTIONS"){let h=new So([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers","Accept, Content-Type, Authorization"],["Access-Control-Allow-Origin",i]]);return Bm&&h.set("Access-Control-Allow-Credentials","true"),{status:200,headers:h}}o.push("Access-Control-Allow-Origin",i),Bm&&o.push("Access-Control-Allow-Credentials","true")}}let l,u;if(Bm){i||(i=r.host);let f=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.split(/;\s+/)||[];for(let T of h)if(T.startsWith(f)){let m=T.indexOf(";");l=T.slice(f.length,m===-1?T.length:m),u=await jF.get(l);break}e.session=u||(u={})}let d=a((f,h,T)=>{let m=new ku.AuthAuditLog(f,h,Or.AUTH_AUDIT_TYPES.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);m.auth_strategy=T,l&&(m.session_id=l),r.referer&&(m.referer=r.referer),r.origin&&(m.origin=r.origin),h===Or.AUTH_AUDIT_STATUS.SUCCESS?pO.notify(m):pO.error(m)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&pO.error("Authorization error:",e._nodeRequest.socket.authorizationError),e.mtlsConfig&&e.authorized&&e.peerCertificate.subject){let f=e.mtlsConfig.user;f!==null?((f===void 0||f==="Common Name"||f==="CN")&&(f=e.peerCertificate.subject.CN),e.user=await it.getUser(f,null,e),d(f,Or.AUTH_AUDIT_STATUS.SUCCESS,"mTLS")):(0,ku.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let _;if(!e.user)if(n){if(_=Kc.get(n),!_){let f=n.indexOf(" "),h=n.slice(0,f),T=n.slice(f+1),m,g;try{switch(h){case"Basic":let S=atob(T),b=S.indexOf(":");m=S.slice(0,b),g=S.slice(b+1),_=m||g?await it.getUser(m,g,e):null;break;case"Bearer":try{_=await(0,Hm.validateOperationToken)(T)}catch(I){if(I.message==="invalid token")try{return await(0,Hm.validateRefreshToken)(T),c({status:-1})}catch{throw I}}break}}catch(S){return dce&&(Kc.get(T)||(Kc.set(T,T),d(m,Or.AUTH_AUDIT_STATUS.FAILURE,h))),c({status:401,body:Yc({error:S.message},e)})}Kc.set(n,_),uce&&d(_.username,Or.AUTH_AUDIT_STATUS.SUCCESS,h)}e.user=_}else u?.user?e.user=await it.getUser(u.user,null,e):(ZF&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,QF.getSuperUser)());Bm&&(e.session.update=function(f){if(!l){l=(0,JF.v4)();let T=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${l}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",T):E?.headers?.set&&E.headers.set("Set-Cookie",T)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):E?.headers?.set&&(i&&E.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),E.headers.set("X-Hdb-Session","Secure"))),f.id=l,jF.put(f)},e.login=async function(f,h){e.user=await it.getUser(f,h,e),e.session.update({user:e.user&&(e.user.getId?.()??e.user.username)})});let E=await t(e);return E&&(E.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&wi.loginPath?(E.status=302,E.headers.set("Location",wi.loginPath(e))):E.headers.set("WWW-Authenticate","Basic")),c(E))}catch(l){throw c(l)}function c(l){let u=o.length;if(u>0){let d=l.headers;d||(l.headers=d=new So);for(let _=0;_<u;){let E=o[_++];d.set(E,o[_++])}}return o=null,l}a(c,"applyResponseHeaders")}function fce({server:e,port:t,securePort:r}){e.http(eG,t||r?{port:t,securePort:r}:{port:"all"}),zF||(zF=!0,setInterval(()=>{Kc=new Map},Ts.get(Or.CONFIG_PARAMS.AUTHENTICATION_CACHETTL)).unref(),XF.user.addListener(()=>{Kc=new Map}))}async function Ece(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 hce(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var QF,Hm,JF,Ts,Or,ku,XF,pO,oce,ace,cce,lce,jF,Bm,ZF,uce,dce,Kc,zF,xm=Oe(()=>{QF=L(xn());qr();eu();Hm=L(lu());Pe();JF=require("uuid"),Ts=L(se()),Or=L(M()),ku=L(W()),XF=L(m_());Bf();Wc();pO=(0,ku.loggerWithTag)("auth-event");Ts.initSync();oce=Ts.get(Or.CONFIG_PARAMS.HTTP_CORSACCESSLIST),ace=Ts.get(Or.CONFIG_PARAMS.HTTP_CORS),cce=Ts.get(Or.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORSACCESSLIST),lce=Ts.get(Or.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORS),jF=Et({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),Bm=Ts.get(Or.CONFIG_PARAMS.AUTHENTICATION_ENABLESESSIONS)??!0,ZF=process.env.AUTHENTICATION_AUTHORIZELOCAL??Ts.get(Or.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,uce=Ts.get(Or.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,dce=Ts.get(Or.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,Kc=new Map;it.onInvalidatedUser(()=>{Kc=new Map});a(_ce,"bypassAuth");a(eG,"authentication");a(fce,"start");a(Ece,"login");a(hce,"logout")});var aG=N((MCe,oG)=>{"use strict";var Ne=require("joi"),tG=require("fs-extra"),rG=require("path"),Yn=Tt(),nG=se(),sG=M(),iG=W(),{hdb_errors:pce}=_e(),{HDB_ERROR_MSGS:Xr}=pce,To=/^[a-zA-Z0-9-_]+$/,mce=/^[a-zA-Z0-9-_]+$/;oG.exports={getDropCustomFunctionValidator:Tce,setCustomFunctionValidator:gce,addComponentValidator:bce,dropCustomFunctionProjectValidator:Oce,packageComponentValidator:Nce,deployComponentValidator:Ice,setComponentFileValidator:Rce,getComponentFileValidator:yce,dropComponentFileValidator:Ace,addSSHKeyValidator:wce,updateSSHKeyValidator:Cce,deleteSSHKeyValidator:Dce,setSSHKnownHostsValidator:Pce};function km(e,t,r){try{let n=nG.get(sG.CONFIG_PARAMS.COMPONENTSROOT),s=rG.join(n,t);return tG.existsSync(s)?e?t:r.message(Xr.PROJECT_EXISTS):e?r.message(Xr.NO_PROJECT):t}catch(n){return iG.error(n),r.message(Xr.VALIDATION_ERR)}}a(km,"checkProjectExists");function xf(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(xf,"checkFilePath");function Sce(e,t,r,n){try{let s=nG.get(sG.CONFIG_PARAMS.COMPONENTSROOT),i=rG.join(s,e,t,r+".js");return tG.existsSync(i)?r:n.message(Xr.NO_FILE)}catch(s){return iG.error(s),n.message(Xr.VALIDATION_ERR)}}a(Sce,"checkFileExists");function Tce(e){let t=Ne.object({project:Ne.string().pattern(To).custom(km.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().pattern(To).custom(Sce.bind(null,e.project,e.type)).custom(xf).required().messages({"string.pattern.base":Xr.BAD_FILE_NAME})});return Yn.validateBySchema(e,t)}a(Tce,"getDropCustomFunctionValidator");function gce(e){let t=Ne.object({project:Ne.string().pattern(To).custom(km.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().custom(xf).required(),function_content:Ne.string().required()});return Yn.validateBySchema(e,t)}a(gce,"setCustomFunctionValidator");function Rce(e){let t=Ne.object({project:Ne.string().pattern(To).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),file:Ne.string().custom(xf).required(),payload:Ne.string().allow("").optional(),encoding:Ne.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Yn.validateBySchema(e,t)}a(Rce,"setComponentFileValidator");function Ace(e){let t=Ne.object({project:Ne.string().pattern(To).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),file:Ne.string().custom(xf).optional()});return Yn.validateBySchema(e,t)}a(Ace,"dropComponentFileValidator");function yce(e){let t=Ne.object({project:Ne.string().required(),file:Ne.string().custom(xf).required(),encoding:Ne.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Yn.validateBySchema(e,t)}a(yce,"getComponentFileValidator");function bce(e){let t=Ne.object({project:Ne.string().pattern(To).custom(km.bind(null,!1)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME})});return Yn.validateBySchema(e,t)}a(bce,"addComponentValidator");function Oce(e){let t=Ne.object({project:Ne.string().pattern(To).custom(km.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME})});return Yn.validateBySchema(e,t)}a(Oce,"dropCustomFunctionProjectValidator");function Nce(e){let t=Ne.object({project:Ne.string().pattern(To).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),skip_node_modules:Ne.boolean()});return Yn.validateBySchema(e,t)}a(Nce,"packageComponentValidator");function Ice(e){let t=Ne.object({project:Ne.string().pattern(To).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),package:Ne.string().optional(),restart:Ne.boolean().optional()});return Yn.validateBySchema(e,t)}a(Ice,"deployComponentValidator");function wce(e){let t=Ne.object({name:Ne.string().pattern(mce).required().messages({"string.pattern.base":Xr.BAD_SSH_KEY_NAME}),key:Ne.string().required(),host:Ne.string().required(),hostname:Ne.string().required(),known_hosts:Ne.string().optional()});return Yn.validateBySchema(e,t)}a(wce,"addSSHKeyValidator");function Cce(e){let t=Ne.object({name:Ne.string().required(),key:Ne.string().required()});return Yn.validateBySchema(e,t)}a(Cce,"updateSSHKeyValidator");function Dce(e){let t=Ne.object({name:Ne.string().required()});return Yn.validateBySchema(e,t)}a(Dce,"deleteSSHKeyValidator");function Pce(e){let t=Ne.object({known_hosts:Ne.string().required()});return Yn.validateBySchema(e,t)}a(Pce,"setSSHKnownHostsValidator")});var kf=N((vCe,fG)=>{"use strict";var Fm=require("joi"),jc=require("path"),qm=require("fs-extra"),{exec:Lce}=require("child_process"),Mce=require("util"),cG=Mce.promisify(Lce),qu=M(),{handleHDBError:Fu,hdb_errors:Uce}=_e(),{HTTP_STATUS_CODES:Gu}=Uce,Vu=se(),vce=Tt(),$u=W();Vu.initSync();var mO=Vu.get(qu.CONFIG_PARAMS.COMPONENTSROOT),lG="npm install --force --omit=dev --json",Bce=`${lG} --dry-run`,Hce=Vu.get(qu.CONFIG_PARAMS.ROOTPATH),Gm=jc.join(Hce,"ssh");fG.exports={installModules:Gce,auditModules:qce,installAllRootModules:xce,uninstallRootModule:kce,linkHarperdb:Fce,runCommand:Ku};async function xce(e=!1,t=Vu.get(qu.CONFIG_PARAMS.ROOTPATH)){await $m();let r=!1,n=process.env;qm.pathExistsSync(Gm)&&qm.readdirSync(Gm).forEach(s=>{s.includes(".key")&&!r&&(n={GIT_SSH_COMMAND:"ssh -F "+jc.join(Gm,"config")+" -o UserKnownHostsFile="+jc.join(Gm,"known_hosts"),...process.env},r=!0)}),await Ku(e?"npm install --force --ignore-scripts":"npm install --force",t,n)}a(xce,"installAllRootModules");async function kce(e){await Ku(`npm uninstall ${e}`,Vu.get(qu.CONFIG_PARAMS.ROOTPATH))}a(kce,"uninstallRootModule");async function Fce(){await $m(),await Ku(`npm link ${qu.PACKAGE_ROOT}`,Vu.get(qu.CONFIG_PARAMS.ROOTPATH))}a(Fce,"linkHarperdb");async function Ku(e,t=void 0,r=process.env){let n,s;try{({stdout:n,stderr:s}=await cG(e,{cwd:t,env:r}))}catch(i){throw new Error(i.stderr.replace(`
19
- `,""))}return s&&!s.includes("Debugger listening")&&!s.includes("warn using --force")&&$u.error("Error running NPM command:",e,s),$u.trace(n,s),n?.replace(`
20
- `,"")}a(Ku,"runCommand");async function Gce(e){let t="install_node_modules is deprecated. Dependencies are automatically installed on deploy, and install_node_modules can lead to inconsistent behavior";$u.warn(t,e);let r=_G(e);if(r)throw Fu(r,r.message,Gu.BAD_REQUEST);let{projects:n,dry_run:s}=e,i=s===!0?Bce:lG;await $m(),await dG(n);let o={};for(let c=0,l=n.length;c<l;c++){let u=n[c];o[u]={npm_output:null,npm_error:null};let d=jc.join(mO,u),_,E=null;try{let{stdout:f,stderr:h}=await cG(i,{cwd:d});_=f?f.replace(`
17
+ Database backup has not been removed and can be found here: ${s}`;Df.error(l),console.error(l)}(0,nO.get)(pa.CONFIG_PARAMS.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||o===!1||(console.log("Removing backup",s),await(0,Vc.remove)(s))}(0,sO.updateConfigValue)(pa.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1)}async function NF(e){let t=await(0,DF.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}async function PF(e,t){console.log("copyDb start");let r=ut()[e],n;for(let _ in r){n=r[_].primaryStore.rootStore;break}let s=n.dbisDb,i=n.auditStore,o=(0,IF.open)(new wF.default(t)),c=o.openDB(Pm.INTERNAL_DBIS_NAME),l,u=0,d=s.useReadTransaction();try{for(let{key:E,value:f}of s.getRange({transaction:d})){let h=f.is_hash_attribute||f.isPrimaryKey,T,m;if(h&&(T=f.compression,m=Lm(),m?f.compression=m:delete f.compression,T?.dictionary?.toString()===m?.dictionary?.toString()&&(T=null,m=null)),c.put(E,f),!(h||f.indexed))continue;let g=new CF.default(!h,h);g.encoding="binary",g.compression=T;let S=n.openDB(E,g);S.decoder=null,g.compression=m;let b=o.openDB(E,g);b.encoder=null,console.log("copying",E,"from",e,"to",t),await _(S,b,h,d)}if(i){let E=n.openDB(Pm.AUDIT_STORE_NAME,Pf);console.log("copying audit log for",e,"to",t),_(i,E,!1,d)}async function _(E,f,h,T){let m=0,g=0;for(let{key:S,value:b,version:I}of E.getRange({start:null,versions:h,transaction:T}))l=f.put(S,b,I),m++,T.openTimer&&(T.openTimer=0),g+=(S?.length||10)+b.length,u++>5e3&&(await l,console.log("copied",m,"entries",g,"bytes"),u=0);console.log("finish copying, copied",m,"entries",g,"bytes")}a(_,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{d.done(),o.close()}}var IF,Dm,Vc,nO,wF,CF,Pm,pa,DF,sO,Df,oO=Ie(()=>{Pe();IF=require("lmdb"),Dm=require("path"),Vc=require("fs-extra"),nO=L(se()),wF=L(c_()),CF=L(a_()),Pm=L(Ht()),pa=L(M());Ji();DF=L(ro()),sO=L(wt()),Df=L(W());a(Gae,"compactOnStart");a(NF,"getTotalDBRecordCount");a(PF,"copyDb")});var Gu=N((OCe,xF)=>{"use strict";var qae=require("minimist"),{isMainThread:cO,parentPort:Mf,threadId:RCe}=require("worker_threads"),Pt=M(),{PROCESS_DESCRIPTORS_VALIDATE:ku}=Pt,Pi=W(),lO=te(),Um=Om(),Mm=mr(),yCe=Ct(),vF=wt(),ei=Hu(),LF=wu(),{compactOnStart:$ae}=(oO(),oe(iO)),Vae=Wa(),{restartWorkers:vm,onMessageByType:Kae}=dt(),{handleHDBError:Yae,hdb_errors:Wae}=_e(),{HTTP_STATUS_CODES:jae}=Wae,Uf=se(),{sendOperationToNode:MF,getThisNodeName:zae,monitorNodeCAs:Qae}=(us(),oe(ca)),{getHDBNodeTable:bCe}=(cu(),oe(pB));Uf.initSync();var Lf=`Restarting HarperDB. This may take up to ${Pt.RESTART_TIMEOUT_MS/1e3} seconds.`,Jae="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",UF="Clustering is not enabled so cannot be restarted",Xae="Invalid service",Fu,Ss;xF.exports={restart:BF,restartService:uO};cO&&Kae(Pt.ITC_EVENT_TYPES.RESTART,async(e,t)=>{e.workerType?await uO({service:e.workerType}):BF({operation:"restart"}),t.postMessage({type:"restart-complete"})});async function BF(e){Ss=Object.keys(e).length===0,Fu=await ei.isServiceRegistered(Pt.HDB_PROC_DESCRIPTOR);let t=qae(process.argv);if(t.service){await uO(t);return}if(Ss&&!Fu){console.error(Jae);return}if(Ss&&console.log(Lf),Fu){ei.enterPM2Mode(),Pi.notify(Lf);let r=Vae(Object.keys(Pt.CONFIG_PARAM_MAP),!0);return lO.isEmptyOrZeroLength(Object.keys(r))||vF.updateConfigValue(void 0,void 0,r,!0,!0),Zae(),Lf}return cO?(Pi.notify(Lf),Uf.get(Pt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await $ae(),setTimeout(()=>{vm()},50)):Mf.postMessage({type:Pt.ITC_EVENT_TYPES.RESTART}),Lf}a(BF,"restart");async function uO(e){let{service:t}=e;if(Pt.PROCESS_DESCRIPTORS_VALIDATE[t]===void 0)throw Yae(new Error,Xae,jae.BAD_REQUEST,void 0,void 0,!0);if(ei.expectedRestartOfChildren(),Fu=await ei.isServiceRegistered(Pt.HDB_PROC_DESCRIPTOR),!cO){e.replicated&&Qae(),Mf.postMessage({type:Pt.ITC_EVENT_TYPES.RESTART,workerType:t}),Mf.ref(),await new Promise(s=>{Mf.on("message",i=>{i.type==="restart-complete"&&(s(),Mf.unref())})});let n;if(e.replicated){e.replicated=!1,n=[];for(let s of server.nodes){if(s.name===zae())continue;let{job_id:i}=await MF(s,e);n.push(await new Promise((o,c)=>{let u=2400,d=setInterval(async()=>{if(u--<=0){clearInterval(d);let f=new Error("Timed out waiting for restart job to complete");f.replicated=n,c(f)}let E=(await MF(s,{operation:"get_job",id:i})).results[0];if(E.status==="COMPLETE"&&(clearInterval(d),o({node:s.name,message:E.message})),E.status==="ERROR"){clearInterval(d);let f=new Error(E.message);f.replicated=n,c(f)}},250)}))}return{replicated:n}}return}let r;switch(t){case ku.clustering:if(!Uf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=UF;break}Ss&&console.log("Restarting clustering"),Pi.notify("Restarting clustering"),await HF();break;case ku.clustering_config:case ku["clustering config"]:if(!Uf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=UF;break}Ss&&console.log("Restarting clustering_config"),Pi.notify("Restarting clustering_config"),await ei.reloadClustering();break;case"custom_functions":case"custom functions":case ku.harperdb:case ku.http_workers:case ku.http:if(Ss&&!Fu){r=`Restart ${t} is not available from the CLI when running in non-pm2 mode. Either call restart ${t} from the API or stop and start HarperDB.`;break}Ss&&console.log("Restarting http_workers"),Pi.notify("Restarting http_workers"),Ss?await ei.restart(Pt.HDB_PROC_DESCRIPTOR):await vm("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(Pi.error(r),Ss&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(uO,"restartService");async function Zae(){await HF(),await ei.restart(Pt.HDB_PROC_DESCRIPTOR),await lO.async_set_timeout(2e3),Uf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await aO(),Ss&&(await Mm.closeConnection(),process.exit(0))}a(Zae,"restartPM2Mode");async function HF(){if(!vF.getConfigFromFile(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await LF.getHDBProcessInfo()).clustering.length===0)Pi.trace("Clustering not running, restart will start clustering services"),await Um.generateNatsConfig(!0),await ei.startClusteringProcesses(),await ei.startClusteringThreads(),await aO(),Ss&&await Mm.closeConnection();else{await Um.generateNatsConfig(!0),Fu?(Pi.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await ei.restart(Pt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await ei.restart(Pt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await LF.getHDBProcessInfo()).clustering.forEach(s=>{Pi.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await lO.async_set_timeout(3e3),await aO(),await Mm.updateLocalStreams(),Ss&&await Mm.closeConnection(),Pi.trace("Restart clustering restarting ingest and reply service threads");let t=vm(Pt.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=vm(Pt.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(HF,"restartClustering");async function aO(){await Um.removeNatsConfig(Pt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Um.removeNatsConfig(Pt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(aO,"removeNatsConfig")});var zF=N((wCe,jF)=>{"use strict";var ICe=require("lodash"),gn=M(),{handleHDBError:kF,hdb_errors:ece}=_e(),{HDB_ERROR_MSGS:tce,HTTP_STATUS_CODES:rce}=ece,dO=W();jF.exports={getRolePermissions:sce};var Kc=Object.create(null),nce=a(e=>({key:e,perms:{}}),"perms_template_obj"),$F=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),VF=a((e=!1,t=!1,r=!1,n=!1)=>({[gn.PERMS_CRUD_ENUM.READ]:e,[gn.PERMS_CRUD_ENUM.INSERT]:t,[gn.PERMS_CRUD_ENUM.UPDATE]:r,[gn.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),_O=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...VF(t,r,n,s)}),"table_perms_template"),FF=a((e,t=VF())=>({attribute_name:e,describe:WF(t),[vf]:t[vf],[fO]:t[fO],[EO]:t[EO]}),"attr_perms_template"),GF=a((e,t=!1)=>({attribute_name:e,describe:t,[vf]:t}),"timestamp_attr_perms_template"),{READ:vf,INSERT:fO,UPDATE:EO}=gn.PERMS_CRUD_ENUM,KF=Object.values(gn.PERMS_CRUD_ENUM),YF=[vf,fO,EO];function sce(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r={...global.hdb_schema};delete r[gn.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(Kc[t]&&Kc[t].key===n)return Kc[t].perms;let s=ice(e,r);return Kc[t]?Kc[t].key=n:Kc[t]=nce(n),Kc[t].perms=s,s}catch(r){if(!e[gn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[gn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<gn.PERMS_UPDATE_RELEASE_TIMESTAMP){let n=`Role permissions for role '${t}' must be updated to align with new structure from the 2.2.0 release.`;throw dO.error(n),dO.debug(r),kF(new Error,tce.OUTDATED_PERMS_TRANSLATION_ERROR,rce.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
18
+ ${r.stack}`;throw dO.error(n),kF(new Error)}}}a(sce,"getRolePermissions");function ice(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[gn.SYSTEM_SCHEMA_NAME]=n[gn.SYSTEM_SCHEMA_NAME],r.structure_user=n.structure_user;let s=Array.isArray(e.permission.structure_user)||e.permission.structure_user===!0?e.permission.structure_user:[];return Object.keys(t).forEach(i=>{if(s===!0||s.indexOf(i)>-1){r[i]=oce(t[i]);return}r[i]=$F(),n[i]?(n[i].describe&&(r[i].describe=!0),Object.keys(t[i]).forEach(o=>{if(n[i].tables[o]){let c=n[i].tables[o],l=t[i][o],u=ace(c,l);r[i].describe||KF.forEach(d=>{u[d]&&(r[i].describe=!0)}),r[i].tables[o]=u}else r[i].tables[o]=_O()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=_O()})}),r}a(ice,"translateRolePermissions");function oce(e){let t=$F(!0);return Object.keys(e).forEach(r=>{t.tables[r]=_O(!0,!0,!0,!0,!0)}),t}a(oce,"createStructureUserPermissions");function ace(e,t){let{attribute_permissions:r}=e;if(r?.length>0){let s={...e};s.attribute_permissions=[];let i=r.reduce((u,d)=>{let{attribute_name:_}=d,E=d;return gn.TIME_STAMP_NAMES.includes(_)&&(E=GF(_,d[vf])),u[_]=E,u},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=FF(o);return t.attributes.forEach(({attribute:u})=>{if(i[u]){let d=i[u];d.describe=WF(d),s.attribute_permissions.push(d),c||cce(d,l)}else if(u!==o){let d;gn.TIME_STAMP_NAMES.includes(u)?d=GF(u):d=FF(u),s.attribute_permissions.push(d)}}),c||s.attribute_permissions.push(l),s.describe=qF(s),s}else return e.describe=qF(e),e}a(ace,"getTableAttrPerms");function qF(e){return KF.filter(t=>e[t]).length>0}a(qF,"getSchemaTableDescribePerm");function WF(e){return YF.filter(t=>e[t]).length>0}a(WF,"getAttributeDescribePerm");function cce(e,t){YF.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(cce,"checkForHashPerms")});var QF={};je(QF,{Headers:()=>mo,appendHeader:()=>Bm,mergeHeaders:()=>hO});function Bm(e,t,r,n){if(e.append)e.append(t,r,n);else if(e.set){let s=e.get(t);if(s)if(n)r=(typeof s=="string"?s:s.join(", "))+", "+r;else if(typeof s=="string")r=[s,r];else{s.push(r);return}return e.set(t,r)}else e[t]=(e[t]?e[t]+", ":"")+r}function hO(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new mo(e));for(let[r,n]of t)e.has(r)?r.toLowerCase()==="set-cookie"&&e.append?.(r,n,!0):e.set(r,n);return e}var mo,Bf=Ie(()=>{mo=class extends Map{static{a(this,"Headers")}constructor(t){if(t)if(t[Symbol.iterator])super(t);else{super();for(let r in t)this.set(r,t[r])}else super()}set(t,r){return typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r),super.set(t.toLowerCase(),[t,r])}get(t){return typeof t!="string"&&(t=""+t),super.get(t.toLowerCase())?.[1]}has(t){return typeof t!="string"&&(t=""+t),super.has(t.toLowerCase())}setIfNone(t,r){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let n=t.toLowerCase();if(!super.has(n))return super.set(n,[t,r])}append(t,r,n){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let s=t.toLowerCase(),i=super.get(s);if(i){let o=i[1];if(n)r=(typeof o=="string"?o:o.join(", "))+", "+r;else if(typeof o=="string")r=[o,r];else{o.push(r);return}}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}};a(Bm,"appendHeader");a(hO,"mergeHeaders")});var Hf={};je(Hf,{authentication:()=>nG,bypassAuth:()=>hce,login:()=>mce,logout:()=>Sce,start:()=>pce});function hce(){rG=!0}async function nG(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let f=e.isOperationsServer?_ce?dce:[]:uce?lce:[];if(f.includes(i)||f.includes("*")){if(e.method==="OPTIONS"){let h=new mo([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers","Accept, Content-Type, Authorization"],["Access-Control-Allow-Origin",i]]);return Hm&&h.set("Access-Control-Allow-Credentials","true"),{status:200,headers:h}}o.push("Access-Control-Allow-Origin",i),Hm&&o.push("Access-Control-Allow-Credentials","true")}}let l,u;if(Hm){i||(i=r.host);let f=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.split(/;\s+/)||[];for(let T of h)if(T.startsWith(f)){let m=T.indexOf(";");l=T.slice(f.length,m===-1?T.length:m),u=await JF.get(l);break}e.session=u||(u={})}let d=a((f,h,T)=>{let m=new qu.AuthAuditLog(f,h,Or.AUTH_AUDIT_TYPES.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);m.auth_strategy=T,l&&(m.session_id=l),r.referer&&(m.referer=r.referer),r.origin&&(m.origin=r.origin),h===Or.AUTH_AUDIT_STATUS.SUCCESS?pO.notify(m):pO.error(m)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&pO.error("Authorization error:",e._nodeRequest.socket.authorizationError),e.mtlsConfig&&e.authorized&&e.peerCertificate.subject){let f=e.mtlsConfig.user;f!==null?((f===void 0||f==="Common Name"||f==="CN")&&(f=e.peerCertificate.subject.CN),e.user=await it.getUser(f,null,e),d(f,Or.AUTH_AUDIT_STATUS.SUCCESS,"mTLS")):(0,qu.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let _;if(!e.user)if(n){if(_=Yc.get(n),!_){let f=n.indexOf(" "),h=n.slice(0,f),T=n.slice(f+1),m,g;try{switch(h){case"Basic":let S=atob(T),b=S.indexOf(":");m=S.slice(0,b),g=S.slice(b+1),_=m||g?await it.getUser(m,g,e):null;break;case"Bearer":try{_=await(0,xm.validateOperationToken)(T)}catch(I){if(I.message==="invalid token")try{return await(0,xm.validateRefreshToken)(T),c({status:-1})}catch{throw I}}break}}catch(S){return Ece&&(Yc.get(T)||(Yc.set(T,T),d(m,Or.AUTH_AUDIT_STATUS.FAILURE,h))),c({status:401,body:Wc({error:S.message},e)})}Yc.set(n,_),fce&&d(_.username,Or.AUTH_AUDIT_STATUS.SUCCESS,h)}e.user=_}else u?.user?e.user=await it.getUser(u.user,null,e):(rG&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,ZF.getSuperUser)());Hm&&(e.session.update=function(f){if(!l){l=(0,eG.v4)();let T=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${l}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",T):E?.headers?.set&&E.headers.set("Set-Cookie",T)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):E?.headers?.set&&(i&&E.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),E.headers.set("X-Hdb-Session","Secure"))),f.id=l,JF.put(f)},e.login=async function(f,h){e.user=await it.getUser(f,h,e),e.session.update({user:e.user&&(e.user.getId?.()??e.user.username)})});let E=await t(e);return E&&(E.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&wi.loginPath?(E.status=302,E.headers.set("Location",wi.loginPath(e))):E.headers.set("WWW-Authenticate","Basic")),c(E))}catch(l){throw c(l)}function c(l){let u=o.length;if(u>0){let d=l.headers;d||(l.headers=d=new mo);for(let _=0;_<u;){let E=o[_++];d.set(E,o[_++])}}return o=null,l}a(c,"applyResponseHeaders")}function pce({server:e,port:t,securePort:r}){e.http(nG,t||r?{port:t,securePort:r}:{port:"all"}),XF||(XF=!0,setInterval(()=>{Yc=new Map},Ts.get(Or.CONFIG_PARAMS.AUTHENTICATION_CACHETTL)).unref(),tG.user.addListener(()=>{Yc=new Map}))}async function mce(e){if(!e.baseRequest?.login)throw new Error("No session for login");return e.baseResponse.headers.set=(t,r)=>{e.fastifyResponse.header(t,r)},await e.baseRequest.login(e.username,e.password),"Login successful"}async function Sce(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var ZF,xm,eG,Ts,Or,qu,tG,pO,lce,uce,dce,_ce,JF,Hm,rG,fce,Ece,Yc,XF,km=Ie(()=>{ZF=L(xn());qr();nu();xm=L(_u());Pe();eG=require("uuid"),Ts=L(se()),Or=L(M()),qu=L(W()),tG=L(S_());Bf();jc();pO=(0,qu.loggerWithTag)("auth-event");Ts.initSync();lce=Ts.get(Or.CONFIG_PARAMS.HTTP_CORSACCESSLIST),uce=Ts.get(Or.CONFIG_PARAMS.HTTP_CORS),dce=Ts.get(Or.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORSACCESSLIST),_ce=Ts.get(Or.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORS),JF=Et({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),Hm=Ts.get(Or.CONFIG_PARAMS.AUTHENTICATION_ENABLESESSIONS)??!0,rG=process.env.AUTHENTICATION_AUTHORIZELOCAL??Ts.get(Or.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,fce=Ts.get(Or.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,Ece=Ts.get(Or.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,Yc=new Map;it.onInvalidatedUser(()=>{Yc=new Map});a(hce,"bypassAuth");a(nG,"authentication");a(pce,"start");a(mce,"login");a(Sce,"logout")});var uG=N((HCe,lG)=>{"use strict";var Ne=require("joi"),sG=require("fs-extra"),iG=require("path"),Yn=Tt(),oG=se(),aG=M(),cG=W(),{hdb_errors:Tce}=_e(),{HDB_ERROR_MSGS:Xr}=Tce,So=/^[a-zA-Z0-9-_]+$/,gce=/^[a-zA-Z0-9-_]+$/;lG.exports={getDropCustomFunctionValidator:Rce,setCustomFunctionValidator:yce,addComponentValidator:Ice,dropCustomFunctionProjectValidator:wce,packageComponentValidator:Cce,deployComponentValidator:Dce,setComponentFileValidator:bce,getComponentFileValidator:Nce,dropComponentFileValidator:Oce,addSSHKeyValidator:Pce,updateSSHKeyValidator:Lce,deleteSSHKeyValidator:Mce,setSSHKnownHostsValidator:Uce};function Fm(e,t,r){try{let n=oG.get(aG.CONFIG_PARAMS.COMPONENTSROOT),s=iG.join(n,t);return sG.existsSync(s)?e?t:r.message(Xr.PROJECT_EXISTS):e?r.message(Xr.NO_PROJECT):t}catch(n){return cG.error(n),r.message(Xr.VALIDATION_ERR)}}a(Fm,"checkProjectExists");function xf(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(xf,"checkFilePath");function Ace(e,t,r,n){try{let s=oG.get(aG.CONFIG_PARAMS.COMPONENTSROOT),i=iG.join(s,e,t,r+".js");return sG.existsSync(i)?r:n.message(Xr.NO_FILE)}catch(s){return cG.error(s),n.message(Xr.VALIDATION_ERR)}}a(Ace,"checkFileExists");function Rce(e){let t=Ne.object({project:Ne.string().pattern(So).custom(Fm.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().pattern(So).custom(Ace.bind(null,e.project,e.type)).custom(xf).required().messages({"string.pattern.base":Xr.BAD_FILE_NAME})});return Yn.validateBySchema(e,t)}a(Rce,"getDropCustomFunctionValidator");function yce(e){let t=Ne.object({project:Ne.string().pattern(So).custom(Fm.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().custom(xf).required(),function_content:Ne.string().required()});return Yn.validateBySchema(e,t)}a(yce,"setCustomFunctionValidator");function bce(e){let t=Ne.object({project:Ne.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),file:Ne.string().custom(xf).required(),payload:Ne.string().allow("").optional(),encoding:Ne.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Yn.validateBySchema(e,t)}a(bce,"setComponentFileValidator");function Oce(e){let t=Ne.object({project:Ne.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),file:Ne.string().custom(xf).optional()});return Yn.validateBySchema(e,t)}a(Oce,"dropComponentFileValidator");function Nce(e){let t=Ne.object({project:Ne.string().required(),file:Ne.string().custom(xf).required(),encoding:Ne.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Yn.validateBySchema(e,t)}a(Nce,"getComponentFileValidator");function Ice(e){let t=Ne.object({project:Ne.string().pattern(So).custom(Fm.bind(null,!1)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME})});return Yn.validateBySchema(e,t)}a(Ice,"addComponentValidator");function wce(e){let t=Ne.object({project:Ne.string().pattern(So).custom(Fm.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME})});return Yn.validateBySchema(e,t)}a(wce,"dropCustomFunctionProjectValidator");function Cce(e){let t=Ne.object({project:Ne.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),skip_node_modules:Ne.boolean()});return Yn.validateBySchema(e,t)}a(Cce,"packageComponentValidator");function Dce(e){let t=Ne.object({project:Ne.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),package:Ne.string().optional(),restart:Ne.alternatives().try(Ne.boolean(),Ne.string().valid("rolling")).optional()});return Yn.validateBySchema(e,t)}a(Dce,"deployComponentValidator");function Pce(e){let t=Ne.object({name:Ne.string().pattern(gce).required().messages({"string.pattern.base":Xr.BAD_SSH_KEY_NAME}),key:Ne.string().required(),host:Ne.string().required(),hostname:Ne.string().required(),known_hosts:Ne.string().optional()});return Yn.validateBySchema(e,t)}a(Pce,"addSSHKeyValidator");function Lce(e){let t=Ne.object({name:Ne.string().required(),key:Ne.string().required()});return Yn.validateBySchema(e,t)}a(Lce,"updateSSHKeyValidator");function Mce(e){let t=Ne.object({name:Ne.string().required()});return Yn.validateBySchema(e,t)}a(Mce,"deleteSSHKeyValidator");function Uce(e){let t=Ne.object({known_hosts:Ne.string().required()});return Yn.validateBySchema(e,t)}a(Uce,"setSSHKnownHostsValidator")});var kf=N((kCe,pG)=>{"use strict";var Gm=require("joi"),ma=require("path"),$u=require("fs-extra"),{exec:vce}=require("child_process"),Bce=require("util"),dG=Bce.promisify(vce),zc=M(),{handleHDBError:Vu,hdb_errors:Hce}=_e(),{HTTP_STATUS_CODES:Ku}=Hce,Qc=se(),xce=Tt(),Jc=W();Qc.initSync();var mO=Qc.get(zc.CONFIG_PARAMS.COMPONENTSROOT),_G="npm install --force --omit=dev --json",kce=`${_G} --dry-run`,Fce=Qc.get(zc.CONFIG_PARAMS.ROOTPATH),qm=ma.join(Fce,"ssh");pG.exports={installModules:Vce,auditModules:Kce,installAllRootModules:Gce,uninstallRootModule:qce,linkHarperdb:$ce,runCommand:Yu};async function Gce(e=!1,t=Qc.get(zc.CONFIG_PARAMS.ROOTPATH)){await $m();let r=!1,n=process.env;$u.pathExistsSync(qm)&&$u.readdirSync(qm).forEach(s=>{s.includes(".key")&&!r&&(n={GIT_SSH_COMMAND:"ssh -F "+ma.join(qm,"config")+" -o UserKnownHostsFile="+ma.join(qm,"known_hosts"),...process.env},r=!0)});try{let s=Qc.get(zc.CONFIG_PARAMS.ROOTPATH),i=ma.join(s,"node_modules","harperdb");$u.lstatSync(i).isSymbolicLink()&&$u.unlinkSync(i)}catch(s){s.code!=="ENOENT"&&Jc.error("Error removing symlink:",s)}await Yu(e?"npm install --force --ignore-scripts":"npm install --force",t,n)}a(Gce,"installAllRootModules");async function qce(e){await Yu(`npm uninstall ${e}`,Qc.get(zc.CONFIG_PARAMS.ROOTPATH))}a(qce,"uninstallRootModule");async function $ce(){await $m(),await Yu(`npm link ${zc.PACKAGE_ROOT}`,Qc.get(zc.CONFIG_PARAMS.ROOTPATH))}a($ce,"linkHarperdb");async function Yu(e,t=void 0,r=process.env){let n,s;try{({stdout:n,stderr:s}=await dG(e,{cwd:t,env:r}))}catch(i){throw new Error(i.stderr.replace(`
19
+ `,""))}return s&&!s.includes("Debugger listening")&&!s.includes("warn using --force")&&Jc.error("Error running NPM command:",e,s),Jc.trace(n,s),n?.replace(`
20
+ `,"")}a(Yu,"runCommand");async function Vce(e){let t="install_node_modules is deprecated. Dependencies are automatically installed on deploy, and install_node_modules can lead to inconsistent behavior";Jc.warn(t,e);let r=hG(e);if(r)throw Vu(r,r.message,Ku.BAD_REQUEST);let{projects:n,dry_run:s}=e,i=s===!0?kce:_G;await $m(),await EG(n);let o={};for(let c=0,l=n.length;c<l;c++){let u=n[c];o[u]={npm_output:null,npm_error:null};let d=ma.join(mO,u),_,E=null;try{let{stdout:f,stderr:h}=await dG(i,{cwd:d});_=f?f.replace(`
21
21
  `,""):null,E=h?h.replace(`
22
- `,""):null}catch(f){f.stderr?o[u].npm_error=uG(f.stderr):o[u].npm_error=f.message;continue}try{o[u].npm_output=JSON.parse(_)}catch{o[u].npm_output=_}try{o[u].npm_error=JSON.parse(E)}catch{o[u].npm_error=E}}return $u.info(`finished installModules with response ${o}`),o.warning=t,o}a(Gce,"installModules");function uG(e){let t='"error": {',r=e.indexOf('"error": {'),n=e.indexOf(`}
23
- `);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(uG,"parseNPMStdErr");async function qce(e){$u.info(`starting auditModules for request: ${e}`);let t=_G(e);if(t)throw Fu(t,t.message,Gu.BAD_REQUEST);let{projects:r}=e;await $m(),await dG(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=jc.join(mO,o);n[o]={npm_output:null,npm_error:null};try{let l=await Ku("npm audit --json",c);n[o].npm_output=JSON.parse(l)}catch(l){n[o].npm_error=uG(l.stderr)}}return $u.info(`finished auditModules with response ${n}`),n}a(qce,"auditModules");async function $m(){try{return await Ku("npm -v"),!0}catch{throw Fu(new Error,"Unable to install project dependencies: npm is not installed on this instance of HarperDB.",Gu.BAD_REQUEST,void 0,void 0,!0)}}a($m,"checkNPMInstalled");async function dG(e){if(!Array.isArray(e)||e.length===0)throw Fu(new Error,"projects argument must be an array with at least 1 element",Gu.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=jc.join(mO,i.toString());if(!await qm.pathExists(o)){t.push(i);continue}let l=jc.join(o,"package.json");await qm.pathExists(l)||r.push(i)}if(t.length>0)throw Fu(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,Gu.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw Fu(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,Gu.BAD_REQUEST,void 0,void 0,!0)}a(dG,"checkProjectPaths");function _G(e){let t=Fm.object({projects:Fm.array().min(1).items(Fm.string()).required(),dry_run:Fm.boolean().default(!1)});return vce.validateBySchema(e,t)}a(_G,"modulesValidator")});var SO=N((HCe,TG)=>{"use strict";var gs=require("fs-extra"),Gf=require("path"),Ff=W(),EG=te(),Vm=M(),SG=se(),$ce=wt();TG.exports=Vce;async function Vce(){let e=Kce(),t=SG.get(Vm.CONFIG_PARAMS.ROOTPATH),r=Gf.join(t,"package.json"),n={dependencies:{harperdb:"file:"+Vm.PACKAGE_ROOT}},s=Gf.join(t,"node_modules");gs.ensureDirSync(s);let i,o=!0,c=!1;try{i=gs.readJsonSync(r)}catch(l){if(EG.isEmptyOrZeroLength(e))return;if(l.code!==Vm.NODE_ERROR_CODES.ENOENT)throw l;o=!1}if(!EG.isEmptyOrZeroLength(e)){for(let{name:l,package:u}of e){let d=pG(u);n.dependencies[l]=d+u}if(!o){Ff.notify("Installing components"),await mG(r,n,null),await hG(t,e);return}for(let{name:l,package:u}of e){let d=i.dependencies[l],_=pG(u);if(d===void 0||d!==_+u){c=!0;break}if(u.startsWith("file:"))try{if(gs.statSync(new URL(u+"/package.json")).mtimeMs>gs.statSync(r).mtimeMs){c=!0;break}}catch(E){Ff.info(`Error checking ${u}/package.json modification time`,E);break}}}for(let l in i.dependencies)n.dependencies[l]===void 0&&(Ff.notify("Removing component",l),c=!0);c&&(Ff.notify("Updating components."),await mG(r,n,i),await hG(t,e))}a(Vce,"installComponents");function hG(e,t){return Promise.all(t.map(({name:r})=>{let n=Gf.join(e,"node_modules",r),s=Gf.join(e,"components",r);if(gs.existsSync(n)&&gs.lstatSync(n).isDirectory())return gs.move(n,s,{overwrite:!0}).then(()=>{gs.symlink(s,n)})}))}a(hG,"moveModuleToComponents");function Kce(){let e=$ce.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(Kce,"getComponentsConfig");function pG(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":Gf.extname(e)||gs.existsSync(e)?"file:":"github:"}a(pG,"getPkgPrefix");async function mG(e,t,r){Ff.trace("npm installing components package.json",t),gs.writeFileSync(e,JSON.stringify(t,null," "));try{await kf().installAllRootModules(SG.get(Vm.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?gs.writeFileSync(e,JSON.stringify(r,null," ")):gs.unlinkSync(e),n}}a(mG,"installPackages")});var AG={};je(AG,{packageDirectory:()=>Wce});function Wce(e,t){let{skip_node_modules:r,hidden_folders:n}=t;return new Promise((s,i)=>{let o=r?{ignore:a(l=>l.includes(TO.default.join("node_modules"))||l.includes(TO.default.join("cache","webpack")),"ignore")}:{},c=[];gG.default.pack(e,o).pipe((0,RG.createGzip)()).on("data",l=>c.push(l)).on("end",()=>{let l=Buffer.concat(c);s(l)}).on("error",i)})}var TO,gG,Yce,RG,yG=Oe(()=>{TO=L(require("path")),gG=L(require("tar-fs")),Yce=require("node:fs"),RG=require("node:zlib");a(Wce,"packageDirectory")});var AO=N(NG=>{"use strict";var ge=require("fs-extra"),gO=require("fast-glob"),Ce=require("path"),jce=require("tar-fs"),zce=require("gunzip-maybe"),FCe=require("uuid").v4,RO=require("normalize-path"),Rn=aG(),kt=W(),ft=M(),xt=se(),Km=wt(),Qce=te(),{PACKAGE_ROOT:Jce}=M(),{handleHDBError:Ft,hdb_errors:Xce}=_e(),{basename:Zce}=require("path"),ele=SO(),OG=se(),tle=M(),{Readable:rle}=require("stream"),{isMainThread:nle}=require("worker_threads"),{HDB_ERROR_MSGS:zc,HTTP_STATUS_CODES:Gt}=Xce,sle=dt(),{replicateOperation:ti}=(us(),oe(ca)),{packageDirectory:ile}=(yG(),oe(AG)),bG=kf(),ole=Ce.join(Jce,"application-template"),GCe=Ce.join(xt.get(ft.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),"tmp"),ale=xt.get(ft.CONFIG_PARAMS.ROOTPATH),Sa=Ce.join(ale,"ssh"),go=Ce.join(Sa,"known_hosts");function cle(){kt.trace("getting custom api status");let e={};try{e={port:xt.get(ft.CONFIG_PARAMS.HTTP_PORT),directory:xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw Ft(new Error,zc.FUNCTION_STATUS,Gt.INTERNAL_SERVER_ERROR,kt.ERR,t)}return e}a(cle,"customFunctionsStatus");function lle(){kt.trace("getting custom api endpoints");let e={},t=xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT);try{gO.sync(RO(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:gO.sync(RO(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:gO.sync(RO(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw Ft(new Error,zc.GET_FUNCTIONS,Gt.INTERNAL_SERVER_ERROR,kt.ERR,r)}return e}a(lle,"getCustomFunctions");function ule(e){e.project&&(e.project=Ce.parse(e.project).name),e.file&&(e.file=Ce.parse(e.file).name);let t=Rn.getDropCustomFunctionValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);kt.trace("getting custom api endpoint file content");let r=xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=Ce.join(r,n,s,i+".js");try{return ge.readFileSync(o,{encoding:"utf8"})}catch(c){throw Ft(new Error,zc.GET_FUNCTION,Gt.INTERNAL_SERVER_ERROR,kt.ERR,c)}}a(ule,"getCustomFunction");async function dle(e){e.project&&(e.project=Ce.parse(e.project).name),e.file&&(e.file=Ce.parse(e.file).name);let t=Rn.setCustomFunctionValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);kt.trace("setting custom function file content");let r=xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{ge.outputFileSync(Ce.join(r,n,s,i+".js"),o);let c=await ti(e);return c.message=`Successfully updated custom function: ${i}.js`,c}catch(c){throw Ft(new Error,zc.SET_FUNCTION,Gt.INTERNAL_SERVER_ERROR,kt.ERR,c)}}a(dle,"setCustomFunction");async function _le(e){e.project&&(e.project=Ce.parse(e.project).name),e.file&&(e.file=Ce.parse(e.file).name);let t=Rn.getDropCustomFunctionValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);kt.trace("dropping custom function file");let r=xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{ge.unlinkSync(Ce.join(r,n,s,i+".js"));let o=await ti(e);return o.message=`Successfully deleted custom function: ${i}.js`,o}catch(o){throw Ft(new Error,zc.DROP_FUNCTION,Gt.INTERNAL_SERVER_ERROR,kt.ERR,o)}}a(_le,"dropCustomFunction");async function fle(e){e.project&&(e.project=Ce.parse(e.project).name);let t=Rn.addComponentValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);kt.trace("adding component");let r=xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=Ce.join(r,n);ge.mkdirSync(s,{recursive:!0}),ge.copySync(ole,s);let i=await ti(e);return i.message=`Successfully added project: ${n}`,i}catch(s){throw Ft(new Error,zc.ADD_FUNCTION,Gt.INTERNAL_SERVER_ERROR,kt.ERR,s)}}a(fle,"addComponent");async function Ele(e){e.project&&(e.project=Ce.parse(e.project).name);let t=Rn.dropCustomFunctionProjectValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);kt.trace("dropping custom function project");let r=xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=xt.get(ft.CONFIG_PARAMS.APPS);if(!Qce.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 Km.updateConfigValue(ft.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=Ce.join(r,n);ge.rmSync(i,{recursive:!0});let o=await ti(e);return o.message=`Successfully deleted project: ${n}`,o}catch(i){throw Ft(new Error,zc.DROP_FUNCTION_PROJECT,Gt.INTERNAL_SERVER_ERROR,kt.ERR,i)}}a(Ele,"dropCustomFunctionProject");async function hle(e){e.project&&(e.project=Ce.parse(e.project).name);let t=Rn.packageComponentValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);let r=xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;kt.trace("packaging component",n);let s;try{s=await ge.realpath(Ce.join(r,n))}catch(o){if(o.code!==ft.NODE_ERROR_CODES.ENOENT)throw o;try{s=await ge.realpath(Ce.join(xt.get(ft.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(c){if(c.code===ft.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}let i=(await ile(s,e)).toString("base64");return{project:n,payload:i}}a(hle,"packageComponent");async function ple(e){e.project&&(e.project=Ce.parse(e.project).name);let t=Rn.deployComponentValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);let r=xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i,install_command:o}=e;if(kt.trace("deploying component",n),!s&&!i)throw new Error("'payload' or 'package' must be provided");let c;if(s){c=Ce.join(r,n),i="file:"+c,await ge.emptyDir(c);let h=rle.from(s instanceof Buffer?s:Buffer.from(s,"base64"));await new Promise((g,S)=>{h.pipe(zce()).pipe(jce.extract(c,{finish:g})).on("error",S)});let T=await ge.readdir(c);T.length===1&&T[0]==="package"&&(await ge.copy(Ce.join(c,"package"),c),await ge.remove(Ce.join(c,"package")));let m=Ce.join(c,"node_modules");o?await bG.runCommand(o,c):ge.existsSync(m)||await bG.installAllRootModules(!1,c)}else{await Km.addConfig(n,{package:i}),await ele();let h=OG.get(tle.CONFIG_PARAMS.ROOTPATH);c=Ce.join(h,"node_modules",n)}if(nle)return;let l=new Map;l.isWorker=!0;let u=($f(),oe(qf)),d;u.setErrorReporter(h=>d=h);let _=Zce(c),E=u.component_errors.get(_);try{await u.loadComponent(c,l)}finally{u.component_errors.set(_,E)}if(d)throw d;kt.info("Installed component");let f=await ti(e);return e.restart===!0?(sle.restartWorkers("http"),f.message=`Successfully deployed: ${n}, restarting HarperDB`):f.message=`Successfully deployed: ${n}`,f}a(ple,"deployComponent");async function mle(){let e=a(async(s,i)=>{try{let o=await ge.readdir(s,{withFileTypes:!0});for(let c of o){let l=c.name;if(l.startsWith(".")||l==="node_modules")continue;let u=Ce.join(s,l);if(c.isDirectory()||c.isSymbolicLink()){let d={name:l,entries:[]};i.entries.push(d),await e(u,d)}else{let d=await ge.stat(u),_={name:Ce.basename(l),mtime:d.mtime,size:d.size};i.entries.push(_)}}return i}catch(o){return kt.warn("Error loading package",o),{error:o.toString(),entries:[]}}},"walkDir"),t=await e(xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{name:xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT).split(Ce.sep).slice(-1).pop(),entries:[]}),n=($f(),oe(qf)).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(mle,"getComponents");async function Sle(e){let t=Rn.getComponentFileValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);let n=Km.getConfigObj()[e.project]||e.project==="harperdb"?Ce.join(OG.get(ft.CONFIG_PARAMS.ROOTPATH),"node_modules"):xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await ge.stat(Ce.join(n,e.project,e.file));return{message:await ge.readFile(Ce.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===ft.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${Ce.join(e.project,e.file)}'`):i}}a(Sle,"getComponentFile");async function Tle(e){let t=Rn.setComponentFileValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=Ce.join(xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);e.payload!==void 0?(await ge.ensureFile(n),await ge.outputFile(n,e.payload,r)):await ge.ensureDir(n);let s=await ti(e);return s.message="Successfully set component: "+e.file,s}a(Tle,"setComponentFile");async function gle(e){let t=Rn.dropComponentFileValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);let{project:r,file:n}=e,s=e.file?Ce.join(r,n):r,i=Ce.join(xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),s),o=Ce.join(xt.get(ft.CONFIG_PARAMS.ROOTPATH),"node_modules",r);await ge.pathExists(o)&&await ge.unlink(o),await ge.pathExists(i)&&await ge.remove(i);let c=Ce.join(xt.get(ft.CONFIG_PARAMS.ROOTPATH),"package.json");if(await ge.pathExists(c)){let u=JSON.parse(await ge.readFile(c,"utf8"));u?.dependencies?.[r]&&delete u.dependencies[r],await ge.writeFile(c,JSON.stringify(u,null,2),"utf8")}Km.deleteConfigFromFile([r]);let l=await ti(e);return l.message="Successfully dropped: "+s,l}a(gle,"dropComponent");async function Rle(e){let t=Rn.addSSHKeyValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);let{name:r,key:n,host:s,hostname:i,known_hosts:o}=e;kt.trace("adding ssh key",r);let c=Ce.join(Sa,r+".key"),l=Ce.join(Sa,"config");if(await ge.pathExists(c))throw new Error("Key already exists. Use update_ssh_key or delete_ssh_key and then add_ssh_key");await ge.outputFile(c,n),await ge.chmod(c,"0600");let u=`#${r}
22
+ `,""):null}catch(f){f.stderr?o[u].npm_error=fG(f.stderr):o[u].npm_error=f.message;continue}try{o[u].npm_output=JSON.parse(_)}catch{o[u].npm_output=_}try{o[u].npm_error=JSON.parse(E)}catch{o[u].npm_error=E}}return Jc.info(`finished installModules with response ${o}`),o.warning=t,o}a(Vce,"installModules");function fG(e){let t='"error": {',r=e.indexOf('"error": {'),n=e.indexOf(`}
23
+ `);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(fG,"parseNPMStdErr");async function Kce(e){Jc.info(`starting auditModules for request: ${e}`);let t=hG(e);if(t)throw Vu(t,t.message,Ku.BAD_REQUEST);let{projects:r}=e;await $m(),await EG(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=ma.join(mO,o);n[o]={npm_output:null,npm_error:null};try{let l=await Yu("npm audit --json",c);n[o].npm_output=JSON.parse(l)}catch(l){n[o].npm_error=fG(l.stderr)}}return Jc.info(`finished auditModules with response ${n}`),n}a(Kce,"auditModules");async function $m(){try{return await Yu("npm -v"),!0}catch{throw Vu(new Error,"Unable to install project dependencies: npm is not installed on this instance of HarperDB.",Ku.BAD_REQUEST,void 0,void 0,!0)}}a($m,"checkNPMInstalled");async function EG(e){if(!Array.isArray(e)||e.length===0)throw Vu(new Error,"projects argument must be an array with at least 1 element",Ku.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=ma.join(mO,i.toString());if(!await $u.pathExists(o)){t.push(i);continue}let l=ma.join(o,"package.json");await $u.pathExists(l)||r.push(i)}if(t.length>0)throw Vu(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,Ku.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw Vu(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,Ku.BAD_REQUEST,void 0,void 0,!0)}a(EG,"checkProjectPaths");function hG(e){let t=Gm.object({projects:Gm.array().min(1).items(Gm.string()).required(),dry_run:Gm.boolean().default(!1)});return xce.validateBySchema(e,t)}a(hG,"modulesValidator")});var SO=N((GCe,RG)=>{"use strict";var gs=require("fs-extra"),Gf=require("path"),Ff=W(),mG=te(),Vm=M(),AG=se(),Yce=wt();RG.exports=Wce;async function Wce(){let e=jce(),t=AG.get(Vm.CONFIG_PARAMS.ROOTPATH),r=Gf.join(t,"package.json"),n={dependencies:{harperdb:"file:"+Vm.PACKAGE_ROOT}},s=Gf.join(t,"node_modules");gs.ensureDirSync(s);let i,o=!0,c=!1;try{i=gs.readJsonSync(r)}catch(l){if(mG.isEmptyOrZeroLength(e))return;if(l.code!==Vm.NODE_ERROR_CODES.ENOENT)throw l;o=!1}if(!mG.isEmptyOrZeroLength(e)){for(let{name:l,package:u}of e){let d=TG(u);n.dependencies[l]=d+u}if(!o){Ff.notify("Installing components"),await gG(r,n,null),await SG(t,e);return}for(let{name:l,package:u}of e){let d=i.dependencies[l],_=TG(u);if(d===void 0||d!==_+u){c=!0;break}if(u.startsWith("file:"))try{if(gs.statSync(new URL(u+"/package.json")).mtimeMs>gs.statSync(r).mtimeMs){c=!0;break}}catch(E){Ff.info(`Error checking ${u}/package.json modification time`,E);break}}}for(let l in i.dependencies)n.dependencies[l]===void 0&&(Ff.notify("Removing component",l),c=!0);c&&(Ff.notify("Updating components."),await gG(r,n,i),await SG(t,e))}a(Wce,"installComponents");function SG(e,t){return Promise.all(t.map(({name:r})=>{let n=Gf.join(e,"node_modules",r),s=Gf.join(e,"components",r);if(gs.existsSync(n)&&gs.lstatSync(n).isDirectory())return gs.move(n,s,{overwrite:!0}).then(()=>{gs.symlink(s,n)})}))}a(SG,"moveModuleToComponents");function jce(){let e=Yce.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(jce,"getComponentsConfig");function TG(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":Gf.extname(e)||gs.existsSync(e)?"file:":"github:"}a(TG,"getPkgPrefix");async function gG(e,t,r){Ff.trace("npm installing components package.json",t),gs.writeFileSync(e,JSON.stringify(t,null," "));try{await kf().installAllRootModules(AG.get(Vm.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?gs.writeFileSync(e,JSON.stringify(r,null," ")):gs.unlinkSync(e),n}}a(gG,"installPackages")});var OG={};je(OG,{packageDirectory:()=>Qce});function Qce(e,t){let{skip_node_modules:r,hidden_folders:n}=t;return new Promise((s,i)=>{let o=r?{ignore:a(l=>l.includes(TO.default.join("node_modules"))||l.includes(TO.default.join("cache","webpack")),"ignore")}:{},c=[];yG.default.pack(e,o).pipe((0,bG.createGzip)()).on("data",l=>c.push(l)).on("end",()=>{let l=Buffer.concat(c);s(l)}).on("error",i)})}var TO,yG,zce,bG,NG=Ie(()=>{TO=L(require("path")),yG=L(require("tar-fs")),zce=require("node:fs"),bG=require("node:zlib");a(Qce,"packageDirectory")});var OO=N((YCe,DG)=>{var jm=require("clone"),zm=Tt(),Jce=te(),Ym=M(),VCe=W(),gO=require("fs"),RO=require("joi"),{string:Wm}=RO.types(),{hdb_errors:Xce,handleHDBError:Km}=_e(),{HDB_ERROR_MSGS:KCe,HTTP_STATUS_CODES:AO}=Xce,{common_validators:Wu}=Ti(),IG=" is required",Zce=["insert","update","upsert"],yO={database:{presence:!1,format:Wu.schema_format,length:Wu.schema_length},schema:{presence:!1,format:Wu.schema_format,length:Wu.schema_length},table:{presence:!0,format:Wu.schema_format,length:Wu.schema_length},action:{inclusion:{within:Zce,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},ele={schema:Wm.required(),table:Wm.required(),action:Wm.valid("insert","update","upsert")},{AWS_ACCESS_KEY:tle,AWS_SECRET:rle,AWS_BUCKET:nle,AWS_FILE_KEY:sle,REGION:ile}=Ym.S3_BUCKET_AUTH_KEYS,ole={s3:{presence:!0},[`s3.${tle}`]:{presence:!0,type:"String"},[`s3.${rle}`]:{presence:!0,type:"String"},[`s3.${nle}`]:{presence:!0,type:"String"},[`s3.${sle}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${ile}`]:{presence:!0,type:"String"}},wG=jm(yO);wG.data.presence={message:IG};var CG=jm(yO);CG.file_path.presence={message:IG};var ale=Object.assign(jm(yO),ole),bO=jm(ele);bO.csv_url=Wm.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();bO.passthrough_headers=RO.object();function cle(e){let t=zm.validateObject(e,wG);return Qm(e,t)}a(cle,"dataObject");function lle(e){let t=zm.validateBySchema(e,RO.object(bO));return Qm(e,t)}a(lle,"urlObject");function ule(e){let t=zm.validateObject(e,CG);return Qm(e,t)}a(ule,"fileObject");function dle(e){let t=zm.validateObject(e,ale);return Qm(e,t)}a(dle,"s3FileObject");function Qm(e,t){if(!t){let r=Jce.checkGlobalSchemaTable(e.schema,e.table);if(r)return Km(new Error,r,AO.BAD_REQUEST);if(e.operation===Ym.OPERATIONS_ENUM.CSV_FILE_LOAD)try{gO.accessSync(e.file_path,gO.constants.R_OK|gO.constants.F_OK)}catch(n){return n.code===Ym.NODE_ERROR_CODES.ENOENT?Km(n,`No such file or directory ${n.path}`,AO.BAD_REQUEST):n.code===Ym.NODE_ERROR_CODES.EACCES?Km(n,`Permission denied ${n.path}`,AO.BAD_REQUEST):Km(n)}}return t}a(Qm,"postValidateChecks");DG.exports={dataObject:cle,urlObject:lle,fileObject:ule,s3FileObject:dle}});var NO=N((jCe,PG)=>{"use strict";var qf=W(),Jm=M();async function _le(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===Jm.OPERATIONS_ENUM.INSERT||t.operation===Jm.OPERATIONS_ENUM.UPDATE||t.operation===Jm.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===Jm.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(qf.info(i.message),i):i.http_resp_msg?(qf.error(`Error calling operation: ${e.name}`),qf.error(i.http_resp_msg),i):(qf.error(`Error calling operation: ${e.name}`),qf.error(i),i)}}a(_le,"callOperationFunctionAsAwait");PG.exports={callOperationFunctionAsAwait:_le}});var IO=N((QCe,MG)=>{"use strict";var{S3:fle,GetObjectCommand:Ele}=require("@aws-sdk/client-s3");MG.exports={getFileStreamFromS3:hle,getS3AuthObj:LG};async function hle(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await LG(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new Ele(r))).Body}a(hle,"getFileStreamFromS3");function LG(e,t,r){return new fle({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(LG,"getS3AuthObj")});var vG=N((XCe,UG)=>{"use strict";var wO=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}},CO=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};UG.exports={BulkLoadFileObject:wO,BulkLoadDataObject:CO}});var HG=N((eDe,BG)=>{"use strict";var DO=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}};BG.exports=DO});var kG=N((rDe,xG)=>{"use strict";var PO=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};xG.exports=PO});var MO=N((sDe,GG)=>{"use strict";var FG=HG(),ple=kG(),{HDB_ERROR_MSGS:mle}=Dn(),LO=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=mle.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 FG(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let l=new ple(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 FG(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}};GG.exports=LO});var $G=N((oDe,qG)=>{"use strict";var UO=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};qG.exports=UO});var FO=N((_De,oq)=>{"use strict";var Xm=un(),eS=OO(),Sle=require("needle"),ti=M(),cDe=Ct(),ju=te(),{handleHDBError:kt,hdb_errors:XG}=_e(),{HTTP_STATUS_CODES:Mr,HDB_ERROR_MSGS:gr,CHECK_LOGS_WRAPPER:Zc}=XG,zu=W(),vO=require("papaparse");ju.promisifyPapaParse();var ri=require("fs-extra"),Tle=require("path"),{chain:VG}=require("stream-chain"),KG=require("stream-json/streamers/StreamArray"),YG=require("stream-json/utils/Batch"),WG=require("stream-chain/utils/comp"),{finished:jG}=require("stream"),gle=se(),ZG=NO(),Ale=IO(),{BulkLoadFileObject:HO,BulkLoadDataObject:Rle}=vG(),xO=MO(),{verifyBulkLoadAttributePerms:eq}=tS(),lDe=$G(),uDe=mr(),dDe=to(),{databases:yle}=(Pe(),oe(lt)),{coerceType:ble}=($f(),oe(GO)),zG="No records parsed from csv file.",Xc=`${gle.get("HDB_ROOT")}/tmp`,{schema_regex:Ole}=Ti(),QG=1024*1024*2,JG=5e3,Nle={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};oq.exports={csvDataLoad:Ile,csvURLLoad:wle,csvFileLoad:Cle,importFromS3:Dle};async function Ile(e,t){let r=eS.dataObject(e);if(r)throw kt(r,r.message,Mr.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=nq(e.schema,e.table),i=vO.parse(e.data,{header:!0,skipEmptyLines:!0,transform:BO.bind(null,s),dynamicTyping:!1}),o=new xO;e.hdb_user&&e.hdb_user?.role&&e.hdb_user?.role?.permission&&e.hdb_user?.role?.permission?.super_user!==!0&&eq(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 kt(new Error,c,Mr.BAD_REQUEST,void 0,void 0,!0);let l=new Rle(e.action,e.schema,e.table,i.data);return n=await ZG.callOperationFunctionAsAwait(sq,l,null),n.message===zG?zG:iq(n.records,n.number_written)}catch(s){throw el(s)}}a(Ile,"csvDataLoad");async function wle(e){let t=eS.urlObject(e);if(t)throw kt(t,t.message,Mr.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${Xc}/${r}`;try{await Ple(e,r)}catch(s){throw zu.error(gr.DOWNLOAD_FILE_ERR(r)+" - "+s),kt(s,Zc(gr.DOWNLOAD_FILE_ERR(r)))}try{let s=new HO(this.job_operation_function.name,e.action,e.schema,e.table,n,ti.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission),i=await kO(s);return await Zm(n),i}catch(s){throw await Zm(n),el(s)}}a(wle,"csvURLLoad");async function Cle(e){let t=eS.fileObject(e);if(t)throw kt(t,t.message,Mr.BAD_REQUEST,void 0,void 0,!0);let r=new HO(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,ti.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission);try{return await kO(r)}catch(n){throw el(n)}}a(Cle,"csvFileLoad");async function Dle(e){let t=eS.s3FileObject(e);if(t)throw kt(t,t.message,Mr.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=Tle.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${Xc}/${s}`;let i=new HO(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user?.role?.permission);await Lle(s,e);let o=await kO(i);return await Zm(r),o}catch(n){throw await Zm(r),el(n)}}a(Dle,"importFromS3");async function Ple(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await Sle("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 kt(n,s,n.statusCode,ti.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}Ule(r,e.csv_url),await Mle(t,r.raw)}a(Ple,"downloadCSVFile");async function Lle(e,t){try{let r=`${Xc}/${e}`;await ri.mkdirp(Xc),await ri.writeFile(`${Xc}/${e}`,"",{flag:"a+"});let n=await ri.createWriteStream(r),s=await Ale.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(){zu.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw zu.error(gr.S3_DOWNLOAD_ERR+" - "+r),kt(r,Zc(gr.S3_DOWNLOAD_ERR))}}a(Lle,"downloadFileFromS3");async function Mle(e,t){try{await ri.mkdirp(Xc),await ri.writeFile(`${Xc}/${e}`,t)}catch(r){throw zu.error(gr.WRITE_TEMP_FILE_ERR),kt(r,Zc(gr.DEFAULT_BULK_LOAD_ERR))}}a(Mle,"writeFileToTempFolder");async function Zm(e){if(e)try{await ri.access(e),await ri.unlink(e)}catch{zu.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(Zm,"deleteTempFile");function Ule(e,t){if(e.statusCode!==XG.HTTP_STATUS_CODES.OK)throw kt(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,Mr.BAD_REQUEST);if(!Nle[e.headers["content-type"]])throw kt(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,Mr.BAD_REQUEST);if(!e.raw)throw kt(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,Mr.BAD_REQUEST)}a(Ule,"validateURLResponse");async function kO(e){try{let t;switch(e.file_type){case ti.VALID_S3_FILE_TYPES.CSV:t=await vle(e);break;case ti.VALID_S3_FILE_TYPES.JSON:t=await Ble(e);break;default:throw kt(new Error,gr.DEFAULT_BULK_LOAD_ERR,Mr.BAD_REQUEST,ti.LOG_LEVELS.ERROR,gr.INVALID_FILE_EXT_ERR(e))}return iq(t.records,t.number_written)}catch(t){throw el(t)}}a(kO,"fileLoad");async function tq(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 Xm.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&eq(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let l=kt(c);r(l)}}a(tq,"validateChunk");async function rq(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;ju.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!ju.isEmpty(c)&&!ju.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 ZG.callOperationFunctionAsAwait(sq,c,null);t.records+=l.records,t.number_written+=l.number_written,s&&s.resume()}catch(c){let l=kt(c,Zc(gr.INSERT_CSV_ERR),Mr.INTERNAL_SERVER_ERROR,ti.LOG_LEVELS.ERROR,gr.INSERT_CSV_ERR+" - "+c);r(l)}}a(rq,"insertChunk");async function vle(e){let t={records:0,number_written:0},r=nq(e.schema,e.table);try{let n=new xO,s=ri.createReadStream(e.file_path,{highWaterMark:QG});s.setEncoding("utf8"),await vO.parsePromise(s,tq.bind(null,e,n),BO.bind(null,r));let i=n.getPermsResponse();if(i)throw kt(new Error,i,Mr.BAD_REQUEST);return s=ri.createReadStream(e.file_path,{highWaterMark:QG}),s.setEncoding("utf8"),await vO.parsePromise(s,rq.bind(null,e,t),BO.bind(null,r)),s.destroy(),t}catch(n){throw kt(n,Zc(gr.PAPA_PARSE_ERR),Mr.INTERNAL_SERVER_ERROR,ti.LOG_LEVELS.ERROR,gr.PAPA_PARSE_ERR+n)}}a(vle,"callPapaParse");function nq(e,t){let r=yle[e][t].attributes,n=new Map;for(let s of r)s.type&&!s.computed&&!s.relationship&&n.set(s.name,i=>ble(i,s));return n}a(nq,"createTransformMap");function BO(e,t,r){let n=e.get(r);return n?n(t):ju.autoCast(t)}a(BO,"typeFunction");async function Ble(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new xO,s=VG([ri.createReadStream(e.file_path,{encoding:"utf-8"}),KG.withParser(),c=>c.value,new YG({batchSize:JG}),WG(async c=>{await tq(e,n,r,c)})]);await new Promise((c,l)=>{jG(s,u=>{u?l(u):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw kt(new Error,i,Mr.BAD_REQUEST);let o=VG([ri.createReadStream(e.file_path,{encoding:"utf-8"}),KG.withParser(),c=>c.value,new YG({batchSize:JG}),WG(async c=>{await rq(e,t,r,c)})]);return await new Promise((c,l)=>{jG(o,u=>{u?l(u):c()}),o.resume()}),t}catch(n){throw kt(n,Zc(gr.INSERT_JSON_ERR),Mr.INTERNAL_SERVER_ERROR,ti.LOG_LEVELS.ERROR,gr.INSERT_JSON_ERR+n)}}a(Ble,"insertJson");async function sq(e){let t={};try{e.data&&e.data.length>0&&Hle(e.data[0])?t=await xle(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",zu.info(t.message))}catch(r){throw el(r)}return t}a(sq,"callBulkFileLoad");function Hle(e){let t=Object.keys(e);for(let r of t)if(!Ole.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(Hle,"validateColumnNames");async function xle(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=Xm.insert;break;case"update":i=Xm.update;break;case"upsert":i=Xm.upsert;break;default:throw kt(new Error,gr.INVALID_ACTION_PARAM_ERR(n),Mr.BAD_REQUEST,ti.LOG_LEVELS.ERROR,gr.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 d=global.hdb_schema[t][r].hash_attribute,_=e.length;for(;_--;)o.skipped_hashes.indexOf(e[_][d])>=0&&e.splice(_,1)}let l=ju.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw el(o)}}a(xle,"bulkFileLoad");function iq(e,t){return`successfully loaded ${t} of ${e} records`}a(iq,"buildResponseMsg");function el(e){return kt(e,Zc(gr.DEFAULT_BULK_LOAD_ERR),Mr.INTERNAL_SERVER_ERROR,ti.LOG_LEVELS.ERROR,gr.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(el,"buildTopLevelErrMsg")});var cq=N((EDe,aq)=>{"use strict";var qO=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};aq.exports=qO});var dq=N((pDe,uq)=>{"use strict";var kle=M(),lq=require("moment"),Fle=require("uuid").v4,$O=class{static{a(this,"JobObject")}constructor(){this.id=Fle(),this.type=void 0,this.start_datetime=lq().valueOf(),this.created_datetime=lq().valueOf(),this.end_datetime=void 0,this.status=kle.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};uq.exports=$O});var VO=N((SDe,fq)=>{"use strict";var As=require("joi"),_q=Tt();fq.exports={readTransactionLogValidator:Gle,deleteTransactionLogsBeforeValidator:qle};function Gle(e){let t=As.object({schema:As.string(),database:As.string(),table:As.string().required(),from:As.date().timestamp(),to:As.date().timestamp(),limit:As.number().min(1)});return _q.validateBySchema(e,t)}a(Gle,"readTransactionLogValidator");function qle(e){let t=As.object({schema:As.string(),database:As.string(),table:As.string().required(),timestamp:As.date().timestamp().required()});return _q.validateBySchema(e,t)}a(qle,"deleteTransactionLogsBeforeValidator")});var KO=N((gDe,Aq)=>{"use strict";var $le=require("uuid").v4,Sq=un(),Tq=Vr(),Vle=$s(),Kle=Wl(),Yle=cq(),bt=M(),Wle=dq(),jle=Hp(),ni=W(),zle=Jd(),Qu=te(),{promisify:Qle}=require("util"),tl=require("moment"),Jle=nS(),rS=OO(),Eq=yA(),{deleteTransactionLogsBeforeValidator:Xle}=VO(),{handleHDBError:hq,hdb_errors:Zle,ClientError:eue}=_e(),{HTTP_STATUS_CODES:pq}=Zle,mq=Tq.searchByValue,tue=Tq.searchByHash,rue=Sq.insert,nue=Qle(Jle.evaluateSQL),sue=Sq.update;Aq.exports={addJob:aue,updateJob:lue,handleGetJob:iue,handleGetJobsByStartDate:oue,getJobById:gq};async function iue(e){if(e.id===void 0)throw new eue("'id' is required");let t=await gq(e.id);return Qu.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(iue,"handleGetJob");async function oue(e){try{let t=await cue(e);if(ni.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=tl(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=tl(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 ni.error(r),new Error(r)}}a(oue,"handleGetJobsByStartDate");async function aue(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||Qu.isEmptyOrZeroLength(e.operation)){let d="job parameter is invalid";return ni.info(d),t.error=d,t}if(!bt.JOB_TYPE_ENUM[e.operation])return ni.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case bt.OPERATIONS_ENUM.CSV_FILE_LOAD:n=rS.fileObject(e);break;case bt.OPERATIONS_ENUM.CSV_URL_LOAD:n=rS.urlObject(e);break;case bt.OPERATIONS_ENUM.CSV_DATA_LOAD:n=rS.dataObject(e);break;case bt.OPERATIONS_ENUM.IMPORT_FROM_S3:n=rS.s3FileObject(e);break;case bt.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case bt.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=Eq(e,"date");break;case bt.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=Eq(e,"timestamp");break;case bt.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=Xle(e);break;case bt.OPERATIONS_ENUM.RESTART_SERVICE:if(bt.PROCESS_DESCRIPTORS_VALIDATE[e.service]===void 0)throw hq(new Error,"Invalid service",pq.BAD_REQUEST,void 0,void 0,!0);break;default:break}if(n)throw hq(n,n.message,pq.BAD_REQUEST,void 0,void 0,!0);let s=new Wle;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 Vle(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await mq(i))}catch(d){let _=`There was an error inserting a new job: ${d}`;return ni.error(_),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=$le();try{o=await mq(i)}catch(d){let _=`There was an error inserting a new job: ${d}`;return ni.error(_),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return ni.error("Error creating a job, could not find a unique job id."),t}s.request=e;let l=new zle(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),u;try{u=await rue(l)}catch(d){return ni.error(`There was an error inserting a job for job type: ${e.operation} -- ${d}`),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 d=`Created a job with type ${s.type} and id ${s.id}`;t.message=d,t.createdJob=s,t.success=!0,ni.trace(d)}return t}a(aue,"addJob");async function cue(e){let t=tl(e.from_date,tl.ISO_8601),r=tl(e.to_date,tl.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 Yle(n,e.hdb_user);try{return await nue(s)}catch(i){throw ni.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(cue,"getJobsInDateRange");async function gq(e){if(Qu.isEmptyOrZeroLength(e))return Qu.errorizeMessage("Invalid job ID specified.");let t=new Kle(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await tue(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return ni.error(n),Qu.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(gq,"getJobById");async function lue(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(Qu.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=tl().valueOf());let t=new jle(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await sue(t),r}a(lue,"updateJob")});var oS=N((RDe,Iq)=>{"use strict";var YO=M(),Vf=mr(),Rq=te(),yq=se(),bq=to(),Oq=W(),{handleHDBError:sS,hdb_errors:uue}=_e(),{HTTP_STATUS_CODES:iS}=uue,{readTransactionLogValidator:due,deleteTransactionLogsBeforeValidator:_ue}=VO(),Nq=Bn(),fue="Logs successfully deleted from transaction log.",Eue="All logs successfully deleted from transaction log.";Iq.exports={readTransactionLog:hue,deleteTransactionLogsBefore:mue};async function hue(e){let t=due(e);if(t)throw sS(t,t.message,iS.BAD_REQUEST,void 0,void 0,!0);e.database=e.database??e.schema??"data";let r=Rq.checkSchemaTableExist(e.database,e.table);if(r)throw sS(new Error,r,iS.NOT_FOUND,void 0,void 0,!0);return yq.get(YO.CONFIG_PARAMS.CLUSTERING_ENABLED)?await pue(e):(Oq.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)),Nq.readAuditLog(e))}a(hue,"readTransactionLog");async function*pue(e){let t=bq.createNatsTableStreamName(e.database,e.table),r=await Vf.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===YO.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(pue,"readTransactionLogNats");async function mue(e){let t=_ue(e);if(t)throw sS(t,t.message,iS.BAD_REQUEST,void 0,void 0,!0);if(e.database=e.database??e.schema??"data",!yq.get(YO.CONFIG_PARAMS.CLUSTERING_ENABLED))return Oq.info("Delete transaction logs called for Plexus"),Nq.deleteAuditLogsBefore(e);let{database:r,table:n,timestamp:s}=e,i=Rq.checkSchemaTableExist(r,n);if(i)throw sS(new Error,i,iS.NOT_FOUND,void 0,void 0,!0);let o=bq.createNatsTableStreamName(r,n),{jsm:c}=await Vf.getNATSReferences(),l=await Vf.getStreamInfo(o),u=new Date(l.state.first_ts).getTime();if(s<=u)return`No transactions exist before: ${s}`;let d=fue,_,E=new Date(l.state.last_ts).getTime();return s>E?(_=l.state.last_seq+1,d=Eue):_=(await Vf.viewStream(o,parseInt(s),1))[0].nats_sequence,await Vf.purgeTableStream(r,n,{seq:_}),d}a(mue,"deleteTransactionLogsBefore")});var vq=N((bDe,Uq)=>{"use strict";var wq=te(),Ar=M(),Sue=require("moment"),aS=FO(),Kf=W(),Cq=KO(),Dq=cS(),Pq=uc(),Lq=dt(),Tue=oS(),gue=Gu(),{parentPort:Aue,isMainThread:Mq}=require("worker_threads"),{onMessageByType:Rue}=dt(),WO=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function yue(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(wq.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(wq.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case Ar.JOB_TYPE_ENUM.csv_file_load:await Li(e,aS.csvFileLoad);break;case Ar.JOB_TYPE_ENUM.csv_url_load:await Li(e,aS.csvURLLoad);break;case Ar.JOB_TYPE_ENUM.csv_data_load:await Li(e,aS.csvDataLoad);break;case Ar.JOB_TYPE_ENUM.import_from_s3:await Li(e,aS.importFromS3);break;case Ar.JOB_TYPE_ENUM.empty_trash:break;case Ar.JOB_TYPE_ENUM.export_local:await Li(e,Dq.export_local);break;case Ar.JOB_TYPE_ENUM.export_to_s3:await Li(e,Dq.export_to_s3);break;case Ar.JOB_TYPE_ENUM.delete_files_before:case Ar.JOB_TYPE_ENUM.delete_records_before:await Li(e,Pq.deleteFilesBefore);break;case Ar.JOB_TYPE_ENUM.delete_audit_logs_before:await Li(e,Pq.deleteAuditLogsBefore);break;case Ar.JOB_TYPE_ENUM.delete_transaction_logs_before:await Li(e,Tue.deleteTransactionLogsBefore);break;case Ar.JOB_TYPE_ENUM.restart_service:return await Li(e,gue.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(yue,"parseMessage");async function Li(e,t){try{e.job.status=Ar.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=Sue().valueOf(),await Cq.updateJob(e.job),await bue(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):Kf.error(`There was an error running ${t.name} job with id ${e.job.id}`),Kf.error(n),e.job.message=n,e.job.status=Ar.JOB_STATUS_ENUM.ERROR;try{await Cq.updateJob(e.job)}catch(s){throw Kf.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(Li,"runJob");async function bue(e){Kf.trace("launching job thread:",e),Mq?Lq.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Ar.PROCESS_NAME_ENV_PROP]:`JOB-${e}`}}):Aue.postMessage({type:Ar.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(bue,"launchJobThread");Mq&&Rue(Ar.ITC_EVENT_TYPES.START_JOB,async(e,t)=>{try{Lq.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Ar.PROCESS_NAME_ENV_PROP]:`JOB-${e.jobId}`}})}catch(r){Kf.error(r)}});Uq.exports={parseMessage:yue,RunnerMessage:WO}});var Hq=N((NDe,Bq)=>{"use strict";var jO=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};Bq.exports=jO});var tN=N((CDe,eN)=>{"use strict";var fS=Vr(),JO=nS(),lS=FO(),To=tm(),uS=ro(),Wf=uc(),Oue=zy(),Yf=xn(),dS=lf(),Lt=rN(),_S=W(),Nue=ob(),Iue=pf(),xq=Lb(),wue=Af(),Cue=vb(),Due=Bb(),Pue=Sm(),Lue=Fb(),zO=gm(),kq=cS(),Mue=tS(),XO=KO(),$=M(),{hdb_errors:zf,handleHDBError:jf}=_e(),{HTTP_STATUS_CODES:Fq}=zf,QO=Wb(),Gq=Gu(),Jq=require("util"),Xu=un(),Uue=ls(),vue=wu(),qq=vq(),$q=_u(),Vq=(km(),oe(Hf)),Kq=wt(),Yq=oS(),Wq=kf(),{setServerUtilities:Bue}=($f(),oe(GO)),{CONTEXT:wDe}=(Vs(),oe(_R)),{_assignPackageExport:Hue}=fi(),{transformReq:xue}=te(),{server:kue}=(qr(),oe(Qa)),Zr=_S.loggerWithTag("operation"),Ju=Xs(),jq=(xc(),oe(Hc)),Fue=NO(),zq=fS.searchByHash,Gue=fS.searchByValue,que=Jq.promisify(fS.search),$ue=Jq.promisify(JO.evaluateSQL),Vue={[$.OPERATIONS_ENUM.CREATE_ATTRIBUTE]:!0,[$.OPERATIONS_ENUM.CREATE_TABLE]:!0,[$.OPERATIONS_ENUM.CREATE_SCHEMA]:!0,[$.OPERATIONS_ENUM.DROP_ATTRIBUTE]:!0,[$.OPERATIONS_ENUM.DROP_TABLE]:!0,[$.OPERATIONS_ENUM.DROP_SCHEMA]:!0},J=Hq();async function Xq(e,t){try{if(e.body.operation!=="read_log"&&(_S.log_level===$.LOG_LEVELS.INFO||_S.log_level===$.LOG_LEVELS.DEBUG||_S.log_level===$.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,payload:o,...c}=e.body;Zr.info(c)}}catch(n){Zr.error(n)}let r=await Fue.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return Vue[e.body.operation]&&Uue.setSchemaDataToGlobal(n=>{n&&Zr.error(n)}),r}a(Xq,"processLocalTransaction");var Qq=Yue();eN.exports={chooseOperation:Zq,getOperationFunction:e$,operation:ZO,processLocalTransaction:Xq,executeJob:Rs};Bue(eN.exports);kue.operation=ZO;function Zq(e){let t;try{t=e$(e)}catch(s){throw Zr.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=JO.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=JO.checkASTPermissions(e,i);if(o)throw Zr.error(`${Fq.FORBIDDEN} from operation ${e.operation}`),Zr.warn(`User '${e.hdb_user?.username}' is not permitted to ${e.operation}`),jf(new Error,o,zf.HTTP_STATUS_CODES.FORBIDDEN,void 0,void 0,!0)}}else if(!e.bypass_auth&&e.operation!==$.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.operation!==$.OPERATIONS_ENUM.LOGIN&&e.operation!==$.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=Mue.verifyPerms(i,s);if(o)throw Zr.error(`${Fq.FORBIDDEN} from operation ${e.operation}`),Zr.warn(`User '${i.hdb_user?.username}' is not permitted to ${i.operation}`),jf(new Error,o,zf.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw jf(s,"There was an error when trying to choose an operation path")}return r}a(Zq,"chooseOperation");function e$(e){if(Zr.trace(`getOperationFunction with operation: ${e.operation}`),Qq.has(e.operation))return Qq.get(e.operation);throw jf(new Error,zf.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),zf.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(e$,"getOperationFunction");Hue("operation",ZO);function ZO(e,t,r){e.hdb_user=t?.user,e.bypass_auth=!r;let n=Zq(e);return Xq({body:e},n)}a(ZO,"operation");async function Kue(e){Zr.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[$.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case $.OPERATIONS_ENUM.INSERT:o=await Xu.insert(i);break;case $.OPERATIONS_ENUM.UPDATE:o=await Xu.update(i);break;case $.OPERATIONS_ENUM.UPSERT:o=await Xu.upsert(i);break;case $.OPERATIONS_ENUM.DELETE:o=await Wf.deleteRecord(i);break;default:Zr.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){Zr.info("Invalid operation in transaction"),Zr.error(o)}}a(Kue,"catchup");async function Rs(e){xue(e);let t,r;try{r=await XO.addJob(e),t=r.createdJob,Zr.info("addJob result",r);let n=new qq.RunnerMessage(t,e);return{message:await qq.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 Zr.error(s),jf(n,s)}}a(Rs,"executeJob");function Yue(){let e=new Map;return e.set($.OPERATIONS_ENUM.INSERT,new J(Xu.insert)),e.set($.OPERATIONS_ENUM.UPDATE,new J(Xu.update)),e.set($.OPERATIONS_ENUM.UPSERT,new J(Xu.upsert)),e.set($.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new J(fS.searchByConditions)),e.set($.OPERATIONS_ENUM.SEARCH_BY_HASH,new J(zq)),e.set($.OPERATIONS_ENUM.SEARCH_BY_ID,new J(zq)),e.set($.OPERATIONS_ENUM.SEARCH_BY_VALUE,new J(Gue)),e.set($.OPERATIONS_ENUM.SEARCH,new J(que)),e.set($.OPERATIONS_ENUM.SQL,new J($ue)),e.set($.OPERATIONS_ENUM.CSV_DATA_LOAD,new J(Rs,lS.csvDataLoad)),e.set($.OPERATIONS_ENUM.CSV_FILE_LOAD,new J(Rs,lS.csvFileLoad)),e.set($.OPERATIONS_ENUM.CSV_URL_LOAD,new J(Rs,lS.csvURLLoad)),e.set($.OPERATIONS_ENUM.IMPORT_FROM_S3,new J(Rs,lS.importFromS3)),e.set($.OPERATIONS_ENUM.CREATE_SCHEMA,new J(To.createSchema)),e.set($.OPERATIONS_ENUM.CREATE_DATABASE,new J(To.createSchema)),e.set($.OPERATIONS_ENUM.CREATE_TABLE,new J(To.createTable)),e.set($.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new J(To.createAttribute)),e.set($.OPERATIONS_ENUM.DROP_SCHEMA,new J(To.dropSchema)),e.set($.OPERATIONS_ENUM.DROP_DATABASE,new J(To.dropSchema)),e.set($.OPERATIONS_ENUM.DROP_TABLE,new J(To.dropTable)),e.set($.OPERATIONS_ENUM.DROP_ATTRIBUTE,new J(To.dropAttribute)),e.set($.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new J(uS.describeSchema)),e.set($.OPERATIONS_ENUM.DESCRIBE_DATABASE,new J(uS.describeSchema)),e.set($.OPERATIONS_ENUM.DESCRIBE_TABLE,new J(uS.describeTable)),e.set($.OPERATIONS_ENUM.DESCRIBE_ALL,new J(uS.describeAll)),e.set($.OPERATIONS_ENUM.DELETE,new J(Wf.deleteRecord)),e.set($.OPERATIONS_ENUM.ADD_USER,new J(Yf.addUser)),e.set($.OPERATIONS_ENUM.ALTER_USER,new J(Yf.alterUser)),e.set($.OPERATIONS_ENUM.DROP_USER,new J(Yf.dropUser)),e.set($.OPERATIONS_ENUM.LIST_USERS,new J(Yf.listUsersExternal)),e.set($.OPERATIONS_ENUM.LIST_ROLES,new J(dS.listRoles)),e.set($.OPERATIONS_ENUM.ADD_ROLE,new J(dS.addRole)),e.set($.OPERATIONS_ENUM.ALTER_ROLE,new J(dS.alterRole)),e.set($.OPERATIONS_ENUM.DROP_ROLE,new J(dS.dropRole)),e.set($.OPERATIONS_ENUM.USER_INFO,new J(Yf.userInfo)),e.set($.OPERATIONS_ENUM.READ_LOG,new J(Nue)),e.set($.OPERATIONS_ENUM.ADD_NODE,new J(Iue)),e.set($.OPERATIONS_ENUM.UPDATE_NODE,new J(xq)),e.set($.OPERATIONS_ENUM.SET_NODE_REPLICATION,new J(xq)),e.set($.OPERATIONS_ENUM.REMOVE_NODE,new J(wue)),e.set($.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new J(Cue)),e.set($.OPERATIONS_ENUM.PURGE_STREAM,new J(Due)),e.set($.OPERATIONS_ENUM.SET_CONFIGURATION,new J(Kq.setConfiguration)),e.set($.OPERATIONS_ENUM.CLUSTER_STATUS,new J(Pue.clusterStatus)),e.set($.OPERATIONS_ENUM.CLUSTER_NETWORK,new J(Lue)),e.set($.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new J(zO.setRoutes)),e.set($.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new J(zO.getRoutes)),e.set($.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new J(zO.deleteRoutes)),e.set($.OPERATIONS_ENUM.EXPORT_TO_S3,new J(Rs,kq.export_to_s3)),e.set($.OPERATIONS_ENUM.CREATE_CSR,new J(Ju.createCsr)),e.set($.OPERATIONS_ENUM.SIGN_CERTIFICATE,new J(Ju.signCertificate)),e.set($.OPERATIONS_ENUM.LIST_CERTIFICATES,new J(Ju.listCertificates)),e.set($.OPERATIONS_ENUM.ADD_CERTIFICATES,new J(Ju.addCertificate)),e.set($.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new J(Ju.removeCertificate)),e.set($.OPERATIONS_ENUM.GET_KEY,new J(Ju.getKey)),e.set($.OPERATIONS_ENUM.ADD_NODE_BACK,new J(jq.addNodeBack)),e.set($.OPERATIONS_ENUM.REMOVE_NODE_BACK,new J(jq.removeNodeBack)),e.set($.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new J(Rs,Wf.deleteFilesBefore)),e.set($.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new J(Rs,Wf.deleteFilesBefore)),e.set($.OPERATIONS_ENUM.EXPORT_LOCAL,new J(Rs,kq.export_local)),e.set($.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new J(XO.handleGetJobsByStartDate)),e.set($.OPERATIONS_ENUM.GET_JOB,new J(XO.handleGetJob)),e.set($.OPERATIONS_ENUM.GET_FINGERPRINT,new J(QO.getFingerprint)),e.set($.OPERATIONS_ENUM.SET_LICENSE,new J(QO.setLicense)),e.set($.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new J(QO.getRegistrationInfo)),e.set($.OPERATIONS_ENUM.RESTART,new J(Gq.restart)),e.set($.OPERATIONS_ENUM.RESTART_SERVICE,new J(Rs,Gq.restartService)),e.set($.OPERATIONS_ENUM.CATCHUP,new J(Kue)),e.set($.OPERATIONS_ENUM.SYSTEM_INFORMATION,new J(vue.systemInformation)),e.set($.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new J(Rs,Wf.deleteAuditLogsBefore)),e.set($.OPERATIONS_ENUM.READ_AUDIT_LOG,new J(Oue)),e.set($.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new J($q.createTokens)),e.set($.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new J($q.refreshOperationToken)),e.set($.OPERATIONS_ENUM.LOGIN,new J(Vq.login)),e.set($.OPERATIONS_ENUM.LOGOUT,new J(Vq.logout)),e.set($.OPERATIONS_ENUM.GET_CONFIGURATION,new J(Kq.getConfiguration)),e.set($.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new J(Lt.customFunctionsStatus)),e.set($.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new J(Lt.getCustomFunctions)),e.set($.OPERATIONS_ENUM.GET_COMPONENT_FILE,new J(Lt.getComponentFile)),e.set($.OPERATIONS_ENUM.GET_COMPONENTS,new J(Lt.getComponents)),e.set($.OPERATIONS_ENUM.SET_COMPONENT_FILE,new J(Lt.setComponentFile)),e.set($.OPERATIONS_ENUM.DROP_COMPONENT,new J(Lt.dropComponent)),e.set($.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new J(Lt.getCustomFunction)),e.set($.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new J(Lt.setCustomFunction)),e.set($.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new J(Lt.dropCustomFunction)),e.set($.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new J(Lt.addComponent)),e.set($.OPERATIONS_ENUM.ADD_COMPONENT,new J(Lt.addComponent)),e.set($.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new J(Lt.dropCustomFunctionProject)),e.set($.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new J(Lt.packageComponent)),e.set($.OPERATIONS_ENUM.PACKAGE_COMPONENT,new J(Lt.packageComponent)),e.set($.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new J(Lt.deployComponent)),e.set($.OPERATIONS_ENUM.DEPLOY_COMPONENT,new J(Lt.deployComponent)),e.set($.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new J(Yq.readTransactionLog)),e.set($.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new J(Rs,Yq.deleteTransactionLogsBefore)),e.set($.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new J(Wq.installModules)),e.set($.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new J(Wq.auditModules)),e.set($.OPERATIONS_ENUM.GET_BACKUP,new J(To.getBackup)),e.set($.OPERATIONS_ENUM.ADD_SSH_KEY,new J(Lt.addSSHKey)),e.set($.OPERATIONS_ENUM.UPDATE_SSH_KEY,new J(Lt.updateSSHKey)),e.set($.OPERATIONS_ENUM.DELETE_SSH_KEY,new J(Lt.deleteSSHKey)),e.set($.OPERATIONS_ENUM.LIST_SSH_KEYS,new J(Lt.listSSHKeys)),e.set($.OPERATIONS_ENUM.SET_SSH_KNOWN_HOSTS,new J(Lt.setSSHKnownHosts)),e.set($.OPERATIONS_ENUM.GET_SSH_KNOWN_HOSTS,new J(Lt.getSSHKnownHosts)),e}a(Yue,"initializeOperationFunctionMap")});var rN=N(s$=>{"use strict";var Te=require("fs-extra"),nN=require("fast-glob"),ye=require("path"),Wue=require("tar-fs"),jue=require("gunzip-maybe"),PDe=require("uuid").v4,sN=require("normalize-path"),An=uG(),Gt=W(),ft=M(),Ft=se(),ES=wt(),zue=te(),{PACKAGE_ROOT:Que}=M(),{handleHDBError:qt,hdb_errors:Jue}=_e(),{basename:Xue}=require("path"),Zue=SO(),r$=se(),ede=M(),{Readable:tde}=require("stream"),{isMainThread:rde}=require("worker_threads"),{HDB_ERROR_MSGS:rl,HTTP_STATUS_CODES:$t}=Jue,n$=dt(),{replicateOperation:si}=(us(),oe(ca)),{packageDirectory:nde}=(NG(),oe(OG)),t$=kf(),sde=ye.join(Que,"application-template"),LDe=ye.join(Ft.get(ft.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),"tmp"),ide=Ft.get(ft.CONFIG_PARAMS.ROOTPATH),Sa=ye.join(ide,"ssh"),go=ye.join(Sa,"known_hosts");function ode(){Gt.trace("getting custom api status");let e={};try{e={port:Ft.get(ft.CONFIG_PARAMS.HTTP_PORT),directory:Ft.get(ft.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw qt(new Error,rl.FUNCTION_STATUS,$t.INTERNAL_SERVER_ERROR,Gt.ERR,t)}return e}a(ode,"customFunctionsStatus");function ade(){Gt.trace("getting custom api endpoints");let e={},t=Ft.get(ft.CONFIG_PARAMS.COMPONENTSROOT);try{nN.sync(sN(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:nN.sync(sN(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:nN.sync(sN(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw qt(new Error,rl.GET_FUNCTIONS,$t.INTERNAL_SERVER_ERROR,Gt.ERR,r)}return e}a(ade,"getCustomFunctions");function cde(e){e.project&&(e.project=ye.parse(e.project).name),e.file&&(e.file=ye.parse(e.file).name);let t=An.getDropCustomFunctionValidator(e);if(t)throw qt(t,t.message,$t.BAD_REQUEST);Gt.trace("getting custom api endpoint file content");let r=Ft.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=ye.join(r,n,s,i+".js");try{return Te.readFileSync(o,{encoding:"utf8"})}catch(c){throw qt(new Error,rl.GET_FUNCTION,$t.INTERNAL_SERVER_ERROR,Gt.ERR,c)}}a(cde,"getCustomFunction");async function lde(e){e.project&&(e.project=ye.parse(e.project).name),e.file&&(e.file=ye.parse(e.file).name);let t=An.setCustomFunctionValidator(e);if(t)throw qt(t,t.message,$t.BAD_REQUEST);Gt.trace("setting custom function file content");let r=Ft.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{Te.outputFileSync(ye.join(r,n,s,i+".js"),o);let c=await si(e);return c.message=`Successfully updated custom function: ${i}.js`,c}catch(c){throw qt(new Error,rl.SET_FUNCTION,$t.INTERNAL_SERVER_ERROR,Gt.ERR,c)}}a(lde,"setCustomFunction");async function ude(e){e.project&&(e.project=ye.parse(e.project).name),e.file&&(e.file=ye.parse(e.file).name);let t=An.getDropCustomFunctionValidator(e);if(t)throw qt(t,t.message,$t.BAD_REQUEST);Gt.trace("dropping custom function file");let r=Ft.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{Te.unlinkSync(ye.join(r,n,s,i+".js"));let o=await si(e);return o.message=`Successfully deleted custom function: ${i}.js`,o}catch(o){throw qt(new Error,rl.DROP_FUNCTION,$t.INTERNAL_SERVER_ERROR,Gt.ERR,o)}}a(ude,"dropCustomFunction");async function dde(e){e.project&&(e.project=ye.parse(e.project).name);let t=An.addComponentValidator(e);if(t)throw qt(t,t.message,$t.BAD_REQUEST);Gt.trace("adding component");let r=Ft.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=ye.join(r,n);Te.mkdirSync(s,{recursive:!0}),Te.copySync(sde,s);let i=await si(e);return i.message=`Successfully added project: ${n}`,i}catch(s){throw qt(new Error,rl.ADD_FUNCTION,$t.INTERNAL_SERVER_ERROR,Gt.ERR,s)}}a(dde,"addComponent");async function _de(e){e.project&&(e.project=ye.parse(e.project).name);let t=An.dropCustomFunctionProjectValidator(e);if(t)throw qt(t,t.message,$t.BAD_REQUEST);Gt.trace("dropping custom function project");let r=Ft.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=Ft.get(ft.CONFIG_PARAMS.APPS);if(!zue.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 ES.updateConfigValue(ft.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=ye.join(r,n);Te.rmSync(i,{recursive:!0});let o=await si(e);return o.message=`Successfully deleted project: ${n}`,o}catch(i){throw qt(new Error,rl.DROP_FUNCTION_PROJECT,$t.INTERNAL_SERVER_ERROR,Gt.ERR,i)}}a(_de,"dropCustomFunctionProject");async function fde(e){e.project&&(e.project=ye.parse(e.project).name);let t=An.packageComponentValidator(e);if(t)throw qt(t,t.message,$t.BAD_REQUEST);let r=Ft.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;Gt.trace("packaging component",n);let s;try{s=await Te.realpath(ye.join(r,n))}catch(o){if(o.code!==ft.NODE_ERROR_CODES.ENOENT)throw o;try{s=await Te.realpath(ye.join(Ft.get(ft.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(c){if(c.code===ft.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}let i=(await nde(s,e)).toString("base64");return{project:n,payload:i}}a(fde,"packageComponent");async function Ede(e){e.project?e.project=ye.parse(e.project).name:e.package&&(e.project=hde(e.package));let t=An.deployComponentValidator(e);if(t)throw qt(t,t.message,$t.BAD_REQUEST);let r=Ft.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i,install_command:o}=e;if(Gt.trace("deploying component",n),!s&&!i)throw new Error("'payload' or 'package' must be provided");let c;if(s){c=ye.join(r,n),i="file:"+c,await Te.emptyDir(c);let T=tde.from(s instanceof Buffer?s:Buffer.from(s,"base64"));await new Promise((S,b)=>{T.pipe(jue()).pipe(Wue.extract(c,{finish:S})).on("error",b)});let m=await Te.readdir(c);m.length===1&&m[0]==="package"&&(await Te.copy(ye.join(c,"package"),c),await Te.remove(ye.join(c,"package")));let g=ye.join(c,"node_modules");o?await t$.runCommand(o,c):Te.existsSync(g)||await t$.installAllRootModules(!1,c)}else{await ES.addConfig(n,{package:i}),await Zue();let T=r$.get(ede.CONFIG_PARAMS.ROOTPATH);c=ye.join(T,"node_modules",n)}if(rde)return;let l=new Map;l.isWorker=!0;let u=(Jf(),oe(Qf)),d;u.setErrorReporter(T=>d=T);let _=Xue(c),E=u.component_errors.get(_);try{await u.loadComponent(c,l)}finally{u.component_errors.set(_,E)}if(d)throw d;Gt.info("Installed component");let f=e.restart==="rolling";e.restart=f?!1:e.restart;let h=await si(e);if(e.restart===!0)n$.restartWorkers("http"),h.message=`Successfully deployed: ${n}, restarting HarperDB`;else if(f){let m=await tN().executeJob({operation:"restart_service",service:"http",replicated:!0});h.restartJobId=m.job_id,h.message=`Successfully deployed: ${n}, restarting HarperDB`}else h.message=`Successfully deployed: ${n}`;return h}a(Ede,"deployComponent");function hde(e){if(e.startsWith("git+ssh://"))return ye.basename(e.split("#")[0].replace(/\.git$/,""));if(e.startsWith("http://")||e.startsWith("https://"))return ye.basename(new URL(e.replace(/\.git$/,"")).pathname);if(e.startsWith("file://"))try{let{name:t}=JSON.parse(Te.readFileSync(ye.join(e,"package.json"),"utf8"));return ye.basename(t)}catch{}return ye.basename(e)}a(hde,"getProjectNameFromPackage");async function pde(){let e=a(async(s,i)=>{try{let o=await Te.readdir(s,{withFileTypes:!0});for(let c of o){let l=c.name;if(l.startsWith(".")||l==="node_modules")continue;let u=ye.join(s,l);if(c.isDirectory()||c.isSymbolicLink()){let d={name:l,entries:[]};i.entries.push(d),await e(u,d)}else{let d=await Te.stat(u),_={name:ye.basename(l),mtime:d.mtime,size:d.size};i.entries.push(_)}}return i}catch(o){return Gt.warn("Error loading package",o),{error:o.toString(),entries:[]}}},"walkDir"),t=await e(Ft.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{name:Ft.get(ft.CONFIG_PARAMS.COMPONENTSROOT).split(ye.sep).slice(-1).pop(),entries:[]}),n=(Jf(),oe(Qf)).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(pde,"getComponents");async function mde(e){let t=An.getComponentFileValidator(e);if(t)throw qt(t,t.message,$t.BAD_REQUEST);let n=ES.getConfigObj()[e.project]||e.project==="harperdb"?ye.join(r$.get(ft.CONFIG_PARAMS.ROOTPATH),"node_modules"):Ft.get(ft.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await Te.stat(ye.join(n,e.project,e.file));return{message:await Te.readFile(ye.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===ft.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${ye.join(e.project,e.file)}'`):i}}a(mde,"getComponentFile");async function Sde(e){let t=An.setComponentFileValidator(e);if(t)throw qt(t,t.message,$t.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=ye.join(Ft.get(ft.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);e.payload!==void 0?(await Te.ensureFile(n),await Te.outputFile(n,e.payload,r)):await Te.ensureDir(n);let s=await si(e);return s.message="Successfully set component: "+e.file,s}a(Sde,"setComponentFile");async function Tde(e){let t=An.dropComponentFileValidator(e);if(t)throw qt(t,t.message,$t.BAD_REQUEST);let{project:r,file:n}=e,s=e.file?ye.join(r,n):r,i=ye.join(Ft.get(ft.CONFIG_PARAMS.COMPONENTSROOT),s),o=ye.join(Ft.get(ft.CONFIG_PARAMS.ROOTPATH),"node_modules",r);await Te.pathExists(o)&&await Te.unlink(o),await Te.pathExists(i)&&await Te.remove(i);let c=ye.join(Ft.get(ft.CONFIG_PARAMS.ROOTPATH),"package.json");if(await Te.pathExists(c)){let u=JSON.parse(await Te.readFile(c,"utf8"));u?.dependencies?.[r]&&delete u.dependencies[r],await Te.writeFile(c,JSON.stringify(u,null,2),"utf8")}ES.deleteConfigFromFile([r]);let l=await si(e);return e.restart===!0?(n$.restartWorkers("http"),l.message=`Successfully dropped: ${s}, restarting HarperDB`):l.message=`Successfully dropped: ${s}`,l}a(Tde,"dropComponent");async function gde(e){let t=An.addSSHKeyValidator(e);if(t)throw qt(t,t.message,$t.BAD_REQUEST);let{name:r,key:n,host:s,hostname:i,known_hosts:o}=e;Gt.trace("adding ssh key",r);let c=ye.join(Sa,r+".key"),l=ye.join(Sa,"config");if(await Te.pathExists(c))throw new Error("Key already exists. Use update_ssh_key or delete_ssh_key and then add_ssh_key");await Te.outputFile(c,n),await Te.chmod(c,"0600");let u=`#${r}
24
24
  Host ${s}
25
25
  HostName ${i}
26
26
  User git
27
27
  IdentityFile ${c}
28
- IdentitiesOnly yes`;await ge.pathExists(l)?await ge.appendFile(l,`
29
- `+u):await ge.outputFile(l,u);let d="";if(await ge.pathExists(go)||(await ge.writeFile(go,""),await ge.chmod(go,"0600")),i=="github.com"&&!(await ge.readFile(go,"utf8")).includes("github.com"))try{let T=(await(await fetch("https://api.github.com/meta")).json()).ssh_keys;for(let m of T)ge.appendFile(go,"github.com "+m+`
30
- `)}catch{d=". Unable to get known hosts from github.com. Set your known hosts manually using set_ssh_known_hosts."}o&&await ge.appendFile(go,o);let _=await ti(e);return _.message=`Added ssh key: ${r}${d}`,_}a(Rle,"addSSHKey");async function Ale(e){let t=Rn.updateSSHKeyValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);let{name:r,key:n}=e;kt.trace("updating ssh key",r);let s=Ce.join(Sa,r+".key");if(!await ge.pathExists(s))throw new Error("Key does not exist. Use add_ssh_key");await ge.outputFile(s,n);let i=await ti(e);return i.message=`Updated ssh key: ${r}`,i}a(Ale,"updateSSHKey");async function yle(e){let t=Rn.deleteSSHKeyValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);let{name:r}=e;kt.trace("deleting ssh key",r);let n=Ce.join(Sa,r+".key"),s=Ce.join(Sa,"config");if(!await ge.pathExists(n))throw new Error("Key does not exist");let i=await ge.readFile(s,"utf8"),o=new RegExp(`#${r}[\\S\\s]*?IdentitiesOnly yes`,"g");i=i.replace(o,""),await ge.outputFile(s,i),ge.removeSync(n);let c=await ti(e);return c.message=`Deleted ssh key: ${r}`,c}a(yle,"deleteSSHKey");async function ble(e){let t=[];return await ge.pathExists(Sa)&&(await ge.readdir(Sa)).forEach(r=>{r!="known_hosts"&&r!="config"&&t.push({name:r.split(".")[0]})}),t}a(ble,"listSSHKeys");async function Ole(e){let t=Rn.setSSHKnownHostsValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);let{known_hosts:r}=e;await ge.outputFile(go,r);let n=await ti(e);return n.message="Known hosts successfully set",n}a(Ole,"setSSHKnownHosts");async function Nle(e){return await ge.pathExists(go)?{known_hosts:await ge.readFile(go,"utf8")}:{known_hosts:null}}a(Nle,"getSSHKnownHosts");Object.assign(NG,{customFunctionsStatus:cle,getCustomFunctions:lle,getCustomFunction:ule,setCustomFunction:dle,dropCustomFunction:_le,addComponent:fle,dropCustomFunctionProject:Ele,packageComponent:hle,deployComponent:ple,getComponents:mle,getComponentFile:Sle,setComponentFile:Tle,dropComponent:gle,addSSHKey:Rle,updateSSHKey:Ale,deleteSSHKey:yle,listSSHKeys:ble,setSSHKnownHosts:Ole,getSSHKnownHosts:Nle})});var yO=N((VCe,wG)=>{"use strict";var Rs=require("joi"),IG=Tt();wG.exports={readTransactionLogValidator:Ile,deleteTransactionLogsBeforeValidator:wle};function Ile(e){let t=Rs.object({schema:Rs.string(),database:Rs.string(),table:Rs.string().required(),from:Rs.date().timestamp(),to:Rs.date().timestamp(),limit:Rs.number().min(1)});return IG.validateBySchema(e,t)}a(Ile,"readTransactionLogValidator");function wle(e){let t=Rs.object({schema:Rs.string(),database:Rs.string(),table:Rs.string().required(),timestamp:Rs.date().timestamp().required()});return IG.validateBySchema(e,t)}a(wle,"deleteTransactionLogsBeforeValidator")});var jm=N((YCe,UG)=>{"use strict";var bO=M(),Vf=mr(),CG=te(),DG=se(),PG=to(),LG=W(),{handleHDBError:Ym,hdb_errors:Cle}=_e(),{HTTP_STATUS_CODES:Wm}=Cle,{readTransactionLogValidator:Dle,deleteTransactionLogsBeforeValidator:Ple}=yO(),MG=Bn(),Lle="Logs successfully deleted from transaction log.",Mle="All logs successfully deleted from transaction log.";UG.exports={readTransactionLog:Ule,deleteTransactionLogsBefore:Ble};async function Ule(e){let t=Dle(e);if(t)throw Ym(t,t.message,Wm.BAD_REQUEST,void 0,void 0,!0);e.database=e.database??e.schema??"data";let r=CG.checkSchemaTableExist(e.database,e.table);if(r)throw Ym(new Error,r,Wm.NOT_FOUND,void 0,void 0,!0);return DG.get(bO.CONFIG_PARAMS.CLUSTERING_ENABLED)?await vle(e):(LG.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)),MG.readAuditLog(e))}a(Ule,"readTransactionLog");async function*vle(e){let t=PG.createNatsTableStreamName(e.database,e.table),r=await Vf.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===bO.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(vle,"readTransactionLogNats");async function Ble(e){let t=Ple(e);if(t)throw Ym(t,t.message,Wm.BAD_REQUEST,void 0,void 0,!0);if(e.database=e.database??e.schema??"data",!DG.get(bO.CONFIG_PARAMS.CLUSTERING_ENABLED))return LG.info("Delete transaction logs called for Plexus"),MG.deleteAuditLogsBefore(e);let{database:r,table:n,timestamp:s}=e,i=CG.checkSchemaTableExist(r,n);if(i)throw Ym(new Error,i,Wm.NOT_FOUND,void 0,void 0,!0);let o=PG.createNatsTableStreamName(r,n),{jsm:c}=await Vf.getNATSReferences(),l=await Vf.getStreamInfo(o),u=new Date(l.state.first_ts).getTime();if(s<=u)return`No transactions exist before: ${s}`;let d=Lle,_,E=new Date(l.state.last_ts).getTime();return s>E?(_=l.state.last_seq+1,d=Mle):_=(await Vf.viewStream(o,parseInt(s),1))[0].nats_sequence,await Vf.purgeTableStream(r,n,{seq:_}),d}a(Ble,"deleteTransactionLogsBefore")});var BG=N((jCe,vG)=>{"use strict";var OO=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}};vG.exports=OO});var xG=N((QCe,HG)=>{"use strict";var NO=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};HG.exports=NO});var wO=N((XCe,FG)=>{"use strict";var kG=BG(),Hle=xG(),{HDB_ERROR_MSGS:xle}=Dn(),IO=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=xle.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 kG(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let l=new Hle(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 kG(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}};FG.exports=IO});var Xm=N((rDe,nq)=>{"use strict";var CO=un(),zm=Vr(),As=em(),Wf=ro(),DO=uc(),kle=zy(),Fle=KH(),jf=xn(),Qm=lf(),gr=W(),Gle=ob(),qle=pf(),$le=Lb(),Vle=Rf(),Kle=vb(),Yle=Bb(),Wle=mm(),jle=Fb(),PO=Tm(),Ro=te(),zle=Fk(),LO=Wb(),$G=xu(),Zr=M(),VG=YF(),Qle=Ou(),KG=lu(),YG=(xm(),oe(Hf)),WG=wt(),or=AO(),Jle=require("alasql"),jG=jm(),zG=kf(),Yu=Xs(),QG=(Hc(),oe(Bc)),JG=wO(),{handleHDBError:An,hdb_errors:XG}=_e(),{addNodeBack:eDe,removeNodeBack:tDe}=(Hc(),oe(Bc)),{HDB_ERROR_MSGS:Mr,HTTP_STATUS_CODES:Kf}=XG,z=new Map,ZG="delete",Ta="insert",Ao="read",Qc="update",Yf="describe",GG=Wf.describeSchema.name,qG=Wf.describeTable.name,eq={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},Xle={insert:!0,delete:!0,deleteRecord:!0,update:!0,updateData:!0,upsert:!0,upsertData:!0},Zle="catchup",eue="handleGetJob",tue="handleGetJobsByStartDate",Jm={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},rue=[As.createTable.name,As.createAttribute.name,As.dropTable.name,As.dropAttribute.name],tq={EXPORT_TO_S3:"export_to_s3",EXPORT_LOCAL:"export_local"},Z=class{static{a(this,"permission")}constructor(t,r){this.requires_su=t,this.perms=r}};z.set(CO.insert.name,new Z(!1,[Ta]));z.set(CO.update.name,new Z(!1,[Qc]));z.set(CO.upsert.name,new Z(!1,[Ta,Qc]));z.set(zm.searchByConditions.name,new Z(!1,[Ao]));z.set(zm.searchByHash.name,new Z(!1,[Ao]));z.set(zm.searchByValue.name,new Z(!1,[Ao]));z.set(zm.search.name,new Z(!1,[Ao]));z.set(As.createSchema.name,new Z(!0,[]));z.set(As.createTable.name,new Z(!0,[]));z.set(As.createAttribute.name,new Z(!1,[Ta]));z.set(As.dropSchema.name,new Z(!0,[]));z.set(As.dropTable.name,new Z(!0,[]));z.set(As.dropAttribute.name,new Z(!0,[]));z.set(Wf.describeSchema.name,new Z(!1,[Ao]));z.set(Wf.describeTable.name,new Z(!1,[Ao]));z.set(DO.deleteRecord.name,new Z(!1,[ZG]));z.set(jf.addUser.name,new Z(!0,[]));z.set(jf.alterUser.name,new Z(!0,[]));z.set(jf.dropUser.name,new Z(!0,[]));z.set(jf.listUsersExternal.name,new Z(!0,[]));z.set(Qm.listRoles.name,new Z(!0,[]));z.set(Qm.addRole.name,new Z(!0,[]));z.set(Qm.alterRole.name,new Z(!0,[]));z.set(Qm.dropRole.name,new Z(!0,[]));z.set(Gle.name,new Z(!0,[]));z.set(qle.name,new Z(!0,[]));z.set($le.name,new Z(!0,[]));z.set(Vle.name,new Z(!0,[]));z.set(Kle.name,new Z(!0,[]));z.set(Yle.name,new Z(!0,[]));z.set(PO.setRoutes.name,new Z(!0,[]));z.set(PO.getRoutes.name,new Z(!0,[]));z.set(PO.deleteRoutes.name,new Z(!0,[]));z.set(WG.setConfiguration.name,new Z(!0,[]));z.set(Wle.clusterStatus.name,new Z(!0,[]));z.set(jle.name,new Z(!0,[]));z.set(LO.getFingerprint.name,new Z(!0,[]));z.set(LO.setLicense.name,new Z(!0,[]));z.set(DO.deleteFilesBefore.name,new Z(!0,[]));z.set(DO.deleteAuditLogsBefore.name,new Z(!0,[]));z.set($G.restart.name,new Z(!0,[]));z.set($G.restartService.name,new Z(!0,[]));z.set(kle.name,new Z(!0,[]));z.set(Fle.name,new Z(!0,[Ao]));z.set(Qle.systemInformation.name,new Z(!0,[]));z.set(WG.getConfiguration.name,new Z(!0,[]));z.set(jG.readTransactionLog.name,new Z(!0,[]));z.set(jG.deleteTransactionLogsBefore.name,new Z(!0,[]));z.set(zG.installModules.name,new Z(!0,[]));z.set(zG.auditModules.name,new Z(!0,[]));z.set(Yu.createCsr.name,new Z(!0,[]));z.set(Yu.signCertificate.name,new Z(!0,[]));z.set(Yu.listCertificates.name,new Z(!0,[]));z.set(Yu.addCertificate.name,new Z(!0,[]));z.set(Yu.removeCertificate.name,new Z(!0,[]));z.set(Yu.getKey.name,new Z(!0,[]));z.set(QG.addNodeBack.name,new Z(!0,[]));z.set(QG.removeNodeBack.name,new Z(!0,[]));z.set(KG.createTokens.name,new Z(!1,[]));z.set(KG.refreshOperationToken.name,new Z(!1,[]));z.set(YG.login.name,new Z(!1,[]));z.set(YG.logout.name,new Z(!1,[]));z.set(or.customFunctionsStatus.name,new Z(!0,[]));z.set(or.getCustomFunctions.name,new Z(!0,[]));z.set(or.getComponents.name,new Z(!0,[]));z.set(or.getComponentFile.name,new Z(!0,[]));z.set(or.setComponentFile.name,new Z(!0,[]));z.set(or.dropComponent.name,new Z(!0,[]));z.set(or.getCustomFunction.name,new Z(!0,[]));z.set(or.setCustomFunction.name,new Z(!0,[]));z.set(or.dropCustomFunction.name,new Z(!0,[]));z.set(or.addComponent.name,new Z(!0,[]));z.set(or.dropCustomFunctionProject.name,new Z(!0,[]));z.set(or.packageComponent.name,new Z(!0,[]));z.set(or.deployComponent.name,new Z(!0,[]));z.set(or.addSSHKey.name,new Z(!0,[]));z.set(or.updateSSHKey.name,new Z(!0,[]));z.set(or.deleteSSHKey.name,new Z(!0,[]));z.set(or.listSSHKeys.name,new Z(!0,[]));z.set(or.setSSHKnownHosts.name,new Z(!0,[]));z.set(or.getSSHKnownHosts.name,new Z(!0,[]));z.set(LO.getRegistrationInfo.name,new Z(!1,[]));z.set(jf.userInfo.name,new Z(!1,[]));z.set(Wf.describeAll.name,new Z(!1,[]));z.set(eue,new Z(!1,[]));z.set(tue,new Z(!0,[]));z.set(Zle,new Z(!0,[]));z.set(Jm.CSV_DATA_LOAD,new Z(!1,[Ta,Qc]));z.set(Jm.CSV_URL_LOAD,new Z(!1,[Ta,Qc]));z.set(Jm.CSV_FILE_LOAD,new Z(!1,[Ta,Qc]));z.set(Jm.IMPORT_FROM_S3,new Z(!1,[Ta,Qc]));z.set(tq.EXPORT_TO_S3,new Z(!0,[]));z.set(tq.EXPORT_LOCAL,new Z(!0,[]));z.set(Zr.VALID_SQL_OPS_ENUM.DELETE,new Z(!1,[ZG]));z.set(Zr.VALID_SQL_OPS_ENUM.SELECT,new Z(!1,[Ao]));z.set(Zr.VALID_SQL_OPS_ENUM.INSERT,new Z(!1,[Ta]));z.set(Zr.VALID_SQL_OPS_ENUM.UPDATE,new Z(!1,[Qc]));nq.exports={verifyPerms:sue,verifyPermsAst:nue,verifyBulkLoadAttributePerms:oue};function nue(e,t,r){if(Ro.isEmptyOrZeroLength(e))throw gr.info("verify_perms_ast has an empty user parameter"),An(new Error);if(Ro.isEmptyOrZeroLength(t))throw gr.info("verify_perms_ast has an empty user parameter"),An(new Error);if(Ro.isEmptyOrZeroLength(r))throw gr.info("verify_perms_ast has a null operation parameter"),An(new Error);try{let n=new JG,s=new zle(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw gr.info("No schemas defined in verifyPermsAst(), will not continue."),An(new Error);let c=!!t.role.permission.super_user,l=i.includes("system");if(l&&eq[r])throw An(new Error,Mr.DROP_SYSTEM,Kf.FORBIDDEN);if(c&&!l)return null;let u=VG.getRolePermissions(t.role);t.role.permission=u,!c&&e instanceof Jle.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(u));for(let _=0;_<i.length;_++){let E=s.getTablesBySchemaName(i[_]);E&&o.set(i[_],E)}let d=rq(t,r,o,n);return d||(o.forEach((_,E)=>{for(let f=0;f<_.length;f++){let h=s.getAttributesBySchemaTableName(E,_[f]),T=UO(t.role.permission,E,_[f]);MO(h,T,r,_[f],E,n)}}),n.getPermsResponse())}catch(n){throw An(n)}}a(nue,"verifyPermsAst");function sue(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw gr.info("null required parameter in verifyPerms"),An(new Error,Mr.DEFAULT_INVALID_REQUEST,Kf.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 JG;if(Ro.isEmptyOrZeroLength(e.hdb_user?.role)||Ro.isEmptyOrZeroLength(e.hdb_user?.role?.permission))return gr.info(`User ${e.hdb_user?.username} has no role or permissions. Please assign the user a valid role.`),c.handleUnauthorizedItem(Mr.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,d=o.has(Zr.SYSTEM_SCHEMA_NAME)||s===Zr.SYSTEM_SCHEMA_NAME;if(l&&d&&Xle[e.operation]&&(i===Zr.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME||i===Zr.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||i===Zr.SYSTEM_TABLE_NAMES.USER_TABLE_NAME))return null;if(d&&eq[r])throw An(new Error,Mr.DROP_SYSTEM,Kf.FORBIDDEN);if(l&&!d||u===!0&&(r===As.createSchema.name||r===As.dropSchema.name))return null;if(rue.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 _=VG.getRolePermissions(e.hdb_user?.role);if(e.hdb_user?.role&&(e.hdb_user.role.permission=_),r===GG||r===qG){if(s===Zr.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(Mr.SCHEMA_PERM_ERROR(s));if(!_.super_user){if(r===GG&&(!_[s]||!_[s][Yf]))return c.handleInvalidItem(Mr.SCHEMA_NOT_FOUND(s));if(r===qG&&(!_[s]||!_[s].tables[i]||!_[s].tables[i][Yf]))return c.handleInvalidItem(Mr.TABLE_NOT_FOUND(s,i))}}let E=rq(e.hdb_user,r,o,c,n);if(E)return E;if(z.get(r)&&z.get(r).perms.length===0)return null;if(!l&&e.get_attributes&&Zr.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let T=[],m=_[s].tables[i];m[Zr.PERMS_CRUD_ENUM.READ]&&(m.attribute_permissions.length>0?m.attribute_permissions.filter(S=>S[Zr.PERMS_CRUD_ENUM.READ]).forEach(S=>{T.push(S.attribute_name)}):T=global.hdb_schema[s][i].attributes.map(g=>g.attribute),e.get_attributes=T)}let f=iue(e),h=UO(e.hdb_user?.role?.permission,s,i);return MO(f,h,r,i,s,c,n),c.getPermsResponse()}a(sue,"verifyPerms");function rq(e,t,r,n,s){if(Ro.arrayHasEmptyValues([e,t,r]))throw gr.info("hasPermissions has an invalid parameter"),An(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 gr.info(`operation ${t} not found.`),An(new Error,Mr.OP_NOT_FOUND(t),Kf.BAD_REQUEST);if(z.get(t)&&z.get(t).requires_su)return gr.info(`operation ${t} requires SU permissions.`),n.handleUnauthorizedItem(Mr.OP_IS_SU_ONLY(t));let c=r.keys();for(let l of c){try{if(l&&!o[l]||o[l][Yf]===!1){n.addInvalidItem(Mr.SCHEMA_NOT_FOUND(l));continue}}catch{n.addInvalidItem(Mr.SCHEMA_NOT_FOUND(l));continue}let u=r.get(l);for(let d of u){let _=o[l].tables[d];if(!_||_[Yf]===!1)n.addInvalidItem(Mr.TABLE_NOT_FOUND(l,d));else try{let E=[],f=z.get(t).perms;!Ro.isEmpty(s)&&f.includes(s)&&(f=[s]);for(let h=0;h<f.length;h++){let T=f[h],m=_[T];(m==null||m===!1)&&(gr.info(`Required ${T} permission not found for ${t} ${s?`${s} `:""}operation in role ${e.role.id}`),E.push(T))}E.length>0&&n.addUnauthorizedTable(l,d,E)}catch(E){let f=Mr.UNKNOWN_OP_AUTH_ERROR(t,l,d);throw gr.error(f),gr.error(E),An(XG.CHECK_LOGS_WRAPPER(f))}}}return r.size<2?n.getPermsResponse():null}a(rq,"hasPermissions");function MO(e,t,r,n,s,i,o){if(!e||!t)throw gr.info("no attributes specified in checkAttributePerms."),An(new Error);let c=z.get(r).perms;if(!c||c==="")throw gr.info(`no permissions found for ${r} in checkAttributePerms().`),An(new Error);if(Ro.isEmptyOrZeroLength(t))return gr.info("No role permissions set (this is OK)."),null;o&&c.includes(o)&&(c=[o]);let l={};for(let d of e){let _=t.get(d);if(_){if(_[Yf]===!1){i.addInvalidItem(Mr.ATTR_NOT_FOUND(s,n,d),s,n);continue}if(c)for(let E of c){if(Zr.TIME_STAMP_NAMES.includes(_.attribute_name)&&E!==Ao)throw An(new Error,Mr.SYSTEM_TIMESTAMP_PERMS_ERR,Kf.FORBIDDEN);_[E]===!1&&(l[_.attribute_name]?l[_.attribute_name].push(E):l[_.attribute_name]=[E])}}else i.addInvalidItem(Mr.ATTR_NOT_FOUND(s,n,d),s,n)}let u=Object.keys(l);u.length>0&&i.addUnauthorizedAttributes(u,s,n,l)}a(MO,"checkAttributePerms");function iue(e){let t=new Set;try{if(e.action)return t;if(e.operation===Zr.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){gr.info(r)}return t}a(iue,"getRecordAttributes");function UO(e,t,r){let n=new Map;if(Ro.isEmpty(e))return gr.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{gr.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(UO,"getAttributePermissions");function oue(e,t,r,n,s,i,o){let c=new Set(i),l=UO(e,n,s);MO(c,l,t,s,n,o,r)}a(oue,"verifyBulkLoadAttributePerms")});var eS=N((sDe,cq)=>{"use strict";cq.exports={evaluateSQL:Tue,processAST:aq,convertSQLToAST:oq,checkASTPermissions:iq};var aue=un(),sq=require("util"),cue=sq.callbackify(aue.insert),lue=Vr().search,uue=Zv().update,due=sq.callbackify(uue),_ue=t0().convertDelete,ga=require("alasql"),fue=Xm(),Zm=W(),Eue=Ep(),hue=te(),zf=M(),{hdb_errors:pue,handleHDBError:vO}=_e(),{HTTP_STATUS_CODES:BO}=pue;Eue(ga);var mue=403,Sue="There was a problem performing this insert. Please check the logs and try again.",HO=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function Tue(e,t){let r=e.parsed_sql_object;if(!r){r=oq(e.sql);let n,s=r.ast.statements[0];if(s instanceof ga.yy.Insert?n=s.into.databaseid:s instanceof ga.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof ga.yy.Update||s instanceof ga.yy.Delete?n=s.table.databaseid:Zm.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof ga.yy.Select)&&hue.isEmptyOrZeroLength(n))return t("No schema specified",null)}aq(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(Tue,"evaluateSQL");function iq(e,t){let r;try{r=fue.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(iq,"checkASTPermissions");function oq(e){let t=new HO;if(!e)throw vO(new Error,"The 'sql' parameter is missing from the request body",BO.BAD_REQUEST);try{let r=e.trim(),n=ga.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
31
- `);throw n[1]?vO(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,BO.BAD_REQUEST):vO(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",BO.BAD_REQUEST)}return t}a(oq,"convertSQLToAST");function aq(e,t,r){try{let n=gue;if(!e.bypass_auth&&!t.permissions_checked){let i=iq(e,t);if(i&&i.length>0)return r(mue,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case zf.VALID_SQL_OPS_ENUM.SELECT:n=lue,s=t.ast.statements[0];break;case zf.VALID_SQL_OPS_ENUM.INSERT:n=Rue;break;case zf.VALID_SQL_OPS_ENUM.UPDATE:n=due;break;case zf.VALID_SQL_OPS_ENUM.DELETE:n=_ue;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(aq,"processAST");function gue(e,t){Zm.info(e),t("unknown sql statement")}a(gue,"nullFunction");function Rue({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=Aue(i,e.values)}catch(o){return r(o)}cue(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(l){Zm.error(`Error delete new_attributes from insert response: ${l}`)}r(null,c)})}a(Rue,"convertInsert");function Aue(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]]=ga.compile(`SELECT ${s.toString()} AS [${zf.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw Zm.error(r),new Error(Sue)}}a(Aue,"createDataObjects")});var xO=N((oDe,uq)=>{"use strict";var{S3:yue,GetObjectCommand:bue}=require("@aws-sdk/client-s3");uq.exports={getFileStreamFromS3:Oue,getS3AuthObj:lq};async function Oue(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await lq(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new bue(r))).Body}a(Oue,"getFileStreamFromS3");function lq(e,t,r){return new yue({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(lq,"getS3AuthObj")});var tS=N((cDe,Tq)=>{"use strict";var FO=Vr(),Nue=eS(),Iue=xO(),{AsyncParser:wue,Transform:Cue}=require("json2csv"),Jf=require("stream"),Wn=te(),kO=require("fs-extra"),Due=require("path"),ys=W(),{promisify:fq}=require("util"),Qf=te(),{handleHDBError:ar,hdb_errors:Pue}=_e(),{HDB_ERROR_MSGS:yn,HTTP_STATUS_CODES:cr}=Pue,{streamAsJSON:Lue}=(Ug(),oe(MD)),{Upload:Mue}=require("@aws-sdk/lib-storage"),dq=["search_by_value","search_by_hash","sql","search_by_conditions"],_q=["json","csv"],Eq="json",hq="csv",Uue="Successfully exported JSON locally.",vue="Successfully exported CSV locally.",Bue=1e3,Hue=FO.searchByHash,xue=FO.searchByValue,kue=fq(Nue.evaluateSQL),Fue=fq(Jf.finished);Tq.exports={export_to_s3:Vue,export_local:Gue,toCsvStream:pq};async function Gue(e){ys.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=mq(e);if(!Wn.isEmpty(t))throw ys.error(t),ar(new Error,t,cr.BAD_REQUEST,void 0,void 0,!0);if(Wn.isEmpty(e.path))throw ys.error(yn.MISSING_VALUE("path")),ar(new Error,yn.MISSING_VALUE("path"),cr.BAD_REQUEST,void 0,void 0,!0);let r=(Wn.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(Due.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=Wn.buildFolderPath(e.path,r);await que(e.path);let s=await Sq(e);return await $ue(n,e.format,s)}a(Gue,"export_local");async function que(e){if(ys.trace("in confirmPath"),Wn.isEmptyOrZeroLength(e))throw ar(new Error,`Invalid path: ${e}`,cr.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await kO.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,ys.error(n),ar(new Error,n,cr.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 ys.error(r),ar(new Error,r,cr.BAD_REQUEST,void 0,void 0,!0)}return!0}a(que,"confirmPath");async function $ue(e,t,r){if(ys.trace("in saveToLocal"),Qf.isEmptyOrZeroLength(e))throw ar(new Error,yn.INVALID_VALUE("file_path"),cr.BAD_REQUEST,void 0,void 0,!0);if(Qf.isEmptyOrZeroLength(t))throw ar(new Error,yn.INVALID_VALUE("Source format"),cr.BAD_REQUEST,void 0,void 0,!0);if(Qf.isEmpty(r))throw ar(new Error,yn.NOT_FOUND("Data"),cr.BAD_REQUEST,void 0,void 0,!0);if(t===Eq){let n=kO.createWriteStream(e);return Lue(r).pipe(n),await Fue(n),{message:Uue,path:e}}else if(t===hq){let n=kO.createWriteStream(e),s=Jf.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(d=>({label:d,value:d})));let c={objectMode:!0};return await new wue(i,c).fromInput(s).toOutput(n).promise(!1),{message:vue,path:e}}throw ar(new Error,yn.INVALID_VALUE("format"),cr.BAD_REQUEST)}a($ue,"saveToLocal");async function Vue(e){if(!e.s3||Object.keys(e.s3).length===0)throw ar(new Error,yn.MISSING_VALUE("S3 object"),cr.BAD_REQUEST);if(Wn.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw ar(new Error,yn.MISSING_VALUE("aws_access_key_id"),cr.BAD_REQUEST);if(Wn.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw ar(new Error,yn.MISSING_VALUE("aws_secret_access_key"),cr.BAD_REQUEST);if(Wn.isEmptyOrZeroLength(e.s3.bucket))throw ar(new Error,yn.MISSING_VALUE("bucket"),cr.BAD_REQUEST);if(Wn.isEmptyOrZeroLength(e.s3.key))throw ar(new Error,yn.MISSING_VALUE("key"),cr.BAD_REQUEST);if(Wn.isEmptyOrZeroLength(e.s3.region))throw ar(new Error,yn.MISSING_VALUE("region"),cr.BAD_REQUEST);let t=mq(e);if(!Wn.isEmpty(t))throw ar(new Error,t,cr.BAD_REQUEST);ys.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await Sq(e)}catch(l){throw ys.error(l),l}let n,s=await Iue.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new Jf.PassThrough;if(e.format===hq){i=e.s3.key+".csv";let l=pq(r,r.getColumns?.());l.on("error",u=>{throw u}),l.pipe(o)}else if(e.format===Eq){i=e.s3.key+".json";let l=new Jf.Readable;l.pipe(o),l.on("error",_=>{throw _}),l.push("[");let u=r.length,d="";for(let[_,E]of r.entries()){let f=_===u-1?JSON.stringify(E):JSON.stringify(E)+",";d+=f,_!==0&&_%Bue===0&&(l.push(d),d="")}d.length!==0&&l.push(d),l.push("]"),l.push(null)}else throw ar(new Error,yn.INVALID_VALUE("format"),cr.BAD_REQUEST);return new Mue({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(Vue,"export_to_s3");function pq(e,t){let r=Jf.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 Cue(n,s);return r.pipe(i)}a(pq,"toCsvStream");function mq(e){if(ys.trace("in exportCoreValidation"),Wn.isEmpty(e.format))return"format missing";if(_q.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${_q.join(", ")}`;let t=e.search_operation.operation;if(Wn.isEmpty(t))return"search_operation.operation missing";if(dq.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${dq.join(", ")}`}a(mq,"exportCoreValidation");async function Sq(e){ys.trace("in getRecords");let t,r;if(Qf.isEmpty(e.search_operation)||Qf.isEmptyOrZeroLength(e.search_operation.operation))throw ar(new Error,yn.INVALID_VALUE("Search operation"),cr.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=xue;break;case"search_by_hash":t=Hue;break;case"search_by_conditions":t=FO.searchByConditions;break;case"sql":t=kue;break;default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,ys.error(r),ar(new Error,r,cr.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(Sq,"getRecords")});var Iq={};je(Iq,{contentTypes:()=>KO,findBestSerializer:()=>sS,getDeserializer:()=>bo,registerContentHandlers:()=>YO,serialize:()=>eE,serializeMessage:()=>Yc});function Kue(e){try{return e?.[0]===123?VO(e):e}catch{return e}}function YO(e){e.register(Wue,{serializers:[{regex:/^application\/json$/,serializer:Xd},{regex:/^application\/cbor$/,serializer:a(function(t){return new Jc.EncoderStream(Zf).end(t)},"serializer")},{regex:/^application\/(x-)?msgpack$/,serializer:a(function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?nS.Readable.from((0,Li.encodeIter)(t,Zf)):(0,Li.pack)(t)},"serializer")},{regex:/^text\/csv$/,serializer:a(function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),(0,rS.toCsvStream)(t)},"serializer")}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Li.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Jc.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function sS(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,...d]=l.split(/\s*;\s*/),_=1,E={q:1};for(let h of d){let T=h.indexOf("=");E[h.substring(0,T)]=h.substring(T+1)}_=+E.q;let f=en.get(u);if(f){let h=(f.q||1)*_;h>s&&(n=f,i=f.type||u,s=h,o=E)}}if(!n){if(r)throw new Aq.ClientError("No supported content types found in Accept header, supported types include: "+Array.from(en.keys()).join(", "),406);n=en.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function eE(e,t,r){let n=Rq&&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)r.headers.set("Content-Type","application/octet-stream"),r.headers.set("Vary","Accept-Encoding"),s=e;else{let i=sS(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}),$O.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,yo.createBrotliCompress)({params:{[yo.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?yo.constants.BROTLI_MODE_TEXT:yo.constants.BROTLI_MODE_GENERIC,[yo.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>Rq?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,yo.brotliCompress)(s,(c,l)=>{c?o(c):i(l)}))):s}function Yc(e,t){if(e?.contentType!=null&&e.data!=null)return e.data;if(!t)return Xf(e);let r=t.serialize;if(r)return r(e);let n=sS(t);return r=t.serialize=n.serializer.serialize,r(e)}function jue(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 Que(e){return zue.includes(e)}function Jue(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 bo(e="",t=!1){let r=Jue(e),n=r.type&&en.get(r.type)?.deserialize||Xue(r);return t?s=>jue(s).then(n):n}function Xue(e){return e.type.startsWith("text/")?(e.parameters?.charset&&!Que(e.parameters.charset)&&$O.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 VO(t)}catch{}return{contentType:e.type||"application/octet-stream",data:t}}}function Zue(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)}}}}}var rS,Li,Jc,yo,Aq,nS,yq,GO,qO,bq,$O,Oq,Xf,VO,Zf,en,KO,gq,Nq,Yue,Wue,Rq,zue,Wc=Oe(()=>{Ug();rS=L(tS()),Li=require("msgpackr"),Jc=require("cbor-x"),yo=require("zlib"),Aq=L(_e()),nS=require("stream");qr();yq=L(fi()),GO=L(se()),qO=L(M()),bq=L(require("yaml")),$O=L(bc()),Oq=GO.default.get(qO.CONFIG_PARAMS.SERIALIZATION_BIGINT)!==!1,Xf=Oq?Za:JSON.stringify,VO=Oq?Mg:JSON.parse,Zf={useRecords:!1,useToJSON:!0},en=new Map,KO=en;it.contentTypes=KO;(0,yq._assignPackageExport)("contentTypes",KO);en.set("application/json",{serializeStream:Xd,serialize:Xf,deserialize(e){return VO(e)},q:.8});gq=new Jc.Encoder(Zf);en.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new Jc.EncoderStream(Zf).end(e)},serialize:gq.encode,deserialize:gq.decode,q:1});en.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?nS.Readable.from((0,Li.encodeIter)(e,Zf)):(0,Li.pack)(e)},serialize:Li.pack,deserialize:Li.unpack,q:.9});en.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),(0,rS.toCsvStream)(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]),(0,rS.toCsvStream)(e,e?.getColumns?.())},q:.1});en.set("text/plain",{serialize(e){return e.toString()},deserialize(e){return e.toString()},q:.2});en.set("text/yaml",{serialize(e){return bq.stringify(e,{aliasDuplicateObjects:!1})},q:.7});en.set("text/event-stream",{serializeStream:a(function(e){return nS.Readable.from(Zue(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+`
32
- `),e.data){let r=e.data;typeof r=="object"&&(r=Xf(r)),t+="data: "+r+`
28
+ IdentitiesOnly yes`;await Te.pathExists(l)?await Te.appendFile(l,`
29
+ `+u):await Te.outputFile(l,u);let d="";if(await Te.pathExists(go)||(await Te.writeFile(go,""),await Te.chmod(go,"0600")),i=="github.com"&&!(await Te.readFile(go,"utf8")).includes("github.com"))try{let T=(await(await fetch("https://api.github.com/meta")).json()).ssh_keys;for(let m of T)Te.appendFile(go,"github.com "+m+`
30
+ `)}catch{d=". Unable to get known hosts from github.com. Set your known hosts manually using set_ssh_known_hosts."}o&&await Te.appendFile(go,o);let _=await si(e);return _.message=`Added ssh key: ${r}${d}`,_}a(gde,"addSSHKey");async function Ade(e){let t=An.updateSSHKeyValidator(e);if(t)throw qt(t,t.message,$t.BAD_REQUEST);let{name:r,key:n}=e;Gt.trace("updating ssh key",r);let s=ye.join(Sa,r+".key");if(!await Te.pathExists(s))throw new Error("Key does not exist. Use add_ssh_key");await Te.outputFile(s,n);let i=await si(e);return i.message=`Updated ssh key: ${r}`,i}a(Ade,"updateSSHKey");async function Rde(e){let t=An.deleteSSHKeyValidator(e);if(t)throw qt(t,t.message,$t.BAD_REQUEST);let{name:r}=e;Gt.trace("deleting ssh key",r);let n=ye.join(Sa,r+".key"),s=ye.join(Sa,"config");if(!await Te.pathExists(n))throw new Error("Key does not exist");let i=await Te.readFile(s,"utf8"),o=new RegExp(`#${r}[\\S\\s]*?IdentitiesOnly yes`,"g");i=i.replace(o,""),await Te.outputFile(s,i),Te.removeSync(n);let c=await si(e);return c.message=`Deleted ssh key: ${r}`,c}a(Rde,"deleteSSHKey");async function yde(e){let t=[];return await Te.pathExists(Sa)&&(await Te.readdir(Sa)).forEach(r=>{r!="known_hosts"&&r!="config"&&t.push({name:r.split(".")[0]})}),t}a(yde,"listSSHKeys");async function bde(e){let t=An.setSSHKnownHostsValidator(e);if(t)throw qt(t,t.message,$t.BAD_REQUEST);let{known_hosts:r}=e;await Te.outputFile(go,r);let n=await si(e);return n.message="Known hosts successfully set",n}a(bde,"setSSHKnownHosts");async function Ode(e){return await Te.pathExists(go)?{known_hosts:await Te.readFile(go,"utf8")}:{known_hosts:null}}a(Ode,"getSSHKnownHosts");Object.assign(s$,{customFunctionsStatus:ode,getCustomFunctions:ade,getCustomFunction:cde,setCustomFunction:lde,dropCustomFunction:ude,addComponent:dde,dropCustomFunctionProject:_de,packageComponent:fde,deployComponent:Ede,getComponents:pde,getComponentFile:mde,setComponentFile:Sde,dropComponent:Tde,addSSHKey:gde,updateSSHKey:Ade,deleteSSHKey:Rde,listSSHKeys:yde,setSSHKnownHosts:bde,getSSHKnownHosts:Ode})});var tS=N((HDe,A$)=>{"use strict";var iN=un(),hS=Vr(),ys=tm(),eE=ro(),oN=uc(),Nde=zy(),Ide=jH(),tE=xn(),pS=lf(),Rr=W(),wde=ob(),Cde=pf(),Dde=Lb(),Pde=Af(),Lde=vb(),Mde=Bb(),Ude=Sm(),vde=Fb(),aN=gm(),Ao=te(),Bde=$k(),cN=Wb(),a$=Gu(),en=M(),c$=zF(),Hde=wu(),l$=_u(),u$=(km(),oe(Hf)),d$=wt(),or=rN(),xde=require("alasql"),_$=oS(),f$=kf(),Zu=Xs(),E$=(xc(),oe(Hc)),h$=MO(),{handleHDBError:Rn,hdb_errors:p$}=_e(),{addNodeBack:vDe,removeNodeBack:BDe}=(xc(),oe(Hc)),{HDB_ERROR_MSGS:Ur,HTTP_STATUS_CODES:Xf}=p$,z=new Map,m$="delete",Ta="insert",Ro="read",nl="update",Zf="describe",i$=eE.describeSchema.name,o$=eE.describeTable.name,S$={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},kde={insert:!0,delete:!0,deleteRecord:!0,update:!0,updateData:!0,upsert:!0,upsertData:!0},Fde="catchup",Gde="handleGetJob",qde="handleGetJobsByStartDate",mS={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},$de=[ys.createTable.name,ys.createAttribute.name,ys.dropTable.name,ys.dropAttribute.name],T$={EXPORT_TO_S3:"export_to_s3",EXPORT_LOCAL:"export_local"},Z=class{static{a(this,"permission")}constructor(t,r){this.requires_su=t,this.perms=r}};z.set(iN.insert.name,new Z(!1,[Ta]));z.set(iN.update.name,new Z(!1,[nl]));z.set(iN.upsert.name,new Z(!1,[Ta,nl]));z.set(hS.searchByConditions.name,new Z(!1,[Ro]));z.set(hS.searchByHash.name,new Z(!1,[Ro]));z.set(hS.searchByValue.name,new Z(!1,[Ro]));z.set(hS.search.name,new Z(!1,[Ro]));z.set(ys.createSchema.name,new Z(!0,[]));z.set(ys.createTable.name,new Z(!0,[]));z.set(ys.createAttribute.name,new Z(!1,[Ta]));z.set(ys.dropSchema.name,new Z(!0,[]));z.set(ys.dropTable.name,new Z(!0,[]));z.set(ys.dropAttribute.name,new Z(!0,[]));z.set(eE.describeSchema.name,new Z(!1,[Ro]));z.set(eE.describeTable.name,new Z(!1,[Ro]));z.set(oN.deleteRecord.name,new Z(!1,[m$]));z.set(tE.addUser.name,new Z(!0,[]));z.set(tE.alterUser.name,new Z(!0,[]));z.set(tE.dropUser.name,new Z(!0,[]));z.set(tE.listUsersExternal.name,new Z(!0,[]));z.set(pS.listRoles.name,new Z(!0,[]));z.set(pS.addRole.name,new Z(!0,[]));z.set(pS.alterRole.name,new Z(!0,[]));z.set(pS.dropRole.name,new Z(!0,[]));z.set(wde.name,new Z(!0,[]));z.set(Cde.name,new Z(!0,[]));z.set(Dde.name,new Z(!0,[]));z.set(Pde.name,new Z(!0,[]));z.set(Lde.name,new Z(!0,[]));z.set(Mde.name,new Z(!0,[]));z.set(aN.setRoutes.name,new Z(!0,[]));z.set(aN.getRoutes.name,new Z(!0,[]));z.set(aN.deleteRoutes.name,new Z(!0,[]));z.set(d$.setConfiguration.name,new Z(!0,[]));z.set(Ude.clusterStatus.name,new Z(!0,[]));z.set(vde.name,new Z(!0,[]));z.set(cN.getFingerprint.name,new Z(!0,[]));z.set(cN.setLicense.name,new Z(!0,[]));z.set(oN.deleteFilesBefore.name,new Z(!0,[]));z.set(oN.deleteAuditLogsBefore.name,new Z(!0,[]));z.set(a$.restart.name,new Z(!0,[]));z.set(a$.restartService.name,new Z(!0,[]));z.set(Nde.name,new Z(!0,[]));z.set(Ide.name,new Z(!0,[Ro]));z.set(Hde.systemInformation.name,new Z(!0,[]));z.set(d$.getConfiguration.name,new Z(!0,[]));z.set(_$.readTransactionLog.name,new Z(!0,[]));z.set(_$.deleteTransactionLogsBefore.name,new Z(!0,[]));z.set(f$.installModules.name,new Z(!0,[]));z.set(f$.auditModules.name,new Z(!0,[]));z.set(Zu.createCsr.name,new Z(!0,[]));z.set(Zu.signCertificate.name,new Z(!0,[]));z.set(Zu.listCertificates.name,new Z(!0,[]));z.set(Zu.addCertificate.name,new Z(!0,[]));z.set(Zu.removeCertificate.name,new Z(!0,[]));z.set(Zu.getKey.name,new Z(!0,[]));z.set(E$.addNodeBack.name,new Z(!0,[]));z.set(E$.removeNodeBack.name,new Z(!0,[]));z.set(l$.createTokens.name,new Z(!1,[]));z.set(l$.refreshOperationToken.name,new Z(!1,[]));z.set(u$.login.name,new Z(!1,[]));z.set(u$.logout.name,new Z(!1,[]));z.set(or.customFunctionsStatus.name,new Z(!0,[]));z.set(or.getCustomFunctions.name,new Z(!0,[]));z.set(or.getComponents.name,new Z(!0,[]));z.set(or.getComponentFile.name,new Z(!0,[]));z.set(or.setComponentFile.name,new Z(!0,[]));z.set(or.dropComponent.name,new Z(!0,[]));z.set(or.getCustomFunction.name,new Z(!0,[]));z.set(or.setCustomFunction.name,new Z(!0,[]));z.set(or.dropCustomFunction.name,new Z(!0,[]));z.set(or.addComponent.name,new Z(!0,[]));z.set(or.dropCustomFunctionProject.name,new Z(!0,[]));z.set(or.packageComponent.name,new Z(!0,[]));z.set(or.deployComponent.name,new Z(!0,[]));z.set(or.addSSHKey.name,new Z(!0,[]));z.set(or.updateSSHKey.name,new Z(!0,[]));z.set(or.deleteSSHKey.name,new Z(!0,[]));z.set(or.listSSHKeys.name,new Z(!0,[]));z.set(or.setSSHKnownHosts.name,new Z(!0,[]));z.set(or.getSSHKnownHosts.name,new Z(!0,[]));z.set(cN.getRegistrationInfo.name,new Z(!1,[]));z.set(tE.userInfo.name,new Z(!1,[]));z.set(eE.describeAll.name,new Z(!1,[]));z.set(Gde,new Z(!1,[]));z.set(qde,new Z(!0,[]));z.set(Fde,new Z(!0,[]));z.set(mS.CSV_DATA_LOAD,new Z(!1,[Ta,nl]));z.set(mS.CSV_URL_LOAD,new Z(!1,[Ta,nl]));z.set(mS.CSV_FILE_LOAD,new Z(!1,[Ta,nl]));z.set(mS.IMPORT_FROM_S3,new Z(!1,[Ta,nl]));z.set(T$.EXPORT_TO_S3,new Z(!0,[]));z.set(T$.EXPORT_LOCAL,new Z(!0,[]));z.set(en.VALID_SQL_OPS_ENUM.DELETE,new Z(!1,[m$]));z.set(en.VALID_SQL_OPS_ENUM.SELECT,new Z(!1,[Ro]));z.set(en.VALID_SQL_OPS_ENUM.INSERT,new Z(!1,[Ta]));z.set(en.VALID_SQL_OPS_ENUM.UPDATE,new Z(!1,[nl]));A$.exports={verifyPerms:Kde,verifyPermsAst:Vde,verifyBulkLoadAttributePerms:Wde};function Vde(e,t,r){if(Ao.isEmptyOrZeroLength(e))throw Rr.info("verify_perms_ast has an empty user parameter"),Rn(new Error);if(Ao.isEmptyOrZeroLength(t))throw Rr.info("verify_perms_ast has an empty user parameter"),Rn(new Error);if(Ao.isEmptyOrZeroLength(r))throw Rr.info("verify_perms_ast has a null operation parameter"),Rn(new Error);try{let n=new h$,s=new Bde(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw Rr.info("No schemas defined in verifyPermsAst(), will not continue."),Rn(new Error);let c=!!t.role.permission.super_user,l=i.includes("system");if(l&&S$[r])throw Rn(new Error,Ur.DROP_SYSTEM,Xf.FORBIDDEN);if(c&&!l)return null;let u=c$.getRolePermissions(t.role);t.role.permission=u,!c&&e instanceof xde.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(u));for(let _=0;_<i.length;_++){let E=s.getTablesBySchemaName(i[_]);E&&o.set(i[_],E)}let d=g$(t,r,o,n);return d||(o.forEach((_,E)=>{for(let f=0;f<_.length;f++){let h=s.getAttributesBySchemaTableName(E,_[f]),T=uN(t.role.permission,E,_[f]);lN(h,T,r,_[f],E,n)}}),n.getPermsResponse())}catch(n){throw Rn(n)}}a(Vde,"verifyPermsAst");function Kde(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw Rr.info("null required parameter in verifyPerms"),Rn(new Error,Ur.DEFAULT_INVALID_REQUEST,Xf.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 h$;if(Ao.isEmptyOrZeroLength(e.hdb_user?.role)||Ao.isEmptyOrZeroLength(e.hdb_user?.role?.permission))return Rr.info(`User ${e.hdb_user?.username} has no role or permissions. Please assign the user a valid role.`),c.handleUnauthorizedItem(Ur.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,d=o.has(en.SYSTEM_SCHEMA_NAME)||s===en.SYSTEM_SCHEMA_NAME;if(l&&d&&kde[e.operation]&&(i===en.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME||i===en.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||i===en.SYSTEM_TABLE_NAMES.USER_TABLE_NAME))return null;if(d&&S$[r])throw Rn(new Error,Ur.DROP_SYSTEM,Xf.FORBIDDEN);if(l&&!d||u===!0&&(r===ys.createSchema.name||r===ys.dropSchema.name))return null;if($de.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 _=c$.getRolePermissions(e.hdb_user?.role);if(e.hdb_user?.role&&(e.hdb_user.role.permission=_),r===i$||r===o$){if(s===en.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(Ur.SCHEMA_PERM_ERROR(s));if(!_.super_user){if(r===i$&&(!_[s]||!_[s][Zf]))return c.handleInvalidItem(Ur.SCHEMA_NOT_FOUND(s));if(r===o$&&(!_[s]||!_[s].tables[i]||!_[s].tables[i][Zf]))return c.handleInvalidItem(Ur.TABLE_NOT_FOUND(s,i))}}let E=g$(e.hdb_user,r,o,c,n);if(E)return E;if(z.get(r)&&z.get(r).perms.length===0)return null;if(!l&&e.get_attributes&&en.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let T=[],m=_[s].tables[i];m[en.PERMS_CRUD_ENUM.READ]&&(m.attribute_permissions.length>0?m.attribute_permissions.filter(S=>S[en.PERMS_CRUD_ENUM.READ]).forEach(S=>{T.push(S.attribute_name)}):T=global.hdb_schema[s][i].attributes.map(g=>g.attribute),e.get_attributes=T)}let f=Yde(e),h=uN(e.hdb_user?.role?.permission,s,i);return lN(f,h,r,i,s,c,n),c.getPermsResponse()}a(Kde,"verifyPerms");function g$(e,t,r,n,s){if(Ao.arrayHasEmptyValues([e,t,r]))throw Rr.info("hasPermissions has an invalid parameter"),Rn(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 Rr.info(`operation ${t} not found.`),Rn(new Error,Ur.OP_NOT_FOUND(t),Xf.BAD_REQUEST);if(z.get(t)&&z.get(t).requires_su)return Rr.info(`operation ${t} requires SU permissions.`),n.handleUnauthorizedItem(Ur.OP_IS_SU_ONLY(t));let c=r.keys();for(let l of c){try{if(l&&!o[l]||o[l][Zf]===!1){n.addInvalidItem(Ur.SCHEMA_NOT_FOUND(l));continue}}catch{n.addInvalidItem(Ur.SCHEMA_NOT_FOUND(l));continue}let u=r.get(l);for(let d of u){let _=o[l].tables[d];if(!_||_[Zf]===!1)n.addInvalidItem(Ur.TABLE_NOT_FOUND(l,d));else try{let E=[],f=z.get(t).perms;!Ao.isEmpty(s)&&f.includes(s)&&(f=[s]);for(let h=0;h<f.length;h++){let T=f[h],m=_[T];(m==null||m===!1)&&(Rr.info(`Required ${T} permission not found for ${t} ${s?`${s} `:""}operation in role ${e.role.id}`),E.push(T))}E.length>0&&n.addUnauthorizedTable(l,d,E)}catch(E){let f=Ur.UNKNOWN_OP_AUTH_ERROR(t,l,d);throw Rr.error(f),Rr.error(E),Rn(p$.CHECK_LOGS_WRAPPER(f))}}}return r.size<2?n.getPermsResponse():null}a(g$,"hasPermissions");function lN(e,t,r,n,s,i,o){if(!e||!t)throw Rr.info("no attributes specified in checkAttributePerms."),Rn(new Error);let c=z.get(r).perms;if(!c||c==="")throw Rr.info(`no permissions found for ${r} in checkAttributePerms().`),Rn(new Error);if(Ao.isEmptyOrZeroLength(t))return Rr.info("No role permissions set (this is OK)."),null;o&&c.includes(o)&&(c=[o]);let l={};for(let d of e){let _=t.get(d);if(_){if(_[Zf]===!1){i.addInvalidItem(Ur.ATTR_NOT_FOUND(s,n,d),s,n);continue}if(c)for(let E of c){if(en.TIME_STAMP_NAMES.includes(_.attribute_name)&&E!==Ro)throw Rn(new Error,Ur.SYSTEM_TIMESTAMP_PERMS_ERR,Xf.FORBIDDEN);_[E]===!1&&(l[_.attribute_name]?l[_.attribute_name].push(E):l[_.attribute_name]=[E])}}else i.addInvalidItem(Ur.ATTR_NOT_FOUND(s,n,d),s,n)}let u=Object.keys(l);u.length>0&&i.addUnauthorizedAttributes(u,s,n,l)}a(lN,"checkAttributePerms");function Yde(e){let t=new Set;try{if(e.action)return t;if(e.operation===en.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){Rr.info(r)}return t}a(Yde,"getRecordAttributes");function uN(e,t,r){let n=new Map;if(Ao.isEmpty(e))return Rr.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{Rr.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(uN,"getAttributePermissions");function Wde(e,t,r,n,s,i,o){let c=new Set(i),l=uN(e,n,s);lN(c,l,t,s,n,o,r)}a(Wde,"verifyBulkLoadAttributePerms")});var nS=N((kDe,N$)=>{"use strict";N$.exports={evaluateSQL:o_e,processAST:O$,convertSQLToAST:b$,checkASTPermissions:y$};var jde=un(),R$=require("util"),zde=R$.callbackify(jde.insert),Qde=Vr().search,Jde=e0().update,Xde=R$.callbackify(Jde),Zde=r0().convertDelete,ga=require("alasql"),e_e=tS(),SS=W(),t_e=Ep(),r_e=te(),rE=M(),{hdb_errors:n_e,handleHDBError:dN}=_e(),{HTTP_STATUS_CODES:_N}=n_e;t_e(ga);var s_e=403,i_e="There was a problem performing this insert. Please check the logs and try again.",fN=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function o_e(e,t){let r=e.parsed_sql_object;if(!r){r=b$(e.sql);let n,s=r.ast.statements[0];if(s instanceof ga.yy.Insert?n=s.into.databaseid:s instanceof ga.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof ga.yy.Update||s instanceof ga.yy.Delete?n=s.table.databaseid:SS.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof ga.yy.Select)&&r_e.isEmptyOrZeroLength(n))return t("No schema specified",null)}O$(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(o_e,"evaluateSQL");function y$(e,t){let r;try{r=e_e.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(y$,"checkASTPermissions");function b$(e){let t=new fN;if(!e)throw dN(new Error,"The 'sql' parameter is missing from the request body",_N.BAD_REQUEST);try{let r=e.trim(),n=ga.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
31
+ `);throw n[1]?dN(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,_N.BAD_REQUEST):dN(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",_N.BAD_REQUEST)}return t}a(b$,"convertSQLToAST");function O$(e,t,r){try{let n=a_e;if(!e.bypass_auth&&!t.permissions_checked){let i=y$(e,t);if(i&&i.length>0)return r(s_e,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case rE.VALID_SQL_OPS_ENUM.SELECT:n=Qde,s=t.ast.statements[0];break;case rE.VALID_SQL_OPS_ENUM.INSERT:n=c_e;break;case rE.VALID_SQL_OPS_ENUM.UPDATE:n=Xde;break;case rE.VALID_SQL_OPS_ENUM.DELETE:n=Zde;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(O$,"processAST");function a_e(e,t){SS.info(e),t("unknown sql statement")}a(a_e,"nullFunction");function c_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=l_e(i,e.values)}catch(o){return r(o)}zde(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(l){SS.error(`Error delete new_attributes from insert response: ${l}`)}r(null,c)})}a(c_e,"convertInsert");function l_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]]=ga.compile(`SELECT ${s.toString()} AS [${rE.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw SS.error(r),new Error(i_e)}}a(l_e,"createDataObjects")});var cS=N((GDe,v$)=>{"use strict";var hN=Vr(),u_e=nS(),d_e=IO(),{AsyncParser:__e,Transform:f_e}=require("json2csv"),sE=require("stream"),Wn=te(),EN=require("fs-extra"),E_e=require("path"),bs=W(),{promisify:C$}=require("util"),nE=te(),{handleHDBError:ar,hdb_errors:h_e}=_e(),{HDB_ERROR_MSGS:yn,HTTP_STATUS_CODES:cr}=h_e,{streamAsJSON:p_e}=(Ug(),oe(UD)),{Upload:m_e}=require("@aws-sdk/lib-storage"),I$=["search_by_value","search_by_hash","sql","search_by_conditions"],w$=["json","csv"],D$="json",P$="csv",S_e="Successfully exported JSON locally.",T_e="Successfully exported CSV locally.",g_e=1e3,A_e=hN.searchByHash,R_e=hN.searchByValue,y_e=C$(u_e.evaluateSQL),b_e=C$(sE.finished);v$.exports={export_to_s3:w_e,export_local:O_e,toCsvStream:L$};async function O_e(e){bs.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=M$(e);if(!Wn.isEmpty(t))throw bs.error(t),ar(new Error,t,cr.BAD_REQUEST,void 0,void 0,!0);if(Wn.isEmpty(e.path))throw bs.error(yn.MISSING_VALUE("path")),ar(new Error,yn.MISSING_VALUE("path"),cr.BAD_REQUEST,void 0,void 0,!0);let r=(Wn.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(E_e.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=Wn.buildFolderPath(e.path,r);await N_e(e.path);let s=await U$(e);return await I_e(n,e.format,s)}a(O_e,"export_local");async function N_e(e){if(bs.trace("in confirmPath"),Wn.isEmptyOrZeroLength(e))throw ar(new Error,`Invalid path: ${e}`,cr.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await EN.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,bs.error(n),ar(new Error,n,cr.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 bs.error(r),ar(new Error,r,cr.BAD_REQUEST,void 0,void 0,!0)}return!0}a(N_e,"confirmPath");async function I_e(e,t,r){if(bs.trace("in saveToLocal"),nE.isEmptyOrZeroLength(e))throw ar(new Error,yn.INVALID_VALUE("file_path"),cr.BAD_REQUEST,void 0,void 0,!0);if(nE.isEmptyOrZeroLength(t))throw ar(new Error,yn.INVALID_VALUE("Source format"),cr.BAD_REQUEST,void 0,void 0,!0);if(nE.isEmpty(r))throw ar(new Error,yn.NOT_FOUND("Data"),cr.BAD_REQUEST,void 0,void 0,!0);if(t===D$){let n=EN.createWriteStream(e);return p_e(r).pipe(n),await b_e(n),{message:S_e,path:e}}else if(t===P$){let n=EN.createWriteStream(e),s=sE.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(d=>({label:d,value:d})));let c={objectMode:!0};return await new __e(i,c).fromInput(s).toOutput(n).promise(!1),{message:T_e,path:e}}throw ar(new Error,yn.INVALID_VALUE("format"),cr.BAD_REQUEST)}a(I_e,"saveToLocal");async function w_e(e){if(!e.s3||Object.keys(e.s3).length===0)throw ar(new Error,yn.MISSING_VALUE("S3 object"),cr.BAD_REQUEST);if(Wn.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw ar(new Error,yn.MISSING_VALUE("aws_access_key_id"),cr.BAD_REQUEST);if(Wn.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw ar(new Error,yn.MISSING_VALUE("aws_secret_access_key"),cr.BAD_REQUEST);if(Wn.isEmptyOrZeroLength(e.s3.bucket))throw ar(new Error,yn.MISSING_VALUE("bucket"),cr.BAD_REQUEST);if(Wn.isEmptyOrZeroLength(e.s3.key))throw ar(new Error,yn.MISSING_VALUE("key"),cr.BAD_REQUEST);if(Wn.isEmptyOrZeroLength(e.s3.region))throw ar(new Error,yn.MISSING_VALUE("region"),cr.BAD_REQUEST);let t=M$(e);if(!Wn.isEmpty(t))throw ar(new Error,t,cr.BAD_REQUEST);bs.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await U$(e)}catch(l){throw bs.error(l),l}let n,s=await d_e.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new sE.PassThrough;if(e.format===P$){i=e.s3.key+".csv";let l=L$(r,r.getColumns?.());l.on("error",u=>{throw u}),l.pipe(o)}else if(e.format===D$){i=e.s3.key+".json";let l=new sE.Readable;l.pipe(o),l.on("error",_=>{throw _}),l.push("[");let u=r.length,d="";for(let[_,E]of r.entries()){let f=_===u-1?JSON.stringify(E):JSON.stringify(E)+",";d+=f,_!==0&&_%g_e===0&&(l.push(d),d="")}d.length!==0&&l.push(d),l.push("]"),l.push(null)}else throw ar(new Error,yn.INVALID_VALUE("format"),cr.BAD_REQUEST);return new m_e({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(w_e,"export_to_s3");function L$(e,t){let r=sE.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 f_e(n,s);return r.pipe(i)}a(L$,"toCsvStream");function M$(e){if(bs.trace("in exportCoreValidation"),Wn.isEmpty(e.format))return"format missing";if(w$.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${w$.join(", ")}`;let t=e.search_operation.operation;if(Wn.isEmpty(t))return"search_operation.operation missing";if(I$.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${I$.join(", ")}`}a(M$,"exportCoreValidation");async function U$(e){bs.trace("in getRecords");let t,r;if(nE.isEmpty(e.search_operation)||nE.isEmptyOrZeroLength(e.search_operation.operation))throw ar(new Error,yn.INVALID_VALUE("Search operation"),cr.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=R_e;break;case"search_by_hash":t=A_e;break;case"search_by_conditions":t=hN.searchByConditions;break;case"sql":t=y_e;break;default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,bs.error(r),ar(new Error,r,cr.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(U$,"getRecords")});var $$={};je($$,{contentTypes:()=>gN,findBestSerializer:()=>AS,getDeserializer:()=>bo,registerContentHandlers:()=>AN,serialize:()=>aE,serializeMessage:()=>Wc});function C_e(e){try{return e?.[0]===123?TN(e):e}catch{return e}}function AN(e){e.register(P_e,{serializers:[{regex:/^application\/json$/,serializer:Zd},{regex:/^application\/cbor$/,serializer:a(function(t){return new sl.EncoderStream(oE).end(t)},"serializer")},{regex:/^application\/(x-)?msgpack$/,serializer:a(function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?gS.Readable.from((0,Mi.encodeIter)(t,oE)):(0,Mi.pack)(t)},"serializer")},{regex:/^text\/csv$/,serializer:a(function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),(0,TS.toCsvStream)(t)},"serializer")}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Mi.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,sl.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function AS(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,...d]=l.split(/\s*;\s*/),_=1,E={q:1};for(let h of d){let T=h.indexOf("=");E[h.substring(0,T)]=h.substring(T+1)}_=+E.q;let f=tn.get(u);if(f){let h=(f.q||1)*_;h>s&&(n=f,i=f.type||u,s=h,o=E)}}if(!n){if(r)throw new x$.ClientError("No supported content types found in Accept header, supported types include: "+Array.from(tn.keys()).join(", "),406);n=tn.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function aE(e,t,r){let n=H$&&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)r.headers.set("Content-Type","application/octet-stream"),r.headers.set("Vary","Accept-Encoding"),s=e;else{let i=AS(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}),SN.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,yo.createBrotliCompress)({params:{[yo.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?yo.constants.BROTLI_MODE_TEXT:yo.constants.BROTLI_MODE_GENERIC,[yo.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>H$?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,yo.brotliCompress)(s,(c,l)=>{c?o(c):i(l)}))):s}function Wc(e,t){if(e?.contentType!=null&&e.data!=null)return e.data;if(!t)return iE(e);let r=t.serialize;if(r)return r(e);let n=AS(t);return r=t.serialize=n.serializer.serialize,r(e)}function L_e(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 U_e(e){return M_e.includes(e)}function v_e(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 bo(e="",t=!1){let r=v_e(e),n=r.type&&tn.get(r.type)?.deserialize||B_e(r);return t?s=>L_e(s).then(n):n}function B_e(e){return e.type.startsWith("text/")?(e.parameters?.charset&&!U_e(e.parameters.charset)&&SN.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 TN(t)}catch{}return{contentType:e.type||"application/octet-stream",data:t}}}function H_e(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)}}}}}var TS,Mi,sl,yo,x$,gS,k$,pN,mN,F$,SN,G$,iE,TN,oE,tn,gN,B$,q$,D_e,P_e,H$,M_e,jc=Ie(()=>{Ug();TS=L(cS()),Mi=require("msgpackr"),sl=require("cbor-x"),yo=require("zlib"),x$=L(_e()),gS=require("stream");qr();k$=L(fi()),pN=L(se()),mN=L(M()),F$=L(require("yaml")),SN=L(bc()),G$=pN.default.get(mN.CONFIG_PARAMS.SERIALIZATION_BIGINT)!==!1,iE=G$?Za:JSON.stringify,TN=G$?Mg:JSON.parse,oE={useRecords:!1,useToJSON:!0},tn=new Map,gN=tn;it.contentTypes=gN;(0,k$._assignPackageExport)("contentTypes",gN);tn.set("application/json",{serializeStream:Zd,serialize:iE,deserialize(e){return TN(e)},q:.8});B$=new sl.Encoder(oE);tn.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new sl.EncoderStream(oE).end(e)},serialize:B$.encode,deserialize:B$.decode,q:1});tn.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?gS.Readable.from((0,Mi.encodeIter)(e,oE)):(0,Mi.pack)(e)},serialize:Mi.pack,deserialize:Mi.unpack,q:.9});tn.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),(0,TS.toCsvStream)(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]),(0,TS.toCsvStream)(e,e?.getColumns?.())},q:.1});tn.set("text/plain",{serialize(e){return e.toString()},deserialize(e){return e.toString()},q:.2});tn.set("text/yaml",{serialize(e){return F$.stringify(e,{aliasDuplicateObjects:!1})},q:.7});tn.set("text/event-stream",{serializeStream:a(function(e){return gS.Readable.from(H_e(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+`
32
+ `),e.data){let r=e.data;typeof r=="object"&&(r=iE(r)),t+="data: "+r+`
33
33
  `}return e.id&&(t+="id: "+e.id+`
34
34
  `),e.retry&&(t+="retry: "+e.retry+`
35
35
  `),t+`
36
- `}else return typeof e=="object"?`data: ${Xf(e)}
36
+ `}else return typeof e=="object"?`data: ${iE(e)}
37
37
 
38
38
  `:`data: ${e}
39
39
 
40
- `},"serialize"),compressible:!1,q:.8});en.set("application/x-www-form-urlencoded",{deserialize(e){let t={};for(let[r,n]of new URLSearchParams(e))if(t.hasOwnProperty(r)){let s=t[r];Array.isArray(s)?s.push(n):t.key=[s,n]}else t[r]=n},serialize(e){let t=new URLSearchParams;for(let r in e)t.set(r,e);return t.toString()}});Nq={type:"application/json",serializeStream:Xd,serialize:Xf,deserialize:Kue,q:.5};en.set("*/*",Nq);en.set("",Nq);a(Kue,"tryJSONParse");a(YO,"registerContentHandlers");Yue=require("fastify-plugin"),Wue=Yue(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=sS(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 d=l.getColumns;l=l.mapError(_=>(_.toJSON=()=>({error:_.name,message:_.message,..._.partialObject}),_)),l.getColumns=d}u=o.serializeStream}else u=o.serialize;return u(l,{headers:{set:a((d,_)=>{s.header(d,_)},"set")}})})}),r()},{name:"content-type-negotiation"});a(sS,"findBestSerializer");Rq=GO.default.get(qO.CONFIG_PARAMS.HTTP_COMPRESSIONTHRESHOLD);a(eE,"serialize");a(Yc,"serializeMessage");a(jue,"streamToBuffer");zue=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(Que,"isBufferEncoding");a(Jue,"parseContentType");a(bo,"getDeserializer");a(Xue,"deserializerUnknownType");a(Zue,"transformIterable")});var jO={};je(jO,{start:()=>cde});function ede(e){if(e.kind!==Le.Kind.OPERATION_DEFINITION&&e.kind!==Le.Kind.FRAGMENT_DEFINITION)throw new Ur(`Unexpected non-executable definition type ${e.kind}.`)}function wq(e){if(typeof e!="object"||e===null)throw new Mi("Request body must be an object.");if(!("query"in e))throw new Mi("Request body must contain a `query` field.");if(typeof e.query!="string")throw new Mi("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new Mi("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new Mi("Request body `operationName` field must be a string.")}function WO(e){return parseInt(e.value,10)}function Dq(e){return parseFloat(e.value)}function Pq(e,t,r){let n=r.get(e.name.value);return Lq(n)?Mq(n,t):{attribute:t,value:n}}function Lq(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function Mq(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],Lq(n)?Mq(n,t):{attribute:t,value:n}))}function tde(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:WO(e.value)};case Le.Kind.FLOAT:return{attribute:t,value:Dq(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:t,value:e.value.value};case Le.Kind.VARIABLE:return Pq(e.value,t,r);case Le.Kind.OBJECT:return Uq(e.value,t,r);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Ur(`Value type, ${e.value.kind}, is not supported.`)}}function Uq(e,t,r){return e.fields.flatMap(n=>tde(n,t,r))}function rde(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:WO(e.value)};case Le.Kind.FLOAT:return{attribute:e.name.value,value:Dq(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Le.Kind.VARIABLE:return Pq(e.value,e.name.value,t);case Le.Kind.OBJECT:return Uq(e.value,[e.name.value],t);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Ur(`Argument type, ${e.value.kind}, is not supported.`)}}function nde(e,t){return e.flatMap(r=>rde(r,t))}function iS(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 Ur(`Fragment \`${n}\` not found.`);return iS(s.selectionSet,t)}case Le.Kind.INLINE_FRAGMENT:return iS(r.selectionSet,t)}})}function vq(e,t){return iS(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:vq(r.selectionSet,t)}:r.name.value)}async function sde(e,t,r,n){let i=wi.getMatch(e.name.value,"graphql").Resource,o={select:vq(e.selectionSet,r),conditions:nde(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 Bq(e){switch(e.kind){case Le.Kind.NULL:return null;case Le.Kind.INT:return WO(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]:Bq(r.value),...t}),{});case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Ur(`Value type, ${e.kind}, is not supported.`)}}function ide(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=Bq(n.defaultValue)),n.type.kind===Le.Kind.NON_NULL_TYPE&&!(s in t)&&i===void 0)throw new Ur(`Variable $${s} is required, but not provided.`);r.set(n.variable.name.value,i??null)}return r}async function ode(e,t,r,n){if(e.operation===Le.OperationTypeNode.SUBSCRIPTION)throw new Ur("Subscriptions are not supported.");if(e.operation===Le.OperationTypeNode.MUTATION)throw new Ur("Mutations are not supported yet.");let s=ide(e.variableDefinitions,t),i=await Promise.all(iS(e.selectionSet,r).map(c=>sde(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function Cq({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(ede(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 Ur("Unnamed operations are only allowed when there is a single operation in the document.");let d=u.name?.value??"Unnamed Query";if(i.has(d))throw new Ur(`Duplicate operation definition: ${d}`);i.set(d,u)}let c;if(r==null)if(i.size===1)c=i.entries().next().value[1];else throw new Ur("Operation name is required when there are multiple operations in the document.");else if(c=i.get(r),c==null)throw new Ur(`Operation \`${r}\` not found.`);let l=await ode(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function ade(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 wq(r),Cq(r,e)}case"POST":{let r=await bo(e.headers.get("content-type"),!0)(e._nodeRequest);return wq(r),Cq(r,e)}default:throw new Mi("Method Not Allowed",405,{Allow:"GET, POST"})}}function cde(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await ade(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof Mi)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 Ur)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 Mi)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 Ur)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}})}var Le,Ur,Mi,Hq=Oe(()=>{Le=L(require("graphql"));Wc();eu();a(ede,"assertExecutableDefinitionNode");a(wq,"assertRequestParams");a(WO,"processIntValueNode");a(Dq,"processFloatValueNode");a(Pq,"processVariableNode");a(Lq,"isObject");a(Mq,"transformObjectIntoQueryCondition");a(tde,"processObjectFieldNode");a(Uq,"processObjectValueNode");a(rde,"processArgumentNode");a(nde,"buildConditionsQuery");a(iS,"fillInFragments");a(vq,"buildSelectQuery");a(sde,"processFieldNode");a(Bq,"processConstValueNode");a(ide,"resolveVariables");a(ode,"executeOperation");a(Cq,"resolver");Ur=class extends Error{static{a(this,"GraphQLQueryingError")}},Mi=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a(ade,"graphqlQueryingHandler");a(cde,"start")});var zO={};je(zO,{start:()=>Fq,startOnMainThread:()=>dde});function Fq({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,xq.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(lde.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 d=[];for(let _ in u.attributes){let E=u.attributes[_];E.attribute_name=_,d.push(E)}u.attribute_permissions=d,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 d of u.attribute_permissions)d.read=!!d.read,d.insert=!!d.insert,d.update=!!d.update}else u.attribute_permissions=null}}i.role=i.id=s,await ude(i)}}}async function ude(e){let t=ut().system.hdb_role;for await(let r of t.search([{attribute:"role",value:e.role}])){let{__createdtime__:n,__updatedtime__:s,...i}=r;return(0,kq.isEqual)(i,e)?void 0:(e.id=r.id,(0,oS.alterRole)(e))}return(0,oS.addRole)(e)}var oS,xq,kq,lde,dde,Gq=Oe(()=>{Pe();oS=L(lf()),xq=require("yaml"),kq=require("lodash"),lde=["super_user","cluster_user","structure_user"];a(Fq,"start");a(ude,"ensureRole");dde=Fq});async function aS(e){let t=(0,Vq.pathToFileURL)(e).toString();return _de?(tE||(tE=fde(hde)),(await(await tE).import(t)).namespace):import(t)}async function fde(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),tE=new Compartment({console,Math,Date,fetch:Ede,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,$q.extname)(r)||(r+=".js"),r)},importHook:a(async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Lr,tables:jn,databases:We})}};let n=await(0,qq.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),tE}function Ede(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 hde(){return{Resource:Lr,tables:jn}}var qq,$q,Vq,_de,tE,QO=Oe(()=>{Vs();Pe();qq=require("fs/promises"),$q=require("path"),Vq=require("url"),_de=!1;a(aS,"secureImport");a(fde,"getCompartment");a(Ede,"secureOnlyFetch");a(hde,"getGlobalVars")});var XO={};je(XO,{handleFile:()=>pde});async function pde(e,t,r,n){let s=new Map,i=await aS(r);c(i.default)&&n.set((0,JO.dirname)(t),i.default),o(i,(0,JO.dirname)(t));function o(l,u){for(let d in l){let _=l[d];c(_)?n.set(u+"/"+d,_):typeof _=="object"&&o(_,u+"/"+d)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var JO,Kq=Oe(()=>{QO();JO=require("path");a(pde,"handleFile")});var eN={};je(eN,{start:()=>mde});function mde({resources:e}){e.set("login",ZO),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var ZO,Yq=Oe(()=>{Vs();a(mde,"start");ZO=class extends Lr{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)}}}});function rN(e,t,r,n,s,i,o,c){let l=e[0];if(t==="or"){let _=u(l);for(let f=1;f<e.length;f++){let h=e[f],T=u(h);_=_.concat(T)}let E=new Set;return _.filter(f=>{let h=f.key??f;return E.has(h)?!1:(E.add(h),!0)})}else{let _=u(l),E=d(e.slice(1),!0,l.estimated_count);return E.length>0?o(_,E):_}function u(_){return _.conditions?rN(_.conditions,_.operator,r,n,s,i,o,c):zu(_,n,_.descending||s.reverse===!0,r,s.allowFullScan,c)}a(u,"executeCondition");function d(_,E,f){return _.map((h,T)=>{if(h.conditions){let S=h.operator==="or",b=d(h.conditions,!S,f);return S?(I,B)=>b.some(H=>H(I,B)):(I,B)=>b.every(H=>H(I,B))}let m=(h.attribute||h[0])===r.primaryKey,g=sE(h,r,i,c,m,f);return E&&T<_.length-1&&f&&(f=Nde(r.primaryStore,h.estimated_count,f)),g}).filter(Boolean)}a(d,"mapConditionsToFilters")}function zu(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 On.ClientError(`Search condition for ${o} must have a value`);if(Array.isArray(o)){let S=o[0],b=vi(n.attributes,S);if(b.relationship){if(o.length<2)throw new On.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let I=b.definition?.tableClass||b.elements?.definition?.tableClass,B=new Map,H=zu({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,I,s,B);if(b.relationship.to){i[o[0]]=B;let X=!!vi(I.attributes,b.relationship.to)?.elements;H=Ade(H,b,I.primaryStore,X,B)}if(b.relationship.from){let X=a(Y=>(Y?.key!==void 0&&(Y=Y.key),zu({attribute:b.relationship.from,value:Y},t,r,n,s,B)),"searchEntry");b.elements?(i[o[0]]=B,H=yde(H,b,I.primaryStore,B,X)):H=H.flatMap(X)}return H}else if(o.length===1)o=o[0];else throw new On.ClientError("Unable to query by attribute "+JSON.stringify(o))}let u,d,_,E;c instanceof Date&&(c=c.getTime());let f;switch(nN[l]||l){case"lt":u=!0,d=c;break;case"le":u=!0,d=c,_=!0;break;case"gt":u=c,E=!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,d=c.slice(0),d[d.length-1]=Ui.MAXIMUM_KEY;break;case"starts_with":u=c.toString(),d=c+"\uFFFF";break;case"between":case"gele":case"gelt":case"gtlt":case"gtle":u=c[0],u instanceof Date&&(u=u.getTime()),d=c[1],d instanceof Date&&(d=d.getTime()),_=l==="gele"||l==="gtle"||l==="between",E=l==="gtlt"||l==="gtle";break;case"equals":case void 0:u=c,d=c,_=!0;break;case"ne":if(c===null){u=c,E=!0;break}case"sort":case"contains":case"ends_with":u=!0,f=!0;break;default:throw new On.ClientError(`Unknown query comparator "${l}"`)}let h,T=o===n.primaryKey||o==null;if(typeof u=="string"&&u.length>bs.MAX_SEARCH_KEY_LENGTH&&(u=u.slice(0,bs.MAX_SEARCH_KEY_LENGTH)+bs.OVERFLOW_MARKER,E=!1,h=sE(e,n,null,i,T)),typeof d=="string"&&d.length>bs.MAX_SEARCH_KEY_LENGTH&&(d=d.slice(0,bs.MAX_SEARCH_KEY_LENGTH)+bs.OVERFLOW_MARKER,_=!0,h=h??sE(e,n,null,i,T)),r){let S=u;u=d,d=S,S=!E,E=!_,_=S}let m=T?n.primaryStore:n.indices[o];if(!m||m.isIndexing||f||c===null&&!m.indexNulls){if(s===!1&&!m)throw new On.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&f)throw new On.ClientError(`Can not use ${l||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(m?.isIndexing)throw new On.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&m&&!m.indexNulls)throw new On.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??sE(e,n,null,i,T),!h)throw new On.ClientError(`Unknown search operator ${e.comparator}`)}let g={start:u,end:d,inclusiveEnd:_,exclusiveStart:E,values:!0,versions:T,transaction:t,reverse:r};if(T){let S=m.getRange(g).map(h?function({key:b,value:I}){return this?.isSync?I&&h(I)?b:Ra.SKIP:new Promise((B,H)=>setImmediate(()=>{try{B(I&&h(I)?b:Ra.SKIP)}catch(X){H(X)}}))}:b=>b.value==null&&!(b.metadataFlags&(Os|ya))?Ra.SKIP:b);return S.hasEntries=!0,S}else return m?m.getRange(g).map(h?function({key:S,value:b}){let I;return typeof S=="string"&&S.length>bs.MAX_SEARCH_KEY_LENGTH?I=n.primaryStore.get(b):I={[o]:S},this.isSync?h(I)?b:Ra.SKIP:new Promise((B,H)=>setImmediate(()=>{try{B(h(I)?b:Ra.SKIP)}catch(X){H(X)}}))}:({value:S})=>S):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:S,value:b}){return this.isSync?b&&h(b)?S:Ra.SKIP:new Promise((I,B)=>setImmediate(()=>{try{I(b&&h(b)?S:Ra.SKIP)}catch(H){B(H)}}))})}function vi(e,t){if(Array.isArray(t))if(t.length>1){let r=vi(e,t[0]),n=(r?.definition?.tableClass||r?.elements?.definition?.tableClass)?.attributes??r?.properties;return n?vi(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 Ade(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,d)=>{let _=s.get(u);_?_.push(d):s.set(u,_=[d])},"add_entry");for(let u of e){let d=u.value??r.get(u.key??u),_=d?.[c];if(_!=null&&!s.filters?.some(E=>!E(d)))if(n)for(let E=0;E<_.length;E++)l(_[E],u);else l(_,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 yde(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=d=>d[t.relationship.from]?.filter?.(_=>u.has(_));for(let d of e){if(n.filters){let _=r.get(d);if(n.filters.some(E=>!E(_)))continue}u.add(d)}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 sE(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 d=c[0],_=vi(t.attributes,d),E=_.definition?.tableClass||_.elements.definition?.tableClass,f=n?.[d],h=sE({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:o},E,r,f?.[d]?.joined,c[1]===E.primaryKey,i);if(!h)return;if(f){f.filters||(f.filters=[]),f.filters.push(h);return}let T=t.propertyResolvers?.[d],m,g=a((S,b)=>{let I,B;if(T){if(T.from&&h.idFilter){if(!m)if(h.idFilter.idSet?.size===1){for(let X of h.idFilter.idSet)e={attribute:T.from,value:X};m=u(T.from,h.idFilter,!0,!0)}else m=u(T.from,h.idFilter,!1,!0);let H=m(S);return m.idFilter&&(g.idFilter=m.idFilter),H}B=T(S,r,b),I=B?.value}else I=S[d];return I?Array.isArray(I)?I.some(h):h(I,B):!1},"recordFilter");return g}}switch(l instanceof Date&&(l=l.getTime()),nN[o]||o){case bs.SEARCH_TYPES.EQUALS:case void 0:return u(c,d=>d===l,!0);case"contains":return u(c,d=>d?.toString().includes(l));case"ends_with":return u(c,d=>d?.toString().endsWith(l));case"starts_with":return u(c,d=>typeof d=="string"&&d.startsWith(l),!0);case"prefix":return Array.isArray(l)?l[l.length-1]==null&&(l=l.slice(0,-1)):l=[l],u(c,d=>{if(!Array.isArray(d))return!1;for(let _=0,E=l.length;_<E;_++)if(d[_]!==l[_])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,d=>(0,Ui.compareKeys)(d,l[0])>=0&&(0,Ui.compareKeys)(d,l[1])<=0,!0);case"gt":return u(c,d=>(0,Ui.compareKeys)(d,l)>0);case"ge":return u(c,d=>(0,Ui.compareKeys)(d,l)>=0);case"lt":return u(c,d=>(0,Ui.compareKeys)(d,l)<0);case"le":return u(c,d=>(0,Ui.compareKeys)(d,l)<=0);case"ne":return u(c,d=>(0,Ui.compareKeys)(d,l)!==0,!1,!0);case"sort":return()=>!0;default:throw new On.ClientError(`Unknown query comparator "${o}"`)}function u(d,_,E,f){let h;E=E&&!s&&t?.indices[d]&&i>3,E&&(e.estimated_count==null&&lS(t)(e),h=e.estimated_count>>4,(isNaN(h)||h>=i)&&(E=!1));let T=0,m=3;function g(S){let b=S[d],I;if(typeof b!="object"||!b||f?I=_(b):Array.isArray(b)?I=b.some(_):b instanceof Date&&(I=_(b.getTime())),E&&(m++,!I&&!g.idFilter&&++T/m*(i-m)>h)){let B=zu(e,r.transaction.getReadTxn(),!1,t).map(Qu),H=new Set(B);g.idFilter=X=>H.has(Qu(X)),g.idFilter.idSet=H}return I}return a(g,"recordFilter"),s&&(g.idFilter=_),g}a(u,"attributeComparator")}function lS(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/Oo(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=nN[n]||n,n===bs.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=vi(e.attributes,s[0]),o=i.definition?.tableClass||i.elements.definition?.tableClass,c=lS(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*Oo(e.indices[i.relationship.from])/(Oo(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=Oo(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=gde*Oo(e.primaryStore)+1:n==="between"?r.estimated_count=Tde*Oo(e.primaryStore)+1:n==="sort"?r.estimated_count=Oo(e.primaryStore)+1:r.estimated_count=Sde*Oo(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function uS(e){if(e)if(Aa=e,Wu.lastIndex=0,bde.test(e))try{let t=rE(new ju,"");if(bn!==Aa.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 ${bn} in '${Aa}'`,t}else return new URLSearchParams(e)}function rE(e,t){let r=Wu,n,s,i,o,c,l=decodeURIComponent,u;for(;n=r.exec(Aa);){bn=r.lastIndex;let[,d,_]=n;if(o){if(d)throw new SyntaxError(`expected operator, but encountered '${d}'`);o=!1,c=!1}else c=!0;let E;switch(_){case"=":if(s!=null){if(d.length<=2)i=d;else throw new SyntaxError(`invalid FIQL operator ${d}`);l=Wq}else{if(l=decodeURIComponent,i="equals",!d)throw new SyntaxError("attribute must be specified before equality comparator");s=nE(d)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=Rde[_],l=tN[i]?Wq:decodeURIComponent,!d)throw new SyntaxError(`attribute must be specified before comparator ${_}`);s=nE(d);break;case"&=":case"|=":case"|":case"&":case"":case void 0:if(s==null){if(s===void 0)throw t?new SyntaxError(`expected '${t}', but encountered ${_[0]?"'"+_[0]+"'":"end of string"}}`):new SyntaxError(`no comparison specified before ${_?"'"+_+"'":"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(d)};if(i==="eq"&&jq(h,d),s===""){let T=e.conditions[e.conditions.length-1];T.chainedConditions=T.chainedConditions||[],T.chainedConditions.push(h),T.operator=u}else cS(e,u),e.conditions.push(h)}_==="&"?(u="and",s=void 0):_==="|"?(u="or",s=void 0):_==="&="?(u="and",s=""):_==="|="&&(u="or",s="");break;case",":if(e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");e.push(nE(d)),s=void 0;break;case"(":Wu.lastIndex=bn;let f=rE(d?[]:new ju,")");switch(d){case"":cS(e,u),e.conditions.push(f);break;case"limit":switch(f.length){case 1:e.limit=+f[0];break;case 2:e.offset=+f[0],e.limit=f[1]-e.offset;break;default:throw new SyntaxError("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(f[0])&&f.length===1&&!f[0].name?(e.select=f[0],e.select.asArray=!0):f.length===1?e.select=f[0]:f.length===2&&f[1]===""?e.select=f.slice(0,1):e.select=f;break;case"group-by":throw new SyntaxError("group by is not implemented yet");case"sort":e.sort=zq(f);break;default:throw new SyntaxError(`unknown query function call ${d}`)}Aa[bn]===","?r.lastIndex=++bn:o=!0,s=null;break;case"{":if(e.conditions)throw new SyntaxError("property sets are not allowed in a queries");if(!d)throw new SyntaxError("property sets must have a defined parent property name");Wu.lastIndex=bn,E=rE([],"}"),E.name=d,e.push(E),Aa[bn]===","?r.lastIndex=++bn:o=!0;break;case"[":Wu.lastIndex=bn,d?(E=rE(new ju,"]"),E.name=d):E=rE(e.conditions?new ju:[],"]"),e.conditions?(cS(e,u),e.conditions.push(E),s=null):e.push(E),Aa[bn]===","?r.lastIndex=++bn:o=!0;break;case")":case"]":case"}":if(t===_[0]){if(e.conditions){if(s){let h={comparator:i||"equals",attribute:s,value:l(d)};i==="eq"&&jq(h,d),cS(e,u),e.conditions.push(h)}else if(d)throw new SyntaxError("no attribute or comparison specified")}else(d||e.length>0&&c)&&e.push(nE(d));return e}else throw t?new SyntaxError(`expected '${t}', but encountered '${_[0]}'`):new SyntaxError(`unexpected token '${_[0]}'`);default:throw new SyntaxError(`unexpected operator '${_}'`)}if(t!==")"&&(r=s?Ode:Wu,r.lastIndex=bn),bn===Aa.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function cS(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 nE(e){return e.indexOf(".")>-1?e.split(".").map(nE):decodeURIComponent(e)}function Wq(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 On.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function jq(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new On.ClientError("wildcard can only be used at the end of a string")}function zq(e){let t=Qq(e[0]);return e.length>1&&(t.next=zq(e.slice(1))),t}function Qq(e){if(Array.isArray(e)){let t=Qq(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 Qu(e){return Array.isArray(e)?e.join("\0"):e}function Oo(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function Nde(e,t,r){return t*r/Oo(e)}var On,bs,Ui,Ra,Sde,Tde,gde,Rde,tN,nN,bde,Wu,Ode,bn,Aa,ju,Xc,iE=Oe(()=>{On=L(_e()),bs=L(Bt()),Ui=require("ordered-binary"),Ra=require("lmdb");oE();Sde=.3,Tde=.1,gde=.05,Rde={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},tN={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(rN,"executeConditions");a(zu,"searchByIndex");a(vi,"findAttribute");a(Ade,"joinTo");a(yde,"joinFrom");nN={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(sE,"filterByType");a(lS,"estimateCondition");bde=/[()[\]|!<>.]|(=\w*=)/,Wu=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,Ode=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(uS,"parseQuery");a(rE,"parseBlock");a(cS,"assignOperator");a(nE,"decodeProperty");a(Wq,"typedDecoding");a(jq,"wildcardDecoding");a(zq,"toSortObject");a(Qq,"toSortEntry");ju=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(Qu,"flattenKey");a(Oo,"estimatedEntryCount");a(Nde,"intersectionEstimate");Xc=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});function t$(e){let t={openapi:Ide,info:{title:"HarperDB HTTP REST interface",version:(0,e$.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={},d=[];if(o)for(let{type:b,name:I,elements:B,relationship:H,definition:X}of o){if(H)b==="array"?u[I]={type:"array",items:{$ref:ba+B.type}}:u[I]={$ref:ba+b};else{let Y=X??B?.definition;if(Y){if(!t.components.schemas[Y.type]){let V={};Y.properties.forEach(ne=>{V[ne.name]=new aN(sN[ne.type],ne.type)}),t.components.schemas[Y.type]=new Zq(V)}b==="array"?u[I]={type:"array",items:{$ref:ba+Y.type}}:u[I]={$ref:ba+Y.type}}else b==="array"?B.type==="Any"||B.type=="ID"?u[I]={type:"array",items:{format:B.type}}:u[I]={type:"array",items:new aN(sN[B.type],B.type)}:b==="Any"||b=="ID"?u[I]={format:b}:u[I]=new aN(sN[b],b)}d.push(new cN(I,"query",u[I]))}let _=Object.keys(u),E=new cN(c,"path",{format:"ID"});E.required=!0,E.description="primary key of record";let f=new cN("property","path",{enum:_});f.required=!0,t.components.schemas[i]=new Zq(u);let h=l.post!==Resource.prototype.post||l.update,T=typeof l.put=="function",m=typeof l.get=="function",g=typeof l.delete=="function",S="/"+s+"/";h&&(t.paths[S]={},t.paths[S].post=new wde(i,r,"create a new record auto-assigning a primary key")),m&&(t.paths[S]||(t.paths[S]={}),t.paths[S].get=new iN(d,r,{200:new oN({$ref:ba+i})},"search for records by the specified property name and value pairs")),g&&(t.paths[S]||(t.paths[S]={}),t.paths[S].delete=new Xq(d,r,"delete all the records that match the provided query",{204:new Jq})),S="/"+s+"/{"+c+"}",m&&(t.paths[S]={},t.paths[S].get=new iN([E],r,{200:new oN({$ref:ba+i})},"retrieve a record by its primary key")),T&&(t.paths[S]||(t.paths[S]={}),t.paths[S].put=new Cde([E],r,i,"create or update the record with the URL path that maps to the record's primary key")),g&&(t.paths[S]||(t.paths[S]={}),t.paths[S].delete=new Xq([E],r,"delete a record with the given primary key",{204:new Jq})),m&&f.schema.enum.length>0&&(S="/"+s+"/{"+c+"}.{property}",t.paths[S]={},t.paths[S].get=new iN([E,f],r,{200:new oN({enum:_})},"used to retrieve the specified property of the specified record"))}return t}function wde(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:ba+e}}}},this.security=t,this.responses={200:{description:lN,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function iN(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function oN(e){this.description=lN,this.content={"application/json":{schema:e}}}function Jq(){this.description="successfully processed request, no content returned to client"}function Cde(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:ba+r}}}},this.responses={200:{description:lN}}}function Xq(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function Zq(e){this.type="object",this.properties=e}function aN(e,t){this.type=e,this.format=t}function cN(e,t,r){this.name=e,this.in=t,this.schema=r}var e$,Ide,sN,ba,lN,r$=Oe(()=>{e$=L(Uc()),Ide="3.0.3",sN={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},ba="#/components/schemas/",lN="successful operation";a(t$,"generateJsonApi");a(wde,"Post");a(iN,"Get");a(oN,"Response200");a(Jq,"Response204");a(Cde,"Put");a(Xq,"Delete");a(Zq,"ResourceSchema");a(aN,"Type");a(cN,"Parameter")});var _S={};je(_S,{parseHeaderValue:()=>dN,start:()=>Lde});async function Pde(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream",s=n?"CONNECT":e.method;e.search&&uS(e);let i=new So;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==n$){let m=dS.getMatch(o,n?"sse":"rest");if(!m)return t(e);e.handlerPath=m.path,c=new Xc(m.relativeURL),c.async=!0,l=m.Resource}if(l?.isCaching){let m=r["cache-control"];if(m){let g=dN(m);for(let S of g)switch(S.name){case"max-age":e.expiresAt=S.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 m=dN(u).map(g=>(g.next?.name==="confirm"&&g.next.value>=0&&(e.replicatedConfirmation=+g.next.value),g.name));e.replicateTo=m.length===1&&+m[0]>=0?+m[0]:m[0]==="*"?void 0:m}r["x-replicate-from"]==="none"&&(e.replicateFrom=!1);let _=await Dt(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=bo(r["content-type"],!0)(e.body,e.headers)}catch(m){throw new Ju.ClientError(m,400)}if(e.authorize=!0,o===n$&&s==="GET"){if(e?.user?.role?.permission?.super_user)return t$(dS);throw new Ju.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 Ju.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Ju.ServerError(`Method ${s} is not recognized`,501)}}),E=200,f;if(_==null)E=s==="GET"||s==="HEAD"?404:204,uN.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(_.status>0&&_.headers){let m=hO(_.headers,i);return _.headers!==m&&(_.headers=m),_.data!==void 0&&(_.body=eE(_.data,e,_)),_}else if(f=e.lastModified){Dde[0]=f;let m=String.fromCharCode(34,(vr[0]&63)+62,(vr[0]>>6)+(vr[1]<<2&63)+62,(vr[1]>>4)+(vr[2]<<4&63)+62,(vr[2]>>2)+62,(vr[3]&63)+62,(vr[3]>>6)+(vr[4]<<2&63)+62,(vr[4]>>4)+(vr[5]<<4&63)+62,(vr[5]>>2)+62,(vr[6]&63)+62,(vr[6]>>6)+(vr[7]<<2&63)+62,34),g=r["if-none-match"];g&&m==g?(_?.onDone&&_.onDone(),E=304,_=void 0):i.setIfNone("ETag",m),uN.lastModified&&i.setIfNone("Last-Modified",new Date(f).toUTCString())}e.createdResource&&(E=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let h={status:E,headers:i,body:void 0},T=_?.wasLoadedFromSource?.();return T!==void 0&&(h.wasCacheMiss=T,!T&&f&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||f))/1e3))),_!==void 0&&(h.body=eE(_,e,h),s==="HEAD"&&(h.body=void 0)),h}catch(o){o.statusCode?o.statusCode===500?Bi.warn(o):Bi.info(o):Bi.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=eE(o.contentType?o:o.toString(),e,c),c}}function Lde(e){uN=e,!s$&&(s$=!0,dS=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return Pde(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{aE++;let s=new Mn;i$||(i$=!0,x_(l=>{aE>0&&l.push({metric:"ws-connections",connections:aE,byThread:!0})}));let i;t.on("error",l=>{i=!0,Bi.warn(l)});let o;t.on("message",a(function(u){o||(o=bo(r.requestedContentType??r.headers.asObject["content-type"],!1));let d=o(u);s.push(d)},"message"));let c;t.on("close",()=>{aE--,qn(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),u=dS.getMatch(l,"ws");if(qn(!!u,"connection","ws","connect"),u){r.handlerPath=u.path,pr(h=>({count:h.count,total:aE}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let d=new Xc(u.relativeURL),_=u.Resource;c=(await Dt(r,()=>_.connect(d,s,r)))[Symbol.asyncIterator]();let f;for(;!(f=await c.next()).done;){let h=Yc(f.value,r);t.send(h),pr(h.length,"bytes-sent",r.handlerPath,"message","ws")}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){l.statusCode?l.statusCode===500?Bi.warn(l):Bi.info(l):Bi.error(l),t.close(Mde[l.statusCode]||1011,l.toString())}t.close()},e))}function dN(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 Bi,Ju,vr,Dde,uN,n$,s$,dS,i$,aE,Mde,o$=Oe(()=>{Wc();Ni();Bi=L(W()),Ju=L(_e());iE();wl();mc();Bf();r$();iE();vr=new Uint8Array(8),Dde=new Float64Array(vr.buffer,0,1),uN={},n$="openapi";a(Pde,"http");aE=0;a(Lde,"start");Mde={401:3e3,403:3003};a(dN,"parseHeaderValue")});var _N=N((GDe,c$)=>{var{recordAction:fS,recordActionBinary:a$}=(Ni(),oe(k_)),Ude=require("fastify-plugin"),vde=200;c$.exports=Ude(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,d,_;l.config?.isOperation?(u=n.body?.operation,d="operation"):(u=l.url,d="fastify-route",_=l.method),fS(o,"duration",u,_,d),a$(s.raw.statusCode<400,"success",u,_,d),a$(1,"response_"+s.raw.statusCode,u,_,d);let E=vde;i?.pipe?(i.on("data",m=>{E+=m.length}),i.on("end",()=>{fS(performance.now()-c,"transfer",u,_,d),fS(E,"bytes-sent",u,_,d)})):(E+=i?.length||0,fS(E,"bytes-sent",u,_,d));let f=o.toFixed(3),h=s.getHeader("Server-Timing"),T=`db;dur=${f}`;s.header("Server-Timing",h?`${h}, ${T}`:T)}),r()},{name:"hdb-request-time"})});var SN=N((VDe,_$)=>{var mS=require("clone"),SS=Tt(),Bde=te(),hS=M(),qDe=W(),fN=require("fs"),hN=require("joi"),{string:pS}=hN.types(),{hdb_errors:Hde,handleHDBError:ES}=_e(),{HDB_ERROR_MSGS:$De,HTTP_STATUS_CODES:EN}=Hde,{common_validators:Xu}=Ti(),l$=" is required",xde=["insert","update","upsert"],pN={database:{presence:!1,format:Xu.schema_format,length:Xu.schema_length},schema:{presence:!1,format:Xu.schema_format,length:Xu.schema_length},table:{presence:!0,format:Xu.schema_format,length:Xu.schema_length},action:{inclusion:{within:xde,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},kde={schema:pS.required(),table:pS.required(),action:pS.valid("insert","update","upsert")},{AWS_ACCESS_KEY:Fde,AWS_SECRET:Gde,AWS_BUCKET:qde,AWS_FILE_KEY:$de,REGION:Vde}=hS.S3_BUCKET_AUTH_KEYS,Kde={s3:{presence:!0},[`s3.${Fde}`]:{presence:!0,type:"String"},[`s3.${Gde}`]:{presence:!0,type:"String"},[`s3.${qde}`]:{presence:!0,type:"String"},[`s3.${$de}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${Vde}`]:{presence:!0,type:"String"}},u$=mS(pN);u$.data.presence={message:l$};var d$=mS(pN);d$.file_path.presence={message:l$};var Yde=Object.assign(mS(pN),Kde),mN=mS(kde);mN.csv_url=pS.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();mN.passthrough_headers=hN.object();function Wde(e){let t=SS.validateObject(e,u$);return TS(e,t)}a(Wde,"dataObject");function jde(e){let t=SS.validateBySchema(e,hN.object(mN));return TS(e,t)}a(jde,"urlObject");function zde(e){let t=SS.validateObject(e,d$);return TS(e,t)}a(zde,"fileObject");function Qde(e){let t=SS.validateObject(e,Yde);return TS(e,t)}a(Qde,"s3FileObject");function TS(e,t){if(!t){let r=Bde.checkGlobalSchemaTable(e.schema,e.table);if(r)return ES(new Error,r,EN.BAD_REQUEST);if(e.operation===hS.OPERATIONS_ENUM.CSV_FILE_LOAD)try{fN.accessSync(e.file_path,fN.constants.R_OK|fN.constants.F_OK)}catch(n){return n.code===hS.NODE_ERROR_CODES.ENOENT?ES(n,`No such file or directory ${n.path}`,EN.BAD_REQUEST):n.code===hS.NODE_ERROR_CODES.EACCES?ES(n,`Permission denied ${n.path}`,EN.BAD_REQUEST):ES(n)}}return t}a(TS,"postValidateChecks");_$.exports={dataObject:Wde,urlObject:jde,fileObject:zde,s3FileObject:Qde}});var TN=N((YDe,f$)=>{"use strict";var cE=W(),gS=M();async function Jde(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===gS.OPERATIONS_ENUM.INSERT||t.operation===gS.OPERATIONS_ENUM.UPDATE||t.operation===gS.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===gS.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(cE.info(i.message),i):i.http_resp_msg?(cE.error(`Error calling operation: ${e.name}`),cE.error(i.http_resp_msg),i):(cE.error(`Error calling operation: ${e.name}`),cE.error(i),i)}}a(Jde,"callOperationFunctionAsAwait");f$.exports={callOperationFunctionAsAwait:Jde}});var h$=N((jDe,E$)=>{"use strict";var gN=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}},RN=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};E$.exports={BulkLoadFileObject:gN,BulkLoadDataObject:RN}});var m$=N((QDe,p$)=>{"use strict";var AN=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};p$.exports=AN});var wN=N((rPe,U$)=>{"use strict";var RS=un(),yS=SN(),Xde=require("needle"),ri=M(),XDe=Ct(),Zu=te(),{handleHDBError:qt,hdb_errors:N$}=_e(),{HTTP_STATUS_CODES:Br,HDB_ERROR_MSGS:Rr,CHECK_LOGS_WRAPPER:el}=N$,ed=W(),yN=require("papaparse");Zu.promisifyPapaParse();var ni=require("fs-extra"),Zde=require("path"),{chain:S$}=require("stream-chain"),T$=require("stream-json/streamers/StreamArray"),g$=require("stream-json/utils/Batch"),R$=require("stream-chain/utils/comp"),{finished:A$}=require("stream"),e_e=se(),I$=TN(),t_e=xO(),{BulkLoadFileObject:ON,BulkLoadDataObject:r_e}=h$(),NN=wO(),{verifyBulkLoadAttributePerms:w$}=Xm(),ZDe=m$(),ePe=mr(),tPe=to(),{databases:n_e}=(Pe(),oe(lt)),{coerceType:s_e}=(oE(),oe(CN)),y$="No records parsed from csv file.",Zc=`${e_e.get("HDB_ROOT")}/tmp`,{schema_regex:i_e}=Ti(),b$=1024*1024*2,O$=5e3,o_e={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};U$.exports={csvDataLoad:a_e,csvURLLoad:c_e,csvFileLoad:l_e,importFromS3:u_e};async function a_e(e,t){let r=yS.dataObject(e);if(r)throw qt(r,r.message,Br.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=P$(e.schema,e.table),i=yN.parse(e.data,{header:!0,skipEmptyLines:!0,transform:bN.bind(null,s),dynamicTyping:!1}),o=new NN;e.hdb_user&&e.hdb_user?.role&&e.hdb_user?.role?.permission&&e.hdb_user?.role?.permission?.super_user!==!0&&w$(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 qt(new Error,c,Br.BAD_REQUEST,void 0,void 0,!0);let l=new r_e(e.action,e.schema,e.table,i.data);return n=await I$.callOperationFunctionAsAwait(L$,l,null),n.message===y$?y$:M$(n.records,n.number_written)}catch(s){throw tl(s)}}a(a_e,"csvDataLoad");async function c_e(e){let t=yS.urlObject(e);if(t)throw qt(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${Zc}/${r}`;try{await d_e(e,r)}catch(s){throw ed.error(Rr.DOWNLOAD_FILE_ERR(r)+" - "+s),qt(s,el(Rr.DOWNLOAD_FILE_ERR(r)))}try{let s=new ON(this.job_operation_function.name,e.action,e.schema,e.table,n,ri.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission),i=await IN(s);return await AS(n),i}catch(s){throw await AS(n),tl(s)}}a(c_e,"csvURLLoad");async function l_e(e){let t=yS.fileObject(e);if(t)throw qt(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r=new ON(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,ri.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission);try{return await IN(r)}catch(n){throw tl(n)}}a(l_e,"csvFileLoad");async function u_e(e){let t=yS.s3FileObject(e);if(t)throw qt(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=Zde.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${Zc}/${s}`;let i=new ON(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user?.role?.permission);await __e(s,e);let o=await IN(i);return await AS(r),o}catch(n){throw await AS(r),tl(n)}}a(u_e,"importFromS3");async function d_e(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await Xde("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 qt(n,s,n.statusCode,ri.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}E_e(r,e.csv_url),await f_e(t,r.raw)}a(d_e,"downloadCSVFile");async function __e(e,t){try{let r=`${Zc}/${e}`;await ni.mkdirp(Zc),await ni.writeFile(`${Zc}/${e}`,"",{flag:"a+"});let n=await ni.createWriteStream(r),s=await t_e.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(){ed.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw ed.error(Rr.S3_DOWNLOAD_ERR+" - "+r),qt(r,el(Rr.S3_DOWNLOAD_ERR))}}a(__e,"downloadFileFromS3");async function f_e(e,t){try{await ni.mkdirp(Zc),await ni.writeFile(`${Zc}/${e}`,t)}catch(r){throw ed.error(Rr.WRITE_TEMP_FILE_ERR),qt(r,el(Rr.DEFAULT_BULK_LOAD_ERR))}}a(f_e,"writeFileToTempFolder");async function AS(e){if(e)try{await ni.access(e),await ni.unlink(e)}catch{ed.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(AS,"deleteTempFile");function E_e(e,t){if(e.statusCode!==N$.HTTP_STATUS_CODES.OK)throw qt(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,Br.BAD_REQUEST);if(!o_e[e.headers["content-type"]])throw qt(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,Br.BAD_REQUEST);if(!e.raw)throw qt(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,Br.BAD_REQUEST)}a(E_e,"validateURLResponse");async function IN(e){try{let t;switch(e.file_type){case ri.VALID_S3_FILE_TYPES.CSV:t=await h_e(e);break;case ri.VALID_S3_FILE_TYPES.JSON:t=await p_e(e);break;default:throw qt(new Error,Rr.DEFAULT_BULK_LOAD_ERR,Br.BAD_REQUEST,ri.LOG_LEVELS.ERROR,Rr.INVALID_FILE_EXT_ERR(e))}return M$(t.records,t.number_written)}catch(t){throw tl(t)}}a(IN,"fileLoad");async function C$(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 RS.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&w$(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let l=qt(c);r(l)}}a(C$,"validateChunk");async function D$(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;Zu.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Zu.isEmpty(c)&&!Zu.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 I$.callOperationFunctionAsAwait(L$,c,null);t.records+=l.records,t.number_written+=l.number_written,s&&s.resume()}catch(c){let l=qt(c,el(Rr.INSERT_CSV_ERR),Br.INTERNAL_SERVER_ERROR,ri.LOG_LEVELS.ERROR,Rr.INSERT_CSV_ERR+" - "+c);r(l)}}a(D$,"insertChunk");async function h_e(e){let t={records:0,number_written:0},r=P$(e.schema,e.table);try{let n=new NN,s=ni.createReadStream(e.file_path,{highWaterMark:b$});s.setEncoding("utf8"),await yN.parsePromise(s,C$.bind(null,e,n),bN.bind(null,r));let i=n.getPermsResponse();if(i)throw qt(new Error,i,Br.BAD_REQUEST);return s=ni.createReadStream(e.file_path,{highWaterMark:b$}),s.setEncoding("utf8"),await yN.parsePromise(s,D$.bind(null,e,t),bN.bind(null,r)),s.destroy(),t}catch(n){throw qt(n,el(Rr.PAPA_PARSE_ERR),Br.INTERNAL_SERVER_ERROR,ri.LOG_LEVELS.ERROR,Rr.PAPA_PARSE_ERR+n)}}a(h_e,"callPapaParse");function P$(e,t){let r=n_e[e][t].attributes,n=new Map;for(let s of r)s.type&&!s.computed&&!s.relationship&&n.set(s.name,i=>s_e(i,s));return n}a(P$,"createTransformMap");function bN(e,t,r){let n=e.get(r);return n?n(t):Zu.autoCast(t)}a(bN,"typeFunction");async function p_e(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new NN,s=S$([ni.createReadStream(e.file_path,{encoding:"utf-8"}),T$.withParser(),c=>c.value,new g$({batchSize:O$}),R$(async c=>{await C$(e,n,r,c)})]);await new Promise((c,l)=>{A$(s,u=>{u?l(u):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw qt(new Error,i,Br.BAD_REQUEST);let o=S$([ni.createReadStream(e.file_path,{encoding:"utf-8"}),T$.withParser(),c=>c.value,new g$({batchSize:O$}),R$(async c=>{await D$(e,t,r,c)})]);return await new Promise((c,l)=>{A$(o,u=>{u?l(u):c()}),o.resume()}),t}catch(n){throw qt(n,el(Rr.INSERT_JSON_ERR),Br.INTERNAL_SERVER_ERROR,ri.LOG_LEVELS.ERROR,Rr.INSERT_JSON_ERR+n)}}a(p_e,"insertJson");async function L$(e){let t={};try{e.data&&e.data.length>0&&m_e(e.data[0])?t=await S_e(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",ed.info(t.message))}catch(r){throw tl(r)}return t}a(L$,"callBulkFileLoad");function m_e(e){let t=Object.keys(e);for(let r of t)if(!i_e.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(m_e,"validateColumnNames");async function S_e(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=RS.insert;break;case"update":i=RS.update;break;case"upsert":i=RS.upsert;break;default:throw qt(new Error,Rr.INVALID_ACTION_PARAM_ERR(n),Br.BAD_REQUEST,ri.LOG_LEVELS.ERROR,Rr.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 d=global.hdb_schema[t][r].hash_attribute,_=e.length;for(;_--;)o.skipped_hashes.indexOf(e[_][d])>=0&&e.splice(_,1)}let l=Zu.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw tl(o)}}a(S_e,"bulkFileLoad");function M$(e,t){return`successfully loaded ${t} of ${e} records`}a(M$,"buildResponseMsg");function tl(e){return qt(e,el(Rr.DEFAULT_BULK_LOAD_ERR),Br.INTERNAL_SERVER_ERROR,ri.LOG_LEVELS.ERROR,Rr.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(tl,"buildTopLevelErrMsg")});var B$=N((sPe,v$)=>{"use strict";var DN=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};v$.exports=DN});var k$=N((oPe,x$)=>{"use strict";var T_e=M(),H$=require("moment"),g_e=require("uuid").v4,PN=class{static{a(this,"JobObject")}constructor(){this.id=g_e(),this.type=void 0,this.start_datetime=H$().valueOf(),this.created_datetime=H$().valueOf(),this.end_datetime=void 0,this.status=T_e.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};x$.exports=PN});var LN=N((cPe,W$)=>{"use strict";var R_e=require("uuid").v4,V$=un(),K$=Vr(),A_e=$s(),y_e=Vl(),b_e=B$(),bt=M(),O_e=k$(),N_e=Hp(),Ns=W(),I_e=Qd(),td=te(),{promisify:w_e}=require("util"),rl=require("moment"),C_e=eS(),bS=SN(),F$=yR(),{deleteTransactionLogsBeforeValidator:D_e}=yO(),{handleHDBError:G$,hdb_errors:P_e}=_e(),{HTTP_STATUS_CODES:q$}=P_e,$$=K$.searchByValue,L_e=K$.searchByHash,M_e=V$.insert,U_e=w_e(C_e.evaluateSQL),v_e=V$.update;W$.exports={addJob:x_e,updateJob:F_e,handleGetJob:B_e,handleGetJobsByStartDate:H_e,getJobById:Y$};async function B_e(e){try{let t=await Y$(e.id);return td.isEmptyOrZeroLength(t)||(t[0]={...t[0]},t[0].request!==void 0&&delete t[0].request,delete t[0].__createdtime__,delete t[0].__updatedtime__),t}catch(t){let r=`There was an error getting job: ${t}`;throw Ns.error("There was an error getting job",t),new Error(r)}}a(B_e,"handleGetJob");async function H_e(e){try{let t=await k_e(e);if(Ns.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=rl(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=rl(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 Ns.error(r),new Error(r)}}a(H_e,"handleGetJobsByStartDate");async function x_e(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||td.isEmptyOrZeroLength(e.operation)){let d="job parameter is invalid";return Ns.info(d),t.error=d,t}if(!bt.JOB_TYPE_ENUM[e.operation])return Ns.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case bt.OPERATIONS_ENUM.CSV_FILE_LOAD:n=bS.fileObject(e);break;case bt.OPERATIONS_ENUM.CSV_URL_LOAD:n=bS.urlObject(e);break;case bt.OPERATIONS_ENUM.CSV_DATA_LOAD:n=bS.dataObject(e);break;case bt.OPERATIONS_ENUM.IMPORT_FROM_S3:n=bS.s3FileObject(e);break;case bt.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case bt.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=F$(e,"date");break;case bt.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=F$(e,"timestamp");break;case bt.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=D_e(e);break;case bt.OPERATIONS_ENUM.RESTART_SERVICE:if(bt.PROCESS_DESCRIPTORS_VALIDATE[e.service]===void 0)throw G$(new Error,"Invalid service",q$.BAD_REQUEST,void 0,void 0,!0);break;default:break}if(n)throw G$(n,n.message,q$.BAD_REQUEST,void 0,void 0,!0);let s=new O_e;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 A_e(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await $$(i))}catch(d){let _=`There was an error inserting a new job: ${d}`;return Ns.error(_),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=R_e();try{o=await $$(i)}catch(d){let _=`There was an error inserting a new job: ${d}`;return Ns.error(_),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return Ns.error("Error creating a job, could not find a unique job id."),t}s.request=e;let l=new I_e(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),u;try{u=await M_e(l)}catch(d){return Ns.error(`There was an error inserting a job for job type: ${e.operation} -- ${d}`),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 d=`Created a job with type ${s.type} and id ${s.id}`;t.message=d,t.createdJob=s,t.success=!0,Ns.trace(d)}return t}a(x_e,"addJob");async function k_e(e){let t=rl(e.from_date,rl.ISO_8601),r=rl(e.to_date,rl.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 b_e(n,e.hdb_user);try{return await U_e(s)}catch(i){throw Ns.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(k_e,"getJobsInDateRange");async function Y$(e){if(td.isEmptyOrZeroLength(e))return td.errorizeMessage("Invalid job ID specified.");let t=new y_e(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await L_e(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return Ns.error(n),td.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(Y$,"getJobById");async function F_e(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(td.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=rl().valueOf());let t=new N_e(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await v_e(t),r}a(F_e,"updateJob")});var tV=N((uPe,eV)=>{"use strict";var j$=te(),Ar=M(),G_e=require("moment"),OS=wN(),lE=W(),z$=LN(),Q$=tS(),J$=uc(),X$=dt(),q_e=jm(),$_e=xu(),{parentPort:V_e,isMainThread:Z$}=require("worker_threads"),{onMessageByType:K_e}=dt(),MN=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function Y_e(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(j$.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(j$.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case Ar.JOB_TYPE_ENUM.csv_file_load:await Hi(e,OS.csvFileLoad);break;case Ar.JOB_TYPE_ENUM.csv_url_load:await Hi(e,OS.csvURLLoad);break;case Ar.JOB_TYPE_ENUM.csv_data_load:await Hi(e,OS.csvDataLoad);break;case Ar.JOB_TYPE_ENUM.import_from_s3:await Hi(e,OS.importFromS3);break;case Ar.JOB_TYPE_ENUM.empty_trash:break;case Ar.JOB_TYPE_ENUM.export_local:await Hi(e,Q$.export_local);break;case Ar.JOB_TYPE_ENUM.export_to_s3:await Hi(e,Q$.export_to_s3);break;case Ar.JOB_TYPE_ENUM.delete_files_before:case Ar.JOB_TYPE_ENUM.delete_records_before:await Hi(e,J$.deleteFilesBefore);break;case Ar.JOB_TYPE_ENUM.delete_audit_logs_before:await Hi(e,J$.deleteAuditLogsBefore);break;case Ar.JOB_TYPE_ENUM.delete_transaction_logs_before:await Hi(e,q_e.deleteTransactionLogsBefore);break;case Ar.JOB_TYPE_ENUM.restart_service:return await Hi(e,$_e.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(Y_e,"parseMessage");async function Hi(e,t){try{e.job.status=Ar.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=G_e().valueOf(),await z$.updateJob(e.job),await W_e(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):lE.error(`There was an error running ${t.name} job with id ${e.job.id}`),lE.error(n),e.job.message=n,e.job.status=Ar.JOB_STATUS_ENUM.ERROR;try{await z$.updateJob(e.job)}catch(s){throw lE.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(Hi,"runJob");async function W_e(e){lE.trace("launching job thread:",e),Z$?X$.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Ar.PROCESS_NAME_ENV_PROP]:`JOB-${e}`}}):V_e.postMessage({type:Ar.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(W_e,"launchJobThread");Z$&&K_e(Ar.ITC_EVENT_TYPES.START_JOB,async(e,t)=>{try{X$.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Ar.PROCESS_NAME_ENV_PROP]:`JOB-${e.jobId}`}})}catch(r){lE.error(r)}});eV.exports={parseMessage:Y_e,RunnerMessage:MN}});var nV=N((_Pe,rV)=>{"use strict";var UN=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};rV.exports=UN});var RV=N((hPe,FN)=>{"use strict";var DS=Vr(),HN=eS(),NS=wN(),No=em(),IS=ro(),dE=uc(),j_e=zy(),uE=xn(),wS=lf(),Lt=AO(),CS=W(),z_e=ob(),Q_e=pf(),sV=Lb(),J_e=Rf(),X_e=vb(),Z_e=Bb(),efe=mm(),tfe=Fb(),vN=Tm(),iV=tS(),rfe=Xm(),xN=LN(),$=M(),{hdb_errors:fE,handleHDBError:_E}=_e(),{HTTP_STATUS_CODES:oV}=fE,BN=Wb(),aV=xu(),mV=require("util"),nd=un(),nfe=ls(),sfe=Ou(),cV=tV(),lV=lu(),uV=(xm(),oe(Hf)),dV=wt(),_V=jm(),fV=kf(),{setServerUtilities:ife}=(oE(),oe(CN)),{CONTEXT:EPe}=(Vs(),oe(_A)),{_assignPackageExport:ofe}=fi(),{transformReq:afe}=te(),{server:cfe}=(qr(),oe(Qa)),tn=CS.loggerWithTag("operation"),rd=Xs(),EV=(Hc(),oe(Bc)),lfe=TN(),hV=DS.searchByHash,ufe=DS.searchByValue,dfe=mV.promisify(DS.search),_fe=mV.promisify(HN.evaluateSQL),ffe={[$.OPERATIONS_ENUM.CREATE_ATTRIBUTE]:!0,[$.OPERATIONS_ENUM.CREATE_TABLE]:!0,[$.OPERATIONS_ENUM.CREATE_SCHEMA]:!0,[$.OPERATIONS_ENUM.DROP_ATTRIBUTE]:!0,[$.OPERATIONS_ENUM.DROP_TABLE]:!0,[$.OPERATIONS_ENUM.DROP_SCHEMA]:!0},J=nV();async function SV(e,t){try{if(e.body.operation!=="read_log"&&(CS.log_level===$.LOG_LEVELS.INFO||CS.log_level===$.LOG_LEVELS.DEBUG||CS.log_level===$.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,payload:o,...c}=e.body;tn.info(c)}}catch(n){tn.error(n)}let r=await lfe.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return ffe[e.body.operation]&&nfe.setSchemaDataToGlobal(n=>{n&&tn.error(n)}),r}a(SV,"processLocalTransaction");var pV=hfe();FN.exports={chooseOperation:TV,getOperationFunction:gV,operation:kN,processLocalTransaction:SV};ife(FN.exports);cfe.operation=kN;function TV(e){let t;try{t=gV(e)}catch(s){throw tn.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=HN.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=HN.checkASTPermissions(e,i);if(o)throw tn.error(`${oV.FORBIDDEN} from operation ${e.operation}`),tn.warn(`User '${e.hdb_user?.username}' is not permitted to ${e.operation}`),_E(new Error,o,fE.HTTP_STATUS_CODES.FORBIDDEN,void 0,void 0,!0)}}else if(!e.bypass_auth&&e.operation!==$.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.operation!==$.OPERATIONS_ENUM.LOGIN&&e.operation!==$.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=rfe.verifyPerms(i,s);if(o)throw tn.error(`${oV.FORBIDDEN} from operation ${e.operation}`),tn.warn(`User '${i.hdb_user?.username}' is not permitted to ${i.operation}`),_E(new Error,o,fE.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw _E(s,"There was an error when trying to choose an operation path")}return r}a(TV,"chooseOperation");function gV(e){if(tn.trace(`getOperationFunction with operation: ${e.operation}`),pV.has(e.operation))return pV.get(e.operation);throw _E(new Error,fE.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),fE.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(gV,"getOperationFunction");ofe("operation",kN);function kN(e,t,r){e.hdb_user=t?.user,e.bypass_auth=!r;let n=TV(e);return SV({body:e},n)}a(kN,"operation");async function Efe(e){tn.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[$.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case $.OPERATIONS_ENUM.INSERT:o=await nd.insert(i);break;case $.OPERATIONS_ENUM.UPDATE:o=await nd.update(i);break;case $.OPERATIONS_ENUM.UPSERT:o=await nd.upsert(i);break;case $.OPERATIONS_ENUM.DELETE:o=await dE.deleteRecord(i);break;default:tn.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){tn.info("Invalid operation in transaction"),tn.error(o)}}a(Efe,"catchup");async function si(e){afe(e);let t,r;try{r=await xN.addJob(e),t=r.createdJob,tn.info("addJob result",r);let n=new cV.RunnerMessage(t,e);return{message:await cV.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 tn.error(s),_E(n,s)}}a(si,"executeJob");function hfe(){let e=new Map;return e.set($.OPERATIONS_ENUM.INSERT,new J(nd.insert)),e.set($.OPERATIONS_ENUM.UPDATE,new J(nd.update)),e.set($.OPERATIONS_ENUM.UPSERT,new J(nd.upsert)),e.set($.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new J(DS.searchByConditions)),e.set($.OPERATIONS_ENUM.SEARCH_BY_HASH,new J(hV)),e.set($.OPERATIONS_ENUM.SEARCH_BY_ID,new J(hV)),e.set($.OPERATIONS_ENUM.SEARCH_BY_VALUE,new J(ufe)),e.set($.OPERATIONS_ENUM.SEARCH,new J(dfe)),e.set($.OPERATIONS_ENUM.SQL,new J(_fe)),e.set($.OPERATIONS_ENUM.CSV_DATA_LOAD,new J(si,NS.csvDataLoad)),e.set($.OPERATIONS_ENUM.CSV_FILE_LOAD,new J(si,NS.csvFileLoad)),e.set($.OPERATIONS_ENUM.CSV_URL_LOAD,new J(si,NS.csvURLLoad)),e.set($.OPERATIONS_ENUM.IMPORT_FROM_S3,new J(si,NS.importFromS3)),e.set($.OPERATIONS_ENUM.CREATE_SCHEMA,new J(No.createSchema)),e.set($.OPERATIONS_ENUM.CREATE_DATABASE,new J(No.createSchema)),e.set($.OPERATIONS_ENUM.CREATE_TABLE,new J(No.createTable)),e.set($.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new J(No.createAttribute)),e.set($.OPERATIONS_ENUM.DROP_SCHEMA,new J(No.dropSchema)),e.set($.OPERATIONS_ENUM.DROP_DATABASE,new J(No.dropSchema)),e.set($.OPERATIONS_ENUM.DROP_TABLE,new J(No.dropTable)),e.set($.OPERATIONS_ENUM.DROP_ATTRIBUTE,new J(No.dropAttribute)),e.set($.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new J(IS.describeSchema)),e.set($.OPERATIONS_ENUM.DESCRIBE_DATABASE,new J(IS.describeSchema)),e.set($.OPERATIONS_ENUM.DESCRIBE_TABLE,new J(IS.describeTable)),e.set($.OPERATIONS_ENUM.DESCRIBE_ALL,new J(IS.describeAll)),e.set($.OPERATIONS_ENUM.DELETE,new J(dE.deleteRecord)),e.set($.OPERATIONS_ENUM.ADD_USER,new J(uE.addUser)),e.set($.OPERATIONS_ENUM.ALTER_USER,new J(uE.alterUser)),e.set($.OPERATIONS_ENUM.DROP_USER,new J(uE.dropUser)),e.set($.OPERATIONS_ENUM.LIST_USERS,new J(uE.listUsersExternal)),e.set($.OPERATIONS_ENUM.LIST_ROLES,new J(wS.listRoles)),e.set($.OPERATIONS_ENUM.ADD_ROLE,new J(wS.addRole)),e.set($.OPERATIONS_ENUM.ALTER_ROLE,new J(wS.alterRole)),e.set($.OPERATIONS_ENUM.DROP_ROLE,new J(wS.dropRole)),e.set($.OPERATIONS_ENUM.USER_INFO,new J(uE.userInfo)),e.set($.OPERATIONS_ENUM.READ_LOG,new J(z_e)),e.set($.OPERATIONS_ENUM.ADD_NODE,new J(Q_e)),e.set($.OPERATIONS_ENUM.UPDATE_NODE,new J(sV)),e.set($.OPERATIONS_ENUM.SET_NODE_REPLICATION,new J(sV)),e.set($.OPERATIONS_ENUM.REMOVE_NODE,new J(J_e)),e.set($.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new J(X_e)),e.set($.OPERATIONS_ENUM.PURGE_STREAM,new J(Z_e)),e.set($.OPERATIONS_ENUM.SET_CONFIGURATION,new J(dV.setConfiguration)),e.set($.OPERATIONS_ENUM.CLUSTER_STATUS,new J(efe.clusterStatus)),e.set($.OPERATIONS_ENUM.CLUSTER_NETWORK,new J(tfe)),e.set($.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new J(vN.setRoutes)),e.set($.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new J(vN.getRoutes)),e.set($.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new J(vN.deleteRoutes)),e.set($.OPERATIONS_ENUM.EXPORT_TO_S3,new J(si,iV.export_to_s3)),e.set($.OPERATIONS_ENUM.CREATE_CSR,new J(rd.createCsr)),e.set($.OPERATIONS_ENUM.SIGN_CERTIFICATE,new J(rd.signCertificate)),e.set($.OPERATIONS_ENUM.LIST_CERTIFICATES,new J(rd.listCertificates)),e.set($.OPERATIONS_ENUM.ADD_CERTIFICATES,new J(rd.addCertificate)),e.set($.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new J(rd.removeCertificate)),e.set($.OPERATIONS_ENUM.GET_KEY,new J(rd.getKey)),e.set($.OPERATIONS_ENUM.ADD_NODE_BACK,new J(EV.addNodeBack)),e.set($.OPERATIONS_ENUM.REMOVE_NODE_BACK,new J(EV.removeNodeBack)),e.set($.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new J(si,dE.deleteFilesBefore)),e.set($.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new J(si,dE.deleteFilesBefore)),e.set($.OPERATIONS_ENUM.EXPORT_LOCAL,new J(si,iV.export_local)),e.set($.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new J(xN.handleGetJobsByStartDate)),e.set($.OPERATIONS_ENUM.GET_JOB,new J(xN.handleGetJob)),e.set($.OPERATIONS_ENUM.GET_FINGERPRINT,new J(BN.getFingerprint)),e.set($.OPERATIONS_ENUM.SET_LICENSE,new J(BN.setLicense)),e.set($.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new J(BN.getRegistrationInfo)),e.set($.OPERATIONS_ENUM.RESTART,new J(aV.restart)),e.set($.OPERATIONS_ENUM.RESTART_SERVICE,new J(si,aV.restartService)),e.set($.OPERATIONS_ENUM.CATCHUP,new J(Efe)),e.set($.OPERATIONS_ENUM.SYSTEM_INFORMATION,new J(sfe.systemInformation)),e.set($.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new J(si,dE.deleteAuditLogsBefore)),e.set($.OPERATIONS_ENUM.READ_AUDIT_LOG,new J(j_e)),e.set($.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new J(lV.createTokens)),e.set($.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new J(lV.refreshOperationToken)),e.set($.OPERATIONS_ENUM.LOGIN,new J(uV.login)),e.set($.OPERATIONS_ENUM.LOGOUT,new J(uV.logout)),e.set($.OPERATIONS_ENUM.GET_CONFIGURATION,new J(dV.getConfiguration)),e.set($.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new J(Lt.customFunctionsStatus)),e.set($.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new J(Lt.getCustomFunctions)),e.set($.OPERATIONS_ENUM.GET_COMPONENT_FILE,new J(Lt.getComponentFile)),e.set($.OPERATIONS_ENUM.GET_COMPONENTS,new J(Lt.getComponents)),e.set($.OPERATIONS_ENUM.SET_COMPONENT_FILE,new J(Lt.setComponentFile)),e.set($.OPERATIONS_ENUM.DROP_COMPONENT,new J(Lt.dropComponent)),e.set($.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new J(Lt.getCustomFunction)),e.set($.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new J(Lt.setCustomFunction)),e.set($.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new J(Lt.dropCustomFunction)),e.set($.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new J(Lt.addComponent)),e.set($.OPERATIONS_ENUM.ADD_COMPONENT,new J(Lt.addComponent)),e.set($.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new J(Lt.dropCustomFunctionProject)),e.set($.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new J(Lt.packageComponent)),e.set($.OPERATIONS_ENUM.PACKAGE_COMPONENT,new J(Lt.packageComponent)),e.set($.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new J(Lt.deployComponent)),e.set($.OPERATIONS_ENUM.DEPLOY_COMPONENT,new J(Lt.deployComponent)),e.set($.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new J(_V.readTransactionLog)),e.set($.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new J(si,_V.deleteTransactionLogsBefore)),e.set($.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new J(fV.installModules)),e.set($.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new J(fV.auditModules)),e.set($.OPERATIONS_ENUM.GET_BACKUP,new J(No.getBackup)),e.set($.OPERATIONS_ENUM.ADD_SSH_KEY,new J(Lt.addSSHKey)),e.set($.OPERATIONS_ENUM.UPDATE_SSH_KEY,new J(Lt.updateSSHKey)),e.set($.OPERATIONS_ENUM.DELETE_SSH_KEY,new J(Lt.deleteSSHKey)),e.set($.OPERATIONS_ENUM.LIST_SSH_KEYS,new J(Lt.listSSHKeys)),e.set($.OPERATIONS_ENUM.SET_SSH_KNOWN_HOSTS,new J(Lt.setSSHKnownHosts)),e.set($.OPERATIONS_ENUM.GET_SSH_KNOWN_HOSTS,new J(Lt.getSSHKnownHosts)),e}a(hfe,"initializeOperationFunctionMap")});var LS=N((mPe,bV)=>{"use strict";var GN=M(),pfe=te(),EE=W(),{handleHDBError:qN,hdb_errors:PS}=_e(),{isMainThread:mfe}=require("worker_threads"),{Readable:Sfe}=require("stream"),AV=require("os"),Tfe=require("util"),gfe=cb(),Rfe=Tfe.promisify(gfe.authorize),yV=RV(),{createGzip:Afe,constants:yfe}=require("zlib");function bfe(e){let t=`Found an uncaught exception with message: ${e.message}. ${AV.EOL}Stack: ${e.stack} ${AV.EOL}Terminating ${mfe?"HDB":"thread"}.`;console.error(t),EE.fatal(t),process.exit(1)}a(bfe,"handleServerUncaughtException");function Ofe(e,t,r){if(EE[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:PS.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(Ofe,"serverErrorHandler");function Nfe(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=qN(new Error,"Invalid JSON.",PS.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(pfe.isEmpty(e.body.operation)){let n=qN(new Error,"Request body must include an 'operation' property.",PS.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(Nfe,"reqBodyValidationHandler");function Ife(e,t,r){let n;e.body.operation!==GN.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.body.operation!==GN.OPERATIONS_ENUM.LOGIN&&e.body.operation!==GN.OPERATIONS_ENUM.LOGOUT?Rfe(e,t).then(s=>{n=s,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(s=>{EE.warn(s),EE.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${s.stack}"`);let i=typeof s=="string"?{error:s}:{error:s.message};r(qN(s,i,PS.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(Ife,"authHandler");async function wfe(e,t,r=!1){let n;try{e.body.bypass_auth&&delete e.body.bypass_auth,n=yV.chooseOperation(e.body);let s=await yV.processLocalTransaction(e,n);if(s instanceof Sfe&&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(Afe({level:yfe.Z_BEST_SPEED})))}return s}catch(s){throw EE.error(s),s}}a(wfe,"handlePostRequest");bV.exports={authHandler:Ife,handlePostRequest:wfe,handleServerUncaughtException:bfe,serverErrorHandler:Ofe,reqBodyValidationHandler:Nfe}});var wV=N((TPe,IV)=>{"use strict";var Cfe=require("fastify-plugin"),{handlePostRequest:OV,authHandler:Dfe,reqBodyValidationHandler:Pfe}=LS();async function Lfe(e){e.decorate("hdbCore",{preValidation:[Pfe,Dfe],request:a(t=>NV(OV(t,response)),"request"),requestWithoutAuthentication:a((t,r)=>NV(OV(t,r,!0)),"requestWithoutAuthentication")})}a(Lfe,"hdbCore");async function NV(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(NV,"convertAsyncIterators");IV.exports=Cfe(Lfe)});var DV=N((APe,CV)=>{"use strict";var RPe=require("fs"),MS=se();MS.initSync();var{CONFIG_PARAMS:$N}=M(),Mfe=1024*1024*1024;function Ufe(e){let t=MS.get($N.HTTP_TIMEOUT),r=MS.get($N.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:Mfe,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,maxParamLength:MS.get($N.HTTP_MAXPARAMLENGTH)??1e3,https:e}}a(Ufe,"getServerOptions");CV.exports=Ufe});var MV=N((bPe,LV)=>{"use strict";var VN=se();VN.initSync();var{CONFIG_PARAMS:PV}=M();function vfe(){let e=VN.get(PV.HTTP_CORSACCESSLIST),t=VN.get(PV.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(vfe,"getCORSOptions");LV.exports=vfe});var BV=N((NPe,vV)=>{"use strict";var UV=se();UV.initSync();var Bfe=M();function Hfe(){return UV.get(Bfe.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(Hfe,"getHeaderTimeoutConfig");vV.exports=Hfe});var YN={};je(YN,{customFunctionsServer:()=>Ffe,ready:()=>JV,start:()=>kfe});function kfe(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){Io||(Io=QV(t),it.http((await Io).server));let o=await Io,c=(0,KN.dirname)(s),l=(0,KN.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!HV.has(c)){HV.add(c);try{o.register(qfe(c,l))}catch(u){if(u.message==="Root plugin has already booted")mt.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw u}}},ready:JV}}async function Ffe(){try{mt.info("In Custom Functions Fastify server"+process.cwd()),mt.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),mt.debug(`Custom Functions server process ${process.pid} starting up.`),await Gfe();let e=$V.get(VV.CONFIG_PARAMS.HTTP_SECUREPORT)>0,t;try{t=Io=await QV(e)}catch(r){throw mt.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw mt.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){mt.error(`Custom Functions ${process.pid} Error: ${e}`),mt.error(e),process.exit(1)}}async function Gfe(){try{mt.info("Custom Functions starting configuration."),await KV.setUsersToGlobal(),mt.info("Custom Functions completed configuration.")}catch(e){mt.error(e)}}function qfe(e,t){return async function(r){try{mt.info("Custom Functions starting buildRoutes"),mt.trace("Loading fastify routes folder "+e),(0,xV.existsSync)(e)&&r.register(qV.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:mt.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?mt.error(s.message):s&&mt.error(s),o()})}catch(n){mt.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function QV(e){mt.info("Custom Functions starting buildServer.");let t=(0,YV.default)(e),r=(0,kV.default)(t);r.server.headersTimeout=(0,jV.default)(),r.setErrorHandler(zV.serverErrorHandler);let n=(0,WV.default)();return n&&r.register(FV.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,l){r.server.emit("unhandled",c.raw,l.raw)}),o()}),r.register(GV.default),await r.register(xfe),await r.after(),YO(r),mt.info("Custom Functions completed buildServer."),r}function JV(){if(Io)return Io.then?Io.then(e=>e.ready()):Io.ready()}var KN,xV,kV,FV,GV,qV,$V,VV,mt,xfe,KV,YV,WV,jV,zV,Io,HV,XV=Oe(()=>{KN=require("path"),xV=require("fs"),kV=L(require("fastify")),FV=L(require("@fastify/cors")),GV=L(_N()),qV=L(require("@fastify/autoload")),$V=L(se()),VV=L(M()),mt=L(W()),xfe=L(wV()),KV=L(xn()),YV=L(DV()),WV=L(MV()),jV=L(BV()),zV=L(LS());Wc();qr();HV=new Set;a(kfe,"start");a(Ffe,"customFunctionsServer");a(Gfe,"setUp");a(qfe,"buildRouteFolder");a(QV,"buildServer");a(JV,"ready")});var WN={};je(WN,{start:()=>$fe});function $fe(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,n1.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){e1||(e1=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=ZV.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,t1.default)(s,(0,r1.realpathSync)(o))}}return i(s)},{runFirst:!0})),ZV.set(r,n)}}}var t1,r1,n1,ZV,e1,s1=Oe(()=>{t1=L(require("send")),r1=require("fs"),n1=L(require("serve-static")),ZV=new Map;a($fe,"start")});var JN={};je(JN,{Request:()=>jN,createReuseportFd:()=>US});var i1,jN,zN,QN,US,vS=Oe(()=>{i1=require("os"),jN=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 QN(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 zN(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}},zN=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)}},QN=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,i1.platform)()!="win32"&&(US=require("node-unix-socket").createReuseportFd)});var ZN=N((MPe,o1)=>{"use strict";var hE=se();hE.initSync();var sd=require("fs-extra"),XN=require("path"),id=M(),Vfe=require("crypto"),Kfe=require("uuid").v4;o1.exports=Yfe;function Yfe(){if(hE.getHdbBasePath()!==void 0){let e=XN.join(hE.getHdbBasePath(),id.LICENSE_KEY_DIR_NAME,id.JWT_ENUM.JWT_PRIVATE_KEY_NAME),t=XN.join(hE.getHdbBasePath(),id.LICENSE_KEY_DIR_NAME,id.JWT_ENUM.JWT_PUBLIC_KEY_NAME),r=XN.join(hE.getHdbBasePath(),id.LICENSE_KEY_DIR_NAME,id.JWT_ENUM.JWT_PASSPHRASE_NAME);try{sd.accessSync(r),sd.accessSync(e),sd.accessSync(t)}catch(n){if(n.code==="ENOENT"){let s=Kfe(),i=Vfe.generateKeyPairSync("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem",cipher:"aes-256-cbc",passphrase:s}});sd.writeFileSync(r,s),sd.writeFileSync(e,i.privateKey),sd.writeFileSync(t,i.publicKey)}else throw n}}}a(Yfe,"checkJWTTokenExist")});var c1=N((vPe,a1)=>{"use strict";var eI=class{static{a(this,"HdbInfoInsertObject")}constructor(t,r,n){this.info_id=t,this.data_version_num=r,this.hdb_version_num=n}};a1.exports={HdbInfoInsertObject:eI}});var d1=N((HPe,u1)=>{"use strict";var l1=M(),tI=class{static{a(this,"UpgradeObject")}constructor(t,r){this[l1.UPGRADE_JSON_FIELD_NAMES_ENUM.DATA_VERSION]=t,this[l1.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION]=r}};u1.exports={UpgradeObject:tI}});var BS=N((kPe,f1)=>{"use strict";var Is=require("prompt"),od=require("chalk"),_1=W(),ii=require("os"),rI=Wa(),nI=["yes","y"];async function Wfe(e){let t=`${ii.EOL}`+od.bold.green("Your current HarperDB version requires that we complete an update process.")+`${ii.EOL}If a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${ii.EOL}${ii.EOL}You can read more about the changes in this upgrade at https://harperdb.io/developers/release-notes/${ii.EOL}`;Is.override=rI(["CONFIRM_UPGRADE"]),Is.start(),Is.message=t;let r={properties:{CONFIRM_UPGRADE:{description:od.magenta(`${ii.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 Is.get([r])}catch(s){return _1.error("There was an error when prompting user about an upgrade."),_1.error(s),!1}return nI.includes(n.CONFIRM_UPGRADE)}a(Wfe,"forceUpdatePrompt");async function jfe(e){let t=`${ii.EOL}`+od.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.${ii.EOL}`);Is.override=rI(["CONFIRM_DOWNGRADE"]),Is.start(),Is.message=t;let r={properties:{CONFIRM_DOWNGRADE:{description:od.magenta(`${ii.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 Is.get([r]);return nI.includes(n.CONFIRM_DOWNGRADE)}a(jfe,"forceDowngradePrompt");async function zfe(){let e=`${ii.EOL}`+od.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");Is.override=rI(["GENERATE_CERTS"]),Is.start(),Is.message=e;let t={properties:{GENERATE_CERTS:{description:od.magenta(`${ii.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 Is.get([t]);return nI.includes(r.GENERATE_CERTS)}a(zfe,"upgradeCertsPrompt");f1.exports={forceUpdatePrompt:Wfe,forceDowngradePrompt:jfe,upgradeCertsPrompt:zfe}});var iI=N((GPe,E1)=>{"use strict";var sI=class{static{a(this,"UpgradeDirective")}constructor(t){this.version=t,this.sync_functions=[],this.async_functions=[]}};E1.exports=sI});var p1=N((WPe,h1)=>{"use strict";var Qfe=te(),Jfe=wt(),$Pe=W(),VPe=require("path"),KPe=require("fs"),YPe=M();h1.exports={getOldPropsValue:Xfe};function Xfe(e,t,r=!1){let n=t.getRaw(e);return Qfe.isNotEmptyAndHasValue(n)?n:r?Jfe.getDefaultConfig(e):""}a(Xfe,"getOldPropsValue")});var g1=N((zPe,T1)=>{"use strict";var Oa=require("path"),Na=require("fs-extra"),Zfe=require("properties-reader"),eEe=iI(),lr=W(),{getOldPropsValue:St}=p1(),{HDB_SETTINGS_NAMES:he,CONFIG_PARAMS:nl}=M(),sl=wt(),HS=se(),m1=te(),xi=M(),oI=new eEe("3.1.0"),S1=[];function tEe(){let e=Zfe(HS.get(he.SETTINGS_PATH_KEY)),t="Updating settings file for version 3.1.0";console.log(t),lr.info(t);let r=` ;Settings for the HarperDB process.
40
+ `},"serialize"),compressible:!1,q:.8});tn.set("application/x-www-form-urlencoded",{deserialize(e){let t={};for(let[r,n]of new URLSearchParams(e))if(t.hasOwnProperty(r)){let s=t[r];Array.isArray(s)?s.push(n):t.key=[s,n]}else t[r]=n},serialize(e){let t=new URLSearchParams;for(let r in e)t.set(r,e);return t.toString()}});q$={type:"application/json",serializeStream:Zd,serialize:iE,deserialize:C_e,q:.5};tn.set("*/*",q$);tn.set("",q$);a(C_e,"tryJSONParse");a(AN,"registerContentHandlers");D_e=require("fastify-plugin"),P_e=D_e(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=AS(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 d=l.getColumns;l=l.mapError(_=>(_.toJSON=()=>({error:_.name,message:_.message,..._.partialObject}),_)),l.getColumns=d}u=o.serializeStream}else u=o.serialize;return u(l,{headers:{set:a((d,_)=>{s.header(d,_)},"set")}})})}),r()},{name:"content-type-negotiation"});a(AS,"findBestSerializer");H$=pN.default.get(mN.CONFIG_PARAMS.HTTP_COMPRESSIONTHRESHOLD);a(aE,"serialize");a(Wc,"serializeMessage");a(L_e,"streamToBuffer");M_e=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(U_e,"isBufferEncoding");a(v_e,"parseContentType");a(bo,"getDeserializer");a(B_e,"deserializerUnknownType");a(H_e,"transformIterable")});var yN={};je(yN,{start:()=>Y_e});function x_e(e){if(e.kind!==Le.Kind.OPERATION_DEFINITION&&e.kind!==Le.Kind.FRAGMENT_DEFINITION)throw new vr(`Unexpected non-executable definition type ${e.kind}.`)}function V$(e){if(typeof e!="object"||e===null)throw new Ui("Request body must be an object.");if(!("query"in e))throw new Ui("Request body must contain a `query` field.");if(typeof e.query!="string")throw new Ui("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new Ui("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new Ui("Request body `operationName` field must be a string.")}function RN(e){return parseInt(e.value,10)}function Y$(e){return parseFloat(e.value)}function W$(e,t,r){let n=r.get(e.name.value);return j$(n)?z$(n,t):{attribute:t,value:n}}function j$(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function z$(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],j$(n)?z$(n,t):{attribute:t,value:n}))}function k_e(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:RN(e.value)};case Le.Kind.FLOAT:return{attribute:t,value:Y$(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:t,value:e.value.value};case Le.Kind.VARIABLE:return W$(e.value,t,r);case Le.Kind.OBJECT:return Q$(e.value,t,r);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new vr(`Value type, ${e.value.kind}, is not supported.`)}}function Q$(e,t,r){return e.fields.flatMap(n=>k_e(n,t,r))}function F_e(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:RN(e.value)};case Le.Kind.FLOAT:return{attribute:e.name.value,value:Y$(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Le.Kind.VARIABLE:return W$(e.value,e.name.value,t);case Le.Kind.OBJECT:return Q$(e.value,[e.name.value],t);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new vr(`Argument type, ${e.value.kind}, is not supported.`)}}function G_e(e,t){return e.flatMap(r=>F_e(r,t))}function RS(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 vr(`Fragment \`${n}\` not found.`);return RS(s.selectionSet,t)}case Le.Kind.INLINE_FRAGMENT:return RS(r.selectionSet,t)}})}function J$(e,t){return RS(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:J$(r.selectionSet,t)}:r.name.value)}async function q_e(e,t,r,n){let i=wi.getMatch(e.name.value,"graphql").Resource,o={select:J$(e.selectionSet,r),conditions:G_e(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 X$(e){switch(e.kind){case Le.Kind.NULL:return null;case Le.Kind.INT:return RN(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]:X$(r.value),...t}),{});case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new vr(`Value type, ${e.kind}, is not supported.`)}}function $_e(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=X$(n.defaultValue)),n.type.kind===Le.Kind.NON_NULL_TYPE&&!(s in t)&&i===void 0)throw new vr(`Variable $${s} is required, but not provided.`);r.set(n.variable.name.value,i??null)}return r}async function V_e(e,t,r,n){if(e.operation===Le.OperationTypeNode.SUBSCRIPTION)throw new vr("Subscriptions are not supported.");if(e.operation===Le.OperationTypeNode.MUTATION)throw new vr("Mutations are not supported yet.");let s=$_e(e.variableDefinitions,t),i=await Promise.all(RS(e.selectionSet,r).map(c=>q_e(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function K$({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(x_e(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 vr("Unnamed operations are only allowed when there is a single operation in the document.");let d=u.name?.value??"Unnamed Query";if(i.has(d))throw new vr(`Duplicate operation definition: ${d}`);i.set(d,u)}let c;if(r==null)if(i.size===1)c=i.entries().next().value[1];else throw new vr("Operation name is required when there are multiple operations in the document.");else if(c=i.get(r),c==null)throw new vr(`Operation \`${r}\` not found.`);let l=await V_e(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function K_e(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 V$(r),K$(r,e)}case"POST":{let r=await bo(e.headers.get("content-type"),!0)(e._nodeRequest);return V$(r),K$(r,e)}default:throw new Ui("Method Not Allowed",405,{Allow:"GET, POST"})}}function Y_e(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await K_e(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof Ui)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 vr)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 Ui)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 vr)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}})}var Le,vr,Ui,Z$=Ie(()=>{Le=L(require("graphql"));jc();nu();a(x_e,"assertExecutableDefinitionNode");a(V$,"assertRequestParams");a(RN,"processIntValueNode");a(Y$,"processFloatValueNode");a(W$,"processVariableNode");a(j$,"isObject");a(z$,"transformObjectIntoQueryCondition");a(k_e,"processObjectFieldNode");a(Q$,"processObjectValueNode");a(F_e,"processArgumentNode");a(G_e,"buildConditionsQuery");a(RS,"fillInFragments");a(J$,"buildSelectQuery");a(q_e,"processFieldNode");a(X$,"processConstValueNode");a($_e,"resolveVariables");a(V_e,"executeOperation");a(K$,"resolver");vr=class extends Error{static{a(this,"GraphQLQueryingError")}},Ui=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a(K_e,"graphqlQueryingHandler");a(Y_e,"start")});var bN={};je(bN,{start:()=>rV,startOnMainThread:()=>z_e});function rV({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,eV.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(W_e.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 d=[];for(let _ in u.attributes){let E=u.attributes[_];E.attribute_name=_,d.push(E)}u.attribute_permissions=d,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 d of u.attribute_permissions)d.read=!!d.read,d.insert=!!d.insert,d.update=!!d.update}else u.attribute_permissions=null}}i.role=i.id=s,await j_e(i)}}}async function j_e(e){let t=ut().system.hdb_role;for await(let r of t.search([{attribute:"role",value:e.role}])){let{__createdtime__:n,__updatedtime__:s,...i}=r;return(0,tV.isEqual)(i,e)?void 0:(e.id=r.id,(0,yS.alterRole)(e))}return(0,yS.addRole)(e)}var yS,eV,tV,W_e,z_e,nV=Ie(()=>{Pe();yS=L(lf()),eV=require("yaml"),tV=require("lodash"),W_e=["super_user","cluster_user","structure_user"];a(rV,"start");a(j_e,"ensureRole");z_e=rV});async function bS(e){let t=(0,oV.pathToFileURL)(e).toString();return Q_e?(cE||(cE=J_e(Z_e)),(await(await cE).import(t)).namespace):import(t)}async function J_e(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),cE=new Compartment({console,Math,Date,fetch:X_e,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,iV.extname)(r)||(r+=".js"),r)},importHook:a(async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Lr,tables:jn,databases:We})}};let n=await(0,sV.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),cE}function X_e(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 Z_e(){return{Resource:Lr,tables:jn}}var sV,iV,oV,Q_e,cE,ON=Ie(()=>{Vs();Pe();sV=require("fs/promises"),iV=require("path"),oV=require("url"),Q_e=!1;a(bS,"secureImport");a(J_e,"getCompartment");a(X_e,"secureOnlyFetch");a(Z_e,"getGlobalVars")});var IN={};je(IN,{handleFile:()=>efe});async function efe(e,t,r,n){let s=new Map,i=await bS(r);c(i.default)&&n.set((0,NN.dirname)(t),i.default),o(i,(0,NN.dirname)(t));function o(l,u){for(let d in l){let _=l[d];c(_)?n.set(u+"/"+d,_):typeof _=="object"&&o(_,u+"/"+d)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var NN,aV=Ie(()=>{ON();NN=require("path");a(efe,"handleFile")});var CN={};je(CN,{start:()=>tfe});function tfe({resources:e}){e.set("login",wN),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var wN,cV=Ie(()=>{Vs();a(tfe,"start");wN=class extends Lr{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)}}}});function PN(e,t,r,n,s,i,o,c){let l=e[0];if(t==="or"){let _=u(l);for(let f=1;f<e.length;f++){let h=e[f],T=u(h);_=_.concat(T)}let E=new Set;return _.filter(f=>{let h=f.key??f;return E.has(h)?!1:(E.add(h),!0)})}else{let _=u(l),E=d(e.slice(1),!0,l.estimated_count);return E.length>0?o(_,E):_}function u(_){return _.conditions?PN(_.conditions,_.operator,r,n,s,i,o,c):rd(_,n,_.descending||s.reverse===!0,r,s.allowFullScan,c)}a(u,"executeCondition");function d(_,E,f){return _.map((h,T)=>{if(h.conditions){let S=h.operator==="or",b=d(h.conditions,!S,f);return S?(I,B)=>b.some(H=>H(I,B)):(I,B)=>b.every(H=>H(I,B))}let m=(h.attribute||h[0])===r.primaryKey,g=dE(h,r,i,c,m,f);return E&&T<_.length-1&&f&&(f=ufe(r.primaryStore,h.estimated_count,f)),g}).filter(Boolean)}a(d,"mapConditionsToFilters")}function rd(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 On.ClientError(`Search condition for ${o} must have a value`);if(Array.isArray(o)){let S=o[0],b=Bi(n.attributes,S);if(b.relationship){if(o.length<2)throw new On.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let I=b.definition?.tableClass||b.elements?.definition?.tableClass,B=new Map,H=rd({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,I,s,B);if(b.relationship.to){i[o[0]]=B;let X=!!Bi(I.attributes,b.relationship.to)?.elements;H=ofe(H,b,I.primaryStore,X,B)}if(b.relationship.from){let X=a(Y=>(Y?.key!==void 0&&(Y=Y.key),rd({attribute:b.relationship.from,value:Y},t,r,n,s,B)),"searchEntry");b.elements?(i[o[0]]=B,H=afe(H,b,I.primaryStore,B,X)):H=H.flatMap(X)}return H}else if(o.length===1)o=o[0];else throw new On.ClientError("Unable to query by attribute "+JSON.stringify(o))}let u,d,_,E;c instanceof Date&&(c=c.getTime());let f;switch(LN[l]||l){case"lt":u=!0,d=c;break;case"le":u=!0,d=c,_=!0;break;case"gt":u=c,E=!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,d=c.slice(0),d[d.length-1]=vi.MAXIMUM_KEY;break;case"starts_with":u=c.toString(),d=c+"\uFFFF";break;case"between":case"gele":case"gelt":case"gtlt":case"gtle":u=c[0],u instanceof Date&&(u=u.getTime()),d=c[1],d instanceof Date&&(d=d.getTime()),_=l==="gele"||l==="gtle"||l==="between",E=l==="gtlt"||l==="gtle";break;case"equals":case void 0:u=c,d=c,_=!0;break;case"ne":if(c===null){u=c,E=!0;break}case"sort":case"contains":case"ends_with":u=!0,f=!0;break;default:throw new On.ClientError(`Unknown query comparator "${l}"`)}let h,T=o===n.primaryKey||o==null;if(typeof u=="string"&&u.length>Os.MAX_SEARCH_KEY_LENGTH&&(u=u.slice(0,Os.MAX_SEARCH_KEY_LENGTH)+Os.OVERFLOW_MARKER,E=!1,h=dE(e,n,null,i,T)),typeof d=="string"&&d.length>Os.MAX_SEARCH_KEY_LENGTH&&(d=d.slice(0,Os.MAX_SEARCH_KEY_LENGTH)+Os.OVERFLOW_MARKER,_=!0,h=h??dE(e,n,null,i,T)),r){let S=u;u=d,d=S,S=!E,E=!_,_=S}let m=T?n.primaryStore:n.indices[o];if(!m||m.isIndexing||f||c===null&&!m.indexNulls){if(s===!1&&!m)throw new On.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&f)throw new On.ClientError(`Can not use ${l||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(m?.isIndexing)throw new On.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&m&&!m.indexNulls)throw new On.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??dE(e,n,null,i,T),!h)throw new On.ClientError(`Unknown search operator ${e.comparator}`)}let g={start:u,end:d,inclusiveEnd:_,exclusiveStart:E,values:!0,versions:T,transaction:t,reverse:r};if(T){let S=m.getRange(g).map(h?function({key:b,value:I}){return this?.isSync?I&&h(I)?b:Aa.SKIP:new Promise((B,H)=>setImmediate(()=>{try{B(I&&h(I)?b:Aa.SKIP)}catch(X){H(X)}}))}:b=>b.value==null&&!(b.metadataFlags&(Ns|ya))?Aa.SKIP:b);return S.hasEntries=!0,S}else return m?m.getRange(g).map(h?function({key:S,value:b}){let I;return typeof S=="string"&&S.length>Os.MAX_SEARCH_KEY_LENGTH?I=n.primaryStore.get(b):I={[o]:S},this.isSync?h(I)?b:Aa.SKIP:new Promise((B,H)=>setImmediate(()=>{try{B(h(I)?b:Aa.SKIP)}catch(X){H(X)}}))}:({value:S})=>S):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:S,value:b}){return this.isSync?b&&h(b)?S:Aa.SKIP:new Promise((I,B)=>setImmediate(()=>{try{I(b&&h(b)?S:Aa.SKIP)}catch(H){B(H)}}))})}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 ofe(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,d)=>{let _=s.get(u);_?_.push(d):s.set(u,_=[d])},"add_entry");for(let u of e){let d=u.value??r.get(u.key??u),_=d?.[c];if(_!=null&&!s.filters?.some(E=>!E(d)))if(n)for(let E=0;E<_.length;E++)l(_[E],u);else l(_,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 afe(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=d=>d[t.relationship.from]?.filter?.(_=>u.has(_));for(let d of e){if(n.filters){let _=r.get(d);if(n.filters.some(E=>!E(_)))continue}u.add(d)}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 dE(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 d=c[0],_=Bi(t.attributes,d),E=_.definition?.tableClass||_.elements.definition?.tableClass,f=n?.[d],h=dE({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:o},E,r,f?.[d]?.joined,c[1]===E.primaryKey,i);if(!h)return;if(f){f.filters||(f.filters=[]),f.filters.push(h);return}let T=t.propertyResolvers?.[d],m,g=a((S,b)=>{let I,B;if(T){if(T.from&&h.idFilter){if(!m)if(h.idFilter.idSet?.size===1){for(let X of h.idFilter.idSet)e={attribute:T.from,value:X};m=u(T.from,h.idFilter,!0,!0)}else m=u(T.from,h.idFilter,!1,!0);let H=m(S);return m.idFilter&&(g.idFilter=m.idFilter),H}B=T(S,r,b),I=B?.value}else I=S[d];return I?Array.isArray(I)?I.some(h):h(I,B):!1},"recordFilter");return g}}switch(l instanceof Date&&(l=l.getTime()),LN[o]||o){case Os.SEARCH_TYPES.EQUALS:case void 0:return u(c,d=>d===l,!0);case"contains":return u(c,d=>d?.toString().includes(l));case"ends_with":return u(c,d=>d?.toString().endsWith(l));case"starts_with":return u(c,d=>typeof d=="string"&&d.startsWith(l),!0);case"prefix":return Array.isArray(l)?l[l.length-1]==null&&(l=l.slice(0,-1)):l=[l],u(c,d=>{if(!Array.isArray(d))return!1;for(let _=0,E=l.length;_<E;_++)if(d[_]!==l[_])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,d=>(0,vi.compareKeys)(d,l[0])>=0&&(0,vi.compareKeys)(d,l[1])<=0,!0);case"gt":return u(c,d=>(0,vi.compareKeys)(d,l)>0);case"ge":return u(c,d=>(0,vi.compareKeys)(d,l)>=0);case"lt":return u(c,d=>(0,vi.compareKeys)(d,l)<0);case"le":return u(c,d=>(0,vi.compareKeys)(d,l)<=0);case"ne":return u(c,d=>(0,vi.compareKeys)(d,l)!==0,!1,!0);case"sort":return()=>!0;default:throw new On.ClientError(`Unknown query comparator "${o}"`)}function u(d,_,E,f){let h;E=E&&!s&&t?.indices[d]&&i>3,E&&(e.estimated_count==null&&NS(t)(e),h=e.estimated_count>>4,(isNaN(h)||h>=i)&&(E=!1));let T=0,m=3;function g(S){let b=S[d],I;if(typeof b!="object"||!b||f?I=_(b):Array.isArray(b)?I=b.some(_):b instanceof Date&&(I=_(b.getTime())),E&&(m++,!I&&!g.idFilter&&++T/m*(i-m)>h)){let B=rd(e,r.transaction.getReadTxn(),!1,t).map(nd),H=new Set(B);g.idFilter=X=>H.has(nd(X)),g.idFilter.idSet=H}return I}return a(g,"recordFilter"),s&&(g.idFilter=_),g}a(u,"attributeComparator")}function NS(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/Oo(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=LN[n]||n,n===Os.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=NS(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*Oo(e.indices[i.relationship.from])/(Oo(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=Oo(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=sfe*Oo(e.primaryStore)+1:n==="between"?r.estimated_count=nfe*Oo(e.primaryStore)+1:n==="sort"?r.estimated_count=Oo(e.primaryStore)+1:r.estimated_count=rfe*Oo(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function IS(e){if(e)if(Ra=e,ed.lastIndex=0,cfe.test(e))try{let t=lE(new td,"");if(bn!==Ra.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 ${bn} in '${Ra}'`,t}else return new URLSearchParams(e)}function lE(e,t){let r=ed,n,s,i,o,c,l=decodeURIComponent,u;for(;n=r.exec(Ra);){bn=r.lastIndex;let[,d,_]=n;if(o){if(d)throw new SyntaxError(`expected operator, but encountered '${d}'`);o=!1,c=!1}else c=!0;let E;switch(_){case"=":if(s!=null){if(d.length<=2)i=d;else throw new SyntaxError(`invalid FIQL operator ${d}`);l=lV}else{if(l=decodeURIComponent,i="equals",!d)throw new SyntaxError("attribute must be specified before equality comparator");s=uE(d)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=ife[_],l=DN[i]?lV:decodeURIComponent,!d)throw new SyntaxError(`attribute must be specified before comparator ${_}`);s=uE(d);break;case"&=":case"|=":case"|":case"&":case"":case void 0:if(s==null){if(s===void 0)throw t?new SyntaxError(`expected '${t}', but encountered ${_[0]?"'"+_[0]+"'":"end of string"}}`):new SyntaxError(`no comparison specified before ${_?"'"+_+"'":"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(d)};if(i==="eq"&&uV(h,d),s===""){let T=e.conditions[e.conditions.length-1];T.chainedConditions=T.chainedConditions||[],T.chainedConditions.push(h),T.operator=u}else OS(e,u),e.conditions.push(h)}_==="&"?(u="and",s=void 0):_==="|"?(u="or",s=void 0):_==="&="?(u="and",s=""):_==="|="&&(u="or",s="");break;case",":if(e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");e.push(uE(d)),s=void 0;break;case"(":ed.lastIndex=bn;let f=lE(d?[]:new td,")");switch(d){case"":OS(e,u),e.conditions.push(f);break;case"limit":switch(f.length){case 1:e.limit=+f[0];break;case 2:e.offset=+f[0],e.limit=f[1]-e.offset;break;default:throw new SyntaxError("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(f[0])&&f.length===1&&!f[0].name?(e.select=f[0],e.select.asArray=!0):f.length===1?e.select=f[0]:f.length===2&&f[1]===""?e.select=f.slice(0,1):e.select=f;break;case"group-by":throw new SyntaxError("group by is not implemented yet");case"sort":e.sort=dV(f);break;default:throw new SyntaxError(`unknown query function call ${d}`)}Ra[bn]===","?r.lastIndex=++bn:o=!0,s=null;break;case"{":if(e.conditions)throw new SyntaxError("property sets are not allowed in a queries");if(!d)throw new SyntaxError("property sets must have a defined parent property name");ed.lastIndex=bn,E=lE([],"}"),E.name=d,e.push(E),Ra[bn]===","?r.lastIndex=++bn:o=!0;break;case"[":ed.lastIndex=bn,d?(E=lE(new td,"]"),E.name=d):E=lE(e.conditions?new td:[],"]"),e.conditions?(OS(e,u),e.conditions.push(E),s=null):e.push(E),Ra[bn]===","?r.lastIndex=++bn:o=!0;break;case")":case"]":case"}":if(t===_[0]){if(e.conditions){if(s){let h={comparator:i||"equals",attribute:s,value:l(d)};i==="eq"&&uV(h,d),OS(e,u),e.conditions.push(h)}else if(d)throw new SyntaxError("no attribute or comparison specified")}else(d||e.length>0&&c)&&e.push(uE(d));return e}else throw t?new SyntaxError(`expected '${t}', but encountered '${_[0]}'`):new SyntaxError(`unexpected token '${_[0]}'`);default:throw new SyntaxError(`unexpected operator '${_}'`)}if(t!==")"&&(r=s?lfe:ed,r.lastIndex=bn),bn===Ra.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function OS(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 uE(e){return e.indexOf(".")>-1?e.split(".").map(uE):decodeURIComponent(e)}function lV(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 On.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function uV(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new On.ClientError("wildcard can only be used at the end of a string")}function dV(e){let t=_V(e[0]);return e.length>1&&(t.next=dV(e.slice(1))),t}function _V(e){if(Array.isArray(e)){let t=_V(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 nd(e){return Array.isArray(e)?e.join("\0"):e}function Oo(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function ufe(e,t,r){return t*r/Oo(e)}var On,Os,vi,Aa,rfe,nfe,sfe,ife,DN,LN,cfe,ed,lfe,bn,Ra,td,il,_E=Ie(()=>{On=L(_e()),Os=L(Ht()),vi=require("ordered-binary"),Aa=require("lmdb");$f();rfe=.3,nfe=.1,sfe=.05,ife={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},DN={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(PN,"executeConditions");a(rd,"searchByIndex");a(Bi,"findAttribute");a(ofe,"joinTo");a(afe,"joinFrom");LN={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(dE,"filterByType");a(NS,"estimateCondition");cfe=/[()[\]|!<>.]|(=\w*=)/,ed=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,lfe=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(IS,"parseQuery");a(lE,"parseBlock");a(OS,"assignOperator");a(uE,"decodeProperty");a(lV,"typedDecoding");a(uV,"wildcardDecoding");a(dV,"toSortObject");a(_V,"toSortEntry");td=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(nd,"flattenKey");a(Oo,"estimatedEntryCount");a(ufe,"intersectionEstimate");il=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});function mV(e){let t={openapi:dfe,info:{title:"HarperDB HTTP REST interface",version:(0,pV.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={},d=[];if(o)for(let{type:b,name:I,elements:B,relationship:H,definition:X}of o){if(H)b==="array"?u[I]={type:"array",items:{$ref:ba+B.type}}:u[I]={$ref:ba+b};else{let Y=X??B?.definition;if(Y){if(!t.components.schemas[Y.type]){let V={};Y.properties.forEach(ne=>{V[ne.name]=new BN(MN[ne.type],ne.type)}),t.components.schemas[Y.type]=new hV(V)}b==="array"?u[I]={type:"array",items:{$ref:ba+Y.type}}:u[I]={$ref:ba+Y.type}}else b==="array"?B.type==="Any"||B.type=="ID"?u[I]={type:"array",items:{format:B.type}}:u[I]={type:"array",items:new BN(MN[B.type],B.type)}:b==="Any"||b=="ID"?u[I]={format:b}:u[I]=new BN(MN[b],b)}d.push(new HN(I,"query",u[I]))}let _=Object.keys(u),E=new HN(c,"path",{format:"ID"});E.required=!0,E.description="primary key of record";let f=new HN("property","path",{enum:_});f.required=!0,t.components.schemas[i]=new hV(u);let h=l.post!==Resource.prototype.post||l.update,T=typeof l.put=="function",m=typeof l.get=="function",g=typeof l.delete=="function",S="/"+s+"/";h&&(t.paths[S]={},t.paths[S].post=new _fe(i,r,"create a new record auto-assigning a primary key")),m&&(t.paths[S]||(t.paths[S]={}),t.paths[S].get=new UN(d,r,{200:new vN({$ref:ba+i})},"search for records by the specified property name and value pairs")),g&&(t.paths[S]||(t.paths[S]={}),t.paths[S].delete=new EV(d,r,"delete all the records that match the provided query",{204:new fV})),S="/"+s+"/{"+c+"}",m&&(t.paths[S]={},t.paths[S].get=new UN([E],r,{200:new vN({$ref:ba+i})},"retrieve a record by its primary key")),T&&(t.paths[S]||(t.paths[S]={}),t.paths[S].put=new ffe([E],r,i,"create or update the record with the URL path that maps to the record's primary key")),g&&(t.paths[S]||(t.paths[S]={}),t.paths[S].delete=new EV([E],r,"delete a record with the given primary key",{204:new fV})),m&&f.schema.enum.length>0&&(S="/"+s+"/{"+c+"}.{property}",t.paths[S]={},t.paths[S].get=new UN([E,f],r,{200:new vN({enum:_})},"used to retrieve the specified property of the specified record"))}return t}function _fe(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:ba+e}}}},this.security=t,this.responses={200:{description:xN,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function UN(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function vN(e){this.description=xN,this.content={"application/json":{schema:e}}}function fV(){this.description="successfully processed request, no content returned to client"}function ffe(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:ba+r}}}},this.responses={200:{description:xN}}}function EV(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function hV(e){this.type="object",this.properties=e}function BN(e,t){this.type=e,this.format=t}function HN(e,t,r){this.name=e,this.in=t,this.schema=r}var pV,dfe,MN,ba,xN,SV=Ie(()=>{pV=L(vc()),dfe="3.0.3",MN={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},ba="#/components/schemas/",xN="successful operation";a(mV,"generateJsonApi");a(_fe,"Post");a(UN,"Get");a(vN,"Response200");a(fV,"Response204");a(ffe,"Put");a(EV,"Delete");a(hV,"ResourceSchema");a(BN,"Type");a(HN,"Parameter")});var CS={};je(CS,{parseHeaderValue:()=>FN,start:()=>pfe});async function hfe(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream",s=n?"CONNECT":e.method;e.search&&IS(e);let i=new mo;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==TV){let m=wS.getMatch(o,n?"sse":"rest");if(!m)return t(e);e.handlerPath=m.path,c=new il(m.relativeURL),c.async=!0,l=m.Resource}if(l?.isCaching){let m=r["cache-control"];if(m){let g=FN(m);for(let S of g)switch(S.name){case"max-age":e.expiresAt=S.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 m=FN(u).map(g=>(g.next?.name==="confirm"&&g.next.value>=0&&(e.replicatedConfirmation=+g.next.value),g.name));e.replicateTo=m.length===1&&+m[0]>=0?+m[0]:m[0]==="*"?void 0:m}r["x-replicate-from"]==="none"&&(e.replicateFrom=!1);let _=await Dt(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=bo(r["content-type"],!0)(e.body,e.headers)}catch(m){throw new sd.ClientError(m,400)}if(e.authorize=!0,o===TV&&s==="GET"){if(e?.user?.role?.permission?.super_user)return mV(wS);throw new sd.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 sd.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new sd.ServerError(`Method ${s} is not recognized`,501)}}),E=200,f;if(_==null)E=s==="GET"||s==="HEAD"?404:204,kN.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(_.status>0&&_.headers){let m=hO(_.headers,i);return _.headers!==m&&(_.headers=m),_.data!==void 0&&(_.body=aE(_.data,e,_)),_}else if(f=e.lastModified){Efe[0]=f;let m=String.fromCharCode(34,(Br[0]&63)+62,(Br[0]>>6)+(Br[1]<<2&63)+62,(Br[1]>>4)+(Br[2]<<4&63)+62,(Br[2]>>2)+62,(Br[3]&63)+62,(Br[3]>>6)+(Br[4]<<2&63)+62,(Br[4]>>4)+(Br[5]<<4&63)+62,(Br[5]>>2)+62,(Br[6]&63)+62,(Br[6]>>6)+(Br[7]<<2&63)+62,34),g=r["if-none-match"];g&&m==g?(_?.onDone&&_.onDone(),E=304,_=void 0):i.setIfNone("ETag",m),kN.lastModified&&i.setIfNone("Last-Modified",new Date(f).toUTCString())}e.createdResource&&(E=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let h={status:E,headers:i,body:void 0},T=_?.wasLoadedFromSource?.();return T!==void 0&&(h.wasCacheMiss=T,!T&&f&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||f))/1e3))),_!==void 0&&(h.body=aE(_,e,h),s==="HEAD"&&(h.body=void 0)),h}catch(o){o.statusCode?o.statusCode===500?Hi.warn(o):Hi.info(o):Hi.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=aE(o.contentType?o:o.toString(),e,c),c}}function pfe(e){kN=e,!gV&&(gV=!0,wS=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return hfe(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{fE++;let s=new Mn;AV||(AV=!0,k_(l=>{fE>0&&l.push({metric:"ws-connections",connections:fE,byThread:!0})}));let i;t.on("error",l=>{i=!0,Hi.warn(l)});let o;t.on("message",a(function(u){o||(o=bo(r.requestedContentType??r.headers.asObject["content-type"],!1));let d=o(u);s.push(d)},"message"));let c;t.on("close",()=>{fE--,qn(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),u=wS.getMatch(l,"ws");if(qn(!!u,"connection","ws","connect"),u){r.handlerPath=u.path,pr(h=>({count:h.count,total:fE}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let d=new il(u.relativeURL),_=u.Resource;c=(await Dt(r,()=>_.connect(d,s,r)))[Symbol.asyncIterator]();let f;for(;!(f=await c.next()).done;){let h=Wc(f.value,r);t.send(h),pr(h.length,"bytes-sent",r.handlerPath,"message","ws")}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){l.statusCode?l.statusCode===500?Hi.warn(l):Hi.info(l):Hi.error(l),t.close(mfe[l.statusCode]||1011,l.toString())}t.close()},e))}function FN(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 Hi,sd,Br,Efe,kN,TV,gV,wS,AV,fE,mfe,RV=Ie(()=>{jc();Ni();Hi=L(W()),sd=L(_e());_E();Pl();mc();Bf();SV();_E();Br=new Uint8Array(8),Efe=new Float64Array(Br.buffer,0,1),kN={},TV="openapi";a(hfe,"http");fE=0;a(pfe,"start");mfe={401:3e3,403:3003};a(FN,"parseHeaderValue")});var GN=N((gPe,bV)=>{var{recordAction:DS,recordActionBinary:yV}=(Ni(),oe(F_)),Sfe=require("fastify-plugin"),Tfe=200;bV.exports=Sfe(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,d,_;l.config?.isOperation?(u=n.body?.operation,d="operation"):(u=l.url,d="fastify-route",_=l.method),DS(o,"duration",u,_,d),yV(s.raw.statusCode<400,"success",u,_,d),yV(1,"response_"+s.raw.statusCode,u,_,d);let E=Tfe;i?.pipe?(i.on("data",m=>{E+=m.length}),i.on("end",()=>{DS(performance.now()-c,"transfer",u,_,d),DS(E,"bytes-sent",u,_,d)})):(E+=i?.length||0,DS(E,"bytes-sent",u,_,d));let f=o.toFixed(3),h=s.getHeader("Server-Timing"),T=`db;dur=${f}`;s.header("Server-Timing",h?`${h}, ${T}`:T)}),r()},{name:"hdb-request-time"})});var LS=N((APe,IV)=>{"use strict";var qN=M(),gfe=te(),EE=W(),{handleHDBError:$N,hdb_errors:PS}=_e(),{isMainThread:Afe}=require("worker_threads"),{Readable:Rfe}=require("stream"),OV=require("os"),yfe=require("util"),bfe=cb(),Ofe=yfe.promisify(bfe.authorize),NV=tN(),{createGzip:Nfe,constants:Ife}=require("zlib");function wfe(e){let t=`Found an uncaught exception with message: ${e.message}. ${OV.EOL}Stack: ${e.stack} ${OV.EOL}Terminating ${Afe?"HDB":"thread"}.`;console.error(t),EE.fatal(t),process.exit(1)}a(wfe,"handleServerUncaughtException");function Cfe(e,t,r){if(EE[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:PS.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(Cfe,"serverErrorHandler");function Dfe(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=$N(new Error,"Invalid JSON.",PS.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(gfe.isEmpty(e.body.operation)){let n=$N(new Error,"Request body must include an 'operation' property.",PS.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(Dfe,"reqBodyValidationHandler");function Pfe(e,t,r){let n;e.body.operation!==qN.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.body.operation!==qN.OPERATIONS_ENUM.LOGIN&&e.body.operation!==qN.OPERATIONS_ENUM.LOGOUT?Ofe(e,t).then(s=>{n=s,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(s=>{EE.warn(s),EE.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${s.stack}"`);let i=typeof s=="string"?{error:s}:{error:s.message};r($N(s,i,PS.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(Pfe,"authHandler");async function Lfe(e,t,r=!1){let n;try{e.body.bypass_auth&&delete e.body.bypass_auth,n=NV.chooseOperation(e.body);let s=await NV.processLocalTransaction(e,n);if(s instanceof Rfe&&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(Nfe({level:Ife.Z_BEST_SPEED})))}return s}catch(s){throw EE.error(s),s}}a(Lfe,"handlePostRequest");IV.exports={authHandler:Pfe,handlePostRequest:Lfe,handleServerUncaughtException:wfe,serverErrorHandler:Cfe,reqBodyValidationHandler:Dfe}});var PV=N((yPe,DV)=>{"use strict";var Mfe=require("fastify-plugin"),{handlePostRequest:wV,authHandler:Ufe,reqBodyValidationHandler:vfe}=LS();async function Bfe(e){e.decorate("hdbCore",{preValidation:[vfe,Ufe],request:a(t=>CV(wV(t,response)),"request"),requestWithoutAuthentication:a((t,r)=>CV(wV(t,r,!0)),"requestWithoutAuthentication")})}a(Bfe,"hdbCore");async function CV(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(CV,"convertAsyncIterators");DV.exports=Mfe(Bfe)});var MV=N((NPe,LV)=>{"use strict";var OPe=require("fs"),MS=se();MS.initSync();var{CONFIG_PARAMS:VN}=M(),Hfe=1024*1024*1024;function xfe(e){let t=MS.get(VN.HTTP_TIMEOUT),r=MS.get(VN.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:Hfe,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,maxParamLength:MS.get(VN.HTTP_MAXPARAMLENGTH)??1e3,https:e}}a(xfe,"getServerOptions");LV.exports=xfe});var BV=N((wPe,vV)=>{"use strict";var KN=se();KN.initSync();var{CONFIG_PARAMS:UV}=M();function kfe(){let e=KN.get(UV.HTTP_CORSACCESSLIST),t=KN.get(UV.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(kfe,"getCORSOptions");vV.exports=kfe});var kV=N((DPe,xV)=>{"use strict";var HV=se();HV.initSync();var Ffe=M();function Gfe(){return HV.get(Ffe.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(Gfe,"getHeaderTimeoutConfig");xV.exports=Gfe});var WN={};je(WN,{customFunctionsServer:()=>Vfe,ready:()=>e1,start:()=>$fe});function $fe(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){No||(No=ZV(t),it.http((await No).server));let o=await No,c=(0,YN.dirname)(s),l=(0,YN.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!FV.has(c)){FV.add(c);try{o.register(Yfe(c,l))}catch(u){if(u.message==="Root plugin has already booted")mt.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw u}}},ready:e1}}async function Vfe(){try{mt.info("In Custom Functions Fastify server"+process.cwd()),mt.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),mt.debug(`Custom Functions server process ${process.pid} starting up.`),await Kfe();let e=YV.get(WV.CONFIG_PARAMS.HTTP_SECUREPORT)>0,t;try{t=No=await ZV(e)}catch(r){throw mt.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw mt.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){mt.error(`Custom Functions ${process.pid} Error: ${e}`),mt.error(e),process.exit(1)}}async function Kfe(){try{mt.info("Custom Functions starting configuration."),await jV.setUsersToGlobal(),mt.info("Custom Functions completed configuration.")}catch(e){mt.error(e)}}function Yfe(e,t){return async function(r){try{mt.info("Custom Functions starting buildRoutes"),mt.trace("Loading fastify routes folder "+e),(0,GV.existsSync)(e)&&r.register(KV.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:mt.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?mt.error(s.message):s&&mt.error(s),o()})}catch(n){mt.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function ZV(e){mt.info("Custom Functions starting buildServer.");let t=(0,zV.default)(e),r=(0,qV.default)(t);r.server.headersTimeout=(0,JV.default)(),r.setErrorHandler(XV.serverErrorHandler);let n=(0,QV.default)();return n&&r.register($V.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,l){r.server.emit("unhandled",c.raw,l.raw)}),o()}),r.register(VV.default),await r.register(qfe),await r.after(),AN(r),mt.info("Custom Functions completed buildServer."),r}function e1(){if(No)return No.then?No.then(e=>e.ready()):No.ready()}var YN,GV,qV,$V,VV,KV,YV,WV,mt,qfe,jV,zV,QV,JV,XV,No,FV,t1=Ie(()=>{YN=require("path"),GV=require("fs"),qV=L(require("fastify")),$V=L(require("@fastify/cors")),VV=L(GN()),KV=L(require("@fastify/autoload")),YV=L(se()),WV=L(M()),mt=L(W()),qfe=L(PV()),jV=L(xn()),zV=L(MV()),QV=L(BV()),JV=L(kV()),XV=L(LS());jc();qr();FV=new Set;a($fe,"start");a(Vfe,"customFunctionsServer");a(Kfe,"setUp");a(Yfe,"buildRouteFolder");a(ZV,"buildServer");a(e1,"ready")});var jN={};je(jN,{start:()=>Wfe});function Wfe(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,o1.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){n1||(n1=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=r1.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,s1.default)(s,(0,i1.realpathSync)(o))}}return i(s)},{runFirst:!0})),r1.set(r,n)}}}var s1,i1,o1,r1,n1,a1=Ie(()=>{s1=L(require("send")),i1=require("fs"),o1=L(require("serve-static")),r1=new Map;a(Wfe,"start")});var XN={};je(XN,{Request:()=>zN,createReuseportFd:()=>US});var c1,zN,QN,JN,US,vS=Ie(()=>{c1=require("os"),zN=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 JN(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 QN(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}},QN=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)}},JN=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,c1.platform)()!="win32"&&(US=require("node-unix-socket").createReuseportFd)});var eI=N((HPe,l1)=>{"use strict";var hE=se();hE.initSync();var id=require("fs-extra"),ZN=require("path"),od=M(),jfe=require("crypto"),zfe=require("uuid").v4;l1.exports=Qfe;function Qfe(){if(hE.getHdbBasePath()!==void 0){let e=ZN.join(hE.getHdbBasePath(),od.LICENSE_KEY_DIR_NAME,od.JWT_ENUM.JWT_PRIVATE_KEY_NAME),t=ZN.join(hE.getHdbBasePath(),od.LICENSE_KEY_DIR_NAME,od.JWT_ENUM.JWT_PUBLIC_KEY_NAME),r=ZN.join(hE.getHdbBasePath(),od.LICENSE_KEY_DIR_NAME,od.JWT_ENUM.JWT_PASSPHRASE_NAME);try{id.accessSync(r),id.accessSync(e),id.accessSync(t)}catch(n){if(n.code==="ENOENT"){let s=zfe(),i=jfe.generateKeyPairSync("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem",cipher:"aes-256-cbc",passphrase:s}});id.writeFileSync(r,s),id.writeFileSync(e,i.privateKey),id.writeFileSync(t,i.publicKey)}else throw n}}}a(Qfe,"checkJWTTokenExist")});var d1=N((kPe,u1)=>{"use strict";var tI=class{static{a(this,"HdbInfoInsertObject")}constructor(t,r,n){this.info_id=t,this.data_version_num=r,this.hdb_version_num=n}};u1.exports={HdbInfoInsertObject:tI}});var E1=N((GPe,f1)=>{"use strict";var _1=M(),rI=class{static{a(this,"UpgradeObject")}constructor(t,r){this[_1.UPGRADE_JSON_FIELD_NAMES_ENUM.DATA_VERSION]=t,this[_1.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION]=r}};f1.exports={UpgradeObject:rI}});var BS=N(($Pe,p1)=>{"use strict";var Is=require("prompt"),ad=require("chalk"),h1=W(),ii=require("os"),nI=Wa(),sI=["yes","y"];async function Jfe(e){let t=`${ii.EOL}`+ad.bold.green("Your current HarperDB version requires that we complete an update process.")+`${ii.EOL}If a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${ii.EOL}${ii.EOL}You can read more about the changes in this upgrade at https://harperdb.io/developers/release-notes/${ii.EOL}`;Is.override=nI(["CONFIRM_UPGRADE"]),Is.start(),Is.message=t;let r={properties:{CONFIRM_UPGRADE:{description:ad.magenta(`${ii.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 Is.get([r])}catch(s){return h1.error("There was an error when prompting user about an upgrade."),h1.error(s),!1}return sI.includes(n.CONFIRM_UPGRADE)}a(Jfe,"forceUpdatePrompt");async function Xfe(e){let t=`${ii.EOL}`+ad.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.${ii.EOL}`);Is.override=nI(["CONFIRM_DOWNGRADE"]),Is.start(),Is.message=t;let r={properties:{CONFIRM_DOWNGRADE:{description:ad.magenta(`${ii.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 Is.get([r]);return sI.includes(n.CONFIRM_DOWNGRADE)}a(Xfe,"forceDowngradePrompt");async function Zfe(){let e=`${ii.EOL}`+ad.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");Is.override=nI(["GENERATE_CERTS"]),Is.start(),Is.message=e;let t={properties:{GENERATE_CERTS:{description:ad.magenta(`${ii.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 Is.get([t]);return sI.includes(r.GENERATE_CERTS)}a(Zfe,"upgradeCertsPrompt");p1.exports={forceUpdatePrompt:Jfe,forceDowngradePrompt:Xfe,upgradeCertsPrompt:Zfe}});var oI=N((KPe,m1)=>{"use strict";var iI=class{static{a(this,"UpgradeDirective")}constructor(t){this.version=t,this.sync_functions=[],this.async_functions=[]}};m1.exports=iI});var T1=N((JPe,S1)=>{"use strict";var eEe=te(),tEe=wt(),WPe=W(),jPe=require("path"),zPe=require("fs"),QPe=M();S1.exports={getOldPropsValue:rEe};function rEe(e,t,r=!1){let n=t.getRaw(e);return eEe.isNotEmptyAndHasValue(n)?n:r?tEe.getDefaultConfig(e):""}a(rEe,"getOldPropsValue")});var y1=N((ZPe,R1)=>{"use strict";var Oa=require("path"),Na=require("fs-extra"),nEe=require("properties-reader"),sEe=oI(),lr=W(),{getOldPropsValue:St}=T1(),{HDB_SETTINGS_NAMES:he,CONFIG_PARAMS:ol}=M(),al=wt(),HS=se(),g1=te(),xi=M(),aI=new sEe("3.1.0"),A1=[];function iEe(){let e=nEe(HS.get(he.SETTINGS_PATH_KEY)),t="Updating settings file for version 3.1.0";console.log(t),lr.info(t);let r=` ;Settings for the HarperDB process.
41
41
 
42
42
  ;The directory selected during install where the database files reside.
43
43
  ${he.HDB_ROOT_KEY} = ${St(he.HDB_ROOT_KEY,e)}
@@ -60,9 +60,9 @@ ${he.SERVER_KEEP_ALIVE_TIMEOUT_KEY} = ${St(he.SERVER_KEEP_ALIVE_TIMEOUT_KEY,e,!0
60
60
  ;Limit the amount of time the parser will wait to receive the complete HTTP headers.. Defaults to 60,000 ms (1 minute).
61
61
  ${he.SERVER_HEADERS_TIMEOUT_KEY} = ${St(he.SERVER_HEADERS_TIMEOUT_KEY,e,!0)}
62
62
  ;Define whether to log to file or not.
63
- ${he.LOG_TO_FILE} = ${sl.getDefaultConfig(nl.LOGGING_FILE)}
63
+ ${he.LOG_TO_FILE} = ${al.getDefaultConfig(ol.LOGGING_FILE)}
64
64
  ;Define whether to log to stdout/stderr or not. NOTE HarperDB must run in foreground in order to receive the std stream from HarperDB.
65
- ${he.LOG_TO_STDSTREAMS} = ${sl.getDefaultConfig(nl.LOGGING_STDSTREAMS)}
65
+ ${he.LOG_TO_STDSTREAMS} = ${al.getDefaultConfig(ol.LOGGING_STDSTREAMS)}
66
66
  ;Set to control amount of logging generated. Accepted levels are trace, debug, warn, error, fatal.
67
67
  ${he.LOG_LEVEL_KEY} = ${St(he.LOG_LEVEL_KEY,e)}
68
68
  ;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'
@@ -95,39 +95,39 @@ ${he.OPERATION_TOKEN_TIMEOUT_KEY} = ${St(he.OPERATION_TOKEN_TIMEOUT_KEY,e,!0)}
95
95
  ;Defines the length of time a refresh token will be valid until it expires. Example values: https://github.com/vercel/ms
96
96
  ${he.REFRESH_TOKEN_TIMEOUT_KEY} = ${St(he.REFRESH_TOKEN_TIMEOUT_KEY,e,!0)}
97
97
  ;The port the IPC server will run on.
98
- ${he.IPC_SERVER_PORT} = ${sl.getDefaultConfig(nl.IPC_NETWORK_PORT)}
98
+ ${he.IPC_SERVER_PORT} = ${al.getDefaultConfig(ol.IPC_NETWORK_PORT)}
99
99
  ;Run HDB in the foreground.
100
- ${he.RUN_IN_FOREGROUND} = ${sl.getDefaultConfig(nl.OPERATIONSAPI_FOREGROUND)}
100
+ ${he.RUN_IN_FOREGROUND} = ${al.getDefaultConfig(ol.OPERATIONSAPI_FOREGROUND)}
101
101
  ;Set to true to enable custom API endpoints. Requires a valid enterprise license.
102
- ${he.CUSTOM_FUNCTIONS_ENABLED_KEY} = ${sl.getDefaultConfig(nl.CUSTOMFUNCTIONS_ENABLED)}
102
+ ${he.CUSTOM_FUNCTIONS_ENABLED_KEY} = ${al.getDefaultConfig(ol.CUSTOMFUNCTIONS_ENABLED)}
103
103
  ;The port used to access the custom functions server.
104
- ${he.CUSTOM_FUNCTIONS_PORT_KEY} = ${sl.getDefaultConfig(nl.HTTP_PORT)}
104
+ ${he.CUSTOM_FUNCTIONS_PORT_KEY} = ${al.getDefaultConfig(ol.HTTP_PORT)}
105
105
  ;The path to the folder containing HarperDB custom function files.
106
106
  ${he.CUSTOM_FUNCTIONS_DIRECTORY_KEY} = ${Oa.join(St(he.HDB_ROOT_KEY,e),"custom_functions")}
107
107
  ;Set the max number of processes HarperDB will start for the Custom Functions server
108
- ${he.MAX_CUSTOM_FUNCTION_PROCESSES} = ${sl.getDefaultConfig(nl.HTTP_THREADS)}
109
- `,n=HS.get("settings_path"),s=Oa.dirname(n),i=Oa.join(s,"3_1_0_upgrade_settings.bak");try{lr.info(`Backing up old settings file to: ${i}`),Na.copySync(n,i)}catch(c){throw lr.error(c),console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),c}try{lr.info("New settings file values for 3.1.0 upgrade:",r),lr.info(`Creating new/upgraded settings file at '${n}'`),Na.writeFileSync(n,r),lr.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."),lr.error("Attempting to reset the settings file to its original state. Use the '.bak' file if this fails."),lr.error(c),Na.copySync(i,n),c}HS.initSync();let o="New settings file for 3.1.0 upgrade successfully created.";return console.log(o),lr.info(o),o}a(tEe,"updateSettingsFile_3_1_0");function rEe(){let e=Oa.join(m1.getHomeDir(),xi.HDB_HOME_DIR_NAME,xi.LICENSE_KEY_DIR_NAME,xi.LICENSE_FILE_NAME),t=Oa.join(m1.getHomeDir(),xi.HDB_HOME_DIR_NAME,xi.LICENSE_KEY_DIR_NAME,xi.REG_KEY_FILE_NAME),r=Oa.join(HS.getHdbBasePath(),xi.LICENSE_KEY_DIR_NAME,xi.LICENSE_FILE_NAME),n=Oa.join(r,xi.LICENSE_FILE_NAME),s=Oa.join(r,xi.REG_KEY_FILE_NAME),i="Move license files for version 3.1.0";console.log(i),lr.info(i);let o="Creating .license directory";console.log(o),lr.info(o),Na.mkdirpSync(r);try{Na.accessSync(e);try{let c="Moving licence file";console.log(c),lr.info(c),Na.moveSync(e,n);let l="License file successfully moved.";console.log(l),lr.info(l)}catch{let l="moving license file failed";console.error(l),lr.error(l)}}catch{let l=`license file '${e}' does not exist.`;console.warn(l),lr.warn(l)}try{Na.accessSync(t);try{let c="Moving registration file";console.log(c),lr.info(c),Na.moveSync(t,s);let l="Registration file successfully moved.";console.log(l),lr.info(l)}catch{let l="moving registration file failed";console.error(l),lr.error(l)}}catch{let l=`registration file '${t}' does not exist.`;console.warn(l),lr.warn(l)}}a(rEe,"moveLicenseFiles");oI.sync_functions.push(tEe);oI.sync_functions.push(rEe);S1.push(oI);T1.exports=S1});var O1=N((JPe,b1)=>{"use strict";var zn=ht(),{insertRecords:nEe}=sc(),sEe=cn(),Ia=Bt(),iEe=te(),wo=W(),oEe=te(),ki=require("fs-extra"),Co=require("path"),aEe=require("cli-progress"),pE=require("assert"),cEe=require("pino"),lEe=se();b1.exports=uEe;var xS,R1,kS,aI,rn,mE=!1;async function uEe(e=!0){return xS=lEe.getHdbBasePath(),R1=Co.join(xS,"schema"),kS=Co.join(xS,"4_0_0_upgrade_tmp"),aI=Co.join(xS,"transactions"),console.info("Reindexing upgrade started for schemas"),wo.notify("Reindexing upgrade started for schemas"),await A1(R1,!1,e),await ki.pathExists(aI)&&(console.info(`
108
+ ${he.MAX_CUSTOM_FUNCTION_PROCESSES} = ${al.getDefaultConfig(ol.HTTP_THREADS)}
109
+ `,n=HS.get("settings_path"),s=Oa.dirname(n),i=Oa.join(s,"3_1_0_upgrade_settings.bak");try{lr.info(`Backing up old settings file to: ${i}`),Na.copySync(n,i)}catch(c){throw lr.error(c),console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),c}try{lr.info("New settings file values for 3.1.0 upgrade:",r),lr.info(`Creating new/upgraded settings file at '${n}'`),Na.writeFileSync(n,r),lr.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."),lr.error("Attempting to reset the settings file to its original state. Use the '.bak' file if this fails."),lr.error(c),Na.copySync(i,n),c}HS.initSync();let o="New settings file for 3.1.0 upgrade successfully created.";return console.log(o),lr.info(o),o}a(iEe,"updateSettingsFile_3_1_0");function oEe(){let e=Oa.join(g1.getHomeDir(),xi.HDB_HOME_DIR_NAME,xi.LICENSE_KEY_DIR_NAME,xi.LICENSE_FILE_NAME),t=Oa.join(g1.getHomeDir(),xi.HDB_HOME_DIR_NAME,xi.LICENSE_KEY_DIR_NAME,xi.REG_KEY_FILE_NAME),r=Oa.join(HS.getHdbBasePath(),xi.LICENSE_KEY_DIR_NAME,xi.LICENSE_FILE_NAME),n=Oa.join(r,xi.LICENSE_FILE_NAME),s=Oa.join(r,xi.REG_KEY_FILE_NAME),i="Move license files for version 3.1.0";console.log(i),lr.info(i);let o="Creating .license directory";console.log(o),lr.info(o),Na.mkdirpSync(r);try{Na.accessSync(e);try{let c="Moving licence file";console.log(c),lr.info(c),Na.moveSync(e,n);let l="License file successfully moved.";console.log(l),lr.info(l)}catch{let l="moving license file failed";console.error(l),lr.error(l)}}catch{let l=`license file '${e}' does not exist.`;console.warn(l),lr.warn(l)}try{Na.accessSync(t);try{let c="Moving registration file";console.log(c),lr.info(c),Na.moveSync(t,s);let l="Registration file successfully moved.";console.log(l),lr.info(l)}catch{let l="moving registration file failed";console.error(l),lr.error(l)}}catch{let l=`registration file '${t}' does not exist.`;console.warn(l),lr.warn(l)}}a(oEe,"moveLicenseFiles");aI.sync_functions.push(iEe);aI.sync_functions.push(oEe);A1.push(aI);R1.exports=A1});var w1=N((tLe,I1)=>{"use strict";var zn=ht(),{insertRecords:aEe}=sc(),cEe=cn(),Ia=Ht(),lEe=te(),Io=W(),uEe=te(),ki=require("fs-extra"),wo=require("path"),dEe=require("cli-progress"),pE=require("assert"),_Ee=require("pino"),fEe=se();I1.exports=EEe;var xS,b1,kS,cI,rn,mE=!1;async function EEe(e=!0){return xS=fEe.getHdbBasePath(),b1=wo.join(xS,"schema"),kS=wo.join(xS,"4_0_0_upgrade_tmp"),cI=wo.join(xS,"transactions"),console.info("Reindexing upgrade started for schemas"),Io.notify("Reindexing upgrade started for schemas"),await O1(b1,!1,e),await ki.pathExists(cI)&&(console.info(`
110
110
 
111
- Reindexing upgrade started for transaction logs`),wo.notify("Reindexing upgrade started for transaction logs"),await A1(aI,!0,e)),wo.notify("Reindexing upgrade complete"),"Reindexing for 4.0.0 upgrade complete"+(mE?", but errors occurred":"")}a(uEe,"reindexUpgrade");async function A1(e,t,r){let n=await ki.readdir(e),s=n.length;for(let i=0;i<s;i++){let o=n[i],c=Co.join(e,o.toString());if(o===".DS_Store")continue;let l=await ki.readdir(c),u=l.length;for(let d=0;d<u;d++){let _=l[d];if(_!==".DS_Store"&&ki.statSync(Co.join(c,_)).isDirectory())try{await dEe(o,_,t),rn.info(`Reindexing started for ${o}.${_}`),wo.notify(`${t?"Transaction":"Schema"} reindexing started for ${o}.${_}`),await fEe(o,_,c,t,r),rn.info(`Reindexing completed for ${o}.${_}`),wo.notify(`Reindexing completed for ${o}.${_}`)}catch(E){mE=!0,E.schema_path=c,E.table_name=_,wo.error("There was an error with the reindex upgrade, check the logs in hdb/3_0_0_upgrade_tmp for more details"),wo.error(E),rn.error(E),console.error(E)}}}if(!mE)try{await ki.rm(kS,{recursive:!0})}catch{}}a(A1,"processTables");async function dEe(e,t,r){let s=`${e}_${t}_${r?"transaction_reindex":"schema_reindex"}.log`,i=Co.join(kS,s);await ki.ensureDir(kS),await ki.writeFile(i,""),rn=cEe({level:"debug",formatters:{bindings(){}}},i)}a(dEe,"initPinoLogger");var _Ee=20;async function fEe(e,t,r,n,s){let i;try{i=await zn.openEnvironment(r,t,n)}catch(S){if(S.message==="MDB_INVALID: File is not an LMDB file"){wo.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`),rn.error(S);return}throw S}let o=pEe(i.dbis),c=zn.openDBI(i,o),l=Object.keys(i.dbis),u=zn.statDBI(i,o);rn.info(`Old environment stats: ${JSON.stringify(u)}`);let d=new aEe.SingleBar({format:`${e}.${t} |{bar}| {percentage}% || {value}/{total} records`,barCompleteChar:"\u2588",barIncompleteChar:"\u2591",hideCursor:!0,clearOnComplete:!1});d.start(u.entryCount,0,{});let _=await zn.createEnvironment(r,t,!1);zn.createDBI(_,o,!1,!0);let E=[];try{for(let S of c.getRange({start:!1}))S.value={...S.value},E.push(S),n||e==="system"&&(t==="hdb_schema"&&(S.key=S.key.toString(),S.value.name=S.value.name.toString()),t==="hdb_table"&&(S.key=S.key.toString(),S.value.schema=S.value.schema.toString(),S.value.name=S.value.name.toString()),t==="hdb_attribute"&&(S.key=S.key.toString(),S.value.schema=S.value.schema.toString(),S.value.table=S.value.table.toString(),S.value.attribute=S.value.attribute.toString())),E.length>_Ee&&await f();await f()}catch(S){throw mE=!0,rn.error(S),S}async function f(){let S,b=E.map(({value:B})=>B);n?S=await Promise.all(b.map(B=>EEe(_,B))):S=await nEe(_,o,l.filter(B=>B!=="__blob__"),b,!1);for(let B=0,H=E.length;B<H;B++){let{key:X,value:Y}=E[B];rn.info(`Record hash value: ${X} hash: ${o}`);let V;n?V=S[B]:V=S.written_hashes.indexOf(X)>-1,pE(V,!0),hEe(_,o,Y[o],n),rn.info(`Insert success, written hashes: ${S.written_hashes}`),d.increment()}E=[],d.value/d.total*100%10===0&&wo.notify(`${e}.${t} ${d.value}/${d.total} records inserted`),rn.info(`${d.value}/${d.total} records inserted`)}a(f,"finishOutstanding"),d.stop();let h=zn.statDBI(i,o),T=zn.statDBI(_,o);if(rn.info(`Old stats entry count: ${h.entryCount}. New stats entry count: ${T.entryCount}`),pE.deepStrictEqual(h.entryCount,T.entryCount),await zn.closeEnvironment(i),await zn.closeEnvironment(_),delete global.lmdb_map[`${e}.${t}`],s){let S=Co.join(r,t),b=Co.join(S,"data.mdb"),I=Co.join(S,"lock.mdb");await ki.unlink(b),await ki.unlink(I),await ki.rmdir(S),rn.info(`Deleted old environment files from schema folder: ${b}, ${I}`)}let m=await zn.openEnvironment(r,t),g=zn.statDBI(m,o);rn.info(`New stats: ${JSON.stringify(T)}. New stats after move: ${JSON.stringify(g)}`),pE.deepStrictEqual(g.entryCount,T.entryCount),await zn.closeEnvironment(m),delete global.lmdb_map[`${e}.${t}`]}a(fEe,"processTable");async function EEe(e,t){zn.initializeDBIs(e,Ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Ia.TRANSACTIONS_DBIS);let r=t.timestamp;return e.dbis[Ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(r,()=>{e.dbis[Ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(r,t),oEe.isEmpty(t.user_name)||e.dbis[Ia.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(t.user_name,r);for(let n of t.hash_values)e.dbis[Ia.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(n,r)})}a(EEe,"insertTransaction");function hEe(e,t,r,n){let i=e.dbis[t].get(r);pE.deepStrictEqual(typeof i,"object");let o;if(n){let c={[Ia.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME]:i.user_name,[Ia.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&&!iEe.isEmptyOrZeroLength(l))if(n&&c==="hash_value")for(let u=0,d=l.length;u<d;u++){let _=l[u];y1(e,c,_,r)}else y1(e,c,l,r)}a(hEe,"validateIndices");function y1(e,t,r,n){try{let s=!1,i=sEe.getIndexedValues(r);if(!i)return;for(let o of i)s=e.dbis[t].doesExist(o,n),s||rn.info(`Validate indices did not find value in new DBI: ${o}. Hash: ${n}`),pE.deepStrictEqual(s,!0)}catch(s){mE=!0,rn.error(s),console.error(s)}}a(y1,"validateIndex");function pEe(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(pEe,"getHashDBI")});var D1=N((eLe,C1)=>{"use strict";var FS=require("path"),wa=require("fs-extra"),mEe=iI(),il=W(),N1=wt(),cI=se(),oi=M(),GS=te(),SEe=require("properties-reader"),TEe=$s(),gEe=Hp(),REe=Vr(),ZPe=require("util"),AEe=REe.searchByValue,yEe=un(),bEe=Tm(),OEe=Ct(),NEe=O1(),I1=Xs(),IEe=BS(),gE=new mEe("4.0.0"),w1=[],SE,TE;async function wEe(){try{if(await IEe.upgradeCertsPrompt()){if(console.log("Generating new certificates."),SE){let t=GS.changeExtension(SE,".bak");await wa.move(SE,t)}if(TE){let t=GS.changeExtension(TE,".bak");await wa.move(TE,t)}await I1.generateKeys()}else console.log("Using existing certificates."),I1.updateConfigCert(SE,TE,void 0)}catch(e){throw console.error("There was a problem generating new keys. Please check the log for details."),e}}a(wEe,"generateNewKeys");async function CEe(){console.log("Updating HarperDB nodes."),il.info("Updating HarperDB nodes.");let e=[];try{let t=new TEe(oi.SYSTEM_SCHEMA_NAME,oi.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*","name",["*"]),r=Array.from(await AEe(t)),n=[];for(let i=0,o=r.length;i<o;i++){let c=r[i];if(!OEe.NATS_TERM_CONSTRAINTS_RX.test(c.name)){let d=`Node name '${c.name}' is invalid, must not contain ., * or >. Please change name and try again.`;throw console.error(d),d}let l={host:c.host,port:c.port};e.push(l);let u=[];for(let d=0,_=c.subscriptions.length;d<_;d++){let E=c.subscriptions[d],f=E.channel.split(":");u.push({schema:f[0],table:f[1],publish:E.publish,subscribe:E.subscribe})}n.push({name:c.name,subscriptions:u,system_info:{hdb_version:oi.PRE_4_0_0_VERSION,node_version:void 0,platform:void 0}})}if(GS.isEmptyOrZeroLength(n))return;let s=new gEe(oi.SYSTEM_SCHEMA_NAME,oi.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,n);await yEe.update(s)}catch(t){throw console.error("There was a problem updating the hdb_nodes table. Please check the log for details."),t}try{bEe.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(CEe,"updateNodes");async function DEe(){let e=cI.get(oi.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);if(!e.includes(FS.join("config","settings.js"))){il.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),il.info(t);let r=FS.dirname(e),n=cI.get(oi.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),s=FS.join(n,"backup","4_0_0_upgrade_settings.bak"),i=FS.join(n,oi.HDB_CONFIG_FILE);try{il.info(`Backing up old settings file to: ${s}`),console.log(`Backing up old settings file to: ${s}`),wa.copySync(e,s)}catch(_){throw console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),_}try{il.info(`Creating new/upgraded settings file at '${i}'`),console.log(`Creating new/upgraded settings file at '${i}'`),il.info("Updating env variables with new settings values");let _=N1.initOldConfig(e);SE=_[oi.CONFIG_PARAMS.TLS_CERTIFICATE.toLowerCase()],TE=_[oi.CONFIG_PARAMS.TLS_PRIVATEKEY.toLowerCase()],N1.createConfigFile(_)}catch(_){throw console.log("There was a problem creating the new HarperDB config file. Please check the log for details."),_}let o=GS.getPropsFilePath();wa.accessSync(o,wa.constants.F_OK|wa.constants.R_OK);let l=SEe(o).get(oi.HDB_SETTINGS_NAMES.INSTALL_USER),u=`settings_path = ${i}
112
- install_user = ${l}`;try{wa.writeFileSync(o,u)}catch(_){throw console.log("There was a problem updating the HarperDB boot properties file. Please check the log for details."),_}try{cI.initSync(!0)}catch(_){throw console.error("Unable to initialize new properties. Please check the log for details."),_}let d="New settings file for 4.0.0 upgrade successfully created.";try{wa.removeSync(r),console.log(d),il.info(d)}catch(_){throw console.error("There was a problem deleting the old settings file and directory. Please check the log for details."),_}}a(DEe,"updateSettingsFile_4_0_0");gE.async_functions.push(DEe);gE.async_functions.push(wEe);gE.async_functions.push(NEe);gE.async_functions.push(CEe);w1.push(gE);C1.exports=w1});var lI=N((rLe,U1)=>{"use strict";var ol=te(),PEe=M(),P1=W(),{DATA_VERSION:LEe,UPGRADE_VERSION:MEe}=PEe.UPGRADE_JSON_FIELD_NAMES_ENUM,L1=g1(),qS=D1(),al=new Map;L1&&L1.forEach(e=>{al.set(e.version,e)});qS&&qS.forEach(e=>{al.set(e.version,e)});qS&&qS.forEach(e=>{al.set(e.version,e)});function UEe(){return[...al.keys()].sort(ol.compareVersions)}a(UEe,"getSortedVersions");function M1(e){let t=e[LEe],r=e[MEe];return ol.isEmptyOrZeroLength(t)||ol.isEmptyOrZeroLength(r)?(P1.info(`There is an issue with the version data in your instance of HDB. Current version data: ${e}`),P1.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."),[]):[...al.keys()].sort(ol.compareVersions).filter(function(n){return ol.compareVersions(n,t)>0&&ol.compareVersions(n,r)<=0})}a(M1,"getVersionsForUpgrade");function vEe(e){return M1(e).length>0}a(vEe,"hasUpgradesRequired");function BEe(e){return ol.isEmptyOrZeroLength(e)?null:al.has(e)?al.get(e):null}a(BEe,"getDirectiveByVersion");U1.exports={getSortedVersions:UEe,getDirectiveByVersion:BEe,getVersionsForUpgrade:M1,hasUpgradesRequired:vEe}});var VS=N((sLe,k1)=>{"use strict";var HEe=require("util"),uI=require("chalk"),xEe=require("os"),B1=un(),kEe=Vr(),Qn=M(),H1=c1(),_I=wR(),{UpgradeObject:v1}=d1(),{forceDowngradePrompt:FEe}=BS(),GEe=Uc(),$S=W(),ad=te(),fI=ls(),qEe=(Pe(),oe(lt)),$Ee=lI(),VEe=HEe.promisify(fI.setSchemaDataToGlobal),KEe=kEe.searchByValue,YEe="info_id",WEe="2.9.9",jEe="3.0.0";async function zEe(e){let t=new H1.HdbInfoInsertObject(1,e,e),r=new _I.InsertObject(Qn.OPERATIONS_ENUM.INSERT,Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,Qn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,[t]);return fI.setSchemaDataToGlobal(),B1.insert(r)}a(zEe,"insertHdbInstallInfo");async function dI(e){let t,r=await x1(),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 H1.HdbInfoInsertObject(i,e,e);let o=new _I.InsertObject(Qn.OPERATIONS_ENUM.INSERT,Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,Qn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,[t]);return await VEe(),B1.insert(o)}a(dI,"insertHdbUpgradeInfo");async function x1(){let e=new _I.NoSQLSeachObject(Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,YEe,Qn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,["*"],"*"),t=[];try{t=Array.from(await KEe(e))}catch(r){console.error(r)}return t}a(x1,"getAllHdbInfoRecords");async function QEe(){let e=await x1();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(QEe,"getLatestHdbInfoRecord");async function JEe(){$S.info("Checking if HDB software has been updated");try{let e=GEe.version(),t=await QEe(),r;if(ad.isEmpty(t))r=WEe;else if(r=t.data_version_num,ad.compareVersions(r.toString(),e.toString())>0){if(!ad.isCompatibleDataVersion(r.toString(),e.toString()))throw console.log(uI.yellow(`This instance's data was last run on version ${r}`)),console.error(uI.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.${xEe.EOL}${Qn.SUPPORT_HELP_MSG}`)),new Error("Trying to downgrade major HDB versions is not supported.");ad.isCompatibleDataVersion(r.toString(),e.toString(),!0)||(console.log(uI.yellow(`This instance's data was last run on version ${r}`)),await FEe(new v1(r,e))?await dI(e.toString()):(console.log("Cancelled downgrade, closing HarperDB"),process.exit(0)))}if(fI.setSchemaDataToGlobal(),XEe(r),e.toString()===r.toString())return;let n=new v1(r,e);if($Ee.hasUpgradesRequired(n))return n;ad.compareVersions(n.data_version.toString(),n.upgrade_version.toString())<0&&(await dI(n.upgrade_version),$S.notify(`HarperDB running on upgraded version: ${n.upgrade_version}`))}catch(e){throw $S.fatal("Error while trying to evaluate the state of hdb data and the installed hdb version"),$S.fatal(e),e}}a(JEe,"getVersionUpdateInfo");function XEe(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 ${Qn.HDB_SUPPORT_ADDRESS}`;if(!("hdb_info"in qEe.databases.system))throw console.log(t),new Error(t);if(!ad.isEmpty(e)&&e<jEe)throw console.log(t),new Error(t)}a(XEe,"checkIfInstallIsSupported");k1.exports={insertHdbInstallInfo:zEe,insertHdbUpgradeInfo:dI,getVersionUpdateInfo:JEe}});var $1=N((oLe,q1)=>{"use strict";var KS=require("joi"),{boolean:ZEe,string:EI,number:ehe}=KS.types(),F1=require("fs-extra"),RE=M(),G1=require("path"),the=Tt();q1.exports=rhe;function rhe(e){let t=EI.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),r=KS.object({[RE.INSTALL_PROMPTS.ROOTPATH]:KS.custom(nhe),[RE.INSTALL_PROMPTS.OPERATIONSAPI_NETWORK_PORT]:KS.alternatives([ehe.min(0),EI]).allow("null",null),[RE.INSTALL_PROMPTS.TC_AGREEMENT]:EI.valid("yes","YES","Yes"),[RE.INSTALL_PROMPTS.CLUSTERING_NODENAME]:t,[RE.INSTALL_PROMPTS.CLUSTERING_ENABLED]:ZEe});return the.validateBySchema(e,r)}a(rhe,"installValidator");function nhe(e,t){if(F1.existsSync(G1.join(e,"system/hdb_user/data.mdb"))||F1.existsSync(G1.join(e,"system/hdb_user.mdb")))return t.message(`'${e}' is already in use. Please enter a different path.`)}a(nhe,"validateRootAvailable")});var K1=N((cLe,V1)=>{"use strict";var{mkdirpSync:she,copySync:ihe}=require("fs-extra"),Ca=require("path"),cd=M(),pI=W(),ohe=Bn(),hI=Zi(),ahe=gt();V1.exports=che;async function che(e){pI.trace("Mounting HarperDB"),cl(e),cl(Ca.join(e,"backup")),cl(Ca.join(e,"keys")),cl(Ca.join(e,"keys",cd.LICENSE_FILE_NAME)),cl(Ca.join(e,"log")),cl(Ca.join(e,"database")),cl(Ca.join(e,"components")),ihe(Ca.resolve(cd.PACKAGE_ROOT,"./utility/install/README.md"),Ca.join(e,"README.md")),await lhe()}a(che,"mountHdb");async function lhe(){let e=I_(),t=Object.keys(hI);for(let r=0;r<t.length;r++){let n=t[r],s=hI[n].hash_attribute;try{ahe.initSystemSchemaPaths(cd.SYSTEM_SCHEMA_NAME,n);let i=new e(cd.SYSTEM_SCHEMA_NAME,n,s);i.attributes=hI[n].attributes;let o=i.attributes.find(({attribute:c})=>c===s);o.isPrimaryKey=!0,["hdb_user","hdb_role"].includes(n)&&(i.audit=!0),await ohe.createTable(n,i)}catch(i){throw pI.error(`issue creating environment for ${cd.SYSTEM_SCHEMA_NAME}.${n}: ${i}`),i}}}a(lhe,"createLMDBTables");function cl(e){she(e,{mode:cd.HDB_FILE_PERMISSIONS}),pI.info(`Directory ${e} created`)}a(cl,"makeDirectory")});var iK=N((_Le,sK)=>{"use strict";var SI=require("os"),Q1=require("inquirer"),Cs=require("fs-extra"),uhe=require("properties-reader"),ul=require("chalk"),Gi=require("path"),dhe=require("human-readable-ids").hri,_he=require("ora"),fhe=require("yaml"),ur=W(),Da=se(),AE=te(),WS=Wa(),J1=VS(),X1=Uc(),ue=M(),{CONFIG_PARAM_MAP:uLe,CONFIG_PARAMS:Mt}=ue,Ehe=$1(),hhe=K1(),TI=wt(),phe=xn(),mhe=lf(),She=ZN(),The=ls(),ghe=require("util").promisify,Rhe=ghe(The.setSchemaDataToGlobal),Y1=Xs(),ll=a(e=>e,"PROMPT_ANSWER_TRANSFORMER"),xr=a(e=>ul.magenta.bold(e),"HDB_PROMPT_MSG"),Ahe="https://harperdb.io/legal/end-user-license-agreement",Pa=SI.EOL,Do="",yhe="yes",W1="Starting HarperDB install...",j1="HarperDB installation was successful.",z1="Terms & Conditions acceptance is required to proceed with installation. Exiting install...",bhe="An out of date version of HarperDB is already installed.",mI="It appears that HarperDB is already installed. Exiting install...",Ohe="Aborting install",dLe=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])$/),Nhe=new RegExp(/^[^\s.,*>]+$/),Ihe=SI.homedir(),whe=Gi.join(Ihe,ue.HDB_ROOT_DIR_NAME),Che="HDB_ADMIN",Dhe="CLUSTER_USER",Phe="dev",Lhe="localhost",YS={[Mt.HTTP_CORS]:!0,[Mt.HTTP_CORSACCESSLIST]:["*"],[Mt.HTTP_PORT]:9926,[Mt.AUTHENTICATION_AUTHORIZELOCAL]:!0,[Mt.THREADS_COUNT]:1,[Mt.THREADS_DEBUG]:!0,[Mt.LOGGING_STDSTREAMS]:!0,[Mt.LOGGING_LEVEL]:"info",[Mt.OPERATIONSAPI_NETWORK_PORT]:9925,[Mt.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:"},La=WS([ue.INSTALL_PROMPTS.HDB_CONFIG]),Fi,Z1=!1,gI=!1,eK=!1;sK.exports={install:tK,updateConfigEnv:$he,setIgnoreExisting:Vhe};tK.createSuperUser=nK;async function tK(){console.log(xr(Pa+W1+Pa)),ur.notify(W1);let e;La[ue.INSTALL_PROMPTS.HDB_CONFIG]&&(e=Mhe());let t=vhe();Object.assign(t,e),t[ue.INSTALL_PROMPTS.TC_AGREEMENT]&&t[ue.INSTALL_PROMPTS.ROOTPATH]&&t[ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME]&&t[ue.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]&&t[ue.INSTALL_PROMPTS.DEFAULTS_MODE]===void 0&&(eK=!0,t[ue.INSTALL_PROMPTS.DEFAULTS_MODE]="prod");let r=Ehe(t);if(r)throw r.message;await Bhe(),await Hhe(t);let n=await Uhe(t);Fi=n[ue.INSTALL_PROMPTS.ROOTPATH],La[ue.INSTALL_PROMPTS.HDB_CONFIG]&&Gi.dirname(La[ue.INSTALL_PROMPTS.HDB_CONFIG])===Fi&&(Z1=!0),!gI&&!La[ue.INSTALL_PROMPTS.HDB_CONFIG]&&await Cs.pathExists(Gi.join(Fi,ue.HDB_CONFIG_FILE))&&(console.error(mI),process.exit());let s=_he({prefixText:xr("Installing"),color:"magenta",spinner:"simpleDots"});if(s.start(),AE.isEmpty(Fi))throw new Error("Installer should have the HDB root param at the stage it is in but it does not.");Da.setHdbBasePath(Fi),await hhe(Fi),await xhe(),await khe(n),ur.initLogSettings(!0),await nK(n),await Ghe(n),await Y1.updateConfigCert(),await Y1.generateCertsKeys(),await qhe(),She(),s.stop(),console.log(xr(Pa+j1+Pa)),ur.notify(j1)}a(tK,"install");function Mhe(){let e=fhe.parseDocument(Cs.readFileSync(La[ue.INSTALL_PROMPTS.HDB_CONFIG],"utf8"),{simpleKeys:!0}),t=TI.flattenConfig(e.toJSON());return t[ue.CONFIG_PARAMS.ROOTPATH.toLowerCase()]&&(t.ROOTPATH=t[ue.CONFIG_PARAMS.ROOTPATH.toLowerCase()]),t}a(Mhe,"getConfigFromFile");async function Uhe(e){ur.trace("Getting install prompts and params.");let t,r=[{type:"input",transformer:ll,when:Po(e[ue.INSTALL_PROMPTS.ROOTPATH],Hr.DESTINATION),name:ue.INSTALL_PROMPTS.ROOTPATH,prefix:Do,default:whe,validate:a(async s=>ws(s)?ws(s):await Cs.pathExists(Gi.join(s,"system","hdb_user.mdb"))?`'${s}' is already in use. Please enter a different path.`:!0,"validate"),message:xr(Hr.DESTINATION)},{type:"input",transformer:ll,when:Po(e[ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],Hr.HDB_USERNAME),name:ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME,prefix:Do,default:Che,validate:a(s=>ws(s)?ws(s):(t=s,!0),"validate"),message:xr(Hr.HDB_USERNAME)},{type:"password",when:Po(e[ue.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD],Hr.HDB_PASS),name:ue.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD,prefix:Do,validate:a(s=>ws(s)?ws(s):!0,"validate"),message:xr(Hr.HDB_PASS)},{type:"input",transformer:ll,when:Po(e[ue.INSTALL_PROMPTS.DEFAULTS_MODE],Hr.DEFAULTS_MODE),name:ue.INSTALL_PROMPTS.DEFAULTS_MODE,prefix:Do,default:Phe,validate:a(s=>ws(s)?ws(s):s!=="dev"&&s!=="prod"?`Invalid response '${s}', options are 'dev' or 'prod'.`:!0,"validate"),message:xr(Hr.DEFAULTS_MODE)}];if(eK||r.push({type:"input",name:ue.INSTALL_PROMPTS.REPLICATION_HOSTNAME,transformer:ll,when:Po(e[ue.INSTALL_PROMPTS.REPLICATION_HOSTNAME],Hr.REPLICATION_HOSTNAME),prefix:Do,default:Lhe,message:xr(Hr.REPLICATION_HOSTNAME)}),AE.autoCastBoolean(e[ue.INSTALL_PROMPTS.CLUSTERING_ENABLED])===!0){let s=[{type:"input",transformer:ll,when:Po(e[ue.INSTALL_PROMPTS.CLUSTERING_NODENAME],Hr.NODE_NAME),name:ue.INSTALL_PROMPTS.CLUSTERING_NODENAME,prefix:Do,default:dhe.random(),validate:a(i=>Nhe.test(i)?!0:"Invalid node name, must not contain ., * or >","validate"),message:xr(Hr.NODE_NAME)},{type:"input",transformer:ll,when:Po(e[ue.INSTALL_PROMPTS.CLUSTERING_USER],Hr.CLUSTER_USERNAME),name:ue.INSTALL_PROMPTS.CLUSTERING_USER,prefix:Do,default:Dhe,validate:a(i=>ws(i)?ws(i):i.toLowerCase()===t.toLowerCase()?"Username is already in use.":!0,"validate"),message:xr(Hr.CLUSTER_USERNAME)},{type:"password",when:Po(e[ue.INSTALL_PROMPTS.CLUSTERING_PASSWORD],Hr.CLUSTER_PASS),name:ue.INSTALL_PROMPTS.CLUSTERING_PASSWORD,prefix:Do,validate:a(i=>ws(i)?ws(i):!0,"validate"),message:xr(Hr.CLUSTER_PASS)}];r.push(...s)}let n=await Q1.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(Uhe,"installPrompts");function Po(e,t){return e!==void 0?(t.includes("password")?(console.log(`${xr(t)} ${ul.gray("[hidden]")}`),ur.trace(`${xr(t)} [hidden]`)):(console.log(`${xr(t)} ${e}`),ur.trace(`${xr(t)} ${e}`)),!1):!0}a(Po,"displayCmdEnvVar");function ws(e){let t=e.replace(/ /g,"");if(t===""||t==="''"||t==='""')return"Value cannot be empty."}a(ws,"checkForEmptyValue");function vhe(){let e=Object.keys(ue.INSTALL_PROMPTS),t=WS(e),r=WS(Object.keys(ue.CONFIG_PARAM_MAP),!0),n={};for(let s of e){let i=ue.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(vhe,"checkForPromptOverride");async function Bhe(){ur.trace("Checking for existing install.");let e=AE.getPropsFilePath(),t=await Cs.pathExists(e),r;if(t){ur.trace(`Install found an existing boot prop file at:${e}`);let n=uhe(e),s=TI.getConfigValue(ue.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)||n.get(ue.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY);r=await Cs.pathExists(s)}if(!t&&AE.noBootFile()&&(r=!0),r&&!gI){if(ur.trace(`Install found existing HDB config at:${e}`),await J1.getVersionUpdateInfo()){let s=`Please use \`harperdb upgrade\` to update to ${X1.version()}. Exiting install...`;console.log(Pa+ul.magenta.bold(bhe)),console.log(ul.magenta.bold(s)),ur.error(s)}else console.log(Pa+ul.magenta.bold(mI)),ur.error(mI);process.exit(0)}}a(Bhe,"checkForExistingInstall");async function Hhe(e){ur.info("Asking for terms agreement.");let t=`Terms & Conditions can be found at ${Ahe}${Pa}and can be viewed by typing or copying and pasting the URL into your web browser.${Pa}I agree to the HarperDB Terms and Conditions: (yes/no)`,r={prefix:Do,transformer:ll,when:Po(e[ue.INSTALL_PROMPTS.TC_AGREEMENT],t),name:ue.INSTALL_PROMPTS.TC_AGREEMENT,message:xr(t),validate:a(s=>s.toLowerCase()==="yes"||s.toLowerCase()==="no"?!0:ul.yellow("Please enter 'yes' or 'no'"),"validate")},n=await Q1.prompt([r]);n[ue.INSTALL_PROMPTS.TC_AGREEMENT]&&n[ue.INSTALL_PROMPTS.TC_AGREEMENT].toLowerCase()!==yhe&&(console.log(ul.yellow(z1)),ur.error(z1),process.exit(0))}a(Hhe,"termsAgreement");async function xhe(){let e=Gi.join(Fi,ue.HDB_CONFIG_FILE),t;try{t=SI.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}
113
- install_user = ${t}`,n=AE.getHomeDir(),s=Gi.join(n,ue.HDB_HOME_DIR_NAME),i=Gi.join(s,ue.LICENSE_KEY_DIR_NAME);try{Cs.mkdirpSync(s,{mode:ue.HDB_FILE_PERMISSIONS}),Cs.mkdirpSync(i,{mode:ue.HDB_FILE_PERMISSIONS})}catch{console.error(`Could not make settings directory ${ue.HDB_HOME_DIR_NAME} in home directory. Please check your permissions and try again.`)}let o=Gi.join(s,ue.BOOT_PROPS_FILE_NAME);try{await Cs.writeFile(o,r)}catch(c){throw ur.error(`There was an error creating the boot file at path: ${o}`),c}Da.setProperty(ue.HDB_SETTINGS_NAMES.INSTALL_USER,`${t}`),Da.setProperty(ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,e),Da.setProperty(Da.BOOT_PROPS_FILE_PATH,o)}}a(xhe,"createBootPropertiesFile");async function khe(e){ur.trace("Creating HarperDB config file");let t=WS(Object.keys(ue.CONFIG_PARAM_MAP),!0);if(Object.assign(t,e),e[ue.INSTALL_PROMPTS.DEFAULTS_MODE]==="dev"){process.env.DEV_MODE="true";for(let r in YS){if(r===Mt.HTTP_PORT&&t[Mt.HTTP_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??YS[r],t[Mt.HTTP_SECUREPORT]=null;continue}else if(r===Mt.HTTP_PORT)continue;if(r===Mt.OPERATIONSAPI_NETWORK_PORT&&t[Mt.OPERATIONSAPI_NETWORK_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??YS[r],t[Mt.OPERATIONSAPI_NETWORK_SECUREPORT]=null;continue}else if(r===Mt.OPERATIONSAPI_NETWORK_PORT)continue;t[r.toLowerCase()]===void 0&&(t[r]=YS[r])}}else t[Mt.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]&&(t[Mt.OPERATIONSAPI_NETWORK_SECUREPORT]=null),t[Mt.HTTP_PORT.toLowerCase()]&&(t[Mt.HTTP_SECUREPORT]=null);try{La[ue.INSTALL_PROMPTS.HDB_CONFIG]||TI.createConfigFile(t),Da.initSync()}catch(r){Fhe(r)}}a(khe,"createConfigFile");function Fhe(e){ur.error(`Error creating HarperDB config file. Rolling back install - ${e}`),console.error(e),console.error(Ohe);let t=Gi.resolve(Da.get(Da.BOOT_PROPS_FILE_PATH),"../");t&&Cs.removeSync(t),Fi&&(Z1?Cs.readdirSync(Fi,{withFileTypes:!0}).forEach(n=>{let s=Gi.join(n.path,n.name);s!==La[ue.INSTALL_PROMPTS.HDB_CONFIG]&&Cs.removeSync(s)}):Cs.removeSync(Fi)),process.exit(1)}a(Fhe,"rollbackInstall");async function rK(e,t){ur.trace("Creating admin user"),await Rhe();let r;try{r=await mhe.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 phe.addUser(t)}catch(n){throw n.message=`Error creating user - ${n}`,n}}a(rK,"createAdminUser");async function nK(e){ur.trace("Creating Super user.");let t={role:"super_user",permission:{super_user:!0}},r={username:e[ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME].toString(),password:e[ue.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD].toString(),active:!0};await rK(t,r),delete e[ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],delete e[ue.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]}a(nK,"createSuperUser");async function Ghe(e){ur.trace("Creating Cluster user.");let t;e[ue.INSTALL_PROMPTS.CLUSTERING_USER]&&e[ue.INSTALL_PROMPTS.CLUSTERING_PASSWORD]&&(t={username:e[ue.INSTALL_PROMPTS.CLUSTERING_USER].toString(),password:e[ue.INSTALL_PROMPTS.CLUSTERING_PASSWORD].toString(),active:!0}),await rK({role:"cluster_user",permission:{cluster_user:!0}},t),delete e[ue.INSTALL_PROMPTS.CLUSTERING_USER],delete e[ue.INSTALL_PROMPTS.CLUSTERING_PASSWORD]}a(Ghe,"createClusterUser");async function qhe(){let e=X1.version();if(e)await J1.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(qhe,"insertHdbVersionInfo");function $he(e){La[ue.INSTALL_PROMPTS.HDB_CONFIG]=e}a($he,"updateConfigEnv");function Vhe(e){gI=e}a(Vhe,"setIgnoreExisting")});var cK=N((ELe,aK)=>{"use strict";var RI=te(),Jn=W(),oK=lI();aK.exports={processDirectives:Khe};async function Khe(e){console.log("Starting upgrade process...");let t=oK.getVersionsForUpgrade(e),r=jhe(t),n=[],s=r.length;for(let i=0;i<s;i++){let o=r[i],c=`Running upgrade for version ${o.version}`;Jn.notify(c),console.log(c);let l=[],u=[];try{l=Yhe(o.sync_functions)}catch(d){throw Jn.error(`Error while running an upgrade script for ${o.version}`),d}try{u=await Whe(o.async_functions)}catch(d){throw Jn.error(`Error while running an upgrade script for ${o.version}`),d}n.push(...l,...u)}return n}a(Khe,"processDirectives");function Yhe(e){if(RI.isEmptyOrZeroLength(e))return Jn.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return Jn.info("Passed parameter is not an array"),[];let t=[];for(let r of e){if(Jn.info(`Running function ${r.name}`),!(r instanceof Function)){Jn.info("Variable being processed is not a function");continue}let n=r();Jn.info(n),t.push(n)}return t}a(Yhe,"runSyncFunctions");async function Whe(e){if(RI.isEmptyOrZeroLength(e))return Jn.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return Jn.info("Passed parameter is not an array"),[];let t=[],r=e.length;for(let n=0;n<r;n++){let s=e[n];if(Jn.info(`Running function ${s.name}`),!(s instanceof Function)){Jn.info("Variable being processed is not a function");continue}let i=await s();Jn.info(i),t.push(i)}return t}a(Whe,"runAsyncFunctions");function jhe(e){if(RI.isEmptyOrZeroLength(e))return[];let t=[];for(let r of e){let n=oK.getDirectiveByVersion(r);n&&t.push(n)}return t}a(jhe,"getUpgradeDirectivesToInstall")});var hK=N((pLe,EK)=>{"use strict";var jS=se();jS.initSync();var _K=require("chalk"),lK=require("fs-extra"),Mo=W(),Lo=M(),uK=Uc(),zhe=cK(),AI=te(),fK=VS(),Qhe=BS(),dK=hg(),Jhe=ls(),Xhe=require("util").promisify,Zhe=Xhe(Jhe.setSchemaDataToGlobal),yI,{UPGRADE_VERSION:zS}=Lo.UPGRADE_JSON_FIELD_NAMES_ENUM;EK.exports={upgrade:epe};async function epe(e){await Zhe(),yI===void 0&&(yI=Uu()),lK.existsSync(jS.get(jS.BOOT_PROPS_FILE_PATH))||(yE("The hdb_boot_properties file was not found. Please install HDB.",Lo.LOG_LEVELS.ERROR),process.exit(1)),lK.existsSync(jS.get(Lo.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))||(yE("The hdb settings file was not found. Please make sure HDB is installed.",Lo.LOG_LEVELS.ERROR),process.exit(1));let t=e;t||(t=await fK.getVersionUpdateInfo(),t||(console.log("HarperDB version is current"),process.exit(0))),yE(`This version of HarperDB is ${uK.version()}`,Lo.LOG_LEVELS.INFO);let r=t[zS]?t[zS]:uK.version();r||(console.log(`Current Version field missing from the package.json file. Cannot continue with upgrade. If you need support, please contact ${Lo.HDB_SUPPORT_ADDRESS}`),Mo.notify("Missing new version field from upgrade info object"),process.exit(1)),await tpe();let n,s=0;try{n=await Qhe.forceUpdatePrompt(t)}catch(i){Mo.error("There was an error when prompting user about upgrade."),Mo.error(i),n=!1,s=1}n||(console.log("Cancelled upgrade, closing HarperDB"),process.exit(s)),Mo.info(`Starting upgrade to version ${r}`),await rpe(t),yE(`HarperDB was successfully upgraded to version ${t[zS]}`,Lo.LOG_LEVELS.INFO)}a(epe,"upgrade");async function tpe(){let e=!1,t=await dK.findPs(Lo.HDB_PROC_NAME);if(AI.isEmptyOrZeroLength(t)||(e=!0),!e){let r=await dK.findPs("hdb_express");AI.isEmptyOrZeroLength(r)||(e=!0)}if(!e){let r=await yI.list();AI.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(_K.red(r)),Mo.error(r),process.exit(1)}}a(tpe,"checkIfRunning");async function rpe(e){try{await zhe.processDirectives(e)}catch(t){throw yE("There was an error during the data upgrade. Please check the logs.",Lo.LOG_LEVELS.ERROR),t}try{await fK.insertHdbUpgradeInfo(e[zS])}catch(t){Mo.error("Error updating the 'hdb_info' system table."),Mo.error(t)}}a(rpe,"runUpgrade");function yE(e,t=void 0){t||(t=Mo.info),Mo[t](e),console.log(_K.magenta(e))}a(yE,"printToLogAndConsole")});var gK=N((SLe,TK)=>{"use strict";var{promises:OI,createReadStream:npe,createWriteStream:spe}=require("fs"),{createGzip:ipe}=require("zlib"),{promisify:ope}=require("util"),{pipeline:ape}=require("stream"),cpe=ope(ape),lpe=require("path"),_l=se();_l.initSync();var dl=W(),{CONFIG_PARAMS:bE,ITC_EVENT_TYPES:upe}=M(),{onMessageFromWorkers:dpe}=dt(),_pe=6e4,fpe="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",Epe="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",bI,mK;TK.exports=SK;dpe(e=>{e.type===upe.RESTART&&(_l.initSync(!0),clearInterval(mK),_l.get(bE.LOGGING_ROTATION_ENABLED)&&SK())});async function SK(){try{let e=dl.getLogFilePath(),t=_l.get(bE.LOGGING_ROTATION_MAXSIZE),r=_l.get(bE.LOGGING_ROTATION_INTERVAL);if(!t&&!r){dl.error(fpe);return}let n=_l.get(bE.LOGGING_ROTATION_PATH);if(!n){dl.error(Epe);return}let s;if(t){let o=t.slice(-1),c=t.slice(0,-1);o==="G"?s=c*1e9:o==="M"?s=c*1e6:s=c*1e3}let i;if(r){let o=r.slice(-1),c=r.slice(0,-1);o==="D"?i=c*1440:o==="H"?i=c*60:i=c}bI=Date.now()/6e4,dl.trace("Log rotate enabled, maxSize:",t,"interval:",r),mK=setInterval(async()=>{if(s){let o;o=await OI.stat(e),o.size>=s&&await pK(e,n)}i&&Date.now()/6e4-bI>=i&&(await pK(e,n),bI=Date.now()/6e4)},_pe).unref()}catch(e){dl.error(e)}}a(SK,"logRotator");async function pK(e,t){let r=_l.get(bE.LOGGING_ROTATION_COMPRESS),n=lpe.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.${r?"log.gz":"log"}`);r?(await cpe(npe(e),ipe(),spe(n)),await OI.unlink(e)):await OI.rename(e,n),dl.closeLogFile(),dl.notify(`hdb.log rotated, old log moved to ${n}`)}a(pK,"moveLogFile")});var wK=N(IK=>{"use strict";var pe=se();pe.initSync();var gLe=xu(),Xt=M(),Xn=W(),Uo=require("fs-extra"),vo=require("path"),hpe=require("systeminformation"),ppe=ZN(),{install:mpe}=iK(),NI=require("chalk"),Spe=jl(),Bo=te(),II=wt(),AK=Wa(),RK=bm(),Tpe=hK(),gpe=gK(),{compactOnStart:Rpe}=(oO(),oe(iO)),Ape=require("minimist"),ype=Xs(),{PACKAGE_ROOT:bpe,CONFIG_PARAMS:we}=M(),{startHTTPThreads:Ope,startSocketServer:RLe,mostIdleRouting:ALe,remoteAffinityRouting:yLe}=(wI(),oe(CK)),Npe=VS(),{isMainThread:Ipe}=require("worker_threads"),bLe=Zi(),OLe=ro(),NLe=mA(),ILe=I_(),QS=M(),qi,ld,yK=!1,wpe="Upgrade complete. Starting HarperDB.",Cpe="Got an error while trying to upgrade your HarperDB instance. Exiting HarperDB.",Dpe="HarperDB not found, starting install process.",Ppe="There was an error during install, check install_log.log for more details. Exiting.",Lpe="HarperDB successfully started.";function Mpe(){if(!yK){let e=a(()=>{Uo.removeSync(vo.join(pe.get(Xt.CONFIG_PARAMS.ROOTPATH),Xt.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(Mpe,"addExitListeners");async function bK(e=!1,t=!1){if(console.log(NI.magenta("Starting HarperDB...")),Xn.suppressLogging?.(()=>{console.log(NI.magenta(""+Uo.readFileSync(vo.join(bpe,"utility/install/ascii_logo.txt"))))}),await NK()===!1){console.log(Dpe);try{await mpe()}catch(o){console.error(Ppe,o),Xn.error(o),process.exit(1)}}if(!e){let o=AK(Object.keys(Xt.CONFIG_PARAM_MAP),!0);!Bo.isEmpty(o)&&!Bo.isEmptyOrZeroLength(Object.keys(o))&&II.updateConfigValue(void 0,void 0,o,!0,!0)}let r,n=ld?.service==="clustering";ld?.service&&!n&&(console.error("Unrecognized service argument"),process.exit(1));try{let o=Number.parseInt(await Uo.readFile(vo.join(pe.get(Xt.CONFIG_PARAMS.ROOTPATH),Xt.HDB_PID_FILE),"utf8")),c=await hpe.processes();for(let l of c.list)if(l.pid===o){n?r=!0:console.log("HarperDB appears to be already running.");break}}catch{}qi===void 0&&(qi=Uu()),n&&(r||(console.error("HarperDB must be running to start clustering."),process.exit()),pe.get(Xt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY)||(console.error("Clustering must be setup and enabled in harperdb-config."),process.exit()),console.log("Starting clustering."),await RK.generateNatsConfig(),await qi.startClusteringProcesses(!0),process.exit()),Mpe(),await Uo.writeFile(vo.join(pe.get(QS.CONFIG_PARAMS.ROOTPATH),QS.HDB_PID_FILE),`${process.pid}`),Xn.info("HarperDB PID",process.pid);let s;try{let o=await Npe.getVersionUpdateInfo();o!==void 0&&(s=o[Xt.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION],await Tpe.upgrade(o),console.log(wpe))}catch(o){s?(console.error(`Got an error while trying to upgrade your HarperDB instance to version ${s}. Exiting HarperDB.`,o),Xn.error(o)):(console.error(Cpe,o),Xn.error(o)),process.exit(1)}ppe(),Bpe(),await ype.reviewSelfSignedCert(),Bo.autoCastBoolean(pe.get(Xt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&Ipe&&await RK.generateNatsConfig(t)}a(bK,"initialize");async function Upe(e=!1){try{ld=Ape(process.argv),ld.ROOTPATH&&II.updateConfigObject("settings_path",vo.join(ld.ROOTPATH,Xt.HDB_CONFIG_FILE)),await bK(e,!0),pe.get(Xt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await Rpe();let t=process.env.IS_SCRIPTED_SERVICE&&!ld.service;Bo.autoCastBoolean(pe.get(Xt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&(t||await qi.startClusteringProcesses(),await qi.startClusteringThreads()),await Ope(process.env.DEV_MODE?1:pe.get(QS.CONFIG_PARAMS.THREADS_COUNT)??pe.get(QS.CONFIG_PARAMS.THREADS)),pe.get(Xt.CONFIG_PARAMS.LOGGING_ROTATION_ENABLED)&&await gpe(),t||OK()}catch(t){console.error(t),Xn.error(t),process.exit(1)}}a(Upe,"main");function OK(){Xn.suppressLogging(()=>{console.log(NI.magenta(`HarperDB ${Spe.version} successfully started`))}),Xn.notify(Lpe)}a(OK,"started");async function vpe(e=!0){yK=!e;try{qi===void 0&&(qi=Uu()),qi.enterPM2Mode(),await bK(),Bo.autoCastBoolean(pe.get(Xt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&await qi.startClusteringProcesses(),await qi.startService(Xt.PROCESS_DESCRIPTORS.HDB),OK(),e&&process.exit(0)}catch(t){console.error(t),Xn.error(t),process.exit(1)}}a(vpe,"launch");function Bpe(){let e=vo.join(pe.get(Xt.CONFIG_PARAMS.ROOTPATH),Xt.LICENSE_KEY_DIR_NAME,Xt.LICENSE_FILE_NAME),t=vo.join(e,Xt.LICENSE_FILE_NAME),r=vo.join(e,Xt.REG_KEY_FILE_NAME);try{let{HARPERDB_FINGERPRINT:n,HARPERDB_LICENSE:s}=AK(["HARPERDB_FINGERPRINT","HARPERDB_LICENSE"]);if(Bo.isEmpty(n)||Bo.isEmpty(s))return;Uo.mkdirpSync(e),Uo.writeFileSync(r,n),Uo.writeFileSync(t,s)}catch(n){let s=`Failed to write license & fingerprint due to: ${n.message}`;console.error(s),Xn.error(s)}}a(Bpe,"writeLicenseFromVars");Object.assign(IK,{launch:vpe,main:Upe,isHdbInstalled:NK,startupLog:Hpe});async function NK(){try{await Uo.stat(Bo.getPropsFilePath()),await Uo.stat(pe.get(Xt.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}catch(e){if(Bo.noBootFile())return!0;if(e.code==="ENOENT")return!1;throw Xn.error(`Error checking for HDB install - ${e}`),e}return!0}a(NK,"isHdbInstalled");function Hpe(e){let r=a(f=>f.padEnd(20),"pad"),n=`
114
- `;pe.get(we.REPLICATION_HOSTNAME)&&(n+=`${r("Hostname:")}${pe.get(we.REPLICATION_HOSTNAME)}
115
- `),pe.get(we.REPLICATION_URL)&&(n+=`${r("Replication Url:")}${pe.get(we.REPLICATION_URL)}
116
- `),n+=`${r("Worker Threads:")}${pe.get(we.THREADS_COUNT)}
117
- `,n+=`${r("Root Path:")}${pe.get(we.ROOTPATH)}
118
- `,pe.get(we.THREADS_DEBUG)!==!1&&(n+=`${r("Debugging:")}enabled: true`,n+=pe.get(we.THREADS_DEBUG_PORT)?`, TCP: ${pe.get(we.THREADS_DEBUG_PORT)}
111
+ Reindexing upgrade started for transaction logs`),Io.notify("Reindexing upgrade started for transaction logs"),await O1(cI,!0,e)),Io.notify("Reindexing upgrade complete"),"Reindexing for 4.0.0 upgrade complete"+(mE?", but errors occurred":"")}a(EEe,"reindexUpgrade");async function O1(e,t,r){let n=await ki.readdir(e),s=n.length;for(let i=0;i<s;i++){let o=n[i],c=wo.join(e,o.toString());if(o===".DS_Store")continue;let l=await ki.readdir(c),u=l.length;for(let d=0;d<u;d++){let _=l[d];if(_!==".DS_Store"&&ki.statSync(wo.join(c,_)).isDirectory())try{await hEe(o,_,t),rn.info(`Reindexing started for ${o}.${_}`),Io.notify(`${t?"Transaction":"Schema"} reindexing started for ${o}.${_}`),await mEe(o,_,c,t,r),rn.info(`Reindexing completed for ${o}.${_}`),Io.notify(`Reindexing completed for ${o}.${_}`)}catch(E){mE=!0,E.schema_path=c,E.table_name=_,Io.error("There was an error with the reindex upgrade, check the logs in hdb/3_0_0_upgrade_tmp for more details"),Io.error(E),rn.error(E),console.error(E)}}}if(!mE)try{await ki.rm(kS,{recursive:!0})}catch{}}a(O1,"processTables");async function hEe(e,t,r){let s=`${e}_${t}_${r?"transaction_reindex":"schema_reindex"}.log`,i=wo.join(kS,s);await ki.ensureDir(kS),await ki.writeFile(i,""),rn=_Ee({level:"debug",formatters:{bindings(){}}},i)}a(hEe,"initPinoLogger");var pEe=20;async function mEe(e,t,r,n,s){let i;try{i=await zn.openEnvironment(r,t,n)}catch(S){if(S.message==="MDB_INVALID: File is not an LMDB file"){Io.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`),rn.error(S);return}throw S}let o=gEe(i.dbis),c=zn.openDBI(i,o),l=Object.keys(i.dbis),u=zn.statDBI(i,o);rn.info(`Old environment stats: ${JSON.stringify(u)}`);let d=new dEe.SingleBar({format:`${e}.${t} |{bar}| {percentage}% || {value}/{total} records`,barCompleteChar:"\u2588",barIncompleteChar:"\u2591",hideCursor:!0,clearOnComplete:!1});d.start(u.entryCount,0,{});let _=await zn.createEnvironment(r,t,!1);zn.createDBI(_,o,!1,!0);let E=[];try{for(let S of c.getRange({start:!1}))S.value={...S.value},E.push(S),n||e==="system"&&(t==="hdb_schema"&&(S.key=S.key.toString(),S.value.name=S.value.name.toString()),t==="hdb_table"&&(S.key=S.key.toString(),S.value.schema=S.value.schema.toString(),S.value.name=S.value.name.toString()),t==="hdb_attribute"&&(S.key=S.key.toString(),S.value.schema=S.value.schema.toString(),S.value.table=S.value.table.toString(),S.value.attribute=S.value.attribute.toString())),E.length>pEe&&await f();await f()}catch(S){throw mE=!0,rn.error(S),S}async function f(){let S,b=E.map(({value:B})=>B);n?S=await Promise.all(b.map(B=>SEe(_,B))):S=await aEe(_,o,l.filter(B=>B!=="__blob__"),b,!1);for(let B=0,H=E.length;B<H;B++){let{key:X,value:Y}=E[B];rn.info(`Record hash value: ${X} hash: ${o}`);let V;n?V=S[B]:V=S.written_hashes.indexOf(X)>-1,pE(V,!0),TEe(_,o,Y[o],n),rn.info(`Insert success, written hashes: ${S.written_hashes}`),d.increment()}E=[],d.value/d.total*100%10===0&&Io.notify(`${e}.${t} ${d.value}/${d.total} records inserted`),rn.info(`${d.value}/${d.total} records inserted`)}a(f,"finishOutstanding"),d.stop();let h=zn.statDBI(i,o),T=zn.statDBI(_,o);if(rn.info(`Old stats entry count: ${h.entryCount}. New stats entry count: ${T.entryCount}`),pE.deepStrictEqual(h.entryCount,T.entryCount),await zn.closeEnvironment(i),await zn.closeEnvironment(_),delete global.lmdb_map[`${e}.${t}`],s){let S=wo.join(r,t),b=wo.join(S,"data.mdb"),I=wo.join(S,"lock.mdb");await ki.unlink(b),await ki.unlink(I),await ki.rmdir(S),rn.info(`Deleted old environment files from schema folder: ${b}, ${I}`)}let m=await zn.openEnvironment(r,t),g=zn.statDBI(m,o);rn.info(`New stats: ${JSON.stringify(T)}. New stats after move: ${JSON.stringify(g)}`),pE.deepStrictEqual(g.entryCount,T.entryCount),await zn.closeEnvironment(m),delete global.lmdb_map[`${e}.${t}`]}a(mEe,"processTable");async function SEe(e,t){zn.initializeDBIs(e,Ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Ia.TRANSACTIONS_DBIS);let r=t.timestamp;return e.dbis[Ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(r,()=>{e.dbis[Ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(r,t),uEe.isEmpty(t.user_name)||e.dbis[Ia.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(t.user_name,r);for(let n of t.hash_values)e.dbis[Ia.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(n,r)})}a(SEe,"insertTransaction");function TEe(e,t,r,n){let i=e.dbis[t].get(r);pE.deepStrictEqual(typeof i,"object");let o;if(n){let c={[Ia.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME]:i.user_name,[Ia.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&&!lEe.isEmptyOrZeroLength(l))if(n&&c==="hash_value")for(let u=0,d=l.length;u<d;u++){let _=l[u];N1(e,c,_,r)}else N1(e,c,l,r)}a(TEe,"validateIndices");function N1(e,t,r,n){try{let s=!1,i=cEe.getIndexedValues(r);if(!i)return;for(let o of i)s=e.dbis[t].doesExist(o,n),s||rn.info(`Validate indices did not find value in new DBI: ${o}. Hash: ${n}`),pE.deepStrictEqual(s,!0)}catch(s){mE=!0,rn.error(s),console.error(s)}}a(N1,"validateIndex");function gEe(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(gEe,"getHashDBI")});var M1=N((sLe,L1)=>{"use strict";var FS=require("path"),wa=require("fs-extra"),AEe=oI(),cl=W(),C1=wt(),lI=se(),oi=M(),GS=te(),REe=require("properties-reader"),yEe=$s(),bEe=Hp(),OEe=Vr(),nLe=require("util"),NEe=OEe.searchByValue,IEe=un(),wEe=gm(),CEe=Ct(),DEe=w1(),D1=Xs(),PEe=BS(),gE=new AEe("4.0.0"),P1=[],SE,TE;async function LEe(){try{if(await PEe.upgradeCertsPrompt()){if(console.log("Generating new certificates."),SE){let t=GS.changeExtension(SE,".bak");await wa.move(SE,t)}if(TE){let t=GS.changeExtension(TE,".bak");await wa.move(TE,t)}await D1.generateKeys()}else console.log("Using existing certificates."),D1.updateConfigCert(SE,TE,void 0)}catch(e){throw console.error("There was a problem generating new keys. Please check the log for details."),e}}a(LEe,"generateNewKeys");async function MEe(){console.log("Updating HarperDB nodes."),cl.info("Updating HarperDB nodes.");let e=[];try{let t=new yEe(oi.SYSTEM_SCHEMA_NAME,oi.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*","name",["*"]),r=Array.from(await NEe(t)),n=[];for(let i=0,o=r.length;i<o;i++){let c=r[i];if(!CEe.NATS_TERM_CONSTRAINTS_RX.test(c.name)){let d=`Node name '${c.name}' is invalid, must not contain ., * or >. Please change name and try again.`;throw console.error(d),d}let l={host:c.host,port:c.port};e.push(l);let u=[];for(let d=0,_=c.subscriptions.length;d<_;d++){let E=c.subscriptions[d],f=E.channel.split(":");u.push({schema:f[0],table:f[1],publish:E.publish,subscribe:E.subscribe})}n.push({name:c.name,subscriptions:u,system_info:{hdb_version:oi.PRE_4_0_0_VERSION,node_version:void 0,platform:void 0}})}if(GS.isEmptyOrZeroLength(n))return;let s=new bEe(oi.SYSTEM_SCHEMA_NAME,oi.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,n);await IEe.update(s)}catch(t){throw console.error("There was a problem updating the hdb_nodes table. Please check the log for details."),t}try{wEe.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(MEe,"updateNodes");async function UEe(){let e=lI.get(oi.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);if(!e.includes(FS.join("config","settings.js"))){cl.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),cl.info(t);let r=FS.dirname(e),n=lI.get(oi.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),s=FS.join(n,"backup","4_0_0_upgrade_settings.bak"),i=FS.join(n,oi.HDB_CONFIG_FILE);try{cl.info(`Backing up old settings file to: ${s}`),console.log(`Backing up old settings file to: ${s}`),wa.copySync(e,s)}catch(_){throw console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),_}try{cl.info(`Creating new/upgraded settings file at '${i}'`),console.log(`Creating new/upgraded settings file at '${i}'`),cl.info("Updating env variables with new settings values");let _=C1.initOldConfig(e);SE=_[oi.CONFIG_PARAMS.TLS_CERTIFICATE.toLowerCase()],TE=_[oi.CONFIG_PARAMS.TLS_PRIVATEKEY.toLowerCase()],C1.createConfigFile(_)}catch(_){throw console.log("There was a problem creating the new HarperDB config file. Please check the log for details."),_}let o=GS.getPropsFilePath();wa.accessSync(o,wa.constants.F_OK|wa.constants.R_OK);let l=REe(o).get(oi.HDB_SETTINGS_NAMES.INSTALL_USER),u=`settings_path = ${i}
112
+ install_user = ${l}`;try{wa.writeFileSync(o,u)}catch(_){throw console.log("There was a problem updating the HarperDB boot properties file. Please check the log for details."),_}try{lI.initSync(!0)}catch(_){throw console.error("Unable to initialize new properties. Please check the log for details."),_}let d="New settings file for 4.0.0 upgrade successfully created.";try{wa.removeSync(r),console.log(d),cl.info(d)}catch(_){throw console.error("There was a problem deleting the old settings file and directory. Please check the log for details."),_}}a(UEe,"updateSettingsFile_4_0_0");gE.async_functions.push(UEe);gE.async_functions.push(LEe);gE.async_functions.push(DEe);gE.async_functions.push(MEe);P1.push(gE);L1.exports=P1});var uI=N((oLe,H1)=>{"use strict";var ll=te(),vEe=M(),U1=W(),{DATA_VERSION:BEe,UPGRADE_VERSION:HEe}=vEe.UPGRADE_JSON_FIELD_NAMES_ENUM,v1=y1(),qS=M1(),ul=new Map;v1&&v1.forEach(e=>{ul.set(e.version,e)});qS&&qS.forEach(e=>{ul.set(e.version,e)});qS&&qS.forEach(e=>{ul.set(e.version,e)});function xEe(){return[...ul.keys()].sort(ll.compareVersions)}a(xEe,"getSortedVersions");function B1(e){let t=e[BEe],r=e[HEe];return ll.isEmptyOrZeroLength(t)||ll.isEmptyOrZeroLength(r)?(U1.info(`There is an issue with the version data in your instance of HDB. Current version data: ${e}`),U1.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."),[]):[...ul.keys()].sort(ll.compareVersions).filter(function(n){return ll.compareVersions(n,t)>0&&ll.compareVersions(n,r)<=0})}a(B1,"getVersionsForUpgrade");function kEe(e){return B1(e).length>0}a(kEe,"hasUpgradesRequired");function FEe(e){return ll.isEmptyOrZeroLength(e)?null:ul.has(e)?ul.get(e):null}a(FEe,"getDirectiveByVersion");H1.exports={getSortedVersions:xEe,getDirectiveByVersion:FEe,getVersionsForUpgrade:B1,hasUpgradesRequired:kEe}});var VS=N((cLe,q1)=>{"use strict";var GEe=require("util"),dI=require("chalk"),qEe=require("os"),k1=un(),$Ee=Vr(),Qn=M(),F1=d1(),fI=wA(),{UpgradeObject:x1}=E1(),{forceDowngradePrompt:VEe}=BS(),KEe=vc(),$S=W(),cd=te(),EI=ls(),YEe=(Pe(),oe(lt)),WEe=uI(),jEe=GEe.promisify(EI.setSchemaDataToGlobal),zEe=$Ee.searchByValue,QEe="info_id",JEe="2.9.9",XEe="3.0.0";async function ZEe(e){let t=new F1.HdbInfoInsertObject(1,e,e),r=new fI.InsertObject(Qn.OPERATIONS_ENUM.INSERT,Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,Qn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,[t]);return EI.setSchemaDataToGlobal(),k1.insert(r)}a(ZEe,"insertHdbInstallInfo");async function _I(e){let t,r=await G1(),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 F1.HdbInfoInsertObject(i,e,e);let o=new fI.InsertObject(Qn.OPERATIONS_ENUM.INSERT,Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,Qn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,[t]);return await jEe(),k1.insert(o)}a(_I,"insertHdbUpgradeInfo");async function G1(){let e=new fI.NoSQLSeachObject(Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,QEe,Qn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,["*"],"*"),t=[];try{t=Array.from(await zEe(e))}catch(r){console.error(r)}return t}a(G1,"getAllHdbInfoRecords");async function ehe(){let e=await G1();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(ehe,"getLatestHdbInfoRecord");async function the(){$S.info("Checking if HDB software has been updated");try{let e=KEe.version(),t=await ehe(),r;if(cd.isEmpty(t))r=JEe;else if(r=t.data_version_num,cd.compareVersions(r.toString(),e.toString())>0){if(!cd.isCompatibleDataVersion(r.toString(),e.toString()))throw console.log(dI.yellow(`This instance's data was last run on version ${r}`)),console.error(dI.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.${qEe.EOL}${Qn.SUPPORT_HELP_MSG}`)),new Error("Trying to downgrade major HDB versions is not supported.");cd.isCompatibleDataVersion(r.toString(),e.toString(),!0)||(console.log(dI.yellow(`This instance's data was last run on version ${r}`)),await VEe(new x1(r,e))?await _I(e.toString()):(console.log("Cancelled downgrade, closing HarperDB"),process.exit(0)))}if(EI.setSchemaDataToGlobal(),rhe(r),e.toString()===r.toString())return;let n=new x1(r,e);if(WEe.hasUpgradesRequired(n))return n;cd.compareVersions(n.data_version.toString(),n.upgrade_version.toString())<0&&(await _I(n.upgrade_version),$S.notify(`HarperDB running on upgraded version: ${n.upgrade_version}`))}catch(e){throw $S.fatal("Error while trying to evaluate the state of hdb data and the installed hdb version"),$S.fatal(e),e}}a(the,"getVersionUpdateInfo");function rhe(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 ${Qn.HDB_SUPPORT_ADDRESS}`;if(!("hdb_info"in YEe.databases.system))throw console.log(t),new Error(t);if(!cd.isEmpty(e)&&e<XEe)throw console.log(t),new Error(t)}a(rhe,"checkIfInstallIsSupported");q1.exports={insertHdbInstallInfo:ZEe,insertHdbUpgradeInfo:_I,getVersionUpdateInfo:the}});var Y1=N((uLe,K1)=>{"use strict";var KS=require("joi"),{boolean:nhe,string:hI,number:she}=KS.types(),$1=require("fs-extra"),AE=M(),V1=require("path"),ihe=Tt();K1.exports=ohe;function ohe(e){let t=hI.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),r=KS.object({[AE.INSTALL_PROMPTS.ROOTPATH]:KS.custom(ahe),[AE.INSTALL_PROMPTS.OPERATIONSAPI_NETWORK_PORT]:KS.alternatives([she.min(0),hI]).allow("null",null),[AE.INSTALL_PROMPTS.TC_AGREEMENT]:hI.valid("yes","YES","Yes"),[AE.INSTALL_PROMPTS.CLUSTERING_NODENAME]:t,[AE.INSTALL_PROMPTS.CLUSTERING_ENABLED]:nhe});return ihe.validateBySchema(e,r)}a(ohe,"installValidator");function ahe(e,t){if($1.existsSync(V1.join(e,"system/hdb_user/data.mdb"))||$1.existsSync(V1.join(e,"system/hdb_user.mdb")))return t.message(`'${e}' is already in use. Please enter a different path.`)}a(ahe,"validateRootAvailable")});var j1=N((_Le,W1)=>{"use strict";var{mkdirpSync:che,copySync:lhe}=require("fs-extra"),Ca=require("path"),ld=M(),mI=W(),uhe=Bn(),pI=Zi(),dhe=gt();W1.exports=_he;async function _he(e){mI.trace("Mounting HarperDB"),dl(e),dl(Ca.join(e,"backup")),dl(Ca.join(e,"keys")),dl(Ca.join(e,"keys",ld.LICENSE_FILE_NAME)),dl(Ca.join(e,"log")),dl(Ca.join(e,"database")),dl(Ca.join(e,"components")),lhe(Ca.resolve(ld.PACKAGE_ROOT,"./utility/install/README.md"),Ca.join(e,"README.md")),await fhe()}a(_he,"mountHdb");async function fhe(){let e=w_(),t=Object.keys(pI);for(let r=0;r<t.length;r++){let n=t[r],s=pI[n].hash_attribute;try{dhe.initSystemSchemaPaths(ld.SYSTEM_SCHEMA_NAME,n);let i=new e(ld.SYSTEM_SCHEMA_NAME,n,s);i.attributes=pI[n].attributes;let o=i.attributes.find(({attribute:c})=>c===s);o.isPrimaryKey=!0,["hdb_user","hdb_role"].includes(n)&&(i.audit=!0),await uhe.createTable(n,i)}catch(i){throw mI.error(`issue creating environment for ${ld.SYSTEM_SCHEMA_NAME}.${n}: ${i}`),i}}}a(fhe,"createLMDBTables");function dl(e){che(e,{mode:ld.HDB_FILE_PERMISSIONS}),mI.info(`Directory ${e} created`)}a(dl,"makeDirectory")});var cK=N((pLe,aK)=>{"use strict";var TI=require("os"),Z1=require("inquirer"),Cs=require("fs-extra"),Ehe=require("properties-reader"),fl=require("chalk"),Gi=require("path"),hhe=require("human-readable-ids").hri,phe=require("ora"),mhe=require("yaml"),ur=W(),Da=se(),RE=te(),WS=Wa(),eK=VS(),tK=vc(),ue=M(),{CONFIG_PARAM_MAP:ELe,CONFIG_PARAMS:Mt}=ue,She=Y1(),The=j1(),gI=wt(),ghe=xn(),Ahe=lf(),Rhe=eI(),yhe=ls(),bhe=require("util").promisify,Ohe=bhe(yhe.setSchemaDataToGlobal),z1=Xs(),_l=a(e=>e,"PROMPT_ANSWER_TRANSFORMER"),xr=a(e=>fl.magenta.bold(e),"HDB_PROMPT_MSG"),Nhe="https://harperdb.io/legal/end-user-license-agreement",Pa=TI.EOL,Co="",Ihe="yes",Q1="Starting HarperDB install...",J1="HarperDB installation was successful.",X1="Terms & Conditions acceptance is required to proceed with installation. Exiting install...",whe="An out of date version of HarperDB is already installed.",SI="It appears that HarperDB is already installed. Exiting install...",Che="Aborting install",hLe=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])$/),Dhe=new RegExp(/^[^\s.,*>]+$/),Phe=TI.homedir(),Lhe=Gi.join(Phe,ue.HDB_ROOT_DIR_NAME),Mhe="HDB_ADMIN",Uhe="CLUSTER_USER",vhe="dev",Bhe="localhost",YS={[Mt.HTTP_CORS]:!0,[Mt.HTTP_CORSACCESSLIST]:["*"],[Mt.HTTP_PORT]:9926,[Mt.AUTHENTICATION_AUTHORIZELOCAL]:!0,[Mt.THREADS_COUNT]:1,[Mt.THREADS_DEBUG]:!0,[Mt.LOGGING_STDSTREAMS]:!0,[Mt.LOGGING_LEVEL]:"info",[Mt.OPERATIONSAPI_NETWORK_PORT]:9925,[Mt.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:"},La=WS([ue.INSTALL_PROMPTS.HDB_CONFIG]),Fi,rK=!1,AI=!1,nK=!1;aK.exports={install:sK,updateConfigEnv:Whe,setIgnoreExisting:jhe};sK.createSuperUser=oK;async function sK(){console.log(xr(Pa+Q1+Pa)),ur.notify(Q1);let e;La[ue.INSTALL_PROMPTS.HDB_CONFIG]&&(e=Hhe());let t=khe();Object.assign(t,e),t[ue.INSTALL_PROMPTS.TC_AGREEMENT]&&t[ue.INSTALL_PROMPTS.ROOTPATH]&&t[ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME]&&t[ue.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]&&t[ue.INSTALL_PROMPTS.DEFAULTS_MODE]===void 0&&(nK=!0,t[ue.INSTALL_PROMPTS.DEFAULTS_MODE]="prod");let r=She(t);if(r)throw r.message;await Fhe(),await Ghe(t);let n=await xhe(t);Fi=n[ue.INSTALL_PROMPTS.ROOTPATH],La[ue.INSTALL_PROMPTS.HDB_CONFIG]&&Gi.dirname(La[ue.INSTALL_PROMPTS.HDB_CONFIG])===Fi&&(rK=!0),!AI&&!La[ue.INSTALL_PROMPTS.HDB_CONFIG]&&await Cs.pathExists(Gi.join(Fi,ue.HDB_CONFIG_FILE))&&(console.error(SI),process.exit());let s=phe({prefixText:xr("Installing"),color:"magenta",spinner:"simpleDots"});if(s.start(),RE.isEmpty(Fi))throw new Error("Installer should have the HDB root param at the stage it is in but it does not.");Da.setHdbBasePath(Fi),await The(Fi),await qhe(),await $he(n),ur.initLogSettings(!0),await oK(n),await Khe(n),await z1.updateConfigCert(),await z1.generateCertsKeys(),await Yhe(),Rhe(),s.stop(),console.log(xr(Pa+J1+Pa)),ur.notify(J1)}a(sK,"install");function Hhe(){let e=mhe.parseDocument(Cs.readFileSync(La[ue.INSTALL_PROMPTS.HDB_CONFIG],"utf8"),{simpleKeys:!0}),t=gI.flattenConfig(e.toJSON());return t[ue.CONFIG_PARAMS.ROOTPATH.toLowerCase()]&&(t.ROOTPATH=t[ue.CONFIG_PARAMS.ROOTPATH.toLowerCase()]),t}a(Hhe,"getConfigFromFile");async function xhe(e){ur.trace("Getting install prompts and params.");let t,r=[{type:"input",transformer:_l,when:Do(e[ue.INSTALL_PROMPTS.ROOTPATH],Hr.DESTINATION),name:ue.INSTALL_PROMPTS.ROOTPATH,prefix:Co,default:Lhe,validate:a(async s=>ws(s)?ws(s):await Cs.pathExists(Gi.join(s,"system","hdb_user.mdb"))?`'${s}' is already in use. Please enter a different path.`:!0,"validate"),message:xr(Hr.DESTINATION)},{type:"input",transformer:_l,when:Do(e[ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],Hr.HDB_USERNAME),name:ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME,prefix:Co,default:Mhe,validate:a(s=>ws(s)?ws(s):(t=s,!0),"validate"),message:xr(Hr.HDB_USERNAME)},{type:"password",when:Do(e[ue.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD],Hr.HDB_PASS),name:ue.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD,prefix:Co,validate:a(s=>ws(s)?ws(s):!0,"validate"),message:xr(Hr.HDB_PASS)},{type:"input",transformer:_l,when:Do(e[ue.INSTALL_PROMPTS.DEFAULTS_MODE],Hr.DEFAULTS_MODE),name:ue.INSTALL_PROMPTS.DEFAULTS_MODE,prefix:Co,default:vhe,validate:a(s=>ws(s)?ws(s):s!=="dev"&&s!=="prod"?`Invalid response '${s}', options are 'dev' or 'prod'.`:!0,"validate"),message:xr(Hr.DEFAULTS_MODE)}];if(nK||r.push({type:"input",name:ue.INSTALL_PROMPTS.REPLICATION_HOSTNAME,transformer:_l,when:Do(e[ue.INSTALL_PROMPTS.REPLICATION_HOSTNAME],Hr.REPLICATION_HOSTNAME),prefix:Co,default:Bhe,message:xr(Hr.REPLICATION_HOSTNAME)}),RE.autoCastBoolean(e[ue.INSTALL_PROMPTS.CLUSTERING_ENABLED])===!0){let s=[{type:"input",transformer:_l,when:Do(e[ue.INSTALL_PROMPTS.CLUSTERING_NODENAME],Hr.NODE_NAME),name:ue.INSTALL_PROMPTS.CLUSTERING_NODENAME,prefix:Co,default:hhe.random(),validate:a(i=>Dhe.test(i)?!0:"Invalid node name, must not contain ., * or >","validate"),message:xr(Hr.NODE_NAME)},{type:"input",transformer:_l,when:Do(e[ue.INSTALL_PROMPTS.CLUSTERING_USER],Hr.CLUSTER_USERNAME),name:ue.INSTALL_PROMPTS.CLUSTERING_USER,prefix:Co,default:Uhe,validate:a(i=>ws(i)?ws(i):i.toLowerCase()===t.toLowerCase()?"Username is already in use.":!0,"validate"),message:xr(Hr.CLUSTER_USERNAME)},{type:"password",when:Do(e[ue.INSTALL_PROMPTS.CLUSTERING_PASSWORD],Hr.CLUSTER_PASS),name:ue.INSTALL_PROMPTS.CLUSTERING_PASSWORD,prefix:Co,validate:a(i=>ws(i)?ws(i):!0,"validate"),message:xr(Hr.CLUSTER_PASS)}];r.push(...s)}let n=await Z1.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(xhe,"installPrompts");function Do(e,t){return e!==void 0?(t.includes("password")?(console.log(`${xr(t)} ${fl.gray("[hidden]")}`),ur.trace(`${xr(t)} [hidden]`)):(console.log(`${xr(t)} ${e}`),ur.trace(`${xr(t)} ${e}`)),!1):!0}a(Do,"displayCmdEnvVar");function ws(e){let t=e.replace(/ /g,"");if(t===""||t==="''"||t==='""')return"Value cannot be empty."}a(ws,"checkForEmptyValue");function khe(){let e=Object.keys(ue.INSTALL_PROMPTS),t=WS(e),r=WS(Object.keys(ue.CONFIG_PARAM_MAP),!0),n={};for(let s of e){let i=ue.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(khe,"checkForPromptOverride");async function Fhe(){ur.trace("Checking for existing install.");let e=RE.getPropsFilePath(),t=await Cs.pathExists(e),r;if(t){ur.trace(`Install found an existing boot prop file at:${e}`);let n=Ehe(e),s=gI.getConfigValue(ue.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)||n.get(ue.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY);r=await Cs.pathExists(s)}if(!t&&RE.noBootFile()&&(r=!0),r&&!AI){if(ur.trace(`Install found existing HDB config at:${e}`),await eK.getVersionUpdateInfo()){let s=`Please use \`harperdb upgrade\` to update to ${tK.version()}. Exiting install...`;console.log(Pa+fl.magenta.bold(whe)),console.log(fl.magenta.bold(s)),ur.error(s)}else console.log(Pa+fl.magenta.bold(SI)),ur.error(SI);process.exit(0)}}a(Fhe,"checkForExistingInstall");async function Ghe(e){ur.info("Asking for terms agreement.");let t=`Terms & Conditions can be found at ${Nhe}${Pa}and can be viewed by typing or copying and pasting the URL into your web browser.${Pa}I agree to the HarperDB Terms and Conditions: (yes/no)`,r={prefix:Co,transformer:_l,when:Do(e[ue.INSTALL_PROMPTS.TC_AGREEMENT],t),name:ue.INSTALL_PROMPTS.TC_AGREEMENT,message:xr(t),validate:a(s=>s.toLowerCase()==="yes"||s.toLowerCase()==="no"?!0:fl.yellow("Please enter 'yes' or 'no'"),"validate")},n=await Z1.prompt([r]);n[ue.INSTALL_PROMPTS.TC_AGREEMENT]&&n[ue.INSTALL_PROMPTS.TC_AGREEMENT].toLowerCase()!==Ihe&&(console.log(fl.yellow(X1)),ur.error(X1),process.exit(0))}a(Ghe,"termsAgreement");async function qhe(){let e=Gi.join(Fi,ue.HDB_CONFIG_FILE),t;try{t=TI.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}
113
+ install_user = ${t}`,n=RE.getHomeDir(),s=Gi.join(n,ue.HDB_HOME_DIR_NAME),i=Gi.join(s,ue.LICENSE_KEY_DIR_NAME);try{Cs.mkdirpSync(s,{mode:ue.HDB_FILE_PERMISSIONS}),Cs.mkdirpSync(i,{mode:ue.HDB_FILE_PERMISSIONS})}catch{console.error(`Could not make settings directory ${ue.HDB_HOME_DIR_NAME} in home directory. Please check your permissions and try again.`)}let o=Gi.join(s,ue.BOOT_PROPS_FILE_NAME);try{await Cs.writeFile(o,r)}catch(c){throw ur.error(`There was an error creating the boot file at path: ${o}`),c}Da.setProperty(ue.HDB_SETTINGS_NAMES.INSTALL_USER,`${t}`),Da.setProperty(ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,e),Da.setProperty(Da.BOOT_PROPS_FILE_PATH,o)}}a(qhe,"createBootPropertiesFile");async function $he(e){ur.trace("Creating HarperDB config file");let t=WS(Object.keys(ue.CONFIG_PARAM_MAP),!0);if(Object.assign(t,e),e[ue.INSTALL_PROMPTS.DEFAULTS_MODE]==="dev"){process.env.DEV_MODE="true";for(let r in YS){if(r===Mt.HTTP_PORT&&t[Mt.HTTP_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??YS[r],t[Mt.HTTP_SECUREPORT]=null;continue}else if(r===Mt.HTTP_PORT)continue;if(r===Mt.OPERATIONSAPI_NETWORK_PORT&&t[Mt.OPERATIONSAPI_NETWORK_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??YS[r],t[Mt.OPERATIONSAPI_NETWORK_SECUREPORT]=null;continue}else if(r===Mt.OPERATIONSAPI_NETWORK_PORT)continue;t[r.toLowerCase()]===void 0&&(t[r]=YS[r])}}else t[Mt.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]&&(t[Mt.OPERATIONSAPI_NETWORK_SECUREPORT]=null),t[Mt.HTTP_PORT.toLowerCase()]&&(t[Mt.HTTP_SECUREPORT]=null);try{La[ue.INSTALL_PROMPTS.HDB_CONFIG]||gI.createConfigFile(t),Da.initSync()}catch(r){Vhe(r)}}a($he,"createConfigFile");function Vhe(e){ur.error(`Error creating HarperDB config file. Rolling back install - ${e}`),console.error(e),console.error(Che);let t=Gi.resolve(Da.get(Da.BOOT_PROPS_FILE_PATH),"../");t&&Cs.removeSync(t),Fi&&(rK?Cs.readdirSync(Fi,{withFileTypes:!0}).forEach(n=>{let s=Gi.join(n.path,n.name);s!==La[ue.INSTALL_PROMPTS.HDB_CONFIG]&&Cs.removeSync(s)}):Cs.removeSync(Fi)),process.exit(1)}a(Vhe,"rollbackInstall");async function iK(e,t){ur.trace("Creating admin user"),await Ohe();let r;try{r=await Ahe.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 ghe.addUser(t)}catch(n){throw n.message=`Error creating user - ${n}`,n}}a(iK,"createAdminUser");async function oK(e){ur.trace("Creating Super user.");let t={role:"super_user",permission:{super_user:!0}},r={username:e[ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME].toString(),password:e[ue.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD].toString(),active:!0};await iK(t,r),delete e[ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],delete e[ue.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]}a(oK,"createSuperUser");async function Khe(e){ur.trace("Creating Cluster user.");let t;e[ue.INSTALL_PROMPTS.CLUSTERING_USER]&&e[ue.INSTALL_PROMPTS.CLUSTERING_PASSWORD]&&(t={username:e[ue.INSTALL_PROMPTS.CLUSTERING_USER].toString(),password:e[ue.INSTALL_PROMPTS.CLUSTERING_PASSWORD].toString(),active:!0}),await iK({role:"cluster_user",permission:{cluster_user:!0}},t),delete e[ue.INSTALL_PROMPTS.CLUSTERING_USER],delete e[ue.INSTALL_PROMPTS.CLUSTERING_PASSWORD]}a(Khe,"createClusterUser");async function Yhe(){let e=tK.version();if(e)await eK.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(Yhe,"insertHdbVersionInfo");function Whe(e){La[ue.INSTALL_PROMPTS.HDB_CONFIG]=e}a(Whe,"updateConfigEnv");function jhe(e){AI=e}a(jhe,"setIgnoreExisting")});var dK=N((SLe,uK)=>{"use strict";var RI=te(),Jn=W(),lK=uI();uK.exports={processDirectives:zhe};async function zhe(e){console.log("Starting upgrade process...");let t=lK.getVersionsForUpgrade(e),r=Xhe(t),n=[],s=r.length;for(let i=0;i<s;i++){let o=r[i],c=`Running upgrade for version ${o.version}`;Jn.notify(c),console.log(c);let l=[],u=[];try{l=Qhe(o.sync_functions)}catch(d){throw Jn.error(`Error while running an upgrade script for ${o.version}`),d}try{u=await Jhe(o.async_functions)}catch(d){throw Jn.error(`Error while running an upgrade script for ${o.version}`),d}n.push(...l,...u)}return n}a(zhe,"processDirectives");function Qhe(e){if(RI.isEmptyOrZeroLength(e))return Jn.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return Jn.info("Passed parameter is not an array"),[];let t=[];for(let r of e){if(Jn.info(`Running function ${r.name}`),!(r instanceof Function)){Jn.info("Variable being processed is not a function");continue}let n=r();Jn.info(n),t.push(n)}return t}a(Qhe,"runSyncFunctions");async function Jhe(e){if(RI.isEmptyOrZeroLength(e))return Jn.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return Jn.info("Passed parameter is not an array"),[];let t=[],r=e.length;for(let n=0;n<r;n++){let s=e[n];if(Jn.info(`Running function ${s.name}`),!(s instanceof Function)){Jn.info("Variable being processed is not a function");continue}let i=await s();Jn.info(i),t.push(i)}return t}a(Jhe,"runAsyncFunctions");function Xhe(e){if(RI.isEmptyOrZeroLength(e))return[];let t=[];for(let r of e){let n=lK.getDirectiveByVersion(r);n&&t.push(n)}return t}a(Xhe,"getUpgradeDirectivesToInstall")});var SK=N((gLe,mK)=>{"use strict";var jS=se();jS.initSync();var hK=require("chalk"),_K=require("fs-extra"),Lo=W(),Po=M(),fK=vc(),Zhe=dK(),yI=te(),pK=VS(),epe=BS(),EK=hg(),tpe=ls(),rpe=require("util").promisify,npe=rpe(tpe.setSchemaDataToGlobal),bI,{UPGRADE_VERSION:zS}=Po.UPGRADE_JSON_FIELD_NAMES_ENUM;mK.exports={upgrade:spe};async function spe(e){await npe(),bI===void 0&&(bI=Hu()),_K.existsSync(jS.get(jS.BOOT_PROPS_FILE_PATH))||(yE("The hdb_boot_properties file was not found. Please install HDB.",Po.LOG_LEVELS.ERROR),process.exit(1)),_K.existsSync(jS.get(Po.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))||(yE("The hdb settings file was not found. Please make sure HDB is installed.",Po.LOG_LEVELS.ERROR),process.exit(1));let t=e;t||(t=await pK.getVersionUpdateInfo(),t||(console.log("HarperDB version is current"),process.exit(0))),yE(`This version of HarperDB is ${fK.version()}`,Po.LOG_LEVELS.INFO);let r=t[zS]?t[zS]:fK.version();r||(console.log(`Current Version field missing from the package.json file. Cannot continue with upgrade. If you need support, please contact ${Po.HDB_SUPPORT_ADDRESS}`),Lo.notify("Missing new version field from upgrade info object"),process.exit(1)),await ipe();let n,s=0;try{n=await epe.forceUpdatePrompt(t)}catch(i){Lo.error("There was an error when prompting user about upgrade."),Lo.error(i),n=!1,s=1}n||(console.log("Cancelled upgrade, closing HarperDB"),process.exit(s)),Lo.info(`Starting upgrade to version ${r}`),await ope(t),yE(`HarperDB was successfully upgraded to version ${t[zS]}`,Po.LOG_LEVELS.INFO)}a(spe,"upgrade");async function ipe(){let e=!1,t=await EK.findPs(Po.HDB_PROC_NAME);if(yI.isEmptyOrZeroLength(t)||(e=!0),!e){let r=await EK.findPs("hdb_express");yI.isEmptyOrZeroLength(r)||(e=!0)}if(!e){let r=await bI.list();yI.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(hK.red(r)),Lo.error(r),process.exit(1)}}a(ipe,"checkIfRunning");async function ope(e){try{await Zhe.processDirectives(e)}catch(t){throw yE("There was an error during the data upgrade. Please check the logs.",Po.LOG_LEVELS.ERROR),t}try{await pK.insertHdbUpgradeInfo(e[zS])}catch(t){Lo.error("Error updating the 'hdb_info' system table."),Lo.error(t)}}a(ope,"runUpgrade");function yE(e,t=void 0){t||(t=Lo.info),Lo[t](e),console.log(hK.magenta(e))}a(yE,"printToLogAndConsole")});var yK=N((RLe,RK)=>{"use strict";var{promises:NI,createReadStream:ape,createWriteStream:cpe}=require("fs"),{createGzip:lpe}=require("zlib"),{promisify:upe}=require("util"),{pipeline:dpe}=require("stream"),_pe=upe(dpe),fpe=require("path"),hl=se();hl.initSync();var El=W(),{CONFIG_PARAMS:bE,ITC_EVENT_TYPES:Epe}=M(),{onMessageFromWorkers:hpe}=dt(),ppe=6e4,mpe="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",Spe="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",OI,gK;RK.exports=AK;hpe(e=>{e.type===Epe.RESTART&&(hl.initSync(!0),clearInterval(gK),hl.get(bE.LOGGING_ROTATION_ENABLED)&&AK())});async function AK(){try{let e=El.getLogFilePath(),t=hl.get(bE.LOGGING_ROTATION_MAXSIZE),r=hl.get(bE.LOGGING_ROTATION_INTERVAL);if(!t&&!r){El.error(mpe);return}let n=hl.get(bE.LOGGING_ROTATION_PATH);if(!n){El.error(Spe);return}let s;if(t){let o=t.slice(-1),c=t.slice(0,-1);o==="G"?s=c*1e9:o==="M"?s=c*1e6:s=c*1e3}let i;if(r){let o=r.slice(-1),c=r.slice(0,-1);o==="D"?i=c*1440:o==="H"?i=c*60:i=c}OI=Date.now()/6e4,El.trace("Log rotate enabled, maxSize:",t,"interval:",r),gK=setInterval(async()=>{if(s){let o;o=await NI.stat(e),o.size>=s&&await TK(e,n)}i&&Date.now()/6e4-OI>=i&&(await TK(e,n),OI=Date.now()/6e4)},ppe).unref()}catch(e){El.error(e)}}a(AK,"logRotator");async function TK(e,t){let r=hl.get(bE.LOGGING_ROTATION_COMPRESS),n=fpe.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.${r?"log.gz":"log"}`);r?(await _pe(ape(e),lpe(),cpe(n)),await NI.unlink(e)):await NI.rename(e,n),El.closeLogFile(),El.notify(`hdb.log rotated, old log moved to ${n}`)}a(TK,"moveLogFile")});var PK=N(DK=>{"use strict";var pe=se();pe.initSync();var bLe=Gu(),Xt=M(),Xn=W(),Mo=require("fs-extra"),Uo=require("path"),Tpe=require("systeminformation"),gpe=eI(),{install:Ape}=cK(),II=require("chalk"),Rpe=Jl(),vo=te(),wI=wt(),OK=Wa(),bK=Om(),ype=SK(),bpe=yK(),{compactOnStart:Ope}=(oO(),oe(iO)),Npe=require("minimist"),Ipe=Xs(),{PACKAGE_ROOT:wpe,CONFIG_PARAMS:Ce}=M(),{startHTTPThreads:Cpe,startSocketServer:OLe,mostIdleRouting:NLe,remoteAffinityRouting:ILe}=(CI(),oe(LK)),Dpe=VS(),{isMainThread:Ppe}=require("worker_threads"),wLe=Zi(),CLe=ro(),DLe=mR(),PLe=w_(),QS=M(),qi,ud,NK=!1,Lpe="Upgrade complete. Starting HarperDB.",Mpe="Got an error while trying to upgrade your HarperDB instance. Exiting HarperDB.",Upe="HarperDB not found, starting install process.",vpe="There was an error during install, check install_log.log for more details. Exiting.",Bpe="HarperDB successfully started.";function Hpe(){if(!NK){let e=a(()=>{Mo.removeSync(Uo.join(pe.get(Xt.CONFIG_PARAMS.ROOTPATH),Xt.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(Hpe,"addExitListeners");async function IK(e=!1,t=!1){if(console.log(II.magenta("Starting HarperDB...")),Xn.suppressLogging?.(()=>{console.log(II.magenta(""+Mo.readFileSync(Uo.join(wpe,"utility/install/ascii_logo.txt"))))}),await CK()===!1){console.log(Upe);try{await Ape()}catch(o){console.error(vpe,o),Xn.error(o),process.exit(1)}}if(!e){let o=OK(Object.keys(Xt.CONFIG_PARAM_MAP),!0);!vo.isEmpty(o)&&!vo.isEmptyOrZeroLength(Object.keys(o))&&wI.updateConfigValue(void 0,void 0,o,!0,!0)}let r,n=ud?.service==="clustering";ud?.service&&!n&&(console.error("Unrecognized service argument"),process.exit(1));try{let o=Number.parseInt(await Mo.readFile(Uo.join(pe.get(Xt.CONFIG_PARAMS.ROOTPATH),Xt.HDB_PID_FILE),"utf8")),c=await Tpe.processes();for(let l of c.list)if(l.pid===o){n?r=!0:console.log("HarperDB appears to be already running.");break}}catch{}qi===void 0&&(qi=Hu()),n&&(r||(console.error("HarperDB must be running to start clustering."),process.exit()),pe.get(Xt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY)||(console.error("Clustering must be setup and enabled in harperdb-config."),process.exit()),console.log("Starting clustering."),await bK.generateNatsConfig(),await qi.startClusteringProcesses(!0),process.exit()),Hpe(),await Mo.writeFile(Uo.join(pe.get(QS.CONFIG_PARAMS.ROOTPATH),QS.HDB_PID_FILE),`${process.pid}`),Xn.info("HarperDB PID",process.pid);let s;try{let o=await Dpe.getVersionUpdateInfo();o!==void 0&&(s=o[Xt.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION],await ype.upgrade(o),console.log(Lpe))}catch(o){s?(console.error(`Got an error while trying to upgrade your HarperDB instance to version ${s}. Exiting HarperDB.`,o),Xn.error(o)):(console.error(Mpe,o),Xn.error(o)),process.exit(1)}gpe(),Fpe(),await Ipe.reviewSelfSignedCert(),vo.autoCastBoolean(pe.get(Xt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&Ppe&&await bK.generateNatsConfig(t)}a(IK,"initialize");async function xpe(e=!1){try{ud=Npe(process.argv),ud.ROOTPATH&&wI.updateConfigObject("settings_path",Uo.join(ud.ROOTPATH,Xt.HDB_CONFIG_FILE)),await IK(e,!0),pe.get(Xt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await Ope();let t=process.env.IS_SCRIPTED_SERVICE&&!ud.service;vo.autoCastBoolean(pe.get(Xt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&(t||await qi.startClusteringProcesses(),await qi.startClusteringThreads()),await Cpe(process.env.DEV_MODE?1:pe.get(QS.CONFIG_PARAMS.THREADS_COUNT)??pe.get(QS.CONFIG_PARAMS.THREADS)),pe.get(Xt.CONFIG_PARAMS.LOGGING_ROTATION_ENABLED)&&await bpe(),t||wK()}catch(t){console.error(t),Xn.error(t),process.exit(1)}}a(xpe,"main");function wK(){Xn.suppressLogging(()=>{console.log(II.magenta(`HarperDB ${Rpe.version} successfully started`))}),Xn.notify(Bpe)}a(wK,"started");async function kpe(e=!0){NK=!e;try{qi===void 0&&(qi=Hu()),qi.enterPM2Mode(),await IK(),vo.autoCastBoolean(pe.get(Xt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&await qi.startClusteringProcesses(),await qi.startService(Xt.PROCESS_DESCRIPTORS.HDB),wK(),e&&process.exit(0)}catch(t){console.error(t),Xn.error(t),process.exit(1)}}a(kpe,"launch");function Fpe(){let e=Uo.join(pe.get(Xt.CONFIG_PARAMS.ROOTPATH),Xt.LICENSE_KEY_DIR_NAME,Xt.LICENSE_FILE_NAME),t=Uo.join(e,Xt.LICENSE_FILE_NAME),r=Uo.join(e,Xt.REG_KEY_FILE_NAME);try{let{HARPERDB_FINGERPRINT:n,HARPERDB_LICENSE:s}=OK(["HARPERDB_FINGERPRINT","HARPERDB_LICENSE"]);if(vo.isEmpty(n)||vo.isEmpty(s))return;Mo.mkdirpSync(e),Mo.writeFileSync(r,n),Mo.writeFileSync(t,s)}catch(n){let s=`Failed to write license & fingerprint due to: ${n.message}`;console.error(s),Xn.error(s)}}a(Fpe,"writeLicenseFromVars");Object.assign(DK,{launch:kpe,main:xpe,isHdbInstalled:CK,startupLog:Gpe});async function CK(){try{await Mo.stat(vo.getPropsFilePath()),await Mo.stat(pe.get(Xt.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}catch(e){if(vo.noBootFile())return!0;if(e.code==="ENOENT")return!1;throw Xn.error(`Error checking for HDB install - ${e}`),e}return!0}a(CK,"isHdbInstalled");function Gpe(e){let r=a(f=>f.padEnd(20),"pad"),n=`
114
+ `;pe.get(Ce.REPLICATION_HOSTNAME)&&(n+=`${r("Hostname:")}${pe.get(Ce.REPLICATION_HOSTNAME)}
115
+ `),pe.get(Ce.REPLICATION_URL)&&(n+=`${r("Replication Url:")}${pe.get(Ce.REPLICATION_URL)}
116
+ `),n+=`${r("Worker Threads:")}${pe.get(Ce.THREADS_COUNT)}
117
+ `,n+=`${r("Root Path:")}${pe.get(Ce.ROOTPATH)}
118
+ `,pe.get(Ce.THREADS_DEBUG)!==!1&&(n+=`${r("Debugging:")}enabled: true`,n+=pe.get(Ce.THREADS_DEBUG_PORT)?`, TCP: ${pe.get(Ce.THREADS_DEBUG_PORT)}
119
119
  `:`
120
- `);let s=vo.join(pe.get(we.LOGGING_ROOT),"hdb.log");n+=`${r("Logging:")}level: ${pe.get(we.LOGGING_LEVEL)}, location: ${s+(pe.get(we.LOGGING_STDSTREAMS)?", stdout/err":"")}
121
- `,n+=r("Default:"),n+=pe.get(we.HTTP_PORT)?`HTTP (and WS): ${pe.get(we.HTTP_PORT)}, `:"",n+=pe.get(we.HTTP_SECUREPORT)?`HTTPS (and WS): ${pe.get(we.HTTP_SECUREPORT)}, `:"",n+=`CORS: ${pe.get(we.HTTP_CORS)?`enabled for ${pe.get(we.HTTP_CORSACCESSLIST)}`:"disabled"}
122
- `,n+=r("Operations API:"),n+=pe.get(we.OPERATIONSAPI_NETWORK_PORT)?`HTTP: ${pe.get(we.OPERATIONSAPI_NETWORK_PORT)}, `:"",n+=pe.get(we.OPERATIONSAPI_NETWORK_SECUREPORT)?`HTTPS: ${pe.get(we.OPERATIONSAPI_NETWORK_SECUREPORT)}, `:"",n+=`CORS: ${pe.get(we.OPERATIONSAPI_NETWORK_CORS)?`enabled for ${pe.get(we.OPERATIONSAPI_NETWORK_CORSACCESSLIST)}`:"disabled"}`,n+=`, unix socket: ${pe.get(we.OPERATIONSAPI_NETWORK_DOMAINSOCKET)}
123
- `,n+=r("MQTT:"),n+=pe.get(we.MQTT_NETWORK_PORT)?`TCP: ${pe.get(we.MQTT_NETWORK_PORT)}, `:"",n+=pe.get(we.MQTT_NETWORK_SECUREPORT)?`TLS: ${pe.get(we.MQTT_NETWORK_SECUREPORT)}`:"",n+=pe.get(we.MQTT_WEBSOCKET)&&pe.get(we.HTTP_PORT)?`, WS: ${pe.get(we.HTTP_PORT)}`:"",n+=pe.get(we.MQTT_WEBSOCKET)&&pe.get(we.HTTP_SECUREPORT)?`, WSS: ${pe.get(we.HTTP_SECUREPORT)}
120
+ `);let s=Uo.join(pe.get(Ce.LOGGING_ROOT),"hdb.log");n+=`${r("Logging:")}level: ${pe.get(Ce.LOGGING_LEVEL)}, location: ${s+(pe.get(Ce.LOGGING_STDSTREAMS)?", stdout/err":"")}
121
+ `,n+=r("Default:"),n+=pe.get(Ce.HTTP_PORT)?`HTTP (and WS): ${pe.get(Ce.HTTP_PORT)}, `:"",n+=pe.get(Ce.HTTP_SECUREPORT)?`HTTPS (and WS): ${pe.get(Ce.HTTP_SECUREPORT)}, `:"",n+=`CORS: ${pe.get(Ce.HTTP_CORS)?`enabled for ${pe.get(Ce.HTTP_CORSACCESSLIST)}`:"disabled"}
122
+ `,n+=r("Operations API:"),n+=pe.get(Ce.OPERATIONSAPI_NETWORK_PORT)?`HTTP: ${pe.get(Ce.OPERATIONSAPI_NETWORK_PORT)}, `:"",n+=pe.get(Ce.OPERATIONSAPI_NETWORK_SECUREPORT)?`HTTPS: ${pe.get(Ce.OPERATIONSAPI_NETWORK_SECUREPORT)}, `:"",n+=`CORS: ${pe.get(Ce.OPERATIONSAPI_NETWORK_CORS)?`enabled for ${pe.get(Ce.OPERATIONSAPI_NETWORK_CORSACCESSLIST)}`:"disabled"}`,n+=`, unix socket: ${pe.get(Ce.OPERATIONSAPI_NETWORK_DOMAINSOCKET)}
123
+ `,n+=r("MQTT:"),n+=pe.get(Ce.MQTT_NETWORK_PORT)?`TCP: ${pe.get(Ce.MQTT_NETWORK_PORT)}, `:"",n+=pe.get(Ce.MQTT_NETWORK_SECUREPORT)?`TLS: ${pe.get(Ce.MQTT_NETWORK_SECUREPORT)}`:"",n+=pe.get(Ce.MQTT_WEBSOCKET)&&pe.get(Ce.HTTP_PORT)?`, WS: ${pe.get(Ce.HTTP_PORT)}`:"",n+=pe.get(Ce.MQTT_WEBSOCKET)&&pe.get(Ce.HTTP_SECUREPORT)?`, WSS: ${pe.get(Ce.HTTP_SECUREPORT)}
124
124
  `:`
125
- `;let i=pe.get(we.REPLICATION_PORT)??pe.get(we.OPERATIONSAPI_NETWORK_PORT),o=pe.get(we.REPLICATION_SECUREPORT)??pe.get(we.OPERATIONSAPI_NETWORK_SECUREPORT),c=r("Replication:");c+=i?`WS: ${i}, `:"",c+=o?`WSS: ${o} `:"",n+=`${c.slice(0,-2)}
126
- `;let l=[],u=II.getConfigObj();for(let f in u)u[f].package&&l.push(f);let d={},_=`${r("REST:")}`;for(let[f,h]of e)for(let T of h){let m=T.name;m==="rest"&&(_+=`${T.protocol_name}: ${f}, `),l.includes(m)&&(d[m]?d[m]+=`${T.protocol_name}: ${f}, `:d[m]=`${T.protocol_name}: ${f}, `)}_.length>21&&(_=_.slice(0,-2),n+=`${_}
127
- `);let E=pe.get(we.HTTP_PORT)?`HTTP: ${pe.get(we.HTTP_PORT)}, `:"";E+=pe.get(we.HTTP_SECUREPORT)?`HTTPS: ${pe.get(we.HTTP_SECUREPORT)}, `:"",E.length>21&&(E=E.slice(0,-2));for(let f of l)d[f]?n+=`${r(f+": ")}${d[f].slice(0,-2)}
125
+ `;let i=pe.get(Ce.REPLICATION_PORT)??pe.get(Ce.OPERATIONSAPI_NETWORK_PORT),o=pe.get(Ce.REPLICATION_SECUREPORT)??pe.get(Ce.OPERATIONSAPI_NETWORK_SECUREPORT),c=r("Replication:");c+=i?`WS: ${i}, `:"",c+=o?`WSS: ${o} `:"",n+=`${c.slice(0,-2)}
126
+ `;let l=[],u=wI.getConfigObj();for(let f in u)u[f].package&&l.push(f);let d={},_=`${r("REST:")}`;for(let[f,h]of e)for(let T of h){let m=T.name;m==="rest"&&(_+=`${T.protocol_name}: ${f}, `),l.includes(m)&&(d[m]?d[m]+=`${T.protocol_name}: ${f}, `:d[m]=`${T.protocol_name}: ${f}, `)}_.length>21&&(_=_.slice(0,-2),n+=`${_}
127
+ `);let E=pe.get(Ce.HTTP_PORT)?`HTTP: ${pe.get(Ce.HTTP_PORT)}, `:"";E+=pe.get(Ce.HTTP_SECUREPORT)?`HTTPS: ${pe.get(Ce.HTTP_SECUREPORT)}, `:"",E.length>21&&(E=E.slice(0,-2));for(let f of l)d[f]?n+=`${r(f+": ")}${d[f].slice(0,-2)}
128
128
  `:n+=`${r(f+": ")}${E}
129
- `;console.log(n),pe.get(we.LOGGING_STDSTREAMS)&&Xn.logsAtLevel("info")&&Xn.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(Hpe,"startupLog")});var xI=N(Ho=>{"use strict";var{isMainThread:CI,parentPort:wE,threadId:XS,workerData:xpe}=require("worker_threads"),{Socket:kpe,createServer:Fpe}=require("net"),{createServer:Gpe,IncomingMessage:qpe}=require("http"),{createServer:$pe}=require("https"),{unlinkSync:HK,existsSync:Vpe}=require("fs"),Nn=W(),Rt=se(),Zt=M(),{server:CE}=(qr(),oe(Qa)),{WebSocketServer:Kpe}=require("ws"),{createServer:Ype}=require("node:tls"),{getTicketKeys:Wpe,restartNumber:jpe,getWorkerIndex:ud}=dt(),{Headers:DI,appendHeader:zpe}=(Bf(),oe(WF)),{recordAction:OE,recordActionBinary:DK}=(Ni(),oe(k_)),{Request:xK,createReuseportFd:IE}=(vS(),oe(JN)),{checkMemoryLimit:Qpe}=dc(),{createTLSSelector:kK}=Xs(),{resolvePath:FK}=wt(),{startupLog:Jpe}=wK(),{Readable:PK}=require("node:stream"),Xpe=fi(),GK=Rt.get(Zt.CONFIG_PARAMS.THREADS_DEBUG);if(GK){let e;if(CI)e=Rt.get(Zt.CONFIG_PARAMS.THREADS_DEBUG_PORT)??9229,process.on(["SIGINT","SIGTERM","SIGQUIT","exit"],()=>{try{require("inspector").close()}catch(t){Nn.info("Could not close debugger",t)}});else{let t=Rt.get(Zt.CONFIG_PARAMS.THREADS_DEBUG_STARTINGPORT);t&&ud()>=0&&(e=t+ud())}if(e){let t=Rt.get(Zt.CONFIG_PARAMS.THREADS_DEBUG_HOST),r=Rt.get(Zt.CONFIG_PARAMS.THREADS_DEBUG_WAITFORDEBUGGER);try{require("inspector").open(e,t,r)}catch(n){Nn.trace(`Could not start debugging on port ${e}, you may already be debugging:`,n.message)}}}else if(process.env.DEV_MODE&&CI)try{require("inspector").open(9229)}catch(e){jpe<=1&&Nn.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:DLe,CONFIG_PARAMS:Zpe}=Zt;Rt.initSync();var eme=Rt.get(Zpe.HTTP_SESSIONAFFINITY),$i={},PI=new Map;Ho.registerServer=vI;Ho.httpServer=HI;Ho.deliverSocket=UI;Ho.startServers=qK;Ho.listenOnPorts=$K;Ho.globals=Xpe;Ho.when_components_loaded=null;CE.http=HI;CE.request=rme;CE.socket=nme;CE.ws=sme;CE.upgrade=YK;var NE={},JS={},ZS={},LI=[];function qK(){return Ho.when_components_loaded=nT().loadRootComponents(!0).then(()=>{wE?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)UI(n,r,s);else if(t.requestId)tme(t);else if(t.type===Zt.ITC_EVENT_TYPES.SHUTDOWN){Nn.trace("received shutdown request",XS);for(let i in $i){let o=$i[i],c;if(o.closeIdleConnections){let u=Object.getOwnPropertySymbols(o).find(E=>E.description.includes("connections")),d=0,_=setInterval(()=>{d++;let E=d>=100,f=o[u][E?"all":"idle"]();if(f.length===0){E&&clearInterval(_);return}d===1?Nn.info(`Closing ${f.length} idle connections`):E&&Nn.warn(`Forcefully closing ${f.length} active connections`);for(let h=0,T=f.length;h<T;h++){let m=f[h].socket;m._httpMessage&&!m._httpMessage.finished&&!E||(E?m.destroySoon():m.end(`HTTP/1.1 408 Request Timeout\r
129
+ `;console.log(n),pe.get(Ce.LOGGING_STDSTREAMS)&&Xn.logsAtLevel("info")&&Xn.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(Gpe,"startupLog")});var kI=N(Bo=>{"use strict";var{isMainThread:DI,parentPort:wE,threadId:XS,workerData:qpe}=require("worker_threads"),{Socket:$pe,createServer:Vpe}=require("net"),{createServer:Kpe,IncomingMessage:Ype}=require("http"),{createServer:Wpe}=require("https"),{unlinkSync:FK,existsSync:jpe}=require("fs"),Nn=W(),At=se(),Zt=M(),{server:CE}=(qr(),oe(Qa)),{WebSocketServer:zpe}=require("ws"),{createServer:Qpe}=require("node:tls"),{getTicketKeys:Jpe,restartNumber:Xpe,getWorkerIndex:dd}=dt(),{Headers:PI,appendHeader:Zpe}=(Bf(),oe(QF)),{recordAction:OE,recordActionBinary:MK}=(Ni(),oe(F_)),{Request:GK,createReuseportFd:IE}=(vS(),oe(XN)),{checkMemoryLimit:eme}=dc(),{createTLSSelector:qK}=Xs(),{resolvePath:$K}=wt(),{startupLog:tme}=PK(),{Readable:UK}=require("node:stream"),rme=fi(),VK=At.get(Zt.CONFIG_PARAMS.THREADS_DEBUG);if(VK){let e;if(DI)e=At.get(Zt.CONFIG_PARAMS.THREADS_DEBUG_PORT)??9229,process.on(["SIGINT","SIGTERM","SIGQUIT","exit"],()=>{try{require("inspector").close()}catch(t){Nn.info("Could not close debugger",t)}});else{let t=At.get(Zt.CONFIG_PARAMS.THREADS_DEBUG_STARTINGPORT);t&&dd()>=0&&(e=t+dd())}if(e){let t=At.get(Zt.CONFIG_PARAMS.THREADS_DEBUG_HOST),r=At.get(Zt.CONFIG_PARAMS.THREADS_DEBUG_WAITFORDEBUGGER);try{require("inspector").open(e,t,r)}catch(n){Nn.trace(`Could not start debugging on port ${e}, you may already be debugging:`,n.message)}}}else if(process.env.DEV_MODE&&DI)try{require("inspector").open(9229)}catch(e){Xpe<=1&&Nn.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:ULe,CONFIG_PARAMS:nme}=Zt;At.initSync();var sme=At.get(nme.HTTP_SESSIONAFFINITY),$i={},LI=new Map;Bo.registerServer=BI;Bo.httpServer=xI;Bo.deliverSocket=vI;Bo.startServers=KK;Bo.listenOnPorts=YK;Bo.globals=rme;Bo.when_components_loaded=null;CE.http=xI;CE.request=ome;CE.socket=ame;CE.ws=cme;CE.upgrade=zK;var NE={},JS={},ZS={},MI=[];function KK(){return Bo.when_components_loaded=nT().loadRootComponents(!0).then(()=>{wE?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)vI(n,r,s);else if(t.requestId)ime(t);else if(t.type===Zt.ITC_EVENT_TYPES.SHUTDOWN){Nn.trace("received shutdown request",XS);for(let i in $i){let o=$i[i],c;if(o.closeIdleConnections){let u=Object.getOwnPropertySymbols(o).find(E=>E.description.includes("connections")),d=0,_=setInterval(()=>{d++;let E=d>=100,f=o[u][E?"all":"idle"]();if(f.length===0){E&&clearInterval(_);return}d===1?Nn.info(`Closing ${f.length} idle connections`):E&&Nn.warn(`Forcefully closing ${f.length} active connections`);for(let h=0,T=f.length;h<T;h++){let m=f[h].socket;m._httpMessage&&!m._httpMessage.finished&&!E||(E?m.destroySoon():m.end(`HTTP/1.1 408 Request Timeout\r
130
130
  Connection: close\r
131
131
  \r
132
- `))}},25).unref()}o.close?.(()=>{if(Rt.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&ud()==0)try{HK(FK(Rt.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,XS),o.cantCleanupProperly||Nn.warn("Had to forcefully exit the thread",XS),process.exit(0)},5e3).unref()})}if(GK||process.env.DEV_MODE)try{require("inspector").close()}catch(i){Nn.info("Could not close debugger",i)}}}).ref();let e;IE&&!eme&&(e=$K()),Promise.resolve(e).then(()=>{if(ud()===0)try{Jpe(PI)}catch(t){console.error("Error displaying start-up log",t)}wE?.postMessage({type:Zt.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(qK,"startServers");function $K(){let e=[];for(let t in $i){let r=$i[t];if(t.includes?.("/")&&ud()==0){Vpe(t)&&HK(t),e.push(new Promise((o,c)=>{r.listen({path:t},()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),Nn.info("Domain socket listening on "+t)}).on("error",c)}));continue}let n,s=Rt.get(Zt.CONFIG_PARAMS.HTTP_THREADRANGE);if(s){let o=typeof s=="string"?s.split("-"):s,c=ud();if(c<o[0]||c>o[1])continue}let i;try{let o=t.lastIndexOf(":");o>0?IE?n={fd:IE(+t.slice(o+1).replace(/[\[\]]/g,""),t.slice(0,o))}:n={host:+t.slice(o+1).replace(/[\[\]]/g,""),port:t.slice(0,o)}:IE?n={fd:IE(+t,"::")}:n={port:t}}catch(o){console.error(`Unable to bind to port ${t}`,o);continue}e.push(new Promise((o,c)=>{r.listen(n,()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),Nn.trace("Listening on port "+t,XS)}).on("error",c)}))}return Promise.all(e)}a($K,"listenOnPorts");!CI&&!xpe?.noServerStart&&qK();function UI(e,t,r){let n=e?.read?e:new kpe({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=$i[t];if(s.isSecure&&(n.startTime=performance.now()),s)typeof s=="function"?s(n):s.emit("connection",n),r&&n.emit("data",r);else{let i=a(o=>{setTimeout(()=>{let c=$i[t];c?(typeof c=="function"?c(n):c.emit("connection",n),r&&n.emit("data",r)):o<5?i(o+1):(Nn.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a(UI,"deliverSocket");var LK=new Map;function tme(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=LK.get(s),r){case"connection":i=UI(void 0,t),LK.set(s,i),i.write=(c,l,u)=>(wE.postMessage({requestId:s,event:"data",data:c.toString("latin1")}),u&&u(),!0),i.end=(c,l,u)=>(wE.postMessage({requestId:s,event:"end",data:c?.toString("latin1")}),u&&u(),!0);let o=i.destroy;i.destroy=()=>{o.call(i),wE.postMessage({requestId:s,event:"destroy"})};break;case"data":i._readableState.destroyed||i.emit("data",Buffer.from(n,"latin1"));break;case"drain":i._readableState.destroyed||i.emit("drain",{});break;case"end":i._readableState.destroyed||i.emit("end",{});break;case"error":i._readableState.destroyed||i.emit("error",{});break}}a(tme,"proxyRequest");var{getComponentName:eT}=($f(),oe(qf));function vI(e,t,r=!0){t||(t=Rt.get(Zt.CONFIG_PARAMS.HTTP_PORT));let n=$i[t];if(n){let s=n.lastServer||n;if(s===e)throw new Error(`Can not register the same server twice for the same port ${t}`);if(r&&!!s.sessionIdContext!=!!e.sessionIdContext&&+t)throw new Error(`Can not mix secure HTTPS and insecure HTTP on the same port ${t}`);s.off("unhandled",BK),s.on("unhandled",(i,o)=>{e.cantCleanupProperly&&(n.cantCleanupProperly=!0),e.emit("request",i,o)}),n.lastServer=e}else $i[t]=e;e.on("unhandled",BK)}a(vI,"registerServer");function BI(e){let t=[],r=e?.securePort;return r&&t.push({port:r,secure:!0}),r=e?.port,r&&t.push({port:r,secure:!1}),t.length===0&&(t=[],Rt.get(Zt.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:Rt.get(Zt.CONFIG_PARAMS.HTTP_PORT),secure:Rt.get(Zt.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),Rt.get(Zt.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:Rt.get(Zt.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&Rt.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:FK(Rt.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)),secure:!1}),t}a(BI,"getPorts");function HI(e,t){let r=[];for(let{port:n,secure:s}of BI(t))r.push(VK(n,s,t?.isOperationsServer,t?.mtls)),typeof e=="function"?LI[t?.runFirst?"unshift":"push"]({listener:e,port:t?.port||n}):(e.isSecure=s,vI(e,n,!1)),ZS[n]=rT(LI,n);return r}a(HI,"httpServer");function tT(e,t){let r=PI.get(e)??[];PI.set(e,[...r,t])}a(tT,"setPortServerMap");function VK(e,t,r,n){if(tT(e,{protocol_name:t?"HTTPS":"HTTP",name:eT()}),!JS[e]){let s=r?"operationsApi_network":"http",i=Rt.get(s+"_keepAliveTimeout"),o=Rt.get(s+"_timeout"),c=Rt.get(s+"_headersTimeout"),l={noDelay:!0,keepAliveTimeout:i,headersTimeout:c,requestTimeout:o,highWaterMark:128*1024,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,maxHeaderSize:Rt.get(Zt.CONFIG_PARAMS.HTTP_MAXHEADERSIZE)},u=Rt.get(s+"_mtls"),d=Rt.get(s+"_mtls_required");t&&Object.assign(l,{allowHTTP1:!0,rejectUnauthorized:!!d,requestCert:!!(u||n),ticketKeys:Wpe(),SNICallback:kK(r?"operations-api":"server",u),ALPNCallback:a(function(f){return f.protocols.includes("harperdb-replication")&&(this.isReplicationConnection=!0),"http/1.1"},"ALPNCallback"),ALPNProtocols:null});let _=Qpe(),E=JS[e]=(t?$pe:Gpe)(l,async(f,h)=>{try{let m=performance.now(),g=new xK(f,h);r&&(g.isOperationsServer=!0);let S=await ZS[e](g);if(!S){if(g._nodeResponse.statusCode)return;S=KK(g)}if(S.headers?.set||(S.headers=new DI(S.headers)),_?S.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):S.headers?.set?.("Server","HarperDB"),S.status===-1){for(let ne of S.headers||[])h.setHeader(ne[0],ne[1]);return f.baseRequest=g,h.baseResponse=S,JS[e].emit("unhandled",f,h)}let b=S.status||200,I=performance.now(),B=I-m,H=S.body,X;if(!S.handlesHeaders){let ne=S.headers||new DI;H?H.length>=0&&(typeof H=="string"?ne.set("Content-Length",Buffer.byteLength(H)):ne.set("Content-Length",H.length),X=!0):(ne.set("Content-Length","0"),X=!0);let Q=`hdb;dur=${B.toFixed(2)}`;S.wasCacheMiss&&(Q+=", miss"),zpe(ne,"Server-Timing",Q,!0),h.headersSent||h.writeHead(b,ne&&(ne[Symbol.iterator]?Array.from(ne):ne)),X&&h.end(H)}let Y=g.handlerPath,V=g.method;if(OE(B,"duration",Y,V,S.wasCacheMiss==null?void 0:S.wasCacheMiss?"cache-miss":"cache-hit"),DK(b<400,"success",Y,V),DK(1,"response_"+b,Y,V),!X)if(H instanceof ReadableStream&&(H=PK.fromWeb(H)),(H[Symbol.iterator]||H[Symbol.asyncIterator])&&(H=PK.from(H)),H?.pipe){H.pipe(h),H.destroy&&h.on("close",()=>{H.destroy()});let ne=0;H.on("data",Q=>{ne+=Q.length}),H.on("end",()=>{OE(performance.now()-I,"transfer",Y,V),OE(ne,"bytes-sent",Y,V)})}else H?.then?H.then(ne=>{h.end(ne)},T):h.end(H)}catch(m){T(m)}function T(m){let g=m.headers;h.writeHead(m.statusCode||500,g&&(g[Symbol.iterator]?Array.from(g):g)),h.end(m.toString()),m.statusCode?m.statusCode===500?Nn.warn(m):Nn.info(m):Nn.error(m)}a(T,"onError")});i>=0&&(E.keepAliveTimeout=i),c>=0&&(E.headersTimeout=c),t&&(E.ports||(E.ports=[]),E.ports.push(e),l.SNICallback.initialize(E),u&&(E.mtlsConfig=u),E.on("secureConnection",f=>{f._parent.startTime&&OE(performance.now()-f._parent.startTime,"tls-handshake",e),OE(f.isSessionReused(),"tls-reused",e)}),E.isSecure=!0),vI(E,e)}return JS[e]}a(VK,"getHTTPServer");function rT(e,t){let r=KK;for(let n=e.length;n>0;){let{listener:s,port:i}=e[--n];if(i===t||i==="all"){let o=r;r=a((...c)=>s(...c,o),"next_callback")}}return r}a(rT,"makeCallbackChain");function KK(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new DI}}a(KK,"unhandled");function rme(e,t){HI(e,{requestOnly:!0,...t})}a(rme,"onRequest");function nme(e,t){let r;if(t.securePort){tT(t.securePort,{protocol_name:"TLS",name:eT()});let n=kK("server",t.mtls);r=Ype({rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,SNICallback:n},e),n.initialize(r),$i[t.securePort]=r}return t.port&&(tT(t.port,{protocol_name:"TCP",name:eT()}),r=Fpe(e,{noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600}),$i[t.port]=r),r}a(nme,"onSocket");Object.defineProperty(qpe.prototype,"upgrade",{get(){return"connection"in this.headers&&"upgrade"in this.headers&&this.headers.connection.includes("Upgrade")&&this.headers.upgrade.toLowerCase()=="websocket"},set(e){}});var MK=[],MI={};function YK(e,t){for(let{port:r}of BI(t))MK[t?.runFirst?"unshift":"push"]({listener:e,port:r}),MI[r]=rT(MK,r)}a(YK,"onUpgrade");var UK=[],vK={};function sme(e,t){let r=[];for(let{port:n,secure:s}of BI(t)){tT(n,{protocol_name:s?"WSS":"WS",name:eT()});let i=VK(n,s,t?.isOperationsServer,t?.mtls);NE[n]||(NE[n]=new Kpe({noServer:!0,maxPayload:t.maxPayload??100*1024*1024}),NE[n].on("connection",(o,c)=>{let l=new xK(c);l.isWebSocket=!0;let u=ZS[n](l);vK[n](o,l,u)}),YK((o,c,l,u)=>o.__harperdb_request_upgraded?u(o,c,l):NE[n].handleUpgrade(o,c,l,d=>{o.__harperdb_request_upgraded=!0,u(o,c,l),NE[n].emit("connection",d,o)}),{port:n}),i.on("upgrade",(o,c,l)=>{MI[n]&&MI[n](o,c,l)})),r.push(i),UK[t?.runFirst?"unshift":"push"]({listener:e,port:n}),vK[n]=rT(UK,n),ZS[n]=rT(LI,n)}return r}a(sme,"onWebSocket");function BK(e,t){t.writeHead(404),t.end(`Not found
133
- `)}a(BK,"defaultNotFound")});var CK={};je(CK,{startHTTPThreads:()=>ome,startSocketServer:()=>$I,updateWorkerIdleness:()=>eY});async function ome(e=2,t){try{if(t)GI(0,1,!0);else{let{loadRootComponents:r}=nT();if(e===0)return(0,Ds.setMainIsWorker)(!0),await xI().startServers(),Promise.resolve([]);await r()}ZK();for(let r=0;r<e;r++)GI(r,e);return Promise.all(XK)}finally{(0,Ds.threadsHaveStarted)()}}function ZK(){let e=(0,QK.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),FI=setInterval(()=>{oT.notify(e)},ime).unref())}function GI(e,t=1,r){if(kI++,(0,Ds.startWorker)("server/threads/threadServer.js",{name:hd.THREAD_TYPES.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(u){u.type===hd.CLUSTER_MESSAGE_TYPE_ENUM.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});XK.push(s),await s,dd.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=iT.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=dd.indexOf(n);o>-1&&dd.splice(o,1)}if(a(i,"removeWorker"),_d){let o=_d;_d=[];for(let c of o)JK[c.localPort](null,c)}}}),r){let n=setInterval(()=>{qI?qI=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,Ds.shutdownWorkers)(),kI=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function $I(e=0,t){if(typeof e=="string")try{(0,aT.existsSync)(e)&&(0,aT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=ame:r=cme(t):r=VI;let n=(0,fd.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);if(n._handle){n._handle.onconnection=JK[e]=function(i,o){r.readsData||(o.reading=!1,o.readStop()),qI=!0,r(o,(c,l)=>{if(!c){if(WK){let d=o._socket||new fd.Socket({handle:o,writable:!0,readable:!0});WK.deliverSocket(d,e,l),d.resume()}else kI>0?(_d.length===0&&setTimeout(()=>{_d.length>0&&console.warn("Incoming sockets/requests have been queued for workers to start, and no workers have handled them. Check to make sure an error is not preventing workers from starting")},1e4).unref(),o.localPort=e,_d.push(o)):(console.log("start up a dynamic thread to handle request"),GI(0));pr(!1,"socket-routed");return}c.requests++;let u=o.fd;if(u>=0)c.postMessage({port:e,fd:u,data:l});else{let d=o._socket||new fd.Socket({handle:o,writable:!0,readable:!0});dme(d,c,e)}pr(!0,"socket-routed")})};let s=jl();oT.info(`HarperDB ${s.version} Server running on port ${e}`)}return n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function VI(e,t){let r,n=0;for(let s of dd){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=sT)return sT=i,t(r);n=i}sT=0,t(r)}function ame(e,t){let r={};e.getpeername(r);let n=r.address,s=Ed.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);VI(e,o=>{Ed.set(n,{worker:o,lastUsed:i}),t(o)})}function cme(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new fd.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=Ed.get(l),d=Date.now();if(u&&u.worker.threadId!==-1)return u.lastUsed=d,s(u.worker);VI(n,_=>{Ed.set(l,{worker:_,lastUsed:d}),s(_,o)})})}a(r,"findByHeaderAffinity")}function eY(){sT=0;for(let e of dd)e.expectedIdle=e.recentELU.idle+lme,e.requests=1;dd.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function dme(e,t,r){let n=ume++;t.postMessage({port:r,requestId:n,event:"connection"}),e.on("data",s=>{let i=s.toString("latin1");t.postMessage({port:r,requestId:n,data:i,event:"data"})}).on("close",s=>{t.postMessage({port:r,requestId:n,event:"close",hadError:s})}).on("error",s=>{t.postMessage({port:r,requestId:n,event:"error",error:s})}).on("drain",s=>{t.postMessage({port:r,requestId:n,event:"drain",error:s})}).on("end",()=>{t.postMessage({port:r,requestId:n,event:"end"})}).resume(),iT.set(n,s=>{s.event=="data"&&e.write(Buffer.from(s.data,"latin1")),s.event=="end"&&(e.end(s.data&&Buffer.from(s.data,"latin1")),iT.delete(n)),s.event=="destroy"&&(e.destroy(),iT.delete(n))})}var Ds,fd,hd,oT,aT,zK,QK,dd,_d,JK,WK,kI,XK,FI,ime,qI,sT,jK,Ed,lme,iT,ume,wI=Oe(()=>{Ds=L(dt()),fd=require("net"),hd=L(M()),oT=L(W()),aT=require("fs");Ni();zK=require("worker_threads"),QK=L(dc()),dd=[],_d=[],JK=[],kI=0,XK=[];zK.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,Ds.onMessageFromWorkers)(e=>{e.type===hd.ITC_EVENT_TYPES.RESTART&&FI&&(clearInterval(FI),ZK())}));ime=6e5;a(ome,"startHTTPThreads");a(ZK,"licenseWarning");a(GI,"startHTTPWorker");a($I,"startSocketServer");sT=0;a(VI,"findMostIdleWorker");jK=36e5,Ed=new Map;a(ame,"findByRemoteAddressAffinity");a(cme,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of Ed)r.lastUsed+jK<e&&Ed.delete(t)},jK).unref();lme=1e3;a(eY,"updateWorkerIdleness");(0,Ds.setMonitorListener)(eY);iT=new Map,ume=1;a(dme,"proxySocket")});var sY=N((FLe,nY)=>{"use strict";var _me=require("cluster"),fl=se();fl.initSync();var rY=M(),vLe=require("util"),xo=W(),BLe=require("fs"),fme=require("fastify"),HLe=jl(),Eme=require("@fastify/cors"),hme=require("@fastify/compress"),pme=require("@fastify/static"),mme=_N(),Sme=require("path"),{PACKAGE_ROOT:Tme}=M(),gme=ls(),Rme=te(),Ame=xn(),yme=dc(),{server:bme}=(qr(),oe(Qa)),{node_request_key:xLe}=(vS(),oe(JN)),{authHandler:Ome,handlePostRequest:Nme,serverErrorHandler:Ime,reqBodyValidationHandler:wme}=LS(),kLe=require("net"),{registerContentHandlers:Cme}=(Wc(),oe(Iq)),Dme=6e4,Pme=1024*1024*1024,Lme="TRUE",{CONFIG_PARAMS:DE}=rY,pd;nY.exports={hdbServer:tY,start:tY};async function tY(e){try{xo.debug("In Fastify server"+process.cwd()),xo.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),xo.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=_me.isMaster,await Mme();let t=e.securePort>0;pd=Ume(t),await pd.ready(),e||(e={}),e.isOperationsServer=!0;try{bme.http(pd.server,e),pd.server.closeIdleConnections||await pd.listen({port:0,host:"::"})}catch(r){throw pd.close(),xo.error(r),xo.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),xo.fatal(t),process.exit(1)}}a(tY,"operationsServer");async function Mme(){xo.trace("Configuring HarperDB process."),gme.setSchemaDataToGlobal(),await Ame.setUsersToGlobal(),await yme.getLicense()}a(Mme,"setUp");function Ume(e){xo.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=vme(e),r=fme(t);r.server.headersTimeout=Hme(),r.setErrorHandler(Ime);let n=Bme();n&&r.register(Eme,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,u){r.server.emit("unhandled",l.raw,u.raw)}),c()}),r.register(mme),r.register(hme),r.register(pme,{root:Sme.join(Tme,"studio/build-local")}),Cme(r);let s=fl.get(rY.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!Rme.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[wme,Ome],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),Nme(i,o)}),r.get("/health",()=>"HarperDB is running."),xo.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(Ume,"buildServer");function vme(e){let t=fl.get(DE.OPERATIONSAPI_NETWORK_TIMEOUT),r=fl.get(DE.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:Pme,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(vme,"getServerOptions");function Bme(){let e=fl.get(DE.OPERATIONSAPI_NETWORK_CORS),t=fl.get(DE.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===Lme)&&(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(Bme,"getCORSOpts");function Hme(){return fl.get(DE.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??Dme}a(Hme,"getHeaderTimeoutConfig")});var QI={};je(QI,{disableNATS:()=>kme,publishToStream:()=>uT,setNATSReplicator:()=>KI,setPublishToStream:()=>Fme,setSubscription:()=>zI,start:()=>xme});function xme(){PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_ENABLED)&&qme()}function kme(e=!0){lY=e}function Fme(e,t){uT=e,zI=t}function qme(){if(lY||process.env._DISABLE_NATS)return;let e=ut(),t=Object.keys(e);t.push("system");for(let r of t){let n=e[r];for(let s in n){let i=n[s];KI(s,r,i)}}Dc((r,n)=>{KI(r.tableName,r.databaseName,r),n&&dY(r)}),!iY&&(iY=!0)}function KI(e,t,r){if(t==="system"&&$me.includes(e))return;if(!r)return console.error(`Attempt to replicate non-existent table ${e} from database ${t}`);if(r.sources.some(s=>s?.isNATSReplicator))return;r.sourcedFrom(class extends Lr{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this[ze],record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this[ze]})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this[ze],record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this[ze],record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this[ze]})}static defineSchema(i){dY(i)}static subscribe(){let i=new Mn;return zI(t,e,i),i}static subscribeOnThisThread(i){return i<(PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??Gme)}static isEqual(i){return i.isNATSReplicator}static isNATSReplicator=!0;static shouldReceiveInvalidations=!0},{intermediateSource:!0});function n(s){let i=s?.transaction?.nats;if(!i)if(s?.transaction){s.transaction.nats=i=new cT(s.transaction,s);let o=s.transaction;for(;o.next;)o=o.next;o.next=s.transaction.nats,i.user=s.user,i.context=s}else i=uY;return i}a(n,"getNATSTransaction")}function dY(e){let t=PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_NODENAME);uT(`${WI.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,jI.createNatsTableStreamName)(e.databaseName,e.tableName),void 0,{operation:"define_schema",schema:e.databaseName,table:e.tableName,attributes:e.attributes,__origin:{timestamp:Date.now(),node_name:t}})}var oY,WI,jI,aY,cY,PE,LE,lT,lY,uT,zI,Gme,uY,iY,$me,cT,YI,_Y=Oe(()=>{Pe();Vs();oY=L(mr()),WI=L(Ct()),jI=L(to());wl();aY=L(ey()),cY=L(cn()),PE=L(se()),LE=L(M()),lT=L(W());a(xme,"start");a(kme,"disableNATS");uT=oY.publishToStream,zI=aY.setSubscription;a(Fme,"setPublishToStream");Gme=2;a(qme,"assignReplicationSource");$me=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(KI,"setNATSReplicator");a(dY,"publishSchema");cT=class{constructor(t,r){this.transaction=t;this.options=r}static{a(this,"NATSTransaction")}user;writes_by_db=new Map;addWrite(t,r){r.expiresAt=this.context?.expiresAt;let n=this.writes_by_db.get(t);n||this.writes_by_db.set(t,n=[]),n.push(r)}commit({timestamp:t}){let r=PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],l,u;for(let d of i){let _=d.table,E=d.operation=="put"?"upsert":d.operation;l||(lT.trace(`Sending transaction event ${E}`),u=l={operation:E,schema:s,table:_,__origin:{user:this.user?.username,timestamp:t,node_name:r}},l.hash_values=c,E!=="delete"&&E!=="invalidate"&&(l.records=o)),l.table===_&&l.operation===E?(o.push(d.record),c.push(d.id)):u=u.next={operation:E,table:_,id:d.id,record:d.record},d.expiresAt&&(u.expiresAt=d.expiresAt)}l&&n.push(uT(`${WI.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,jI.createNatsTableStreamName)(s,l.table),void 0,l)?.catch(d=>{throw lT.error("An error has occurred trying to replicate transaction",l,d),d.statusCode=504,d}))}return Promise.all(n)}},YI=class extends cT{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,cY.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};uY=new YI});async function mY({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await JI.get(e,{returnNonexistent:!0});i=new ew(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await JI.get(e);o&&o.delete()}i=new _T(e,t)}return n&&(n.id=e,n.user={username:t?.username},ME.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function XI(){return dT++,dT>65500&&(dT=1),dT}function ZI(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=wi.getMatch(n,"mqtt");if(!i)throw new Error(`Can not publish to topic ${n} as it does not exist, no resource has been defined to handle this topic`);e.url=i.relativeURL;let o=i.Resource;return Dt(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var EY,Ma,hY,pY,fY,JI,ME,dT,_T,ew,SY=Oe(()=>{Pe();eu();EY=L(cn()),Ma=L(W());mc();hY=L(dt()),pY=L(xI());qr();fY=100,JI=Et({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),ME=Et({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,hY.getWorkerIndex)()===0&&(async()=>{await pY.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of ME.search({})){let t=e.data,r={...e};r.user?.username&&(r.user=await it.getUser(r.user.username));try{await ZI(r,t,r)}catch{(0,Ma.warn)("Failed to publish will",t)}ME.delete(e.id)}})();a(mY,"getSession");dT=1;a(XI,"getNextMessageId");_T=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;request;socket;subscriptions=[];awaitingAcks;sessionWasPresent;keepalive;keepaliveTimer;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),l,u;if(c>-1?(l=s.slice(c),u=s.slice(0,c)):u=s,!u)throw new Error("No topic provided");if(u.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let d=this.subscriptions.find(g=>g.topic===s),_;d?(_=i>0,d.end(),this.subscriptions.splice(this.subscriptions.indexOf(d),1)):_=i===2;let E={search:l,async:!0,user:this.user,startTime:o,omitCurrent:_,url:""};o&&(0,Ma.trace)("Resuming subscription from",s,"from",o);let f=wi.getMatch(u,"mqtt");if(!f){let g=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw g.statusCode=404,g}if(E.url=f.relativeURL,E.url.indexOf("+")>-1||E.url.indexOf("#")>-1){let g=E.url.slice(1);if(g.indexOf("#")>-1&&g.indexOf("#")!==g.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(E.isCollection=!0,g.indexOf("+")===g.length-1)E.onlyChildren=!0,E.url="/"+g.slice(0,g.length-1);else{let S=g.split("/"),b;for(let H=0;H<S.length;H++)if(S[H].indexOf("+")>-1)if(S[H]==="+")b=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&b)throw new Error("Filters can not be combined");let I=!0;S[S.length-1]==="#"&&(S.length--,I=!1),b&&(n=a(H=>{let X=H.id;if(!Array.isArray(X)||I&&X.length!==S.length)return!1;for(let Y=0;Y<S.length;Y++)if(S[Y]!=="+"&&S[Y]!==X[Y])return!1;return!0},"filter"));let B=S.indexOf("+");E.url="/"+(B>-1?S.slice(0,B):S).concat("").join("/")}}let h=f.path,T=f.Resource,m=await Dt(E,async()=>{let g=this.createContext();g.topic=s,g.retainHandling=i;let S=await T.subscribe(E,g);if(!S)return;if(!S[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let b=(async()=>{for await(let I of S)try{let B;if(I.type&&I.type!=="put"&&I.type!=="delete"&&I.type!=="message"&&I.type!=="patch"||n&&!n(I))continue;r?(I.topic=s,B=this.needsAcknowledge(I)):(I.acknowledge?.(),B=XI());let H=I.id;if(Array.isArray(H)&&(H=Zl(H)),H==null&&(H=""),await this.listener(h+"/"+H,I.value,B,t)===!1)break;this.awaitingAcks?.size>fY?await new Promise(Y=>setTimeout(Y,this.awaitingAcks.size-fY)):await new Promise(setImmediate)}catch(B){(0,Ma.warn)(B)}})();return S});return m.topic=s,m.qos=t.qos,this.subscriptions.push(m),m}resume(){}needsAcknowledge(t){let r=XI();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,{acknowledge:t.acknowledge})),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r.acknowledge())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),this.subscriptions.splice(this.subscriptions.indexOf(r),1),!0}async publish(t,r){return ZI(t,r,this.createContext())}createContext(){let t={session:this,socket:this.socket,user:this.user,authorize:!0};return this.request&&(t.request=this.request,t.url=this.request.url,t.headers=this.request.headers),t}setListener(t){this.listener=t}disconnect(t){this.keepaliveTimer&&clearTimeout(this.keepaliveTimer);let r=this.createContext();Dt(r,async()=>{try{if(!t){let n=await ME.get(this.sessionId);n?.doesExist()&&await ZI(n,n.data,r)}}finally{await ME.delete(this.sessionId)}}).catch(n=>{(0,Ma.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}receivedPacket(){this.keepalive&&(clearTimeout(this.keepaliveTimer),this.keepaliveTimer=setTimeout(()=>{this.socket?.destroy?this.socket.destroy(new Error("Keepalive timeout")):this.socket?.terminate()},this.keepalive*1500))}};a(ZI,"publish");ew=class extends _T{static{a(this,"DurableSubscriptionsSession")}sessionRecord;constructor(t,r,n){super(t,r),this.sessionRecord=n||{id:t,subscriptions:[]}}async resume(){for(let t of this.sessionRecord.subscriptions||[])await this.resumeSubscription({omitCurrent:!0,topic:t.topic,qos:t.qos,startTime:t.startTime},!0,t.acks?r=>!t.acks.includes(r.localTime):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=XI(),n={topic:t.topic,timestamp:t.localTime};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks?.get(t);if(!r)return;this.awaitingAcks?.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,Ma.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,EY.getNextMonotonicTime)()),(0,Ma.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),JI.put(this.sessionRecord)}}});var rw={};je(rw,{bypassAuth:()=>Vme,start:()=>Kme});function Vme(){yY=!0}function Kme({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new AY.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c=[],l=r?.mtls;return n&&(c=e.ws((u,d,_,E)=>{if(d.headers.get("sec-websocket-protocol")!=="mqtt")return E(u,d,_);o.events.emit("connection",u),dr.debug?.("Received WebSocket connection for MQTT from",u._socket.remoteAddress);let{onMessage:f,onClose:h}=gY(u,T=>{u.send(T)},d,Promise.resolve(_).then(()=>d?.user),o);u.on("message",f),u.on("close",h),u.on("error",T=>{dr.info?.("WebSocket error",T)})},{...n})),(t||s)&&c.push(e.socket(async u=>{let d;if(o.events.emit("connection",u),dr.debug?.(`Received ${u.getCertificate?"SSL":"TCP"} connection for MQTT from ${u.remoteAddress}`),l){if(u.authorized)try{let f=l.user;if(f!==null){(f===void 0||f==="Common Name"||f==="CN")&&(f=u.getPeerCertificate().subject.CN);try{d=await e.getUser(f,null,null),(0,md.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ET.notify?.({username:d?.username,status:kr.AUTH_AUDIT_STATUS.SUCCESS,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:u.remoteAddress})}catch(h){throw(0,md.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ET.error?.({username:f,status:kr.AUTH_AUDIT_STATUS.FAILURE,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:u.remoteAddress}),h}}else dr.debug?.("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",u.remoteAddress)}catch(f){o.events.emit("error",f,u),dr.error?.(f)}else if(l.required)return dr.info?.(`Unauthorized connection attempt, no authorized client certificate provided, error: ${u.authorizationError}`),u.end()}!d&&yY&&u.remoteAddress.includes("127.0.0.1")&&(d=await(0,RY.getSuperUser)(),dr.debug?.("Auto-authorizing local connection",d?.username));let{onMessage:_,onClose:E}=gY(u,f=>u.write(f),null,d,o);u.on("data",_),u.on("close",E),u.on("error",f=>{dr.info?.("Socket error",f)})},{port:t,securePort:s,mtls:l})),c}function gY(e,t,r,n,s){TY||(TY=!0,x_(_=>{fT>0&&_.push({metric:"mqtt-connections",connections:fT,byThread:!0})}));let i;fT++;let o,c={protocolVersion:4},l=(0,hT.parser)({protocolVersion:5});function u(_){l.parse(_)}a(u,"onMessage");function d(){fT--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),qn(!1,"connection","mqtt","disconnect"),dr.debug?.("MQTT connection was closed",e.remoteAddress))}return a(d,"onClose"),l.on("packet",async _=>{n?.then&&(n=await n);let E=_.cmd;if(o)o.then&&await o;else if(E!=="connect"){dr.info?.("Received packet before connection was established, closing connection"),e?.destroy?e.destroy():e?.terminate();return}let f=_.topic,h=f?.indexOf("/",1),T=h>0?f.slice(0,h):f;pr(_.length,"bytes-received",T,g(_),"mqtt");try{switch(o?.receivedPacket?.(),E){case"connect":if(c.protocolVersion=_.protocolVersion,_.username)try{n=await it.getUser(_.username,_.password.toString(),r),(0,md.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ET.notify?.({username:n?.username,status:kr.AUTH_AUDIT_STATUS.SUCCESS,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(V){return(0,md.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ET.error?.({username:_.username,status:kr.AUTH_AUDIT_STATUS.FAILURE,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",_,e,V),qn(!1,"connection","mqtt","connect"),m({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",_,e),qn(!1,"connection","mqtt","connect"),m({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(_,n),_.will){let V=e.deserialize||(e.deserialize=bo(r?.headers.get?.("content-type")));_.will.data=_.will.payload?.length>0?V(_.will.payload):void 0,delete _.will.payload}o=mY({user:n,..._}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(V){return dr.error?.(V),s.events.emit("auth-failed",_,e,V),qn(!1,"connection","mqtt","connect"),m({cmd:"connack",reasonCode:V.code||5,returnCode:V.code||128})}s.events.emit("connected",o,e),qn(!0,"connection","mqtt","connect"),m({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0}),o.setListener((V,ne,Q,de)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",V);let j=V.indexOf("/",1),ae=j>0?V.slice(0,j):V;m({cmd:"publish",topic:V,payload:S(ne),messageId:Q||Math.floor(Math.random()*1e8),qos:de.qos},ae);let Ae=e._socket??e;return Ae.writableNeedDrain?new Promise(ye=>Ae.once("drain",ye)):!Ae.closed}catch(j){return dr.error?.(j),o?.disconnect(),s.sessions.delete(o),!1}}),o.sessionWasPresent&&await o.resume();break;case"subscribe":let b=[];for(let V of _.subscriptions){let ne;try{let Q=await o.addSubscription(V,V.qos>=1);ne=Q?Q.qos||0:c.protocolVersion<5?128:143}catch(Q){s.events.emit("error",Q,e,V,o),Q.statusCode?Q.statusCode===500?dr.warn?.(Q):dr.info?.(Q):dr.error?.(Q),ne=c.protocolVersion<5?128:Q.statusCode===403?135:Q.statusCode===404?143:128}b.push(ne)}await o.committed,m({cmd:"suback",granted:b,messageId:_.messageId});break;case"unsubscribe":{let V=[];for(let ne of _.unsubscriptions)V.push(o.removeSubscription(ne)?0:17);m({cmd:"unsuback",granted:V,messageId:_.messageId});break}case"pubrel":m({cmd:"pubcomp",messageId:_.messageId,reasonCode:0});return;case"publish":let I=_.qos===2?"pubrec":"puback",B=e.deserialize||(e.deserialize=bo(r?.headers.get?.("content-type"))),X=(_.payload?.length||0)>0?B(_.payload):void 0,Y;try{Y=await o.publish(_,X)}catch(V){s.events.emit("error",V,e,_,o),dr.warn?.(V),_.qos>0&&m({cmd:I,messageId:_.messageId,reasonCode:128},_.topic);break}_.qos>0&&m({cmd:I,messageId:_.messageId,reasonCode:Y===!1?144:0},_.topic);break;case"pubrec":m({cmd:"pubrel",messageId:_.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(_.messageId);break;case"pingreq":m({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),qn(!0,"connection","mqtt","disconnect"),dr.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(b){s.events.emit("error",b,e,_,o),dr.error?.(b),m({cmd:"disconnect"})}function m(b,I){let B=(0,hT.generate)(b,c);t(B),pr(B.length,"bytes-sent",I,g(b),"mqtt")}a(m,"sendPacket");function g(b){return b.qos>0?b.cmd+",qos="+b.qos:b.cmd}a(g,"packetMethodName");function S(b){return Yc(b,r)}a(S,"serialize")}),l.on("error",_=>{dr.warn("MQTT parsing error, closing connection:",_.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:u,onClose:d}}var hT,RY,md,kr,tw,AY,ET,dr,yY,TY,fT,bY=Oe(()=>{hT=require("mqtt-packet");SY();RY=L(xn());Wc();Ni();qr();md=L(se()),kr=L(M()),tw=L(bc()),AY=require("events"),ET=(0,tw.loggerWithTag)("auth-event"),dr=(0,tw.loggerWithTag)("mqtt"),yY=(0,md.get)(kr.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(Vme,"bypassAuth");a(Kme,"start");fT=0;a(gY,"onSocket")});var qf={};je(qf,{component_errors:()=>Td,getComponentName:()=>Qme,loadComponent:()=>ST,loadComponentDirectories:()=>PY,setErrorReporter:()=>zme});function PY(e,t){t&&(sw=t),e&&(iw=e);let r=[];if((0,Nt.existsSync)(nw)){let s=(0,Nt.readdirSync)(nw,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,Ot.join)(nw,o);r.push(ST(c,sw,"hdb",!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(ST(n,sw,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{DY=!0})}function zme(e){UE=e}async function ST(e,t,r,n,s,i){let o=(0,Nt.realpathSync)(e);if(pT.has(o))return pT.get(o);pT.set(o,!0),s&&(iw=s);try{let c;n&&(Td=new Map);let l=(0,Ot.join)(e,n?"harperdb-config.yaml":"config.yaml");(0,Nt.existsSync)(l)?c=n?(0,TT.getConfigObj)():(0,NY.parseDocument)((0,Nt.readFileSync)(l,"utf8")).toJSON():c=ow;let u=(0,Ot.join)(e,"node_modules","harperdb");try{El.isMainThread&&(n||(0,Nt.existsSync)(u)&&(0,Nt.realpathSync)(Rd.PACKAGE_ROOT)!==(0,Nt.realpathSync)(u))&&((0,Nt.rmSync)(u,{recursive:!0,force:!0}),(0,Nt.existsSync)((0,Ot.join)(e,"node_modules"))||(0,Nt.mkdirSync)((0,Ot.join)(e,"node_modules")),(0,Nt.symlinkSync)(Rd.PACKAGE_ROOT,u,"dir"))}catch(E){Sd.default.error("Error symlinking harperdb module",E)}let d=mT,_=n;for(let E in c){mT=E;let f=c[E];if(Td.set(n?E:(0,Ot.basename)(e),!1),!f)continue;let h,T=f.package;try{if(T){let I=e,B;for(;!(0,Nt.existsSync)(B=(0,Ot.join)(I,"node_modules",E));)if(I=(0,Ot.dirname)(I),I.length<(0,CY.getHdbBasePath)().length){B=null;break}if(B)h=await ST(B,t,r,!1),_=!0;else throw new Error(`Unable to find package ${E}:${T}`)}else h=jme[E];if(!h)continue;let m=a(I=>(I.origin=r,Et(I)),"ensureTable"),g=f.network||(f.port||f.securePort)&&f,S=g?.securePort||g?.https&&g.port,b=!g?.https&&g?.port;if(El.isMainThread&&(h=await h.startOnMainThread?.({server:it,ensureTable:m,port:b,securePort:S,resources:t,...f})||h,n&&g))for(let I of[b,S])try{if(+I&&!OY.includes(I)){let B=aw.get(Rd.CONFIG_PARAMS.HTTP_SESSIONAFFINITY);B&&Sd.default.warn("Session affinity is not recommended and may cause memory leaks"),(B||!US)&&(OY.push(I),$I(I,B))}}catch(B){console.error("Error listening on socket",I,B,E)}if(t.isWorker&&(h=await h.start?.({server:it,ensureTable:m,port:b,securePort:S,resources:t,...f})||h),iw.set(h,!0),(h.handleFile||h.handleDirectory||h.setupFile||h.setupDirectory)&&f.files!=null){if(f.files.includes(".."))throw(0,wY.handleHDBError)("Can not reference parent directories");let I=(0,Ot.join)(e,f.files).replace(/\\/g,"/"),B=I.indexOf("/*");if(B>-1&&f.files!==ow[E]?.files&&!(0,Nt.existsSync)(I.slice(0,B)))throw new Error(`The path '${I.slice(0,B)}' does not exist and cannot be used as the base of the resolved 'files' path value '${f.files}'`);let H=(0,Ot.basename)(e),X=f.path||"/";X=X.startsWith("/")?X:X.startsWith("./")?"/"+H+X.slice(2):X==="."?"/"+H:"/"+H+"/"+X;let Y,V,ne;if(f.root){let de=f.root;de.startsWith("/")&&(de=de.slice(1)),de.endsWith("/")&&(de=de.slice(0,-1)),de+="/",V=(0,Ot.join)(e,de)}else(ne=I.indexOf("/*"))>-1?(V=I.slice(0,ne+1),Y=(0,Ot.relative)(e,V)):f.files.indexOf("/")>-1&&(V=I.slice(0,I.lastIndexOf("/")+1),Y=(0,Ot.relative)(e,V));let Q=!1;if(El.isMainThread&&h.setupDirectory&&(Q=await h.setupDirectory?.(X,V,t)),t.isWorker&&h.handleDirectory&&(Q=await h.handleDirectory?.(X,V,t)),Q){_=!0;continue}for(let de of await(0,IY.default)(I,{onlyFiles:!1,objectMode:!0})){let{path:j,dirent:ae}=de;_=!0;let Ae=(0,Ot.relative)(e,j).replace(/\\/g,"/");if(Y)if(Ae.startsWith(Y))Ae=Ae.slice(Y.length+1);else throw new Error(`The root path '${f.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 ye=X+(X.endsWith("/")?"":"/")+Ae;try{if(ae.isFile()){let Me=await Wme(j);El.isMainThread&&await h.setupFile?.(Me,ye,j,t),t.isWorker&&await h.handleFile?.(Me,ye,j,t)}else El.isMainThread&&await h.setupDirectory?.(ye,j,t),t.isWorker&&await h.handleDirectory?.(ye,j,t)}catch(Me){Me.message=`Could not load ${ae.isFile()?"file":"directory"} '${j}'${f.module?" using '"+f.module+"'":""} for application '${e}' due to: ${Me.message}`,UE?.(Me),((0,gd.getWorkerIndex)()===0?console:Sd.default).error(Me),t.set(f.path||"/",new ta(Me)),Td.set(n?E:(0,Ot.basename)(e),Me.message)}}}}catch(m){m.message=`Could not load component '${E}' for application '${(0,Ot.basename)(e)}' due to: ${m.message}`,UE?.(m),((0,gd.getWorkerIndex)()===0?console:Sd.default).error(m),t.set(f.path||"/",new ta(m),null,!0),Td.set(n?E:(0,Ot.basename)(e),m.message)}}if(mT=d,El.isMainThread&&!DY&&i&&(0,gd.watchDir)(e,async()=>PY()),c.extensionModule){let E=await aS((0,Ot.join)(e,c.extensionModule));return pT.set(o,E),E}if(!_&&t.isWorker){let E=`${e} did not load any modules, resources, or files, is this a valid component?`;UE?.(new Error(E)),((0,gd.getWorkerIndex)()===0?console:Sd.default).error(E),Td.set((0,Ot.basename)(e),E)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,UE?.(c),t.set("",new ta(c))}}var Nt,Ot,El,NY,aw,Rd,IY,gd,Sd,wY,CY,Yme,TT,Wme,nw,iw,DY,sw,Td,jme,ow,OY,pT,UE,mT,Qme,$f=Oe(()=>{Nt=require("fs"),Ot=require("path"),El=require("worker_threads"),NY=require("yaml"),aw=L(se()),Rd=L(M());ND();Hq();Gq();Kq();Yq();o$();XV();s1();IY=L(require("fast-glob")),gd=L(dt()),Sd=L(W());QO();qr();wY=L(_e());Pe();wI();CY=L(se()),Yme=L(sY());xm();_Y();us();bY();TT=L(wt());vS();fy();({readFile:Wme}=Nt.promises),nw=(0,TT.resolvePath)(aw.get(Rd.CONFIG_PARAMS.COMPONENTSROOT)),iw=new Map,Td=new Map;a(PY,"loadComponentDirectories");jme={REST:_S,rest:_S,graphql:jO,graphqlSchema:Pg,roles:zO,jsResource:XO,fastifyRoutes:YN,login:eN,static:WN,operationsApi:Yme,customFunctions:{},http:{},clustering:QI,replication:ca,authentication:Hf,mqtt:rw},ow={rest:!0,graphql:!0,graphqlSchema:{files:"*.graphql"},roles:{files:"roles.yaml"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(ow,"static",{value:{files:"web/**"}});OY=[],pT=new Map;a(zme,"setErrorReporter");Qme=a(()=>mT,"getComponentName");a(ST,"loadComponent")});var nT=N((EMe,MY)=>{var{isMainThread:LY}=require("worker_threads"),{getTables:Jme,getDatabases:_Me,table:fMe}=(Pe(),oe(lt)),{loadComponentDirectories:Xme,loadComponent:Zme}=($f(),oe(qf)),{resetResources:eSe}=(eu(),oe(sB)),tSe=SO(),rSe=wt(),{dirname:nSe}=require("path"),{getConnection:sSe}=mr(),iSe=se(),{CONFIG_PARAMS:oSe}=M(),{loadCertificates:aSe}=Xs(),cw=new Map;async function cSe(e=!1){!LY&&iSe.get(oSe.CLUSTERING_ENABLED)&&sSe();try{LY&&await tSe()}catch(n){console.error(n)}let t=eSe();Jme(),t.isWorker=e,await aSe(),await Zme(nSe(rSe.getConfigFilePath()),t,"hdb",!0,cw),await Xme(cw,t);let r=[];for(let[n]of cw)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(cSe,"loadRootComponents");MY.exports.loadRootComponents=cSe});var dt=N((pMe,ai)=>{"use strict";var{Worker:lSe,MessageChannel:uSe,parentPort:Vi,isMainThread:fw,threadId:dSe,workerData:Ki}=require("worker_threads"),{PACKAGE_ROOT:_Se}=M(),{join:HY,isAbsolute:fSe,extname:ESe}=require("path"),{server:xY}=(qr(),oe(Qa)),{watch:hSe,readdir:pSe}=require("fs/promises"),{totalmem:UY}=require("os"),vE=M(),kY=se(),Yi=W(),{randomBytes:mSe}=require("crypto"),{_assignPackageExport:SSe}=fi(),TSe=M(),vY=1024*1024,Ua=[],Ps=[],gSe=50,Ew=1e4,RSe="restart",FY="request_thread_info",GY="resource_report",qY="thread_info",$Y="added-port",ASe="ack",lw;SSe("threads",Ps);ai.exports={startWorker:uw,restartWorkers:pw,shutdownWorkers:ISe,workers:Ua,setMonitorListener:vSe,onMessageFromWorkers:wSe,onMessageByType:QY,broadcast:DSe,broadcastWithAcknowledgement:LSe,setChildListenerByType:NSe,getWorkerIndex:VY,getWorkerCount:KY,getTicketKeys:WY,setMainIsWorker:bSe,setTerminateTimeout:ySe,restartNumber:Ki?.restartNumber||1};Ps.onMessageByType=QY;Ps.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=Ps.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};ai.exports.whenThreadsStarted=new Promise(e=>{ai.exports.threadsHaveStarted=e});var hw;function ySe(e){Ew=e}a(ySe,"setTerminateTimeout");function VY(){return Ki?Ki.workerIndex:hw?0:void 0}a(VY,"getWorkerIndex");function KY(){return Ki?Ki.workerCount:hw?1:void 0}a(KY,"getWorkerCount");function bSe(e){hw=e,ai.exports.threadsHaveStarted()}a(bSe,"setMainIsWorker");var YY=1,gT;function WY(){return gT||(gT=fw?mSe(48):Ki.ticketKeys,gT)}a(WY,"getTicketKeys");Object.defineProperty(xY,"workerIndex",{get(){return VY()}});Object.defineProperty(xY,"workerCount",{get(){return KY()}});var jY={[FY](e,t){MSe(t)},[GY](e,t){USe(t,e)}};function uw(e,t={}){let r=process.constrainedMemory?.()||UY();r=Math.min(r,UY(),2e4*vY);let n=kY.get(vE.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/vY/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let l of Ps){let u=new uSe;u.existingPort=l,i.push(u),o.push(u.port2)}ESe(e)||(e+=".js");let c=new lSe(fSe(e)?e:HY(_Se,e),{resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps"],argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(l=>l.existingPort.threadId),workerIndex:t.workerIndex,workerCount:YY=t.threadCount,name:t.name,restartNumber:ai.exports.restartNumber,ticketKeys:WY()},transferList:o,...t});for(let{port1:l,existingPort:u}of i)u.postMessage({type:$Y,port:l,threadId:c.threadId},[l]);return AT(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>uw(e,t),c.on("error",l=>{Yi.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{Ua.splice(Ua.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<gSe?(t.unexpectedRestarts=c.unexpectedRestarts+1,uw(e,t)):Yi.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{jY[l.type]?.(l,c)}),Ua.push(c),HSe(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(uw,"startWorker");var OSe=[vE.THREAD_TYPES.HTTP];async function pw(e=null,t=Math.max(YY>3,1),r=!0){if(fw){if(r){let{loadRootComponents:o}=nT();await o()}ai.exports.restartNumber++,t<1&&(t=t*Ua.length);let n=[],s=[];for(let o of Ua.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;Yi.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:ai.exports.restartNumber,type:vE.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=OSe.indexOf(o.name)>-1,l=new Promise(u=>{let d=setTimeout(()=>{Yi.warn("Thread did not voluntarily terminate, terminating from the outside",o.threadId),o.terminate()},Ew*2).unref();o.on("exit",()=>{clearTimeout(d),n.splice(n.indexOf(l)),!c&&r&&o.startCopy(),u()})});if(n.push(l),c&&r){let u=o.startCopy(),d=new Promise(_=>{let E=a(f=>{f.type===TSe.ITC_EVENT_TYPES.CHILD_STARTED&&(Yi.trace("Worker has started",u.threadId),_(),s.splice(s.indexOf(d)),u.off("message",E))},"startListener");Yi.trace("Waiting for worker to start",u.threadId),u.on("message",E)});s.push(d),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=xu();r&&(e==="http"||!e)&&kY.get(vE.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else Vi.postMessage({type:RSe,workerType:e})}a(pw,"restartWorkers");function NSe(e,t){jY[e]=t}a(NSe,"setChildListenerByType");function ISe(e){return pw(e,1/0,!1)}a(ISe,"shutdownWorkers");var zY=[];function wSe(e){zY.push(e)}a(wSe,"onMessageFromWorkers");var dw=new Map;function QY(e,t){let r=dw.get(e);r||dw.set(e,r=[]),r.push(t)}a(QY,"onMessageByType");var CSe=10;async function DSe(e,t){let r=0;for(let n of Ps)try{n.postMessage(e),r++>CSe&&(r=0,await new Promise(setImmediate))}catch(s){Yi.error("Unable to send message to worker",s)}t&&XY(e,null)}a(DSe,"broadcast");var RT=new Map,PSe=1;function LSe(e){return new Promise(t=>{let r=0;for(let n of Ps)try{let s=PSe++,i=a(()=>{RT.delete(s),--r===0&&t(),n!==Vi&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,RT.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of RT)o.port===n&&o()})),n.postMessage(e),r++}catch(s){Yi.error("Unable to send message to worker",s)}r===0&&t()})}a(LSe,"broadcastWithAcknowledgement");function MSe(e){e.postMessage({type:qY,workers:JY()})}a(MSe,"sendThreadInfo");function JY(){let e=Date.now();return Ua.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(JY,"getChildWorkerInfo");function USe(e,t){e.resources=t,e.resources.updated=Date.now()}a(USe,"recordResourceReport");var _w;function vSe(e){_w=e}a(vSe,"setMonitorListener");var BSe=1e3,BY=!1;function HSe(){BY||(BY=!0,setInterval(()=>{for(let e of Ua){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}_w&&_w()},BSe).unref())}a(HSe,"startMonitoring");var xSe=1e3;if(Vi&&Ki?.addPorts){AT(Vi);for(let e=0,t=Ki.addPorts.length;e<t;e++){let r=Ki.addPorts[e];r.threadId=Ki.addThreadIds[e],AT(r)}setInterval(()=>{let e=process.memoryUsage();Vi.postMessage({type:GY,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},xSe).unref(),lw=a(()=>new Promise((e,t)=>{Vi.on("message",r),Vi.postMessage({type:FY});function r(n){n.type===qY&&(Vi.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else lw=JY;ai.exports.getThreadInfo=lw;function AT(e,t){Ps.push(e),e.on("message",r=>{if(r.type===$Y)r.port.threadId=r.threadId,AT(r.port);else if(r.type===ASe){let n=RT.get(r.id);n&&n()}else XY(r,e)}).on("close",()=>{Ps.splice(Ps.indexOf(e),1)}).on("exit",()=>{Ps.splice(Ps.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(AT,"addPort");function XY(e,t){for(let n of zY)n(e,t);let r=dw.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){Yi.error(s)}}a(XY,"notifyMessageListeners");if(fw){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await pSe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(HY(s,o.name));try{for await(let{filename:o}of hSe(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await pw(),console.log("Reloaded HarperDB components, changed files:",Array.from(r)),r.clear()},100)}catch(o){console.warn("Error trying to watch component directory",s,o)}},"watch_dir");ai.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else Vi.on("message",async e=>{let{type:t}=e;t===vE.ITC_EVENT_TYPES.SHUTDOWN&&(ai.exports.restartNumber=e.restartNumber,Vi.unref(),setTimeout(()=>{Yi.warn("Thread did not voluntarily terminate",dSe),process.exit(0)},Ew).unref())})});var uv={};je(uv,{AUDIT_STORE_OPTIONS:()=>Pf,Decoder:()=>Cc,HAS_CURRENT_RESIDENCY_ID:()=>tc,HAS_EXPIRATION_EXTENDED_TYPE:()=>i_,HAS_ORIGINATING_OPERATION:()=>s_,HAS_PREVIOUS_RESIDENCY_ID:()=>rc,REMOTE_SEQUENCE_UPDATE:()=>Kp,createAuditEntry:()=>Dl,getLastRemoved:()=>Yy,openAuditStore:()=>IT,readAuditEntry:()=>Ht,removeAuditEntry:()=>wT,setAuditRetention:()=>FSe,transactionKeyEncoder:()=>cW});function IT(e){let t=e.auditStore=e.openDB(mw.AUDIT_STORE_NAME,{create:!1,...Pf});t||(t=e.auditStore=e.openDB(mw.AUDIT_STORE_NAME,Pf),eW(t,1)),t.rootStore=e;let r=[];t.addDeleteRemovalCallback=function(i,o){return r[i]=o,t.deleteCallbacks=r,{remove(){delete r[i]}}};let n=null;function s(i=yT){clearTimeout(n),n=setTimeout(async()=>{if(t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let o=0,c,l;try{for(let{key:u,value:d}of t.getRange({start:1,snapshot:!1,end:Date.now()-Sw}))if(c=wT(t,u,d),l=u,await new Promise(setImmediate),++o>=kSe){i=10;break}await c}finally{o===0?i=Math.min(i<<1,Sw/10):eW(t,l),s(i)}},i).unref()}if(a(s,"scheduleAuditCleanup"),t.scheduleAuditCleanup=s,(0,HE.getWorkerIndex)()===(0,HE.getWorkerCount)()-1&&s(yT),(0,HE.getWorkerIndex)()===0&&!ZY)for(let i of t.getKeys({reverse:!0,limit:1}))i>Date.now()&&(ZY=!0,NT.error("The current time is before the last recorded entry in the audit log. Time reversal can undermine the integrity of data tracking and certificate validation and the time must be corrected."));return t}function wT(e,t,r){if((GSe(r)&15)===Tw){let n=Ht(r),s=n.tableId;e.deleteCallbacks?.[s]?.(n.recordId)}return e.remove(t)}function eW(e,t){gw[0]=t,e.put(Symbol.for("last-removed"),lW)}function Yy(e){let t=e.get(Symbol.for("last-removed"));if(t)return lW.set(t),gw[0]}function FSe(e,t=yT){Sw=e,yT=t}function Dl(e,t,r,n,s,i,o,c,l,u,d,_,E){let f=uW[o];if(!f)throw new Error(`Invalid audit entry type ${o}`);let h=1;if(n&&(n>1?va.setFloat64(0,n):Ls.set(jg),h=9),l){if(l&16761087)throw new Error("Illegal extended type");h++}g(s),g(t),m(r),va.setFloat64(h,e),h+=8,l&tc&&g(u),l&rc&&g(d),l&i_&&(va.setFloat64(h,_),h+=8),l&s_&&g(dW[E]),i?m(i):Ls[h++]=0,l?va.setUint16(n?8:0,f|l|32768):Ls[n?8:0]=f;let T=Ls.subarray(0,h);if(c)return Buffer.concat([T,c]);return T;function m(S){let b=h;h+=1,h=(0,hl.writeKey)(S,Ls,h);let I=h-b-1;I>127?I>16383?(NT.error("Key or username was too large for audit entry",S),h=b+1,Ls[b]=0):(Ls.copyWithin(b+2,b+1,h),va.setUint16(b,I|32768),h++):Ls[b]=I}function g(S){S<128?Ls[h++]=S:S<16384?(va.setUint16(h,S|32768),h+=2):S<1056964608?(va.setUint32(h,S|3221225472),h+=4):(Ls[h]=255,va.setUint32(h+1,S),h+=5)}}function GSe(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 Cc(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function Ht(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new Cc(e.buffer,e.byteOffset,e.byteLength));n.position=t;let s;e[n.position]==66&&(s=n.readFloat64());let i=n.readInt(),o=n.readInt(),c=n.readInt(),l=n.readInt(),u=n.position,d=n.position+=l,_=n.readFloat64(),E,f,h,T;if(i&tc&&(E=n.readInt()),i&rc&&(f=n.readInt()),i&i_&&(h=n.readFloat64()),i&s_){let S=n.readInt();T=dW[S]}l=n.readInt();let m=n.position,g=n.position+=l;return{type:uW[i&7],tableId:c,nodeId:o,get recordId(){return(0,hl.readKey)(e,u,d)},getBinaryRecordId(){return e.subarray(u,d)},version:_,previousLocalTime:s,get user(){return g>m?(0,hl.readKey)(e,m,g):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(S,b,I){if(i&bT||i&BE&&!b)return S.decoder.decode(e.subarray(n.position,r));if(i&BE&&I)return Rw(S.getEntry(this.recordId),I,S)},getBinaryValue(){return i&(bT|BE)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:E,previousResidencyId:f,expiresAt:h,originatingOperation:T}}catch(n){return NT.error("Reading audit entry error",n,e),{}}}var hl,OT,mw,oW,HE,aW,NT,Ls,va,cW,Pf,Sw,kSe,gw,lW,yT,ZY,bT,BE,tW,Tw,rW,nW,sW,iW,Kp,tc,rc,s_,i_,uW,dW,Cc,Ji=Oe(()=>{hl=require("ordered-binary"),OT=L(se()),mw=L(Bt()),oW=L(M()),HE=L(dt()),aW=L(te());Pl();NT=L(W());CT();(0,OT.initSync)();Ls=Buffer.alloc(1024),va=new DataView(Ls.buffer,Ls.byteOffset,1024),cW={writeKey(e,t,r){return e===n_?(t.set(n_,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,hl.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,hl.readKey)(e,t,r)}},Pf={encoding:"binary",keyEncoder:cW},Sw=(0,aW.convertToMS)((0,OT.get)(oW.CONFIG_PARAMS.LOGGING_AUDITRETENTION))||86400*3,kSe=1e3,gw=new Float64Array(1),lW=new Uint8Array(gw.buffer),yT=1e4,ZY=!1;a(IT,"openAuditStore");a(wT,"removeAuditEntry");a(eW,"updateLastRemoved");a(Yy,"getLastRemoved");a(FSe,"setAuditRetention");bT=16,BE=32,tW=1,Tw=2,rW=3,nW=4,sW=5,iW=6,Kp=11,tc=512,rc=1024,s_=2048,i_=4096,uW={put:tW|bT,[tW]:"put",delete:Tw,[Tw]:"delete",message:rW|bT,[rW]:"message",invalidate:nW|BE,[nW]:"invalidate",patch:sW|BE,[sW]:"patch",relocate:iW,[iW]:"relocate"},dW={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};a(Dl,"createAuditEntry");a(GSe,"readAction");a(Ht,"readAuditEntry");Cc=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t;return t=this.getUint8(this.position++),t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch(t){throw t.message=`Error reading float64: ${t.message} at position ${this.position}`,t}}}});var Aw={};je(Aw,{add:()=>DT,applyReverse:()=>_W,getRecordAtTime:()=>Rw,rebuildUpdateBefore:()=>PT});function DT(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n+BigInt(r.value):isNaN(e[t])?e[t]=r.value:e[t]=n+r.value}function PT(e,t,r){let n=null;for(let s in e)if(s in t){let i=t[s];if(i?.__op__){let o=e[s];if(o?.__op__)if(o.__op__===i.__op__)n||(n={}),n[s]=o;else throw new Error("Can not merge updates with different operations");else n||(n={}),n[s]=o,DT(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function _W(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=qSe[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=fW}}function Rw(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),u=Ht(l);switch(u.type){case"put":s=u.getValue(r);break;case"patch":_W(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===fW&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),u=Ht(l),d;switch(u.type){case"put":d=u.getValue(r);break;case"patch":d=u.getValue(r);break}for(let _ in d)o[_]&&(s[_]=d[_],o[_]=!1,c--);i=u.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var qSe,fW,CT=Oe(()=>{Ji();a(DT,"add");DT.reverse=function(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n-BigInt(r.value):isNaN(e[t])||(e[t]=n-r.value)};qSe={add:DT};a(PT,"rebuildUpdateBefore");a(_W,"applyReverse");fW={};a(Rw,"getRecordAtTime")});function Zn(e){return e[_r]||(e[_r]=Object.create(null))}function BT(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let o of s){let c=o.name,l,u;if(o.resolve)u={get(){return o.resolve(this,this[ke])},set(d){return o.set(this,d)},configurable:!0};else{switch(o.type){case"String":l=a(function(d){if(!(typeof d=="string"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a string, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"ID":l=a(function(d){if(!(typeof d=="string"||d?.length>0&&d.every?.(_=>typeof _=="string")||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a string, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Float":case"Number":l=a(function(d){let _=d?.__op__?d.value:d;if(!(typeof _=="number"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a number, attempt to assign ${_}`);Zn(this)[c]=d},"set");break;case"Int":l=a(function(d){let _=d?.__op__?d.value:d;if(!(_>>0===_||d==null&&o.nullable!==!1))if(typeof _=="number"&&Math.abs((_>>0)-_)<=1)_=Math.round(_),d?.__op__?d.value=_:d=_;else throw new Ms.ClientError(`${c} must be an integer between -2147483648 and 2147483647, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Long":l=a(function(d){let _=d?.__op__?d.value:d;if(!(Math.round(_)===d&&Math.abs(_)<=9007199254740992||d==null&&o.nullable!==!1))if(typeof _=="number"&&Math.abs(_)<=9007199254740992)_=Math.round(_),d?.__op__?d.value=_:d=_;else throw new Ms.ClientError(`${c} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"BigInt":l=a(function(d){let _=d?.__op__?d.value:d;if(!(typeof _=="bigint"||d==null&&o.nullable!==!1))if(typeof _=="string"||typeof _=="number")_=BigInt(_),d?.__op__?d.value=_:d=_;else throw new Ms.ClientError(`${c} must be a number, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Boolean":l=a(function(d){if(!(typeof d=="boolean"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a boolean, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Date":l=a(function(d){if(!(d instanceof Date||d==null&&o.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=new Date(d);else throw new Ms.ClientError(`${c} must be a Date, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Bytes":l=a(function(d){if(!(d instanceof Uint8Array||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a Buffer or Uint8Array, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Any":case void 0:l=a(function(d){Zn(this)[c]=d},"set");break;default:l=a(function(d){if(!(typeof d=="object"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be an object, attempt to assign ${d}`);Zn(this)[c]=d},"set")}u={get(){let d=this[_r];if(d&&c in d){let E=d[c];if(E?.__op__){let f=this[ve]?.[c];return E.update(f)}return E}let _=this[ve]?.[c];if(_&&typeof _=="object"){let E=hW(_,o);if(E)return d||(d=this[_r]=Object.create(null)),d[c]=E}return _},set:l,enumerable:!0,configurable:!0}}u.get.isAttribute=!0,n[c]=u,(!(c in r)||Object.getOwnPropertyDescriptor(r,c)?.get?.isAttribute)&&Object.defineProperty(r,c,u)}i("getProperty",function(o){let c=n[o];if(c)return c.get.call(this);let l=this[_r];return l?.[o]!==void 0?l[o]:this[ve]?.[o]}),i("set",function(o,c){let l=n[o];if(l)return l.set.call(this,c);if(t.sealed)throw new Ms.ClientError("Can not add a property to a sealed table schema");Zn(this)[o]=c}),i("deleteProperty",function(o){Zn(this)[o]=void 0}),i("toJSON",function(){let o=this[_r],c;for(let u in o){c||(c={...this[ve]});let d=o[u];if(d?.__op__){let _=c[u];d=d.update(_)}c[u]=d}return Object.keys(this).length>0&&(c||(c={...this[ve]}),Object.assign(c,this)),c||this[ve]}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty);function i(o,c){Object.defineProperty(r,o,{value:c,configurable:!0})}a(i,"setMethod")}function hW(e,t){let r;switch(e.constructor){case Object:return t?((r=t.TrackedObject)||(t.TrackedObject=r=class{static{a(this,"TrackedObject")}constructor(s){if(s?.[ve])throw new Error("Can not track an already tracked object, check for circular references");this[ve]=s}},BT(r,t)),new r(e)):new LT(e);case Array:let n=new UT(e.length);n[ve]=e;for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=hW(o,t?.elements)),n[s]=o}return n;default:return e}}function dp(e){let t=e[_r],r;for(let s in t){r||(r={...e[ve]});let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=dp(i);r[s]=i}return Object.keys(e).length>0&&(r||(r={...e[ve]}),Object.assign(r,e)),r||e[ve]}function ml(e,t=e[_r]){let r;if(EW.call(e,ve)&&e.constructor===Array&&!Object.isFrozen(e)){r=e;for(let n=0,s=e.length;n<s;n++){let i=e[n];if(i&&typeof i=="object"){let o=ml(i);o!==i&&r===e&&(r=e.slice(0)),i=o}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r={...e[ve]});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=Aw[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=ml(s);r[n]=s}return r?Object.freeze(r):EW.call(e,ve)?e[ve]:e}function MT(e){let t=e[ve];if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[pl]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.[ve]===s){if(MT(i))return!0}else return!0}}else{let r=e[_r];if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s[ve]===i){if(MT(s))return!0}else return!0}else return!0}}return!1}var Ms,_r,LT,EW,pl,UT,vT,_p=Oe(()=>{Vs();Ms=L(_e());CT();_r=Symbol("own-data");a(Zn,"getChanges");a(BT,"assignTrackedAccessors");a(hW,"trackObject");LT=class{static{a(this,"GenericTrackedObject")}constructor(t){if(t?.[ve])throw new Error("Can not track an already tracked object, check for circular references");this[ve]=t}};BT(LT,{});a(dp,"collapseData");EW=Object.prototype.hasOwnProperty;a(ml,"updateAndFreeze");a(MT,"hasChanges");pl=Symbol.for("has-array-changes"),UT=class extends Array{static{a(this,"TrackedArray")}[pl];constructor(t){super(t)}splice(...t){return this[pl]=!0,super.splice(...t)}push(...t){return this[pl]=!0,super.push(...t)}pop(){return this[pl]=!0,super.pop()}unshift(...t){return this[pl]=!0,super.unshift(...t)}shift(){return this[pl]=!0,super.shift()}};UT.prototype.constructor=Array;vT=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var _A={};je(_A,{CONTEXT:()=>ke,ID_PROPERTY:()=>ze,IS_COLLECTION:()=>ci,MultiPartId:()=>xT,RECORD_PROPERTY:()=>ve,Resource:()=>Lr,snake_case:()=>VSe,transformForSelect:()=>kT});function VSe(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function pW(e,t){if(Sl=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(Sl=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new xT;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Sl=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return Sl=!0,null;e[e.length-1]==="/"&&(Sl=!0)}return t.coerceId(decodeURIComponent(e))}function es(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,l,u,d;if(r?(o?(d=i,o=o[ke]||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(d=s,c=d[this.primaryKey]??null,o=i[ke]||i):d=i:(d=s,s=void 0,c=d[ze]??d[this.primaryKey]),c===null&&(u=!0)):i?o=i[ke]||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="object"&&s){if(l=s,typeof(c=s.url)=="string"){let f=c.indexOf("?");if(f>-1){let T=this.parseQuery(c.slice(f+1));l?T&&(l=Object.assign(T,l)):l=T,c=c.slice(0,f)}let h=this.parsePath(c,o,l);h?.id!==void 0?(h.query&&(l?l=Object.assign(h.query,l):l=h.query),u=h.isCollection,c=h.id):c=h}else if(s[Symbol.iterator]){c=[],u=!0;for(let f of s){if(typeof f=="object"&&f)break;c.push(f)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=null,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new Xc(c),c==null&&(u=!0);o||(o={});let _;if(l?.ensureLoaded!=null||l?.async||u?(_={...t},l?.ensureLoaded!=null&&(_.ensureLoaded=l.ensureLoaded),l?.async&&(_.async=l.async),u&&(_.isCollection=!0)):_=t,o.transaction){let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)}else return Dt(o,()=>{let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)},_);function E(f){if(o.authorize){o.authorize=!1;let h=t.type==="read"?f.allowRead(o.user,l,o):t.type==="update"?f.doesExist?.()===!1?f.allowCreate(o.user,d,o):f.allowUpdate(o.user,d,o):t.type==="create"?f.allowCreate(o.user,d,o):f.allowDelete(o.user,l,o);if(h?.then)return h.then(T=>{if(!T)throw new HT(o.user);return typeof d?.then=="function"?d.then(m=>e(f,l,o,m)):e(f,l,o,d)});if(!h)throw new HT(o.user)}return typeof d?.then=="function"?d.then(h=>e(f,l,o,h)):e(f,l,o,d)}a(E,"authorizeActionOnResource")}}function ts(e,t){let r=new TW.ClientError(`The ${e.constructor.name} does not have a ${t} method implemented`,405);r.allow=[],r.method=t;for(let n of["get","put","post","delete","query","move","copy"])typeof e[n]=="function"&&r.allow.push(n);throw r}function yw(e,t,r){let n=e[ve];if(n){let s=e[_r];return i=>{let o,c;return e.hasOwnProperty(i)&&typeof(o=e[i])!="function"?o:s&&i in s?s[i]:(c=t?.[i])?c(e,r):n[i]}}else return t?s=>{let i=t[s];return i?i(e,r):e[s]}:s=>e[s]}function kT(e,t){let r=t?.propertyResolvers,n=t[ke],s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):yw(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(c);let u=[],d=i(yw(l,r,n));for(let _ of e)u.push(d(_));return u},"transform");let o=e.forceNulls;return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(E=>E&&typeof E=="object"?c(E):E);let u={},d=i(yw(l,r,n)),_;for(let E of e){let f=d(E);f===void 0&&o&&(f=null),f?.then?(_||(_=[]),_.push(f.then(h=>u[E.name||E]=h))):u[E.name||E]=f}return _?Promise.all(_).then(()=>u):u},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(o){return c=>{if(typeof c=="string")return o(c);if(typeof c=="object")if(c.name){s||(s={});let l=s[c.name];if(!l){let d=r[c.name]?.definition?.tableClass;l=s[c.name]=kT(c.select||c,d)}let u=o(c.name);return l(u)}else return o(c);else return c}}a(i,"handleProperty")}var mW,SW,TW,ke,ze,ci,ve,$Se,Lr,HT,Sl,xT,Vs=Oe(()=>{mW=require("crypto");wl();SW=L(fi()),TW=L(_e());_p();mc();iE();ke=Symbol.for("context"),ze=Symbol.for("primary-key"),ci=Symbol("is-collection"),ve=Symbol("stored-record"),$Se={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Lr=class{static{a(this,"Resource")}static transactions;constructor(t,r){this[ze]=t;let n=r?.[ke];this[ke]=n!==void 0?n:r||null}static get=es(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let l;if((l=r?.select)&&c!=null&&!c.selectApplied){let u=kT(l,t.constructor);return typeof c?.map=="function"?c.map(u):u(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=es(function(t,r,n,s){if(Array.isArray(s)&&t[ci]){let i=[],o=n.authorize;for(let c of s){let l=t.constructor,u=l.getResource(c[l.primaryKey],n,{async:!0});u.then?i.push(u.then(d=>d.put(c,n))):i.push(u.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):ts(t,"put")},{hasContent:!0,type:"update"});static patch=es(function(t,r,n,s){return t.patch?t.patch(s,r):ts(t,"patch")},{hasContent:!0,type:"update"});static delete=es(function(t,r,n,s){return t.delete?t.delete(r):ts(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,mW.randomUUID)()}static create(t,r,n){let s;return t==null?s=r?.[this.primaryKey]??this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=r?.[this.primaryKey]??[...t,this.getNewId()]:typeof t!="object"?s=r?.[this.primaryKey]??[t,this.getNewId()]:(s=t?.[this.primaryKey]??this.getNewId(),n=r||{},r=t),n||(n={}),Dt(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):ts(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=es(function(t,r,n,s){return t.invalidate?t.invalidate(r):ts(t,"delete")},{hasContent:!1,type:"update"});static post=es(function(t,r,n,s){return t[ze]!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=es(function(t,r,n,s){return t.connect?t.connect(s,r):ts(t,"connect")},{hasContent:!0,type:"read"});static subscribe=es(function(t,r,n,s){return t.subscribe?t.subscribe(r):ts(t,"subscribe")},{type:"read"});static publish=es(function(t,r,n,s){return t[ze]!=null&&t.update?.(),t.publish?t.publish(s,r):ts(t,"publish")},{hasContent:!0,type:"create"});static search=es(function(t,r,n,s){let i=t.search?t.search(r):ts(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=kT(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=es(function(t,r,n,s){return t.search?t.search(s,r):ts(t,"search")},{hasContent:!0,type:"read"});static copy=es(function(t,r,n,s){return t.copy?t.copy(s,r):ts(t,"copy")},{hasContent:!0,type:"create"});static move=es(function(t,r,n,s){return t.move?t.move(s,r):ts(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this[ci])return(await this.constructor.create(this[ze],t,this[ke]))[ze];ts(this,"post")}static isCollection(t){return t?.[ci]}static coerceId(t){return t}static parseQuery(t){return uS(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1);t=t.slice(0,s);let c=r?.headers&&$Se[o];if(c)r.requestedContentType=c;else if(n)n.property=o;else return{query:{property:o},id:pW(t,this),isCollection:Sl}}let i=pW(t,this);return Sl?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r[ke],o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let u=l.asMap.get(t);if(s=u?.find(d=>d.constructor===c),s)return s;u||l.asMap.set(t,u=[]),u.push(s=new c(t,i))}else{if(s=l.find(u=>u[ze]===t&&u.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let u=new Map;for(let d of l){let _=d[ze],E=u.get(_);E?E.push(d):u.set(_,[d])}i.resourceCache.length=0,i.resourceCache.asMap=u}}}else s=new c(t,i);return o&&(s[ci]=!0),s}subscribe(t){return new Mn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new Mn}allowRead(t){return t?.role.permission.super_user}allowUpdate(t){return t?.role.permission.super_user}allowCreate(t){return t?.role.permission.super_user}allowDelete(t){return t?.role.permission.super_user}getId(){return this[ze]}getContext(){return this[ke]}};Lr.prototype[ke]=null;(0,SW._assignPackageExport)("Resource",Lr);a(VSe,"snake_case");HT=class extends Error{static{a(this,"AccessError")}constructor(t){t?(super("Unauthorized access to resource"),this.statusCode=403):(super("Must login"),this.statusCode=401)}};a(pW,"pathToId");xT=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(es,"transactional");a(ts,"missingMethod");a(yw,"selectFromObject");a(kT,"transformForSelect")});var CN={};je(CN,{EVICTED:()=>ya,INVALIDATED:()=>Os,coerceType:()=>GT,makeTable:()=>VT,setServerUtilities:()=>ZSe,updateResource:()=>qT});function VT(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:l,schemaDefined:u,dbisDB:d,sealed:_,splitSegments:E,replicate:f}=e,{expirationMS:h,evictionMS:T,audit:m,trackDeletes:g}=e,{attributes:S}=e;S||(S=[]);let b=Jg(i,n,l),I,B,H={},X=Promise.resolve(),Y,V,ne;for(let U of S)(U.assignCreatedTime||U.name==="__createdtime__")&&(Y=U),(U.assignUpdatedTime||U.name==="__updatedtime__")&&(V=U),U.expiresAt&&(ne=U),U.isPrimaryKey&&(H=U);let Q,de=[],j=[],ae=1,Ae=2,ye={},Me={},Gr=864e5,wd,ka,wn,Cd=!1,Al,Uw=new Map,jE=new Map,vt,Fa,Ga=yd.get(Us.CONFIG_PARAMS.REPLICATION_DATABASES);if(Array.isArray(Ga)){for(let U of Ga)if(U.name===c&&U.replicateTo>=0){Fa=U.replicateTo;break}}let vs=i.getRange({start:!1,end:!1}).constructor,Bs=10,zE=6;m&&ie();class Ve extends Lr{static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=m;static databasePath=o;static databaseName=c;static attributes=S;static replicate=f;static sealed=_;static splitSegments=E??!0;static createdTimeProperty=Y;static updatedTimeProperty=V;static propertyResolvers;static userResolvers={};static sources=[];static get expirationMS(){return h}static dbisDB=d;static schemaDefined=u;static sourcedFrom(p,R){if(R&&(this.sourceOptions=R,(R.expiration||R.eviction||R.scanInterval)&&this.setTTLExpiration(R)),R?.intermediateSource)p.intermediateSource=!0,this.sources.unshift(p);else{if(this.sources.some(O=>!O.intermediateSource)){if(this.sources.some(O=>O.name===p.name))return;throw new Error("Can not have multiple canonical (non-intermediate) sources")}this.sources.push(p)}B=B||p.get&&(!p.get.reliesOnPrototype||p.prototype.get),I=I||p.load;let w=a(O=>{let v=this.sources;if(v=v.filter(k=>k.intermediateSource&&k[O]&&(!k[O].reliesOnPrototype||k.prototype[O])),v.length>0)if(v.length===1){let k=v[0];return(C,F,x)=>{if(C?.source!==k)return k[O](F,x,C)}}else return(k,C,F)=>{let x=[];for(let q of v){if(k?.source===q)break;x.push(q[O](C,F,k))}return Promise.all(x)}},"getApplyToIntermediateSource"),A=this.sources[this.sources.length-1];A.intermediateSource&&(A={});let y=a(O=>{if(A[O]&&(!A[O].reliesOnPrototype||A.prototype[O]))return(v,k,C)=>{if(!v?.source)return A[O](k,C,v)}},"getApplyToCanonicalSource");ye={put:y("put"),patch:y("patch"),delete:y("delete"),publish:y("publish")},Me={put:w("put"),patch:w("patch"),delete:w("delete"),publish:w("publish"),invalidate:w("invalidate")};let D=A.shouldRevalidateEvents;return(async()=>{let O=!1,v,k=a(async(C,F)=>{let x=C.value,q=C.table?We[c][C.table]:Ve;if(c===Us.SYSTEM_SCHEMA_NAME&&(C.table===Us.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||C.table===Us.SYSTEM_TABLE_NAMES.USER_TABLE_NAME)&&(O=!0),C.id===void 0&&(C.id=x[q.primaryKey],C.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(C));C.source=p;let ee={residencyId:tt(C.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:C.nodeId},G=await q.getResource(C.id,F,ee);switch(C.type){case"put":return D?G._writeInvalidate(ee):G._writeUpdate(x,!0,ee);case"patch":return D?G._writeInvalidate(ee):G._writeUpdate(x,!1,ee);case"delete":return G._writeDelete(ee);case"publish":return G._writePublish(x,ee);case"invalidate":return G._writeInvalidate(ee);case"relocate":return G._writeRelocate(ee);default:Ge.default.error?.("Unknown operation",C.type,C.id)}},"writeUpdate");try{let C=p.subscribe;C&&g==null&&(g=!0);let F={crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0},x=p.subscribeOnThisThread?p.subscribeOnThisThread((0,Tl.getWorkerIndex)(),F):(0,Tl.getWorkerIndex)()===0,q=C&&x&&await p.subscribe?.(F);if(q){let ee;for await(let G of q)try{if(!(G.type==="transaction"?G.writes[0]:G)){Ge.default.error?.("Bad subscription event",G);continue}if(G.source=p,G.type==="end_txn"){if(ee?.resolve(),G.localTime&&v!==G.localTime){if(G.remoteNodeIds?.length>0){let Re=[Symbol.for("seq"),G.remoteNodeIds[0]],re=d.get(Re),K=re?.nodes;K||(K=[]);for(let Be of G.remoteNodeIds.slice(1)){let Ie=K.find(ce=>ce.id===Be);K=K.filter(ce=>ce.id!==Be||ce===Ie),Ie||(Ie={id:Be,seqId:0},K.push(Ie)),Ie.seqId=Math.max(re?.seqId??1,G.localTime),Be===ee?.nodeId&&(Ie.lastTxnTime=G.timestamp)}let Te=Math.max(re?.seqId??1,G.localTime);Ge.default.trace?.("Received txn",c,Te,G.localTime,G.remoteNodeIds),d.put(Re,{seqId:Te,nodes:K})}v=G.localTime}G.onCommit&&ee?.committed.then(G.onCommit);continue}if(ee)if(G.beginTxn)ee.resolve();else{ee.write_promises.push(k(G,ee));continue}!G.timestamp&&G.version&&(G.timestamp=G.version);let Ee=Dt(G,()=>{if(G.type==="transaction"){let Re=[];for(let re of G.writes)try{Re.push(k(re,G))}catch(K){throw K.message+=" writing "+JSON.stringify(re)+" of event "+JSON.stringify(G),K}return Promise.all(Re)}else if(G.type==="define_schema"){let Re=this.attributes.slice(0),re;for(let K of G.attributes)Re.find(Te=>Te.name===K.name)||(Re.push(K),re=!0);re&&(Et({table:s,database:c,attributes:Re,origin:"cluster"}),GE.signalSchemaChange(new qE.SchemaEventMsg(process.pid,Us.OPERATIONS_ENUM.CREATE_TABLE,c,s)))}else return G.beginTxn?(ee=G,ee.write_promises=[k(G,G)],new Promise(Re=>{ee.resolve=()=>Re(Promise.all(ee.write_promises))})):k(G,G)});ee&&(ee.committed=Ee),O&&Ee&&!Ee?.waitingForUserChange&&(Ee.then(()=>GE.signalUserChange(new qE.UserEventMsg(process.pid))),Ee.waitingForUserChange=!0),G.onCommit&&(Ee?Ee.then(G.onCommit):G.onCommit())}catch(be){Ge.default.error?.("error in subscription handler",be)}}}catch(C){Ge.default.error?.(C)}})(),this}static get isCaching(){return B}static get shouldRevalidateEvents(){return this.prototype.get!==Ve.prototype.get}static getResource(p,R,w){let A=super.getResource(p,R,w);if(p!=null){ji(p);try{if(A.hasOwnProperty(ve))return A;if(typeof p=="object"&&p&&!Array.isArray(p))throw new Error(`Invalid id ${JSON.stringify(p)}`);let y=!w?.async||i.cache?.get?.(p),D=Ir(R),O=D.getReadTxn();if(O?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return $a(p,R,{transaction:O,ensureLoaded:w?.ensureLoaded},y,v=>{if(v?qT(A,v):A[ve]=null,R.onlyIfCached&&R.noCacheStore){if(!A.doesExist())throw new Nr.ServerError("Entry is not cached",504)}else if(w?.ensureLoaded){let k=Dd(p,v,R,A);if(k)return D?.disregardReadTxn(),A[bw]=!0,Nw(k,C=>(qT(A,C),A))}return A})}catch(y){throw y.message.includes("Unable to serialize object")&&(y.message+=": "+JSON.stringify(p)),y}}return A}ensureLoaded(){let p=Dd(this[ze],this[Fr],this[ke]);if(p)return this[bw]=!0,Nw(p,R=>{this[Fr]=R,this[ve]=R.value,this[kE]=R.version})}static getNewId(){let p=H?.type;if(p==="String"||p==="ID")return super.getNewId();if(!vt){let y=i.getEntry(Symbol.for("id_allocation")),D=y?.value,O;if(D&&D.nodeName===server.hostname&&(!tTe(i)||D.pid===process.pid)){let v=D.start,k=D.end;O=v;for(let C of i.getKeys({start:k,end:v,limit:1,reverse:!0}))O=C}else D=A(y?.version??null),O=D.start;vt=new BigInt64Array([BigInt(O)+1n]),vt=new BigInt64Array(i.getUserSharedBuffer("id",vt.buffer)),vt.maxSafeId=D.end}let R=Number(Atomics.add(vt,0,1n)),w=p==="Int"?512:1048576;if(R+w>=vt.maxSafeId){let y=a(D=>{vt.maxSafeId=R+(p==="Int"?1023:4194303);let O=(p==="Int"?Math.pow(2,31):Math.pow(2,49))-1,v=D?void 0:i.useReadTransaction(),k=Number(vt[0]);for(let x of i.getKeys({start:k+1,end:O,limit:1,transaction:v}))O=x;v?.done();let{value:C,version:F}=i.getEntry(Symbol.for("id_allocation"));if(vt.maxSafeId<O){if(C.end>vt.maxSafeId-100)return;Ge.default.info?.("New id allocation",R,vt.maxSafeId,F),i.put(Symbol.for("id_allocation"),{start:C.start,end:vt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),F)}else{Ge.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${vt.maxSafeId}, but id of ${O} detected`);let x=A(F);x.alreadyUpdated||Atomics.store(vt,0,BigInt(x.start+1)),vt.maxSafeId=x.end}},"updateEnd");R+w===vt.maxSafeId?setImmediate(y):R+100>=vt.maxSafeId&&(Ge.default.warn?.(`Synchronous id allocation required on table ${s}${p=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>y(!0)))}return R;function A(y){let D=(p==="Int"?Math.pow(2,31):Math.pow(2,49))-1,O=D/4,v,k,C=!1,F,x;do{F=Math.floor(Math.random()*D),x={start:F,end:F+(p==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},v=0;for(let q of i.getKeys({start:F,limit:1,reverse:!0}))v=q;k=D;for(let q of i.getKeys({start:F+1,end:D,limit:1}))k=q;O*=.875,O<1e3&&!C&&(C=!0,Ge.default.error?.(`Id allocation in table ${s} is very dense, limited safe range of numbers to allocate ids in${p==="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`,F,v,k,O))}while(!(O<k-F&&(O<F-v||v===0)));return i.transactionSync(()=>{let q=i.getEntry(Symbol.for("id_allocation"));return(q?.version??null)==y?(Ge.default.info?.("Allocated new id range",x),i.put(Symbol.for("id_allocation"),x,Date.now()),x):(Ge.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...q.value})})}}static setTTLExpiration(p){if(typeof p=="number")h=p*1e3,T||(T=0);else if(p&&typeof p=="object")h=p.expiration*1e3,T=(p.eviction||0)*1e3,Gr=p.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(h<0)throw new Error("Expiration can not be negative");Gr=Gr||(h+T)/4,ko()}static getResidencyRecord(p){return d.get([Symbol.for("residency_by_id"),p])}static setResidency(p){Ve.getResidency=p}static setResidencyById(p){Ve.getResidencyById=p}static getResidency(p,R,w){if(Ve.getResidencyById)return Ve.getResidencyById(p[t]);let A=Fa;if(R.replicateTo!=null){if(Array.isArray(R.replicateTo))return R.replicateTo.includes(server.hostname)?R.replicateTo:[server.hostname,...R.replicateTo];R.replicateTo>=0&&(A=R.replicateTo)}if(A>=0&&server.nodes){let y=[server.hostname];if(w)y.push(...w.slice(0,A));else{let D=server.nodes.map(k=>k.name),O=Math.floor(D.length*Math.random());y.push(...D.slice(O,O+A));let v=O+A-D.length;v>0&&y.push(...D.slice(0,v))}return y}}static enableAuditing(p=!0){m=p,p&&ie(),Ve.audit=p}static coerceId(p){return p===""?null:GT(p,H)}static async dropTable(){if(delete We[c][s],c===o){for(let p of S)d.remove(Ve.tableName+"/"+p.name),r[p.name]?.drop();d.remove(Ve.tableName+"/"),i.drop(),await d.committed}else console.log("legacy dropTable"),await i.close(),await fs.remove(data_path),await fs.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));GE.signalSchemaChange(new qE.SchemaEventMsg(process.pid,Us.OPERATIONS_ENUM.DROP_TABLE,c,s))}get(p){if(typeof p=="string")return this.getProperty(p);if(this[ci])return this.search(p);if(this[ze]===null){if(p?.conditions)return this.search(p);let R=Ve.getRecordCount();return{recordCount:R.recordCount,estimatedRecordRange:R.estimatedRange,records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:S}}if(p?.property)return this.getProperty(p.property);if(this.doesExist()||p?.ensureLoaded===!1||this[ke]?.returnNonexistent)return this}allowRead(p,R){let w=Va(p);if(w?.read){if(w.isSuperUser)return!0;let A=w.attribute_permissions,y=R?.select;if(A?.length>0||Cd&&y){if(R||(R={}),y){let D=A?.length>0&&Ow(A,"read");R.select=y.map(O=>{let v=O.name||O;if(!D||D[v]){let k=wn[v]?.definition?.tableClass;if(k){if(O.name||(O={name:O}),!k.prototype.allowRead.call(null,p,O))return!1;if(!O.select)return O.name}return O}}).filter(Boolean)}else R.select=A.filter(D=>D.read&&!wn[D.attribute_name]).map(D=>D.attribute_name);return R}else return!0}}allowUpdate(p,R){let w=Va(p);if(w?.update){let A=w.attribute_permissions;if(A?.length>0){let y=Ow(A,"update");for(let D in R)if(!y[D])return!1;for(let D of A){let O=D.attribute_name;!D.update&&!(O in R)&&(R[O]=this.getProperty(O))}}return Ka(this[ke])}}allowCreate(p,R){if(this[ci]){let w=Va(p);if(w?.insert){let A=w.attribute_permissions;if(A?.length>0){let y=Ow(A,"insert");for(let D in R)if(!y[D])return!1;return Ka(this[ke])}else return Ka(this[ke])}}else return this.allowUpdate(p,{})}allowDelete(p){return Va(p)?.delete&&Ka(this[ke])}update(p,R){if(!Ir(this[ke]))throw new Error("Can not update a table resource outside of a transaction");if(p===!1)return this;let A;return typeof p=="object"&&p&&(R?(Object.isFrozen(p)&&(p={...p}),this[ve]={},this[_r]=p):(A=this[_r],A&&(p=Object.assign(A,p)),this[_r]=A=p)),this._writeUpdate(this[_r],R),this}addTo(p,R){if(typeof R=="number"||typeof R=="bigint")this[xE]===RW?this.set(p,(+this.getProperty(p)||0)+R):(this[xE]||this.update(),this.set(p,new vT(R)));else throw new Error("Can not add a non-numeric value")}subtractFrom(p,R){if(typeof R=="number")return this.addTo(p,-R);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this[Fr]}invalidate(){this._writeInvalidate()}_writeInvalidate(p){let R=this[ke],w=this[ze];ji(w),Ir(this[ke]).addWrite({key:w,store:i,invalidated:!0,entry:this[Fr],before:ye.invalidate?.bind(this,R,w),beforeIntermediate:Me.invalidate?.bind(this,R,w),commit:a((y,D)=>{if(di(y,D,p?.nodeId)<=0)return;let O=null;for(let v in r)O||(O={}),O[v]=this.getProperty(v);Ge.default.trace?.(`Invalidating entry id: ${w}, timestamp: ${new Date(y).toISOString()}`),b(w,O,this[Fr],y,Os,m,{user:R?.user,residencyId:p?.residencyId,nodeId:p?.nodeId},"invalidate")},"commit")})}_writeRelocate(p){let R=this[ke],w=this[ze];ji(w),Ir(this[ke]).addWrite({key:w,store:i,invalidated:!0,entry:this[Fr],before:ye.relocate?.bind(this,R,w),beforeIntermediate:Me.relocate?.bind(this,R,w),commit:a((y,D)=>{if(di(y,D,p?.nodeId)<=0)return;let O=Ve.getResidencyRecord(p.residencyId),v=0,k=null,C=D?.value;if(O&&!O.includes(server.hostname)){for(let F in r)k||(k={}),k[F]=C(F);v=Os}else k=C;Ge.default.trace?.(`Relocating entry id: ${w}, timestamp: ${new Date(y).toISOString()}`),b(w,k,this[Fr],y,v,m,{user:R.user,residencyId:p.residencyId,nodeId:p.nodeId,expiresAt:p.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(p,R){let w={previousResidency:this.getResidencyRecord(p.residencyId),isRelocation:!0},A=this.getResidency(R.value,w),y;if(A){if(!Array.isArray(A))throw new Error("Residency must be an array, but was: "+A);if(!A.includes(server.hostname))return;y=tt(A)}let O=b(p.key,R.value,p,p.version,0,!0,{residencyId:y,expiresAt:R.expiresAt},"relocate",!1,null)}static evict(p,R,w){let A=this.Source,y;if(!((B||m)&&(!R||(y=i.getEntry(p),!y||!R)||y.version!==w))){if(B){if(i.hasLock(p,y.version))return;let D;for(let O in r)D||(D={}),D[O]=R[O];if(D)return b(p,D,y,w,ya,null,null,null,!0)}return i.ifVersion(p,w,()=>{qa(p,R,null)}),m?b(p,null,y,w,ya,null,null,null,!0):i.remove(p,w)}}lock(){throw new Error("Not yet implemented")}static operation(p,R){return p.table||=s,p.schema||=c,CW.operation(p,R)}put(p){this.update(p,!0)}patch(p){this.update(p,!1)}_writeUpdate(p,R,w){let A=this[ke],y=Ir(A),D=this[ze];ji(D);let O=this[Fr];this[xE]=R?RW:QSe;let v={key:D,store:i,entry:O,nodeName:A?.nodeName,validate:a(k=>{p||(p=this[_r]),R||p&&MT(this[_r]===p?this:p)?A?.source||(y.checkOverloaded(),this.validate(p,!R),V&&(p[V.name]=V.type==="Date"?new Date(k):V.type==="String"?new Date(k).toISOString():k),R&&(t&&p[t]!==D&&(p[t]=D),Y&&(O?.value?p[Y.name]=O?.value[Y.name]:p[Y.name]=Y.type==="Date"?new Date(k):Y.type==="String"?new Date(k).toISOString():k),p=ml(p))):y.removeWrite(v)},"validate"),before:R?ye.put?()=>ye.put(A,D,p):null:ye.patch?()=>ye.patch(A,D,p):ye.put?()=>ye.put(A,D,ml(this)):null,beforeIntermediate:R?Me.put?()=>Me.put(A,D,p):null:Me.patch?()=>Me.patch(A,D,p):Me.put?()=>Me.put(A,D,ml(this)):null,commit:a((k,C,F)=>{if(F){if(A&&C?.version>(A.lastModified||0)&&(A.lastModified=C.version),this[Fr]=C,C?.value?.[ve])throw new Error("Can not assign a record to a record, check for circular references");R||(this[ve]=C?.value??null)}this[_r]=void 0,this[kE]=k;let x=C?.value,q=p;this[xE]=0;let ee=di(k,C,w?.nodeId),G;if(ee<=0)if(m){let K=C.localTime,Te=C.version;Ge.default.trace?.("Applying CRDT update to record with id: ",D,"applying later update:",Te);let Be=[];for(;K>k||Te>=k&&K>0;){let Ie=l.get(K);if(!Ie)break;let ce=Ht(Ie);if(Te=ce.version,Te>=k){if(Te===k){if(ee=di(k,{version:Te,localTime:K},w?.nodeId),ee===0)return;if(ee>0)continue}if(ce.type==="patch")Be.push(ce),G=p;else if(ce.type==="put"||ce.type==="delete")return}K=ce.previousLocalTime}Be.sort((Ie,ce)=>Ie.version-ce.version);for(let Ie of Be){let ce=Ie.getValue(i);if(q=PT(q,ce,R),Ge.default.debug?.("Rebuilding update with future patch:",q),!q)return}}else{if(R)return;q=PT(q,x,R),Ge.default.debug?.("Rebuilding update without audit:",q)}let be;if(R?be=q:(this[ve]=x,be=ml(this,q)),this[ve]=be,be?.[ve])throw new Error("Can not assign a record to a record, check for circular references");let Ee;if(w?.residencyId!=null)Ee=w.residencyId;else{O?.residencyId&&(A.previousResidency=Ve.getResidencyRecord(O.residencyId));let K=Ve.getResidency(be,A);if(K){if(!Array.isArray(K))throw new Error("Residency must be an array, got: "+K);K.includes(server.hostname)||K.push(server.hostname)}Ee=tt(K)}R||(G=p);let Re=A?.expiresAt??(h?h+Date.now():-1);Ge.default.trace?.(`Saving record with id: ${D}, timestamp: ${new Date(k).toISOString()}${Re?", expires at: "+new Date(Re).toISOString():""}${C?", replaces entry from: "+new Date(C.version).toISOString():", new entry"}`,be),qa(D,x,be);let re=R?"put":"patch";b(D,be,C,k,0,m,{user:A?.user,residencyId:Ee,expiresAt:Re,nodeId:w?.nodeId,originatingOperation:A?.originatingOperation},re,!1,G),A.expiresAt&&ko()},"commit")};y.addWrite(v)}async delete(p){if(typeof p=="string")return this.deleteProperty(p);if(this[ci]){for await(let R of this.search(p))(await Ve.getResource(R[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(p);return}return this[ve]?this._writeDelete(p):!1}_writeDelete(p){let R=Ir(this[ke]),w=this[ze];ji(w);let A=this[ke];return R.addWrite({key:w,store:i,resource:this,nodeName:A?.nodeName,before:ye.delete?.bind(this,A,w),beforeIntermediate:Me.delete?.bind(this,A,w),commit:a((y,D,O)=>{let v=D?.value;O&&(A&&D?.version>(A.lastModified||0)&&(A.lastModified=D.version),qT(this,D)),!(di(y,D,p?.nodeId)<=0)&&(qa(this[ze],v),Ge.default.trace?.(`Deleting record with id: ${w}, txn timestamp: ${new Date(y).toISOString()}`),m||g?(b(w,null,this[Fr],y,0,m,{user:A?.user,nodeId:p?.nodeId},"delete"),m||ko()):i.remove(this[ze]))},"commit")}),!0}search(p){let R=this[ke],w=Ir(R);if(!p)throw new Error("No query provided");let A=p.conditions;A?A.length===void 0&&(A=A[Symbol.iterator]?Array.from(A):[A]):A=Array.isArray(p)?p:p[Symbol.iterator]?Array.from(p):[],this[ze]&&(A=[{attribute:null,comparator:Array.isArray(this[ze])?"prefix":"starts_with",value:this[ze]}].concat(A));let y,D={};function O(K,Te){let Be;switch(Te){case"and":case void 0:if(K.length<1)throw new Error('An "and" operator requires at least one condition');Be=!0;break;case"or":if(K.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+Te)}for(let Ie of K){if(Ie.conditions){Ie.conditions=O(Ie.conditions,Ie.operator);continue}let ce=Ie[0]??Ie.attribute,Ye=ce==null?H:vi(S,ce);if(Ye)(Ye.type||tN[Ie.comparator])&&(Ie[1]===void 0?Ie.value=k(Ie.value,Ye):Ie[1]=k(Ie[1],Ye));else if(ce!=null)throw(0,Nr.handleHDBError)(new Error,`${ce} is not a defined attribute`,404);if(Ie.chainedConditions)if(Ie.chainedConditions.length===1&&(!Ie.operator||Ie.operator=="and")){let rt=Ie.chainedConditions[0],Ze,st;if(rt.comparator==="gt"||rt.comparator==="greater_than"||rt.comparator==="ge"||rt.comparator==="greater_than_equal"?(Ze=Ie,st=rt):(Ze=rt,st=Ie),Ze.comparator!=="lt"&&Ze.comparator!=="less_than"&&Ze.comparator!=="le"&&Ze.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let Kt=st.comparator==="ge"||st.comparator==="greater_than_equal",Fo=Ze.comparator==="le"||Ze.comparator==="less_than_equal";Ie.comparator=(Kt?"ge":"gt")+(Fo?"le":"lt"),Ie.value=[st.value,Ze.value]}else throw new Error("Multiple chained conditions are not currently supported")}return K}a(O,"prepareConditions");function v(K,Te){if(p.enforceExecutionOrder)return K;for(let Be of K)Be.conditions&&(Be.conditions=v(Be.conditions,Be.operator));return K.length>1&&Te!=="or"?(0,IW.sortBy)(K,lS(Ve)):K}a(v,"orderConditions");function k(K,Te){return Array.isArray(K)?K.map(Be=>GT(Be,Te)):GT(K,Te)}a(k,"coerceTypedValues");let C=p.operator;(A.length>0||C)&&(A=O(A,C));let F=typeof p.sort=="object"&&p.sort,x;if(F&&C!=="or"){let K=F.attribute;if(K==null)throw new Nr.ClientError("Sort requires an attribute");if(y=A.find(Te=>Qu(Te.attribute)===Qu(K)),!y){let Te=vi(S,K);if(!Te)throw(0,Nr.handleHDBError)(new Error,`${Array.isArray(K)?K.join("."):K} is not a defined attribute`,404);if(Te.indexed)y={attribute:K,comparator:"sort"},A.push(y);else if(A.length===0&&!p.allowFullScan)throw(0,Nr.handleHDBError)(new Error,`${Array.isArray(K)?K.join("."):K} is not indexed and not combined with any other conditions`,404)}y&&(y.descending=!!F.descending)}A=v(A,C),F&&(y&&A[0]===y?F.next&&(x={dbOrderedAttribute:F.attribute,attribute:F.next.attribute,descending:F.next.descending,next:F.next.next}):(y&&A.splice(A.indexOf(y),1),x=F));let q=p.select;if(A.length===0&&(A=[{attribute:t,comparator:"greater_than",value:!0}]),p.explain)return{conditions:A,operator:C,postOrdering:x,selectApplied:!!q};let ee=w.useReadTxn(),G=rN(A,C,Ve,ee,p,R,(K,Te)=>Pd(K,q,R,ee,Te),D),be=p.ensureLoaded!==!1;x||(G=re(G));let Ee=Ve.transformEntryForSelect(q,R,ee,D,be,!0),Re=Ve.transformToOrderedSelect(G,q,x,ee,R,Ee);function re(K){return p.offset||p.limit!==void 0?K.slice(p.offset,p.limit!==void 0?(p.offset||0)+p.limit:void 0):K}return a(re,"applyOffset"),x&&(Re=re(Re)),Re.onDone=()=>{Re.onDone=null,w.doneReadTxn()},Re.selectApplied=!0,Re.getColumns=()=>{if(q){let K=[];for(let Te of q)Te==="*"?K.push(...S.map(Be=>Be.name)):K.push(Te.name||Te);return K}return S.filter(K=>!K.computed&&!K.relationship).map(K=>K.name)},Re}static transformToOrderedSelect(p,R,w,A,y,D){let O=new vs;if(w){p=Pd(p,R,A,y,null);let v;O.iterate=function(){let C,F=p[Symbol.asyncIterator]?p[Symbol.asyncIterator]():p[Symbol.iterator](),x,q=w.dbOrderedAttribute,ee,G,be=!0;function Ee(re){let K=re.next&&Ee(re.next),Te=re.descending;return(Be,Ie)=>{let ce=yl(Be,re.attribute,A),Ye=yl(Ie,re.attribute,A),rt=Te?(0,gl.compareKeys)(Ye,ce):(0,gl.compareKeys)(ce,Ye);return rt===0?K?.(Be,Ie)||0:rt}}a(Ee,"createComparator");let Re=Ee(w);return{async next(){let re;if(C)if(re=C.next(),re.done){if(x)return O.onDone&&O.onDone(),re}else return{value:await D.call(this,re.value)};v=[],ee&&v.push(ee);do if(re=await F.next(),re.done){if(x=!0,v.length)break;return O.onDone&&O.onDone(),re}else{let K=re.value;if(K?.then&&(K=await K),q){let Te=yl(K,q,A);if(be)be=!1,G=Te;else if(Te!==G){G=Te,ee=K;break}}v.push(K)}while(!0);return w.isGrouped,v.sort(Re),C=v[Symbol.iterator](),re=C.next(),re.done?(O.onDone&&O.onDone(),re):{value:await D.call(this,re.value)}},return(){O.onDone&&O.onDone(),F.return()},throw(){O.onDone&&O.onDone(),F.throw()}}};let k=a(C=>{if(typeof R=="object"&&Array.isArray(C.attribute))for(let F=0;F<R.length;F++){let x=R[F],q;if(x.name===C.attribute[0]){for(q=x.sort||(x.sort={});q.next;)q=q.next;q.attribute=C.attribute.slice(1),q.descending=C.descending}else x===C.attribute[0]&&(R[F]=q={name:x,sort:{attribute:C.attribute.slice(1),descending:C.descending}})}C.next&&k(C.next)},"applySortingOnSelect");k(w)}else O.iterate=(p[Symbol.asyncIterator]||p[Symbol.iterator]).bind(p),O=O.map(function(v){try{let k=D.call(this,v);return typeof k?.catch=="function"?k.catch(C=>{throw C.partialObject={[t]:v.key},C}):k}catch(k){throw k.partialObject={[t]:v.key},k}});return O}static transformEntryForSelect(p,R,w,A,y,D){if(p&&(p===t||p?.length===1&&p[0]===t&&Array.isArray(p))){let C=a(F=>(R?.transaction?.stale&&(R.transaction.stale=!1),F?.key??F),"transform");return p===t?C:p.asArray?F=>[C(F)]:F=>({[t]:C(F)})}let O;y&&B&&!(typeof p=="string"?[p]:p)?.every(C=>{let F;return typeof C=="object"?F=C.name:F=C,r[F]||F===t})&&(O=!0);let v,k=a(function(C){let F;if(R?.transaction?.stale&&(R.transaction.stale=!1),C!=null){if(F=C.value||C.deref?.()?.value,!F&&(C.key===void 0||C.deref)||C.metadataFlags&Os){if(C.metadataFlags&Os&&R.replicateFrom===!1&&D&&C.residencyId)return Ba.SKIP;if(C=$a(C.key??C,R,{transaction:w,lazy:p?.length<4,ensureLoaded:y},this?.isSync,x=>x),C?.then)return C.then(k.bind(this));F=C?.value}if(O&&C?.metadataFlags&(Os|ya)||C?.expiresAt!=null&&C?.expiresAt<Date.now()){if(R.onlyIfCached&&R.noCacheStore)return{[t]:C.key,message:"This entry has expired"};let x=Dd(C.key??C,C,R);if(x?.then)return x.then(k)}}if(F==null)return D?Ba.SKIP:F;if(p&&!(p[0]==="*"&&p.length===1)){let x,q=a((G,be)=>{let Ee;typeof G=="object"?Ee=G.name:Ee=G;let Re=wn?.[Ee],re;if(Re){let K=A?.[Ee];if(K)if(K.hasMappings){let Be=Re.from?F[Re.from]:Qu(C.key);re=K.get(Be),re||(re=[])}else re=K.fromRecord?.(F);else re=Re(F,R,C);let Te=a(Be=>{if(Be&&typeof Be=="object"){let Ie=Re.definition?.tableClass||Ve;v||(v={});let ce=v[Ee]||(v[Ee]=Ie.transformEntryForSelect(Ee===G?null:G.select||(Array.isArray(G)?G:null),R,w,K,y));if(Array.isArray(Be)){let Ye=[],rt=Ie.transformToOrderedSelect(Be,G.select,typeof G.sort=="object"&&G.sort,R,w,ce)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),Ze=a(Kt=>{for(;!Kt.done;){if(Kt?.then)return Kt.then(Ze);Ye.push(Kt.value),Kt=rt.next()}be(Ye,Ee)},"nextValue"),st=Ze(rt.next());st&&(x||(x=[]),x.push(st));return}else if(Be=ce.call(this,Be),Be?.then){x||(x=[]),x.push(Be.then(Ye=>be(Ye,Ee)));return}}be(Be,Ee)},"handleResolvedValue");re?.then?(x||(x=[]),x.push(re.then(Te))):Te(re);return}else re=F[Ee],re&&typeof re=="object"&&Ee!==G&&(re=Ve.transformEntryForSelect(G.select||G,R,w,null)({value:re}));be(re,Ee)},"selectAttribute"),ee;if(typeof p=="string")q(p,G=>{ee=G});else if(Array.isArray(p))if(p.asArray)ee=[],p.forEach((G,be)=>{G==="*"?p[be]=F:q(G,Ee=>ee[be]=Ee)});else{ee={};let G=p.forceNulls;for(let be of p)if(be==="*")for(let Ee in F)ee[Ee]=F[Ee];else q(be,(Ee,Re)=>{Ee===void 0&&G&&(Ee=null),ee[Re]=Ee})}else throw new Nr.ClientError("Invalid select"+p);return x?Promise.all(x).then(()=>ee):ee}return F},"transform");return k}async subscribe(p){if(!l)throw new Error("Can not subscribe to a table without an audit log");m||Et({table:s,database:c,schemaDefined:u,attributes:S,audit:!0}),p||(p={});let R=!p.rawEvents,w=[],A=this,y=py(Ve,this[ze]??null,function(O,v,k,C){try{let F=v.getValue?.(i,R),x=v.type;if(!F&&x==="patch"&&R){let ee=i.getEntry(O);ee?.version===v.version?F=ee.value:F=v.getValue?.(i,!0,k),x="put"}let q={id:O,localTime:k,value:F,version:v.version,type:x,beginTxn:C};w?w.push(q):this.send(q)}catch(F){Ge.default.error?.(F)}},p.startTime||0,p),D=(async()=>{this[ci]&&(y.includeDescendants=!0,p.onlyChildren&&(y.onlyChildren=!0)),p.supportsTransactions&&(y.supportsTransactions=!0);let O=this[ze],v=p.previousCount;v>1e3&&(v=1e3);let k=p.startTime;if(this[ci]){if(k){if(v)throw new Nr.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:C,value:F}of l.getRange({start:k,exclusiveStart:!0,snapshot:!1})){let x=Ht(F);if(x.tableId!==n)continue;let q=x.recordId;if(O==null||OW(O,q)){let ee=x.getValue(i,R,C);if(y.send({id:q,localTime:C,value:ee,version:x.version,type:x.type}),y.queue?.length>yW&&await y.waitForDrain()===!1)return}y.startTime=C}}else if(v){let C=[];for(let{key:F,value:x}of l.getRange({start:"z",end:!1,reverse:!0}))try{let q=Ht(x);if(q.tableId!==n)continue;let ee=q.recordId;if(O==null||OW(O,ee)){let G=q.getValue(i,R,F);if(C.push({id:ee,localTime:F,value:G,version:q.version,type:q.type}),--v<=0)break}}catch(q){Ge.default.error("Error getting history entry",F,q)}for(let F=C.length;F>0;)y.send(C[--F]);C[0]&&(y.startTime=C[0].localTime)}else if(!p.omitCurrent){for(let{key:C,value:F,version:x,localTime:q}of i.getRange({start:O??!1,end:O==null?void 0:[O,gl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(F&&(y.send({id:C,localTime:q,value:F,version:x,type:"put"}),y.queue?.length>yW&&await y.waitForDrain()===!1))return}}else{v&&!k&&(k=0);let C=this[Fr]?.localTime;if(C===Qg&&(i.cache?.delete(O),this[Fr]=i.getEntry(O),Ge.default.trace?.("re-retrieved record",C,this[Fr]?.localTime),C=this[Fr]?.localTime),Ge.default.trace?.("Subscription from",k,"from",O,C),k<C){let F=[],x=C;do{let q=l.get(x);if(q){p.omitCurrent=!0;let ee=Ht(q),G=ee.getValue(i,R,x);R&&(ee.type="put"),F.push({id:O,value:G,localTime:x,...ee}),x=ee.previousLocalTime}else break;v&&v--}while(x>k&&v!==0);for(let q=F.length;q>0;)y.send(F[--q]);y.startTime=C}!p.omitCurrent&&this.doesExist()&&y.send({id:O,localTime:C,value:this[ve],version:this[kE],type:"put"})}for(let C of w)y.send(C);w=null})();return p.listener&&y.on("data",p.listener),y}static subscribeOnThisThread(p,R){return p===0||R?.crossThreads===!1}doesExist(){return!!(this[ve]||this[xE])}publish(p,R){this._writePublish(p,R)}_writePublish(p,R){let w=Ir(this[ke]),A=this[ze]||null;A!=null&&ji(A);let y=this[ke];w.addWrite({key:A,store:i,entry:this[Fr],nodeName:y?.nodeName,validate:a(()=>{y?.source||(w.checkOverloaded(),this.validate(p))},"validate"),before:ye.publish?.bind(this,y,A,p),beforeIntermediate:Me.publish?.bind(this,y,A,p),commit:a((D,O,v)=>{O===void 0&&g&&!m&&ko(),Ge.default.trace?.(`Publishing message to id: ${A}, timestamp: ${new Date(D).toISOString()}`),b(A,O?.value??null,O,O?.version||D,0,!0,{user:y?.user,residencyId:R?.residencyId,expiresAt:y?.expiresAt,nodeId:R?.nodeId},"message",!1,p)},"commit")})}validate(p,R){let w,A=a((y,D,O)=>{if(D.type&&y!=null)if(R&&y.__op__&&(y=y.value),D.properties){typeof y!="object"&&(w||(w=[])).push(`Value ${li(y)} in property ${O} must be an object${D.type?" ("+D.type+")":""}`);let v=D.properties;for(let k=0,C=v.length;k<C;k++){let F=v[k],x=A(y[F.name],F,O+"."+F.name);x&&(y[F.name]=x)}if(D.sealed&&y!=null&&typeof y=="object")for(let k in y)v.find(C=>C.name===k)||(w||(w=[])).push(`Property ${k} is not allowed within object in property ${O}`)}else switch(D.type){case"Int":(typeof y!="number"||y>>0!==y)&&(w||(w=[])).push(`Value ${li(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))&&(w||(w=[])).push(`Value ${li(y)} in property ${O} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof y!="number"&&(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a number`);break;case"ID":typeof y=="string"||y?.length>0&&y.every?.(v=>typeof v=="string")||(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a string, or an array of strings`);break;case"String":typeof y!="string"&&(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a string`);break;case"Boolean":typeof y!="boolean"&&(w||(w=[])).push(`Value ${li(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);(w||(w=[])).push(`Value ${li(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);(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a bigint`)}break;case"Bytes":y instanceof Uint8Array||(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a Buffer or Uint8Array`);break;case"array":if(Array.isArray(y)){if(D.elements)for(let v=0,k=y.length;v<k;v++){let C=y[v],F=A(C,D.elements,O+"[*]");F&&(y[v]=F)}}else(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a Buffer or Uint8Array`);break}D.nullable===!1&&y==null&&(w||(w=[])).push(`Property ${O} is required (and not does not allow null values)`)},"validateValue");for(let y=0,D=S.length;y<D;y++){let O=S[y];if(!(O.relationship||O.computed)&&(!R||O.name in p)){let v=A(p[O.name],O,O.name);v&&(p[O.name]=v)}}if(_)for(let y in p)S.find(D=>D.name===y)||(w||(w=[])).push(`Property ${y} is not allowed`);if(w)throw new Nr.ClientError(w.join(". "))}getUpdatedTime(){return this[kE]}wasLoadedFromSource(){return B?!!this[bw]:void 0}static async addAttributes(p){let R=S.slice(0);for(let w of p){if(!w.name)throw new Nr.ClientError("Attribute name is required");if(w.name.match(/[`/]/))throw new Nr.ClientError("Attribute names cannot include backticks or forward slashes");(0,wW.validateAttribute)(w.name),R.push(w)}return Et({table:s,database:c,schemaDefined:u,attributes:R}),Ve.indexingOperation}static async removeAttributes(p){let R=S.filter(w=>!p.includes(w.name));return Et({table:s,database:c,schemaDefined:u,attributes:R}),Ve.indexingOperation}static getSize(p){let R=i.getStats();return(R.treeBranchPageCount+R.treeLeafPageCount+R.overflowPages)*R.pageSize}static getRecordCount(p){let R=i.getStats().entryCount,w=1e3/2,A=performance.now(),y=Math.floor(R/2),D=p?.exactCount,O=0,v=0,k;for(let{value:C}of i.getRange({start:!0,lazy:!0}))if(C!=null&&O++,v++,!D&&v<y&&performance.now()-A>w){k=v;break}if(k){let C=O;O=0;for(let{value:re}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:k}))re!=null&&O++;let F=k*2,x=(O+C)/F,q=Math.pow((O-C+1)/k/2,2)+x*(1-x)/F,ee=Math.max(Math.sqrt(q)*R,1),G=Math.round(x*R),be=Math.max(G-1.96*ee,O+C),Ee=Math.min(G+1.96*ee,R),Re=Math.pow(10,Math.round(Math.log10(ee)));return Re>G&&(Re=Re/10),O=Math.round(G/Re)*Re,{recordCount:O,estimatedRange:[Math.round(be),Math.round(Ee)]}}return{recordCount:O}}static updatedAttributes(){wn=this.propertyResolvers={$id:a((p,R,w)=>({value:w.key}),"$id"),$updatedtime:a((p,R,w)=>w.version,"$updatedtime"),$record:a((p,R,w)=>w?{value:p}:p,"$record")};for(let p of this.attributes){p.resolve=null;let R=p.relationship,w=p.computed;if(R)if(p.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),w&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),Cd=!0,R.to)p.elements?.definition?(wn[p.name]=p.resolve=(A,y,D)=>{let O=A[R.from?R.from:t],v=p.elements.definition.tableClass;return D?zu({attribute:R.to,value:O},Ir(y).getReadTxn(),!1,v,!1).asArray:v.search([{attribute:R.to,value:O}],y).asArray},p.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},p.resolve.definition=p.elements.definition,R.from&&(p.resolve.from=R.from)):console.error(`The one-to-many/many-to-many relationship property "${p.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(R.from){let A=p.definition||p.elements?.definition;A?(wn[p.name]=p.resolve=(y,D,O)=>{let v=y[R.from];if(v!==void 0){if(p.elements){let k,C=v?.map(F=>{let x=O?A.tableClass.primaryStore.getEntry(F,{transaction:Ir(D).getReadTxn()}):A.tableClass.get(F,D);return x?.then&&(k=!0),x});return R.filterMissing?k?Promise.all(C).then(F=>F.filter(NW)):C.filter(NW):k?Promise.all(C):C}return O?A.tableClass.primaryStore.getEntry(v,{transaction:Ir(D).getReadTxn()}):A.tableClass.get(v,D)}},p.set=(y,D)=>{if(Array.isArray(D)){let O=D.map(v=>v[ze]||v[A.tableClass.primaryKey]);y[R.from]=O}else{let O=D[ze]||D[A.tableClass.primaryKey];y[R.from]=O}},p.resolve.definition=p.definition||p.elements?.definition,p.resolve.from=R.from):console.error(`The relationship property "${p.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${p.name}" in table "${s}" must use either "from" or "to" arguments`);else w&&(typeof w.from=="function"&&this.setComputedAttribute(p.name,w.from),wn[p.name]=p.resolve=(A,y,D)=>{let O=typeof w.from=="string"?A[w.from]:A,v=this.userResolvers[p.name];if(v)return v(O,y,D);Ge.default.warn(`Computed attribute "${p.name}" does not have a function assigned to it. Please use setComputedAttribute('${p.name}', resolver) to assign a resolver function.`),this.userResolvers[p.name]=()=>{}})}BT(this,this)}static setComputedAttribute(p,R){let w=vi(S,p);if(!w){console.error(`The attribute "${p}" does not exist in the table "${s}"`);return}if(!w.computed){console.error(`The attribute "${p}" is not defined as computed in the table "${s}"`);return}this.userResolvers[p]=R}static async deleteHistory(p=0,R=!1){let w;for(let{key:A,value:y}of l.getRange({start:0,end:p}))await Ad(),Ht(y).tableId===n&&(w=wT(l,A,y));if(R)for(let{key:A,value:y,localTime:D}of i.getRange({start:0,versions:!0}))await Ad(),y===null&&D<p&&(w=i.remove(A));await w}static async*getHistory(p=0,R=1/0){for(let{key:w,value:A}of l.getRange({start:p||1,end:R})){await Ad();let y=Ht(A);y.tableId===n&&(yield{id:y.recordId,localTime:w,version:y.version,type:y.type,value:y.getValue(i,!0,w),user:y.user,operation:y.originatingOperation})}}static async getHistoryOfRecord(p){let R=[];if(p==null)throw new Error("An id is required");let w=i.getEntry(p);if(!w)return R;let A=w.localTime;if(!A)throw new Error("The entry does not have a local audit time");let y=0;do{await Ad();let D=l.get(A);if(D){let O=Ht(D);R.push({id:O.recordId,localTime:A,version:O.version,type:O.type,value:O.getValue(i,!0,A),user:O.user}),A=O.previousLocalTime}else break}while(y<1e3&&A);return R.reverse()}static cleanup(){Q?.remove()}}Ve.updatedAttributes();let ss=Ve.prototype;return ss[zSe]=!0,h&&Ve.setTTLExpiration(h/1e3),ne&&Se(),Ve;function qa(U,p,R){let w;for(let A in r){let y=r[A],D=y.isIndexing,O=wn[A],v=R&&(O?O(R):R[A]),k=p&&(O?O(p):p[A]);if(v===k&&!D)continue;w=!0;let C=y.indexNulls,F=(0,FE.getIndexedValues)(v,C),x=(0,FE.getIndexedValues)(k,C);if(x?.length>0){let q=new Set(x);if(F=F?F.filter(ee=>{if(q.has(ee))q.delete(ee);else return!0}):[],x=Array.from(q),(x.length>0||F.length>0)&&gW){let ee=x.concat(F).map(G=>({key:G,value:U}));y.prefetch(ee,bW)}for(let ee=0,G=x.length;ee<G;ee++)y.remove(x[ee],U)}else F?.length>0&&gW&&y.prefetch(F.map(q=>({key:q,value:U})),bW);if(F)for(let q=0,ee=F.length;q<ee;q++)y.put(F[q],U)}return w}a(qa,"updateIndices");function ji(U){switch(typeof U){case"number":return!0;case"string":if(U.length<659)return!0;if(U.length>AW)throw new Error("Primary key size is too large: "+U.length);break;case"object":if(U===null)throw new Error("Invalid primary key of null");break;case"bigint":if(U<2n**64n&&U>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof U)}if((0,gl.writeKey)(U,JSe,0)>AW)throw new Error("Primary key size is too large: "+U.length);return!0}a(ji,"checkValidId");function $a(U,p,R,w,A){if(Ve.getResidencyById&&R.ensureLoaded&&p?.replicateFrom!==!1){let D=Ve.getResidencyById(U);if(D&&!D.includes(server.hostname)&&I)return I({key:U,residency:D}).then(A)}let y=a(()=>{if(p?.transaction?.stale&&(p.transaction.stale=!1),R.transaction?.isDone)return A(null,U);let D=i.getEntry(U,R);return D?.residencyId&&D.metadataFlags&Os&&I&&R.ensureLoaded&&p?.replicateFrom!==!1?I(D).then(O=>A(O,U)):(D&&p&&(D?.version>(p.lastModified||0)&&(p.lastModified=D.version),D?.localTime&&!p.lastRefreshed&&(p.lastRefreshed=D.localTime)),A(D,U))},"whenPrefetched");return w?y():ae>0?(ae--,y()):new Promise((D,O)=>{ae===0?(ae--,i.prefetch([U],()=>{v(),k()})):(de.push(U),j.push(k),de.length>zE&&(ae--,v()));function v(){if(de.length>0){let C=j;i.prefetch(de,()=>{ae===-1?v():ae++;for(let F of C)F()}),de=[],j=[],Ae>2&&Ae--}else ae=Ae,Ae<Bs&&Ae++}a(v,"prefetch");function k(){try{D(y())}catch(C){O(C)}}a(k,"load")})}a($a,"loadLocalRecord");function Va(U){if(!U?.role)return;let p=U.role.permission;if(p.super_user)return XSe;let R=p[c],w,A=R?.tables;if(A)return A[s];if(c==="data"&&(w=p[s])&&!w.tables)return w}a(Va,"getTablePermissions");function Dd(U,p,R,w){if(B){let A=!1;if(R.noCache?A=!0:(p?(!p.value||p.metadataFlags&(Os|ya)||p.expiresAt!=null&&p.expiresAt<Date.now())&&(A=!0):A=!0,qn(!A,"cache-hit",s)),A){let y=Ld(U,p,R).then(D=>(D?.value?.[ve]&&Ge.default.error?.("Can not assign a record with a record property"),R&&(D?.version>(R.lastModified||0)&&(R.lastModified=D.version),R.lastRefreshed=Date.now()),D));if(R?.onlyIfCached||p?.value&&w?.allowStaleWhileRevalidate?.(p,U)){if(y.catch(D=>Ge.default.warn?.(D)),R?.onlyIfCached&&!w.doesExist())throw new Nr.ServerError("Entry is not cached",504);return}else return y}}else if(p?.value&&p.expiresAt!=null&&p.expiresAt<Date.now())return Ve.evict(p.key,p.value,p.version),p.value=null,{then(A){return A(p)}}}a(Dd,"ensureLoadedFromSource");function Ir(U){let p=U?.transaction;if(p){if(!p.lmdbDb)return p.lmdbDb=i,p;do{if(p.lmdbDb?.path===i.path)return p;let R=p.next;if(!R)return p=p.next=new pc,p.lmdbDb=i,p;p=R}while(!0)}else return new cp}a(Ir,"txnForContext");function yl(U,p,R){if(!U)return;let w=U.value||i.getEntry(U.key)?.value;if(typeof p=="object"){let y=wn,D=w;for(let O=0,v=p.length;O<v;O++){let k=p[O],C=y?.[k];D=C&&D?C(D,R,!0)?.value:D?.[k],y=C?.definition?.tableClass?.propertyResolvers}return D}let A=wn[p];return A?A(w,R):w[p]}a(yl,"getAttributeValue");function Pd(U,p,R,w,A){let y=A?.length,D={transaction:w,lazy:y>0||typeof p=="string"||p?.length<4,alwaysPrefetch:!0},O;function v(k,C){let F=k?.value;if(!F)return Ba.SKIP;for(let x=0;x<y;x++)if(!O?.includes(x)&&!A[x](F,k))return Ba.SKIP;return C!==void 0&&(k.key=C),k}if(a(v,"processEntry"),y>0||!U.hasEntries){let k=U.map(C=>{if(O=null,typeof C=="object"&&C?.key!==void 0)return y>0?v(C):C;if(C==null)return Ba.SKIP;for(let F=0;F<y;F++){let q=A[F].idFilter;if(q){if(!q(C))return Ba.SKIP;O||(O=[]),O.push(F)}}return $a(C,R,D,!1,v)});return Array.isArray(U)&&(k=k.filter(C=>C!==Ba.SKIP)),k.hasEntries=!0,k}return U}a(Pd,"transformToEntries");function di(U,p,R=server.replication?.getThisNodeId(l)){if(U<=p?.version){if(p?.version===U&&R!==void 0){let w=server.replication?.exportIdMapping(l),A=p.localTime,y=A&&l.get(A);if(y){let D,O,v=Ht(y);for(let k in w)w[k]===R&&(D=k),w[k]===v.nodeId&&(O=k);if(D>O)return 1;if(D===O)return 0}}return-1}return 1}a(di,"precedesExistingVersion");async function Ld(U,p,R){let w=p?.metadataFlags,A=p?.version,y,D;if(!i.attemptLock(U,A,()=>{clearTimeout(D);let C=i.getEntry(U);!C||!C.value||C.metadataFlags&(Os|ya)?y(Ld(U,i.getEntry(U),R)):y(C)}))return new Promise(C=>{y=C,D=setTimeout(()=>{i.unlock(U,A)},jSe)});let O=p?.value,v={requestContext:R,replacingRecord:O,replacingEntry:p,replacingVersion:A,noCacheStore:!1,source:null,resourceCache:R?.resourceCache},k=R?.responseHeaders;return new Promise((C,F)=>{let x;Nw(Dt(v,async q=>{let ee=performance.now(),G,be,Ee;try{for(let Te of Ve.sources)if(Te.get&&(!Te.get.reliesOnPrototype||Te.prototype.get)){if(Te.available?.(p)===!1)continue;if(v.source=Te,G=await Te.get(U,v),G)break}Ee=w&Os;let re=v.lastModified||Ee&&A;be=Ee||re>A||!O,re||(re=(0,FE.getNextMonotonicTime)());let K=performance.now()-ee;if(pr(K,"cache-resolution",s,null,"success"),k&&vm(k,"Server-Timing",`cache-resolve;dur=${K.toFixed(2)}`,!0),q.timestamp=re,h&&v.expiresAt==null&&(v.expiresAt=Date.now()+h),G){if(typeof G!="object")throw new Error("Only objects can be cached and stored in tables");if(G.status>0&&G.headers)if(G.status>=300)if(G.status===304)G=O,re=A;else throw new Nr.ServerError(G.body||"Error from source",G.status);else G=G.body;typeof G.toJSON=="function"&&(G=G.toJSON()),t&&G[t]!==U&&(G[t]=U)}x=!0,C({key:U,version:re,value:G})}catch(re){re.message+=` while resolving record ${U} for ${s}`,O&&((re.code==="ECONNRESET"||re.code==="ECONNREFUSED"||re.code==="EAI_AGAIN")&&!R?.mustRevalidate||R?.staleIfError&&(re.statusCode===500||re.statusCode===502||re.statusCode===503||re.statusCode===504))?(C({key:U,version:A,value:O}),Ge.default.trace?.(re.message,"(returned stale record)")):F(re);let K=performance.now()-ee;pr(K,"cache-resolution",s,null,"fail"),k&&vm(k,"Server-Timing",`cache-resolve;dur=${K.toFixed(2)}`,!0),v.transaction.abort();return}if(R?.noCacheStore||v.noCacheStore){v.transaction.abort();return}Ir(v).addWrite({key:U,store:i,entry:p,nodeName:"source",commit:a((re,K)=>{if(K?.version!==A)return;let Te=qa(U,O,G);G?(Me.put?.(v,U,G),Ge.default.trace?.(`Writing resolved record from source with id: ${U}, timestamp: ${new Date(re).toISOString()}`),b(U,G,K,re,0,m&&be||null,{user:v?.user,expiresAt:v.expiresAt},"put",!!Ee)):K&&(Me.delete?.(v,U),Ge.default.trace?.(`Deleting resolved record from source with id: ${U}, timestamp: ${new Date(re).toISOString()}`),m||g?b(U,null,K,re,0,m&&be||null,{user:v?.user},"delete",!!Ee):i.remove(U,A))},"commit")})}),()=>{i.unlock(U,A)},q=>{i.unlock(U,A),x&&Ge.default.error?.("Error committing cache update",q)})})}a(Ld,"getFromSource");function Ka(U){if(!U||U.user?.role?.permission?.super_user)return!0;if(U.replicateTo)throw new Nr.ClientError("Can not specify replication parameters without super user permissions",403);if(U.replicatedConfirmation)throw new Nr.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}a(Ka,"checkContextPermissions");function ko(){if(Gr!==wd&&(wd=Gr,(0,Tl.getWorkerIndex)()===(0,Tl.getWorkerCount)()-1)){if(ka&&clearTimeout(ka),!Gr)return;let U=new Date;U.setMonth(0),U.setDate(1),U.setHours(0),U.setMinutes(0),U.setSeconds(0);let p=Math.ceil((Date.now()-U.getTime())/Gr)*Gr+U.getTime(),R=a(w=>{Ge.default.trace?.(`Scheduled next cleanup scan at ${new Date(w)}ms`),ka=setTimeout(()=>X=X.then(async()=>{if(R(Math.max(w+Gr,Date.now())),i.rootStore.status!=="open"){clearTimeout(ka);return}let A=50,y=new Array(A),D=0;Ge.default.info?.(`Starting cleanup scan for ${s}`);try{let O=0;for(let{key:v,value:k,version:C,expiresAt:F}of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let x;k===null&&!m&&C+WSe<Date.now()?x=i.remove(v,C):F!=null&&F+T<Date.now()&&(x=Ve.evict(v,k,C),O++),x&&(await y[D],y[D]=x.catch(q=>{Ge.default.error?.("Cleanup error",q)}),++D>=A&&(D=0)),await Ad()}Ge.default.info?.(`Finished cleanup scan for ${s}, evicted ${O} entries`)}catch(O){Ge.default.warn?.(`Error in cleanup scan for ${s}:`,O)}}),Math.min(w-Date.now(),2147483647)).unref()},"startNextTimer");R(p)}}a(ko,"scheduleCleanup");function ie(){Q=l?.addDeleteRemovalCallback(n,U=>{let p=i.getEntry(U);p?.value===null&&i.remove(U,p.version)})}a(ie,"addDeleteRemoval");function Se(){(0,Tl.getWorkerIndex)()===0&&setInterval(async()=>{if(!Al){Al=!0;try{let U=ne.name,p=r[U];if(!p)throw new Error(`expiresAt attribute ${ne} must be indexed`);for(let R of p.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let w of p.getValues(R)){let A=i.getEntry(w);A?.value?A.value[U]<Date.now()&&Ve.evict(w,A.value,A.version):i.ifVersion(w,A?.version,()=>p.remove(R,w))}await Ad()}}catch(U){Ge.default.error?.("Error in evicting old records",U)}finally{Al=!1}}},YSe).unref()}a(Se,"runRecordExpirationEviction");function tt(U){if(U){let p=U.join(","),R=d.get([Symbol.for("residency_by_set"),p]);return R||(d.put([Symbol.for("residency_by_set"),p],R=Math.floor(Math.random()*2147483647)),d.put([Symbol.for("residency_by_id"),R],U),R)}}a(tt,"getResidencyId")}function Ow(e,t){let r=e.attr_object||(e.attr_object={}),n=r[t];if(n)return n;n=r[t]=Object.create(null);for(let s of e)n[s.attribute_name]=s[t];return n}function bW(){}function ZSe(e){CW=e}function GT(e,t){let r=t?.type;if(e===null)return e;if(e===""&&r&&r!=="String"&&r!=="Any")return null;try{switch(r){case"Int":case"Long":if(e[0]==="$")return FT(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return FT(+e);case"Float":return e==="null"?null:FT(+e);case"BigInt":return e==="null"?null:BigInt(e);case"Boolean":return e==="true"?!0:e==="false"?!1:e;case"Date":if(isNaN(e)){if(e==="null")return null;eTe.test(e)||(e+="Z");let n=new Date(e);return FT(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,$T.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function FT(e){if(isNaN(e))throw new SyntaxError;return e}function OW(e,t){if(e==null)return!0;if(!Array.isArray(t))return e===t||t.startsWith?.(e);if(Array.isArray(e)){let r=e.length;if(e[r-1]===null&&r--,t.length>=r){for(let n=0;n<r;n++)if(t[n]!==e[n])return!1;return!0}return!1}else if(t[0]===e)return!0}function Nw(e,t,r){return e?.then?e.then(t,r):t(e)}function qT(e,t){e[Fr]=t,e[ve]=t?.value??null,e[kE]=t?.version}function NW(e){return e!=null}function li(e){try{return JSON.stringify(e)}catch{return e}}function tTe(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var Us,Ba,FE,IW,wW,yd,Nr,GE,qE,Ge,gl,Tl,$T,KSe,CW,YSe,WSe,gW,jSe,kE,zSe,Fr,xE,RW,QSe,bw,Os,ya,JSe,AW,yW,XSe,YMe,eTe,Ad,oE=Oe(()=>{Us=L(M()),Ba=require("lmdb"),FE=L(cn()),IW=require("lodash"),wW=L(Jd());Vs();lp();yd=L(se());my();Nr=L(_e()),GE=L(no()),qE=L(qs());Pe();iE();Ge=L(bc());_p();mc();gl=require("ordered-binary"),Tl=L(dt());Ji();$T=L(te());Pl();Ni();CT();Bf();KSe=new Uint8Array(9);KSe[8]=192;YSe=6e4,WSe=864e5;yd.initSync();gW=yd.get(Us.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),jSe=1e4,kE=Symbol.for("version"),zSe=Symbol.for("incremental-update"),Fr=Symbol("entry"),xE=Symbol("is-saving"),RW=1,QSe=2,bw=Symbol("loaded-from-source"),Os=1,ya=8,JSe=Buffer.allocUnsafeSlow(8192),AW=1978,yW=100,XSe={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},YMe=(0,$T.convertToMS)(yd.get(Us.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(VT,"makeTable");a(Ow,"attributesAsObject");a(bW,"noop");a(ZSe,"setServerUtilities");eTe=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(GT,"coerceType");a(FT,"rejectNaN");a(OW,"isDescendantId");Ad=a(()=>new Promise(setImmediate),"rest");a(Nw,"when");a(qT,"updateResource");a(NW,"exists");a(li,"stringify");a(tTe,"hasOtherProcesses")});var lt={};je(lt,{database:()=>Yl,databases:()=>We,dropDatabase:()=>xA,dropTableMeta:()=>oTe,getDatabases:()=>ut,getDefaultCompression:()=>Pm,getTables:()=>rTe,onRemovedDB:()=>nf,onUpdatedTable:()=>Dc,readMetaDb:()=>$E,resetDatabases:()=>vu,table:()=>Et,tables:()=>jn});function rTe(){return jT||ut(),jn||{}}function ut(){if(jT)return We;jT=!0,Nd=new Map;let e=(0,er.getHdbBasePath)()&&(0,Ut.join)((0,er.getHdbBasePath)(),yr.DATABASES_DIR_NAME),t=(0,er.get)(yr.CONFIG_PARAMS.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,er.get)(yr.CONFIG_PARAMS.STORAGE_PATH)||e&&((0,rs.existsSync)(e)?e:(0,Ut.join)((0,er.getHdbBasePath)(),yr.LEGACY_DATABASES_DIR_NAME)),!e)return;if((0,rs.existsSync)(e))for(let n of(0,rs.readdirSync)(e,{withFileTypes:!0})){let s=(0,Ut.basename)(n.name,".mdb");n.isFile()&&(0,Ut.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&$E((0,Ut.join)(e,n.name),null,s)}if((0,rs.existsSync)((0,Od.getBaseSchemaPath)())){for(let n of(0,rs.readdirSync)((0,Od.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,Ut.join)((0,Od.getBaseSchemaPath)(),n.name),i=(0,Ut.join)((0,Od.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,rs.readdirSync)(s,{withFileTypes:!0}))if(o.isFile()&&(0,Ut.extname)(o.name).toLowerCase()===".mdb"){let c=(0,Ut.join)(i,o.name);$E((0,Ut.join)(s,o.name),(0,Ut.basename)(o.name,".mdb"),n.name,c,!0)}}}if(t)for(let n in t){let s=t[n],i=s.path;if((0,rs.existsSync)(i))for(let c of(0,rs.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,Ut.extname)(c.name).toLowerCase()===".mdb"&&$E((0,Ut.join)(i,c.name),(0,Ut.basename)(c.name,".mdb"),n);let o=s.tables;if(o)for(let c in o){let l=o[c],u=(0,Ut.join)(l.path,(0,Ut.basename)(c+".mdb"));(0,rs.existsSync)(u)&&$E(u,c,n,null,!0)}}for(let n in We){let s=Nd.get(n);if(s){let i=We[n];n.includes("delete")&&$t.trace(`defined tables ${Array.from(s.keys())}`);for(let o in i)s.has(o)||($t.trace(`delete table class ${o}`),delete i[o])}else if(delete We[n],n==="data"){for(let i in jn)delete jn[i];delete jn[zT]}}let r=["hdb_temp","hdb_certificate","hdb_analytics","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if(We.system)for(let n of r)We.system[n]&&(We.system[n].replicate=!1);return Nd=null,We}function vu(){jT=!1;for(let[,e]of Ha)e.needsDeletion=!0;ut();for(let[e,t]of Ha)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),Ha.delete(e),delete We[t.databaseName],KE.forEach(r=>r(t.databaseName)));return We}function $E(e,t,r=Cw,n,s){let i=new Iw.default(e,!1);try{let o=Ha.get(e);o?o.needsDeletion=!1:(o=(0,Id.open)(i),Ha.set(e,o));let c=new Rl.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(KT.INTERNAL_DBIS_NAME,c)),u=o.auditStore;u||(n?(0,rs.existsSync)(n)&&(i.path=n,u=(0,Id.open)(i),u.isLegacy=!0):u=IT(o));let d=MW(r),_=d[zT],E=new Map;for(let{key:f,value:h}of l.getRange({start:!1})){let[T,m]=f.toString().split("/");m===""?m=h.name:m||(m=T,T=t,h.name||(h.name=m,h.indexed=!h.is_hash_attribute)),_?.add(T);let g=E.get(T);g||E.set(T,g={attributes:[]}),(m==null||h.is_hash_attribute)&&(g.primary=h),m!=null&&g.attributes.push(h),Object.defineProperty(h,"key",{value:f,configurable:!0})}for(let[f,h]of E){let{attributes:T,primary:m}=h;if(!m){for(let j of T)if(j.is_hash_attribute||j.isPrimaryKey){m=j;break}if(!m){$t.warn(`Unable to find a primary key attribute on table ${f}, with attributes: ${JSON.stringify(T)}`);continue}}let g=d[f],S={},b=[],I,B,H=typeof m.audit=="boolean"?m.audit:(0,er.get)(yr.CONFIG_PARAMS.LOGGING_AUDITLOG),X=m.trackDeletes,Y=m.expiration,V=m.eviction,ne=m.sealed,Q=m.splitSegments,de=m.replicate;if(g)S=g.indices,b=g.attributes,g.schemaVersion++;else{I=m.tableId,I?I>=(l.get(bd)||0)&&(l.putSync(bd,I+1),$t.info(`Updating next table id (it was out of sync) to ${I+1} for ${f}`)):(m.tableId=I=l.get(bd),I||(I=1),$t.debug("Table {table_name} missing an id, assigning {table_id}"),l.putSync(bd,I+1),l.putSync(m.key,m));let j=new Rl.default(!m.is_hash_attribute,m.is_hash_attribute);if(j.compression=m.compression,j.compression){let ae=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||LW;j.compression.threshold=ae}B=Nh(o.openDB(m.key,j)),o.databaseName=r,B.rootStore=o,B.tableId=I}for(let j of T){j.attribute=j.name;try{if(!j.is_hash_attribute&&(j.indexed||j.attribute&&!j.name)){if(!S[j.name]){let Ae=new Rl.default(!j.is_hash_attribute,j.is_hash_attribute);S[j.name]=o.openDB(j.key,Ae),S[j.name].indexNulls=j.indexNulls}let ae=b.find(Ae=>Ae.name===j.name);ae?b.splice(b.indexOf(ae),1,j):b.push(j)}}catch(ae){$t.error("Error trying to update attribute",j,b,S,ae)}}if(!g){g=UW(d,f,VT({primaryStore:B,auditStore:u,audit:H,sealed:ne,splitSegments:Q,replicate:de,expirationMS:Y&&Y*1e3,evictionMS:V&&V*1e3,trackDeletes:X,tableName:f,tableId:I,primaryKey:m.name,databasePath:s?r+"/"+f:r,databaseName:r,indices:S,attributes:T,schemaDefined:m.schemaDefined,dbisDB:l})),g.schemaVersion=1;for(let j of VE)j(g)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function MW(e){let t=We[e];if(t||(e==="data"?t=We[e]=jn:e==="system"?Object.defineProperty(We,"system",{value:t=Object.create(null),configurable:!0}):t=We[e]=Object.create(null)),Nd&&!Nd.has(e)){let r=new Set;t[zT]=r,Nd.set(e,r)}return t}function UW(e,t,r){return e[t]=r,r}function Yl({database:e,table:t}){e||(e=Cw),ut();let r=MW(e),n=(0,Ut.join)((0,er.getHdbBasePath)(),yr.DATABASES_DIR_NAME),s=(0,er.get)(yr.CONFIG_PARAMS.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,er.get)(yr.CONFIG_PARAMS.STORAGE_PATH)||((0,rs.existsSync)(n)?n:(0,Ut.join)((0,er.getHdbBasePath)(),yr.LEGACY_DATABASES_DIR_NAME));let o=(0,Ut.join)(n,(i?t:e)+".mdb"),c=Ha.get(o);if(!c||c.status==="closed"){let l=new Iw.default(o,!1);c=(0,Id.open)(l),Ha.set(o,c)}return c.auditStore||(c.auditStore=IT(c)),c}async function xA(e){if(!We[e])throw new Error("Schema does not exist");let t=We[e],r;for(let n in t)r=t[n].primaryStore.rootStore,Ha.delete(r.path),r.status==="open"&&(await r.close(),await YE.remove(r.path));if(r||(r=Yl({database:e,table:null}),r.status==="open"&&(await r.close(),await YE.remove(r.path))),e==="data"){for(let n in jn)delete jn[n];delete jn[zT]}delete We[e],KE.forEach(n=>n(e))}function Et(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:o,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:_,schemaDefined:E,origin:f}=e;r||(r=Cw);let h=Yl({database:r,table:t}),T=We[r];$t.trace(`Defining ${t} in ${r}`);let m=T?.[t];if(h.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let g,S,b;E==null&&(E=!0);let I=new Rl.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 B,H;if(m){if(g=m.primaryKey,m.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);u==null&&(u=m.splitSegments),m.attributes.splice(0,m.attributes.length,...o)}else{let Q=h.auditStore;S=o.find(Ae=>Ae.isPrimaryKey)||{},g=S.name,S.is_hash_attribute=S.isPrimaryKey=!0,S.schemaDefined=E,S.compression=Pm(),_&&(S.trackDeletes=!0),c=S.audit=typeof c=="boolean"?c:(0,er.get)(yr.CONFIG_PARAMS.LOGGING_AUDITLOG),n&&(S.expiration=n),s&&(S.eviction=s),S.splitSegments=!1,typeof l=="boolean"&&(S.sealed=l),typeof d=="boolean"&&(S.replicate=d),f&&(S.origins?S.origins.includes(f)||S.origins.push(f):S.origins=[f]),$t.trace(`${t} table loading, opening primary store`);let de=new Rl.default(!1,!0);de.compression=S.compression;let j=t+"/";if(b=h.dbisDb=h.openDB(KT.INTERNAL_DBIS_NAME,I),ne(),b.get(j))return H&&H(),vu(),Et(e);let ae=Nh(h.openDB(j,de));h.databaseName=r,ae.rootStore=h,ae.tableId=b.get(bd),$t.trace(`Assigning new table id ${ae.tableId} for ${t}`),ae.tableId||(ae.tableId=1),b.put(bd,ae.tableId+1),S.tableId=ae.tableId,m=UW(T,t,VT({primaryStore:ae,auditStore:Q,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:_,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:g,tableName:t,tableId:ae.tableId,databasePath:r,databaseName:r,indices:{},attributes:o,schemaDefined:E,dbisDB:b})),m.schemaVersion=1,B=!0,b.put(j,S)}let X=m.indices;b=b||(h.dbisDb=h.openDB(KT.INTERNAL_DBIS_NAME,I)),m.dbisDB=b;let Y=[];for(let{key:Q,value:de}of b.getRange({start:!0})){let[j,ae]=Q.toString().split("/");if(ae===""&&(ae=de.name),ae){if(j!==t)continue}else continue;let Ae=o.find(Me=>Me.name===ae),ye=!Ae?.indexed&&de.indexed&&!de.isPrimaryKey;if((!Ae||ye)&&(ne(),B=!0,Ae||b.remove(Q),ye)){let Me=m.indices[j];Me&&Y.push(Me)}}let V=[];try{for(let Q of o||[]){if((Q.relationship||Q.computed)&&(B=!0,Q.relationship))continue;let de=t+"/"+(Q.name||"");Object.defineProperty(Q,"key",{value:de,configurable:!0});let j=b.get(de);if(Q.isPrimaryKey){if(j=j||b.get(de=t+"/")||{},c!==void 0&&c!==m.audit||l!==void 0&&l!==m.sealed||d!==void 0&&d!==m.replicate||(+n||void 0)!==(+j.expiration||void 0)||(+s||void 0)!==(+j.eviction||void 0)){let Ae={...j};typeof c=="boolean"&&(c&&m.enableAuditing(c),Ae.audit=c),n&&(Ae.expiration=+n),s&&(Ae.eviction=+s),l!==void 0&&(Ae.sealed=l),d!==void 0&&(Ae.replicate=d),B=!0,ne(),b.put(de,Ae)}continue}j?.attribute&&!j.name&&(j.indexed=!0);let ae=!j||j.type!==Q.type||j.indexed!==Q.indexed||j.nullable!==Q.nullable||j.version!==Q.version||JSON.stringify(j.properties)!==JSON.stringify(Q.properties)||JSON.stringify(j.elements)!==JSON.stringify(Q.elements);if(Q.indexed){let Ae=new Rl.default(!0,!1),ye=h.openDB(de,Ae);(ae||j.indexingPID&&j.indexingPID!==process.pid||j.restartNumber<WE.workerData?.restartNumber)&&(B=!0,ne(),j=b.get(de),(ae||j.indexingPID&&j.indexingPID!==process.pid||j.restartNumber<WE.workerData?.restartNumber)&&(B=!0,Q.indexNulls===void 0&&(Q.indexNulls=!0),m.primaryStore.getStats().entryCount>0&&(Q.lastIndexedKey=j?.lastIndexedKey??void 0,Q.indexingPID=process.pid,ye.isIndexing=!0,Object.defineProperty(Q,"dbi",{value:ye}),V.push(Q))),b.put(de,Q)),j?.indexNulls&&Q.indexNulls===void 0&&(Q.indexNulls=!0),ye.indexNulls=Q.indexNulls,X[Q.name]=ye}else ae&&(B=!0,ne(),b.put(de,Q))}}finally{H&&H()}if(B&&(m.schemaVersion++,m.updatedAttributes()),$t.trace(`${t} table loading, running index`),V.length>0||Y.length>0?m.indexingOperation=iTe(m,V,Y):B&&YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"schema-change",m.databaseName,m.tableName)),m.origin=f,B)for(let Q of VE)Q(m,f!=="cluster");return(n||s||i)&&m.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),$t.trace(`${t} table loaded`),m;function ne(){H||h.transactionSync(()=>({then(Q){H=Q}}))}a(ne,"startTxn")}async function iTe(e,t,r){try{$t.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o={},c=0,l=t.length;if(await new Promise(u=>setImmediate(u)),l>0){let u;for(let _ of t)(0,Id.compareKeys)(_.lastIndexedKey,u)<0&&(u=_.lastIndexedKey),_.lastIndexedKey==null&&_.dbi.clearAsync();let d=0;for(let{key:_,value:E,version:f}of e.primaryStore.getRange({start:u,lazy:l<4,versions:!0,snapshot:!1}))if(E){if(d++,s=e.primaryStore.ifVersion(_,f,()=>{for(let h=0;h<l;h++){let T=t[h],m=T.name;try{let g=T.resolve,S=E&&(g?g(E):E[m]),b=(0,DW.getIndexedValues)(S);if(b)for(let I=0,B=b.length;I<B;I++)T.dbi.put(b[I],_)}catch(g){o[m]||(o[m]=!0,$t.error(`Error indexing attribute ${m}`,g))}}}),s.then(()=>d--,h=>{d--,$t.error(h)}),WE.workerData&&WE.workerData.restartNumber!==PW.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=_,e.dbisDB.put(h.key,h);if(i)return}d>nTe?await s:d>sTe&&await new Promise(h=>setImmediate(h))}for(let _ of t)delete _.lastIndexedKey,delete _.indexingPID,_.dbi.isIndexing=!1,s=e.dbisDB.put(_.key,_)}await s,await YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),$t.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){$t.error("Error in indexing",n)}}function oTe({table:e,database:t}){let r=Yl({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 Dc(e){return VE.push(e),{remove(){let t=VE.indexOf(e);t>-1&&VE.splice(t,1)}}}function nf(e){return KE.push(e),{remove(){let t=KE.indexOf(e);t>-1&&KE.splice(t,1)}}}function Pm(){let e=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION),t=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION_DICTIONARY),r=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||LW,n={startingOffset:32};return t&&(n.dictionary=YE.readFileSync(t)),r&&(n.threshold=r),e&&n}var er,KT,Id,Ut,rs,Od,Rl,Iw,yr,YE,ww,DW,YT,WT,WE,$t,PW,Cw,zT,LW,jn,We,bd,VE,KE,jT,Ha,Nd,nTe,sTe,Pe=Oe(()=>{er=L(se()),KT=L(Bt()),Id=require("lmdb"),Ut=require("path"),rs=require("fs"),Od=L(gt());oE();Rl=L(o_()),Iw=L(a_()),yr=L(M()),YE=L(require("fs-extra")),ww=L(fi()),DW=L(cn()),YT=L(no()),WT=L(qs()),WE=require("worker_threads"),$t=L(W()),PW=L(dt());Ji();Pl();Cw="data",zT=Symbol("defined-tables"),LW=((0,er.get)(yr.CONFIG_PARAMS.STORAGE_PAGESIZE)||4096)-60;(0,er.initSync)();jn=Object.create(null),We=Object.create(null);(0,ww._assignPackageExport)("databases",We);(0,ww._assignPackageExport)("tables",jn);bd=Symbol.for("next-table-id"),VE=[],KE=[],Ha=new Map;a(rTe,"getTables");a(ut,"getDatabases");a(vu,"resetDatabases");a($E,"readMetaDb");a(MW,"ensureDB");a(UW,"setTable");a(Yl,"database");a(xA,"dropDatabase");a(Et,"table");nTe=1e3,sTe=10;a(iTe,"runIndexing");a(oTe,"dropTableMeta");a(Dc,"onUpdatedTable");a(nf,"onRemovedDB");a(Pm,"getDefaultCompression")});var te=N((tUe,jW)=>{"use strict";var xa=require("path"),kW=require("fs-extra"),In=W(),vW=require("fs-extra"),QT=require("os"),aTe=require("net"),cTe=require("recursive-iterator"),Vt=M(),lTe=hg(),BW=require("papaparse"),JT=require("moment"),{inspect:uTe}=require("util"),HW=require("is-number"),eUe=require("lodash"),dTe=require("minimist"),_Te=require("https"),fTe=require("http"),{hdb_errors:XT}=_e(),ETe=/^((\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)))$/,FW=require("util").promisify(setTimeout),hTe=100,pTe=5,mTe="",STe=4,xW={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};jW.exports={isEmpty:ns,isEmptyOrZeroLength:Wi,arrayHasEmptyValues:RTe,arrayHasEmptyOrZeroLengthValues:ATe,buildFolderPath:yTe,isBoolean:GW,errorizeMessage:TTe,stripFileExtension:OTe,autoCast:NTe,autoCastJSON:qW,autoCastJSONDeep:Pw,removeDir:ITe,compareVersions:wTe,isCompatibleDataVersion:CTe,escapeRawValue:DTe,unescapeValue:PTe,stringifyProps:LTe,timeoutPromise:UTe,isClusterOperation:BTe,getClusterUser:xTe,checkGlobalSchemaTable:HTe,getHomeDir:VW,getPropsFilePath:MTe,promisifyPapaParse:kTe,removeBOM:KW,createEventPromise:FTe,checkProcessRunning:GTe,checkSchemaTableExist:qTe,checkSchemaExists:YW,checkTableExists:WW,getStartOfTomorrowInSeconds:$Te,getLimitKey:VTe,isObject:bTe,isNotEmptyAndHasValue:gTe,autoCasterIsNumberCheck:$W,backtickASTSchemaItems:KTe,isPortTaken:vTe,createForkArgs:YTe,autoCastBoolean:WTe,async_set_timeout:FW,getTableHashAttribute:jTe,doesSchemaExist:zTe,doesTableExist:QTe,stringifyObj:JTe,ms_to_time:XTe,changeExtension:ZTe,getEnvCliRootPath:Lw,noBootFile:ege,httpRequest:tge,transformReq:rge,convertToMS:nge,PACKAGE_ROOT:Vt.PACKAGE_ROOT};function TTe(e){return e instanceof Error?e:new Error(e)}a(TTe,"errorizeMessage");function ns(e){return e==null}a(ns,"isEmpty");function gTe(e){return!ns(e)&&(e||e===0||e===""||GW(e))}a(gTe,"isNotEmptyAndHasValue");function Wi(e){return ns(e)||e.length===0||e.size===0}a(Wi,"isEmptyOrZeroLength");function RTe(e){if(ns(e))return!0;for(let t=0;t<e.length;t++)if(ns(e[t]))return!0;return!1}a(RTe,"arrayHasEmptyValues");function ATe(e){if(Wi(e))return!0;for(let t=0;t<e.length;t++)if(Wi(e[t]))return!0;return!1}a(ATe,"arrayHasEmptyOrZeroLengthValues");function yTe(...e){try{return e.join(xa.sep)}catch{console.error(e)}}a(yTe,"buildFolderPath");function GW(e){return ns(e)?!1:e===!0||e===!1}a(GW,"isBoolean");function bTe(e){return ns(e)?!1:typeof e=="object"}a(bTe,"isObject");function OTe(e){return Wi(e)?mTe:e.slice(0,-STe)}a(OTe,"stripFileExtension");function NTe(e){return ns(e)||e===""||typeof e!="string"?e:xW[e]!==void 0?xW[e]:$W(e)===!0?Number(e):ETe.test(e)?new Date(e):e}a(NTe,"autoCast");function qW(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(qW,"autoCastJSON");function Pw(e){if(e&&typeof e=="object"){if(Array.isArray(e))for(let t=0,r=e.length;t<r;t++){let n=e[t],s=Pw(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=Pw(r);n!==r&&(e[t]=n)}return e}else return qW(e)}a(Pw,"autoCastJSONDeep");function $W(e){if(e.startsWith("0.")&&HW(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&HW(e))}a($W,"autoCasterIsNumberCheck");async function ITe(e){if(Wi(e))throw new Error(`Directory path: ${e} does not exist`);try{await vW.emptyDir(e),await vW.remove(e)}catch(t){throw In.error(`Error removing files in ${e} -- ${t}`),t}}a(ITe,"removeDir");function wTe(e,t){if(Wi(e)){In.info("Invalid current version sent as parameter.");return}if(Wi(t)){In.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,o=s.replace(n,"").split("."),c=i.replace(n,"").split("."),l=Math.min(o.length,c.length);for(let u=0;u<l;u++)if(r=parseInt(o[u],10)-parseInt(c[u],10),r)return r;return o.length-c.length}a(wTe,"compareVersions");function CTe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(CTe,"isCompatibleDataVersion");function DTe(e){if(ns(e))return e;let t=String(e);return t==="."?Vt.UNICODE_PERIOD:t===".."?Vt.UNICODE_PERIOD+Vt.UNICODE_PERIOD:t.replace(Vt.FORWARD_SLASH_REGEX,Vt.UNICODE_FORWARD_SLASH)}a(DTe,"escapeRawValue");function PTe(e){if(ns(e))return e;let t=String(e);return t===Vt.UNICODE_PERIOD?".":t===Vt.UNICODE_PERIOD+Vt.UNICODE_PERIOD?"..":String(e).replace(Vt.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(PTe,"unescapeValue");function LTe(e,t){if(ns(e))return In.info("Properties object is null"),"";let r="";return e.each(function(n,s){try{if(t&&t[n]){let i=t[n];for(let o of i)r+=";"+o+QT.EOL}!Wi(n)&&n[0]===";"?r+=" "+n+s+QT.EOL:Wi(n)||(r+=n+"="+s+QT.EOL)}catch{In.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(LTe,"stringifyProps");function VW(){let e;try{e=QT.homedir()}catch{e=process.env.HOME}return e}a(VW,"getHomeDir");function MTe(){let e=xa.join(VW(),Vt.HDB_HOME_DIR_NAME,Vt.BOOT_PROPS_FILE_NAME);return kW.existsSync(e)||(e=xa.join(__dirname,"../","hdb_boot_properties.file")),e}a(MTe,"getPropsFilePath");function UTe(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(UTe,"timeoutPromise");async function vTe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=aTe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(vTe,"isPortTaken");function BTe(e){try{return Vt.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){In.error(`Error checking operation against cluster ops ${t}`)}return!1}a(BTe,"isClusterOperation");function HTe(e,t){let r=(Pe(),oe(lt)).getDatabases();if(!r[e])return XT.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return XT.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(HTe,"checkGlobalSchemaTable");function xTe(e,t){if(ns(t)){In.warn("No CLUSTERING_USER defined, clustering disabled");return}if(ns(e)||Wi(e)){In.warn("No users to search.");return}let r;try{let n=e.get(t);n&&n.role.permission.cluster_user===!0&&n.active===!0&&(r=n)}catch(n){In.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){In.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(xTe,"getClusterUser");function kTe(){BW.parsePromise=function(e,t,r){return new Promise(function(n,s){BW.parse(e,{header:!0,transformHeader:KW,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(kTe,"promisifyPapaParse");function KW(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(KW,"removeBOM");function FTe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;In.info(`Got cluster status event response: ${uTe(s)}`);try{i.cancel()}catch{In.error("Error trying to cancel timeout.")}n(s)})})}a(FTe,"createEventPromise");async function GTe(e){let t=!0,r=0;do await FW(hTe*r++),(await lTe.findPs(e)).length>0&&(t=!1);while(t&&r<pTe);if(t)throw new Error(`process ${e} was not started`)}a(GTe,"checkProcessRunning");function qTe(e,t){let r=YW(e);if(r)return r;let n=WW(e,t);if(n)return n}a(qTe,"checkSchemaTableExist");function YW(e){let{getDatabases:t}=(Pe(),oe(lt));if(!t()[e])return XT.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(YW,"checkSchemaExists");function WW(e,t){let{getDatabases:r}=(Pe(),oe(lt));if(!r()[e][t])return XT.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(WW,"checkTableExists");function $Te(){let e=JT().utc().add(1,Vt.MOMENT_DAYS_TAG).startOf(Vt.MOMENT_DAYS_TAG).unix(),t=JT().utc().unix();return e-t}a($Te,"getStartOfTomorrowInSeconds");function VTe(){return JT().utc().format("DD-MM-YYYY")}a(VTe,"getLimitKey");function KTe(e){try{let t=new cTe(e);for(let{node:r}of t)r&&(r.columnid&&typeof r.columnid!="string"&&(r.columnid=r.columnid.toString()),r.columnid&&!r.columnid.startsWith("`")&&(r.columnid_orig=r.columnid,r.columnid=`\`${r.columnid}\``),r.tableid&&!r.tableid.startsWith("`")&&(r.tableid_orig=r.tableid,r.tableid=`\`${r.tableid}\``),r.databaseid&&!r.databaseid.startsWith("`")&&(r.databaseid_orig=r.databaseid,r.databaseid=`\`${r.databaseid}\``),r.as&&typeof r.as=="string"&&!r.as.startsWith("[")&&(r.as_orig=r.as,r.as=`\`${r.as}\``))}catch(t){In.error("Got an error back ticking items."),In.error(t)}}a(KTe,"backtickASTSchemaItems");function YTe(e){return[e]}a(YTe,"createForkArgs");function WTe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(WTe,"autoCastBoolean");function jTe(e,t){let{getDatabases:r}=(Pe(),oe(lt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(jTe,"getTableHashAttribute");function zTe(e){let{getDatabases:t}=(Pe(),oe(lt));return t()[e]!==void 0}a(zTe,"doesSchemaExist");function QTe(e,t){let{getDatabases:r}=(Pe(),oe(lt));return r()[e]?.[t]!==void 0}a(QTe,"doesTableExist");function JTe(e){try{return JSON.stringify(e)}catch{return e}}a(JTe,"stringifyObj");function XTe(e){let t=JT.duration(e),r=t.seconds()>0?t.seconds()+"s":"",n=t.minutes()>0?t.minutes()+"m ":"",s=t.hours()>0?t.hours()+"h ":"",i=t.days()>0?t.days()+"d ":"";return(t.years()>0?t.years()+"y ":"")+i+s+n+r}a(XTe,"ms_to_time");function ZTe(e,t){let r=xa.basename(e,xa.extname(e));return xa.join(xa.dirname(e),r+t)}a(ZTe,"changeExtension");function Lw(){if(process.env[Vt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[Vt.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=dTe(process.argv);if(e[Vt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[Vt.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(Lw,"getEnvCliRootPath");var Dw;function ege(){if(Dw)return Dw;let e=Lw();if(Lw()&&kW.pathExistsSync(xa.join(e,Vt.HDB_CONFIG_FILE)))return Dw=!0,!0}a(ege,"noBootFile");function tge(e,t){let r;return e.protocol==="http:"?r=fTe:r=_Te,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(tge,"httpRequest");function rge(e){if(!e.schema&&!e.database){e.schema=Vt.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(rge,"transformReq");function nge(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(nge,"convertToMS")});var QW=N((sUe,zW)=>{"use strict";var Mw=M(),sge=te(),ige=Di(),ui=W(),oge=mm(),age=pf(),nUe=Uu(),cge=ls(),lge=Rf(),uge=require("semver/functions/gte"),dge=3e4,_ge=7;zW.exports=fge;async function fge(){try{ui.notify("Starting update nodes. This process will attempt to update any node connections the need to be reestablished after a 4.0.0 upgrade"),await cge.setSchemaDataToGlobalAsync();let e=await ige.getAllNodeRecords(),t=[];for(let r=0,n=e.length;r<n;r++){let s=e[r];s.system_info.hdb_version===Mw.PRE_4_0_0_VERSION&&t.push(Ege(s))}await Promise.allSettled(t),ui.notify("Shutting down 4.0.0 clustering upgrade process")}catch(e){throw ui.error(e),e}}a(fge,"updateAllNodes");async function Ege(e){try{let{name:t,subscriptions:r}=e;ui.notify("Running 4.0.0 update on node:",t);let n=!1,s=0;for(;s<_ge;){let i=[];if(await oge.buildNodeStatus(e,i),ui.trace("Received status:",i[0].status,"from node:",t),i[0].status==="open"&&uge(i[0].system_info.hdb_version,"4.0.0")){ui.notify("Received open status from node:",t,"calling add node");let o={operation:Mw.OPERATIONS_ENUM.ADD_NODE,node_name:t,subscriptions:r};await age(o,!0),ui.notify("Successfully added node",t),n=!0;break}s=(Date.now()-e.__updatedtime__)/(1e3*60*60*24),ui.trace("Update node has been running for",s,"days. Calling node status again for node:",t),await sge.async_set_timeout(dge)}n||(ui.error("4.0.0 node update was unable to update connection to node:",t),ui.error("Removing following node record from hdb_nodes",e),await lge({operation:Mw.OPERATIONS_ENUM.REMOVE_NODE,node_name:t}))}catch(t){throw ui.error(t),t}}a(Ege,"updateNode")});var hge=QW();(async()=>{try{await hge()}catch(e){console.error("Error launching 4.0.0 node update"),console.error(e),process.exit(1)}})();
132
+ `))}},25).unref()}o.close?.(()=>{if(At.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&dd()==0)try{FK($K(At.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,XS),o.cantCleanupProperly||Nn.warn("Had to forcefully exit the thread",XS),process.exit(0)},5e3).unref()})}if(VK||process.env.DEV_MODE)try{require("inspector").close()}catch(i){Nn.info("Could not close debugger",i)}}}).ref();let e;IE&&!sme&&(e=YK()),Promise.resolve(e).then(()=>{if(dd()===0)try{tme(LI)}catch(t){console.error("Error displaying start-up log",t)}wE?.postMessage({type:Zt.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(KK,"startServers");function YK(){let e=[];for(let t in $i){let r=$i[t];if(t.includes?.("/")&&dd()==0){jpe(t)&&FK(t),e.push(new Promise((o,c)=>{r.listen({path:t},()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),Nn.info("Domain socket listening on "+t)}).on("error",c)}));continue}let n,s=At.get(Zt.CONFIG_PARAMS.HTTP_THREADRANGE);if(s){let o=typeof s=="string"?s.split("-"):s,c=dd();if(c<o[0]||c>o[1])continue}let i;try{let o=t.lastIndexOf(":");o>0?IE?n={fd:IE(+t.slice(o+1).replace(/[\[\]]/g,""),t.slice(0,o))}:n={host:+t.slice(o+1).replace(/[\[\]]/g,""),port:t.slice(0,o)}:IE?n={fd:IE(+t,"::")}:n={port:t}}catch(o){console.error(`Unable to bind to port ${t}`,o);continue}e.push(new Promise((o,c)=>{r.listen(n,()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),Nn.trace("Listening on port "+t,XS)}).on("error",c)}))}return Promise.all(e)}a(YK,"listenOnPorts");!DI&&!qpe?.noServerStart&&KK();function vI(e,t,r){let n=e?.read?e:new $pe({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=$i[t];if(s.isSecure&&(n.startTime=performance.now()),s)typeof s=="function"?s(n):s.emit("connection",n),r&&n.emit("data",r);else{let i=a(o=>{setTimeout(()=>{let c=$i[t];c?(typeof c=="function"?c(n):c.emit("connection",n),r&&n.emit("data",r)):o<5?i(o+1):(Nn.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a(vI,"deliverSocket");var vK=new Map;function ime(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=vK.get(s),r){case"connection":i=vI(void 0,t),vK.set(s,i),i.write=(c,l,u)=>(wE.postMessage({requestId:s,event:"data",data:c.toString("latin1")}),u&&u(),!0),i.end=(c,l,u)=>(wE.postMessage({requestId:s,event:"end",data:c?.toString("latin1")}),u&&u(),!0);let o=i.destroy;i.destroy=()=>{o.call(i),wE.postMessage({requestId:s,event:"destroy"})};break;case"data":i._readableState.destroyed||i.emit("data",Buffer.from(n,"latin1"));break;case"drain":i._readableState.destroyed||i.emit("drain",{});break;case"end":i._readableState.destroyed||i.emit("end",{});break;case"error":i._readableState.destroyed||i.emit("error",{});break}}a(ime,"proxyRequest");var{getComponentName:eT}=(Jf(),oe(Qf));function BI(e,t,r=!0){t||(t=At.get(Zt.CONFIG_PARAMS.HTTP_PORT));let n=$i[t];if(n){let s=n.lastServer||n;if(s===e)throw new Error(`Can not register the same server twice for the same port ${t}`);if(r&&!!s.sessionIdContext!=!!e.sessionIdContext&&+t)throw new Error(`Can not mix secure HTTPS and insecure HTTP on the same port ${t}`);s.off("unhandled",kK),s.on("unhandled",(i,o)=>{e.cantCleanupProperly&&(n.cantCleanupProperly=!0),e.emit("request",i,o)}),n.lastServer=e}else $i[t]=e;e.on("unhandled",kK)}a(BI,"registerServer");function HI(e){let t=[],r=e?.securePort;return r&&t.push({port:r,secure:!0}),r=e?.port,r&&t.push({port:r,secure:!1}),t.length===0&&(t=[],At.get(Zt.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:At.get(Zt.CONFIG_PARAMS.HTTP_PORT),secure:At.get(Zt.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),At.get(Zt.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:At.get(Zt.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&At.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:$K(At.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)),secure:!1}),t}a(HI,"getPorts");function xI(e,t){let r=[];for(let{port:n,secure:s}of HI(t))r.push(WK(n,s,t?.isOperationsServer,t?.mtls)),typeof e=="function"?MI[t?.runFirst?"unshift":"push"]({listener:e,port:t?.port||n}):(e.isSecure=s,BI(e,n,!1)),ZS[n]=rT(MI,n);return r}a(xI,"httpServer");function tT(e,t){let r=LI.get(e)??[];LI.set(e,[...r,t])}a(tT,"setPortServerMap");function WK(e,t,r,n){if(tT(e,{protocol_name:t?"HTTPS":"HTTP",name:eT()}),!JS[e]){let s=r?"operationsApi_network":"http",i=At.get(s+"_keepAliveTimeout"),o=At.get(s+"_timeout"),c=At.get(s+"_headersTimeout"),l={noDelay:!0,keepAliveTimeout:i,headersTimeout:c,requestTimeout:o,highWaterMark:128*1024,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,maxHeaderSize:At.get(Zt.CONFIG_PARAMS.HTTP_MAXHEADERSIZE)},u=At.get(s+"_mtls"),d=At.get(s+"_mtls_required");t&&Object.assign(l,{allowHTTP1:!0,rejectUnauthorized:!!d,requestCert:!!(u||n),ticketKeys:Jpe(),SNICallback:qK(r?"operations-api":"server",u),ALPNCallback:a(function(f){return f.protocols.includes("harperdb-replication")&&(this.isReplicationConnection=!0),"http/1.1"},"ALPNCallback"),ALPNProtocols:null});let _=eme(),E=JS[e]=(t?Wpe:Kpe)(l,async(f,h)=>{try{let m=performance.now(),g=new GK(f,h);r&&(g.isOperationsServer=!0);let S=await ZS[e](g);if(!S){if(g._nodeResponse.statusCode)return;S=jK(g)}if(S.headers?.set||(S.headers=new PI(S.headers)),_?S.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):S.headers?.set?.("Server","HarperDB"),S.status===-1){for(let ne of S.headers||[])h.setHeader(ne[0],ne[1]);return f.baseRequest=g,h.baseResponse=S,JS[e].emit("unhandled",f,h)}let b=S.status||200,I=performance.now(),B=I-m,H=S.body,X;if(!S.handlesHeaders){let ne=S.headers||new PI;H?H.length>=0&&(typeof H=="string"?ne.set("Content-Length",Buffer.byteLength(H)):ne.set("Content-Length",H.length),X=!0):(ne.set("Content-Length","0"),X=!0);let Q=`hdb;dur=${B.toFixed(2)}`;S.wasCacheMiss&&(Q+=", miss"),Zpe(ne,"Server-Timing",Q,!0),h.headersSent||h.writeHead(b,ne&&(ne[Symbol.iterator]?Array.from(ne):ne)),X&&h.end(H)}let Y=g.handlerPath,V=g.method;if(OE(B,"duration",Y,V,S.wasCacheMiss==null?void 0:S.wasCacheMiss?"cache-miss":"cache-hit"),MK(b<400,"success",Y,V),MK(1,"response_"+b,Y,V),!X)if(H instanceof ReadableStream&&(H=UK.fromWeb(H)),(H[Symbol.iterator]||H[Symbol.asyncIterator])&&(H=UK.from(H)),H?.pipe){H.pipe(h),H.destroy&&h.on("close",()=>{H.destroy()});let ne=0;H.on("data",Q=>{ne+=Q.length}),H.on("end",()=>{OE(performance.now()-I,"transfer",Y,V),OE(ne,"bytes-sent",Y,V)})}else H?.then?H.then(ne=>{h.end(ne)},T):h.end(H)}catch(m){T(m)}function T(m){let g=m.headers;h.writeHead(m.statusCode||500,g&&(g[Symbol.iterator]?Array.from(g):g)),h.end(m.toString()),m.statusCode?m.statusCode===500?Nn.warn(m):Nn.info(m):Nn.error(m)}a(T,"onError")});i>=0&&(E.keepAliveTimeout=i),c>=0&&(E.headersTimeout=c),t&&(E.ports||(E.ports=[]),E.ports.push(e),l.SNICallback.initialize(E),u&&(E.mtlsConfig=u),E.on("secureConnection",f=>{f._parent.startTime&&OE(performance.now()-f._parent.startTime,"tls-handshake",e),OE(f.isSessionReused(),"tls-reused",e)}),E.isSecure=!0),BI(E,e)}return JS[e]}a(WK,"getHTTPServer");function rT(e,t){let r=jK;for(let n=e.length;n>0;){let{listener:s,port:i}=e[--n];if(i===t||i==="all"){let o=r;r=a((...c)=>s(...c,o),"next_callback")}}return r}a(rT,"makeCallbackChain");function jK(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new PI}}a(jK,"unhandled");function ome(e,t){xI(e,{requestOnly:!0,...t})}a(ome,"onRequest");function ame(e,t){let r;if(t.securePort){tT(t.securePort,{protocol_name:"TLS",name:eT()});let n=qK("server",t.mtls);r=Qpe({rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,SNICallback:n},e),n.initialize(r),$i[t.securePort]=r}return t.port&&(tT(t.port,{protocol_name:"TCP",name:eT()}),r=Vpe(e,{noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600}),$i[t.port]=r),r}a(ame,"onSocket");Object.defineProperty(Ype.prototype,"upgrade",{get(){return"connection"in this.headers&&"upgrade"in this.headers&&this.headers.connection.includes("Upgrade")&&this.headers.upgrade.toLowerCase()=="websocket"},set(e){}});var BK=[],UI={};function zK(e,t){for(let{port:r}of HI(t))BK[t?.runFirst?"unshift":"push"]({listener:e,port:r}),UI[r]=rT(BK,r)}a(zK,"onUpgrade");var HK=[],xK={};function cme(e,t){let r=[];for(let{port:n,secure:s}of HI(t)){tT(n,{protocol_name:s?"WSS":"WS",name:eT()});let i=WK(n,s,t?.isOperationsServer,t?.mtls);NE[n]||(NE[n]=new zpe({noServer:!0,maxPayload:t.maxPayload??100*1024*1024}),NE[n].on("connection",(o,c)=>{let l=new GK(c);l.isWebSocket=!0;let u=ZS[n](l);xK[n](o,l,u)}),zK((o,c,l,u)=>o.__harperdb_request_upgraded?u(o,c,l):NE[n].handleUpgrade(o,c,l,d=>{o.__harperdb_request_upgraded=!0,u(o,c,l),NE[n].emit("connection",d,o)}),{port:n}),i.on("upgrade",(o,c,l)=>{UI[n]&&UI[n](o,c,l)})),r.push(i),HK[t?.runFirst?"unshift":"push"]({listener:e,port:n}),xK[n]=rT(HK,n),ZS[n]=rT(MI,n)}return r}a(cme,"onWebSocket");function kK(e,t){t.writeHead(404),t.end(`Not found
133
+ `)}a(kK,"defaultNotFound")});var LK={};je(LK,{startHTTPThreads:()=>ume,startSocketServer:()=>VI,updateWorkerIdleness:()=>nY});async function ume(e=2,t){try{if(t)qI(0,1,!0);else{let{loadRootComponents:r}=nT();if(e===0)return(0,Ds.setMainIsWorker)(!0),await kI().startServers(),Promise.resolve([]);await r()}rY();for(let r=0;r<e;r++)qI(r,e);return Promise.all(tY)}finally{(0,Ds.threadsHaveStarted)()}}function rY(){let e=(0,ZK.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),GI=setInterval(()=>{oT.notify(e)},lme).unref())}function qI(e,t=1,r){if(FI++,(0,Ds.startWorker)("server/threads/threadServer.js",{name:pd.THREAD_TYPES.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(u){u.type===pd.CLUSTER_MESSAGE_TYPE_ENUM.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});tY.push(s),await s,_d.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=iT.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=_d.indexOf(n);o>-1&&_d.splice(o,1)}if(a(i,"removeWorker"),fd){let o=fd;fd=[];for(let c of o)eY[c.localPort](null,c)}}}),r){let n=setInterval(()=>{$I?$I=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,Ds.shutdownWorkers)(),FI=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function VI(e=0,t){if(typeof e=="string")try{(0,aT.existsSync)(e)&&(0,aT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=dme:r=_me(t):r=KI;let n=(0,Ed.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);if(n._handle){n._handle.onconnection=eY[e]=function(i,o){r.readsData||(o.reading=!1,o.readStop()),$I=!0,r(o,(c,l)=>{if(!c){if(QK){let d=o._socket||new Ed.Socket({handle:o,writable:!0,readable:!0});QK.deliverSocket(d,e,l),d.resume()}else FI>0?(fd.length===0&&setTimeout(()=>{fd.length>0&&console.warn("Incoming sockets/requests have been queued for workers to start, and no workers have handled them. Check to make sure an error is not preventing workers from starting")},1e4).unref(),o.localPort=e,fd.push(o)):(console.log("start up a dynamic thread to handle request"),qI(0));pr(!1,"socket-routed");return}c.requests++;let u=o.fd;if(u>=0)c.postMessage({port:e,fd:u,data:l});else{let d=o._socket||new Ed.Socket({handle:o,writable:!0,readable:!0});hme(d,c,e)}pr(!0,"socket-routed")})};let s=Jl();oT.info(`HarperDB ${s.version} Server running on port ${e}`)}return n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function KI(e,t){let r,n=0;for(let s of _d){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=sT)return sT=i,t(r);n=i}sT=0,t(r)}function dme(e,t){let r={};e.getpeername(r);let n=r.address,s=hd.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);KI(e,o=>{hd.set(n,{worker:o,lastUsed:i}),t(o)})}function _me(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new Ed.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=hd.get(l),d=Date.now();if(u&&u.worker.threadId!==-1)return u.lastUsed=d,s(u.worker);KI(n,_=>{hd.set(l,{worker:_,lastUsed:d}),s(_,o)})})}a(r,"findByHeaderAffinity")}function nY(){sT=0;for(let e of _d)e.expectedIdle=e.recentELU.idle+fme,e.requests=1;_d.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function hme(e,t,r){let n=Eme++;t.postMessage({port:r,requestId:n,event:"connection"}),e.on("data",s=>{let i=s.toString("latin1");t.postMessage({port:r,requestId:n,data:i,event:"data"})}).on("close",s=>{t.postMessage({port:r,requestId:n,event:"close",hadError:s})}).on("error",s=>{t.postMessage({port:r,requestId:n,event:"error",error:s})}).on("drain",s=>{t.postMessage({port:r,requestId:n,event:"drain",error:s})}).on("end",()=>{t.postMessage({port:r,requestId:n,event:"end"})}).resume(),iT.set(n,s=>{s.event=="data"&&e.write(Buffer.from(s.data,"latin1")),s.event=="end"&&(e.end(s.data&&Buffer.from(s.data,"latin1")),iT.delete(n)),s.event=="destroy"&&(e.destroy(),iT.delete(n))})}var Ds,Ed,pd,oT,aT,XK,ZK,_d,fd,eY,QK,FI,tY,GI,lme,$I,sT,JK,hd,fme,iT,Eme,CI=Ie(()=>{Ds=L(dt()),Ed=require("net"),pd=L(M()),oT=L(W()),aT=require("fs");Ni();XK=require("worker_threads"),ZK=L(dc()),_d=[],fd=[],eY=[],FI=0,tY=[];XK.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,Ds.onMessageFromWorkers)(e=>{e.type===pd.ITC_EVENT_TYPES.RESTART&&GI&&(clearInterval(GI),rY())}));lme=6e5;a(ume,"startHTTPThreads");a(rY,"licenseWarning");a(qI,"startHTTPWorker");a(VI,"startSocketServer");sT=0;a(KI,"findMostIdleWorker");JK=36e5,hd=new Map;a(dme,"findByRemoteAddressAffinity");a(_me,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of hd)r.lastUsed+JK<e&&hd.delete(t)},JK).unref();fme=1e3;a(nY,"updateWorkerIdleness");(0,Ds.setMonitorListener)(nY);iT=new Map,Eme=1;a(hme,"proxySocket")});var aY=N((VLe,oY)=>{"use strict";var pme=require("cluster"),pl=se();pl.initSync();var iY=M(),kLe=require("util"),Ho=W(),FLe=require("fs"),mme=require("fastify"),GLe=Jl(),Sme=require("@fastify/cors"),Tme=require("@fastify/compress"),gme=require("@fastify/static"),Ame=GN(),Rme=require("path"),{PACKAGE_ROOT:yme}=M(),bme=ls(),Ome=te(),Nme=xn(),Ime=dc(),{server:wme}=(qr(),oe(Qa)),{node_request_key:qLe}=(vS(),oe(XN)),{authHandler:Cme,handlePostRequest:Dme,serverErrorHandler:Pme,reqBodyValidationHandler:Lme}=LS(),$Le=require("net"),{registerContentHandlers:Mme}=(jc(),oe($$)),Ume=6e4,vme=1024*1024*1024,Bme="TRUE",{CONFIG_PARAMS:DE}=iY,md;oY.exports={hdbServer:sY,start:sY};async function sY(e){try{Ho.debug("In Fastify server"+process.cwd()),Ho.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Ho.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=pme.isMaster,await Hme();let t=e.securePort>0;md=xme(t),await md.ready(),e||(e={}),e.isOperationsServer=!0;try{wme.http(md.server,e),md.server.closeIdleConnections||await md.listen({port:0,host:"::"})}catch(r){throw md.close(),Ho.error(r),Ho.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),Ho.fatal(t),process.exit(1)}}a(sY,"operationsServer");async function Hme(){Ho.trace("Configuring HarperDB process."),bme.setSchemaDataToGlobal(),await Nme.setUsersToGlobal(),await Ime.getLicense()}a(Hme,"setUp");function xme(e){Ho.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=kme(e),r=mme(t);r.server.headersTimeout=Gme(),r.setErrorHandler(Pme);let n=Fme();n&&r.register(Sme,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,u){r.server.emit("unhandled",l.raw,u.raw)}),c()}),r.register(Ame),r.register(Tme),r.register(gme,{root:Rme.join(yme,"studio/build-local")}),Mme(r);let s=pl.get(iY.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!Ome.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[Lme,Cme],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),Dme(i,o)}),r.get("/health",()=>"HarperDB is running."),Ho.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(xme,"buildServer");function kme(e){let t=pl.get(DE.OPERATIONSAPI_NETWORK_TIMEOUT),r=pl.get(DE.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:vme,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(kme,"getServerOptions");function Fme(){let e=pl.get(DE.OPERATIONSAPI_NETWORK_CORS),t=pl.get(DE.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===Bme)&&(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(Fme,"getCORSOpts");function Gme(){return pl.get(DE.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??Ume}a(Gme,"getHeaderTimeoutConfig")});var JI={};je(JI,{disableNATS:()=>$me,publishToStream:()=>uT,setNATSReplicator:()=>YI,setPublishToStream:()=>Vme,setSubscription:()=>QI,start:()=>qme});function qme(){PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_ENABLED)&&Yme()}function $me(e=!0){_Y=e}function Vme(e,t){uT=e,QI=t}function Yme(){if(_Y||process.env._DISABLE_NATS)return;let e=ut(),t=Object.keys(e);t.push("system");for(let r of t){let n=e[r];for(let s in n){let i=n[s];YI(s,r,i)}}Pc((r,n)=>{YI(r.tableName,r.databaseName,r),n&&EY(r)}),!cY&&(cY=!0)}function YI(e,t,r){if(t==="system"&&Wme.includes(e))return;if(!r)return console.error(`Attempt to replicate non-existent table ${e} from database ${t}`);if(r.sources.some(s=>s?.isNATSReplicator))return;r.sourcedFrom(class extends Lr{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this[ze],record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this[ze]})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this[ze],record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this[ze],record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this[ze]})}static defineSchema(i){EY(i)}static subscribe(){let i=new Mn;return QI(t,e,i),i}static subscribeOnThisThread(i){return i<(PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??Kme)}static isEqual(i){return i.isNATSReplicator}static isNATSReplicator=!0;static shouldReceiveInvalidations=!0},{intermediateSource:!0});function n(s){let i=s?.transaction?.nats;if(!i)if(s?.transaction){s.transaction.nats=i=new cT(s.transaction,s);let o=s.transaction;for(;o.next;)o=o.next;o.next=s.transaction.nats,i.user=s.user,i.context=s}else i=fY;return i}a(n,"getNATSTransaction")}function EY(e){let t=PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_NODENAME);uT(`${jI.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,zI.createNatsTableStreamName)(e.databaseName,e.tableName),void 0,{operation:"define_schema",schema:e.databaseName,table:e.tableName,attributes:e.attributes,__origin:{timestamp:Date.now(),node_name:t}})}var lY,jI,zI,uY,dY,PE,LE,lT,_Y,uT,QI,Kme,fY,cY,Wme,cT,WI,hY=Ie(()=>{Pe();Vs();lY=L(mr()),jI=L(Ct()),zI=L(to());Pl();uY=L(ey()),dY=L(cn()),PE=L(se()),LE=L(M()),lT=L(W());a(qme,"start");a($me,"disableNATS");uT=lY.publishToStream,QI=uY.setSubscription;a(Vme,"setPublishToStream");Kme=2;a(Yme,"assignReplicationSource");Wme=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(YI,"setNATSReplicator");a(EY,"publishSchema");cT=class{constructor(t,r){this.transaction=t;this.options=r}static{a(this,"NATSTransaction")}user;writes_by_db=new Map;addWrite(t,r){r.expiresAt=this.context?.expiresAt;let n=this.writes_by_db.get(t);n||this.writes_by_db.set(t,n=[]),n.push(r)}commit({timestamp:t}){let r=PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],l,u;for(let d of i){let _=d.table,E=d.operation=="put"?"upsert":d.operation;l||(lT.trace(`Sending transaction event ${E}`),u=l={operation:E,schema:s,table:_,__origin:{user:this.user?.username,timestamp:t,node_name:r}},l.hash_values=c,E!=="delete"&&E!=="invalidate"&&(l.records=o)),l.table===_&&l.operation===E?(o.push(d.record),c.push(d.id)):u=u.next={operation:E,table:_,id:d.id,record:d.record},d.expiresAt&&(u.expiresAt=d.expiresAt)}l&&n.push(uT(`${jI.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,zI.createNatsTableStreamName)(s,l.table),void 0,l)?.catch(d=>{throw lT.error("An error has occurred trying to replicate transaction",l,d),d.statusCode=504,d}))}return Promise.all(n)}},WI=class extends cT{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,dY.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};fY=new WI});async function gY({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await XI.get(e,{returnNonexistent:!0});i=new tw(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await XI.get(e);o&&o.delete()}i=new _T(e,t)}return n&&(n.id=e,n.user={username:t?.username},ME.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function ZI(){return dT++,dT>65500&&(dT=1),dT}function ew(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=wi.getMatch(n,"mqtt");if(!i)throw new Error(`Can not publish to topic ${n} as it does not exist, no resource has been defined to handle this topic`);e.url=i.relativeURL;let o=i.Resource;return Dt(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var mY,Ma,SY,TY,pY,XI,ME,dT,_T,tw,AY=Ie(()=>{Pe();nu();mY=L(cn()),Ma=L(W());mc();SY=L(dt()),TY=L(kI());qr();pY=100,XI=Et({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),ME=Et({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,SY.getWorkerIndex)()===0&&(async()=>{await TY.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of ME.search({})){let t=e.data,r={...e};r.user?.username&&(r.user=await it.getUser(r.user.username));try{await ew(r,t,r)}catch{(0,Ma.warn)("Failed to publish will",t)}ME.delete(e.id)}})();a(gY,"getSession");dT=1;a(ZI,"getNextMessageId");_T=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;request;socket;subscriptions=[];awaitingAcks;sessionWasPresent;keepalive;keepaliveTimer;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),l,u;if(c>-1?(l=s.slice(c),u=s.slice(0,c)):u=s,!u)throw new Error("No topic provided");if(u.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let d=this.subscriptions.find(g=>g.topic===s),_;d?(_=i>0,d.end(),this.subscriptions.splice(this.subscriptions.indexOf(d),1)):_=i===2;let E={search:l,async:!0,user:this.user,startTime:o,omitCurrent:_,url:""};o&&(0,Ma.trace)("Resuming subscription from",s,"from",o);let f=wi.getMatch(u,"mqtt");if(!f){let g=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw g.statusCode=404,g}if(E.url=f.relativeURL,E.url.indexOf("+")>-1||E.url.indexOf("#")>-1){let g=E.url.slice(1);if(g.indexOf("#")>-1&&g.indexOf("#")!==g.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(E.isCollection=!0,g.indexOf("+")===g.length-1)E.onlyChildren=!0,E.url="/"+g.slice(0,g.length-1);else{let S=g.split("/"),b;for(let H=0;H<S.length;H++)if(S[H].indexOf("+")>-1)if(S[H]==="+")b=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&b)throw new Error("Filters can not be combined");let I=!0;S[S.length-1]==="#"&&(S.length--,I=!1),b&&(n=a(H=>{let X=H.id;if(!Array.isArray(X)||I&&X.length!==S.length)return!1;for(let Y=0;Y<S.length;Y++)if(S[Y]!=="+"&&S[Y]!==X[Y])return!1;return!0},"filter"));let B=S.indexOf("+");E.url="/"+(B>-1?S.slice(0,B):S).concat("").join("/")}}let h=f.path,T=f.Resource,m=await Dt(E,async()=>{let g=this.createContext();g.topic=s,g.retainHandling=i;let S=await T.subscribe(E,g);if(!S)return;if(!S[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let b=(async()=>{for await(let I of S)try{let B;if(I.type&&I.type!=="put"&&I.type!=="delete"&&I.type!=="message"&&I.type!=="patch"||n&&!n(I))continue;r?(I.topic=s,B=this.needsAcknowledge(I)):(I.acknowledge?.(),B=ZI());let H=I.id;if(Array.isArray(H)&&(H=ru(H)),H==null&&(H=""),await this.listener(h+"/"+H,I.value,B,t)===!1)break;this.awaitingAcks?.size>pY?await new Promise(Y=>setTimeout(Y,this.awaitingAcks.size-pY)):await new Promise(setImmediate)}catch(B){(0,Ma.warn)(B)}})();return S});return m.topic=s,m.qos=t.qos,this.subscriptions.push(m),m}resume(){}needsAcknowledge(t){let r=ZI();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 ew(t,r,this.createContext())}createContext(){let t={session:this,socket:this.socket,user:this.user,authorize:!0};return this.request&&(t.request=this.request,t.url=this.request.url,t.headers=this.request.headers),t}setListener(t){this.listener=t}disconnect(t){this.keepaliveTimer&&clearTimeout(this.keepaliveTimer);let r=this.createContext();Dt(r,async()=>{try{if(!t){let n=await ME.get(this.sessionId);n?.doesExist()&&await ew(n,n.data,r)}}finally{await ME.delete(this.sessionId)}}).catch(n=>{(0,Ma.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(ew,"publish");tw=class extends _T{static{a(this,"DurableSubscriptionsSession")}sessionRecord;constructor(t,r,n){super(t,r),this.sessionRecord=n||{id:t,subscriptions:[]}}async resume(){for(let t of this.sessionRecord.subscriptions||[])await this.resumeSubscription({omitCurrent:!0,topic:t.topic,qos:t.qos,startTime:t.startTime},!0,t.acks?r=>!t.acks.includes(r.localTime):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=ZI(),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,Ma.trace)("Received ack",n,r.timestamp),this.sessionRecord.update();return}}for(let s of this.sessionRecord.subscriptions)s.topic===n&&(s.startTime=r.timestamp);this.sessionRecord.update()}async addSubscription(t,r){await this.resumeSubscription(t,r);let{qos:n,startTime:s}=t;return n>0&&!s&&this.saveSubscriptions(),t.qos}removeSubscription(t){let r=this.subscriptions.find(s=>s.topic===t),n=super.removeSubscription(t);return r.qos>0&&this.saveSubscriptions(),n}saveSubscriptions(){this.sessionRecord.subscriptions=this.subscriptions.map(t=>{let r=t.startTime;return r||(r=t.startTime=(0,mY.getNextMonotonicTime)()),(0,Ma.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),XI.put(this.sessionRecord)}}});var nw={};je(nw,{bypassAuth:()=>jme,start:()=>zme});function jme(){NY=!0}function zme({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new OY.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c=[],l=r?.mtls;return n&&(c=e.ws((u,d,_,E)=>{if(d.headers.get("sec-websocket-protocol")!=="mqtt")return E(u,d,_);o.events.emit("connection",u),dr.debug?.("Received WebSocket connection for MQTT from",u._socket.remoteAddress);let{onMessage:f,onClose:h}=yY(u,T=>{u.send(T)},d,Promise.resolve(_).then(()=>d?.user),o);u.on("message",f),u.on("close",h),u.on("error",T=>{dr.info?.("WebSocket error",T)})},{...n})),(t||s)&&c.push(e.socket(async u=>{let d;if(o.events.emit("connection",u),dr.debug?.(`Received ${u.getCertificate?"SSL":"TCP"} connection for MQTT from ${u.remoteAddress}`),l){if(u.authorized)try{let f=l.user;if(f!==null){(f===void 0||f==="Common Name"||f==="CN")&&(f=u.getPeerCertificate().subject.CN);try{d=await e.getUser(f,null,null),(0,Sd.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ET.notify?.({username:d?.username,status:kr.AUTH_AUDIT_STATUS.SUCCESS,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:u.remoteAddress})}catch(h){throw(0,Sd.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ET.error?.({username:f,status:kr.AUTH_AUDIT_STATUS.FAILURE,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:u.remoteAddress}),h}}else dr.debug?.("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",u.remoteAddress)}catch(f){o.events.emit("error",f,u),dr.error?.(f)}else if(l.required)return dr.info?.(`Unauthorized connection attempt, no authorized client certificate provided, error: ${u.authorizationError}`),u.end()}!d&&NY&&u.remoteAddress.includes("127.0.0.1")&&(d=await(0,bY.getSuperUser)(),dr.debug?.("Auto-authorizing local connection",d?.username));let{onMessage:_,onClose:E}=yY(u,f=>u.write(f),null,d,o);u.on("data",_),u.on("close",E),u.on("error",f=>{dr.info?.("Socket error",f)})},{port:t,securePort:s,mtls:l})),c}function yY(e,t,r,n,s){RY||(RY=!0,k_(_=>{fT>0&&_.push({metric:"mqtt-connections",connections:fT,byThread:!0})}));let i;fT++;let o,c={protocolVersion:4},l=(0,hT.parser)({protocolVersion:5});function u(_){l.parse(_)}a(u,"onMessage");function d(){fT--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),qn(!1,"connection","mqtt","disconnect"),dr.debug?.("MQTT connection was closed",e.remoteAddress))}return a(d,"onClose"),l.on("packet",async _=>{n?.then&&(n=await n);let E=_.cmd;if(o)o.then&&await o;else if(E!=="connect"){dr.info?.("Received packet before connection was established, closing connection"),e?.destroy?e.destroy():e?.terminate();return}let f=_.topic,h=f?.indexOf("/",1),T=h>0?f.slice(0,h):f;pr(_.length,"bytes-received",T,g(_),"mqtt");try{switch(o?.receivedPacket?.(),E){case"connect":if(c.protocolVersion=_.protocolVersion,_.username)try{n=await it.getUser(_.username,_.password.toString(),r),(0,Sd.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ET.notify?.({username:n?.username,status:kr.AUTH_AUDIT_STATUS.SUCCESS,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(V){return(0,Sd.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ET.error?.({username:_.username,status:kr.AUTH_AUDIT_STATUS.FAILURE,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",_,e,V),qn(!1,"connection","mqtt","connect"),m({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",_,e),qn(!1,"connection","mqtt","connect"),m({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(_,n),_.will){let V=e.deserialize||(e.deserialize=bo(r?.headers.get?.("content-type")));_.will.data=_.will.payload?.length>0?V(_.will.payload):void 0,delete _.will.payload}o=gY({user:n,..._}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(V){return dr.error?.(V),s.events.emit("auth-failed",_,e,V),qn(!1,"connection","mqtt","connect"),m({cmd:"connack",reasonCode:V.code||5,returnCode:V.code||128})}s.events.emit("connected",o,e),qn(!0,"connection","mqtt","connect"),m({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0}),o.setListener((V,ne,Q,de)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",V);let j=V.indexOf("/",1),ae=j>0?V.slice(0,j):V;m({cmd:"publish",topic:V,payload:S(ne),messageId:Q||Math.floor(Math.random()*1e8),qos:de.qos},ae);let be=e._socket??e;return be.writableNeedDrain?new Promise(Oe=>be.once("drain",Oe)):!be.closed}catch(j){return dr.error?.(j),o?.disconnect(),s.sessions.delete(o),!1}}),o.sessionWasPresent&&await o.resume();break;case"subscribe":let b=[];for(let V of _.subscriptions){let ne;try{let Q=await o.addSubscription(V,V.qos>=1);ne=Q?Q.qos||0:c.protocolVersion<5?128:143}catch(Q){s.events.emit("error",Q,e,V,o),Q.statusCode?Q.statusCode===500?dr.warn?.(Q):dr.info?.(Q):dr.error?.(Q),ne=c.protocolVersion<5?128:Q.statusCode===403?135:Q.statusCode===404?143:128}b.push(ne)}await o.committed,m({cmd:"suback",granted:b,messageId:_.messageId});break;case"unsubscribe":{let V=[];for(let ne of _.unsubscriptions)V.push(o.removeSubscription(ne)?0:17);m({cmd:"unsuback",granted:V,messageId:_.messageId});break}case"pubrel":m({cmd:"pubcomp",messageId:_.messageId,reasonCode:0});return;case"publish":let I=_.qos===2?"pubrec":"puback",B=e.deserialize||(e.deserialize=bo(r?.headers.get?.("content-type"))),X=(_.payload?.length||0)>0?B(_.payload):void 0,Y;try{Y=await o.publish(_,X)}catch(V){s.events.emit("error",V,e,_,o),dr.warn?.(V),_.qos>0&&m({cmd:I,messageId:_.messageId,reasonCode:128},_.topic);break}_.qos>0&&m({cmd:I,messageId:_.messageId,reasonCode:Y===!1?144:0},_.topic);break;case"pubrec":m({cmd:"pubrel",messageId:_.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(_.messageId);break;case"pingreq":m({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),qn(!0,"connection","mqtt","disconnect"),dr.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(b){s.events.emit("error",b,e,_,o),dr.error?.(b),m({cmd:"disconnect"})}function m(b,I){let B=(0,hT.generate)(b,c);t(B),pr(B.length,"bytes-sent",I,g(b),"mqtt")}a(m,"sendPacket");function g(b){return b.qos>0?b.cmd+",qos="+b.qos:b.cmd}a(g,"packetMethodName");function S(b){return Wc(b,r)}a(S,"serialize")}),l.on("error",_=>{dr.warn("MQTT parsing error, closing connection:",_.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:u,onClose:d}}var hT,bY,Sd,kr,rw,OY,ET,dr,NY,RY,fT,IY=Ie(()=>{hT=require("mqtt-packet");AY();bY=L(xn());jc();Ni();qr();Sd=L(se()),kr=L(M()),rw=L(bc()),OY=require("events"),ET=(0,rw.loggerWithTag)("auth-event"),dr=(0,rw.loggerWithTag)("mqtt"),NY=(0,Sd.get)(kr.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(jme,"bypassAuth");a(zme,"start");fT=0;a(yY,"onSocket")});var Qf={};je(Qf,{component_errors:()=>gd,getComponentName:()=>eSe,loadComponent:()=>ST,loadComponentDirectories:()=>UY,setErrorReporter:()=>Zme});function UY(e,t){t&&(iw=t),e&&(ow=e);let r=[];if((0,Nt.existsSync)(sw)){let s=(0,Nt.readdirSync)(sw,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,Ot.join)(sw,o);r.push(ST(c,iw,"hdb",!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(ST(n,iw,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{MY=!0})}function Zme(e){UE=e}async function ST(e,t,r,n,s,i){let o=(0,Nt.realpathSync)(e);if(pT.has(o))return pT.get(o);pT.set(o,!0),s&&(ow=s);try{let c;n&&(gd=new Map);let l=(0,Ot.join)(e,n?"harperdb-config.yaml":"config.yaml");(0,Nt.existsSync)(l)?c=n?(0,TT.getConfigObj)():(0,CY.parseDocument)((0,Nt.readFileSync)(l,"utf8")).toJSON():c=aw;let u=(0,Ot.join)(e,"node_modules","harperdb");try{ml.isMainThread&&(n||(0,Nt.existsSync)(u)&&(0,Nt.realpathSync)(Rd.PACKAGE_ROOT)!==(0,Nt.realpathSync)(u))&&((0,Nt.rmSync)(u,{recursive:!0,force:!0}),(0,Nt.existsSync)((0,Ot.join)(e,"node_modules"))||(0,Nt.mkdirSync)((0,Ot.join)(e,"node_modules")),(0,Nt.symlinkSync)(Rd.PACKAGE_ROOT,u,"dir"))}catch(E){Td.default.error("Error symlinking harperdb module",E)}let d=mT,_=n;for(let E in c){mT=E;let f=c[E];if(gd.set(n?E:(0,Ot.basename)(e),!1),!f)continue;let h,T=f.package;try{if(T){let I=e,B;for(;!(0,Nt.existsSync)(B=(0,Ot.join)(I,"node_modules",E));)if(I=(0,Ot.dirname)(I),I.length<(0,LY.getHdbBasePath)().length){B=null;break}if(B)h=await ST(B,t,r,!1),_=!0;else throw new Error(`Unable to find package ${E}:${T}`)}else h=Xme[E];if(!h)continue;let m=a(I=>(I.origin=r,Et(I)),"ensureTable"),g=f.network||(f.port||f.securePort)&&f,S=g?.securePort||g?.https&&g.port,b=!g?.https&&g?.port;if(ml.isMainThread&&(h=await h.startOnMainThread?.({server:it,ensureTable:m,port:b,securePort:S,resources:t,...f})||h,n&&g))for(let I of[b,S])try{if(+I&&!wY.includes(I)){let B=cw.get(Rd.CONFIG_PARAMS.HTTP_SESSIONAFFINITY);B&&Td.default.warn("Session affinity is not recommended and may cause memory leaks"),(B||!US)&&(wY.push(I),VI(I,B))}}catch(B){console.error("Error listening on socket",I,B,E)}if(t.isWorker&&(h=await h.start?.({server:it,ensureTable:m,port:b,securePort:S,resources:t,...f})||h),ow.set(h,!0),(h.handleFile||h.handleDirectory||h.setupFile||h.setupDirectory)&&f.files!=null){if(f.files.includes(".."))throw(0,PY.handleHDBError)("Can not reference parent directories");let I=(0,Ot.join)(e,f.files).replace(/\\/g,"/"),B=I.indexOf("/*");if(B>-1&&f.files!==aw[E]?.files&&!(0,Nt.existsSync)(I.slice(0,B)))throw new Error(`The path '${I.slice(0,B)}' does not exist and cannot be used as the base of the resolved 'files' path value '${f.files}'`);let H=(0,Ot.basename)(e),X=f.path||"/";X=X.startsWith("/")?X:X.startsWith("./")?"/"+H+X.slice(2):X==="."?"/"+H:"/"+H+"/"+X;let Y,V,ne;if(f.root){let de=f.root;de.startsWith("/")&&(de=de.slice(1)),de.endsWith("/")&&(de=de.slice(0,-1)),de+="/",V=(0,Ot.join)(e,de)}else(ne=I.indexOf("/*"))>-1?(V=I.slice(0,ne+1),Y=(0,Ot.relative)(e,V)):f.files.indexOf("/")>-1&&(V=I.slice(0,I.lastIndexOf("/")+1),Y=(0,Ot.relative)(e,V));let Q=!1;if(ml.isMainThread&&h.setupDirectory&&(Q=await h.setupDirectory?.(X,V,t)),t.isWorker&&h.handleDirectory&&(Q=await h.handleDirectory?.(X,V,t)),Q){_=!0;continue}for(let de of await(0,DY.default)(I,{onlyFiles:!1,objectMode:!0})){let{path:j,dirent:ae}=de;_=!0;let be=(0,Ot.relative)(e,j).replace(/\\/g,"/");if(Y)if(be.startsWith(Y))be=be.slice(Y.length+1);else throw new Error(`The root path '${f.root}' does not reference a valid part of the file path '${be}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let Oe=X+(X.endsWith("/")?"":"/")+be;try{if(ae.isFile()){let Me=await Jme(j);ml.isMainThread&&await h.setupFile?.(Me,Oe,j,t),t.isWorker&&await h.handleFile?.(Me,Oe,j,t)}else ml.isMainThread&&await h.setupDirectory?.(Oe,j,t),t.isWorker&&await h.handleDirectory?.(Oe,j,t)}catch(Me){Me.message=`Could not load ${ae.isFile()?"file":"directory"} '${j}'${f.module?" using '"+f.module+"'":""} for application '${e}' due to: ${Me.message}`,UE?.(Me),((0,Ad.getWorkerIndex)()===0?console:Td.default).error(Me),t.set(f.path||"/",new ea(Me)),gd.set(n?E:(0,Ot.basename)(e),Me.message)}}}}catch(m){m.message=`Could not load component '${E}' for application '${(0,Ot.basename)(e)}' due to: ${m.message}`,UE?.(m),((0,Ad.getWorkerIndex)()===0?console:Td.default).error(m),t.set(f.path||"/",new ea(m),null,!0),gd.set(n?E:(0,Ot.basename)(e),m.message)}}if(mT=d,ml.isMainThread&&!MY&&i&&(0,Ad.watchDir)(e,async()=>UY()),c.extensionModule){let E=await bS((0,Ot.join)(e,c.extensionModule));return pT.set(o,E),E}if(!_&&t.isWorker){let E=`${e} did not load any modules, resources, or files, is this a valid component?`;UE?.(new Error(E)),((0,Ad.getWorkerIndex)()===0?console:Td.default).error(E),gd.set((0,Ot.basename)(e),E)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,UE?.(c),t.set("",new ea(c))}}var Nt,Ot,ml,CY,cw,Rd,DY,Ad,Td,PY,LY,Qme,TT,Jme,sw,ow,MY,iw,gd,Xme,aw,wY,pT,UE,mT,eSe,Jf=Ie(()=>{Nt=require("fs"),Ot=require("path"),ml=require("worker_threads"),CY=require("yaml"),cw=L(se()),Rd=L(M());ID();Z$();nV();aV();cV();RV();t1();a1();DY=L(require("fast-glob")),Ad=L(dt()),Td=L(W());ON();qr();PY=L(_e());Pe();CI();LY=L(se()),Qme=L(aY());km();hY();us();IY();TT=L(wt());vS();fy();({readFile:Jme}=Nt.promises),sw=(0,TT.resolvePath)(cw.get(Rd.CONFIG_PARAMS.COMPONENTSROOT)),ow=new Map,gd=new Map;a(UY,"loadComponentDirectories");Xme={REST:CS,rest:CS,graphql:yN,graphqlSchema:Pg,roles:bN,jsResource:IN,fastifyRoutes:WN,login:CN,static:jN,operationsApi:Qme,customFunctions:{},http:{},clustering:JI,replication:ca,authentication:Hf,mqtt:nw},aw={rest:!0,graphql:!0,graphqlSchema:{files:"*.graphql"},roles:{files:"roles.yaml"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(aw,"static",{value:{files:"web/**"}});wY=[],pT=new Map;a(Zme,"setErrorReporter");eSe=a(()=>mT,"getComponentName");a(ST,"loadComponent")});var nT=N((SMe,BY)=>{var{isMainThread:vY}=require("worker_threads"),{getTables:tSe,getDatabases:pMe,table:mMe}=(Pe(),oe(lt)),{loadComponentDirectories:rSe,loadComponent:nSe}=(Jf(),oe(Qf)),{resetResources:sSe}=(nu(),oe(iB)),iSe=SO(),oSe=wt(),{dirname:aSe}=require("path"),{getConnection:cSe}=mr(),lSe=se(),{CONFIG_PARAMS:uSe}=M(),{loadCertificates:dSe}=Xs(),lw=new Map;async function _Se(e=!1){!vY&&lSe.get(uSe.CLUSTERING_ENABLED)&&cSe();try{vY&&await iSe()}catch(n){console.error(n)}let t=sSe();tSe(),t.isWorker=e,await dSe(),await nSe(aSe(oSe.getConfigFilePath()),t,"hdb",!0,lw),await rSe(lw,t);let r=[];for(let[n]of lw)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(_Se,"loadRootComponents");BY.exports.loadRootComponents=_Se});var dt=N((gMe,ai)=>{"use strict";var{Worker:fSe,MessageChannel:ESe,parentPort:Vi,isMainThread:Ew,threadId:hSe,workerData:Ki}=require("worker_threads"),{PACKAGE_ROOT:pSe}=M(),{join:FY,isAbsolute:mSe,extname:SSe}=require("path"),{server:GY}=(qr(),oe(Qa)),{watch:TSe,readdir:gSe}=require("fs/promises"),{totalmem:HY}=require("os"),vE=M(),qY=se(),Yi=W(),{randomBytes:ASe}=require("crypto"),{_assignPackageExport:RSe}=fi(),ySe=M(),xY=1024*1024,Ua=[],Ps=[],bSe=50,hw=1e4,OSe="restart",$Y="request_thread_info",VY="resource_report",KY="thread_info",YY="added-port",NSe="ack",uw;RSe("threads",Ps);ai.exports={startWorker:dw,restartWorkers:mw,shutdownWorkers:PSe,workers:Ua,setMonitorListener:kSe,onMessageFromWorkers:LSe,onMessageByType:ZY,broadcast:USe,broadcastWithAcknowledgement:BSe,setChildListenerByType:DSe,getWorkerIndex:WY,getWorkerCount:jY,getTicketKeys:QY,setMainIsWorker:wSe,setTerminateTimeout:ISe,restartNumber:Ki?.restartNumber||1};Ps.onMessageByType=ZY;Ps.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=Ps.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};ai.exports.whenThreadsStarted=new Promise(e=>{ai.exports.threadsHaveStarted=e});var pw;function ISe(e){hw=e}a(ISe,"setTerminateTimeout");function WY(){return Ki?Ki.workerIndex:pw?0:void 0}a(WY,"getWorkerIndex");function jY(){return Ki?Ki.workerCount:pw?1:void 0}a(jY,"getWorkerCount");function wSe(e){pw=e,ai.exports.threadsHaveStarted()}a(wSe,"setMainIsWorker");var zY=1,gT;function QY(){return gT||(gT=Ew?ASe(48):Ki.ticketKeys,gT)}a(QY,"getTicketKeys");Object.defineProperty(GY,"workerIndex",{get(){return WY()}});Object.defineProperty(GY,"workerCount",{get(){return jY()}});var JY={[$Y](e,t){HSe(t)},[VY](e,t){xSe(t,e)}};function dw(e,t={}){let r=process.constrainedMemory?.()||HY();r=Math.min(r,HY(),2e4*xY);let n=qY.get(vE.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/xY/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let l of Ps){let u=new ESe;u.existingPort=l,i.push(u),o.push(u.port2)}SSe(e)||(e+=".js");let c=new fSe(mSe(e)?e:FY(pSe,e),{resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps"],argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(l=>l.existingPort.threadId),workerIndex:t.workerIndex,workerCount:zY=t.threadCount,name:t.name,restartNumber:ai.exports.restartNumber,ticketKeys:QY()},transferList:o,...t});for(let{port1:l,existingPort:u}of i)u.postMessage({type:YY,port:l,threadId:c.threadId},[l]);return RT(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>dw(e,t),c.on("error",l=>{Yi.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{Ua.splice(Ua.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<bSe?(t.unexpectedRestarts=c.unexpectedRestarts+1,dw(e,t)):Yi.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{JY[l.type]?.(l,c)}),Ua.push(c),GSe(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(dw,"startWorker");var CSe=[vE.THREAD_TYPES.HTTP];async function mw(e=null,t=Math.max(zY>3,1),r=!0){if(Ew){if(r){let{loadRootComponents:o}=nT();await o()}ai.exports.restartNumber++,t<1&&(t=t*Ua.length);let n=[],s=[];for(let o of Ua.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;Yi.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:ai.exports.restartNumber,type:vE.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=CSe.indexOf(o.name)>-1,l=new Promise(u=>{let d=setTimeout(()=>{Yi.warn("Thread did not voluntarily terminate, terminating from the outside",o.threadId),o.terminate()},hw*2).unref();o.on("exit",()=>{clearTimeout(d),n.splice(n.indexOf(l)),!c&&r&&o.startCopy(),u()})});if(n.push(l),c&&r){let u=o.startCopy(),d=new Promise(_=>{let E=a(f=>{f.type===ySe.ITC_EVENT_TYPES.CHILD_STARTED&&(Yi.trace("Worker has started",u.threadId),_(),s.splice(s.indexOf(d)),u.off("message",E))},"startListener");Yi.trace("Waiting for worker to start",u.threadId),u.on("message",E)});s.push(d),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=Gu();r&&(e==="http"||!e)&&qY.get(vE.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else Vi.postMessage({type:OSe,workerType:e})}a(mw,"restartWorkers");function DSe(e,t){JY[e]=t}a(DSe,"setChildListenerByType");function PSe(e){return mw(e,1/0,!1)}a(PSe,"shutdownWorkers");var XY=[];function LSe(e){XY.push(e)}a(LSe,"onMessageFromWorkers");var _w=new Map;function ZY(e,t){let r=_w.get(e);r||_w.set(e,r=[]),r.push(t)}a(ZY,"onMessageByType");var MSe=10;async function USe(e,t){let r=0;for(let n of Ps)try{n.postMessage(e),r++>MSe&&(r=0,await new Promise(setImmediate))}catch(s){Yi.error("Unable to send message to worker",s)}t&&tW(e,null)}a(USe,"broadcast");var AT=new Map,vSe=1;function BSe(e){return new Promise(t=>{let r=0;for(let n of Ps)try{let s=vSe++,i=a(()=>{AT.delete(s),--r===0&&t(),n!==Vi&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,AT.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of AT)o.port===n&&o()})),n.postMessage(e),r++}catch(s){Yi.error("Unable to send message to worker",s)}r===0&&t()})}a(BSe,"broadcastWithAcknowledgement");function HSe(e){e.postMessage({type:KY,workers:eW()})}a(HSe,"sendThreadInfo");function eW(){let e=Date.now();return Ua.map(t=>({threadId:t.threadId,name:t.name,heapTotal:t.resources?.heapTotal,heapUsed:t.resources?.heapUsed,externalMemory:t.resources?.external,arrayBuffers:t.resources?.arrayBuffers,sinceLastUpdate:e-t.resources?.updated,...t.recentELU}))}a(eW,"getChildWorkerInfo");function xSe(e,t){e.resources=t,e.resources.updated=Date.now()}a(xSe,"recordResourceReport");var fw;function kSe(e){fw=e}a(kSe,"setMonitorListener");var FSe=1e3,kY=!1;function GSe(){kY||(kY=!0,setInterval(()=>{for(let e of Ua){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}fw&&fw()},FSe).unref())}a(GSe,"startMonitoring");var qSe=1e3;if(Vi&&Ki?.addPorts){RT(Vi);for(let e=0,t=Ki.addPorts.length;e<t;e++){let r=Ki.addPorts[e];r.threadId=Ki.addThreadIds[e],RT(r)}setInterval(()=>{let e=process.memoryUsage();Vi.postMessage({type:VY,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},qSe).unref(),uw=a(()=>new Promise((e,t)=>{Vi.on("message",r),Vi.postMessage({type:$Y});function r(n){n.type===KY&&(Vi.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else uw=eW;ai.exports.getThreadInfo=uw;function RT(e,t){Ps.push(e),e.on("message",r=>{if(r.type===YY)r.port.threadId=r.threadId,RT(r.port);else if(r.type===NSe){let n=AT.get(r.id);n&&n()}else tW(r,e)}).on("close",()=>{Ps.splice(Ps.indexOf(e),1)}).on("exit",()=>{Ps.splice(Ps.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(RT,"addPort");function tW(e,t){for(let n of XY)n(e,t);let r=_w.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){Yi.error(s)}}a(tW,"notifyMessageListeners");if(Ew){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await gSe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(FY(s,o.name));try{for await(let{filename:o}of TSe(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await mw(),console.log("Reloaded HarperDB components, changed files:",Array.from(r)),r.clear()},100)}catch(o){console.warn("Error trying to watch component directory",s,o)}},"watch_dir");ai.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else Vi.on("message",async e=>{let{type:t}=e;t===vE.ITC_EVENT_TYPES.SHUTDOWN&&(ai.exports.restartNumber=e.restartNumber,Vi.unref(),setTimeout(()=>{Yi.warn("Thread did not voluntarily terminate",hSe),process.exit(0)},hw).unref())})});var dv={};je(dv,{AUDIT_STORE_OPTIONS:()=>Pf,Decoder:()=>Dc,HAS_CURRENT_RESIDENCY_ID:()=>tc,HAS_EXPIRATION_EXTENDED_TYPE:()=>o_,HAS_ORIGINATING_OPERATION:()=>i_,HAS_PREVIOUS_RESIDENCY_ID:()=>rc,REMOTE_SEQUENCE_UPDATE:()=>Kp,createAuditEntry:()=>Ml,getLastRemoved:()=>Yy,openAuditStore:()=>IT,readAuditEntry:()=>xt,removeAuditEntry:()=>wT,setAuditRetention:()=>VSe,transactionKeyEncoder:()=>dW});function IT(e){let t=e.auditStore=e.openDB(Sw.AUDIT_STORE_NAME,{create:!1,...Pf});t||(t=e.auditStore=e.openDB(Sw.AUDIT_STORE_NAME,Pf),nW(t,1)),t.rootStore=e;let r=[];t.addDeleteRemovalCallback=function(i,o){return r[i]=o,t.deleteCallbacks=r,{remove(){delete r[i]}}};let n=null;function s(i=yT){clearTimeout(n),n=setTimeout(async()=>{if(t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let o=0,c,l;try{for(let{key:u,value:d}of t.getRange({start:1,snapshot:!1,end:Date.now()-Tw}))if(c=wT(t,u,d),l=u,await new Promise(setImmediate),++o>=$Se){i=10;break}await c}finally{o===0?i=Math.min(i<<1,Tw/10):nW(t,l),s(i)}},i).unref()}if(a(s,"scheduleAuditCleanup"),t.scheduleAuditCleanup=s,(0,HE.getWorkerIndex)()===(0,HE.getWorkerCount)()-1&&s(yT),(0,HE.getWorkerIndex)()===0&&!rW)for(let i of t.getKeys({reverse:!0,limit:1}))i>Date.now()&&(rW=!0,NT.error("The current time is before the last recorded entry in the audit log. Time reversal can undermine the integrity of data tracking and certificate validation and the time must be corrected."));return t}function wT(e,t,r){if((KSe(r)&15)===gw){let n=xt(r),s=n.tableId;e.deleteCallbacks?.[s]?.(n.recordId)}return e.remove(t)}function nW(e,t){Aw[0]=t,e.put(Symbol.for("last-removed"),_W)}function Yy(e){let t=e.get(Symbol.for("last-removed"));if(t)return _W.set(t),Aw[0]}function VSe(e,t=yT){Tw=e,yT=t}function Ml(e,t,r,n,s,i,o,c,l,u,d,_,E){let f=fW[o];if(!f)throw new Error(`Invalid audit entry type ${o}`);let h=1;if(n&&(n>1?va.setFloat64(0,n):Ls.set(jg),h=9),l){if(l&16761087)throw new Error("Illegal extended type");h++}g(s),g(t),m(r),va.setFloat64(h,e),h+=8,l&tc&&g(u),l&rc&&g(d),l&o_&&(va.setFloat64(h,_),h+=8),l&i_&&g(EW[E]),i?m(i):Ls[h++]=0,l?va.setUint16(n?8:0,f|l|32768):Ls[n?8:0]=f;let T=Ls.subarray(0,h);if(c)return Buffer.concat([T,c]);return T;function m(S){let b=h;h+=1,h=(0,Sl.writeKey)(S,Ls,h);let I=h-b-1;I>127?I>16383?(NT.error("Key or username was too large for audit entry",S),h=b+1,Ls[b]=0):(Ls.copyWithin(b+2,b+1,h),va.setUint16(b,I|32768),h++):Ls[b]=I}function g(S){S<128?Ls[h++]=S:S<16384?(va.setUint16(h,S|32768),h+=2):S<1056964608?(va.setUint32(h,S|3221225472),h+=4):(Ls[h]=255,va.setUint32(h+1,S),h+=5)}}function KSe(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 Dc(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function xt(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new Dc(e.buffer,e.byteOffset,e.byteLength));n.position=t;let s;e[n.position]==66&&(s=n.readFloat64());let i=n.readInt(),o=n.readInt(),c=n.readInt(),l=n.readInt(),u=n.position,d=n.position+=l,_=n.readFloat64(),E,f,h,T;if(i&tc&&(E=n.readInt()),i&rc&&(f=n.readInt()),i&o_&&(h=n.readFloat64()),i&i_){let S=n.readInt();T=EW[S]}l=n.readInt();let m=n.position,g=n.position+=l;return{type:fW[i&7],tableId:c,nodeId:o,get recordId(){return(0,Sl.readKey)(e,u,d)},getBinaryRecordId(){return e.subarray(u,d)},version:_,previousLocalTime:s,get user(){return g>m?(0,Sl.readKey)(e,m,g):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(S,b,I){if(i&bT||i&BE&&!b)return S.decoder.decode(e.subarray(n.position,r));if(i&BE&&I)return Rw(S.getEntry(this.recordId),I,S)},getBinaryValue(){return i&(bT|BE)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:E,previousResidencyId:f,expiresAt:h,originatingOperation:T}}catch(n){return NT.error("Reading audit entry error",n,e),{}}}var Sl,OT,Sw,lW,HE,uW,NT,Ls,va,dW,Pf,Tw,$Se,Aw,_W,yT,rW,bT,BE,sW,gw,iW,oW,aW,cW,Kp,tc,rc,i_,o_,fW,EW,Dc,Ji=Ie(()=>{Sl=require("ordered-binary"),OT=L(se()),Sw=L(Ht()),lW=L(M()),HE=L(dt()),uW=L(te());Ul();NT=L(W());CT();(0,OT.initSync)();Ls=Buffer.alloc(1024),va=new DataView(Ls.buffer,Ls.byteOffset,1024),dW={writeKey(e,t,r){return e===s_?(t.set(s_,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,Sl.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,Sl.readKey)(e,t,r)}},Pf={encoding:"binary",keyEncoder:dW},Tw=(0,uW.convertToMS)((0,OT.get)(lW.CONFIG_PARAMS.LOGGING_AUDITRETENTION))||86400*3,$Se=1e3,Aw=new Float64Array(1),_W=new Uint8Array(Aw.buffer),yT=1e4,rW=!1;a(IT,"openAuditStore");a(wT,"removeAuditEntry");a(nW,"updateLastRemoved");a(Yy,"getLastRemoved");a(VSe,"setAuditRetention");bT=16,BE=32,sW=1,gw=2,iW=3,oW=4,aW=5,cW=6,Kp=11,tc=512,rc=1024,i_=2048,o_=4096,fW={put:sW|bT,[sW]:"put",delete:gw,[gw]:"delete",message:iW|bT,[iW]:"message",invalidate:oW|BE,[oW]:"invalidate",patch:aW|BE,[aW]:"patch",relocate:cW,[cW]:"relocate"},EW={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};a(Ml,"createAuditEntry");a(KSe,"readAction");a(xt,"readAuditEntry");Dc=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t;return t=this.getUint8(this.position++),t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch(t){throw t.message=`Error reading float64: ${t.message} at position ${this.position}`,t}}}});var yw={};je(yw,{add:()=>DT,applyReverse:()=>hW,getRecordAtTime:()=>Rw,rebuildUpdateBefore:()=>PT});function DT(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n+BigInt(r.value):isNaN(e[t])?e[t]=r.value:e[t]=n+r.value}function PT(e,t,r){let n=null;for(let s in e)if(s in t){let i=t[s];if(i?.__op__){let o=e[s];if(o?.__op__)if(o.__op__===i.__op__)n||(n={}),n[s]=o;else throw new Error("Can not merge updates with different operations");else n||(n={}),n[s]=o,DT(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function hW(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=YSe[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=pW}}function Rw(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),u=xt(l);switch(u.type){case"put":s=u.getValue(r);break;case"patch":hW(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===pW&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),u=xt(l),d;switch(u.type){case"put":d=u.getValue(r);break;case"patch":d=u.getValue(r);break}for(let _ in d)o[_]&&(s[_]=d[_],o[_]=!1,c--);i=u.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var YSe,pW,CT=Ie(()=>{Ji();a(DT,"add");DT.reverse=function(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n-BigInt(r.value):isNaN(e[t])||(e[t]=n-r.value)};YSe={add:DT};a(PT,"rebuildUpdateBefore");a(hW,"applyReverse");pW={};a(Rw,"getRecordAtTime")});function Zn(e){return e[_r]||(e[_r]=Object.create(null))}function BT(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let o of s){let c=o.name,l,u;if(o.resolve)u={get(){return o.resolve(this,this[Fe])},set(d){return o.set(this,d)},configurable:!0};else{switch(o.type){case"String":l=a(function(d){if(!(typeof d=="string"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a string, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"ID":l=a(function(d){if(!(typeof d=="string"||d?.length>0&&d.every?.(_=>typeof _=="string")||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a string, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Float":case"Number":l=a(function(d){let _=d?.__op__?d.value:d;if(!(typeof _=="number"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a number, attempt to assign ${_}`);Zn(this)[c]=d},"set");break;case"Int":l=a(function(d){let _=d?.__op__?d.value:d;if(!(_>>0===_||d==null&&o.nullable!==!1))if(typeof _=="number"&&Math.abs((_>>0)-_)<=1)_=Math.round(_),d?.__op__?d.value=_:d=_;else throw new Ms.ClientError(`${c} must be an integer between -2147483648 and 2147483647, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Long":l=a(function(d){let _=d?.__op__?d.value:d;if(!(Math.round(_)===d&&Math.abs(_)<=9007199254740992||d==null&&o.nullable!==!1))if(typeof _=="number"&&Math.abs(_)<=9007199254740992)_=Math.round(_),d?.__op__?d.value=_:d=_;else throw new Ms.ClientError(`${c} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"BigInt":l=a(function(d){let _=d?.__op__?d.value:d;if(!(typeof _=="bigint"||d==null&&o.nullable!==!1))if(typeof _=="string"||typeof _=="number")_=BigInt(_),d?.__op__?d.value=_:d=_;else throw new Ms.ClientError(`${c} must be a number, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Boolean":l=a(function(d){if(!(typeof d=="boolean"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a boolean, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Date":l=a(function(d){if(!(d instanceof Date||d==null&&o.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=new Date(d);else throw new Ms.ClientError(`${c} must be a Date, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Bytes":l=a(function(d){if(!(d instanceof Uint8Array||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a Buffer or Uint8Array, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Any":case void 0:l=a(function(d){Zn(this)[c]=d},"set");break;default:l=a(function(d){if(!(typeof d=="object"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be an object, attempt to assign ${d}`);Zn(this)[c]=d},"set")}u={get(){let d=this[_r];if(d&&c in d){let E=d[c];if(E?.__op__){let f=this[ve]?.[c];return E.update(f)}return E}let _=this[ve]?.[c];if(_&&typeof _=="object"){let E=SW(_,o);if(E)return d||(d=this[_r]=Object.create(null)),d[c]=E}return _},set:l,enumerable:!0,configurable:!0}}u.get.isAttribute=!0,n[c]=u,(!(c in r)||Object.getOwnPropertyDescriptor(r,c)?.get?.isAttribute)&&Object.defineProperty(r,c,u)}i("getProperty",function(o){let c=n[o];if(c)return c.get.call(this);let l=this[_r];return l?.[o]!==void 0?l[o]:this[ve]?.[o]}),i("set",function(o,c){let l=n[o];if(l)return l.set.call(this,c);if(t.sealed)throw new Ms.ClientError("Can not add a property to a sealed table schema");Zn(this)[o]=c}),i("deleteProperty",function(o){Zn(this)[o]=void 0}),i("toJSON",function(){let o=this[_r],c;for(let u in o){c||(c={...this[ve]});let d=o[u];if(d?.__op__){let _=c[u];d=d.update(_)}c[u]=d}return Object.keys(this).length>0&&(c||(c={...this[ve]}),Object.assign(c,this)),c||this[ve]}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty);function i(o,c){Object.defineProperty(r,o,{value:c,configurable:!0})}a(i,"setMethod")}function SW(e,t){let r;switch(e.constructor){case Object:return t?((r=t.TrackedObject)||(t.TrackedObject=r=class{static{a(this,"TrackedObject")}constructor(s){if(s?.[ve])throw new Error("Can not track an already tracked object, check for circular references");this[ve]=s}},BT(r,t)),new r(e)):new LT(e);case Array:let n=new UT(e.length);n[ve]=e;for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=SW(o,t?.elements)),n[s]=o}return n;default:return e}}function dp(e){let t=e[_r],r;for(let s in t){r||(r={...e[ve]});let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=dp(i);r[s]=i}return Object.keys(e).length>0&&(r||(r={...e[ve]}),Object.assign(r,e)),r||e[ve]}function gl(e,t=e[_r]){let r;if(mW.call(e,ve)&&e.constructor===Array&&!Object.isFrozen(e)){r=e;for(let n=0,s=e.length;n<s;n++){let i=e[n];if(i&&typeof i=="object"){let o=gl(i);o!==i&&r===e&&(r=e.slice(0)),i=o}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r={...e[ve]});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=yw[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=gl(s);r[n]=s}return r?Object.freeze(r):mW.call(e,ve)?e[ve]:e}function MT(e){let t=e[ve];if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[Tl]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.[ve]===s){if(MT(i))return!0}else return!0}}else{let r=e[_r];if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s[ve]===i){if(MT(s))return!0}else return!0}else return!0}}return!1}var Ms,_r,LT,mW,Tl,UT,vT,_p=Ie(()=>{Vs();Ms=L(_e());CT();_r=Symbol("own-data");a(Zn,"getChanges");a(BT,"assignTrackedAccessors");a(SW,"trackObject");LT=class{static{a(this,"GenericTrackedObject")}constructor(t){if(t?.[ve])throw new Error("Can not track an already tracked object, check for circular references");this[ve]=t}};BT(LT,{});a(dp,"collapseData");mW=Object.prototype.hasOwnProperty;a(gl,"updateAndFreeze");a(MT,"hasChanges");Tl=Symbol.for("has-array-changes"),UT=class extends Array{static{a(this,"TrackedArray")}[Tl];constructor(t){super(t)}splice(...t){return this[Tl]=!0,super.splice(...t)}push(...t){return this[Tl]=!0,super.push(...t)}pop(){return this[Tl]=!0,super.pop()}unshift(...t){return this[Tl]=!0,super.unshift(...t)}shift(){return this[Tl]=!0,super.shift()}};UT.prototype.constructor=Array;vT=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var _R={};je(_R,{CONTEXT:()=>Fe,ID_PROPERTY:()=>ze,IS_COLLECTION:()=>ci,MultiPartId:()=>xT,RECORD_PROPERTY:()=>ve,Resource:()=>Lr,snake_case:()=>jSe,transformForSelect:()=>kT});function jSe(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function TW(e,t){if(Al=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(Al=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new xT;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Al=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return Al=!0,null;e[e.length-1]==="/"&&(Al=!0)}return t.coerceId(decodeURIComponent(e))}function es(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,l,u,d;if(r?(o?(d=i,o=o[Fe]||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(d=s,c=d[this.primaryKey]??null,o=i[Fe]||i):d=i:(d=s,s=void 0,c=d[ze]??d[this.primaryKey]),c===null&&(u=!0)):i?o=i[Fe]||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="object"&&s){if(l=s,typeof(c=s.url)=="string"){let f=c.indexOf("?");if(f>-1){let T=this.parseQuery(c.slice(f+1));l?T&&(l=Object.assign(T,l)):l=T,c=c.slice(0,f)}let h=this.parsePath(c,o,l);h?.id!==void 0?(h.query&&(l?l=Object.assign(h.query,l):l=h.query),u=h.isCollection,c=h.id):c=h}else if(s[Symbol.iterator]){c=[],u=!0;for(let f of s){if(typeof f=="object"&&f)break;c.push(f)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=null,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new il(c),c==null&&(u=!0);o||(o={});let _;if(l?.ensureLoaded!=null||l?.async||u?(_={...t},l?.ensureLoaded!=null&&(_.ensureLoaded=l.ensureLoaded),l?.async&&(_.async=l.async),u&&(_.isCollection=!0)):_=t,o.transaction){let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)}else return Dt(o,()=>{let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)},_);function E(f){if(o.authorize){o.authorize=!1;let h=t.type==="read"?f.allowRead(o.user,l,o):t.type==="update"?f.doesExist?.()===!1?f.allowCreate(o.user,d,o):f.allowUpdate(o.user,d,o):t.type==="create"?f.allowCreate(o.user,d,o):f.allowDelete(o.user,l,o);if(h?.then)return h.then(T=>{if(!T)throw new HT(o.user);return typeof d?.then=="function"?d.then(m=>e(f,l,o,m)):e(f,l,o,d)});if(!h)throw new HT(o.user)}return typeof d?.then=="function"?d.then(h=>e(f,l,o,h)):e(f,l,o,d)}a(E,"authorizeActionOnResource")}}function ts(e,t){let r=new RW.ClientError(`The ${e.constructor.name} does not have a ${t} method implemented`,405);r.allow=[],r.method=t;for(let n of["get","put","post","delete","query","move","copy"])typeof e[n]=="function"&&r.allow.push(n);throw r}function bw(e,t,r){let n=e[ve];if(n){let s=e[_r];return i=>{let o,c;return e.hasOwnProperty(i)&&typeof(o=e[i])!="function"?o:s&&i in s?s[i]:(c=t?.[i])?c(e,r):n[i]}}else return t?s=>{let i=t[s];return i?i(e,r):e[s]}:s=>e[s]}function kT(e,t){let r=t?.propertyResolvers,n=t[Fe],s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):bw(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(c);let u=[],d=i(bw(l,r,n));for(let _ of e)u.push(d(_));return u},"transform");let o=e.forceNulls;return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(E=>E&&typeof E=="object"?c(E):E);let u={},d=i(bw(l,r,n)),_;for(let E of e){let f=d(E);f===void 0&&o&&(f=null),f?.then?(_||(_=[]),_.push(f.then(h=>u[E.name||E]=h))):u[E.name||E]=f}return _?Promise.all(_).then(()=>u):u},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(o){return c=>{if(typeof c=="string")return o(c);if(typeof c=="object")if(c.name){s||(s={});let l=s[c.name];if(!l){let d=r[c.name]?.definition?.tableClass;l=s[c.name]=kT(c.select||c,d)}let u=o(c.name);return l(u)}else return o(c);else return c}}a(i,"handleProperty")}var gW,AW,RW,Fe,ze,ci,ve,WSe,Lr,HT,Al,xT,Vs=Ie(()=>{gW=require("crypto");Pl();AW=L(fi()),RW=L(_e());_p();mc();_E();Fe=Symbol.for("context"),ze=Symbol.for("primary-key"),ci=Symbol("is-collection"),ve=Symbol("stored-record"),WSe={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Lr=class{static{a(this,"Resource")}static transactions;constructor(t,r){this[ze]=t;let n=r?.[Fe];this[Fe]=n!==void 0?n:r||null}static get=es(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let l;if((l=r?.select)&&c!=null&&!c.selectApplied){let u=kT(l,t.constructor);return typeof c?.map=="function"?c.map(u):u(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=es(function(t,r,n,s){if(Array.isArray(s)&&t[ci]){let i=[],o=n.authorize;for(let c of s){let l=t.constructor,u=l.getResource(c[l.primaryKey],n,{async:!0});u.then?i.push(u.then(d=>d.put(c,n))):i.push(u.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):ts(t,"put")},{hasContent:!0,type:"update"});static patch=es(function(t,r,n,s){return t.patch?t.patch(s,r):ts(t,"patch")},{hasContent:!0,type:"update"});static delete=es(function(t,r,n,s){return t.delete?t.delete(r):ts(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,gW.randomUUID)()}static create(t,r,n){let s;return t==null?s=r?.[this.primaryKey]??this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=r?.[this.primaryKey]??[...t,this.getNewId()]:typeof t!="object"?s=r?.[this.primaryKey]??[t,this.getNewId()]:(s=t?.[this.primaryKey]??this.getNewId(),n=r||{},r=t),n||(n={}),Dt(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):ts(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=es(function(t,r,n,s){return t.invalidate?t.invalidate(r):ts(t,"delete")},{hasContent:!1,type:"update"});static post=es(function(t,r,n,s){return t[ze]!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=es(function(t,r,n,s){return t.connect?t.connect(s,r):ts(t,"connect")},{hasContent:!0,type:"read"});static subscribe=es(function(t,r,n,s){return t.subscribe?t.subscribe(r):ts(t,"subscribe")},{type:"read"});static publish=es(function(t,r,n,s){return t[ze]!=null&&t.update?.(),t.publish?t.publish(s,r):ts(t,"publish")},{hasContent:!0,type:"create"});static search=es(function(t,r,n,s){let i=t.search?t.search(r):ts(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=kT(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=es(function(t,r,n,s){return t.search?t.search(s,r):ts(t,"search")},{hasContent:!0,type:"read"});static copy=es(function(t,r,n,s){return t.copy?t.copy(s,r):ts(t,"copy")},{hasContent:!0,type:"create"});static move=es(function(t,r,n,s){return t.move?t.move(s,r):ts(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this[ci])return(await this.constructor.create(this[ze],t,this[Fe]))[ze];ts(this,"post")}static isCollection(t){return t?.[ci]}static coerceId(t){return t}static parseQuery(t){return IS(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1);t=t.slice(0,s);let c=r?.headers&&WSe[o];if(c)r.requestedContentType=c;else if(n)n.property=o;else return{query:{property:o},id:TW(t,this),isCollection:Al}}let i=TW(t,this);return Al?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r[Fe],o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let u=l.asMap.get(t);if(s=u?.find(d=>d.constructor===c),s)return s;u||l.asMap.set(t,u=[]),u.push(s=new c(t,i))}else{if(s=l.find(u=>u[ze]===t&&u.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let u=new Map;for(let d of l){let _=d[ze],E=u.get(_);E?E.push(d):u.set(_,[d])}i.resourceCache.length=0,i.resourceCache.asMap=u}}}else s=new c(t,i);return o&&(s[ci]=!0),s}subscribe(t){return new Mn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new Mn}allowRead(t){return t?.role.permission.super_user}allowUpdate(t){return t?.role.permission.super_user}allowCreate(t){return t?.role.permission.super_user}allowDelete(t){return t?.role.permission.super_user}getId(){return this[ze]}getContext(){return this[Fe]}};Lr.prototype[Fe]=null;(0,AW._assignPackageExport)("Resource",Lr);a(jSe,"snake_case");HT=class extends Error{static{a(this,"AccessError")}constructor(t){t?(super("Unauthorized access to resource"),this.statusCode=403):(super("Must login"),this.statusCode=401)}};a(TW,"pathToId");xT=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(es,"transactional");a(ts,"missingMethod");a(bw,"selectFromObject");a(kT,"transformForSelect")});var GO={};je(GO,{EVICTED:()=>ya,INVALIDATED:()=>Ns,coerceType:()=>GT,makeTable:()=>VT,setServerUtilities:()=>nTe,updateResource:()=>qT});function VT(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:l,schemaDefined:u,dbisDB:d,sealed:_,splitSegments:E,replicate:f}=e,{expirationMS:h,evictionMS:T,audit:m,trackDeletes:g}=e,{attributes:S}=e;S||(S=[]);let b=Jg(i,n,l),I,B,H={},X=Promise.resolve(),Y,V,ne;for(let U of S)(U.assignCreatedTime||U.name==="__createdtime__")&&(Y=U),(U.assignUpdatedTime||U.name==="__updatedtime__")&&(V=U),U.expiresAt&&(ne=U),U.isPrimaryKey&&(H=U);let Q,de=[],j=[],ae=1,be=2,Oe={},Me={},Gr=864e5,Cd,ka,wn,Dd=!1,Ol,vw=new Map,jE=new Map,vt,Fa,Ga=bd.get(Us.CONFIG_PARAMS.REPLICATION_DATABASES);if(Array.isArray(Ga)){for(let U of Ga)if(U.name===c&&U.replicateTo>=0){Fa=U.replicateTo;break}}let vs=i.getRange({start:!1,end:!1}).constructor,Bs=10,zE=6;m&&ie();class Ve extends Lr{static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=m;static databasePath=o;static databaseName=c;static attributes=S;static replicate=f;static sealed=_;static splitSegments=E??!0;static createdTimeProperty=Y;static updatedTimeProperty=V;static propertyResolvers;static userResolvers={};static sources=[];static get expirationMS(){return h}static dbisDB=d;static schemaDefined=u;static sourcedFrom(p,A){if(A&&(this.sourceOptions=A,(A.expiration||A.eviction||A.scanInterval)&&this.setTTLExpiration(A)),A?.intermediateSource)p.intermediateSource=!0,this.sources.unshift(p);else{if(this.sources.some(O=>!O.intermediateSource)){if(this.sources.some(O=>O.name===p.name))return;throw new Error("Can not have multiple canonical (non-intermediate) sources")}this.sources.push(p)}B=B||p.get&&(!p.get.reliesOnPrototype||p.prototype.get),I=I||p.load;let w=a(O=>{let v=this.sources;if(v=v.filter(k=>k.intermediateSource&&k[O]&&(!k[O].reliesOnPrototype||k.prototype[O])),v.length>0)if(v.length===1){let k=v[0];return(C,F,x)=>{if(C?.source!==k)return k[O](F,x,C)}}else return(k,C,F)=>{let x=[];for(let q of v){if(k?.source===q)break;x.push(q[O](C,F,k))}return Promise.all(x)}},"getApplyToIntermediateSource"),R=this.sources[this.sources.length-1];R.intermediateSource&&(R={});let y=a(O=>{if(R[O]&&(!R[O].reliesOnPrototype||R.prototype[O]))return(v,k,C)=>{if(!v?.source)return R[O](k,C,v)}},"getApplyToCanonicalSource");Oe={put:y("put"),patch:y("patch"),delete:y("delete"),publish:y("publish")},Me={put:w("put"),patch:w("patch"),delete:w("delete"),publish:w("publish"),invalidate:w("invalidate")};let D=R.shouldRevalidateEvents;return(async()=>{let O=!1,v,k=a(async(C,F)=>{let x=C.value,q=C.table?We[c][C.table]:Ve;if(c===Us.SYSTEM_SCHEMA_NAME&&(C.table===Us.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||C.table===Us.SYSTEM_TABLE_NAMES.USER_TABLE_NAME)&&(O=!0),C.id===void 0&&(C.id=x[q.primaryKey],C.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(C));C.source=p;let ee={residencyId:tt(C.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:C.nodeId},G=await q.getResource(C.id,F,ee);switch(C.type){case"put":return D?G._writeInvalidate(ee):G._writeUpdate(x,!0,ee);case"patch":return D?G._writeInvalidate(ee):G._writeUpdate(x,!1,ee);case"delete":return G._writeDelete(ee);case"publish":return G._writePublish(x,ee);case"invalidate":return G._writeInvalidate(ee);case"relocate":return G._writeRelocate(ee);default:qe.default.error?.("Unknown operation",C.type,C.id)}},"writeUpdate");try{let C=p.subscribe;C&&g==null&&(g=!0);let F={crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0},x=p.subscribeOnThisThread?p.subscribeOnThisThread((0,Rl.getWorkerIndex)(),F):(0,Rl.getWorkerIndex)()===0,q=C&&x&&await p.subscribe?.(F);if(q){let ee;for await(let G of q)try{if(!(G.type==="transaction"?G.writes[0]:G)){qe.default.error?.("Bad subscription event",G);continue}if(G.source=p,G.type==="end_txn"){if(ee?.resolve(),G.localTime&&v!==G.localTime){if(G.remoteNodeIds?.length>0){let Ae=[Symbol.for("seq"),G.remoteNodeIds[0]],re=d.get(Ae),K=re?.nodes;K||(K=[]);for(let Be of G.remoteNodeIds.slice(1)){let we=K.find(ce=>ce.id===Be);K=K.filter(ce=>ce.id!==Be||ce===we),we||(we={id:Be,seqId:0},K.push(we)),we.seqId=Math.max(re?.seqId??1,G.localTime),Be===ee?.nodeId&&(we.lastTxnTime=G.timestamp)}let ge=Math.max(re?.seqId??1,G.localTime);qe.default.trace?.("Received txn",c,ge,G.localTime,G.remoteNodeIds),d.put(Ae,{seqId:ge,nodes:K})}v=G.localTime}G.onCommit&&ee?.committed.then(G.onCommit);continue}if(ee)if(G.beginTxn)ee.resolve();else{ee.write_promises.push(k(G,ee));continue}!G.timestamp&&G.version&&(G.timestamp=G.version);let Ee=Dt(G,()=>{if(G.type==="transaction"){let Ae=[];for(let re of G.writes)try{Ae.push(k(re,G))}catch(K){throw K.message+=" writing "+JSON.stringify(re)+" of event "+JSON.stringify(G),K}return Promise.all(Ae)}else if(G.type==="define_schema"){let Ae=this.attributes.slice(0),re;for(let K of G.attributes)Ae.find(ge=>ge.name===K.name)||(Ae.push(K),re=!0);re&&(Et({table:s,database:c,attributes:Ae,origin:"cluster"}),GE.signalSchemaChange(new qE.SchemaEventMsg(process.pid,Us.OPERATIONS_ENUM.CREATE_TABLE,c,s)))}else return G.beginTxn?(ee=G,ee.write_promises=[k(G,G)],new Promise(Ae=>{ee.resolve=()=>Ae(Promise.all(ee.write_promises))})):k(G,G)});ee&&(ee.committed=Ee),O&&Ee&&!Ee?.waitingForUserChange&&(Ee.then(()=>GE.signalUserChange(new qE.UserEventMsg(process.pid))),Ee.waitingForUserChange=!0),G.onCommit&&(Ee?Ee.then(G.onCommit):G.onCommit())}catch(Re){qe.default.error?.("error in subscription handler",Re)}}}catch(C){qe.default.error?.(C)}})(),this}static get isCaching(){return B}static get shouldRevalidateEvents(){return this.prototype.get!==Ve.prototype.get}static getResource(p,A,w){let R=super.getResource(p,A,w);if(p!=null){ji(p);try{if(R.hasOwnProperty(ve))return R;if(typeof p=="object"&&p&&!Array.isArray(p))throw new Error(`Invalid id ${JSON.stringify(p)}`);let y=!w?.async||i.cache?.get?.(p),D=Ir(A),O=D.getReadTxn();if(O?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return $a(p,A,{transaction:O,ensureLoaded:w?.ensureLoaded},y,v=>{if(v?qT(R,v):R[ve]=null,A.onlyIfCached&&A.noCacheStore){if(!R.doesExist())throw new Nr.ServerError("Entry is not cached",504)}else if(w?.ensureLoaded){let k=Pd(p,v,A,R);if(k)return D?.disregardReadTxn(),R[Ow]=!0,Iw(k,C=>(qT(R,C),R))}return R})}catch(y){throw y.message.includes("Unable to serialize object")&&(y.message+=": "+JSON.stringify(p)),y}}return R}ensureLoaded(){let p=Pd(this[ze],this[Fr],this[Fe]);if(p)return this[Ow]=!0,Iw(p,A=>{this[Fr]=A,this[ve]=A.value,this[kE]=A.version})}static getNewId(){let p=H?.type;if(p==="String"||p==="ID")return super.getNewId();if(!vt){let y=i.getEntry(Symbol.for("id_allocation")),D=y?.value,O;if(D&&D.nodeName===server.hostname&&(!iTe(i)||D.pid===process.pid)){let v=D.start,k=D.end;O=v;for(let C of i.getKeys({start:k,end:v,limit:1,reverse:!0}))O=C}else D=R(y?.version??null),O=D.start;vt=new BigInt64Array([BigInt(O)+1n]),vt=new BigInt64Array(i.getUserSharedBuffer("id",vt.buffer)),vt.maxSafeId=D.end}let A=Number(Atomics.add(vt,0,1n)),w=p==="Int"?512:1048576;if(A+w>=vt.maxSafeId){let y=a(D=>{vt.maxSafeId=A+(p==="Int"?1023:4194303);let O=(p==="Int"?Math.pow(2,31):Math.pow(2,49))-1,v=D?void 0:i.useReadTransaction(),k=Number(vt[0]);for(let x of i.getKeys({start:k+1,end:O,limit:1,transaction:v}))O=x;v?.done();let{value:C,version:F}=i.getEntry(Symbol.for("id_allocation"));if(vt.maxSafeId<O){if(C.end>vt.maxSafeId-100)return;qe.default.info?.("New id allocation",A,vt.maxSafeId,F),i.put(Symbol.for("id_allocation"),{start:C.start,end:vt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),F)}else{qe.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${vt.maxSafeId}, but id of ${O} detected`);let x=R(F);x.alreadyUpdated||Atomics.store(vt,0,BigInt(x.start+1)),vt.maxSafeId=x.end}},"updateEnd");A+w===vt.maxSafeId?setImmediate(y):A+100>=vt.maxSafeId&&(qe.default.warn?.(`Synchronous id allocation required on table ${s}${p=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>y(!0)))}return A;function R(y){let D=(p==="Int"?Math.pow(2,31):Math.pow(2,49))-1,O=D/4,v,k,C=!1,F,x;do{F=Math.floor(Math.random()*D),x={start:F,end:F+(p==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},v=0;for(let q of i.getKeys({start:F,limit:1,reverse:!0}))v=q;k=D;for(let q of i.getKeys({start:F+1,end:D,limit:1}))k=q;O*=.875,O<1e3&&!C&&(C=!0,qe.default.error?.(`Id allocation in table ${s} is very dense, limited safe range of numbers to allocate ids in${p==="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`,F,v,k,O))}while(!(O<k-F&&(O<F-v||v===0)));return i.transactionSync(()=>{let q=i.getEntry(Symbol.for("id_allocation"));return(q?.version??null)==y?(qe.default.info?.("Allocated new id range",x),i.put(Symbol.for("id_allocation"),x,Date.now()),x):(qe.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...q.value})})}}static setTTLExpiration(p){if(typeof p=="number")h=p*1e3,T||(T=0);else if(p&&typeof p=="object")h=p.expiration*1e3,T=(p.eviction||0)*1e3,Gr=p.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(h<0)throw new Error("Expiration can not be negative");Gr=Gr||(h+T)/4,xo()}static getResidencyRecord(p){return d.get([Symbol.for("residency_by_id"),p])}static setResidency(p){Ve.getResidency=p}static setResidencyById(p){Ve.getResidencyById=p}static getResidency(p,A,w){if(Ve.getResidencyById)return Ve.getResidencyById(p[t]);let R=Fa;if(A.replicateTo!=null){if(Array.isArray(A.replicateTo))return A.replicateTo.includes(server.hostname)?A.replicateTo:[server.hostname,...A.replicateTo];A.replicateTo>=0&&(R=A.replicateTo)}if(R>=0&&server.nodes){let y=[server.hostname];if(w)y.push(...w.slice(0,R));else{let D=server.nodes.map(k=>k.name),O=Math.floor(D.length*Math.random());y.push(...D.slice(O,O+R));let v=O+R-D.length;v>0&&y.push(...D.slice(0,v))}return y}}static enableAuditing(p=!0){m=p,p&&ie(),Ve.audit=p}static coerceId(p){return p===""?null:GT(p,H)}static async dropTable(){if(delete We[c][s],c===o){for(let p of S)d.remove(Ve.tableName+"/"+p.name),r[p.name]?.drop();d.remove(Ve.tableName+"/"),i.drop(),await d.committed}else console.log("legacy dropTable"),await i.close(),await fs.remove(data_path),await fs.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));GE.signalSchemaChange(new qE.SchemaEventMsg(process.pid,Us.OPERATIONS_ENUM.DROP_TABLE,c,s))}get(p){if(typeof p=="string")return this.getProperty(p);if(this[ci])return this.search(p);if(this[ze]===null){if(p?.conditions)return this.search(p);let A=Ve.getRecordCount();return{recordCount:A.recordCount,estimatedRecordRange:A.estimatedRange,records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:S}}if(p?.property)return this.getProperty(p.property);if(this.doesExist()||p?.ensureLoaded===!1||this[Fe]?.returnNonexistent)return this}allowRead(p,A){let w=Va(p);if(w?.read){if(w.isSuperUser)return!0;let R=w.attribute_permissions,y=A?.select;if(R?.length>0||Dd&&y){if(A||(A={}),y){let D=R?.length>0&&Nw(R,"read");A.select=y.map(O=>{let v=O.name||O;if(!D||D[v]){let k=wn[v]?.definition?.tableClass;if(k){if(O.name||(O={name:O}),!k.prototype.allowRead.call(null,p,O))return!1;if(!O.select)return O.name}return O}}).filter(Boolean)}else A.select=R.filter(D=>D.read&&!wn[D.attribute_name]).map(D=>D.attribute_name);return A}else return!0}}allowUpdate(p,A){let w=Va(p);if(w?.update){let R=w.attribute_permissions;if(R?.length>0){let y=Nw(R,"update");for(let D in A)if(!y[D])return!1;for(let D of R){let O=D.attribute_name;!D.update&&!(O in A)&&(A[O]=this.getProperty(O))}}return Ka(this[Fe])}}allowCreate(p,A){if(this[ci]){let w=Va(p);if(w?.insert){let R=w.attribute_permissions;if(R?.length>0){let y=Nw(R,"insert");for(let D in A)if(!y[D])return!1;return Ka(this[Fe])}else return Ka(this[Fe])}}else return this.allowUpdate(p,{})}allowDelete(p){return Va(p)?.delete&&Ka(this[Fe])}update(p,A){if(!Ir(this[Fe]))throw new Error("Can not update a table resource outside of a transaction");if(p===!1)return this;let R;return typeof p=="object"&&p&&(A?(Object.isFrozen(p)&&(p={...p}),this[ve]={},this[_r]=p):(R=this[_r],R&&(p=Object.assign(R,p)),this[_r]=R=p)),this._writeUpdate(this[_r],A),this}addTo(p,A){if(typeof A=="number"||typeof A=="bigint")this[xE]===bW?this.set(p,(+this.getProperty(p)||0)+A):(this[xE]||this.update(),this.set(p,new vT(A)));else throw new Error("Can not add a non-numeric value")}subtractFrom(p,A){if(typeof A=="number")return this.addTo(p,-A);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this[Fr]}invalidate(){this._writeInvalidate()}_writeInvalidate(p){let A=this[Fe],w=this[ze];ji(w),Ir(this[Fe]).addWrite({key:w,store:i,invalidated:!0,entry:this[Fr],before:Oe.invalidate?.bind(this,A,w),beforeIntermediate:Me.invalidate?.bind(this,A,w),commit:a((y,D)=>{if(di(y,D,p?.nodeId)<=0)return;let O=null;for(let v in r)O||(O={}),O[v]=this.getProperty(v);qe.default.trace?.(`Invalidating entry id: ${w}, timestamp: ${new Date(y).toISOString()}`),b(w,O,this[Fr],y,Ns,m,{user:A?.user,residencyId:p?.residencyId,nodeId:p?.nodeId},"invalidate")},"commit")})}_writeRelocate(p){let A=this[Fe],w=this[ze];ji(w),Ir(this[Fe]).addWrite({key:w,store:i,invalidated:!0,entry:this[Fr],before:Oe.relocate?.bind(this,A,w),beforeIntermediate:Me.relocate?.bind(this,A,w),commit:a((y,D)=>{if(di(y,D,p?.nodeId)<=0)return;let O=Ve.getResidencyRecord(p.residencyId),v=0,k=null,C=D?.value;if(O&&!O.includes(server.hostname)){for(let F in r)k||(k={}),k[F]=C(F);v=Ns}else k=C;qe.default.trace?.(`Relocating entry id: ${w}, timestamp: ${new Date(y).toISOString()}`),b(w,k,this[Fr],y,v,m,{user:A.user,residencyId:p.residencyId,nodeId:p.nodeId,expiresAt:p.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(p,A){let w={previousResidency:this.getResidencyRecord(p.residencyId),isRelocation:!0},R=this.getResidency(A.value,w),y;if(R){if(!Array.isArray(R))throw new Error("Residency must be an array, but was: "+R);if(!R.includes(server.hostname))return;y=tt(R)}let O=b(p.key,A.value,p,p.version,0,!0,{residencyId:y,expiresAt:A.expiresAt},"relocate",!1,null)}static evict(p,A,w){let R=this.Source,y;if(!((B||m)&&(!A||(y=i.getEntry(p),!y||!A)||y.version!==w))){if(B){if(i.hasLock(p,y.version))return;let D;for(let O in r)D||(D={}),D[O]=A[O];if(D)return b(p,D,y,w,ya,null,null,null,!0)}return i.ifVersion(p,w,()=>{qa(p,A,null)}),m?b(p,null,y,w,ya,null,null,null,!0):i.remove(p,w)}}lock(){throw new Error("Not yet implemented")}static operation(p,A){return p.table||=s,p.schema||=c,LW.operation(p,A)}put(p){this.update(p,!0)}patch(p){this.update(p,!1)}_writeUpdate(p,A,w){let R=this[Fe],y=Ir(R),D=this[ze];ji(D);let O=this[Fr];this[xE]=A?bW:eTe;let v={key:D,store:i,entry:O,nodeName:R?.nodeName,validate:a(k=>{p||(p=this[_r]),A||p&&MT(this[_r]===p?this:p)?R?.source||(y.checkOverloaded(),this.validate(p,!A),V&&(p[V.name]=V.type==="Date"?new Date(k):V.type==="String"?new Date(k).toISOString():k),A&&(t&&p[t]!==D&&(p[t]=D),Y&&(O?.value?p[Y.name]=O?.value[Y.name]:p[Y.name]=Y.type==="Date"?new Date(k):Y.type==="String"?new Date(k).toISOString():k),p=gl(p))):y.removeWrite(v)},"validate"),before:A?Oe.put?()=>Oe.put(R,D,p):null:Oe.patch?()=>Oe.patch(R,D,p):Oe.put?()=>Oe.put(R,D,gl(this)):null,beforeIntermediate:A?Me.put?()=>Me.put(R,D,p):null:Me.patch?()=>Me.patch(R,D,p):Me.put?()=>Me.put(R,D,gl(this)):null,commit:a((k,C,F)=>{if(F){if(R&&C?.version>(R.lastModified||0)&&(R.lastModified=C.version),this[Fr]=C,C?.value?.[ve])throw new Error("Can not assign a record to a record, check for circular references");A||(this[ve]=C?.value??null)}this[_r]=void 0,this[kE]=k;let x=C?.value,q=p;this[xE]=0;let ee=di(k,C,w?.nodeId),G;if(ee<=0)if(m){let K=C.localTime,ge=C.version;qe.default.trace?.("Applying CRDT update to record with id: ",D,"applying later update:",ge);let Be=[];for(;K>k||ge>=k&&K>0;){let we=l.get(K);if(!we)break;let ce=xt(we);if(ge=ce.version,ge>=k){if(ge===k){if(ee=di(k,{version:ge,localTime:K},w?.nodeId),ee===0)return;if(ee>0)continue}if(ce.type==="patch")Be.push(ce),G=p;else if(ce.type==="put"||ce.type==="delete")return}K=ce.previousLocalTime}Be.sort((we,ce)=>we.version-ce.version);for(let we of Be){let ce=we.getValue(i);if(q=PT(q,ce,A),qe.default.debug?.("Rebuilding update with future patch:",q),!q)return}}else{if(A)return;q=PT(q,x,A),qe.default.debug?.("Rebuilding update without audit:",q)}let Re;if(A?Re=q:(this[ve]=x,Re=gl(this,q)),this[ve]=Re,Re?.[ve])throw new Error("Can not assign a record to a record, check for circular references");let Ee;if(w?.residencyId!=null)Ee=w.residencyId;else{O?.residencyId&&(R.previousResidency=Ve.getResidencyRecord(O.residencyId));let K=Ve.getResidency(Re,R);if(K){if(!Array.isArray(K))throw new Error("Residency must be an array, got: "+K);K.includes(server.hostname)||K.push(server.hostname)}Ee=tt(K)}A||(G=p);let Ae=R?.expiresAt??(h?h+Date.now():-1);qe.default.trace?.(`Saving record with id: ${D}, timestamp: ${new Date(k).toISOString()}${Ae?", expires at: "+new Date(Ae).toISOString():""}${C?", replaces entry from: "+new Date(C.version).toISOString():", new entry"}`,Re),qa(D,x,Re);let re=A?"put":"patch";b(D,Re,C,k,0,m,{user:R?.user,residencyId:Ee,expiresAt:Ae,nodeId:w?.nodeId,originatingOperation:R?.originatingOperation},re,!1,G),R.expiresAt&&xo()},"commit")};y.addWrite(v)}async delete(p){if(typeof p=="string")return this.deleteProperty(p);if(this[ci]){for await(let A of this.search(p))(await Ve.getResource(A[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(p);return}return this[ve]?this._writeDelete(p):!1}_writeDelete(p){let A=Ir(this[Fe]),w=this[ze];ji(w);let R=this[Fe];return A.addWrite({key:w,store:i,resource:this,nodeName:R?.nodeName,before:Oe.delete?.bind(this,R,w),beforeIntermediate:Me.delete?.bind(this,R,w),commit:a((y,D,O)=>{let v=D?.value;O&&(R&&D?.version>(R.lastModified||0)&&(R.lastModified=D.version),qT(this,D)),!(di(y,D,p?.nodeId)<=0)&&(qa(this[ze],v),qe.default.trace?.(`Deleting record with id: ${w}, txn timestamp: ${new Date(y).toISOString()}`),m||g?(b(w,null,this[Fr],y,0,m,{user:R?.user,nodeId:p?.nodeId},"delete"),m||xo()):i.remove(this[ze]))},"commit")}),!0}search(p){let A=this[Fe],w=Ir(A);if(!p)throw new Error("No query provided");let R=p.conditions;R?R.length===void 0&&(R=R[Symbol.iterator]?Array.from(R):[R]):R=Array.isArray(p)?p:p[Symbol.iterator]?Array.from(p):[],this[ze]&&(R=[{attribute:null,comparator:Array.isArray(this[ze])?"prefix":"starts_with",value:this[ze]}].concat(R));let y,D={};function O(K,ge){let Be;switch(ge){case"and":case void 0:if(K.length<1)throw new Error('An "and" operator requires at least one condition');Be=!0;break;case"or":if(K.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+ge)}for(let we of K){if(we.conditions){we.conditions=O(we.conditions,we.operator);continue}let ce=we[0]??we.attribute,Ye=ce==null?H:Bi(S,ce);if(Ye)(Ye.type||DN[we.comparator])&&(we[1]===void 0?we.value=k(we.value,Ye):we[1]=k(we[1],Ye));else if(ce!=null)throw(0,Nr.handleHDBError)(new Error,`${ce} is not a defined attribute`,404);if(we.chainedConditions)if(we.chainedConditions.length===1&&(!we.operator||we.operator=="and")){let rt=we.chainedConditions[0],Ze,st;if(rt.comparator==="gt"||rt.comparator==="greater_than"||rt.comparator==="ge"||rt.comparator==="greater_than_equal"?(Ze=we,st=rt):(Ze=rt,st=we),Ze.comparator!=="lt"&&Ze.comparator!=="less_than"&&Ze.comparator!=="le"&&Ze.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let Bt=st.comparator==="ge"||st.comparator==="greater_than_equal",ko=Ze.comparator==="le"||Ze.comparator==="less_than_equal";we.comparator=(Bt?"ge":"gt")+(ko?"le":"lt"),we.value=[st.value,Ze.value]}else throw new Error("Multiple chained conditions are not currently supported")}return K}a(O,"prepareConditions");function v(K,ge){if(p.enforceExecutionOrder)return K;for(let Be of K)Be.conditions&&(Be.conditions=v(Be.conditions,Be.operator));return K.length>1&&ge!=="or"?(0,DW.sortBy)(K,NS(Ve)):K}a(v,"orderConditions");function k(K,ge){return Array.isArray(K)?K.map(Be=>GT(Be,ge)):GT(K,ge)}a(k,"coerceTypedValues");let C=p.operator;(R.length>0||C)&&(R=O(R,C));let F=typeof p.sort=="object"&&p.sort,x;if(F&&C!=="or"){let K=F.attribute;if(K==null)throw new Nr.ClientError("Sort requires an attribute");if(y=R.find(ge=>nd(ge.attribute)===nd(K)),!y){let ge=Bi(S,K);if(!ge)throw(0,Nr.handleHDBError)(new Error,`${Array.isArray(K)?K.join("."):K} is not a defined attribute`,404);if(ge.indexed)y={attribute:K,comparator:"sort"},R.push(y);else if(R.length===0&&!p.allowFullScan)throw(0,Nr.handleHDBError)(new Error,`${Array.isArray(K)?K.join("."):K} is not indexed and not combined with any other conditions`,404)}y&&(y.descending=!!F.descending)}R=v(R,C),F&&(y&&R[0]===y?F.next&&(x={dbOrderedAttribute:F.attribute,attribute:F.next.attribute,descending:F.next.descending,next:F.next.next}):(y&&R.splice(R.indexOf(y),1),x=F));let q=p.select;if(R.length===0&&(R=[{attribute:t,comparator:"greater_than",value:!0}]),p.explain)return{conditions:R,operator:C,postOrdering:x,selectApplied:!!q};let ee=w.useReadTxn(),G=PN(R,C,Ve,ee,p,A,(K,ge)=>Ld(K,q,A,ee,ge),D),Re=p.ensureLoaded!==!1;x||(G=re(G));let Ee=Ve.transformEntryForSelect(q,A,ee,D,Re,!0),Ae=Ve.transformToOrderedSelect(G,q,x,ee,A,Ee);function re(K){return p.offset||p.limit!==void 0?K.slice(p.offset,p.limit!==void 0?(p.offset||0)+p.limit:void 0):K}return a(re,"applyOffset"),x&&(Ae=re(Ae)),Ae.onDone=()=>{Ae.onDone=null,w.doneReadTxn()},Ae.selectApplied=!0,Ae.getColumns=()=>{if(q){let K=[];for(let ge of q)ge==="*"?K.push(...S.map(Be=>Be.name)):K.push(ge.name||ge);return K}return S.filter(K=>!K.computed&&!K.relationship).map(K=>K.name)},Ae}static transformToOrderedSelect(p,A,w,R,y,D){let O=new vs;if(w){p=Ld(p,A,R,y,null);let v;O.iterate=function(){let C,F=p[Symbol.asyncIterator]?p[Symbol.asyncIterator]():p[Symbol.iterator](),x,q=w.dbOrderedAttribute,ee,G,Re=!0;function Ee(re){let K=re.next&&Ee(re.next),ge=re.descending;return(Be,we)=>{let ce=Nl(Be,re.attribute,R),Ye=Nl(we,re.attribute,R),rt=ge?(0,yl.compareKeys)(Ye,ce):(0,yl.compareKeys)(ce,Ye);return rt===0?K?.(Be,we)||0:rt}}a(Ee,"createComparator");let Ae=Ee(w);return{async next(){let re;if(C)if(re=C.next(),re.done){if(x)return O.onDone&&O.onDone(),re}else return{value:await D.call(this,re.value)};v=[],ee&&v.push(ee);do if(re=await F.next(),re.done){if(x=!0,v.length)break;return O.onDone&&O.onDone(),re}else{let K=re.value;if(K?.then&&(K=await K),q){let ge=Nl(K,q,R);if(Re)Re=!1,G=ge;else if(ge!==G){G=ge,ee=K;break}}v.push(K)}while(!0);return w.isGrouped,v.sort(Ae),C=v[Symbol.iterator](),re=C.next(),re.done?(O.onDone&&O.onDone(),re):{value:await D.call(this,re.value)}},return(){O.onDone&&O.onDone(),F.return()},throw(){O.onDone&&O.onDone(),F.throw()}}};let k=a(C=>{if(typeof A=="object"&&Array.isArray(C.attribute))for(let F=0;F<A.length;F++){let x=A[F],q;if(x.name===C.attribute[0]){for(q=x.sort||(x.sort={});q.next;)q=q.next;q.attribute=C.attribute.slice(1),q.descending=C.descending}else x===C.attribute[0]&&(A[F]=q={name:x,sort:{attribute:C.attribute.slice(1),descending:C.descending}})}C.next&&k(C.next)},"applySortingOnSelect");k(w)}else O.iterate=(p[Symbol.asyncIterator]||p[Symbol.iterator]).bind(p),O=O.map(function(v){try{let k=D.call(this,v);return typeof k?.catch=="function"?k.catch(C=>{throw C.partialObject={[t]:v.key},C}):k}catch(k){throw k.partialObject={[t]:v.key},k}});return O}static transformEntryForSelect(p,A,w,R,y,D){if(p&&(p===t||p?.length===1&&p[0]===t&&Array.isArray(p))){let C=a(F=>(A?.transaction?.stale&&(A.transaction.stale=!1),F?.key??F),"transform");return p===t?C:p.asArray?F=>[C(F)]:F=>({[t]:C(F)})}let O;y&&B&&!(typeof p=="string"?[p]:p)?.every(C=>{let F;return typeof C=="object"?F=C.name:F=C,r[F]||F===t})&&(O=!0);let v,k=a(function(C){let F;if(A?.transaction?.stale&&(A.transaction.stale=!1),C!=null){if(F=C.value||C.deref?.()?.value,!F&&(C.key===void 0||C.deref)||C.metadataFlags&Ns){if(C.metadataFlags&Ns&&A.replicateFrom===!1&&D&&C.residencyId)return Ba.SKIP;if(C=$a(C.key??C,A,{transaction:w,lazy:p?.length<4,ensureLoaded:y},this?.isSync,x=>x),C?.then)return C.then(k.bind(this));F=C?.value}if(O&&C?.metadataFlags&(Ns|ya)||C?.expiresAt!=null&&C?.expiresAt<Date.now()){if(A.onlyIfCached&&A.noCacheStore)return{[t]:C.key,message:"This entry has expired"};let x=Pd(C.key??C,C,A);if(x?.then)return x.then(k)}}if(F==null)return D?Ba.SKIP:F;if(p&&!(p[0]==="*"&&p.length===1)){let x,q=a((G,Re)=>{let Ee;typeof G=="object"?Ee=G.name:Ee=G;let Ae=wn?.[Ee],re;if(Ae){let K=R?.[Ee];if(K)if(K.hasMappings){let Be=Ae.from?F[Ae.from]:nd(C.key);re=K.get(Be),re||(re=[])}else re=K.fromRecord?.(F);else re=Ae(F,A,C);let ge=a(Be=>{if(Be&&typeof Be=="object"){let we=Ae.definition?.tableClass||Ve;v||(v={});let ce=v[Ee]||(v[Ee]=we.transformEntryForSelect(Ee===G?null:G.select||(Array.isArray(G)?G:null),A,w,K,y));if(Array.isArray(Be)){let Ye=[],rt=we.transformToOrderedSelect(Be,G.select,typeof G.sort=="object"&&G.sort,A,w,ce)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),Ze=a(Bt=>{for(;!Bt.done;){if(Bt?.then)return Bt.then(Ze);Ye.push(Bt.value),Bt=rt.next()}Re(Ye,Ee)},"nextValue"),st=Ze(rt.next());st&&(x||(x=[]),x.push(st));return}else if(Be=ce.call(this,Be),Be?.then){x||(x=[]),x.push(Be.then(Ye=>Re(Ye,Ee)));return}}Re(Be,Ee)},"handleResolvedValue");re?.then?(x||(x=[]),x.push(re.then(ge))):ge(re);return}else re=F[Ee],re&&typeof re=="object"&&Ee!==G&&(re=Ve.transformEntryForSelect(G.select||G,A,w,null)({value:re}));Re(re,Ee)},"selectAttribute"),ee;if(typeof p=="string")q(p,G=>{ee=G});else if(Array.isArray(p))if(p.asArray)ee=[],p.forEach((G,Re)=>{G==="*"?p[Re]=F:q(G,Ee=>ee[Re]=Ee)});else{ee={};let G=p.forceNulls;for(let Re of p)if(Re==="*")for(let Ee in F)ee[Ee]=F[Ee];else q(Re,(Ee,Ae)=>{Ee===void 0&&G&&(Ee=null),ee[Ae]=Ee})}else throw new Nr.ClientError("Invalid select"+p);return x?Promise.all(x).then(()=>ee):ee}return F},"transform");return k}async subscribe(p){if(!l)throw new Error("Can not subscribe to a table without an audit log");m||Et({table:s,database:c,schemaDefined:u,attributes:S,audit:!0}),p||(p={});let A=!p.rawEvents,w=[],R=this,y=py(Ve,this[ze]??null,function(O,v,k,C){try{let F=v.getValue?.(i,A),x=v.type;if(!F&&x==="patch"&&A){let ee=i.getEntry(O);ee?.version===v.version?F=ee.value:F=v.getValue?.(i,!0,k),x="put"}let q={id:O,localTime:k,value:F,version:v.version,type:x,beginTxn:C};w?w.push(q):this.send(q)}catch(F){qe.default.error?.(F)}},p.startTime||0,p),D=(async()=>{this[ci]&&(y.includeDescendants=!0,p.onlyChildren&&(y.onlyChildren=!0)),p.supportsTransactions&&(y.supportsTransactions=!0);let O=this[ze],v=p.previousCount;v>1e3&&(v=1e3);let k=p.startTime;if(this[ci]){if(k){if(v)throw new Nr.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:C,value:F}of l.getRange({start:k,exclusiveStart:!0,snapshot:!1})){let x=xt(F);if(x.tableId!==n)continue;let q=x.recordId;if(O==null||wW(O,q)){let ee=x.getValue(i,A,C);if(y.send({id:q,localTime:C,value:ee,version:x.version,type:x.type}),y.queue?.length>NW&&await y.waitForDrain()===!1)return}y.startTime=C}}else if(v){let C=[];for(let{key:F,value:x}of l.getRange({start:"z",end:!1,reverse:!0}))try{let q=xt(x);if(q.tableId!==n)continue;let ee=q.recordId;if(O==null||wW(O,ee)){let G=q.getValue(i,A,F);if(C.push({id:ee,localTime:F,value:G,version:q.version,type:q.type}),--v<=0)break}}catch(q){qe.default.error("Error getting history entry",F,q)}for(let F=C.length;F>0;)y.send(C[--F]);C[0]&&(y.startTime=C[0].localTime)}else if(!p.omitCurrent){for(let{key:C,value:F,version:x,localTime:q}of i.getRange({start:O??!1,end:O==null?void 0:[O,yl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(F&&(y.send({id:C,localTime:q,value:F,version:x,type:"put"}),y.queue?.length>NW&&await y.waitForDrain()===!1))return}}else{v&&!k&&(k=0);let C=this[Fr]?.localTime;if(C===Qg&&(i.cache?.delete(O),this[Fr]=i.getEntry(O),qe.default.trace?.("re-retrieved record",C,this[Fr]?.localTime),C=this[Fr]?.localTime),qe.default.trace?.("Subscription from",k,"from",O,C),k<C){let F=[],x=C;do{let q=l.get(x);if(q){p.omitCurrent=!0;let ee=xt(q),G=ee.getValue(i,A,x);A&&(ee.type="put"),F.push({id:O,value:G,localTime:x,...ee}),x=ee.previousLocalTime}else break;v&&v--}while(x>k&&v!==0);for(let q=F.length;q>0;)y.send(F[--q]);y.startTime=C}!p.omitCurrent&&this.doesExist()&&y.send({id:O,localTime:C,value:this[ve],version:this[kE],type:"put"})}for(let C of w)y.send(C);w=null})();return p.listener&&y.on("data",p.listener),y}static subscribeOnThisThread(p,A){return p===0||A?.crossThreads===!1}doesExist(){return!!(this[ve]||this[xE])}publish(p,A){this._writePublish(p,A)}_writePublish(p,A){let w=Ir(this[Fe]),R=this[ze]||null;R!=null&&ji(R);let y=this[Fe];w.addWrite({key:R,store:i,entry:this[Fr],nodeName:y?.nodeName,validate:a(()=>{y?.source||(w.checkOverloaded(),this.validate(p))},"validate"),before:Oe.publish?.bind(this,y,R,p),beforeIntermediate:Me.publish?.bind(this,y,R,p),commit:a((D,O,v)=>{O===void 0&&g&&!m&&xo(),qe.default.trace?.(`Publishing message to id: ${R}, timestamp: ${new Date(D).toISOString()}`),b(R,O?.value??null,O,O?.version||D,0,!0,{user:y?.user,residencyId:A?.residencyId,expiresAt:y?.expiresAt,nodeId:A?.nodeId},"message",!1,p)},"commit")})}validate(p,A){let w,R=a((y,D,O)=>{if(D.type&&y!=null)if(A&&y.__op__&&(y=y.value),D.properties){typeof y!="object"&&(w||(w=[])).push(`Value ${li(y)} in property ${O} must be an object${D.type?" ("+D.type+")":""}`);let v=D.properties;for(let k=0,C=v.length;k<C;k++){let F=v[k],x=R(y[F.name],F,O+"."+F.name);x&&(y[F.name]=x)}if(D.sealed&&y!=null&&typeof y=="object")for(let k in y)v.find(C=>C.name===k)||(w||(w=[])).push(`Property ${k} is not allowed within object in property ${O}`)}else switch(D.type){case"Int":(typeof y!="number"||y>>0!==y)&&(w||(w=[])).push(`Value ${li(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))&&(w||(w=[])).push(`Value ${li(y)} in property ${O} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof y!="number"&&(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a number`);break;case"ID":typeof y=="string"||y?.length>0&&y.every?.(v=>typeof v=="string")||(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a string, or an array of strings`);break;case"String":typeof y!="string"&&(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a string`);break;case"Boolean":typeof y!="boolean"&&(w||(w=[])).push(`Value ${li(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);(w||(w=[])).push(`Value ${li(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);(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a bigint`)}break;case"Bytes":y instanceof Uint8Array||(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a Buffer or Uint8Array`);break;case"array":if(Array.isArray(y)){if(D.elements)for(let v=0,k=y.length;v<k;v++){let C=y[v],F=R(C,D.elements,O+"[*]");F&&(y[v]=F)}}else(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a Buffer or Uint8Array`);break}D.nullable===!1&&y==null&&(w||(w=[])).push(`Property ${O} is required (and not does not allow null values)`)},"validateValue");for(let y=0,D=S.length;y<D;y++){let O=S[y];if(!(O.relationship||O.computed)&&(!A||O.name in p)){let v=R(p[O.name],O,O.name);v&&(p[O.name]=v)}}if(_)for(let y in p)S.find(D=>D.name===y)||(w||(w=[])).push(`Property ${y} is not allowed`);if(w)throw new Nr.ClientError(w.join(". "))}getUpdatedTime(){return this[kE]}wasLoadedFromSource(){return B?!!this[Ow]:void 0}static async addAttributes(p){let A=S.slice(0);for(let w of p){if(!w.name)throw new Nr.ClientError("Attribute name is required");if(w.name.match(/[`/]/))throw new Nr.ClientError("Attribute names cannot include backticks or forward slashes");(0,PW.validateAttribute)(w.name),A.push(w)}return Et({table:s,database:c,schemaDefined:u,attributes:A}),Ve.indexingOperation}static async removeAttributes(p){let A=S.filter(w=>!p.includes(w.name));return Et({table:s,database:c,schemaDefined:u,attributes:A}),Ve.indexingOperation}static getSize(){let p=i.getStats();return(p.treeBranchPageCount+p.treeLeafPageCount+p.overflowPages)*p.pageSize}static getAuditSize(){let p=l?.getStats();return p&&(p.treeBranchPageCount+p.treeLeafPageCount+p.overflowPages)*p.pageSize}static getRecordCount(p){let A=i.getStats().entryCount,w=1e3/2,R=performance.now(),y=Math.floor(A/2),D=p?.exactCount,O=0,v=0,k;for(let{value:C}of i.getRange({start:!0,lazy:!0}))if(C!=null&&O++,v++,!D&&v<y&&performance.now()-R>w){k=v;break}if(k){let C=O;O=0;for(let{value:re}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:k}))re!=null&&O++;let F=k*2,x=(O+C)/F,q=Math.pow((O-C+1)/k/2,2)+x*(1-x)/F,ee=Math.max(Math.sqrt(q)*A,1),G=Math.round(x*A),Re=Math.max(G-1.96*ee,O+C),Ee=Math.min(G+1.96*ee,A),Ae=Math.pow(10,Math.round(Math.log10(ee)));return Ae>G&&(Ae=Ae/10),O=Math.round(G/Ae)*Ae,{recordCount:O,estimatedRange:[Math.round(Re),Math.round(Ee)]}}return{recordCount:O}}static updatedAttributes(){wn=this.propertyResolvers={$id:a((p,A,w)=>({value:w.key}),"$id"),$updatedtime:a((p,A,w)=>w.version,"$updatedtime"),$record:a((p,A,w)=>w?{value:p}:p,"$record")};for(let p of this.attributes){p.resolve=null;let A=p.relationship,w=p.computed;if(A)if(p.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),w&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),Dd=!0,A.to)p.elements?.definition?(wn[p.name]=p.resolve=(R,y,D)=>{let O=R[A.from?A.from:t],v=p.elements.definition.tableClass;return D?rd({attribute:A.to,value:O},Ir(y).getReadTxn(),!1,v,!1).asArray:v.search([{attribute:A.to,value:O}],y).asArray},p.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},p.resolve.definition=p.elements.definition,A.from&&(p.resolve.from=A.from)):console.error(`The one-to-many/many-to-many relationship property "${p.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(A.from){let R=p.definition||p.elements?.definition;R?(wn[p.name]=p.resolve=(y,D,O)=>{let v=y[A.from];if(v!==void 0){if(p.elements){let k,C=v?.map(F=>{let x=O?R.tableClass.primaryStore.getEntry(F,{transaction:Ir(D).getReadTxn()}):R.tableClass.get(F,D);return x?.then&&(k=!0),x});return A.filterMissing?k?Promise.all(C).then(F=>F.filter(CW)):C.filter(CW):k?Promise.all(C):C}return O?R.tableClass.primaryStore.getEntry(v,{transaction:Ir(D).getReadTxn()}):R.tableClass.get(v,D)}},p.set=(y,D)=>{if(Array.isArray(D)){let O=D.map(v=>v[ze]||v[R.tableClass.primaryKey]);y[A.from]=O}else{let O=D[ze]||D[R.tableClass.primaryKey];y[A.from]=O}},p.resolve.definition=p.definition||p.elements?.definition,p.resolve.from=A.from):console.error(`The relationship property "${p.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${p.name}" in table "${s}" must use either "from" or "to" arguments`);else w&&(typeof w.from=="function"&&this.setComputedAttribute(p.name,w.from),wn[p.name]=p.resolve=(R,y,D)=>{let O=typeof w.from=="string"?R[w.from]:R,v=this.userResolvers[p.name];if(v)return v(O,y,D);qe.default.warn(`Computed attribute "${p.name}" does not have a function assigned to it. Please use setComputedAttribute('${p.name}', resolver) to assign a resolver function.`),this.userResolvers[p.name]=()=>{}})}BT(this,this)}static setComputedAttribute(p,A){let w=Bi(S,p);if(!w){console.error(`The attribute "${p}" does not exist in the table "${s}"`);return}if(!w.computed){console.error(`The attribute "${p}" is not defined as computed in the table "${s}"`);return}this.userResolvers[p]=A}static async deleteHistory(p=0,A=!1){let w;for(let{key:R,value:y}of l.getRange({start:0,end:p}))await yd(),xt(y).tableId===n&&(w=wT(l,R,y));if(A)for(let{key:R,value:y,localTime:D}of i.getRange({start:0,versions:!0}))await yd(),y===null&&D<p&&(w=i.remove(R));await w}static async*getHistory(p=0,A=1/0){for(let{key:w,value:R}of l.getRange({start:p||1,end:A})){await yd();let y=xt(R);y.tableId===n&&(yield{id:y.recordId,localTime:w,version:y.version,type:y.type,value:y.getValue(i,!0,w),user:y.user,operation:y.originatingOperation})}}static async getHistoryOfRecord(p){let A=[];if(p==null)throw new Error("An id is required");let w=i.getEntry(p);if(!w)return A;let R=w.localTime;if(!R)throw new Error("The entry does not have a local audit time");let y=0;do{await yd();let D=l.get(R);if(D){let O=xt(D);A.push({id:O.recordId,localTime:R,version:O.version,type:O.type,value:O.getValue(i,!0,R),user:O.user}),R=O.previousLocalTime}else break}while(y<1e3&&R);return A.reverse()}static cleanup(){Q?.remove()}}Ve.updatedAttributes();let ss=Ve.prototype;return ss[ZSe]=!0,h&&Ve.setTTLExpiration(h/1e3),ne&&Se(),Ve;function qa(U,p,A){let w;for(let R in r){let y=r[R],D=y.isIndexing,O=wn[R],v=A&&(O?O(A):A[R]),k=p&&(O?O(p):p[R]);if(v===k&&!D)continue;w=!0;let C=y.indexNulls,F=(0,FE.getIndexedValues)(v,C),x=(0,FE.getIndexedValues)(k,C);if(x?.length>0){let q=new Set(x);if(F=F?F.filter(ee=>{if(q.has(ee))q.delete(ee);else return!0}):[],x=Array.from(q),(x.length>0||F.length>0)&&yW){let ee=x.concat(F).map(G=>({key:G,value:U}));y.prefetch(ee,IW)}for(let ee=0,G=x.length;ee<G;ee++)y.remove(x[ee],U)}else F?.length>0&&yW&&y.prefetch(F.map(q=>({key:q,value:U})),IW);if(F)for(let q=0,ee=F.length;q<ee;q++)y.put(F[q],U)}return w}a(qa,"updateIndices");function ji(U){switch(typeof U){case"number":return!0;case"string":if(U.length<659)return!0;if(U.length>OW)throw new Error("Primary key size is too large: "+U.length);break;case"object":if(U===null)throw new Error("Invalid primary key of null");break;case"bigint":if(U<2n**64n&&U>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof U)}if((0,yl.writeKey)(U,tTe,0)>OW)throw new Error("Primary key size is too large: "+U.length);return!0}a(ji,"checkValidId");function $a(U,p,A,w,R){if(Ve.getResidencyById&&A.ensureLoaded&&p?.replicateFrom!==!1){let D=Ve.getResidencyById(U);if(D&&!D.includes(server.hostname)&&I)return I({key:U,residency:D}).then(R)}let y=a(()=>{if(p?.transaction?.stale&&(p.transaction.stale=!1),A.transaction?.isDone)return R(null,U);let D=i.getEntry(U,A);return D?.residencyId&&D.metadataFlags&Ns&&I&&A.ensureLoaded&&p?.replicateFrom!==!1?I(D).then(O=>R(O,U)):(D&&p&&(D?.version>(p.lastModified||0)&&(p.lastModified=D.version),D?.localTime&&!p.lastRefreshed&&(p.lastRefreshed=D.localTime)),R(D,U))},"whenPrefetched");return w?y():ae>0?(ae--,y()):new Promise((D,O)=>{ae===0?(ae--,i.prefetch([U],()=>{v(),k()})):(de.push(U),j.push(k),de.length>zE&&(ae--,v()));function v(){if(de.length>0){let C=j;i.prefetch(de,()=>{ae===-1?v():ae++;for(let F of C)F()}),de=[],j=[],be>2&&be--}else ae=be,be<Bs&&be++}a(v,"prefetch");function k(){try{D(y())}catch(C){O(C)}}a(k,"load")})}a($a,"loadLocalRecord");function Va(U){if(!U?.role)return;let p=U.role.permission;if(p.super_user)return rTe;let A=p[c],w,R=A?.tables;if(R)return R[s];if(c==="data"&&(w=p[s])&&!w.tables)return w}a(Va,"getTablePermissions");function Pd(U,p,A,w){if(B){let R=!1;if(A.noCache?R=!0:(p?(!p.value||p.metadataFlags&(Ns|ya)||p.expiresAt!=null&&p.expiresAt<Date.now())&&(R=!0):R=!0,qn(!R,"cache-hit",s)),R){let y=Md(U,p,A).then(D=>(D?.value?.[ve]&&qe.default.error?.("Can not assign a record with a record property"),A&&(D?.version>(A.lastModified||0)&&(A.lastModified=D.version),A.lastRefreshed=Date.now()),D));if(A?.onlyIfCached||p?.value&&w?.allowStaleWhileRevalidate?.(p,U)){if(y.catch(D=>qe.default.warn?.(D)),A?.onlyIfCached&&!w.doesExist())throw new Nr.ServerError("Entry is not cached",504);return}else return y}}else if(p?.value&&p.expiresAt!=null&&p.expiresAt<Date.now())return Ve.evict(p.key,p.value,p.version),p.value=null,{then(R){return R(p)}}}a(Pd,"ensureLoadedFromSource");function Ir(U){let p=U?.transaction;if(p){if(!p.lmdbDb)return p.lmdbDb=i,p;do{if(p.lmdbDb?.path===i.path)return p;let A=p.next;if(!A)return p=p.next=new pc,p.lmdbDb=i,p;p=A}while(!0)}else return new cp}a(Ir,"txnForContext");function Nl(U,p,A){if(!U)return;let w=U.value||i.getEntry(U.key)?.value;if(typeof p=="object"){let y=wn,D=w;for(let O=0,v=p.length;O<v;O++){let k=p[O],C=y?.[k];D=C&&D?C(D,A,!0)?.value:D?.[k],y=C?.definition?.tableClass?.propertyResolvers}return D}let R=wn[p];return R?R(w,A):w[p]}a(Nl,"getAttributeValue");function Ld(U,p,A,w,R){let y=R?.length,D={transaction:w,lazy:y>0||typeof p=="string"||p?.length<4,alwaysPrefetch:!0},O;function v(k,C){let F=k?.value;if(!F)return Ba.SKIP;for(let x=0;x<y;x++)if(!O?.includes(x)&&!R[x](F,k))return Ba.SKIP;return C!==void 0&&(k.key=C),k}if(a(v,"processEntry"),y>0||!U.hasEntries){let k=U.map(C=>{if(O=null,typeof C=="object"&&C?.key!==void 0)return y>0?v(C):C;if(C==null)return Ba.SKIP;for(let F=0;F<y;F++){let q=R[F].idFilter;if(q){if(!q(C))return Ba.SKIP;O||(O=[]),O.push(F)}}return $a(C,A,D,!1,v)});return Array.isArray(U)&&(k=k.filter(C=>C!==Ba.SKIP)),k.hasEntries=!0,k}return U}a(Ld,"transformToEntries");function di(U,p,A=server.replication?.getThisNodeId(l)){if(U<=p?.version){if(p?.version===U&&A!==void 0){let w=server.replication?.exportIdMapping(l),R=p.localTime,y=R&&l.get(R);if(y){let D,O,v=xt(y);for(let k in w)w[k]===A&&(D=k),w[k]===v.nodeId&&(O=k);if(D>O)return 1;if(D===O)return 0}}return-1}return 1}a(di,"precedesExistingVersion");async function Md(U,p,A){let w=p?.metadataFlags,R=p?.version,y,D;if(!i.attemptLock(U,R,()=>{clearTimeout(D);let C=i.getEntry(U);!C||!C.value||C.metadataFlags&(Ns|ya)?y(Md(U,i.getEntry(U),A)):y(C)}))return new Promise(C=>{y=C,D=setTimeout(()=>{i.unlock(U,R)},XSe)});let O=p?.value,v={requestContext:A,replacingRecord:O,replacingEntry:p,replacingVersion:R,noCacheStore:!1,source:null,resourceCache:A?.resourceCache},k=A?.responseHeaders;return new Promise((C,F)=>{let x;Iw(Dt(v,async q=>{let ee=performance.now(),G,Re,Ee;try{for(let ge of Ve.sources)if(ge.get&&(!ge.get.reliesOnPrototype||ge.prototype.get)){if(ge.available?.(p)===!1)continue;if(v.source=ge,G=await ge.get(U,v),G)break}Ee=w&Ns;let re=v.lastModified||Ee&&R;Re=Ee||re>R||!O,re||(re=(0,FE.getNextMonotonicTime)());let K=performance.now()-ee;if(pr(K,"cache-resolution",s,null,"success"),k&&Bm(k,"Server-Timing",`cache-resolve;dur=${K.toFixed(2)}`,!0),q.timestamp=re,h&&v.expiresAt==null&&(v.expiresAt=Date.now()+h),G){if(typeof G!="object")throw new Error("Only objects can be cached and stored in tables");if(G.status>0&&G.headers)if(G.status>=300)if(G.status===304)G=O,re=R;else throw new Nr.ServerError(G.body||"Error from source",G.status);else G=G.body;typeof G.toJSON=="function"&&(G=G.toJSON()),t&&G[t]!==U&&(G[t]=U)}x=!0,C({key:U,version:re,value:G})}catch(re){re.message+=` while resolving record ${U} for ${s}`,O&&((re.code==="ECONNRESET"||re.code==="ECONNREFUSED"||re.code==="EAI_AGAIN")&&!A?.mustRevalidate||A?.staleIfError&&(re.statusCode===500||re.statusCode===502||re.statusCode===503||re.statusCode===504))?(C({key:U,version:R,value:O}),qe.default.trace?.(re.message,"(returned stale record)")):F(re);let K=performance.now()-ee;pr(K,"cache-resolution",s,null,"fail"),k&&Bm(k,"Server-Timing",`cache-resolve;dur=${K.toFixed(2)}`,!0),v.transaction.abort();return}if(A?.noCacheStore||v.noCacheStore){v.transaction.abort();return}Ir(v).addWrite({key:U,store:i,entry:p,nodeName:"source",commit:a((re,K)=>{if(K?.version!==R)return;let ge=qa(U,O,G);G?(Me.put?.(v,U,G),qe.default.trace?.(`Writing resolved record from source with id: ${U}, timestamp: ${new Date(re).toISOString()}`),b(U,G,K,re,0,m&&Re||null,{user:v?.user,expiresAt:v.expiresAt},"put",!!Ee)):K&&(Me.delete?.(v,U),qe.default.trace?.(`Deleting resolved record from source with id: ${U}, timestamp: ${new Date(re).toISOString()}`),m||g?b(U,null,K,re,0,m&&Re||null,{user:v?.user},"delete",!!Ee):i.remove(U,R))},"commit")})}),()=>{i.unlock(U,R)},q=>{i.unlock(U,R),x&&qe.default.error?.("Error committing cache update",q)})})}a(Md,"getFromSource");function Ka(U){if(!U||U.user?.role?.permission?.super_user)return!0;if(U.replicateTo)throw new Nr.ClientError("Can not specify replication parameters without super user permissions",403);if(U.replicatedConfirmation)throw new Nr.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}a(Ka,"checkContextPermissions");function xo(){if(Gr!==Cd&&(Cd=Gr,(0,Rl.getWorkerIndex)()===(0,Rl.getWorkerCount)()-1)){if(ka&&clearTimeout(ka),!Gr)return;let U=new Date;U.setMonth(0),U.setDate(1),U.setHours(0),U.setMinutes(0),U.setSeconds(0);let p=Math.ceil((Date.now()-U.getTime())/Gr)*Gr+U.getTime(),A=a(w=>{qe.default.trace?.(`Scheduled next cleanup scan at ${new Date(w)}ms`),ka=setTimeout(()=>X=X.then(async()=>{if(A(Math.max(w+Gr,Date.now())),i.rootStore.status!=="open"){clearTimeout(ka);return}let R=50,y=new Array(R),D=0;qe.default.info?.(`Starting cleanup scan for ${s}`);try{let O=0;for(let{key:v,value:k,version:C,expiresAt:F}of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let x;k===null&&!m&&C+JSe<Date.now()?x=i.remove(v,C):F!=null&&F+T<Date.now()&&(x=Ve.evict(v,k,C),O++),x&&(await y[D],y[D]=x.catch(q=>{qe.default.error?.("Cleanup error",q)}),++D>=R&&(D=0)),await yd()}qe.default.info?.(`Finished cleanup scan for ${s}, evicted ${O} entries`)}catch(O){qe.default.warn?.(`Error in cleanup scan for ${s}:`,O)}}),Math.min(w-Date.now(),2147483647)).unref()},"startNextTimer");A(p)}}a(xo,"scheduleCleanup");function ie(){Q=l?.addDeleteRemovalCallback(n,U=>{let p=i.getEntry(U);p?.value===null&&i.remove(U,p.version)})}a(ie,"addDeleteRemoval");function Se(){(0,Rl.getWorkerIndex)()===0&&setInterval(async()=>{if(!Ol){Ol=!0;try{let U=ne.name,p=r[U];if(!p)throw new Error(`expiresAt attribute ${ne} must be indexed`);for(let A of p.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let w of p.getValues(A)){let R=i.getEntry(w);R?.value?R.value[U]<Date.now()&&Ve.evict(w,R.value,R.version):i.ifVersion(w,R?.version,()=>p.remove(A,w))}await yd()}}catch(U){qe.default.error?.("Error in evicting old records",U)}finally{Ol=!1}}},QSe).unref()}a(Se,"runRecordExpirationEviction");function tt(U){if(U){let p=U.join(","),A=d.get([Symbol.for("residency_by_set"),p]);return A||(d.put([Symbol.for("residency_by_set"),p],A=Math.floor(Math.random()*2147483647)),d.put([Symbol.for("residency_by_id"),A],U),A)}}a(tt,"getResidencyId")}function Nw(e,t){let r=e.attr_object||(e.attr_object={}),n=r[t];if(n)return n;n=r[t]=Object.create(null);for(let s of e)n[s.attribute_name]=s[t];return n}function IW(){}function nTe(e){LW=e}function GT(e,t){let r=t?.type;if(e===null)return e;if(e===""&&r&&r!=="String"&&r!=="Any")return null;try{switch(r){case"Int":case"Long":if(e[0]==="$")return FT(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return FT(+e);case"Float":return e==="null"?null:FT(+e);case"BigInt":return e==="null"?null:BigInt(e);case"Boolean":return e==="true"?!0:e==="false"?!1:e;case"Date":if(isNaN(e)){if(e==="null")return null;sTe.test(e)||(e+="Z");let n=new Date(e);return FT(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,$T.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function FT(e){if(isNaN(e))throw new SyntaxError;return e}function wW(e,t){if(e==null)return!0;if(!Array.isArray(t))return e===t||t.startsWith?.(e);if(Array.isArray(e)){let r=e.length;if(e[r-1]===null&&r--,t.length>=r){for(let n=0;n<r;n++)if(t[n]!==e[n])return!1;return!0}return!1}else if(t[0]===e)return!0}function Iw(e,t,r){return e?.then?e.then(t,r):t(e)}function qT(e,t){e[Fr]=t,e[ve]=t?.value??null,e[kE]=t?.version}function CW(e){return e!=null}function li(e){try{return JSON.stringify(e)}catch{return e}}function iTe(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var Us,Ba,FE,DW,PW,bd,Nr,GE,qE,qe,yl,Rl,$T,zSe,LW,QSe,JSe,yW,XSe,kE,ZSe,Fr,xE,bW,eTe,Ow,Ns,ya,tTe,OW,NW,rTe,QMe,sTe,yd,$f=Ie(()=>{Us=L(M()),Ba=require("lmdb"),FE=L(cn()),DW=require("lodash"),PW=L(Xd());Vs();lp();bd=L(se());my();Nr=L(_e()),GE=L(no()),qE=L(qs());Pe();_E();qe=L(bc());_p();mc();yl=require("ordered-binary"),Rl=L(dt());Ji();$T=L(te());Ul();Ni();CT();Bf();zSe=new Uint8Array(9);zSe[8]=192;QSe=6e4,JSe=864e5;bd.initSync();yW=bd.get(Us.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),XSe=1e4,kE=Symbol.for("version"),ZSe=Symbol.for("incremental-update"),Fr=Symbol("entry"),xE=Symbol("is-saving"),bW=1,eTe=2,Ow=Symbol("loaded-from-source"),Ns=1,ya=8,tTe=Buffer.allocUnsafeSlow(8192),OW=1978,NW=100,rTe={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},QMe=(0,$T.convertToMS)(bd.get(Us.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(VT,"makeTable");a(Nw,"attributesAsObject");a(IW,"noop");a(nTe,"setServerUtilities");sTe=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(GT,"coerceType");a(FT,"rejectNaN");a(wW,"isDescendantId");yd=a(()=>new Promise(setImmediate),"rest");a(Iw,"when");a(qT,"updateResource");a(CW,"exists");a(li,"stringify");a(iTe,"hasOtherProcesses")});var lt={};je(lt,{database:()=>zl,databases:()=>We,dropDatabase:()=>xR,dropTableMeta:()=>uTe,getDatabases:()=>ut,getDefaultCompression:()=>Lm,getTables:()=>oTe,onRemovedDB:()=>sf,onUpdatedTable:()=>Pc,readMetaDb:()=>$E,resetDatabases:()=>xu,table:()=>Et,tables:()=>jn});function oTe(){return jT||ut(),jn||{}}function ut(){if(jT)return We;jT=!0,Id=new Map;let e=(0,er.getHdbBasePath)()&&(0,Ut.join)((0,er.getHdbBasePath)(),yr.DATABASES_DIR_NAME),t=(0,er.get)(yr.CONFIG_PARAMS.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,er.get)(yr.CONFIG_PARAMS.STORAGE_PATH)||e&&((0,rs.existsSync)(e)?e:(0,Ut.join)((0,er.getHdbBasePath)(),yr.LEGACY_DATABASES_DIR_NAME)),!e)return;if((0,rs.existsSync)(e))for(let n of(0,rs.readdirSync)(e,{withFileTypes:!0})){let s=(0,Ut.basename)(n.name,".mdb");n.isFile()&&(0,Ut.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&$E((0,Ut.join)(e,n.name),null,s)}if((0,rs.existsSync)((0,Nd.getBaseSchemaPath)())){for(let n of(0,rs.readdirSync)((0,Nd.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,Ut.join)((0,Nd.getBaseSchemaPath)(),n.name),i=(0,Ut.join)((0,Nd.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,rs.readdirSync)(s,{withFileTypes:!0}))if(o.isFile()&&(0,Ut.extname)(o.name).toLowerCase()===".mdb"){let c=(0,Ut.join)(i,o.name);$E((0,Ut.join)(s,o.name),(0,Ut.basename)(o.name,".mdb"),n.name,c,!0)}}}if(t)for(let n in t){let s=t[n],i=s.path;if((0,rs.existsSync)(i))for(let c of(0,rs.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,Ut.extname)(c.name).toLowerCase()===".mdb"&&$E((0,Ut.join)(i,c.name),(0,Ut.basename)(c.name,".mdb"),n);let o=s.tables;if(o)for(let c in o){let l=o[c],u=(0,Ut.join)(l.path,(0,Ut.basename)(c+".mdb"));(0,rs.existsSync)(u)&&$E(u,c,n,null,!0)}}for(let n in We){let s=Id.get(n);if(s){let i=We[n];n.includes("delete")&&Vt.trace(`defined tables ${Array.from(s.keys())}`);for(let o in i)s.has(o)||(Vt.trace(`delete table class ${o}`),delete i[o])}else if(delete We[n],n==="data"){for(let i in jn)delete jn[i];delete jn[zT]}}let r=["hdb_temp","hdb_certificate","hdb_analytics","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if(We.system)for(let n of r)We.system[n]&&(We.system[n].replicate=!1);return Id=null,We}function xu(){jT=!1;for(let[,e]of Ha)e.needsDeletion=!0;ut();for(let[e,t]of Ha)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),Ha.delete(e),delete We[t.databaseName],KE.forEach(r=>r(t.databaseName)));return We}function $E(e,t,r=Dw,n,s){let i=new ww.default(e,!1);try{let o=Ha.get(e);o?o.needsDeletion=!1:(o=(0,wd.open)(i),Ha.set(e,o));let c=new bl.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(KT.INTERNAL_DBIS_NAME,c)),u=o.auditStore;u||(n?(0,rs.existsSync)(n)&&(i.path=n,u=(0,wd.open)(i),u.isLegacy=!0):u=IT(o));let d=BW(r),_=d[zT],E=new Map;for(let{key:f,value:h}of l.getRange({start:!1})){let[T,m]=f.toString().split("/");m===""?m=h.name:m||(m=T,T=t,h.name||(h.name=m,h.indexed=!h.is_hash_attribute)),_?.add(T);let g=E.get(T);g||E.set(T,g={attributes:[]}),(m==null||h.is_hash_attribute)&&(g.primary=h),m!=null&&g.attributes.push(h),Object.defineProperty(h,"key",{value:f,configurable:!0})}for(let[f,h]of E){let{attributes:T,primary:m}=h;if(!m){for(let j of T)if(j.is_hash_attribute||j.isPrimaryKey){m=j;break}if(!m){Vt.warn(`Unable to find a primary key attribute on table ${f}, with attributes: ${JSON.stringify(T)}`);continue}}let g=d[f],S={},b=[],I,B,H=typeof m.audit=="boolean"?m.audit:(0,er.get)(yr.CONFIG_PARAMS.LOGGING_AUDITLOG),X=m.trackDeletes,Y=m.expiration,V=m.eviction,ne=m.sealed,Q=m.splitSegments,de=m.replicate;if(g)S=g.indices,b=g.attributes,g.schemaVersion++;else{I=m.tableId,I?I>=(l.get(Od)||0)&&(l.putSync(Od,I+1),Vt.info(`Updating next table id (it was out of sync) to ${I+1} for ${f}`)):(m.tableId=I=l.get(Od),I||(I=1),Vt.debug("Table {table_name} missing an id, assigning {table_id}"),l.putSync(Od,I+1),l.putSync(m.key,m));let j=new bl.default(!m.is_hash_attribute,m.is_hash_attribute);if(j.compression=m.compression,j.compression){let ae=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||vW;j.compression.threshold=ae}B=Nh(o.openDB(m.key,j)),o.databaseName=r,B.rootStore=o,B.tableId=I}for(let j of T){j.attribute=j.name;try{if(!j.is_hash_attribute&&(j.indexed||j.attribute&&!j.name)){if(!S[j.name]){let be=new bl.default(!j.is_hash_attribute,j.is_hash_attribute);S[j.name]=o.openDB(j.key,be),S[j.name].indexNulls=j.indexNulls}let ae=b.find(be=>be.name===j.name);ae?b.splice(b.indexOf(ae),1,j):b.push(j)}}catch(ae){Vt.error("Error trying to update attribute",j,b,S,ae)}}if(!g){g=HW(d,f,VT({primaryStore:B,auditStore:u,audit:H,sealed:ne,splitSegments:Q,replicate:de,expirationMS:Y&&Y*1e3,evictionMS:V&&V*1e3,trackDeletes:X,tableName:f,tableId:I,primaryKey:m.name,databasePath:s?r+"/"+f:r,databaseName:r,indices:S,attributes:T,schemaDefined:m.schemaDefined,dbisDB:l})),g.schemaVersion=1;for(let j of VE)j(g)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function BW(e){let t=We[e];if(t||(e==="data"?t=We[e]=jn:e==="system"?Object.defineProperty(We,"system",{value:t=Object.create(null),configurable:!0}):t=We[e]=Object.create(null)),Id&&!Id.has(e)){let r=new Set;t[zT]=r,Id.set(e,r)}return t}function HW(e,t,r){return e[t]=r,r}function zl({database:e,table:t}){e||(e=Dw),ut();let r=BW(e),n=(0,Ut.join)((0,er.getHdbBasePath)(),yr.DATABASES_DIR_NAME),s=(0,er.get)(yr.CONFIG_PARAMS.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,er.get)(yr.CONFIG_PARAMS.STORAGE_PATH)||((0,rs.existsSync)(n)?n:(0,Ut.join)((0,er.getHdbBasePath)(),yr.LEGACY_DATABASES_DIR_NAME));let o=(0,Ut.join)(n,(i?t:e)+".mdb"),c=Ha.get(o);if(!c||c.status==="closed"){let l=new ww.default(o,!1);c=(0,wd.open)(l),Ha.set(o,c)}return c.auditStore||(c.auditStore=IT(c)),c}async function xR(e){if(!We[e])throw new Error("Schema does not exist");let t=We[e],r;for(let n in t)r=t[n].primaryStore.rootStore,Ha.delete(r.path),r.status==="open"&&(await r.close(),await YE.remove(r.path));if(r||(r=zl({database:e,table:null}),r.status==="open"&&(await r.close(),await YE.remove(r.path))),e==="data"){for(let n in jn)delete jn[n];delete jn[zT]}delete We[e],KE.forEach(n=>n(e))}function Et(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:o,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:_,schemaDefined:E,origin:f}=e;r||(r=Dw);let h=zl({database:r,table:t}),T=We[r];Vt.trace(`Defining ${t} in ${r}`);let m=T?.[t];if(h.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let g,S,b;E==null&&(E=!0);let I=new bl.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 B,H;if(m){if(g=m.primaryKey,m.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);u==null&&(u=m.splitSegments),m.attributes.splice(0,m.attributes.length,...o)}else{let Q=h.auditStore;S=o.find(be=>be.isPrimaryKey)||{},g=S.name,S.is_hash_attribute=S.isPrimaryKey=!0,S.schemaDefined=E,S.compression=Lm(),_&&(S.trackDeletes=!0),c=S.audit=typeof c=="boolean"?c:(0,er.get)(yr.CONFIG_PARAMS.LOGGING_AUDITLOG),n&&(S.expiration=n),s&&(S.eviction=s),S.splitSegments=!1,typeof l=="boolean"&&(S.sealed=l),typeof d=="boolean"&&(S.replicate=d),f&&(S.origins?S.origins.includes(f)||S.origins.push(f):S.origins=[f]),Vt.trace(`${t} table loading, opening primary store`);let de=new bl.default(!1,!0);de.compression=S.compression;let j=t+"/";if(b=h.dbisDb=h.openDB(KT.INTERNAL_DBIS_NAME,I),ne(),b.get(j))return H&&H(),xu(),Et(e);let ae=Nh(h.openDB(j,de));h.databaseName=r,ae.rootStore=h,ae.tableId=b.get(Od),Vt.trace(`Assigning new table id ${ae.tableId} for ${t}`),ae.tableId||(ae.tableId=1),b.put(Od,ae.tableId+1),S.tableId=ae.tableId,m=HW(T,t,VT({primaryStore:ae,auditStore:Q,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:_,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:g,tableName:t,tableId:ae.tableId,databasePath:r,databaseName:r,indices:{},attributes:o,schemaDefined:E,dbisDB:b})),m.schemaVersion=1,B=!0,b.put(j,S)}let X=m.indices;b=b||(h.dbisDb=h.openDB(KT.INTERNAL_DBIS_NAME,I)),m.dbisDB=b;let Y=[];for(let{key:Q,value:de}of b.getRange({start:!0})){let[j,ae]=Q.toString().split("/");if(ae===""&&(ae=de.name),ae){if(j!==t)continue}else continue;let be=o.find(Me=>Me.name===ae),Oe=!be?.indexed&&de.indexed&&!de.isPrimaryKey;if((!be||Oe)&&(ne(),B=!0,be||b.remove(Q),Oe)){let Me=m.indices[j];Me&&Y.push(Me)}}let V=[];try{for(let Q of o||[]){if((Q.relationship||Q.computed)&&(B=!0,Q.relationship))continue;let de=t+"/"+(Q.name||"");Object.defineProperty(Q,"key",{value:de,configurable:!0});let j=b.get(de);if(Q.isPrimaryKey){if(j=j||b.get(de=t+"/")||{},c!==void 0&&c!==m.audit||l!==void 0&&l!==m.sealed||d!==void 0&&d!==m.replicate||(+n||void 0)!==(+j.expiration||void 0)||(+s||void 0)!==(+j.eviction||void 0)){let be={...j};typeof c=="boolean"&&(c&&m.enableAuditing(c),be.audit=c),n&&(be.expiration=+n),s&&(be.eviction=+s),l!==void 0&&(be.sealed=l),d!==void 0&&(be.replicate=d),B=!0,ne(),b.put(de,be)}continue}j?.attribute&&!j.name&&(j.indexed=!0);let ae=!j||j.type!==Q.type||j.indexed!==Q.indexed||j.nullable!==Q.nullable||j.version!==Q.version||JSON.stringify(j.properties)!==JSON.stringify(Q.properties)||JSON.stringify(j.elements)!==JSON.stringify(Q.elements);if(Q.indexed){let be=new bl.default(!0,!1),Oe=h.openDB(de,be);(ae||j.indexingPID&&j.indexingPID!==process.pid||j.restartNumber<WE.workerData?.restartNumber)&&(B=!0,ne(),j=b.get(de),(ae||j.indexingPID&&j.indexingPID!==process.pid||j.restartNumber<WE.workerData?.restartNumber)&&(B=!0,Q.indexNulls===void 0&&(Q.indexNulls=!0),m.primaryStore.getStats().entryCount>0&&(Q.lastIndexedKey=j?.lastIndexedKey??void 0,Q.indexingPID=process.pid,Oe.isIndexing=!0,Object.defineProperty(Q,"dbi",{value:Oe}),V.push(Q))),b.put(de,Q)),j?.indexNulls&&Q.indexNulls===void 0&&(Q.indexNulls=!0),Oe.indexNulls=Q.indexNulls,X[Q.name]=Oe}else ae&&(B=!0,ne(),b.put(de,Q))}}finally{H&&H()}if(B&&(m.schemaVersion++,m.updatedAttributes()),Vt.trace(`${t} table loading, running index`),V.length>0||Y.length>0?m.indexingOperation=lTe(m,V,Y):B&&YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"schema-change",m.databaseName,m.tableName)),m.origin=f,B)for(let Q of VE)Q(m,f!=="cluster");return(n||s||i)&&m.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),Vt.trace(`${t} table loaded`),m;function ne(){H||h.transactionSync(()=>({then(Q){H=Q}}))}a(ne,"startTxn")}async function lTe(e,t,r){try{Vt.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o={},c=0,l=t.length;if(await new Promise(u=>setImmediate(u)),l>0){let u;for(let _ of t)(0,wd.compareKeys)(_.lastIndexedKey,u)<0&&(u=_.lastIndexedKey),_.lastIndexedKey==null&&_.dbi.clearAsync();let d=0;for(let{key:_,value:E,version:f}of e.primaryStore.getRange({start:u,lazy:l<4,versions:!0,snapshot:!1}))if(E){if(d++,s=e.primaryStore.ifVersion(_,f,()=>{for(let h=0;h<l;h++){let T=t[h],m=T.name;try{let g=T.resolve,S=E&&(g?g(E):E[m]),b=(0,MW.getIndexedValues)(S);if(b)for(let I=0,B=b.length;I<B;I++)T.dbi.put(b[I],_)}catch(g){o[m]||(o[m]=!0,Vt.error(`Error indexing attribute ${m}`,g))}}}),s.then(()=>d--,h=>{d--,Vt.error(h)}),WE.workerData&&WE.workerData.restartNumber!==UW.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=_,e.dbisDB.put(h.key,h);if(i)return}d>aTe?await s:d>cTe&&await new Promise(h=>setImmediate(h))}for(let _ of t)delete _.lastIndexedKey,delete _.indexingPID,_.dbi.isIndexing=!1,s=e.dbisDB.put(_.key,_)}await s,await YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),Vt.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){Vt.error("Error in indexing",n)}}function uTe({table:e,database:t}){let r=zl({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 Pc(e){return VE.push(e),{remove(){let t=VE.indexOf(e);t>-1&&VE.splice(t,1)}}}function sf(e){return KE.push(e),{remove(){let t=KE.indexOf(e);t>-1&&KE.splice(t,1)}}}function Lm(){let e=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION),t=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION_DICTIONARY),r=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||vW,n={startingOffset:32};return t&&(n.dictionary=YE.readFileSync(t)),r&&(n.threshold=r),e&&n}var er,KT,wd,Ut,rs,Nd,bl,ww,yr,YE,Cw,MW,YT,WT,WE,Vt,UW,Dw,zT,vW,jn,We,Od,VE,KE,jT,Ha,Id,aTe,cTe,Pe=Ie(()=>{er=L(se()),KT=L(Ht()),wd=require("lmdb"),Ut=require("path"),rs=require("fs"),Nd=L(gt());$f();bl=L(a_()),ww=L(c_()),yr=L(M()),YE=L(require("fs-extra")),Cw=L(fi()),MW=L(cn()),YT=L(no()),WT=L(qs()),WE=require("worker_threads"),Vt=L(W()),UW=L(dt());Ji();Ul();Dw="data",zT=Symbol("defined-tables"),vW=((0,er.get)(yr.CONFIG_PARAMS.STORAGE_PAGESIZE)||4096)-60;(0,er.initSync)();jn=Object.create(null),We=Object.create(null);(0,Cw._assignPackageExport)("databases",We);(0,Cw._assignPackageExport)("tables",jn);Od=Symbol.for("next-table-id"),VE=[],KE=[],Ha=new Map;a(oTe,"getTables");a(ut,"getDatabases");a(xu,"resetDatabases");a($E,"readMetaDb");a(BW,"ensureDB");a(HW,"setTable");a(zl,"database");a(xR,"dropDatabase");a(Et,"table");aTe=1e3,cTe=10;a(lTe,"runIndexing");a(uTe,"dropTableMeta");a(Pc,"onUpdatedTable");a(sf,"onRemovedDB");a(Lm,"getDefaultCompression")});var te=N((iUe,JW)=>{"use strict";var xa=require("path"),qW=require("fs-extra"),In=W(),xW=require("fs-extra"),QT=require("os"),dTe=require("net"),_Te=require("recursive-iterator"),Kt=M(),fTe=hg(),kW=require("papaparse"),JT=require("moment"),{inspect:ETe}=require("util"),FW=require("is-number"),sUe=require("lodash"),hTe=require("minimist"),pTe=require("https"),mTe=require("http"),{hdb_errors:XT}=_e(),STe=/^((\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d\.\d+([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z)))$/,$W=require("util").promisify(setTimeout),TTe=100,gTe=5,ATe="",RTe=4,GW={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};JW.exports={isEmpty:ns,isEmptyOrZeroLength:Wi,arrayHasEmptyValues:OTe,arrayHasEmptyOrZeroLengthValues:NTe,buildFolderPath:ITe,isBoolean:VW,errorizeMessage:yTe,stripFileExtension:CTe,autoCast:DTe,autoCastJSON:KW,autoCastJSONDeep:Lw,removeDir:PTe,compareVersions:LTe,isCompatibleDataVersion:MTe,escapeRawValue:UTe,unescapeValue:vTe,stringifyProps:BTe,timeoutPromise:xTe,isClusterOperation:FTe,getClusterUser:qTe,checkGlobalSchemaTable:GTe,getHomeDir:WW,getPropsFilePath:HTe,promisifyPapaParse:$Te,removeBOM:jW,createEventPromise:VTe,checkProcessRunning:KTe,checkSchemaTableExist:YTe,checkSchemaExists:zW,checkTableExists:QW,getStartOfTomorrowInSeconds:WTe,getLimitKey:jTe,isObject:wTe,isNotEmptyAndHasValue:bTe,autoCasterIsNumberCheck:YW,backtickASTSchemaItems:zTe,isPortTaken:kTe,createForkArgs:QTe,autoCastBoolean:JTe,async_set_timeout:$W,getTableHashAttribute:XTe,doesSchemaExist:ZTe,doesTableExist:ege,stringifyObj:tge,ms_to_time:rge,changeExtension:nge,getEnvCliRootPath:Mw,noBootFile:sge,httpRequest:ige,transformReq:oge,convertToMS:age,PACKAGE_ROOT:Kt.PACKAGE_ROOT};function yTe(e){return e instanceof Error?e:new Error(e)}a(yTe,"errorizeMessage");function ns(e){return e==null}a(ns,"isEmpty");function bTe(e){return!ns(e)&&(e||e===0||e===""||VW(e))}a(bTe,"isNotEmptyAndHasValue");function Wi(e){return ns(e)||e.length===0||e.size===0}a(Wi,"isEmptyOrZeroLength");function OTe(e){if(ns(e))return!0;for(let t=0;t<e.length;t++)if(ns(e[t]))return!0;return!1}a(OTe,"arrayHasEmptyValues");function NTe(e){if(Wi(e))return!0;for(let t=0;t<e.length;t++)if(Wi(e[t]))return!0;return!1}a(NTe,"arrayHasEmptyOrZeroLengthValues");function ITe(...e){try{return e.join(xa.sep)}catch{console.error(e)}}a(ITe,"buildFolderPath");function VW(e){return ns(e)?!1:e===!0||e===!1}a(VW,"isBoolean");function wTe(e){return ns(e)?!1:typeof e=="object"}a(wTe,"isObject");function CTe(e){return Wi(e)?ATe:e.slice(0,-RTe)}a(CTe,"stripFileExtension");function DTe(e){return ns(e)||e===""||typeof e!="string"?e:GW[e]!==void 0?GW[e]:YW(e)===!0?Number(e):STe.test(e)?new Date(e):e}a(DTe,"autoCast");function KW(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(KW,"autoCastJSON");function Lw(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=Lw(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=Lw(r);n!==r&&(e[t]=n)}return e}else return KW(e)}a(Lw,"autoCastJSONDeep");function YW(e){if(e.startsWith("0.")&&FW(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&FW(e))}a(YW,"autoCasterIsNumberCheck");async function PTe(e){if(Wi(e))throw new Error(`Directory path: ${e} does not exist`);try{await xW.emptyDir(e),await xW.remove(e)}catch(t){throw In.error(`Error removing files in ${e} -- ${t}`),t}}a(PTe,"removeDir");function LTe(e,t){if(Wi(e)){In.info("Invalid current version sent as parameter.");return}if(Wi(t)){In.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,o=s.replace(n,"").split("."),c=i.replace(n,"").split("."),l=Math.min(o.length,c.length);for(let u=0;u<l;u++)if(r=parseInt(o[u],10)-parseInt(c[u],10),r)return r;return o.length-c.length}a(LTe,"compareVersions");function MTe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(MTe,"isCompatibleDataVersion");function UTe(e){if(ns(e))return e;let t=String(e);return t==="."?Kt.UNICODE_PERIOD:t===".."?Kt.UNICODE_PERIOD+Kt.UNICODE_PERIOD:t.replace(Kt.FORWARD_SLASH_REGEX,Kt.UNICODE_FORWARD_SLASH)}a(UTe,"escapeRawValue");function vTe(e){if(ns(e))return e;let t=String(e);return t===Kt.UNICODE_PERIOD?".":t===Kt.UNICODE_PERIOD+Kt.UNICODE_PERIOD?"..":String(e).replace(Kt.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(vTe,"unescapeValue");function BTe(e,t){if(ns(e))return In.info("Properties object is null"),"";let r="";return e.each(function(n,s){try{if(t&&t[n]){let i=t[n];for(let o of i)r+=";"+o+QT.EOL}!Wi(n)&&n[0]===";"?r+=" "+n+s+QT.EOL:Wi(n)||(r+=n+"="+s+QT.EOL)}catch{In.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(BTe,"stringifyProps");function WW(){let e;try{e=QT.homedir()}catch{e=process.env.HOME}return e}a(WW,"getHomeDir");function HTe(){let e=xa.join(WW(),Kt.HDB_HOME_DIR_NAME,Kt.BOOT_PROPS_FILE_NAME);return qW.existsSync(e)||(e=xa.join(__dirname,"../","hdb_boot_properties.file")),e}a(HTe,"getPropsFilePath");function xTe(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(xTe,"timeoutPromise");async function kTe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=dTe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(kTe,"isPortTaken");function FTe(e){try{return Kt.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){In.error(`Error checking operation against cluster ops ${t}`)}return!1}a(FTe,"isClusterOperation");function GTe(e,t){let r=(Pe(),oe(lt)).getDatabases();if(!r[e])return XT.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return XT.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(GTe,"checkGlobalSchemaTable");function qTe(e,t){if(ns(t)){In.warn("No CLUSTERING_USER defined, clustering disabled");return}if(ns(e)||Wi(e)){In.warn("No users to search.");return}let r;try{let n=e.get(t);n&&n.role.permission.cluster_user===!0&&n.active===!0&&(r=n)}catch(n){In.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){In.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(qTe,"getClusterUser");function $Te(){kW.parsePromise=function(e,t,r){return new Promise(function(n,s){kW.parse(e,{header:!0,transformHeader:jW,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a($Te,"promisifyPapaParse");function jW(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(jW,"removeBOM");function VTe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;In.info(`Got cluster status event response: ${ETe(s)}`);try{i.cancel()}catch{In.error("Error trying to cancel timeout.")}n(s)})})}a(VTe,"createEventPromise");async function KTe(e){let t=!0,r=0;do await $W(TTe*r++),(await fTe.findPs(e)).length>0&&(t=!1);while(t&&r<gTe);if(t)throw new Error(`process ${e} was not started`)}a(KTe,"checkProcessRunning");function YTe(e,t){let r=zW(e);if(r)return r;let n=QW(e,t);if(n)return n}a(YTe,"checkSchemaTableExist");function zW(e){let{getDatabases:t}=(Pe(),oe(lt));if(!t()[e])return XT.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(zW,"checkSchemaExists");function QW(e,t){let{getDatabases:r}=(Pe(),oe(lt));if(!r()[e][t])return XT.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(QW,"checkTableExists");function WTe(){let e=JT().utc().add(1,Kt.MOMENT_DAYS_TAG).startOf(Kt.MOMENT_DAYS_TAG).unix(),t=JT().utc().unix();return e-t}a(WTe,"getStartOfTomorrowInSeconds");function jTe(){return JT().utc().format("DD-MM-YYYY")}a(jTe,"getLimitKey");function zTe(e){try{let t=new _Te(e);for(let{node:r}of t)r&&(r.columnid&&typeof r.columnid!="string"&&(r.columnid=r.columnid.toString()),r.columnid&&!r.columnid.startsWith("`")&&(r.columnid_orig=r.columnid,r.columnid=`\`${r.columnid}\``),r.tableid&&!r.tableid.startsWith("`")&&(r.tableid_orig=r.tableid,r.tableid=`\`${r.tableid}\``),r.databaseid&&!r.databaseid.startsWith("`")&&(r.databaseid_orig=r.databaseid,r.databaseid=`\`${r.databaseid}\``),r.as&&typeof r.as=="string"&&!r.as.startsWith("[")&&(r.as_orig=r.as,r.as=`\`${r.as}\``))}catch(t){In.error("Got an error back ticking items."),In.error(t)}}a(zTe,"backtickASTSchemaItems");function QTe(e){return[e]}a(QTe,"createForkArgs");function JTe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(JTe,"autoCastBoolean");function XTe(e,t){let{getDatabases:r}=(Pe(),oe(lt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(XTe,"getTableHashAttribute");function ZTe(e){let{getDatabases:t}=(Pe(),oe(lt));return t()[e]!==void 0}a(ZTe,"doesSchemaExist");function ege(e,t){let{getDatabases:r}=(Pe(),oe(lt));return r()[e]?.[t]!==void 0}a(ege,"doesTableExist");function tge(e){try{return JSON.stringify(e)}catch{return e}}a(tge,"stringifyObj");function rge(e){let t=JT.duration(e),r=t.seconds()>0?t.seconds()+"s":"",n=t.minutes()>0?t.minutes()+"m ":"",s=t.hours()>0?t.hours()+"h ":"",i=t.days()>0?t.days()+"d ":"";return(t.years()>0?t.years()+"y ":"")+i+s+n+r}a(rge,"ms_to_time");function nge(e,t){let r=xa.basename(e,xa.extname(e));return xa.join(xa.dirname(e),r+t)}a(nge,"changeExtension");function Mw(){if(process.env[Kt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[Kt.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=hTe(process.argv);if(e[Kt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[Kt.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(Mw,"getEnvCliRootPath");var Pw;function sge(){if(Pw)return Pw;let e=Mw();if(Mw()&&qW.pathExistsSync(xa.join(e,Kt.HDB_CONFIG_FILE)))return Pw=!0,!0}a(sge,"noBootFile");function ige(e,t){let r;return e.protocol==="http:"?r=mTe:r=pTe,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(ige,"httpRequest");function oge(e){if(!e.schema&&!e.database){e.schema=Kt.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(oge,"transformReq");function age(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(age,"convertToMS")});var ZW=N((cUe,XW)=>{"use strict";var Uw=M(),cge=te(),lge=Di(),ui=W(),uge=Sm(),dge=pf(),aUe=Hu(),_ge=ls(),fge=Af(),Ege=require("semver/functions/gte"),hge=3e4,pge=7;XW.exports=mge;async function mge(){try{ui.notify("Starting update nodes. This process will attempt to update any node connections the need to be reestablished after a 4.0.0 upgrade"),await _ge.setSchemaDataToGlobalAsync();let e=await lge.getAllNodeRecords(),t=[];for(let r=0,n=e.length;r<n;r++){let s=e[r];s.system_info.hdb_version===Uw.PRE_4_0_0_VERSION&&t.push(Sge(s))}await Promise.allSettled(t),ui.notify("Shutting down 4.0.0 clustering upgrade process")}catch(e){throw ui.error(e),e}}a(mge,"updateAllNodes");async function Sge(e){try{let{name:t,subscriptions:r}=e;ui.notify("Running 4.0.0 update on node:",t);let n=!1,s=0;for(;s<pge;){let i=[];if(await uge.buildNodeStatus(e,i),ui.trace("Received status:",i[0].status,"from node:",t),i[0].status==="open"&&Ege(i[0].system_info.hdb_version,"4.0.0")){ui.notify("Received open status from node:",t,"calling add node");let o={operation:Uw.OPERATIONS_ENUM.ADD_NODE,node_name:t,subscriptions:r};await dge(o,!0),ui.notify("Successfully added node",t),n=!0;break}s=(Date.now()-e.__updatedtime__)/(1e3*60*60*24),ui.trace("Update node has been running for",s,"days. Calling node status again for node:",t),await cge.async_set_timeout(hge)}n||(ui.error("4.0.0 node update was unable to update connection to node:",t),ui.error("Removing following node record from hdb_nodes",e),await fge({operation:Uw.OPERATIONS_ENUM.REMOVE_NODE,node_name:t}))}catch(t){throw ui.error(t),t}}a(Sge,"updateNode")});var Tge=ZW();(async()=>{try{await Tge()}catch(e){console.error("Error launching 4.0.0 node update"),console.error(e),process.exit(1)}})();