harperdb 4.4.25 → 4.4.26

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 ej=Object.create;var Ud=Object.defineProperty;var tj=Object.getOwnPropertyDescriptor;var rj=Object.getOwnPropertyNames;var nj=Object.getPrototypeOf,sj=Object.prototype.hasOwnProperty;var a=(e,t)=>Ud(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)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 rj(t))!sj.call(e,s)&&s!==r&&Ud(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)):{},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((Rge,kw)=>{var ij=require("fast-glob"),{statSync:ig,existsSync:og,readFileSync:oj,writeFileSync:aj}=require("fs"),{spawnSync:cj,spawn:lj,execFileSync:Age}=require("child_process"),{isMainThread:uj}=require("worker_threads"),{join:Fo,relative:xw}=require("path"),{PACKAGE_ROOT:Hs}=M(),{tmpdir:dj,platform:_j}=require("os");require("source-map-support").install();var fj=["resources","server","dataLayer","components"],vd="ts-build",ag,Ej=__filename.endsWith("tsBuild.js");if(Ej){if(uj){let r;try{ig(Fo(Hs,vd)),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,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=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=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=Fo(Hs,xw(vd,i)):o=Fo(Hs,vd,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((Oge,eC)=>{"use strict";var os=require("path"),hj=require("fs"),{relative:yge,join:bge}=os,{existsSync:pj}=hj;function mj(){let e=__dirname;for(;!pj(os.join(e,"package.json"));){let t=os.dirname(e);if(t===e)throw new Error("Could not find package root");e=t}return e}a(mj,"getHDBPackageRoot");var Go=mj(),Gw="js",eh=Gw,Sj="harperdb-config.yaml",Tj="defaultConfig.yaml",gj="hdb",qw=`harperdb.${eh}`,$w=`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:os.join(Go,"server/harperdb"),CUSTOM_FUNCTIONS:os.join(Go,"server/customFunctions"),CLUSTERING_HUB:os.join(Go,"server/nats"),CLUSTERING_LEAF:os.join(Go,"server/nats")},Lj={HDB:os.join(cg.HDB,qw),CUSTOM_FUNCTIONS:os.join(cg.CUSTOM_FUNCTIONS,$w)},Mj={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:os.join(Go,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:os.join(Go,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:os.join(Go,"launchServiceScripts/launchUpdateNodes4-0-0.js")},Uj={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},Vw="support@harperdb.io",vj="customer-success@harperdb.io",Kw=1,Bj=4141,Yw="https://harperdbhelp.zendesk.com/hc/en-us/requests/new",Hj="https://www.harperdb.io/product",xj=`For support, please submit a request at ${Yw} or contact ${Vw}`,Ww=`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 ${Kw} role. ${Ww}`,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",jw={SETTINGS_PATH_KEY:"settings_path"},zw=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"},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 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"},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"},Bz=zw.invert(Qw),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_CORSACCESSCONTROLALLOWHEADERS:"http_corsAccessControlAllowHeaders",HTTP_HEADERSTIMEOUT:"http_headersTimeout",HTTP_KEEPALIVETIMEOUT:"http_keepAliveTimeout",HTTP_MAXPARAMLENGTH:"http_maxParamLength",HTTP_TIMEOUT:"http_timeout",HTTP_PORT:"http_port",HTTP_SECUREPORT:"http_securePort",HTTP_MTLS:"http_mtls",HTTP_MTLS_REQUIRED:"http_mtls_required",HTTP_MTLS_USER:"http_mtls_user",HTTP_MAXHEADERSIZE:"http_maxHeaderSize",HTTP_THREADRANGE:"http_threadRange",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_COPYTABLESTOCATCHUP:"replication_copyTablesToCatchUp",ROOTPATH:"rootPath",SERIALIZATION_BIGINT:"serialization_bigInt",STORAGE_WRITEASYNC:"storage_writeAsync",STORAGE_OVERLAPPINGSYNC:"storage_overlappingSync",STORAGE_CACHING:"storage_caching",STORAGE_COMPRESSION:"storage_compression",STORAGE_NOREADAHEAD:"storage_noReadAhead",STORAGE_PREFETCHWRITES:"storage_prefetchWrites",STORAGE_ENCRYPTION:"storage_encryption",STORAGE_MAXTRANSACTIONQUEUETIME:"storage_maxTransactionQueueTime",STORAGE_PATH:"storage_path",STORAGE_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,replication_enablerootcas:P.REPLICATION_ENABLEROOTCAS,replication_databases:P.REPLICATION_DATABASES,replication_copytablestocatchup:P.REPLICATION_COPYTABLESTOCATCHUP,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 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"},Xw={CREATED_TIME:"__createdtime__",UPDATED_TIME:"__updatedtime__"},Wz=Symbol("metadata"),jz="__clustering__",zz=Object.values(Xw),Qz=15984864e5,Zw={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},Jz=zw.invert(Zw),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"};eC.exports={LOCAL_HARPERDB_OPERATIONS:nt,HDB_SUPPORT_ADDRESS:Vw,HDB_SUPPORT_URL:Yw,HDB_PRICING_URL:Hj,SUPPORT_HELP_MSG:xj,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: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:Qw,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:Bd,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:Xw,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:Kw,BASIC_LICENSE_CLUSTER_CONNECTION_LIMIT_WS_ERROR_CODE:Bj,VALUE_SEARCH_COMPARATORS:Zw,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:Gw,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:$w,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:Jw,CONFIG_PARAMS:P,HDB_CONFIG_FILE:Sj,HDB_DEFAULT_CONFIG_FILE:Tj,ROLE_TYPES_ENUM:Uj,BOOT_PROP_PARAMS:jw,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};Fw()});var ja=N((Ige,nC)=>{"use strict";var tC=require("minimist");nC.exports=EQ;function EQ(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(EQ,"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 Ei=N(fi=>{"use strict";global.Resource=fi.Resource=void 0;global.tables=fi.tables={};global.databases=fi.databases={};global.getUser=fi.getUser=void 0;global.server=fi.server={};global.contentTypes=fi.contentTypes=null;global.threads=fi.threads=[];global.logger={};fi._assignPackageExport=(e,t)=>{global[e]=fi[e]=t}});var W=N((SC,TC)=>{"use strict";var zi=require("fs-extra"),{workerData:hQ,threadId:pQ,isMainThread:mQ}=require("worker_threads"),pi=require("path"),aC=require("yaml"),cC=require("properties-reader"),Wt=M(),sC=ja(),SQ=require("os"),{PACKAGE_ROOT:fg}=M(),{_assignPackageExport:TQ}=Ei(),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"},gQ=pi.join(fg,"logs"),AQ=pi.join(fg,"config/yaml/",Wt.HDB_DEFAULT_CONFIG_FILE),RQ=1e4,ug,hi,as,wr,nh,Hd,sh,qo,xd;xd===void 0&&uC();Object.assign(SC,{notify:hC,fatal:pC,error:ih,warn:mC,info:_C,debug:EC,trace:fC,setLogLevel:DQ,log_level:wr,loggerWithTag:OQ,suppressLogging:NQ,initLogSettings:uC,logCustomLevel:wQ,closeLogFile:Eg,logsAtLevel:yQ,getLogFilePath:a(()=>sh,"getLogFilePath"),OUTPUTS:lC,AuthAuditLog:MQ});TQ("logger",TC.exports);var dg;function yQ(e){return fr[wr]<=fr[e]}a(yQ,"logsAtLevel");function uC(e=!1){try{if(xd===void 0||e){Eg();let t=CQ(),r=sC(["ROOTPATH"]);try{xd=cC(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!zi.pathExistsSync(pi.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE)))throw n}if({level:wr,config_log_path:Hd,to_file:hi,to_stream:as}=PQ(r.ROOTPATH?pi.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE):xd.get("settings_path")),nh=Wt.LOG_NAMES.HDB,sh=pi.join(Hd,nh),mQ)try{require("segfault-handler").registerHandler(pi.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){as=l;continue}c===Wt.CONFIG_PARAMS.LOGGING_FILE&&(hi=c),c===Wt.CONFIG_PARAMS.LOGGING_CONSOLE&&(ug=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=LQ();hi=hi===void 0?s:hi,hi=oC(hi),as=as===void 0?i:as,as=oC(as),wr=wr===void 0?n:wr,Hd=gQ,nh=Wt.LOG_NAMES.INSTALL,sh=pi.join(Hd,nh);return}throw ih("Error initializing log settings"),ih(t),t}process.env.DEV_MODE&&(as=!0),bQ()}a(uC,"initLogSettings");var $o=!0;function bQ(){hi&&(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]))),iC.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]))),iC.apply(process.stderr,arguments)})}a(bQ,"stdioLogging");function OQ(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(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+=`
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((Rge,Fw)=>{var ij=require("fast-glob"),{statSync:ig,existsSync:og,readFileSync:oj,writeFileSync:aj}=require("fs"),{spawnSync:cj,spawn:lj,execFileSync:Age}=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((Oge,tC)=>{"use strict";var os=require("path"),hj=require("fs"),{relative:yge,join:bge}=os,{existsSync:pj}=hj;function mj(){let e=__dirname;for(;!pj(os.join(e,"package.json"));){let t=os.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:os.join(Go,"server/harperdb"),CUSTOM_FUNCTIONS:os.join(Go,"server/customFunctions"),CLUSTERING_HUB:os.join(Go,"server/nats"),CLUSTERING_LEAF:os.join(Go,"server/nats")},Lj={HDB:os.join(cg.HDB,$w),CUSTOM_FUNCTIONS:os.join(cg.CUSTOM_FUNCTIONS,Vw)},Mj={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:os.join(Go,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:os.join(Go,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:os.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",THREADS_HEAPSNAPSHOTNEARLIMIT:"threads_heapSnapshotNearLimit",HTTP_SESSIONAFFINITY:"http_sessionAffinity",HTTP_COMPRESSIONTHRESHOLD:"http_compressionThreshold",HTTP_CORS:"http_cors",HTTP_CORSACCESSLIST:"http_corsAccessList",HTTP_CORSACCESSCONTROLALLOWHEADERS:"http_corsAccessControlAllowHeaders",HTTP_HEADERSTIMEOUT:"http_headersTimeout",HTTP_KEEPALIVETIMEOUT:"http_keepAliveTimeout",HTTP_MAXPARAMLENGTH:"http_maxParamLength",HTTP_TIMEOUT:"http_timeout",HTTP_PORT:"http_port",HTTP_SECUREPORT:"http_securePort",HTTP_MTLS:"http_mtls",HTTP_MTLS_REQUIRED:"http_mtls_required",HTTP_MTLS_USER:"http_mtls_user",HTTP_MAXHEADERSIZE:"http_maxHeaderSize",HTTP_THREADRANGE:"http_threadRange",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_COPYTABLESTOCATCHUP:"replication_copyTablesToCatchUp",ROOTPATH:"rootPath",SERIALIZATION_BIGINT:"serialization_bigInt",STORAGE_WRITEASYNC:"storage_writeAsync",STORAGE_OVERLAPPINGSYNC:"storage_overlappingSync",STORAGE_CACHING:"storage_caching",STORAGE_COMPRESSION:"storage_compression",STORAGE_NOREADAHEAD:"storage_noReadAhead",STORAGE_PREFETCHWRITES:"storage_prefetchWrites",STORAGE_ENCRYPTION:"storage_encryption",STORAGE_MAXTRANSACTIONQUEUETIME:"storage_maxTransactionQueueTime",STORAGE_PATH:"storage_path",STORAGE_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_copytablestocatchup:P.REPLICATION_COPYTABLESTOCATCHUP,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 ja=N((Ige,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 Ei=N(fi=>{"use strict";global.Resource=fi.Resource=void 0;global.tables=fi.tables={};global.databases=fi.databases={};global.getUser=fi.getUser=void 0;global.server=fi.server={};global.contentTypes=fi.contentTypes=null;global.threads=fi.threads=[];global.logger={};fi._assignPackageExport=(e,t)=>{global[e]=fi[e]=t}});var W=N((TC,gC)=>{"use strict";var zi=require("fs-extra"),{workerData:hQ,threadId:pQ,isMainThread:mQ}=require("worker_threads"),pi=require("path"),cC=require("yaml"),lC=require("properties-reader"),Wt=M(),iC=ja(),SQ=require("os"),{PACKAGE_ROOT:fg}=M(),{_assignPackageExport:TQ}=Ei(),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=pi.join(fg,"logs"),AQ=pi.join(fg,"config/yaml/",Wt.HDB_DEFAULT_CONFIG_FILE),RQ=1e4,ug,hi,as,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(pi.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE)))throw n}if({level:wr,config_log_path:xd,to_file:hi,to_stream:as}=PQ(r.ROOTPATH?pi.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE):kd.get("settings_path")),nh=Wt.LOG_NAMES.HDB,sh=pi.join(xd,nh),mQ)try{require("segfault-handler").registerHandler(pi.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){as=l;continue}c===Wt.CONFIG_PARAMS.LOGGING_FILE&&(hi=c),c===Wt.CONFIG_PARAMS.LOGGING_CONSOLE&&(ug=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=LQ();hi=hi===void 0?s:hi,hi=aC(hi),as=as===void 0?i:as,as=aC(as),wr=wr===void 0?n:wr,xd=gQ,nh=Wt.LOG_NAMES.INSTALL,sh=pi.join(xd,nh);return}throw ih("Error initializing log settings"),ih(t),t}process.env.DEV_MODE&&(as=!0),bQ()}a(dC,"initLogSettings");var $o=!0;function bQ(){hi&&(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(hi){if(dC(e),as){$o=!1;try{process.stdout.write(e)}finally{$o=!0}}}else as&&process.stdout.write(e)}a(kd,"logStdOut");function oh(e){if(hi){if(dC(e),as){$o=!1;try{process.stderr.write(e)}finally{$o=!0}}}else as&&process.stderr.write(e)}a(oh,"logStdErr");function dC(e){_g(),qo?zi.appendFileSync(qo,e):dg||console.log(e)}a(dC,"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 _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 wQ(e,t,...r){t===lC.STDERR?oh(xs(e,r)):kd(xs(e,r))}a(wQ,"logCustomLevel");function CQ(){let e;try{e=SQ.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=pi.join(e,Wt.HDB_HOME_DIR_NAME,Wt.BOOT_PROPS_FILE_NAME);return zi.existsSync(t)||(t=pi.join(fg,"utility/hdb_boot_properties.file")),t}a(CQ,"getPropsFilePath");function DQ(e){wr=e}a(DQ,"setLogLevel");function oC(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(oC,"autoCastBoolean");function PQ(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:pi.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(PQ,"getLogConfig");function LQ(){try{let e=aC.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((Pge,gC)=>{"use strict";var UQ=require("util"),vQ=require("path"),BQ=require("child_process"),HQ=UQ.promisify(BQ.execFile),xQ=1e3*1e3*10;gC.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((Mge,RC)=>{"use strict";var FQ="__dbis__",GQ="__txns__",qQ="__environment_name__",$Q="__dbi_defintion__",VQ={EQUALS:"equals",STARTS_WITH:"startsWith",_STARTS_WITH:"starts_with",ENDS_WITH:"endsWith",_ENDS_WITH:"ends_with",CONTAINS:"contains",SEARCH_ALL:"searchAll",SEARCH_ALL_TO_MAP:"searchAllToMap",BATCH_SEARCH_BY_HASH:"batchSearchByHash",BATCH_SEARCH_BY_HASH_TO_MAP:"batchSearchByHashToMap",GREATER_THAN:"greaterThan",_GREATER_THAN:"greater_than",GREATER_THAN_EQUAL:"greaterThanEqual",_GREATER_THAN_EQUAL:"greater_than_equal",LESS_THAN:"lessThan",_LESS_THAN:"less_than",LESS_THAN_EQUAL:"lessThanEqual",_LESS_THAN_EQUAL:"less_than_equal",BETWEEN:"between"},KQ=["__createdtime__","__updatedtime__"],YQ="\uFFFF",AC={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},WQ=Object.values(AC);RC.exports={AUDIT_STORE_NAME:GQ,INTERNAL_DBIS_NAME:FQ,DBI_DEFINITION_NAME:$Q,SEARCH_TYPES:VQ,TIMESTAMP_NAMES:KQ,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:qQ,TRANSACTIONS_DBI_NAMES_ENUM:AC,TRANSACTIONS_DBIS:WQ,OVERFLOW_MARKER:YQ}});var Dn=N((Uge,PC)=>{"use strict";var yC=M(),bC=Ht(),OC={CONTINUE:100,OK:200,CREATED:201,BAD_REQUEST:400,UNAUTHORIZED:401,FORBIDDEN:403,NOT_FOUND:404,METHOD_NOT_ALLOWED:405,REQUEST_TIMEOUT:408,CONFLICT:409,TOO_MANY_REQUESTS:429,INTERNAL_SERVER_ERROR:500,NOT_IMPLEMENTED:501,BAD_GATEWAY:502,SERVICE_UNAVAILABLE:503,GATEWAY_TIMEOUT:504,HTTP_VERSION_NOT_SUPPORTED:505,INSUFFICIENT_STORAGE:507,NETWORK_AUTHENTICATION_REQUIRED:511},NC=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),IC={500:NC("There was an error processing your request."),400:"Invalid request"},jQ=IC[OC.INTERNAL_SERVER_ERROR],zQ={OP_NOT_SUPPORTED_FOR_FS:a(e=>`${e} is not available for this instance because it uses the File System data store.`,"OP_NOT_SUPPORTED_FOR_FS"),MISSING_VALUE:a(e=>`${e} is missing.`,"MISSING_VALUE"),INVALID_VALUE:a(e=>`${e} is invalid.`,"INVALID_VALUE"),NOT_FOUND:a(e=>`${e} not found.`,"NOT_FOUND")},QQ={CONFIG_VALIDATION:a(e=>`HarperDB config file validation error: ${e}`,"CONFIG_VALIDATION")},JQ={DEFAULT_BULK_LOAD_ERR:"There was an error during your bulk load into HarperDB.",DOWNLOAD_FILE_ERR:a(e=>`There was an error downloading '${e}'.`,"DOWNLOAD_FILE_ERR"),INSERT_JSON_ERR:"There was an error inserting the downloaded JSON data.",INSERT_CSV_ERR:"There was an error inserting the downloaded CSV data.",INVALID_ACTION_PARAM_ERR:a(e=>`Bulk load operation failed - ${e} is not a valid 'action' parameter`,"INVALID_ACTION_PARAM_ERR"),INVALID_FILE_EXT_ERR:a(e=>`Error selecting correct parser - valid file type not found in json - ${e}`,"INVALID_FILE_EXT_ERR"),MAX_FILE_SIZE_ERR:a((e,t)=>`File size is ${e} bytes, which exceeded the maximum size allowed of: ${t} bytes`,"MAX_FILE_SIZE_ERR"),PAPA_PARSE_ERR:"There was an error parsing the downloaded CSV data.",S3_DOWNLOAD_ERR:a(e=>`There was an error downloading '${e}' from AWS.`,"S3_DOWNLOAD_ERR"),WRITE_TEMP_FILE_ERR:"Error writing temporary file to storage"},XQ={BASE_PATH_REQUIRED:"base_path is required",DESTINATION_PATH_REQUIRED:"destination_path is required",ENV_NAME_REQUIRED:"env_name is required",INVALID_BASE_PATH:"invalid base_path",INVALID_DESTINATION_PATH:"invalid destination_path",INVALID_ENVIRONMENT:"invalid environment",ENV_REQUIRED:"env is required",DBI_NAME_REQUIRED:"dbi_name is required",DBI_DOES_NOT_EXIST:"dbi does not exist",HASH_ATTRIBUTE_REQUIRED:"hash_attribute is required",ID_REQUIRED:"id is required",IDS_REQUIRED:"ids is required",IDS_MUST_BE_ITERABLE:"ids must be iterable",FETCH_ATTRIBUTES_REQUIRED:"fetch_attributes is required",FETCH_ATTRIBUTES_MUST_BE_ARRAY:"fetch_attributes must be an array",ATTRIBUTE_REQUIRED:"attribute is required",SEARCH_VALUE_REQUIRED:"search_value is required",SEARCH_VALUE_TOO_LARGE:"search_value is too long",WRITE_ATTRIBUTES_REQUIRED:"write_attributes is required",WRITE_ATTRIBUTES_MUST_BE_ARRAY:"write_attributes must be an array",RECORDS_REQUIRED:"records is required",RECORDS_MUST_BE_ARRAY:"records must be an array",CANNOT_CREATE_INTERNAL_DBIS_NAME:`cannot create a dbi named ${bC.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${bC.INTERNAL_DBIS_NAME}`,START_VALUE_REQUIRED:"start_value is required",END_VALUE_REQUIRED:"end_value is required",CANNOT_COMPARE_STRING_TO_NUMERIC_KEYS:"cannot compare a string to numeric keys",END_VALUE_MUST_BE_GREATER_THAN_START_VALUE:"end_value must be greater than or equal to start_value",UNKNOWN_SEARCH_TYPE:"unknown search type",CANNOT_DROP_TABLE_HASH_ATTRIBUTE:"cannot drop a table's hash attribute"},ZQ={ATTR_NAME_LENGTH_ERR:a(e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${yC.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes.`,"ATTR_NAME_LENGTH_ERR"),ATTR_NAME_NULLISH_ERR:"transaction aborted due to record(s) with an attribute name that is null, undefined or empty string",HASH_VAL_LENGTH_ERR:`transaction aborted due to record(s) with a hash value that exceeds ${yC.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes, check log for more info`,INVALID_FORWARD_SLASH_IN_HASH_ERR:"transaction aborted due to record(s) with a hash value that contains a forward slash, check log for more info",RECORD_MISSING_HASH_ERR:"transaction aborted due to record(s) with no hash value, check log for more info"},wC={GENERIC_AUTH_FAIL:"Login failed",USER_INACTIVE:"Cannot complete request: User is inactive",INVALID_TOKEN:"invalid token",NO_ENCRYPTION_KEYS:"unable to generate JWT as there are no encryption keys. please contact your administrator",INVALID_CREDENTIALS:"invalid credentials",PASSWORD_REQUIRED:"password is required",USERNAME_REQUIRED:"username is required",REFRESH_TOKEN_REQUIRED:"refresh_token is required",INVALID_AUTH_OBJECT:"invalid auth_object",INVALID_BODY:"invalid body",TOKEN_EXPIRED:"token expired",REFRESH_TOKEN_SAVE_FAILED:"unable to store refresh_token"},e2={DEFAULT_INVALID_REQUEST:"Invalid request",OP_AUTH_PERMS_ERROR:"This operation is not authorized due to role restrictions and/or invalid database items",OP_IS_SU_ONLY:a(e=>`Operation '${e}' is restricted to 'super_user' roles`,"OP_IS_SU_ONLY"),OP_NOT_FOUND:a(e=>`Operation '${e}' not found`,"OP_NOT_FOUND"),SYSTEM_TIMESTAMP_PERMS_ERR:"Internal timestamp attributes - '__createdtime_' and '__updatedtime__' - cannot be inserted to or updated by HDB users.",UNKNOWN_OP_AUTH_ERROR:a((e,t,r)=>`There was an error authorizing ${e} op on table '${t}.${r}'`,"UNKNOWN_OP_AUTH_ERROR"),USER_HAS_NO_PERMS:a(e=>`User ${e} has no role or permissions. Please assign the user a valid role.`,"USER_HAS_NO_PERMS"),DROP_SYSTEM:"The 'system' database, tables and records are used internally by HarperDB and cannot be updated or removed."},t2={ATTR_PERM_MISSING:a((e,t)=>`${e.toUpperCase()} attribute permission missing for '${t}'`,"ATTR_PERM_MISSING"),ATTR_PERM_MISSING_NAME:"Permission object in 'attribute_permission' missing an 'attribute_name'",ATTR_PERM_NOT_BOOLEAN:a((e,t)=>`${e.toUpperCase()} attribute permission for '${t}' must be a boolean`,"ATTR_PERM_NOT_BOOLEAN"),ATTR_PERMS_ARRAY_MISSING:"Missing 'attribute_permissions' array",ATTR_PERMS_NOT_ARRAY:"Value for 'attribute_permissions' must be an array",INVALID_ATTRIBUTE_IN_PERMS:a(e=>`Invalid attribute '${e}' in 'attribute_permissions'`,"INVALID_ATTRIBUTE_IN_PERMS"),INVALID_PERM_KEY:a(e=>`Invalid table permission key value '${e}'`,"INVALID_PERM_KEY"),INVALID_ATTR_PERM_KEY:a(e=>`Invalid attribute permission key value '${e}'`,"INVALID_ATTR_PERM_KEY"),INVALID_ROLE_JSON_KEYS:a(e=>`Invalid ${e.length>1?"keys":"key"} in JSON body - '${e.join("', '")}'`,"INVALID_ROLE_JSON_KEYS"),MISMATCHED_TABLE_ATTR_PERMS:a(e=>`You have a conflict with TABLE permissions for '${e}' being false and ATTRIBUTE permissions being true`,"MISMATCHED_TABLE_ATTR_PERMS"),OUTDATED_PERMS_TRANSLATION_ERROR:"This instance was recently upgraded and uses our new role permissions structure. Please login to this instance in HarperDB Studio, go to 'Roles', and click 'Update Role Permission' for all standard roles to migrate them to the new structure.",ROLE_ALREADY_EXISTS:a(e=>`A role with name '${e}' already exists`,"ROLE_ALREADY_EXISTS"),ROLE_NOT_FOUND:"Role not found",ROLE_PERMS_ERROR:"Errors in the role permissions JSON provided",SCHEMA_PERM_ERROR:a(e=>`Your role does not have permission to view database metadata for '${e}'`,"SCHEMA_PERM_ERROR"),SCHEMA_TABLE_PERM_ERROR:a((e,t)=>`Your role does not have permission to view database.table metadata for '${e}.${t}'`,"SCHEMA_TABLE_PERM_ERROR"),SU_ROLE_MISSING_ERROR:"Missing 'super_user' key/value in permission set",SU_CU_ROLE_BOOLEAN_ERROR:a(e=>`Value for '${e}' permission must be a boolean`,"SU_CU_ROLE_BOOLEAN_ERROR"),STRUCTURE_USER_ROLE_TYPE_ERROR:a(e=>`Value for '${e}' permission must be a boolean or Array`,"STRUCTURE_USER_ROLE_TYPE_ERROR"),SU_CU_ROLE_NO_PERMS_ALLOWED:a(e=>`Roles with '${e}' set to true cannot have other permissions set.`,"SU_CU_ROLE_NO_PERMS_ALLOWED"),SU_CU_ROLE_COMBINED_ERROR:"Roles cannot have both 'super_user' and 'cluster_user' values included in their permissions set.",TABLE_PERM_MISSING:a(e=>`Missing table ${e.toUpperCase()} permission`,"TABLE_PERM_MISSING"),TABLE_PERM_NOT_BOOLEAN:a(e=>`Table ${e.toUpperCase()} permission must be a boolean`,"TABLE_PERM_NOT_BOOLEAN")},r2={ATTR_NOT_FOUND:a((e,t,r)=>`Attribute '${r}' does not exist on '${e}.${t}'`,"ATTR_NOT_FOUND"),ATTR_EXISTS_ERR:a((e,t,r)=>`Attribute '${r}' already exists in ${e}.${t}'`,"ATTR_EXISTS_ERR"),DESCRIBE_ALL_ERR:"There was an error during describeAll. Please check the logs and try again.",INVALID_TABLE_ERR:a(e=>`Invalid table ${JSON.stringify(e)}`,"INVALID_TABLE_ERR"),SCHEMA_NOT_FOUND:a(e=>`database '${e}' does not exist`,"SCHEMA_NOT_FOUND"),SCHEMA_EXISTS_ERR:a(e=>`database '${e}' already exists`,"SCHEMA_EXISTS_ERR"),TABLE_EXISTS_ERR:a((e,t)=>`Table '${t}' already exists in '${e}'`,"TABLE_EXISTS_ERR"),SCHEMA_REQUIRED_ERR:"database is required",TABLE_NOT_FOUND:a((e,t)=>`Table '${e}.${t}' does not exist`,"TABLE_NOT_FOUND"),TABLE_REQUIRED_ERR:"table is required"},n2={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},s2={ALTER_USER_DUP_ROLES:a(e=>`Update failed. There are duplicates for the '${e}' role which is not allowed. Update your roles and try again.`,"ALTER_USER_DUP_ROLES"),ALTER_USER_ROLE_NOT_FOUND:a(e=>`Update failed. Requested '${e}' role not found.`,"ALTER_USER_ROLE_NOT_FOUND"),DUP_ROLES_FOUND:a(e=>`Multiple ${e} roles found. Roles must have unique 'role' value. Please update and try again.`,"DUP_ROLES_FOUND"),ROLE_NAME_NOT_FOUND:a(e=>`${e} role not found`,"ROLE_NAME_NOT_FOUND"),USER_ALREADY_EXISTS:a(e=>`User ${e} already exists`,"USER_ALREADY_EXISTS"),USER_NOT_EXIST:a(e=>`User ${e} does not exist`,"USER_NOT_EXIST")},CC={INVALID_DATE:"Invalid date, must be in ISO-8601 format (YYYY-MM-DD).",SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE:a(e=>`invalid sort attribute '${e}', the attribute must either be the table's hash attribute or an attribute used in conditions.`,"SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE")},DC={INVALID_ITC_DATA_TYPE:"Invalid ITC event data type, must be an object",MISSING_TYPE:"ITC event missing 'type'",MISSING_MSG:"ITC event missing 'message'",MISSING_ORIGIN:"ITC event message missing 'originator' property",INVALID_EVENT:a(e=>`ITC server received invalid event type: ${e}`,"INVALID_EVENT")},i2={FUNCTION_STATUS:"Error getting custom function status, check the log for more details",GET_FUNCTIONS:"Error getting custom functions, check the log for more details",GET_FUNCTION:"Error getting custom function, check the log for more details",SET_FUNCTION:"Error setting custom function, check the log for more details",NO_PROJECT:"Project does not exist. Create one using 'add_custom_function_project'",PROJECT_EXISTS:"Project already exists",VALIDATION_ERR:"Error validating request, check the log for more details",NO_FILE:"File does not exist",BAD_FILE_NAME:"File name can only contain alphanumeric, dash and underscore characters",BAD_PROJECT_NAME:"Project name can only contain alphanumeric, dash and underscores characters",BAD_PACKAGE:"Packaged project must be base64-encoded tar file of project directory",DROP_FUNCTION:"Error dropping custom function, check the log for more details",ADD_FUNCTION:"Error adding custom function project, check the log for more details",DROP_FUNCTION_PROJECT:"Error dropping custom function project, check the log for more details",BAD_FILE_PATH:"Filepath must be valid, and contain the name of the tarball you wish to write",NOT_ENABLED:"Custom functions is not enabled, to enable set fastifyRoutes enabled to true in hdb/harperdb-config.yaml file.",BAD_SSH_KEY_NAME:"SSH key name can only contain alphanumeric, dash and underscore characters"},o2={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},a2={...wC,...JQ,...zQ,...e2,...t2,...r2,...n2,...s2,...ZQ,...CC,...DC,...i2,...o2,...QQ};PC.exports={CHECK_LOGS_WRAPPER:NC,HDB_ERROR_MSGS:a2,DEFAULT_ERROR_MSGS:IC,DEFAULT_ERROR_RESP:jQ,HTTP_STATUS_CODES:OC,LMDB_ERRORS_ENUM:XQ,AUTHENTICATION_ERROR_MSGS:wC,VALIDATION_ERROR_MSGS:CC,ITC_ERRORS:DC}});var _e=N((Bge,UC)=>{"use strict";var Cl=Dn(),c2=W(),l2=M(),ah=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,LC),this.statusCode=n||Cl.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(Cl.DEFAULT_ERROR_MSGS[n]?Cl.DEFAULT_ERROR_MSGS[n]:Cl.DEFAULT_ERROR_MSGS[Cl.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR]),this.message=t.message?t.message:this.http_resp_msg,this.type=t.name,s&&(this.logLevel=s),typeof this.message!="string"&&(this.stack=t.stack),i&&c2[s](i)}},pg=class extends Error{static{a(this,"ClientError")}constructor(t,r){if(t instanceof Error)return t.statusCode=r||400,t;super(t),this.statusCode=r||400}},mg=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function LC(e,t,r,n=l2.LOG_LEVELS.ERROR,s=null,i=!1){if(MC(e))return e;let o=new ah(e,t,r,n,s);return i&&delete o.stack,o}a(LC,"handleHDBError");function MC(e){return e.__proto__.constructor.name===ah.name}a(MC,"isHDBError");UC.exports={isHDBError:MC,handleHDBError:LC,ClientError:pg,ServerError:mg,hdb_errors:Cl}});var Sg=N(vC=>{"use strict";var u2={cert:"-----BEGIN CERTIFICATE-----\rMIIDXDCCAkSgAwIBAgIFNTE4MzQwDQYJKoZIhvcNAQELBQAwXTEXMBUGA1UEAxMO\rSGFycGVyREIsIEluYy4xCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDTzEPMA0GA1UE\rBxMGRGVudmVyMRcwFQYDVQQKEw5IYXJwZXJEQiwgSW5jLjAeFw0yMjAzMTEyMzAz\rNDlaFw0yNzAzMTAyMzAzNDlaMF0xFzAVBgNVBAMTDkhhcnBlckRCLCBJbmMuMQsw\rCQYDVQQGEwJVUzELMAkGA1UECBMCQ08xDzANBgNVBAcTBkRlbnZlcjEXMBUGA1UE\rChMOSGFycGVyREIsIEluYy4wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB\rAQCsEUlBF8WImS78rCFXVKyntxfrW++4qZ3hGnoD2MHZAuDHyeP/5eGnaE9GQhKc\r4DwG4DGvh0wP2zIYnBfiQ3L2ZtnlDR9ZkKIQYGlVxTUn6T43krhK5nZKqDF43Yg3\rZEvO3cbJBjiKZx0eA2/toehdSsTAHHQx5gTDcggNe2tgoJHYPwi9YF/AxSBZrbgb\ryWlYgtYDmF32ytHP03GUCIdKOFuBPsHTGu4SkdEIdLIqO9oglW1YFH5qZ6NiwApW\rsP+GCuqOwDXXbdjr75iq9Tq/CDrjGFLaTPmvd2Q0qG/BtaCll0ghpG+yIHvt/iQs\rajS+LxEWAnVlGMaDdFErbDUtAgMBAAGjIzAhMA8GA1UdEwEB/wQFMAMBAf8wDgYD\rVR0PAQH/BAQDAgIEMA0GCSqGSIb3DQEBCwUAA4IBAQASR4YW/rPK7PNArHVe9zzM\rb0rKNX/2T9/0nybRhmE/+hdlSgliTAeebmwkUS2APckmekYt/q2ZY2NS65Fo/jjp\rG8TJrtcF4h+ylVqUp0ZXQLFtIsr7r2JZA7hJ6njW6G4DHSZ0gxtECLi4CBlTjzm5\rNmnmIDObvGRTuqmcdAZmXeObbta/He2XIzietukPAYX062pNM+G5XT5UM1eG/Vlp\rN86vjhpyI+ffKy+C60SJqxmKM3ydgN7oLscE7+2wLPN25XqN4W99OwGsp5dTdu/f\r5lPtFayXdJ55e/sNQKmGN+UGLrL05c2MWgjb8U/LFilnupUianceoeSERZmVjzKX\r-----END CERTIFICATE-----\r".replace(/\r/g,`\r
7
+ `}a(xs,"createLogRecord");function Fd(e){if(hi){if(_C(e),as){$o=!1;try{process.stdout.write(e)}finally{$o=!0}}}else as&&process.stdout.write(e)}a(Fd,"logStdOut");function oh(e){if(hi){if(_C(e),as){$o=!1;try{process.stderr.write(e)}finally{$o=!0}}}else as&&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=pi.join(e,Wt.HDB_HOME_DIR_NAME,Wt.BOOT_PROPS_FILE_NAME);return zi.existsSync(t)||(t=pi.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:pi.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((Pge,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((Mge,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((Uge,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((Bge,vC)=>{"use strict";var Cl=Dn(),c2=W(),l2=M(),ah=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,MC),this.statusCode=n||Cl.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(Cl.DEFAULT_ERROR_MSGS[n]?Cl.DEFAULT_ERROR_MSGS[n]:Cl.DEFAULT_ERROR_MSGS[Cl.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR]),this.message=t.message?t.message:this.http_resp_msg,this.type=t.name,s&&(this.logLevel=s),typeof this.message!="string"&&(this.stack=t.stack),i&&c2[s](i)}},pg=class extends Error{static{a(this,"ClientError")}constructor(t,r){if(t instanceof Error)return t.statusCode=r||400,t;super(t),this.statusCode=r||400}},mg=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function 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:Cl}});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
- `)},d2="certificate.pem",_2="privateKey.pem",f2="caCertificate.pem",E2="natsCertificate.pem",h2="natsCaCertificate.pem",Rt={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},p2={tls_certificate:Rt.SERVER,tls_certificateAuthority:Rt.CA,customFunctions_tls_certificate:Rt.SERVER,customFunctions_tls_certificateAuthority:Rt.CA,operationsApi_tls_certificate:Rt["OPERATIONS-API"],operationsApi_tls_certificateAuthority:Rt["OPERATIONS-CA"]},m2={[Rt.SERVER]:2,[Rt.DEFAULT]:1},S2={[Rt["OPERATIONS-API"]]:3,[Rt.SERVER]:2,[Rt.DEFAULT]:1},T2={[Rt["OPERATIONS-API"]]:3,[Rt.SERVER]:2,[Rt.DEFAULT]:1},g2={[Rt["OPERATIONS-CA"]]:3,[Rt.CA]:2,[Rt["DEFAULT-CA"]]:1},A2={[Rt["OPERATIONS-CA"]]:3,[Rt.CA]:2,[Rt["DEFAULT-CA"]]:1},R2={[Rt.CA]:2,[Rt["DEFAULT-CA"]]:1};Object.assign(vC,{CERTIFICATE_PEM_NAME:d2,PRIVATEKEY_PEM_NAME:_2,CA_PEM_NAME:f2,CERT_NAME:Rt,CERT_CONFIG_NAME_MAP:p2,CERT_PREFERENCE_APP:m2,CERT_PREFERENCE_OPS:S2,CERT_PREFERENCE_REP:T2,CA_CERT_PREFERENCE_REP:g2,CA_CERT_PREFERENCE_OPS:A2,CA_CERT_PREFERENCE_APP:R2,CERTIFICATE_VALUES:u2,NATS_CERTIFICATE_PEM_NAME:E2,NATS_CA_PEM_NAME:h2})});var Tt=N((kge,BC)=>{"use strict";var nn=require("validate.js");nn.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||nn.validators.type.checks[t](e)?null:` must be a '${t}' value`};nn.validators.type.checks={Object:a(function(e){return nn.isObject(e)&&!nn.isArray(e)},"Object"),Array:nn.isArray,Integer:nn.isInteger,Number:nn.isNumber,String:nn.isString,Date:nn.isDate,Boolean:a(function(e){return typeof e=="boolean"},"Boolean")};nn.validators.hasValidFileExt=function(e,t){return nn.isString(e)?e===""?"can't be blank":t.filter(r=>e.endsWith(r)).length>0?null:`must include one of the following valid file extensions - '${t.join("', '")}'`:null};BC.exports={validateObject:y2,validateObjectAsync:b2,validateBySchema:O2};function y2(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=nn(e,t,{format:"flat"});return r?new Error(r):null}a(y2,"validateObject");async function b2(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await nn.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(b2,"validateObjectAsync");function O2(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(O2,"validateBySchema")});var gg=N((qge,qC)=>{"use strict";var FC=require("fs-extra"),me=require("joi"),N2=require("os"),{boolean:He,string:It,number:tr,array:Qa}=me.types(),{totalmem:HC}=require("os"),za=require("path"),I2=W(),Tg=te(),Gge=Sg(),xC=M(),w2=Tt(),kC="log",C2="components",D2="Invalid logging.rotation.maxSize unit. Available units are G, M or K",P2="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",L2="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",M2="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",U2="rootPath config parameter is undefined",sn=me.alternatives([tr.min(0),It]).optional().empty(null),ch=me.alternatives([Qa.items(It,{host:It.required(),port:sn},{hostname:It.required(),port:sn}).empty(null),Qa.items(It)]),mi,GC=!1;qC.exports={configValidator:v2,routesValidator:G2,route_constraints:ch};function v2(e,t=!1){if(GC=t,mi=e.rootPath,Tg.isEmpty(mi))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(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(H2).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:He.optional(),databaseLevel:He.optional(),tls:me.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:He.required(),verify:He.optional()}),user:It.optional().empty(null)}).optional():_=me.object({enabled:r,tls:me.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:He.optional()})}).optional(),me.object({authentication:me.alternatives(me.object({authorizeLocal:He,cacheTTL:tr.required(),enableSessions:He}),He).optional(),analytics:me.object({aggregatePeriod:tr}),replication:me.object({hostname:me.alternatives(It,tr).optional().empty(null),url:It.optional().empty(null),port:sn,securePort:sn,routes:Qa.optional().empty(null),databases:me.alternatives(It,Qa),enableRootCAs:He.optional(),copyTablesToCatchUp:He.optional()}).optional(),componentsRoot:s.optional(),clustering:_,localStudio:me.object({enabled:r}).required(),logging:me.object({auditAuthEvents:me.object({logFailed:He,logSuccessful:He}),file:He.required(),level:me.valid("notify","fatal","error","warn","info","debug","trace"),rotation:me.object({enabled:He.optional(),compress:He.optional(),interval:It.custom(k2).optional().empty(null),maxSize:It.custom(x2).optional().empty(null),path:It.optional().empty(null).default(Fd)}).required(),root:s,stdStreams:He.required(),auditLog:He.required()}).required(),operationsApi:me.object({network:me.object({cors:He.optional(),corsAccessList:Qa.optional(),headersTimeout:tr.min(1).optional(),keepAliveTimeout:tr.min(1).optional(),port:sn,domainSocket:me.optional().empty("hdb/operations-server").default(Fd),securePort:sn,timeout:tr.min(1).optional()}).optional(),tls:me.alternatives([me.array().items(d),d])}).required(),rootPath:It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:me.object({network:me.object({port:sn,securePort:sn,mtls:me.alternatives([He.optional(),me.object({user:It.optional(),certificateAuthority:i,required:He.optional()})])}).required(),webSocket:He.optional(),requireAuthentication:He.optional()}),http:me.object({compressionThreshold:tr.optional(),cors:He.optional(),corsAccessList:Qa.optional(),headersTimeout:tr.min(1).optional(),port:sn,securePort:sn,maxHeaderSize:tr.optional(),mtls:me.alternatives([He.optional(),me.object({user:It.optional(),certificateAuthority:i,required:He.optional()})]),threadRange:me.alternatives([Qa.optional(),It.optional()])}).required(),threads:me.alternatives(n.optional(),me.object({count:n.optional(),debug:me.alternatives(He.optional(),me.object({startingPort:tr.min(1).optional(),host:It.optional(),waitForDebugger:He.optional()})),maxHeapMemory:tr.min(0).optional()})),storage:me.object({writeAsync:He.required(),overlappingSync:He.optional(),caching:He.optional(),compression:me.alternatives([He.optional(),me.object({dictionary:It.optional(),threshold:tr.optional()})]),compactOnStart:He.optional(),compactOnStartKeepBackup:He.optional(),noReadAhead:He.optional(),path:l,prefetchWrites:He.optional(),maxFreeSpaceToLoad:tr.optional(),maxFreeSpaceToRetain:tr.optional()}).required(),ignoreScripts:He.optional(),tls:me.alternatives([me.array().items(d),d])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(v2,"configValidator");function B2(e){return GC||FC.existsSync(e)?null:`Specified path ${e} does not exist.`}a(B2,"doesPathExist");function H2(e,t){me.assert(e,It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=B2(e);if(r)return t.message(r)}a(H2,"validatePath");function x2(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(D2);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(L2):e}a(x2,"validateRotationMaxSize");function k2(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(P2);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(M2):e}a(k2,"validateRotationInterval");function F2(e,t){let r=t.state.path.join("."),n=N2.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||HC();return i=Math.round(Math.min(i,HC())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),I2.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(F2,"setDefaultThreads");function Fd(e,t){let r=t.state.path.join(".");if(!Tg.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(Tg.isEmpty(mi))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return za.join(mi,C2);case"logging.root":return za.join(mi,kC);case"clustering.leafServer.streams.path":return za.join(mi,"clustering","leaf");case"storage.path":let n=za.join(mi,xC.LEGACY_DATABASES_DIR_NAME);return FC.existsSync(n)?n:za.join(mi,xC.DATABASES_DIR_NAME);case"logging.rotation.path":return za.join(mi,kC);case"operationsApi.network.domainSocket":return r==null?null:za.join(mi,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(Fd,"setDefaultRoot");function G2(e){let t=me.object({routes:ch});return w2.validateBySchema({routes:e},t)}a(G2,"routesValidator")});var Ja={};je(Ja,{server:()=>it});var $C,it,qr=Ie(()=>{$C=L(Ei()),it={};(0,$C._assignPackageExport)("server",it)});var wt=N(ZC=>{"use strict";var on=M(),Er=te(),hr=W(),{configValidator:q2,routesValidator:VC}=gg(),$r=require("fs-extra"),YC=require("yaml"),Ln=require("path"),$2=require("is-number"),WC=require("properties-reader"),V2=require("lodash"),{handleHDBError:K2}=_e(),{HTTP_STATUS_CODES:Y2,HDB_ERROR_MSGS:Dl}=Dn(),{server:W2}=(qr(),oe(Ja)),{DATABASES_PARAM_CONFIG:Gd,CONFIG_PARAMS:Pn,CONFIG_PARAM_MAP:ks}=on,j2="Unable to get config value because config is uninitialized",z2="Config successfully initialized",Q2="Error backing up config file",J2="Empty parameter sent to getConfigValue",jC=Ln.join(on.PACKAGE_ROOT,"config","yaml",on.HDB_DEFAULT_CONFIG_FILE),X2=Ln.join(on.PACKAGE_ROOT,"config","yaml","defaultNatsConfig.yaml"),Z2="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",KC={logging_rotation_retain:"logging.rotation.retain",logging_rotation_rotate:"logging.rotation.rotate",logging_rotation_rotateinterval:"logging.rotation.rotateInterval",logging_rotation_rotatemodule:"logging.rotation.rotateModule",logging_rotation_timezone:"logging.rotation.timezone",logging_rotation_workerinterval:"logging.rotation.workerInterval"},lh,jt,uh;Object.assign(ZC,{createConfigFile:e4,getDefaultConfig:t4,getConfigValue:QC,initConfig:dh,flattenConfig:Pl,updateConfigValue:JC,updateConfigObject:n4,getConfiguration:o4,setConfiguration:a4,readConfigFile:bg,getClusteringRoutes:c4,initOldConfig:XC,getConfigFromFile:l4,getConfigFilePath:Xa,addConfig:u4,deleteConfigFromFile:d4,getConfigObj:_4,resolvePath:Ag,getFlatConfigObj:f4});function Ag(e){if(e?.startsWith("~/"))return Ln.join(Er.getHomeDir(),e.slice(1));let t=se();return Ln.resolve(t.getHdbBasePath(),e)}a(Ag,"resolvePath");function e4(e,t=!1){let r=Vo(jC);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=YC.parseDocument($r.readFileSync(X2,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}lh=Pl(r.toJSON());let n;for(let c in e){let l=ks[c.toLowerCase()];if(l===Pn.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(u=>({[u]:e[c][u]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let u=l.split("_"),d=Rg(l,e[c]);l==="rootPath"&&d?.endsWith("/")&&(d=d.slice(0,-1));try{r.setIn([...u],d)}catch(_){hr.error(_)}}}n&&zC(r,n),yg(r,t);let s=r.toJSON();jt=Pl(s);let i=r.getIn(["rootPath"]),o=Ln.join(i,on.HDB_CONFIG_FILE);$r.createFileSync(o),$r.writeFileSync(o,String(r)),hr.trace(`Config file written to ${o}`)}a(e4,"createConfigFile");function zC(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!Er.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(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 t4(e){if(lh===void 0){let r=Vo(jC);lh=Pl(r.toJSON())}let t=ks[e.toLowerCase()];if(t!==void 0)return lh[t.toLowerCase()]}a(t4,"getDefaultConfig");function QC(e){if(e==null){hr.info(J2);return}if(jt===void 0){hr.trace(j2);return}let t=ks[e.toLowerCase()];if(t!==void 0)return jt[t.toLowerCase()]}a(QC,"getConfigValue");function Xa(e=Er.getPropsFilePath()){let t=Er.getEnvCliRootPath();if(t)return Ag(Ln.join(t,on.HDB_CONFIG_FILE));let r=WC(e);return Ag(r.get(on.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(Xa,"getConfigFilePath");function dh(e=!1){if(jt===void 0||e){let t;if(!Er.noBootFile()){t=Er.getPropsFilePath();try{$r.accessSync(t,$r.constants.F_OK|$r.constants.R_OK)}catch(i){throw hr.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Xa(t),n;if(r.includes("config/settings.js"))try{XC(r);return}catch(i){if(i.code!==on.NODE_ERROR_CODES.ENOENT)throw i}try{n=Vo(r)}catch(i){if(i.code===on.NODE_ERROR_CODES.ENOENT){hr.trace(`HarperDB config file not found at ${r}.
11
- This can occur during early stages of install where the config file has not yet been created`);return}else throw hr.error(i),new Error(`Error reading HarperDB config file at ${r}`)}r4(n,r),yg(n);let s=n.toJSON();if(W2.config=s,jt=Pl(s),jt.logging_rotation_rotate)for(let i in KC)jt[i]&&hr.error(`Config ${KC[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);hr.trace(z2)}}a(dh,"initConfig");function r4(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Ln.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Ln.join(r,"log")),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n&&(hr.trace("Updating config file with missing config params"),$r.writeFileSync(t,String(e)))}a(r4,"checkForUpdatedConfig");function yg(e,t=!1){let r=e.toJSON();if(r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads),r.http?.port&&r.http?.port===r.http?.securePort)throw Dl.CONFIG_VALIDATION("http.port and http.securePort cannot be the same value");if(r.operationsApi?.network?.port&&r.operationsApi?.network?.port===r.operationsApi?.network?.securePort)throw Dl.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=q2(r,t);if(n.error)throw Dl.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket),r?.clustering?.enabled&&e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path)}a(yg,"validateConfig");function n4(e,t){jt===void 0&&(jt={});let r=ks[e.toLowerCase()];if(r===void 0){hr.trace(`Unable to update config object because config param '${e}' does not exist`);return}jt[r.toLowerCase()]=t}a(n4,"updateConfigObject");function JC(e,t,r=void 0,n=!1,s=!1,i=!1){jt===void 0&&dh();let o=QC(ks.hdb_root),c=Ln.join(o,on.HDB_CONFIG_FILE),l=Vo(c),u;if(r===void 0&&e.toLowerCase()===Pn.DATABASES)u=t;else if(r===void 0){let E;if(i)E=e;else if(E=ks[e.toLowerCase()],E===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let f=E.split("_"),h=Rg(E,t);l.setIn([...f],h)}else for(let E in r){let f=ks[E.toLowerCase()];if(f===Pn.HTTP_SECUREPORT&&r[E]===jt[Pn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),f===Pn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===jt[Pn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),f===Pn.DATABASES){u=r[E];continue}if(f?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!f&&(E.endsWith("_package")||E.endsWith("_port"))&&(f=E),f!==void 0){let h=f.split("_"),T=on.LEGACY_CONFIG_PARAMS[E.toUpperCase()];T&&T.startsWith("customFunctions")&&l.hasIn(T.split("_"))&&(f=T,h=T.split("_"));let m=Rg(f,r[E]);f==="rootPath"&&m?.endsWith("/")&&(m=m.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],m)}catch(g){hr.error(g)}}}u&&zC(l,u),yg(l);let d=l.getIn(["rootPath"]),_=Ln.join(d,on.HDB_CONFIG_FILE);n===!0&&s4(c,d),$r.writeFileSync(_,String(l)),s&&(jt=Pl(l.toJSON())),hr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(JC,"updateConfigValue");function s4(e,t){try{let r=Ln.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${on.HDB_CONFIG_FILE}.bak`);$r.copySync(e,r),hr.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){hr.error(Q2),hr.error(r)}}a(s4,"backupConfigFile");var i4=["databases"];function Pl(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network={...e.http,...e.operationsApi.network}),e?.operationsApi&&(e.operationsApi.tls={...e.tls,...e.operationsApi.tls}),uh=e,r(e);function r(n){let s={};for(let i in n)if(n.hasOwnProperty(i)){if(typeof n[i]=="object"&&n[i]!==null&&!Array.isArray(n[i])&&!i4.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!Pn[l.toUpperCase()]&&ks[l]&&(s[ks[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Pl,"flattenConfig");function Rg(e,t){if(e===Pn.CLUSTERING_NODENAME||e===Pn.CLUSTERING_USER){if(t==null)return t;if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if($2(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Er.isObject(t)||t===null)return t;if(typeof t=="string"&&t.toLowerCase()==="true")return!0;if(typeof t=="string"&&t.toLowerCase()==="false")return!1}if(t===void 0||t.toLowerCase()==="undefined")return null;if(typeof t=="string"&&(t.startsWith("{")&&t.endsWith("}")||t.startsWith("[")&&t.endsWith("]")))try{return JSON.parse(t)}catch{}return Er.autoCast(t)}a(Rg,"castConfigValue");function o4(){let e=Er.getPropsFilePath(),t=Xa(e);return Vo(t).toJSON()}a(o4,"getConfiguration");async function a4(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return JC(void 0,void 0,s,!0),Z2}catch(i){throw typeof i=="string"||i instanceof String?K2(i,i,Y2.BAD_REQUEST,void 0,void 0,!0):i}}a(a4,"setConfiguration");function bg(){let e=Er.getPropsFilePath();try{$r.accessSync(e,$r.constants.F_OK|$r.constants.R_OK)}catch(n){if(!Er.noBootFile())throw hr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Xa(e);return Vo(t).toJSON()}a(bg,"readConfigFile");function Vo(e){return YC.parseDocument($r.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Vo,"parseYamlDoc");function c4(){let e=bg(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Er.isEmptyOrZeroLength(t)?[]:t;let r=VC(t);if(r)throw Dl.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Er.isEmptyOrZeroLength(n)?[]:n;let s=VC(n);if(s)throw Dl.CONFIG_VALIDATION(s.message);if(!Er.isEmptyOrZeroLength(n)&&!Er.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Er.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw Dl.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(c4,"getClusteringRoutes");function XC(e){let t=WC(e);jt={};for(let r in ks){let n=t.get(r.toUpperCase());if(Er.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=ks[r].toLowerCase();s===Pn.LOGGING_ROOT?jt[s]=Ln.dirname(n):jt[s]=n}return jt}a(XC,"initOldConfig");function l4(e){let t=bg();return V2.get(t,e.replaceAll("_","."))}a(l4,"getConfigFromFile");async function u4(e,t){let r=Vo(Xa());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await $r.writeFile(Xa(),String(r))}a(u4,"addConfig");function d4(e){let t=Xa(Er.getPropsFilePath()),r=Vo(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Ln.join(n,on.HDB_CONFIG_FILE);$r.writeFileSync(s,String(r))}a(d4,"deleteConfigFromFile");function _4(){return uh||(dh(),uh)}a(_4,"getConfigObj");function f4(){return jt||dh(),jt}a(f4,"getFlatConfigObj")});var se=N((sD,iD)=>{"use strict";var Og=require("fs-extra"),Za=require("path"),eD=require("os"),E4=require("properties-reader"),$d=W(),qd=te(),De=M(),_h=wt(),h4="Error initializing environment manager",fh="BOOT_PROPS_FILE_PATH",tD=!1,p4={[De.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},Qi={};Object.assign(sD,iD.exports={BOOT_PROPS_FILE_PATH:fh,getHdbBasePath:m4,setHdbBasePath:S4,get:rD,initSync:g4,setProperty:Qe,initTestEnvironment:R4,setCloneVar:A4});function m4(){return Qi[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(m4,"getHdbBasePath");function S4(e){Qi[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(S4,"setHdbBasePath");function rD(e){let t=_h.getConfigValue(e);return t===void 0?Qi[e]:t}a(rD,"get");function Qe(e,t){p4[e]&&(Qi[e]=t),_h.updateConfigObject(e,t)}a(Qe,"setProperty");function T4(){let e;try{e=qd.getPropsFilePath(),Og.accessSync(e,Og.constants.F_OK|Og.constants.R_OK),tD=!0;let t=E4(e);return Qi[De.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(De.HDB_SETTINGS_NAMES.INSTALL_USER),Qi[De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),Qi[fh]=e,!0}catch{return $d.trace(`Environment manager found no properties file at ${e}`),!1}}a(T4,"doesPropFileExist");function g4(e=!1){try{((tD||T4()||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(h4),$d.error(t),console.error(t),process.exit(1)}}a(g4,"initSync");var nD=!1;function A4(e){nD=e}a(A4,"setCloneVar");function R4(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:n,https_enabled:s,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,l=Za.join(__dirname,"../../","unitTests");Qi[fh]=Za.join(l,"hdb_boot_properties.file"),Qe(De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Za.join(l,"settings.test")),Qe(De.HDB_SETTINGS_NAMES.INSTALL_USER,eD.userInfo()?eD.userInfo().username:void 0),Qe(De.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Qe(De.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Za.join(l,"envDir","log")),Qe(De.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Qe(De.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Qe(De.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Qe(De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Za.join(l,"envDir")),Qe(De.CONFIG_PARAMS.STORAGE_PATH,Za.join(l,"envDir")),s&&(Qe(De.CONFIG_PARAMS.HTTP_SECUREPORT,rD(De.CONFIG_PARAMS.HTTP_PORT)),Qe(De.CONFIG_PARAMS.HTTP_PORT,null)),Qe(De.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Qe(De.CONFIG_PARAMS.HTTP_PORT,9926),Qe(De.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Qe(De.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),Qe(De.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,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,Za.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(R4,"initTestEnvironment")});var gt=N((Wge,_D)=>{"use strict";var jd=M(),y4=te(),an=se(),zd=require("path"),b4=require("minimist"),oD=require("fs-extra"),aD=require("lodash");an.initSync();var{CONFIG_PARAMS:Ko,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(Ko.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 O4(e,t){let r=an.get(Ko.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||zd.join(uD(),e.toString())}a(O4,"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 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]?.[Vd.PATH];if(u)return aD.set(l,[Eh,Vd.TABLES,t,Vd.PATH],u),an.setProperty(Ko.DATABASES,l),u;let d=c?.[Vd.PATH];if(d)return aD.set(l,[Eh,Vd.PATH],d),an.setProperty(Ko.DATABASES,l),d}}let s=r[Ko.STORAGE_PATH.toUpperCase()];if(s){if(!oD.pathExistsSync(s))throw new Error(s+" does not exist");let i=zd.join(s,e);return oD.mkdirsSync(i),an.setProperty(Ko.STORAGE_PATH,s),i}return lD()}a(N4,"initSystemSchemaPaths");function I4(){Kd=void 0,Yd=void 0,Wd=void 0}a(I4,"resetPaths");_D.exports={getBaseSchemaPath:cD,getSystemSchemaPath:lD,getTransactionAuditStorePath:O4,getTransactionAuditStoreBasePath:uD,getSchemaPath:dD,initSystemSchemaPaths:N4,resetPaths:I4}});var cn=N((Jge,mD)=>{"use strict";var w4=Dn().LMDB_ERRORS_ENUM,zge=require("lmdb"),C4=Ht(),Qge=require("buffer").Buffer,{OVERFLOW_MARKER:fD,MAX_SEARCH_KEY_LENGTH:hh}=C4,ED=["number","string","symbol","boolean","bigint"];function D4(e){if(e=e?.primaryStore||e,!e)throw new Error(w4.ENV_REQUIRED)}a(D4,"validateEnv");function P4(e){if(e==null)return null;let t;try{t=typeof e=="object"?JSON.stringify(e):e.toString()}catch{t=e.toString()}return t}a(P4,"stringifyData");function L4(e){return e instanceof Date?e.valueOf():e}a(L4,"convertKeyValueToWrite");function M4(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(ED.includes(typeof e))return e.length>hh?[e.slice(0,hh)+fD]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(ED.includes(typeof i))i.length>hh?r.push(i.slice(0,hh)+fD):r.push(i);else{if(i===null&&t)return r.push(null);if(i instanceof Date)return r.push(i.getTime())}}}else if(e instanceof Date)return[e.getTime()];return r}a(M4,"getIndexedValues");var ph=0,hD=0;function pD(){hD=Date.now()-performance.now()}a(pD,"adjustStartTime");pD();var U4=6e4;setInterval(pD,U4).unref();function v4(){let e=performance.now()+hD;return e>ph?(ph=e,e):(ph+=488e-6,ph)}a(v4,"getNextMonotonicTime");mD.exports={validateEnv:D4,stringifyData:P4,convertKeyValueToWrite:L4,getNextMonotonicTime:v4,getIndexedValues:M4}});var Qd=N((Zge,SD)=>{"use strict";var B4=M().OPERATIONS_ENUM,Ng=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=B4.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};SD.exports=Ng});var Jd=N((rAe,RD)=>{"use strict";var tAe=Qd(),mh=M(),Ig=te(),TD=W(),H4=require("uuid"),{handleHDBError:Sh,hdb_errors:x4}=_e(),{HDB_ERROR_MSGS:Th,HTTP_STATUS_CODES:gh}=x4;RD.exports=gD;function gD(e,t,r){for(let s=0;s<t.length;s++)AD(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];k4(i,r,e.operation)}}a(gD,"processRows");gD.validateAttribute=AD;function AD(e){if(Buffer.byteLength(String(e))>mh.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw Sh(new Error,Th.ATTR_NAME_LENGTH_ERR(e),gh.BAD_REQUEST,void 0,void 0,!0);if(Ig.isEmptyOrZeroLength(e)||Ig.isEmpty(e.trim()))throw Sh(new Error,Th.ATTR_NAME_NULLISH_ERR,gh.BAD_REQUEST,void 0,void 0,!0)}a(AD,"validateAttribute");function k4(e,t,r){if(!e.hasOwnProperty(t)||Ig.isEmptyOrZeroLength(e[t])){if(r===mh.OPERATIONS_ENUM.INSERT||r===mh.OPERATIONS_ENUM.UPSERT){e[t]=H4.v4();return}throw TD.error("Update transaction aborted due to record with no hash value:",e),Sh(new Error,Th.RECORD_MISSING_HASH_ERR,gh.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>mh.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw TD.error(e),Sh(new Error,Th.HASH_VAL_LENGTH_ERR,gh.BAD_REQUEST,void 0,void 0,!0)}a(k4,"validateHash")});var yD,Mn,wg,Ll=Ie(()=>{yD=require("events"),Mn=class extends yD.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new wg;return t.queue=this,t}push(t){this.send(t)}send(t){this.resolveNext?(this.resolveNext({value:t}),this.resolveNext=null):this.hasDataListeners?this.emit("data",t):(this.queue||(this.queue=[]),this.queue.push(t))}getNextMessage(){let t=this.queue?.shift();return t||this.emit("drained"),t}waitForDrain(){return new Promise(t=>{!this.queue||this.queue.length===0?t(!0):(this.once("drained",()=>t(!0)),this.currentDrainResolver=t,this.drainCloseListener||(this.drainCloseListener=!0,this.on("close",()=>{this.currentDrainResolver?.(!1)})))})}on(t,r){if(t==="data"&&!this.hasDataListeners)for(this.hasDataListeners=!0;this.queue?.length>0;)r(this.queue.shift());return super.on(t,r)}},wg=class{static{a(this,"EventQueueIterator")}queue;push(t){this.queue.send(t)}next(){let t=this.queue.getNextMessage();return t?{value:t}:new Promise(r=>this.queue.resolveNext=r)}return(t){return this.queue.emit("close"),{value:t,done:!0}}throw(t){return this.queue.emit("close",t),{done:!0}}}});var Pg={};je(Pg,{loadGQLSchema:()=>q4,start:()=>Dg,startOnMainThread:()=>G4});function Dg({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:u,StringValueNode:d}=await import("graphql"),_=o(new c(r.toString(),s)),E=new Map,f=[],h;for(let g of _.definitions)switch(g.kind){case l.OBJECT_TYPE_DEFINITION:let H=function(Y){if(Y.kind==="NonNullType"){let Q=H(Y.type);return Q.nullable=!1,Q}if(Y.kind==="ListType")return{type:"array",elements:H(Y.type)};let ne={type:Y.name?.value};return Object.defineProperty(ne,"location",{value:Y.loc.startToken}),ne};a(H,"getProperty");let S=g.name.value,y=[],I={table:null,database:null,properties:y};E.set(S,I);for(let Y of g.directives){if(Y.name.value==="table"){for(let ne of Y.arguments)I[ne.name.value]=ne.value.value;I.schema&&(I.database=I.schema),I.table||(I.table=S),I.audit&&(I.audit=I.audit!=="false"),I.attributes=I.properties,f.push(I)}if(Y.name.value==="sealed"&&(I.sealed=!0),Y.name.value==="splitSegments"&&(I.splitSegments=!0),Y.name.value==="replicate"&&(I.replicate=!0),Y.name.value==="export"){I.export=!0;for(let ne of Y.arguments)typeof I.export!="object"&&(I.export={}),I.export[ne.name.value]=ne.value.value}}let U=!1,X={};for(let Y of g.fields){let V=H(Y.type);V.name=Y.name.value,y.push(V),X[V.name]=void 0;for(let ne of Y.directives){let Q=ne.name.value;if(Q==="primaryKey")U?console.warn("Can not define two attributes as a primary key at",ne.loc):(V.isPrimaryKey=!0,U=!0);else if(Q==="indexed")V.indexed=!0;else if(Q==="computed"){for(let de of ne.arguments||[])if(de.name.value==="from"){let j=de.value.value;V.computed={from:m(j,de,X)},V.version==null&&(V.version=j)}else de.name.value==="version"&&(V.version=de.value.value);V.computed=V.computed||!0}else if(Q==="relationship"){let de={};for(let j of ne.arguments)de[j.name.value]=j.value.value;V.relationship=de}else if(Q==="createdTime")V.assignCreatedTime=!0;else if(Q==="updatedTime")V.assignUpdatedTime=!0;else if(Q==="expiresAt")V.expiresAt=!0;else if(Q==="allow"){let de=V.authorizedRoles=[];for(let j of ne.arguments)j.name.value==="role"&&de.push(j.value.value)}else server.knownGraphQLDirectives.includes(Q)&&console.warn(`@${Q} is an unknown directive, at`,ne.loc)}}I.type=S,S==="Query"&&(h=I)}function T(g){let S=E.get(g.type);S?(Object.defineProperty(g,"properties",{value:S.properties}),Object.defineProperty(g,"definition",{value:S})):g.type==="array"?T(g.elements):F4.includes(g.type)||(0,OD.getWorkerIndex)()===0&&console.error(`The type ${g.type} is unknown at line ${g.location.line}, column ${g.location.column}, in ${s}`)}a(T,"connectPropertyType");for(let g of E.values())for(let S of g.properties)T(S);for(let g of f)g.tableClass=e(g),g.export&&(g.export.name===""?i.set((0,Cg.dirname)(n),g.tableClass):i.set((0,Cg.dirname)(n)+"/"+(g.export.name||g.type),g.tableClass,g.export));function m(g,S,y){return new bD.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${g}; } } } } computed;`,{filename:s,lineOffset:S.loc.startToken.line-1,columnOffset:S.loc.startToken.column}).runInThisContext()(y)}a(m,"createComputedFrom")}}var Cg,bD,OD,F4,G4,q4,ND=Ie(()=>{Cg=require("path"),bD=require("node:vm");Pe();OD=L(dt()),F4=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];server.knownGraphQLDirectives&&(server.knownGraphQLDirectives=["table","sealed","export","primaryKey","indexed","computed","relationship","createdTime","updatedTime","expiresAt","allow"]);a(Dg,"start");G4=Dg,q4=Dg({ensureTable:Et}).handleFile});var MD={};je(MD,{parse:()=>Mg,streamAsJSON:()=>Xd,stringify:()=>ec});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 ec(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===PD)return LD(e);if(t.resolution)return t.resolution.then(()=>ec(e));throw t}}function LD(e){let t=typeof e;if(t==="object"){if(e===null)return"null";e.toJSON&&(e=e.toJSON());let r;if(Array.isArray(e)){r="[";for(let n=0;n<e.length;n++)n>0&&(r+=","),r+=LD(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+ec(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function Mg(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),K4.test(e)?$4.parse(e):JSON.parse(e)):null}var CD,DD,$4,V4,PD,Lg,K4,Ug=Ie(()=>{CD=require("stream"),DD=L(require("json-bigint-fixes")),$4=(0,DD.default)({useNativeBigInt:!0}),V4=1e4,PD={message:"Cannot serialize BigInt to JSON"};BigInt.prototype.toJSON=function(){throw PD};a(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 ec(t)}else yield ec(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);wD(this.readIterator(this.iterator),t=>{t?(this.done=!0,this.push(null)):this._amReading=!1},t=>{console.error(t),this.done=!0,this.push(t.toString()),this.push(null)})}}push(t){return t===null||t instanceof Buffer?(this.bufferSize>0&&this.flush(),super.push(t)):(this.bufferSize+=t.length||t.toString().length,this.buffer.push(t),this.bufferSize>V4?this.flush():!0)}flush(){let t=super.push(this.buffer.join(""));return this.buffer=[],this.bufferSize=0,t}readIterator(t){try{let r;if(t.childIterator)return wD(this.readIterator(t.childIterator),n=>{if(n)return t.childIterator=null,this.readIterator(t)});do{let n=t.next();if(n.done)return!0;if(r=n.value,r==null)r="null";else{if(r.then)return this.flush(),Promise.resolve(r).then(s=>{if(s&&typeof s.return=="function")return t.childIterator=s,this.readIterator(t);if(this.push(s+""))return this.readIterator(t)});if(typeof r.return=="function")return t.childIterator=r,this.readIterator(t)}}while(this.push(r))}catch(r){return console.error(r),this.push(r.toString()),this.push(null),!0}}_destroy(t,r){for(let n of this.activeIterators)t?n.throw(t):n.return();r()}};a(ID,"handleError");a(wD,"when");a(ec,"stringify");a(LD,"jsStringify");K4=/[[,:]\s*-?\d{16,}/;a(Mg,"parse")});var YD=N((uAe,KD)=>{"use strict";var vg=require("recursive-iterator"),Y4=require("alasql"),Bg=require("clone"),UD=te(),{handleHDBError:vD,hdb_errors:W4}=_e(),{HDB_ERROR_MSGS:BD,HTTP_STATUS_CODES:HD}=W4,{getDatabases:j4}=(Pe(),oe(lt)),z4=["DISTINCT_ARRAY"],xD=Symbol("validateTables"),Hg=Symbol("validateTable"),lAe=Symbol("getAllColumns"),kD=Symbol("validateAllColumns"),Ah=Symbol("findColumn"),FD=Symbol("validateOrderBy"),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=j4();if(!r[t.databaseid])throw vD(new Error,BD.SCHEMA_NOT_FOUND(t.databaseid),HD.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw vD(new Error,BD.TABLE_NOT_FOUND(t.databaseid,t.tableid),HD.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=Bg(s);i.table=Bg(t),this.attributes.push(i)})}[Ah](t){return this.attributes.filter(r=>t.tableid?(r.table.as===t.tableid||r.table.tableid===t.tableid)&&r.attribute===t.columnid:r.attribute===t.columnid)}[qD](){let t=new vg(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[GD](r.tableid)}[GD](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new Y4.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[kD](){this[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&&z4.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=Bg(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[Ah](n)[0];s&&r.push(s)}}}),this.statement.group.forEach(n=>{let s=null;if(!n.columnid)r.forEach((i,o)=>{if(i.toString()===n.toString()){s=i,r.splice(o,1);return}});else{let i=this[Ah](n);if(!i||i.length===0)throw`unknown column '${n.toString()}' in group by`;if(i.length>1)throw`ambiguously defined column '${n.toString()}' in group by`;r.forEach((o,c)=>{if(o.attribute===i[0].attribute&&o.table.tableid===i[0].table.tableid){s=o,r.splice(c,1);return}})}if(!s)throw`group by column '${n.toString()}' must be in select`}),r.length>0)throw`select column '${r[0].attribute?r[0].attribute:r[0].toString()}' must be in group by`}[FD](t){let r=this.statement.columns.filter(n=>n.as===t.columnid);if(r.length>1)throw`ambiguous column reference ${(t.tableid?t.tableid+".":"")+t.columnid} in order by`;r.length===0&&this[xg](t)}[xg](t){let r=this[Ah](t),n=(t.tableid?t.tableid+".":"")+t.columnid;if(r.length===0)throw`unknown column ${n}`;if(r.length>1)throw`ambiguous column reference ${n}`;return r[0]}};KD.exports=kg});var jD=N((_Ae,WD)=>{"use strict";var Fg=class{static{a(this,"BridgeMethods")}createSchema(){throw new Error("createSchema bridge method is not defined")}dropSchema(){throw new Error("dropSchema bridge method is not defined")}createTable(){throw new Error("createTable bridge method is not defined")}dropTable(){throw new Error("dropTable bridge method is not defined")}createRecords(){throw new Error("createRecords bridge method is not defined")}updateRecords(){throw new Error("updateRecords bridge method is not defined")}async upsertRecords(){throw new Error("upsertRecords bridge method is not defined")}deleteRecords(){throw new Error("deleteRecords bridge method is not defined")}createAttribute(){throw new Error("createAttribute bridge method is not defined")}dropAttribute(){throw new Error("dropAttribute bridge method is not defined")}searchByConditions(){throw new Error("searchByConditions bridge method is not defined")}searchByHash(){throw new Error("searchByHash bridge method is not defined")}searchByValue(){throw new Error("searchByValue bridge method is not defined")}getDataByHash(){throw new Error("getDataByHash bridge method is not defined")}getDataByValue(){throw new Error("getDataByValue bridge method is not defined")}deleteRecordsBefore(){throw new Error("deleteRecordsBefore bridge method is not defined")}deleteAuditLogsBefore(){throw new Error("deleteAuditLogsBefore bridge method is not defined")}async readAuditLog(){throw new Error("readAuditLog bridge method is not defined")}};WD.exports=Fg});var QD=N((EAe,zD)=>{"use strict";var Gg=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};zD.exports=Gg});var eP={};je(eP,{HAS_EXPIRATION:()=>bh,HAS_RESIDENCY_ID:()=>zg,HAS_STRUCTURE_UPDATE:()=>Oh,LAST_TIMESTAMP_PLACEHOLDER:()=>n_,LOCAL_TIMESTAMP:()=>Q4,METADATA:()=>e_,NO_TIMESTAMP:()=>$g,PENDING_LOCAL_TIME:()=>Qg,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>jg,RecordEncoder:()=>Wg,TIMESTAMP_ASSIGN_LAST:()=>X4,TIMESTAMP_ASSIGN_NEW:()=>XD,TIMESTAMP_ASSIGN_PREVIOUS:()=>ZD,TIMESTAMP_PLACEHOLDER:()=>Rh,TIMESTAMP_RECORD_PREVIOUS:()=>Vg,getUpdateRecord:()=>Jg,handleLocalTimeForGets:()=>Nh});function eJ(){return 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,tc.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let l=0;l<tc.length;l++){let u=tc[l].deref();(!u||u.isDone||u.isCommitted)&&tc.splice(l--,1)}},i.prototype.done.isTracked=!0}return e}function Jg(e,t,r){return function(n,s,i,o,c=-1,l,u,d="put",_,E){_||l==null?Ml=i?.localTime?Vg|ZD:$g:Ml=l?i?.localTime?Vg|16384:XD|16384:$g;let f=u?.expiresAt;if(f>=0&&(c|=bh),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:Ml>0},T,m=0;try{let g=i?.residencyId,S=u?.residencyId;S&&(Yg=S,t_|=zg,m|=rc),g!==S&&(m|=nc,g||(g=0)),c&bh&&(m|=i_),u?.originatingOperation&&(m|=s_),_&&(h.ifVersion=T=i?.version??null);let y=e.put(n,s,h);if(l){let I=u?.user?.username;if(E&&(yh=e.encoder.encode(E)),e.encoder.hasStructureUpdate&&(m|=Oh,e.encoder.hasStructureUpdate=!1),_&&i?.localTime){let U=i?.localTime,H=r.get(U);if(H){let X=xt(H).previousLocalTime;return r.put(U,Ul(o,t,n,X,u?.nodeId??server.replication.getThisNodeId(r)??0,I,d,yh,m,S,g,f),{ifVersion:T}),y}}r.put(n_,Ul(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,I,d,yh,m,S,g,f,u?.originatingOperation),{append:d!=="invalidate",instructedWrite:!0,ifVersion:T})}return y}catch(g){throw g.message+=" id: "+n+" options: "+h,g}}}var JD,qg,Rh,n_,jg,Q4,e_,r_,J4,$g,XD,X4,ZD,Vg,bh,zg,Qg,Oh,Z4,yh,Ml,t_,Kg,Yg,Wg,tc,vl=Ie(()=>{JD=require("msgpackr");Ji();qg=L(W()),Rh=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]),Q4=Symbol("local-timestamp"),e_=Symbol("metadata"),r_=new Uint8Array(8),J4=new DataView(r_.buffer,0,8),$g=0,XD=0,X4=1,ZD=3,Vg=4,bh=16,zg=32,Qg=1,Oh=256,Ml=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(Ml||t_>=0){let o=0,c=Ml;c&&(o+=8,Ml=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 _=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(r_,0,c),c+=8;else for(let E=0;E<8;E++)r_[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:_,[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(eJ,"getTimestamp");a(Nh,"handleLocalTimeForGets");tc=[];setInterval(()=>{for(let e=0;e<tc.length;e++){let t=tc[e].deref();!t||t.isDone||t.isCommitted?tc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(qg.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):qg.error("Read transaction detected that has been open too long (over one minute), make sure read transactions are quickly closed",t)),t.openTimer++):t.openTimer=1)}},15e3).unref();a(Jg,"getUpdateRecord")});var o_=N((TAe,rP)=>{"use strict";var tP=se(),tJ=M(),{RecordEncoder:rJ}=(vl(),oe(eP)),SAe=require("fs");tP.initSync();var nJ=tP.get(tJ.CONFIG_PARAMS.STORAGE_CACHING)!==!1,Xg=class{static{a(this,"OpenDBIObject")}constructor(t,r=!1){this.dupSort=t===!0,this.encoding=t?"ordered-binary":"msgpack",this.useVersions=r,this.sharedStructuresKey=Symbol.for("structures"),r&&(this.cache=nJ&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:rJ})}};rP.exports=Xg});var a_=N((AAe,nP)=>{"use strict";var Un=se(),cs=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(cs.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Un.get(cs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Un.get(cs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Un.get(cs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Un.get(cs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Un.get(cs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Un.get(cs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Un.get(cs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Un.get(cs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Un.get(cs.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Un.get(cs.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Un.get(cs.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};nP.exports=Ih;Ih.MAX_DBS=1e4});var ht=N((yAe,fP)=>{"use strict";var eA=require("lmdb"),Fs=require("fs-extra"),vn=require("path"),wh=cn(),oP=W(),ln=Dn().LMDB_ERRORS_ENUM,Ch=QD(),tA=o_(),aP=a_(),Yo=Ht(),sP=M(),{table:sJ,resetDatabases:iJ}=(Pe(),oe(lt)),iP=se(),Gs=Yo.INTERNAL_DBIS_NAME,cP=Yo.DBI_DEFINITION_NAME,oJ="data.mdb",aJ="lock.mdb",c_=".mdb",cJ="-lock",Zg=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=ls(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+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,oJ),Fs.constants.R_OK|Fs.constants.F_OK),vn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(ln.INVALID_ENVIRONMENT)}else throw new Error(ln.INVALID_ENVIRONMENT);throw n}}a(rA,"validateEnvironmentPath");function Ph(e,t){if(wh.validateEnv(e),t===void 0)throw new Error(ln.DBI_NAME_REQUIRED)}a(Ph,"validateEnvDBIName");async function lJ(e,t,r=!1,n=!1){Dh(e,t);let s=vn.basename(e);t=t.toString();let i=iP.get(sP.CONFIG_PARAMS.DATABASES);i||iP.setProperty(sP.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await rA(e,t,n),lP(e,t,r)}catch(o){if(o.message===ln.INVALID_ENVIRONMENT){let c=vn.join(e,t);await Fs.mkdirp(n?c:e);let l=new aP(n?c:c+c_,!1),u=eA.open(l);u.dbis=Object.create(null);let d=new tA(!1);u.openDB(Gs,d),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let _=nA(e,t,r);return u[Yo.ENVIRONMENT_NAME_KEY]=_,global.lmdb_map[_]=u,u}throw o}}a(lJ,"createEnvironment");async function uJ(e,t,r,n=!0){Dh(e,t),t=t.toString();let s=vn.join(e,t);return sJ({table:t,database:vn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(uJ,"copyEnvironment");async function lP(e,t,r=!1){Dh(e,t),t=t.toString();let n=nA(e,t,r);if(global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null)),global.lmdb_map[n]!==void 0)return global.lmdb_map[n];let s=await rA(e,t),i=vn.join(e,t+c_),o=s!=i,c=new aP(s,o),l=eA.open(c);l.dbis=Object.create(null);let u=dP(l);for(let d=0;d<u.length;d++)ls(l,u[d]);return l[Yo.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(lP,"openEnvironment");async function dJ(e,t,r=!1){Dh(e,t),t=t.toString();let n=vn.join(e,t+c_),s=await rA(e,t);if(global.lmdb_map!==void 0){let i=nA(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await uP(o),delete global.lmdb_map[i]}}await Fs.remove(s),await Fs.remove(s===n?s+cJ:vn.join(vn.dirname(s),aJ))}a(dJ,"deleteEnvironment");async function uP(e){wh.validateEnv(e);let t=e[Yo.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(uP,"closeEnvironment");function nA(e,t,r=!1){let s=`${vn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(nA,"getCachedEnvironmentName");function _J(e){wh.validateEnv(e);let t=Object.create(null),r=ls(e,Gs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Gs)try{t[n]=Object.assign(new Ch,s)}catch{oP.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(_J,"listDBIDefinitions");function dP(e){wh.validateEnv(e);let t=[],r=ls(e,Gs);for(let{key:n}of r.getRange({start:!1}))n!==Gs&&t.push(n);return t}a(dP,"listDBIs");function fJ(e,t){let n=ls(e,Gs).getEntry(t),s=new Ch;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{oP.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(fJ,"getDBIDefinition");function _P(e,t,r,n=!r){if(Ph(e,t),t=t.toString(),t===Gs)throw new Error(ln.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return ls(e,t)}catch(s){if(s.message===ln.DBI_DOES_NOT_EXIST){let i=new tA(r,n===!0),o=e.openDB(t,i),c=new Ch(r===!0,n);return o[cP]=c,ls(e,Gs).putSync(t,c),e.dbis[t]=o,o}throw s}}a(_P,"createDBI");function ls(e,t){if(Ph(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Gs?r=fJ(e,t):r=new Ch,r===void 0)throw new Error(ln.DBI_DOES_NOT_EXIST);let n;try{let s=new tA(r.dup_sort,r.useVersions);if(n=e.openDB(t,s),n.db===void 0)throw new Error("MDB_NOTFOUND")}catch(s){throw s.message.includes("MDB_NOTFOUND")===!0?new Error(ln.DBI_DOES_NOT_EXIST):s}return n[cP]=r,e.dbis[t]=n,n}a(ls,"openDBI");function EJ(e,t){Ph(e,t),t=t.toString();let r=ls(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+c_);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);ls(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],ls(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{ls(e,i)}catch(o){if(o.message===ln.DBI_DOES_NOT_EXIST)_P(e,i,i!==t,i===t),n=!0;else throw o}}n&&iJ()}a(mJ,"initializeDBIs");fP.exports={openDBI:ls,openEnvironment:lP,createEnvironment:lJ,listDBIs:dP,listDBIDefinitions:_J,createDBI:_P,dropDBI:pJ,statDBI:EJ,deleteEnvironment:dJ,initializeDBIs:mJ,TransactionCursor:Zg,environmentDataSize:hJ,copyEnvironment:uJ,closeEnvironment:uP}});var hP=N((OAe,EP)=>{"use strict";var sA=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};EP.exports=sA});var mP=N((IAe,pP)=>{"use strict";var iA=class{static{a(this,"UpdateRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n,this.original_records=s}};pP.exports=iA});var TP=N((CAe,SP)=>{"use strict";var oA=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};SP.exports=oA});var ic=N((UAe,RP)=>{"use strict";var SJ=ht(),TJ=hP(),gJ=mP(),AJ=TP(),Si=cn(),l_=Dn().LMDB_ERRORS_ENUM,RJ=Ht(),Xi=M(),yJ=te(),bJ=require("uuid"),PAe=require("lmdb"),{handleHDBError:OJ,hdb_errors:NJ}=_e(),{OVERFLOW_MARKER:LAe,MAX_SEARCH_KEY_LENGTH:MAe}=RJ,gP=se();gP.initSync();var Lh=gP.get(Xi.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),aA=Xi.TIME_STAMP_NAMES_ENUM.CREATED_TIME,sc=Xi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function IJ(e,t,r,n,s=Si.getNextMonotonicTime()){dA(e,t,r,n),cA(e,t,r);let i=new TJ,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];AP(u,!0,s);let d=wJ(e,t,r,u),_=u[t];o.push(d),c.push(_)}return lA(o,c,n,i,s)}a(IJ,"insertRecords");function wJ(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let d=c([[{}]]);Array.isArray(d)&&(c=d[0][Xi.FUNC_VAL],n[o]=c)}let l=Si.getIndexedValues(c),u=e.dbis[o];if(l){Lh&&u.prefetch(l.map(d=>({key:d,value:s})),Mh);for(let d=0,_=l.length;d<_;d++)u.put(l[d],s)}}Lh&&e.dbis[t].prefetch([s],Mh),e.dbis[t].put(s,n,n[sc])})}a(wJ,"insertRecord");function CJ(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(CJ,"removeSkippedRecords");function AP(e,t,r){let n=r>0;(n||!Number.isInteger(e[sc]))&&(e[sc]=r||(r=Si.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[aA]))&&(e[aA]=r||Si.getNextMonotonicTime()):delete e[aA]}a(AP,"setTimestamps");function cA(e,t,r){r.indexOf(Xi.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Xi.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Xi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Xi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),SJ.initializeDBIs(e,t,r)}a(cA,"initializeTransaction");async function DJ(e,t,r,n,s=Si.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=Si.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||Si.getNextMonotonicTime(),CJ(r,i),n}a(lA,"finalizeWrite");function uA(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),u=l?.value,d=u;if(!u){if(i)return!1;u={}}if(AP(r,!d,o),Number.isInteger(r[sc])&&u[sc]>r[sc])return!1;d&&s.original_records.push(u);let _,E=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let T=r[h],m=e.dbis[h];if(m===void 0)continue;let g=u[h];if(typeof T=="function"){let y=T([[u]]);Array.isArray(y)&&(T=y[0][Xi.FUNC_VAL],r[h]=T)}if(T===g)continue;let S=Si.getIndexedValues(g);if(S){Lh&&m.prefetch(S.map(y=>({key:y,value:n})),Mh);for(let y=0,I=S.length;y<I;y++)m.remove(S[y],n)}if(S=Si.getIndexedValues(T),S){Lh&&m.prefetch(S.map(y=>({key:y,value:n})),Mh);for(let y=0,I=S.length;y<I;y++)m.put(S[y],n)}}let f={...u,...r};c.put(n,f,f[sc])},"do_put");return l?_=c.ifVersion(n,l.version,E):_=c.ifNoExists(n,E),_.then(f=>f?!0:uA(e,t,r,n,s,i,o))}a(uA,"updateUpsertRecord");function LJ(e,t,r){if(Si.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(LJ,"validateBasic");function dA(e,t,r,n){if(LJ(e,t,r),!Array.isArray(n))throw n===void 0?new Error(l_.RECORDS_REQUIRED):new Error(l_.RECORDS_MUST_BE_ARRAY)}a(dA,"validateWrite");function Mh(){}a(Mh,"noop");RP.exports={insertRecords:IJ,updateRecords:DJ,upsertRecords:PJ}});var Zi=N((BAe,MJ)=>{MJ.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"}]},hdb_certificate:{hash_attribute:"name",name:"hdb_certificate",schema:"system",attributes:[{attribute:"name"},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var gi=N((HAe,OP)=>{"use strict";var bP=te(),yP=M(),Bl=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Ti=require("joi"),Wo={schema_format:{pattern:Bl,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},UJ=Ti.alternatives(Ti.string().min(1).max(Wo.schema_length.maximum).pattern(Bl).messages({"string.pattern.base":"{:#label} "+Wo.schema_format.message}),Ti.number(),Ti.array()).required(),vJ=Ti.alternatives(Ti.string().min(1).max(Wo.schema_length.maximum).pattern(Bl).messages({"string.pattern.base":"{:#label} "+Wo.schema_format.message}),Ti.number()),BJ=Ti.alternatives(Ti.string().min(1).max(Wo.schema_length.maximum).pattern(Bl).messages({"string.pattern.base":"{:#label} "+Wo.schema_format.message}),Ti.number()).required();function HJ(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>Wo.schema_length.maximum?`'${e}' maximum of 250 characters`:Bl.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(HJ,"checkValidTable");function xJ(e,t){return bP.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(xJ,"validateSchemaExists");function kJ(e,t){let r=t.state.ancestors[0].schema;return bP.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(kJ,"validateTableExists");function FJ(e,t){return e.toLowerCase()===yP.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${yP.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(FJ,"validateSchemaName");OP.exports={common_validators:Wo,schema_regex:Bl,hdb_schema_table:UJ,validateSchemaExists:xJ,validateTableExists:kJ,validateSchemaName:FJ,checkValidTable:HJ,hdb_database:vJ,hdb_table:BJ}});var Uh=N((kAe,NP)=>{var{common_validators:Ai}=gi(),d_=Tt(),u_="is required",rr={database:{presence:!1,format:Ai.schema_format,length:Ai.schema_length},schema:{presence:!1,format:Ai.schema_format,length:Ai.schema_length},table:{presence:!0,format:Ai.schema_format,length:Ai.schema_length},attribute:{presence:!0,format:Ai.schema_format,length:Ai.schema_length},hash_attribute:{presence:!0,format:Ai.schema_format,length:Ai.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 GJ(e){return e=__(e),rr.table.presence=!1,rr.attribute.presence=!1,rr.hash_attribute.presence=!1,d_.validateObject(e,rr)}a(GJ,"schema_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,"table_object");function $J(e){return e=__(e),rr.table.presence={message:u_},rr.attribute.presence=!1,d_.validateObject(e,rr)}a($J,"create_table_object");function VJ(e){return e=__(e),rr.table.presence={message:u_},rr.attribute.presence={message:u_},rr.hash_attribute.presence=!1,d_.validateObject(e,rr)}a(VJ,"attribute_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,"describe_table");function YJ(e){if(e){if(!Array.isArray(e))throw new Error("residence must be a string array");if(e.length===0)throw new Error("residence cannot be an empty array");for(let t=0;t<e.length;t++)if(typeof e[t]!="string")throw new Error(`residence must be a string array, item '${e[t]}' is not a string`)}}a(YJ,"validateTableResidence");NP.exports={schema_object:GJ,create_table_object:$J,table_object:qJ,attribute_object:VJ,describe_table:KJ,validateTableResidence:YJ}});var wP=N((GAe,IP)=>{"use strict";var WJ=require("uuid"),_A=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||WJ.v4(),this.schema_table=`${this.schema}.${this.table}`}};IP.exports=_A});var vh=N(($Ae,CP)=>{"use strict";var jJ=wP(),fA=class extends jJ{static{a(this,"LMDBCreateAttributeObject")}constructor(t,r,n,s,i=!0,o=!1){super(t,r,n,s),this.dup_sort=i,this.is_hash_attribute=o}};CP.exports=fA});var PP=N((KAe,DP)=>{"use strict";DP.exports=QJ;var zJ="inserted";function QJ(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===zJ?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(QJ,"returnObject")});var Bh=N((jAe,vP)=>{"use strict";var JJ=M(),EA=ht(),XJ=ic(),{getSystemSchemaPath:ZJ,getSchemaPath:e3}=gt(),WAe=Zi(),t3=Uh(),r3=vh(),n3=PP(),{handleHDBError:LP,hdb_errors:UP}=_e(),MP=te(),{HTTP_STATUS_CODES:s3}=UP,i3="inserted";vP.exports=o3;async function o3(e){let t=t3.attribute_object(e);if(t)throw LP(new Error,t.message,UP.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&MP.checkGlobalSchemaTable(e.schema,e.table);if(r)throw LP(new Error,r,s3.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=MP.isEmpty(e.dup_sort)||e.dup_sort=="true";let n=[];if(global.hdb_schema[e.schema]&&global.hdb_schema[e.schema][e.table]&&(n=global.hdb_schema[e.schema][e.table].attributes),Array.isArray(n)&&n.length>0){for(let i of n)if(i.attribute===e.attribute)throw new Error(`attribute '${i.attribute}' already exists in ${e.schema}.${e.table}`)}let s=new r3(e.schema,e.table,e.attribute,e.id);try{let i=await EA.openEnvironment(e3(e.schema,e.table),e.table);if(i.dbis[e.attribute]!==void 0)throw new Error(`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`);EA.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await EA.openEnvironment(ZJ(),JJ.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await XJ.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return n3(i3,c,{records:[s]},l)}catch(i){throw i}}a(o3,"lmdbCreateAttribute")});var pA=N((QAe,HP)=>{var{hdb_table:a3,hdb_database:BP}=gi(),c3=Tt(),hA=require("joi"),l3={undefined:"undefined",null:"null"},u3=a((e,t)=>{let r=Object.keys(e),n=r.length,s;for(let i=0;i<n;i++){let o=r[i];(!o||o.length===0||l3[o]!==void 0)&&(s===void 0?s=`Invalid attribute name: '${o}'`:s+=`. Invalid attribute name: '${o}'`)}return s?t.message(s):e},"custom_records_val"),d3=hA.object({database:BP,schema:BP,table:a3,records:hA.array().items(hA.object().custom(u3)).required()});HP.exports=function(e){return c3.validateBySchema(e,d3)}});var f_=N((ZAe,kP)=>{"use strict";var eo=te(),xP=W(),XAe=pA(),{getDatabases:_3}=(Pe(),oe(lt)),{ClientError:oc}=_e();kP.exports=f3;function f3(e){if(eo.isEmpty(e))throw new oc("invalid update parameters defined.");if(eo.isEmptyOrZeroLength(e.schema))throw new oc("invalid schema specified.");if(eo.isEmptyOrZeroLength(e.table))throw new oc("invalid table specified.");if(!Array.isArray(e.records))throw new oc("records must be an array");let t=_3()[e.schema]?.[e.table];if(eo.isEmpty(t))throw new oc(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&eo.isEmptyOrZeroLength(o[r]))throw xP.error("a valid hash attribute must be provided with update record:",o),new oc("a valid hash attribute must be provided with update record, check log for more info");if(!eo.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw xP.error(`a valid hash value must be provided with ${e.operation} record:`,o),new oc(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!eo.isEmpty(o[r])&&o[r]!==""&&n.has(eo.autoCast(o[r]))&&(o.skip=!0),n.add(eo.autoCast(o[r]));for(let c in o)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}a(f3,"insertUpdateValidate")});var GP=N((tRe,FP)=>{"use strict";var mA=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};FP.exports=mA});var VP=N((nRe,$P)=>{"use strict";var SA=ht(),E3=W(),qP=Dn().LMDB_ERRORS_ENUM;$P.exports=h3;async function h3(e){try{if(global.lmdb_map!==void 0&&e.operation!==void 0){let t=Object.keys(global.lmdb_map),r;switch(e.operation){case"drop_schema":for(let i=0;i<t.length;i++){let o=t[i];if(o.startsWith(`${e.schema}.`)||o.startsWith(`txn.${e.schema}.`))try{await SA.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==qP.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await SA.closeEnvironment(global.lmdb_map[n]),await SA.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==qP.ENV_REQUIRED)throw i}break;case"drop_attribute":r=global.lmdb_map[`${e.schema}.${e.table}`],r!==void 0&&typeof r.dbis=="object"&&r.dbis[`${e.attribute}`]!==void 0&&delete r.dbis[`${e.attribute}`];break;default:break}}}catch(t){E3.error(t)}}a(h3,"cleanLMDBMap")});var to=N((iRe,jP)=>{"use strict";var E_=require("crypto"),p3=se(),{CONFIG_PARAMS:m3}=M(),YP="aes-256-cbc",S3=32,T3=16,TA=64,WP=32,g3=TA+WP,KP=new Map;jP.exports={encrypt:A3,decrypt:R3,createNatsTableStreamName:y3};function A3(e){let t=E_.randomBytes(S3),r=E_.randomBytes(T3),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(A3,"encrypt");function R3(e){let t=e.substr(0,TA),r=e.substr(TA,WP),n=e.substr(g3,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=E_.createDecipheriv(YP,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(R3,"decrypt");function y3(e,t){let r=p3.get(m3.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=KP.get(r);return n||(n=E_.createHash("md5").update(r).digest("hex"),KP.set(r,n)),n}a(y3,"createNatsTableStreamName")});var ro=N((cRe,JP)=>{"use strict";var aRe=Vr(),h_=W(),zP=Uh(),b3=to(),Hh=te(),{handleHDBError:xh,hdb_errors:O3}=_e(),{HDB_ERROR_MSGS:kh,HTTP_STATUS_CODES:gA}=O3,QP=se();QP.initSync();var{getDatabases:AA}=(Pe(),oe(lt)),N3=require("fs-extra"),I3=M();JP.exports={describeAll:w3,describeTable:Fh,describeSchema:C3};async function w3(e={}){try{let t=Hh.isEmptyOrZeroLength(e),r=!!e.bypass_auth,n,s;!t&&!r&&(n=e.hdb_user?.role?.permission,s=n?.super_user||n?.cluster_user);let i=AA(),o={},c={},l=[],u=e?.exact_count;for(let _ in i){o[_]=!0,!t&&!s&&!r&&(c[_]=e.hdb_user?.role?.permission[_]?.describe);let E=i[_];for(let f in E)try{let h;if(t||s||r)h=await Fh({schema:_,table:f,exact_count:u});else if(n&&n[_].describe&&n[_].tables[f].describe){let T=n[_].tables[f].attribute_permissions;h=await Fh({schema:_,table:f,exact_count:u},T)}h&&l.push(h)}catch(h){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(w3,"describeAll");async function Fh(e,t){Hh.transformReq(e);let{schema:r,table:n}=e;r=r?.toString(),n=n?.toString();let s=t;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(s=e.hdb_user?.role?.permission[r]?.tables[n]?.attribute_permissions);let i=zP.describe_table(e);if(i)throw i;let c=AA()[r];if(!c)throw xh(new Error,kh.SCHEMA_NOT_FOUND(e.schema),gA.NOT_FOUND);let l=c[n];if(!l)throw xh(new Error,kh.TABLE_NOT_FOUND(e.schema,e.table),gA.NOT_FOUND);function u(f){d.push({attribute:f.attribute,type:f.type,elements:f.elements?.type,indexed:f.indexed,is_primary_key:f.isPrimaryKey,assigned_created_time:f.assignCreatedTime,assigned_updated_time:f.assignUpdatedTime,nullable:f.nullable,properties:f.properties?f.properties.map(h=>({type:h.type,name:h.name})):void 0})}a(u,"pushAtt");let d=[];if(s){let f={};s.forEach(h=>{h.describe&&(f[h.attribute_name]=!0)}),l.attributes.forEach(h=>{f[h.name]&&u(h)})}else l.attributes?.forEach(f=>u(f));let _;try{_=(await N3.stat(l.primaryStore.env.path)).size}catch(f){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(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){h_.warn(`unable to stat table dbi due to ${f}`)}return E}a(Fh,"descTable");async function C3(e){Hh.transformReq(e);let t=zP.schema_object(e);if(t)throw t;let r;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(r=e.hdb_user?.role?.permission[e.schema]);let n=e.schema.toString(),i=AA()[n];if(!i)throw xh(new Error,kh.SCHEMA_NOT_FOUND(e.schema),gA.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),Hh.isEmpty(l)||l.describe){let u=await Fh({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(C3,"describeSchema")});var us=N((_Re,rL)=>{var D3=Zi(),{callbackify:ZP,promisify:P3}=require("util"),{getDatabases:eL}=(Pe(),oe(lt));rL.exports={setSchemaDataToGlobal:XP,getTableSchema:L3,getSystemSchema:M3,setSchemaDataToGlobalAsync:P3(XP)};var tL=ro(),uRe=ZP(tL.describeAll),dRe=ZP(tL.describeTable);function XP(e){global.hdb_schema=eL(),e&&e()}a(XP,"setSchemaDataToGlobal");function L3(e,t,r){let n=eL()[e];if(!n)return r(`schema ${e} does not exist`);let s=n[t];return s?r(null,{schema:e,name:t,hash_attribute:s.primaryKey}):r(`table ${e}.${t} does not exist`)}a(L3,"getTableSchema");function M3(){return D3}a(M3,"getSystemSchema")});var un=N((ERe,oL)=>{"use strict";var qh=pA(),Cr=te(),U3=require("util"),$h=Bn(),v3=us(),nL=W(),{handleHDBError:ac,hdb_errors:B3}=_e(),{HTTP_STATUS_CODES:cc}=B3,H3=U3.promisify(v3.getTableSchema),x3="updated",sL="inserted",iL="upserted";oL.exports={insert:F3,update:G3,upsert:q3,validation:k3,flush:$3};async function k3(e){if(Cr.isEmpty(e))throw new Error("invalid update parameters defined.");if(Cr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Cr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await H3(e.schema,e.table),r=qh(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let n=t.hash_attribute,s=new Set,i={},o=!1;return e.operation==="update"&&(o=!0),e.records.forEach(c=>{if(o&&Cr.isEmptyOrZeroLength(c[n]))throw nL.error("a valid hash attribute must be provided with update record:",c),new Error("a valid hash attribute must be provided with update record");if(!Cr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw nL.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Cr.isEmpty(c[n])&&c[n]!==""&&s.has(Cr.autoCast(c[n]))&&(c.skip=!0),s.add(Cr.autoCast(c[n]));for(let l in c)i[l]=1}),i[n]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(i)}}a(k3,"validation");async function F3(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=qh(e);if(t)throw ac(new Error,t.message,cc.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw ac(new Error,r,cc.BAD_REQUEST);let n=await $h.createRecords(e);return Gh(sL,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(F3,"insertData");async function G3(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=qh(e);if(t)throw ac(new Error,t.message,cc.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw ac(new Error,r,cc.BAD_REQUEST);let n=await $h.updateRecords(e);return Cr.isEmpty(n.existing_rows)?Gh(x3,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):Gh(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(G3,"updateData");async function q3(e){if(e.operation!=="upsert")throw ac(new Error,"invalid operation, must be upsert",cc.INTERNAL_SERVER_ERROR);let t=qh(e);if(t)throw ac(new Error,t.message,cc.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw ac(new Error,r,cc.BAD_REQUEST);let n=await $h.upsertRecords(e);return Gh(iL,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(q3,"upsertData");function Gh(e,t,r,n,s,i){let o={message:`${e} ${t.length} of ${t.length+n.length} records`,new_attributes:s,txn_time:i};return e===sL?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===iL?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(Gh,"returnObject");function $3(e){return Cr.transformReq(e),$h.flush(e.schema,e.table)}a($3,"flush")});var yA=N((pRe,lL)=>{var V3=Tt(),RA=require("joi"),{hdb_table:K3,hdb_database:aL}=gi(),cL={schema:aL,database:aL,table:K3},Y3={date:RA.date().iso().required()},W3={timestamp:RA.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};lL.exports=function(e,t){let r=t==="timestamp"?{...cL,...W3}:{...cL,...Y3},n=RA.object(r);return V3.validateBySchema(e,n)}});var _L=N((mRe,dL)=>{var j3=Tt(),bA=require("joi"),{hdb_table:z3,hdb_database:uL}=gi(),Q3=bA.object({schema:uL,database:uL,table:z3,hash_values:bA.array().required(),ids:bA.array()});dL.exports=function(e){return j3.validateBySchema(e,Q3)}});var wA=N((SRe,fL)=>{"use strict";var OA=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i){this.operation=t,this.schema=r,this.table=n,this.hash_attribute=s,this.records=i}},NA=class{static{a(this,"NoSQLSeachObject")}constructor(t,r,n,s,i,o){this.schema=t,this.table=r,this.search_attribute=n,this.hash_attribute=s,this.get_attributes=i,this.search_value=o}},IA=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};fL.exports={InsertObject:OA,NoSQLSeachObject:NA,DeleteResponseObject:IA}});var dc=N((gRe,SL)=>{"use strict";var hL=yA(),J3=_L(),lc=te(),EL=require("moment"),pL=W(),{promisify:X3,callbackify:Z3}=require("util"),uc=M(),eX=us(),CA=X3(eX.getTableSchema),DA=Bn(),{DeleteResponseObject:tX}=wA(),{handleHDBError:jo,hdb_errors:rX}=_e(),{HDB_ERROR_MSGS:Vh,HTTP_STATUS_CODES:zo}=rX,nX="records successfully deleted",sX=Z3(mL);SL.exports={delete:sX,deleteRecord:mL,deleteFilesBefore:iX,deleteAuditLogsBefore:oX};async function iX(e){let t=hL(e,"date");if(t)throw jo(t,t.message,zo.BAD_REQUEST,void 0,void 0,!0);if(lc.transformReq(e),!EL(e.date,EL.ISO_8601).isValid())throw jo(new Error,Vh.INVALID_DATE,zo.BAD_REQUEST,uc.LOG_LEVELS.ERROR,Vh.INVALID_DATE,!0);let n=lc.checkSchemaTableExist(e.schema,e.table);if(n)throw jo(new Error,n,zo.NOT_FOUND,uc.LOG_LEVELS.ERROR,n,!0);let s=await DA.deleteRecordsBefore(e);if(await CA(e.schema,e.table),pL.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(iX,"deleteFilesBefore");async function oX(e){let t=hL(e,"timestamp");if(t)throw jo(t,t.message,zo.BAD_REQUEST,void 0,void 0,!0);if(lc.transformReq(e),isNaN(e.timestamp))throw jo(new Error,Vh.INVALID_VALUE("Timestamp"),zo.BAD_REQUEST,uc.LOG_LEVELS.ERROR,Vh.INVALID_VALUE("Timestamp"),!0);let r=lc.checkSchemaTableExist(e.schema,e.table);if(r)throw jo(new Error,r,zo.NOT_FOUND,uc.LOG_LEVELS.ERROR,r,!0);let n=await DA.deleteAuditLogsBefore(e);return await CA(e.schema,e.table),pL.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(oX,"deleteAuditLogsBefore");async function mL(e){e.ids&&(e.hash_values=e.ids);let t=J3(e);if(t)throw jo(t,t.message,zo.BAD_REQUEST,void 0,void 0,!0);lc.transformReq(e);let r=lc.checkSchemaTableExist(e.schema,e.table);if(r)throw jo(new Error,r,zo.NOT_FOUND,uc.LOG_LEVELS.ERROR,r,!0);try{await CA(e.schema,e.table);let n=await DA.deleteRecords(e);return lc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${nX}`),n}catch(n){if(n.message===uc.SEARCH_NOT_FOUND_MESSAGE){let s=new tX;return s.message=uc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(mL,"deleteRecord")});var Kh=N((RRe,AL)=>{var aX=require("crypto"),TL=9;function cX(e){let t=uX(TL),r=gL(e+t);return t+r}a(cX,"createHash");function lX(e,t){let r=e?.substr(0,TL),n=r+gL(t+r);return e===n}a(lX,"validateHash");function uX(e){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ",r=t.length,n="";for(let s=0;s<e;s++){let i=Math.floor(Math.random()*r);n+=t[i]}return n}a(uX,"generateSalt");function gL(e){return aX.createHash("md5").update(e).digest("hex")}a(gL,"md5");AL.exports={hash:cX,validate:lX}});var yL=N((bRe,RL)=>{var PA=Tt(),Kr={username:{presence:!0,exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function dX(e){return Kr.password.presence=!0,Kr.username.presence=!0,Kr.role.presence=!0,Kr.active.presence=!0,PA.validateObject(e,Kr)}a(dX,"addUserValidation");function _X(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,PA.validateObject(e,Kr)}a(_X,"alterUserValidation");function fX(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,PA.validateObject(e,Kr)}a(fX,"dropUserValidation");RL.exports={addUserValidation:dX,alterUserValidation:_X,dropUserValidation:fX}});var Ct=N((IRe,OL)=>{"use strict";var{platform:NRe}=require("os"),EX="nats-server.zip",LA="nats-server",hX=process.platform==="win32"?`${LA}.exe`:LA,pX=/^[^\s.,*>]+$/,bL="__request__",mX=a(e=>`${e}.${bL}`,"REQUEST_SUBJECT"),SX={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},TX={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},gX={HUB:"hub.pid",LEAF:"leaf.pid"},AX={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},RX={SUCCESS:"success",ERROR:"error"},yX={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},bX={TXN:"txn",MSGID:"msgid"},Hl={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},OX={[Hl.ERR]:1,[Hl.WRN]:2,[Hl.INF]:3,[Hl.DBG]:4,[Hl.TRC]:5},NX={debug:"-D",trace:"-DVV"};OL.exports={NATS_SERVER_ZIP:EX,NATS_SERVER_NAME:LA,NATS_BINARY_NAME:hX,PID_FILES:gX,NATS_CONFIG_FILES:TX,SERVER_SUFFIX:AX,NATS_TERM_CONSTRAINTS_RX:pX,REQUEST_SUFFIX:bL,UPDATE_REMOTE_RESPONSE_STATUSES:RX,CLUSTER_STATUS_STATUSES:yX,REQUEST_SUBJECT:mX,SUBJECT_PREFIXES:bX,MSG_HEADERS:SX,LOG_LEVELS:Hl,LOG_LEVEL_FLAGS:NX,LOG_LEVEL_HIERARCHY:OX}});var IL=N((CRe,NL)=>{"use strict";var Yh=M(),Wh=class{static{a(this,"BaseLicense")}constructor(t=0,r=Yh.RAM_ALLOCATION_ENUM.DEFAULT,n=Yh.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},MA=class extends Wh{static{a(this,"ExtendedLicense")}constructor(t=0,r=Yh.RAM_ALLOCATION_ENUM.DEFAULT,n=Yh.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};NL.exports={BaseLicense:Wh,ExtendedLicense:MA}});var _c=N((PRe,UL)=>{"use strict";var kl=require("fs-extra"),CL=Kh(),DL=require("crypto"),IX=require("moment"),wX=require("uuid").v4,Yr=W(),vA=require("path"),CX=te(),Qo=M(),{totalmem:wL}=require("os"),DX=IL().ExtendedLicense,xl="invalid license key format",PX="061183",LX="mofi25",MX="aes-256-cbc",UX=16,vX=32,PL=se(),{resolvePath:LL}=wt();PL.initSync();var UA;UL.exports={validateLicense:ML,generateFingerPrint:HX,licenseSearch:xA,getLicense:FX,checkMemoryLimit:GX};function BA(){return vA.join(PL.getHdbBasePath(),Qo.LICENSE_KEY_DIR_NAME,Qo.LICENSE_FILE_NAME)}a(BA,"getLicenseDirPath");function BX(){let e=BA();return LL(vA.join(e,Qo.LICENSE_FILE_NAME))}a(BX,"getLicenseFilePath");function HA(){let e=BA();return LL(vA.join(e,Qo.REG_KEY_FILE_NAME))}a(HA,"getFingerPrintFilePath");async function HX(){let e=HA();try{return await kl.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await xX();throw Yr.error(`Error writing fingerprint file to ${e}`),Yr.error(t),new Error("There was an error generating the fingerprint")}}a(HX,"generateFingerPrint");async function xX(){let e=wX(),t=CL.hash(e),r=HA();try{await kl.mkdirp(BA()),await kl.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw Yr.error(`Error writing fingerprint file to ${r}`),Yr.error(n),new Error("There was an error generating the fingerprint")}return t}a(xX,"writeFingerprint");function ML(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:Qo.RAM_ALLOCATION_ENUM.DEFAULT,version:Qo.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Yr.error("empty license key passed to validate."),r;let n=HA(),s=!1;try{s=kl.statSync(n)}catch(i){Yr.error(i)}if(s){let i;try{i=kl.readFileSync(n,"utf8")}catch{Yr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(LX),c=o[1];c=Buffer.concat([Buffer.from(c)],UX);let l=Buffer.concat([Buffer.from(i)],vX),u=DL.createDecipheriv(MX,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let d=null;try{d=u.update(o[0],"hex","utf8"),d.trim(),d+=u.final("utf8")}catch{let f=kX(o[0],i);if(f)d=f;else throw r.valid_license=!1,r.valid_machine=!1,console.error(xl),Yr.error(xl),new Error(xl)}let _;if(isNaN(d))try{_=JSON.parse(d),r.version=_.version,r.exp_date=_.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),_.ram_allocation&&(r.ram_allocation=_.ram_allocation)}catch{throw console.error(xl),Yr.error(xl),new Error(xl)}else r.exp_date=d;r.exp_date<IX().valueOf()&&(r.valid_date=!1),CL.validate(o[1],`${PX}${i}${t}`)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||Yr.error("Invalid licence"),r}a(ML,"validateLicense");function kX(e,t){try{let r=DL.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{Yr.warn("Check old license failed")}}a(kX,"checkOldLicense");function xA(){let e=new DX,t=[];try{t=kl.readFileSync(BX(),"utf-8").split(Qo.NEW_LINE)}catch(r){r.code==="ENOENT"?Yr.debug("no license file found"):Yr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(CX.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=ML(s.license_key,s.company);i.valid_machine===!0&&i.valid_date===!0&&i.valid_machine===!0&&(e.exp_date=i.exp_date>e.exp_date?i.exp_date:e.exp_date,e.ram_allocation=i.ram_allocation,e.enterprise=!0)}catch(s){Yr.error("There was an error parsing the license string."),Yr.error(s),e.ram_allocation=Qo.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return UA=e,e}a(xA,"licenseSearch");async function FX(){return UA||await xA(),UA}a(FX,"getLicense");function GX(){let e=xA().ram_allocation,t=process.constrainedMemory?.()||wL();if(t=Math.round(Math.min(t,wL())/2**20),t>e)return`This server has more memory (${t}MB) than HarperDB is licensed for (${e}MB), this should only be used for educational and development purposes.`}a(GX,"checkMemoryLimit")});var xn=N((BRe,QL)=>{"use strict";var xL="username is required",kL="nothing to update, must supply active, role or password to update",FL="password cannot be an empty string",GL="If role is specified, it cannot be empty.",qL="active must be true or false";QL.exports={addUser:QX,alterUser:JX,dropUser:ZX,getSuperUser:nZ,userInfo:eZ,listUsers:zh,listUsersExternal:tZ,setUsersToGlobal:Gl,findAndValidateUser:jL,getClusterUser:sZ,USERNAME_REQUIRED:xL,ALTERUSER_NOTHING_TO_UPDATE:kL,EMPTY_PASSWORD:FL,EMPTY_ROLE:GL,ACTIVE_BOOLEAN:qL};var $L=un(),qX=dc(),GA=Kh(),VL=yL(),KL=Vr(),qA=no(),Hn=te(),YL=require("validate.js"),Ke=W(),{promisify:$X}=require("util"),$A=to(),vL=M(),BL=Ct(),VX=wt(),MRe=se(),URe=_c(),KX=Zi(),{table:vRe}=(Pe(),oe(lt)),{handleHDBError:Ri,hdb_errors:YX}=_e(),{HTTP_STATUS_CODES:yi,AUTHENTICATION_ERROR_MSGS:kA,HDB_ERROR_MSGS:Fl}=YX,{UserEventMsg:VA}=qs(),FA=require("lodash"),{server:KA}=(qr(),oe(Ja)),WX=W();KA.getUser=(e,t)=>jL(e,t,t!=null);var WL={username:!0,active:!0,role:!0,password:!0},HL=new Map,jh=KL.searchByValue,jX=KL.searchByHash,zX=$X(qX.delete);async function QX(e){let t=YL.cleanAttributes(e,WL),r=VL.addUserValidation(t);if(r)throw Ri(new Error,r.message,yi.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,Fl.ROLE_NAME_NOT_FOUND(t.role),yi.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw Ri(new Error,Fl.DUP_ROLES_FOUND(t.role),yi.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=$A.encrypt(t.password)),t.password=GA.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await $L.insert(i)}catch(l){throw Ke.error("There was an error searching for a user."),Ke.error(l),l}Ke.debug(o);try{await Gl()}catch(l){throw Ke.error("Got an error setting users to global"),Ke.error(l),l}if(o.skipped_hashes.length===1)throw Ri(new Error,Fl.USER_ALREADY_EXISTS(t.username),yi.CONFLICT,void 0,void 0,!0);let c={...t};return c.role=s[0],qA.signalUserChange(new VA(process.pid)),`${c.username} successfully added`}a(QX,"addUser");async function JX(e){let t=YL.cleanAttributes(e,WL);if(Hn.isEmptyOrZeroLength(t.username))throw new Error(xL);if(Hn.isEmptyOrZeroLength(t.password)&&Hn.isEmptyOrZeroLength(t.role)&&Hn.isEmptyOrZeroLength(t.active))throw new Error(kL);if(!Hn.isEmpty(t.password)&&Hn.isEmptyOrZeroLength(t.password.trim()))throw new Error(FL);if(!Hn.isEmpty(t.active)&&!Hn.isBoolean(t.active))throw new Error(qL);let r=XX(t.username);if(!Hn.isEmpty(t.password)&&!Hn.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=$A.encrypt(t.password)),t.password=GA.hash(t.password)),t.role==="")throw new Error(GL);if(t.role){let i={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]},o;try{o=Array.from(await jh(i)||[])}catch(c){throw Ke.error("Got an error searching for a role."),Ke.error(c),c}if(!o||o.length===0){let c=Fl.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Ke.error(c),Ri(new Error,c,yi.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=Fl.ALTER_USER_DUP_ROLES(t.role);throw Ke.error(c),Ri(new Error,c,yi.CONFLICT,void 0,void 0,!0)}t.role=o[0].id}let n={operation:"update",schema:"system",table:"hdb_user",records:[t]},s;try{s=await $L.update(n)}catch(i){throw Ke.error("Error during update."),Ke.error(i),i}try{await Gl()}catch(i){throw Ke.error("Got an error setting users to global"),Ke.error(i),i}return qA.signalUserChange(new VA(process.pid)),s}a(JX,"alterUser");function XX(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(XX,"isClusterUser");async function ZX(e){try{let t=VL.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(Hn.isEmpty(global.hdb_users.get(e.username)))throw Ri(new Error,Fl.USER_NOT_EXIST(e.username),yi.NOT_FOUND,void 0,void 0,!0);let n;try{n=await zX(r)}catch(s){throw Ke.error("Got an error deleting a user."),Ke.error(s),s}Ke.debug(n);try{await Gl()}catch(s){throw Ke.error("Got an error setting users to global."),Ke.error(s),s}return qA.signalUserChange(new VA(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(ZX,"dropUser");async function eZ(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=FA.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await jX(r)}catch(s){throw Ke.error("Got an error searching for a role."),Ke.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw Ke.error(r),r}return t}a(eZ,"userInfo");async function tZ(){let e;try{e=await zh()}catch(t){throw Ke.error("Got an error listing users."),Ke.error(t),t}try{e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token})}catch{throw new Error("there was an error massaging the user data")}return[...e.values()]}a(tZ,"listUsersExternal");async function zh(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await jh(e)}catch(o){throw Ke.error("Got an error searching for roles."),Ke.error(o),o}let r={};for(let o of t)r[o.id]=FA.cloneDeep(o);if(Object.keys(r).length===0)return null;let n={schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]},s;try{s=await jh(n)}catch(o){throw Ke.error("Got an error searching for users."),Ke.error(o),o}let i=new Map;for(let o of s)o=FA.cloneDeep(o),o.role=r[o.role],rZ(o.role),i.set(o.username,o);return i}catch(e){throw Ke.error("got an error listing users"),Ke.error(e),Hn.errorizeMessage(e)}return null}a(zh,"listUsers");function rZ(e){try{if(!e){Ke.error("invalid user role found.");return}e.permission.system||(e.permission.system={}),e.permission.system.tables||(e.permission.system.tables={});for(let t of Object.keys(KX)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){Ke.error("Got an error trying to set system permissions."),Ke.error(t)}}a(rZ,"appendSystemTablesToRole");async function Gl(){try{let e=await zh();global.hdb_users=e}catch(e){throw Ke.error(e),e}}a(Gl,"setUsersToGlobal");async function jL(e,t,r=!0){global.hdb_users||await Gl();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw Ri(new Error,kA.GENERIC_AUTH_FAIL,yi.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw Ri(new Error,kA.USER_INACTIVE,yi.UNAUTHORIZED,void 0,void 0,!0);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(HL.get(t)===n.password)return s;if(GA.validate(n.password,t))HL.set(t,n.password);else throw Ri(new Error,kA.GENERIC_AUTH_FAIL,yi.UNAUTHORIZED,void 0,void 0,!0)}return s}a(jL,"findAndValidateUser");async function nZ(){global.hdb_users||await Gl();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(nZ,"getSuperUser");async function sZ(){let e=await zh(),t=VX.getConfigFromFile(vL.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!Hn.isEmpty(r)&&r?.role?.role===vL.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=$A.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+BL.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+BL.SERVER_SUFFIX.ADMIN,r}a(sZ,"getClusterUser");var zL=[];KA.invalidateUser=function(e){for(let t of zL)try{t(e)}catch(r){WX.error("Error invalidating user",r)}};KA.onInvalidatedUser=function(e){zL.push(e)}});var m_=N((FRe,eM)=>{"use strict";var fc=W(),kn=M(),iZ=VP(),xRe=us(),kRe=ro(),oZ=xn(),{validateEvent:JL}=qs(),p_=Bn(),aZ=require("process"),{resetDatabases:cZ}=(Pe(),oe(lt)),lZ={[kn.ITC_EVENT_TYPES.SCHEMA]:uZ,[kn.ITC_EVENT_TYPES.USER]:ZL};async function uZ(e){let t=JL(e);if(t){fc.error(t);return}fc.trace("ITC schemaHandler received schema event:",e),await iZ(e.message),await dZ(e.message)}a(uZ,"schemaHandler");async function dZ(e){try{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=cZ();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){fc.error(t)}}a(dZ,"syncSchemaMetadata");var XL=[];async function ZL(e){try{try{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){fc.warn(r)}let t=JL(e);if(t){fc.error(t);return}fc.trace(`ITC userHandler ${kn.HDB_ITC_CLIENT_PREFIX}${aZ.pid} received user event:`,e),await oZ.setUsersToGlobal();for(let r of XL)r()}catch(t){fc.error(t)}}a(ZL,"userHandler");ZL.addListener=function(e){XL.push(e)};eM.exports=lZ});var qs=N((YRe,rM)=>{"use strict";var qRe=W(),YA=te(),_Z=M(),{ITC_ERRORS:S_}=Dn(),{parentPort:$Re,threadId:fZ,isMainThread:EZ,workerData:VRe}=require("worker_threads"),{onMessageFromWorkers:hZ,broadcast:KRe,broadcastWithAcknowledgement:pZ}=dt();rM.exports={sendItcEvent:mZ,validateEvent:tM,SchemaEventMsg:SZ,UserEventMsg:TZ};var Qh;hZ(async(e,t)=>{Qh=Qh||m_(),tM(e),Qh[e.type]&&await Qh[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function mZ(e){return!EZ&&e.message&&(e.message.originator=fZ),pZ(e)}a(mZ,"sendItcEvent");function tM(e){if(typeof e!="object")return S_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||YA.isEmpty(e.type))return S_.MISSING_TYPE;if(!e.hasOwnProperty("message")||YA.isEmpty(e.message))return S_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||YA.isEmpty(e.message.originator))return S_.MISSING_ORIGIN;if(_Z.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return S_.INVALID_EVENT(e.type)}a(tM,"validateEvent");function SZ(e,t,r,n=void 0,s=void 0){this.originator=e,this.operation=t,this.schema=r,this.table=n,this.attribute=s}a(SZ,"SchemaEventMsg");function TZ(e){this.originator=e}a(TZ,"UserEventMsg")});var no=N((zRe,oM)=>{"use strict";var nM=M(),jRe=te(),Jh=W(),sM=GP(),ql,{sendItcEvent:iM}=qs();function gZ(e){try{Jh.info("signalSchemaChange called with message:",e),ql=ql||m_();let t=new sM(nM.ITC_EVENT_TYPES.SCHEMA,e);return ql.schema(t),iM(t)}catch(t){Jh.error(t)}}a(gZ,"signalSchemaChange");function AZ(e){try{Jh.trace("signalUserChange called with message:",e),ql=ql||m_();let t=new sM(nM.ITC_EVENT_TYPES.USER,e);return ql.user(t),iM(t)}catch(t){Jh.error(t)}}a(AZ,"signalUserChange");oM.exports={signalSchemaChange:gZ,signalUserChange:AZ}});var Xh=N((JRe,cM)=>{"use strict";var aM=te(),RZ=M(),yZ=W(),bZ=Bh(),OZ=vh(),NZ=no(),{SchemaEventMsg:IZ}=qs(),wZ="already exists in";cM.exports=CZ;async function CZ(e,t,r){if(aM.isEmptyOrZeroLength(r))return r;let n=[];aM.isEmptyOrZeroLength(t.attributes)||t.attributes.forEach(i=>{n.push(i.attribute)});let s=r.filter(i=>n.indexOf(i)<0);return s.length===0||await Promise.all(s.map(async i=>{await DZ(e,t.schema,t.name,i)})),s}a(CZ,"lmdbCheckForNewAttributes");async function DZ(e,t,r,n){let s=new OZ(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await PZ(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(wZ))yZ.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(DZ,"createNewAttribute");async function PZ(e){let t;return t=await bZ(e),NZ.signalSchemaChange(new IZ(process.pid,RZ.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(PZ,"createAttribute")});var $l=N((ZRe,lM)=>{"use strict";var WA=class{static{a(this,"LMDBTransactionObject")}constructor(t,r,n,s,i=void 0){this.operation=t,this.user_name=r,this.timestamp=n,this.hash_values=s,this.origin=i}};lM.exports=WA});var dM=N((tye,uM)=>{"use strict";var LZ=$l(),MZ=M().OPERATIONS_ENUM,jA=class extends LZ{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(MZ.INSERT,r,n,s,i),this.records=t}};uM.exports=jA});var fM=N((nye,_M)=>{"use strict";var UZ=$l(),vZ=M().OPERATIONS_ENUM,zA=class extends UZ{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(vZ.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};_M.exports=zA});var hM=N((iye,EM)=>{"use strict";var BZ=$l(),HZ=M().OPERATIONS_ENUM,QA=class extends BZ{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(HZ.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};EM.exports=QA});var mM=N((aye,pM)=>{"use strict";var xZ=$l(),kZ=M().OPERATIONS_ENUM,JA=class extends xZ{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(kZ.DELETE,n,s,t,i),this.original_records=r}};pM.exports=JA});var T_=N((uye,AM)=>{"use strict";var lye=require("path"),SM=ht(),FZ=dM(),GZ=fM(),qZ=hM(),$Z=mM(),Vl=Ht(),TM=te(),{CONFIG_PARAMS:VZ}=M(),gM=se();gM.initSync();var Zh=M().OPERATIONS_ENUM,{getTransactionAuditStorePath:KZ}=gt();AM.exports=YZ;async function YZ(e,t){if(gM.get(VZ.LOGGING_AUDITLOG)===!1)return;let r=KZ(e.schema,e.table),n=await SM.openEnvironment(r,e.table,!0),s=WZ(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){SM.initializeDBIs(n,Vl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Vl.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Vl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Vl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),TM.isEmpty(s.user_name)||n.dbis[Vl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Vl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(YZ,"writeTransaction");function WZ(e,t){let r=TM.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===Zh.INSERT)return new FZ(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zh.UPDATE)return new GZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zh.UPSERT)return new qZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zh.DELETE)return new $Z(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(WZ,"createTransactionObject")});var XA=N((fye,RM)=>{"use strict";var jZ=f_(),_ye=Qd(),g_=M(),zZ=Jd(),QZ=ic().insertRecords,JZ=ht(),XZ=W(),ZZ=Xh(),{getSchemaPath:e5}=gt(),t5=T_();RM.exports=r5;async function r5(e){try{let{schema_table:t,attributes:r}=jZ(e);zZ(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 ZZ(e.hdb_auth_header,t,r),s=e5(e.schema,e.table),i=await JZ.openEnvironment(s,e.table),o=await QZ(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await t5(e,o)}catch(c){XZ.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(r5,"lmdbCreateRecords")});var OM=N((hye,bM)=>{"use strict";var yM=M(),n5=XA(),s5=Qd(),i5=require("fs-extra"),{getSchemaPath:o5}=gt();bM.exports=a5;async function a5(e){let t=[{name:e.schema,createddate:Date.now()}],r=new s5(yM.SYSTEM_SCHEMA_NAME,yM.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await n5(r),await i5.mkdirp(o5(e.schema))}a(a5,"lmdbCreateSchema")});var IM=N((mye,NM)=>{"use strict";var ZA=class{static{a(this,"DeleteRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.deleted=t,this.skipped=r,this.txn_time=n,this.original_records=s}};NM.exports=ZA});var PM=N((Rye,DM)=>{"use strict";var wM=ht(),eR=cn(),tR=Dn().LMDB_ERRORS_ENUM,c5=Ht(),CM=W(),Tye=te(),l5=require("lmdb"),u5=IM(),d5=M(),{OVERFLOW_MARKER:gye,MAX_SEARCH_KEY_LENGTH:Aye}=c5,_5=d5.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function f5(e,t,r,n){if(eR.validateEnv(e),t===void 0)throw new Error(tR.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(tR.IDS_REQUIRED):new Error(tR.IDS_MUST_BE_ITERABLE);try{let s=wM.listDBIs(e);wM.initializeDBIs(e,t,s);let i=new u5,o,c=[],l=[];for(let E=0,f=r.length;E<f;E++)try{o=r[E];let h=e.dbis[t].get(o);if(!h||n&&h[_5]>n){i.skipped.push(o);continue}let T=e.dbis[t].ifVersion(o,l5.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let m=0;m<s.length;m++){let g=s[m];if(!h.hasOwnProperty(g)||g===t)continue;let S=e.dbis[g],y=h[g];if(y!=null)try{let I=eR.getIndexedValues(y);if(I)for(let U=0,H=I.length;U<H;U++)S.remove(I[U],o)}catch{CM.warn(`cannot delete from attribute: ${g}, ${y}:${o}`)}}});c.push(T),l.push(o),i.original_records.push(h)}catch(h){CM.warn(h),i.skipped.push(o)}let u=[],d=await Promise.all(c);for(let E=0,f=d.length;E<f;E++)d[E]===!0?i.deleted.push(l[E]):(i.skipped.push(l[E]),u.push(E));let _=0;for(let E=0;E<u.length;E++){let f=u[E];i.original_records.splice(f-_,1),_++}return i.txn_time=eR.getNextMonotonicTime(),i}catch(s){throw s}}a(f5,"deleteRecords");DM.exports={deleteRecords:f5}});var A_=N((bye,MM)=>{"use strict";var Kl=te(),E5=PM(),h5=ht(),{getSchemaPath:p5}=gt(),m5=T_(),S5=W();MM.exports=T5;async function T5(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Kl.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Kl.isEmptyOrZeroLength(e.hash_values)&&!Kl.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Kl.isEmpty(l)||e.hash_values.push(l)}}if(Kl.isEmptyOrZeroLength(e.hash_values))return LM([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Kl.isEmptyOrZeroLength(e.records)){e.records=[];for(let c=0;c<e.hash_values.length;c++)e.records[c]={[n]:e.hash_values[c]}}let s=p5(e.schema,e.table),i=await h5.openEnvironment(s,e.table),o=await E5.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await m5(e,o)}catch(c){S5.error(`unable to write transaction due to ${c.message}`)}return LM(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(T5,"lmdbDeleteRecords");function LM(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}a(LM,"createDeleteResponse")});var nR=N((Iye,UM)=>{"use strict";var g5=M(),Nye=cn();function rR(e,t){let r=Object.create(null);if(t.length===1&&g5.SEARCH_WILDCARDS.indexOf(t[0])>=0)Object.assign(r,e);else for(let n=0;n<t.length;n++){let s=t[n],i=e[s];r[s]=i===void 0?null:i}return r}a(rR,"parseRow");function A5(e,t,r,n){let s=rR(r,e);n.push(s)}a(A5,"searchAll");function R5(e,t,r,n){let s=rR(r,e);n[t]=s}a(R5,"searchAllToMap");function y5(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(y5,"iterateDBI");function Ec(e,t,r,n,s){let i=Object.create(null);i[s]=e;let o;n===s?o=e:(o=t,n!==void 0&&(i[n]=o)),r[0].push(o),r[1].push(i)}a(Ec,"pushResults");function b5(e,t,r,n,s,i){t.toString().endsWith(e)&&Ec(t,r,n,s,i)}a(b5,"endsWith");function O5(e,t,r,n,s,i){t.toString().includes(e)&&Ec(t,r,n,s,i)}a(O5,"contains");function N5(e,t,r,n,s,i){t>e&&Ec(t,r,n,s,i)}a(N5,"greaterThanCompare");function I5(e,t,r,n,s,i){t>=e&&Ec(t,r,n,s,i)}a(I5,"greaterThanEqualCompare");function w5(e,t,r,n,s,i){t<e&&Ec(t,r,n,s,i)}a(w5,"lessThanCompare");function C5(e,t,r,n,s,i){t<=e&&Ec(t,r,n,s,i)}a(C5,"lessThanEqualCompare");UM.exports={parseRow:rR,searchAll:A5,searchAllToMap:R5,iterateDBI:y5,endsWith:b5,contains:O5,greaterThanCompare:N5,greaterThanEqualCompare:I5,lessThanCompare:w5,lessThanEqualCompare:C5,pushResults:Ec}});var Yl=N((Lye,GM)=>{"use strict";var Jo=ht(),Cye=W(),Fn=cn(),ep=Ht(),zt=Dn().LMDB_ERRORS_ENUM,Dye=te(),D5=M(),tp=nR(),{parseRow:P5}=tp,Pye=require("lmdb"),{OVERFLOW_MARKER:vM,MAX_SEARCH_KEY_LENGTH:L5}=ep;function BM(e,t,r,n=!1,s=void 0,i=void 0){return hc(e,t,r,(o,c)=>c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}))}a(BM,"iterateFullIndex");function R_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return hc(e,t,r,(d,_,E,f)=>{let S={transaction:d,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return f===r?(S.values=!1,_.getRange(S).map(y=>({value:y}))):_.getRange(S)})}a(R_,"iterateRangeBetween");function hc(e,t,r,n){let s=e.database||e,i=Jo.openDBI(s,r);i[ep.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&Jo.openDBI(s,t);let o;e.database?o=e:(o=e.useReadTransaction(),o.database=e);let c=n(o,i,s,t);return c.transaction=o,e.database||(c.onDone=()=>{o.done()}),c}a(hc,"setupTransaction");function HM(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(vM)){if(!s)if(r)s=Jo.openDBI(e,r);else{let l=Jo.listDBIs(e);for(let u=0,d=l.length;u<d&&(s=Jo.openDBI(e,l[u]),!s[ep.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(HM,"getOverflowCheck");function M5(e,t,r,n=!1,s=void 0,i=void 0){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return hc(e,t,t,(o,c,l)=>(rp(r),r=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=>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=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(U5,"searchAllToMap");function v5(e,t,r=!1,n=void 0,s=void 0){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=BM(e,void 0,t,r,n,s),c=o.transaction,l=HM(c.database,c,void 0,t);for(let{key:u,value:d}of o){let _=l(u,d);i[_]===void 0&&(i[_]=[]),i[_].push(d)}return i}a(v5,"iterateDBI");function B5(e,t){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return Jo.statDBI(e,t).entryCount}a(B5,"countAll");function H5(e,t,r,n,s=!1,i=void 0,o=void 0){return Xo(e,r,n),hc(e,t,r,(c,l,u,d)=>(n=Fn.convertKeyValueToWrite(n),d===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(_=>({key:n,value:_}))))}a(H5,"equals");function x5(e,t,r){return Xo(e,t,r),Jo.openDBI(e,t).getValuesCount(r)}a(x5,"count");function k5(e,t,r,n,s=!1,i=void 0,o=void 0){return Xo(e,r,n),hc(e,null,r,(c,l)=>{n=Fn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let d;if(s===!0){let _;for(let E of l.getKeys({transaction:c,start:n}))if(!E.startsWith(n)){_=E;break}return _!==void 0&&(Number.isInteger(o)?o++:i++),d=l.getRange({transaction:c,start:_,end:void 0,reverse:s,limit:i,offset:o}).map(E=>{let{key:f}=E;if(f!==_){if(f.toString().startsWith(n))return E;if(u===!0)return d.DONE}}),d.filter(E=>E)}else return d=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(_=>{if(_.key.toString().startsWith(n))return _;if(u===!0)return d.DONE}),u?d:d.filter(_=>_)})}a(k5,"startsWith");function F5(e,t,r,n,s=!1,i=void 0,o=void 0){return xM(e,t,r,n,s,i,o,!0)}a(F5,"endsWith");function xM(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Xo(e,r,n),hc(e,null,r,(l,u,d,_)=>{let E=HM(d,l,_,r);return o=Number.isInteger(o)?o:0,u.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(f=>{let h=f.toString();return h.endsWith(vM)?u.getValues(f,{transaction:l}).map(T=>{let m=E(f,T);if(c?m.endsWith(n):m.includes(n))return{key:m,value:T}}).filter(T=>T):(c?h.endsWith(n):h.includes(n))?u[ep.DBI_DEFINITION_NAME].is_hash_attribute?{key:f,value:f}:u.getValues(f,{transaction:l}).map(T=>({key:f,value:T})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(xM,"contains");function G5(e,t,r,n,s=!1,i=void 0,o=void 0){Xo(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),R_(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),R_(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),R_(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),R_(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 R_(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=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(Y5,"searchByHash");function W5(e,t,r){Fn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(W5,"checkHashExists");function j5(e,t,r,n,s=[]){return FM(e,t,r,n,s),kM(e,t,r,n,s).map(i=>i[1])}a(j5,"batchSearchByHash");function z5(e,t,r,n,s=[]){FM(e,t,r,n,s);let i=new Map;for(let[o,c]of kM(e,t,r,n,s))i.set(o,c);return i}a(z5,"batchSearchByHashToMap");function kM(e,t,r,n,s=[]){return hc(e,t,t,(i,o,c)=>{r=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 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 y_(e,t){return t.length===1&&D5.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=Jo.listDBIs(e)),t}a(y_,"setGetWholeRowAttributes");GM.exports={searchAll:M5,searchAllToMap:U5,count:x5,countAll:B5,equals:H5,startsWith:k5,endsWith:F5,contains:xM,searchByHash:Y5,setGetWholeRowAttributes:y_,batchSearchByHash:j5,batchSearchByHashToMap:z5,checkHashExists:W5,iterateDBI:v5,greaterThan:G5,greaterThanEqual:q5,lessThan:$5,lessThanEqual:V5,between:K5}});var Wl=N((Uye,YM)=>{var qM=require("lodash"),$M=Tt(),xe=require("joi"),Q5=te(),{hdb_schema_table:b_,checkValidTable:VM,hdb_table:KM,hdb_database:np}=gi(),{handleHDBError:J5,hdb_errors:X5}=_e(),{getDatabases:Z5}=(Pe(),oe(lt)),{HTTP_STATUS_CODES:e6}=X5,t6=xe.object({database:np,schema:np,table:KM,search_attribute:b_,search_value:xe.any().required(),get_attributes:xe.array().min(1).items(xe.alternatives(b_,xe.object())).optional(),desc:xe.bool(),limit:xe.number().integer().min(1),offset:xe.number().integer().min(0)}),r6=xe.object({database:np,schema:np,table:KM,operator:xe.string().valid("and","or").default("and").lowercase(),offset:xe.number().integer().min(0),limit:xe.number().integer().min(1),get_attributes:xe.array().min(1).items(xe.alternatives(b_,xe.object())).optional(),sort:xe.object({attribute:xe.alternatives(b_,xe.array().min(1)),descending:xe.bool().optional()}).optional(),conditions:xe.array().min(1).items(xe.alternatives(xe.object({operator:xe.string().valid("and","or").default("and").lowercase(),conditions:xe.array()}),xe.object({search_attribute:xe.alternatives(b_,xe.array().min(1)),search_type:xe.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:xe.when("search_type",{switch:[{is:"equals",then:xe.any()},{is:"between",then:xe.array().items(xe.alternatives([xe.string(),xe.number()])).length(2)}],otherwise:xe.alternatives(xe.string(),xe.number())}).required()}))).required()});YM.exports=function(e,t){let r=null;switch(t){case"value":r=$M.validateBySchema(e,t6);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(VM("database",e.schema)),i(VM("table",e.table)),e.hash_values?Array.isArray(e.hash_values)?e.hash_values.every(o=>typeof o=="string"||typeof o=="number")||i("'hash_values' must be strings or numbers"):i("'hash_values' must be an array"):i("'hash_values' is required"),e.get_attributes?Array.isArray(e.get_attributes)?e.get_attributes.length===0?i("'get_attributes' must contain at least 1 item"):e.get_attributes.every(o=>typeof o=="string"||typeof o=="number")||i("'get_attributes' must be strings or numbers"):i("'get_attributes' must be an array"):i("'get_attributes' is required"),s&&(r=new Error(s.trim()));break;case"conditions":r=$M.validateBySchema(e,r6);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=Q5.checkGlobalSchemaTable(e.schema,e.table);if(s)return J5(new Error,s,e6.NOT_FOUND);let o=Z5()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(d=>{for(let _=0,E=d.conditions.length;_<E;_++){let f=d.conditions[_];f.conditions?l(f):c.push(f.search_attribute)}},"addConditions");t==="conditions"&&l(e);let u=qM.filter(c,d=>d!=="*"&&!d.startsWith?.("$")&&d.attribute!=="*"&&!Array.isArray(d)&&!d.name&&!qM.some(o,_=>_===d||_.attribute===d||_.attribute===d.attribute));if(u&&u.length>0){let d=u.join(", ");return d=d.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${d}'`)}}return r}});var sR=N((Bye,WM)=>{"use strict";var n6=ht(),s6=Wl(),{getSchemaPath:i6}=gt();WM.exports=o6;function o6(e){let t=s6(e,"hashes");if(t)throw t;let r=i6(e.schema,e.table);return n6.openEnvironment(r,e.table)}a(o6,"initialize")});var iR=N((xye,jM)=>{"use strict";var a6=Yl(),c6=sR();jM.exports=l6;async function l6(e){let t=await c6(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return a6.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(l6,"lmdbGetDataByHash")});var jl=N((Fye,zM)=>{"use strict";var oR=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};zM.exports=oR});var JM=N(($ye,QM)=>{"use strict";var qye=jl(),u6=Yl(),d6=sR();QM.exports=_6;async function _6(e){let t=await d6(e),r=global.hdb_schema[e.schema][e.table];return u6.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(_6,"lmdbSearchByHash")});var $s=N((Kye,XM)=>{"use strict";var aR=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,u=void 0,d=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=u,this.offset=d}};XM.exports=aR});var sp=N((Wye,sU)=>{"use strict";var Wr=Yl(),f6=ht(),E6=te(),ke=Ht(),pc=M(),h6=Zi(),ZM=Dn().LMDB_ERRORS_ENUM,{getSchemaPath:p6}=gt(),so=pc.SEARCH_WILDCARDS;async function m6(e,t,r){let n;e.schema===pc.SYSTEM_SCHEMA_NAME?n=h6[e.table]:n=global.hdb_schema[e.schema][e.table];let s=nU(e,n.hash_attribute,r,t);return tU(e,s,n.hash_attribute,r)}a(m6,"prepSearch");async function tU(e,t,r,n){let s=p6(e.schema,e.table),i=await f6.openEnvironment(s,e.table),o=rU(i,e,t,r),c=o.transaction||i;if([ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,ke.SEARCH_TYPES.SEARCH_ALL,ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(S6(e,r)===!1){let d=e.search_attribute;if(d===r)return n?eU(o,()=>!0):o.map(E=>({[r]:E.key}));let _=a(E=>({[r]:E.value,[d]:E.key}),"toObject");return n?eU(o,_):o.map(_)}let u=e.search_attribute===r?o.map(d=>d.key):o.map(d=>d.value);return n===!0?Wr.batchSearchByHashToMap(c,r,e.get_attributes,u):Wr.batchSearchByHash(c,r,e.get_attributes,u)}a(tU,"executeSearch");function rU(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case ke.SEARCH_TYPES.EQUALS:s=Wr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.CONTAINS:s=Wr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.ENDS_WITH:case ke.SEARCH_TYPES._ENDS_WITH:s=Wr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.STARTS_WITH:case ke.SEARCH_TYPES._STARTS_WITH:s=Wr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Wr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Wr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case ke.SEARCH_TYPES.SEARCH_ALL:return Wr.searchAll(e,n,t.get_attributes,o,c,l);case ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Wr.searchAllToMap(e,n,t.get_attributes,o,c,l);case ke.SEARCH_TYPES.BETWEEN:s=Wr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case ke.SEARCH_TYPES.GREATER_THAN:case ke.SEARCH_TYPES._GREATER_THAN:s=Wr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.GREATER_THAN_EQUAL:case ke.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Wr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.LESS_THAN:case ke.SEARCH_TYPES._LESS_THAN:s=Wr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.LESS_THAN_EQUAL:case ke.SEARCH_TYPES._LESS_THAN_EQUAL:s=Wr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(rU,"searchByType");function eU(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(eU,"createMapFromIterable");function S6(e,t){if(e.get_attributes.length===1&&e.get_attributes[0]==="*")return!0;let r=[e.search_attribute];e.get_attributes.indexOf(t)>=0&&r.push(t);let n=!1;for(let s=0;s<e.get_attributes.length;s++)if(r.indexOf(e.get_attributes[s])<0){n=!0;break}return n}a(S6,"checkToFetchMore");function nU(e,t,r,n){if(E6.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),o=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),so.indexOf(s)>-1)return r===!0?ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP:ke.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(so[0])<0&&s.indexOf(so[1])<0)return c===!0?r===!0?ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:ke.SEARCH_TYPES.EQUALS;if(so.indexOf(i)>=0&&so.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),ke.SEARCH_TYPES.CONTAINS;if(so.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),ke.SEARCH_TYPES.ENDS_WITH;if(so.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),ke.SEARCH_TYPES.STARTS_WITH;if(s.includes(so[0])||s.includes(so[1]))return ke.SEARCH_TYPES.EQUALS;throw new Error(ZM.UNKNOWN_SEARCH_TYPE)}else switch(n){case pc.VALUE_SEARCH_COMPARATORS.BETWEEN:return ke.SEARCH_TYPES.BETWEEN;case pc.VALUE_SEARCH_COMPARATORS.GREATER:return ke.SEARCH_TYPES.GREATER_THAN;case pc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return ke.SEARCH_TYPES.GREATER_THAN_EQUAL;case pc.VALUE_SEARCH_COMPARATORS.LESS:return ke.SEARCH_TYPES.LESS_THAN;case pc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return ke.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(ZM.UNKNOWN_SEARCH_TYPE)}}a(nU,"createSearchTypeFromSearchObject");sU.exports={executeSearch:tU,createSearchTypeFromSearchObject:nU,prepSearch:m6,searchByType:rU}});var oU=N((Qye,iU)=>{"use strict";var zye=$s(),T6=Wl(),g6=te(),A6=M(),R6=sp();iU.exports=y6;function y6(e,t){if(!g6.isEmpty(t)&&A6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=T6(e,"value");if(n)throw n;return R6.prepSearch(e,t,!0)}a(y6,"lmdbGetDataByValue")});var O_=N((Zye,aU)=>{"use strict";var Xye=$s(),b6=Wl(),O6=te(),N6=M(),I6=sp();aU.exports=w6;async function w6(e,t){if(!O6.isEmpty(t)&&N6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=b6(e,"value");if(n)throw n;return I6.prepSearch(e,t,!1)}a(w6,"lmdbSearchByValue")});var lU=N((rbe,cU)=>{"use strict";var tbe=Ht(),cR=class{static{a(this,"SearchByConditionsObject")}constructor(t,r,n,s,i=void 0,o=void 0,c="and"){this.schema=t,this.table=r,this.get_attributes=n,this.limit=i,this.offset=o,this.conditions=s,this.operator=c}},lR=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},uR=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};cU.exports={SearchByConditionsObject:cR,SearchCondition:lR,SortAttribute:uR}});var EU=N((obe,fU)=>{"use strict";var sbe=lU().SearchByConditionsObject,C6=$s(),D6=Wl(),dR=Yl(),ip=Ht(),{Resource:ibe}=(Vs(),oe(_R)),_U=sp(),P6=nR(),L6=require("lodash"),{getSchemaPath:M6}=gt(),uU=ht(),{handleHDBError:U6,hdb_errors:v6}=_e(),{HTTP_STATUS_CODES:B6}=v6,H6=1e8;fU.exports=x6;async function x6(e){let t=D6(e,"conditions");if(t)throw U6(t,t.message,B6.BAD_REQUEST,void 0,void 0,!0);e.operator=e.operator?e.operator.toLowerCase():void 0,e.offset=Number.isInteger(e.offset)?e.offset:0;let r=M6(e.schema,e.table),n=await uU.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)uU.openDBI(n,u.search_attribute);let i=L6.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let d=u.search_type;d===ip.SEARCH_TYPES.EQUALS?u.estimated_count=dR.count(n,u.search_attribute,u.search_value):d===ip.SEARCH_TYPES.CONTAINS||d===ip.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=H6}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await dU(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let u=n.dbis[s.hash_attribute],d=i.slice(1).map(_U.filterByType),_=d.length,E=dR.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(f=>u.get(f,{transaction:o,lazy:!0})),_>0&&(l=l.filter(f=>{for(let h=0;h<_;h++)if(!d[h](f))return!1;return!0})),(e.offset||e.limit!==void 0)&&(l=l.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),l=l.map(f=>P6.parseRow(f,E))}else{for(let _=1;_<i.length;_++){let E=i[_],f=await dU(o,e,E,s.hash_attribute);c=c.concat(f)}let u=new Set,d=e.offset||0;c=c.filter(_=>u.has(_)?!1:(u.add(_),!0)).slice(d,e.limit&&e.limit+d),l=dR.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(x6,"lmdbSearchByConditions");async function dU(e,t,r,n){let s=new C6(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===ip.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,_U.searchByType(e,s,i,n).map(o=>o.value)}a(dU,"executeConditionSearch")});var N_=N((cbe,hU)=>{"use strict";var k6=M().OPERATIONS_ENUM,fR=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=k6.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};hU.exports=fR});var ER=N((ube,yU)=>{"use strict";var TU=$s(),gU=N_(),AU=O_(),RU=A_(),dn=M(),pU=te(),mU=ht(),{getTransactionAuditStorePath:F6,getSchemaPath:G6}=gt(),SU=W();yU.exports=q6;async function q6(e){try{if(pU.isEmpty(global.hdb_schema[e.schema])||pU.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await $6(e),await V6(e);let t=G6(e.schema,e.table);try{await mU.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")SU.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=F6(e.schema,e.table);await mU.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")SU.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(q6,"lmdbDropTable");async function $6(e){let t=new TU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await AU(t)),n=[];for(let i=0;i<r.length;i++){let o=r[i];n.push(o.id)}if(n.length===0)return;let s=new gU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await RU(s)}a($6,"deleteAttributesFromSystem");async function V6(e){let t=new TU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await AU(t))}catch(i){throw i}for(let i=0;i<r.length;i++){let o=r[i];o.name===e.table&&o.schema===e.schema&&(n=o)}if(!n)throw new Error(`${e.schema}.${e.table} was not found`);let s=new gU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await RU(s)}catch(i){throw i}}a(V6,"dropTableFromSystem")});var OU=N((_be,bU)=>{"use strict";var K6=require("fs-extra"),Y6=$s(),W6=jl(),j6=N_(),z6=ER(),Q6=A_(),J6=iR(),X6=O_(),io=M(),{getSchemaPath:Z6}=gt(),{handleHDBError:e8,hdb_errors:t8}=_e(),{HDB_ERROR_MSGS:r8,HTTP_STATUS_CODES:n8}=t8;bU.exports=s8;async function s8(e){let t;try{t=await i8(e.schema);let r=new Y6(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await X6(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await z6(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new j6(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await Q6(s);let i=Z6(t);await K6.remove(i)}catch(r){throw r}}a(s8,"lmdbDropSchema");async function i8(e){let t=new W6(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await J6(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw e8(new Error,r8.SCHEMA_NOT_FOUND(e),n8.NOT_FOUND,void 0,void 0,!0);return n}a(i8,"validateDropSchema")});var I_=N((Ebe,NU)=>{"use strict";var hR=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};NU.exports=hR});var mR=N((mbe,IU)=>{"use strict";var o8=require("fs-extra"),op=ht(),{getTransactionAuditStorePath:a8}=gt(),pR=Ht(),pbe=I_();IU.exports=c8;async function c8(e){let t;try{let r=a8(e.schema,e.table);await o8.mkdirp(r),t=await op.createEnvironment(r,e.table,!0)}catch(r){throw r.message=`unable to create transactions audit environment for ${e.schema}.${e.table} due to: ${r.message}`,r}try{op.createDBI(t,pR.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),op.createDBI(t,pR.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),op.createDBI(t,pR.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME,!0,!1)}catch(r){throw r.message=`unable to create dbi for ${e.schema}.${e.table} due to: ${r.message}`,r}return t}a(c8,"createTransactionsAuditEnvironment")});var DU=N((gbe,CU)=>{"use strict";var SR=M(),wU=ht(),l8=ic(),{getSystemSchemaPath:u8,getSchemaPath:d8}=gt(),Tbe=Zi(),_8=Bh(),TR=vh(),f8=W(),E8=mR();CU.exports=h8;async function h8(e,t){let r=d8(t.schema,t.table),n=new TR(t.schema,t.table,SR.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new TR(t.schema,t.table,SR.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new TR(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await wU.createEnvironment(r,t.table),e!==void 0){let o=await wU.openEnvironment(u8(),SR.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await l8.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_table_attributes,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await gR(n),await gR(s),await gR(i)}await E8(t)}catch(o){throw o}}a(h8,"lmdbCreateTable");async function gR(e){try{await _8(e)}catch(t){f8.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(gR,"createAttribute")});var LU=N((Rbe,PU)=>{"use strict";var p8=f_(),m8=Jd(),S8=Xh(),w_=M(),T8=ic().updateRecords,g8=ht(),{getSchemaPath:A8}=gt(),R8=T_(),y8=W();PU.exports=b8;async function b8(e){try{let{schema_table:t,attributes:r}=p8(e);m8(e,r,t.hash_attribute),e.schema!==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 S8(e.hdb_auth_header,t,r),s=A8(e.schema,e.table),i=await g8.openEnvironment(s,e.table),o=await T8(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await R8(e,o)}catch(c){y8.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(b8,"lmdbUpdateRecords")});var UU=N((bbe,MU)=>{"use strict";var O8=M().OPERATIONS_ENUM,AR=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=O8.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};MU.exports=AR});var BU=N((Ibe,vU)=>{"use strict";var Nbe=UU(),N8=f_(),I8=Jd(),w8=Xh(),C_=M(),C8=ic().upsertRecords,D8=ht(),{getSchemaPath:P8}=gt(),L8=T_(),M8=W(),{handleHDBError:U8,hdb_errors:v8}=_e();vU.exports=B8;async function B8(e){let t;try{t=N8(e)}catch(l){throw U8(l,l.message,v8.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;I8(e,n,r.hash_attribute),e.schema!==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 w8(e.hdb_auth_header,r,n),i=P8(e.schema,e.table),o=await D8.openEnvironment(i,e.table),c=await C8(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await L8(e,c)}catch(l){M8.error(`unable to write transaction due to ${l.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:s,txn_time:c.txn_time}}a(B8,"lmdbUpsertRecords")});var xU=N((Cbe,HU)=>{"use strict";var RR=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};HU.exports=RR});var FU=N((Pbe,kU)=>{"use strict";var yR=class{static{a(this,"DeleteAuditLogsBeforeResults")}constructor(t=void 0,r=void 0,n=0){this.start_timestamp=t,this.end_timestamp=r,this.transactions_deleted=n}};kU.exports=yR});var $U=N((Ube,qU)=>{"use strict";var bR=ht(),{getTransactionAuditStorePath:H8}=gt(),Mbe=xU(),D_=Ht(),x8=te(),GU=FU(),k8=require("util").promisify,F8=k8(setTimeout),G8=1e4,q8=100;qU.exports=$8;async function $8(e){let t=H8(e.schema,e.table),r=await bR.openEnvironment(t,e.table,!0),n=bR.listDBIs(r);bR.initializeDBIs(r,D_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new GU;do s=await V8(r,e.timestamp),i.start_timestamp===void 0&&(i.start_timestamp=s.start_timestamp),s.end_timestamp!==void 0&&(i.end_timestamp=s.end_timestamp),i.transactions_deleted+=s.transactions_deleted,await F8(q8);while(s.transactions_deleted>0);return i}a($8,"deleteAuditLogsBefore");async function V8(e,t){let r=new GU;try{let n=e.dbis[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];x8.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>G8)break}return await s,r}catch(n){throw n}}a(V8,"deleteTransactions")});var KU=N((Bbe,VU)=>{"use strict";var OR=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};VU.exports=OR});var WU=N((kbe,YU)=>{"use strict";var K8=$s(),Y8=N_(),xbe=KU(),bi=M(),W8=te(),NR=ht(),j8=Zi(),z8=O_(),Q8=A_(),{getSchemaPath:J8}=gt();YU.exports=X8;async function X8(e,t=!0){let r;e.schema===bi.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(bi.SYSTEM_SCHEMA_NAME,bi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await z8(t)).filter(o=>o[bi.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[bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new Y8(bi.SYSTEM_SCHEMA_NAME,bi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return Q8(i)}a(e9,"dropAttributeFromSystem")});var ZU=N((qbe,XU)=>{"use strict";var IR=ht(),zl=Ht(),Gbe=cn(),wR=M(),jU=te(),{getTransactionAuditStorePath:t9}=gt(),r9=Yl(),ap=$l(),n9=W();XU.exports=s9;async function s9(e){let t=t9(e.schema,e.table),r=await IR.openEnvironment(t,e.table,!0),n=IR.listDBIs(r);IR.initializeDBIs(r,zl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case wR.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return zU(r,e.search_values);case wR.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,o9(r,e.search_values,s);case wR.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return i9(r,e.search_values);default:return zU(r)}}a(s9,"readAuditLog");function zU(e,t=[0,Date.now()]){jU.isEmpty(t[0])&&(t[0]=0),jU.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[zl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let s of r.getKeys({start:t[1]}))if(s!==t[1]){n=s;break}return r.getRange({start:t[0],end:n}).map(({value:s})=>Object.assign(new ap,s))}a(zU,"searchTransactionsByTimestamp");function i9(e,t=[]){let r=new Map;for(let n=0;n<t.length;n++){let s=t[n],i=[];for(let o of e.dbis[zl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,JU(e,i))}return Object.fromEntries(r)}a(i9,"searchTransactionsByUsername");function o9(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],d=r9.equals(e,zl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,zl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:_}of d){let E=Number(_);n.has(E)?n.get(E).push(u.toString()):n.set(E,[u.toString()])}}let s=Array.from(n.keys()),i=JU(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,d=n.get(u);QU(l,"records",r,d,o),QU(l,"original_records",r,d,o)}return Object.fromEntries(o)}a(o9,"searchTransactionsByHashValues");function QU(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let u=s.get(l),d=u[u.length-1];if(d.timestamp===i)d[t]=[c];else{let _=new ap(e.operation,e.user_name,i,void 0);_[t]=[c],u.push(_)}}else{let u=new ap(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}a(QU,"loopRecords");function JU(e,t){let r=[];try{let n=e.dbis[zl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let s=0;s<t.length;s++)try{let i=n.get(t[s]);if(i){let o=Object.assign(new ap,i);r.push(o)}}catch(i){n9.warn(i)}return r}catch(n){throw n}}a(JU,"batchSearchTransactions")});var tv=N((Ybe,ev)=>{"use strict";var{getSchemaPath:Vbe}=gt(),Kbe=ht(),{database:a9}=(Pe(),oe(lt));ev.exports={writeTransaction:c9};async function c9(e,t,r){return a9({database:e,table:t}).transaction(r)}a(c9,"writeTransaction")});var iv=N((jbe,sv)=>{"use strict";var{getSchemaPath:rv}=gt(),nv=ht();sv.exports={flush:l9,resetReadTxn:u9};async function l9(e,t){return(await nv.openEnvironment(rv(e,t),t.toString())).flushed}a(l9,"flush");async function u9(e,t){try{(await nv.openEnvironment(rv(e,t),t.toString())).resetReadTxn()}catch{}}a(u9,"resetReadTxn")});var lv=N((Qbe,cv)=>{"use strict";var{Readable:d9}=require("stream"),{getDatabases:_9}=(Pe(),oe(lt)),{readSync:f9,openSync:E9,createReadStream:ov}=require("fs"),{open:h9}=require("lmdb"),av=o_(),p9=a_(),{AUDIT_STORE_OPTIONS:m9}=(Ji(),oe(uv)),{INTERNAL_DBIS_NAME:S9,AUDIT_STORE_NAME:T9}=Ht();cv.exports=A9;var CR=32768,g9=100;async function A9(e){let t=e.database||e.schema||"data",r=_9()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let u=r[s[0]];if(!u)throw new Error(`Can not find table ${s[0]}`);let d=u.dbisDB,_=h9({noSync:!0,maxDbs:p9.MAX_DBS}),E,f=_.openDB(S9,new av(!1)),h=d.useReadTransaction(),T=0,m=a(async function(S,y){y.encoding="binary",y.encoder=void 0;let I=_.openDB(S,y),U=d.openDB(S,y);for(let{key:H,version:X,value:Y}of U.getRange({start:null,transaction:h,versions:U.useVersions}))E=I.put(H,Y,X),T++%g9===0&&(await new Promise(V=>setTimeout(V,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:S,value:y}of d.getRange({transaction:h,start:!1}))if(s.some(I=>S.startsWith?.(I+"/"))){f.put(S,y);let[,I]=S.split("/"),U=!I,H=new av(!U,U);await m(S,H)}e.include_audit&&await m(T9,{...m9}),await E;let g=ov(_.path);return g.headers=l(),g.on("close",()=>{h.done(),_.close()}),g}let o=r[Object.keys(r)[0]].primaryStore,c=E9(o.path);return o.transaction(()=>{let u=Buffer.alloc(CR);f9(c,u,0,CR),o.resetReadTxn();let d=o.useReadTransaction();d.renew();let _=ov(null,{fd:c,start:CR}),E=new d9.from(async function*(){yield u;for await(let f of _)d.openTimer&&(d.openTimer=0),yield f;d.done()}());return E.headers=l(),E});function l(){let u=new Map;return u.set("content-type","application/octet-stream"),u.set("content-disposition",`attachment; filename="${t}"`),u.set("date",n),u}}a(A9,"getBackup")});var fv=N((Xbe,_v)=>{"use strict";var R9=W(),{handleHDBError:y9}=_e(),b9=jD(),O9=Bh(),N9=XA(),I9=OM(),w9=A_(),C9=iR(),D9=JM(),P9=oU(),L9=O_(),M9=EU(),U9=OU(),v9=DU(),B9=LU(),H9=BU(),x9=$U(),k9=ER(),F9=WU(),G9=ZU(),q9=tv(),dv=iv(),$9=lv(),DR=class extends b9{static{a(this,"LMDBBridge")}async searchByConditions(t){return M9(t)}async getDataByHash(t){return await C9(t)}async searchByHash(t){return await D9(t)}async getDataByValue(t,r){return await P9(t,r)}async searchByValue(t){return await L9(t)}async createSchema(t){return await I9(t)}async dropSchema(t){return await U9(t)}async createTable(t,r){return await v9(t,r)}async dropTable(t){return await k9(t)}async createAttribute(t){return await O9(t)}async createRecords(t){return await N9(t)}async updateRecords(t){return await B9(t)}async upsertRecords(t){try{return await H9(t)}catch(r){throw y9(r,null,null,R9.ERR,r)}}async deleteRecords(t){return await w9(t)}async dropAttribute(t){return await F9(t)}async deleteAuditLogsBefore(t){return await x9(t)}async readAuditLog(t){return await G9(t)}writeTransaction(t,r,n){return q9.writeTransaction(t,r,n)}flush(t,r){return dv.flush(t,r)}resetReadTxn(t,r){return dv.resetReadTxn(t,r)}getBackup(t){return $9(t)}};_v.exports=DR});function Av(e){LR=e}function W9(){Y9=setInterval(function(){for(let e of PR)if(e.stale){let t=e[Fe]?.url;mv.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},K9).unref()}var MR,pv,mv,Sv,Tv,gv,Ev,PR,V9,P_,hv,LR,mc,cp,K9,Y9,lp=Ie(()=>{MR=L(cn()),pv=L(_e()),mv=L(W());Vs();Sv=L(se()),Tv=L(M()),gv=L(te()),Ev=100,PR=new Set,V9=(0,gv.convertToMS)(Sv.get(Tv.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(Av,"replicationConfirmation");mc=class e{static{a(this,"DatabaseTransaction")}writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxnsUsed=1,this.readTxn.openTimer&&(this.readTxn.openTimer=0),PR.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(PR.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(P_&&!this.overloadChecked&&performance.now()-hv>V9)throw new pv.ServerError("Outstanding write transactions have too long of queue, please try again later",503);this.overloadChecked=!0}addWrite(t){if(this.open===0)throw new Error("Can not use a transaction that is no longer open");if(this.open===2){let r=new e;return r.addWrite(t),r.commit({})}else this.writes.push(t)}removeWrite(t){let r=this.writes.indexOf(t);r>-1&&(this.writes[r]=null)}commit(t={}){let r=this.timestamp;r||(r=this.timestamp=t.timestamp||(0,MR.getNextMonotonicTime)()),t.timestamp||(t.timestamp=r);let n=t.retries||0;if(this.validated<this.writes.length)try{let _=this.validated;this.validated=this.writes.length;for(let f=_;f<this.validated;f++)this.writes[f]?.validate?.(this.timestamp);let E;for(let f=_;f<this.validated;f++){let h=this.writes[f];h&&(h.before||h.beforeIntermediate)&&(E=!0)}if(E)return(async()=>{try{for(let f=0;f<2;f++){let h;for(let T=_;T<this.validated;T++){let m=this.writes[T];if(!m)continue;let g=m[f===0?"before":"beforeIntermediate"];if(g){let S=g();h?h.push?h.push(S):h=[h,S]:h=S}}h&&await(h.push?Promise.all(h):h)}}catch(f){throw this.abort(),f}return this.commit(t)})()}catch(_){throw this.abort(),_}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(_=>_);let c=a(_=>{_.commit(r,_.entry,n)},"doWrite"),l=a(()=>{let _=this.writes[o++];if(_)if(_.key){n>0&&(_.entry=_.store.getEntry(_.key));let E=_.store.ifVersion(_.key,_.entry?.version??null,l);s=s||E}else l();else for(let E of this.writes)c(E)},"nextCondition"),u=this.lmdbDb;if(this.writes.length>0&&(u?.retryRisk&&(u.retryRisk*=.99),this.writes.length+(u?.retryRisk||0)<Ev>>n?l():s=this.writes[0].store.transaction(()=>{for(let _ of this.writes)_.entry=_.store.getEntry(_.key),c(_);return!0})),s)return 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];LR&&f&&i.push(LR(E,f.store.getEntry(f.key).localTime,this.replicatedConfirmation))}return this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))}else return u&&(u.retryRisk=(u.retryRisk||0)+Ev/2),t?t.retries=n+1:t={retries:1},this.commit(t)});let d={txnTime:r};if(this.next){let _=this.next?.commit(t);if(_?.then)return _?.then(E=>({txnTime:r,next:E}));d.next=_}return d}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},cp=class extends mc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,MR.getNextMonotonicTime)())}getReadTxn(){}},K9=3e4;a(W9,"startMonitoringTxns");W9()});function Dt(e,t,r){if(!t)t=e,e={};else if(!e)e={};else if(e?.transaction?.open===1&&typeof t=="function")return t(e.transaction);if(typeof t!="function")throw new Error("Callback function must be provided to transaction");let n=e.transaction=new mc;e.timestamp&&(n.timestamp=e.timestamp),e.replicatedConfirmation&&(n.replicatedConfirmation=e.replicatedConfirmation),n[Fe]=e,e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var Rv,Sc=Ie(()=>{Rv=L(Ei());Vs();lp();a(Dt,"transaction");(0,Rv._assignPackageExport)("transaction",Dt);Dt.commit=function(e){let t=(e[Fe]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Dt.abort=function(e){let t=(e[Fe]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var Dv={};je(Dv,{ResourceBridge:()=>BR});function HR({get_attributes:e},t){if(e){if(e[0]==="*"){if(t.schemaDefined)return;e=t.attributes.map(r=>r.name)}return e.forceNulls=!0,e}}function bv(e,t){let r=Oi(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 Oi(e){let t=e.database||e.schema||z9,r=ut()[t];if(!r)throw(0,Ks.handleHDBError)(new Error,j9.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function Ov(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}async function*Nv(e,t,r,n){let s,i=0;for await(let o of e.getHistory(t,r)){let c=o.operation??o.type;c==="put"&&(c="upsert");let{id:l,version:u,value:d}=o;if(s?.timestamp===u)s.hash_values.push(l),s.records.push(d);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:u,hash_values:[l],records:[d]}}}s&&(yield s)}var Iv,up,Ks,wv,Ys,UR,vR,Cv,j9,z9,Q9,J9,yv,BR,Pv=Ie(()=>{"use strict";Iv=L(fv()),up=L(Wl()),Ks=L(_e());Pe();wv=L(f_()),Ys=L(M()),UR=L(no()),vR=L(qs()),Cv=L(te());Sc();_p();({HDB_ERROR_MSGS:j9}=Ks.hdb_errors),z9="data",Q9=1e4,J9=10,BR=class extends Iv.default{static{a(this,"ResourceBridge")}constructor(t){super(t),yv=this}async searchByConditions(t){t.select!==void 0&&(t.get_attributes=t.select);for(let o of t.conditions||[])o?.attribute!==void 0&&(o.search_attribute=o.attribute),o?.comparator!==void 0&&(o.search_type=o.comparator),o?.value!==void 0&&(o.search_value=o.value);let r=(0,up.default)(t,"conditions");if(r)throw(0,Ks.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Oi(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 Oi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Oi(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){Oi(t).dropTable()}createSchema(t){return Ql({database:t.schema,table:null}),UR.signalSchemaChange(new vR.SchemaEventMsg(process.pid,Ys.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await xR(t.schema),UR.signalSchemaChange(new vR.SchemaEventMsg(process.pid,Ys.OPERATIONS_ENUM.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,yv.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,wv.default)(t),s,i=ut()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(o.replicateTo=t.replicateTo),t.replicatedConfirmation&&(o.replicatedConfirmation=t.replicatedConfirmation),Dt(o,async c=>{if(!i.schemaDefined){s=[];for(let d of n)i.attributes.find(E=>E.name==d)||s.push(d);s.length>0&&await i.addAttributes(s.map(d=>({name:d,indexed:!0})))}let l=[],u=[];for(let d of t.records){let _=d[i.primaryKey],E=_!=null&&await i.get(_,o);if(t.requires_existing&&!E||t.requires_no_existing&&E){u.push(d[i.primaryKey]);continue}E&&(E=dp(E));for(let f in d)if(Object.prototype.hasOwnProperty.call(d,f)){let h=d[f];if(typeof h=="function")try{let T=h([[E]]);Array.isArray(T)&&(h=T[0].func_val,d[f]=h)}catch(T){throw T.message+="Trying to set key "+f+" on object"+JSON.stringify(d),T}}if(E)for(let f in E)Object.prototype.hasOwnProperty.call(d,f)||(d[f]=E[f]);await(_==null?i.create(d,o):i.put(d,o)),l.push(d[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:u}})}async deleteRecords(t){let r=ut()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),Dt(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),o=[],c=[];for(let l of i)await r.delete(l,n)?o.push(l):c.push(l);return Ov(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=ut()[t.schema][t.table];if(!r.createdTimeProperty)throw new Ks.ClientError("Table must have a '__createdtime__' attribute or @createdTime timestamp defined to perform this operation");let n=await r.search({conditions:[{attribute:r.createdTimeProperty.name,value:Date.parse(t.date),comparator:Ys.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,l=[],u=a(async()=>{let d=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...d.deleted_hashes),o.push(...d.skipped_hashes),await(0,Cv.async_set_timeout)(J9),l=[],s=!0},"chunkDelete");for await(let d of n)l.push(d[r.primaryKey]),c++,c%Q9===0&&await u();return l.length>0&&await u(),s?Ov(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,up.default)(t,"hashes");if(r)throw r;return bv(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of bv(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Ys.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r]===void 0)throw new Error(`Value search comparator - ${r} - is not valid`);t.select!==void 0&&(t.get_attributes=t.select),t.attribute!==void 0&&(t.search_attribute=condition.attribute),t.value!==void 0&&(t.search_value=condition.value);let n=(0,up.default)(t,"value");if(n)throw n;let s=Oi(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=Oi(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){Oi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Oi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=Oi(t),n={};switch(t.search_type){case Ys.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.operation??o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case Ys.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of Nv(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return Nv(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(HR,"getSelect");a(bv,"getRecords");a(Oi,"getTable");a(Ov,"createDeleteResponse");a(Nv,"groupRecordsInHistory")});var Bn=N((fOe,Lv)=>{"use strict";var{ResourceBridge:X9}=(Pv(),oe(Dv)),Z9=se();Z9.initSync();var fp;function e7(){return fp||(fp=new X9,fp)}a(e7,"getBridge");Lv.exports=e7()});var Bv=N((hOe,vv)=>{"use strict";var Mv=require("lodash"),L_=require("mathjs"),t7=require("jsonata"),Uv=te();vv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?Mv.uniqWith(e,Mv.isEqual):e,"distinct_array"),searchJSON:r7,mad: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 r7(e,t){if(typeof e!="string"||e.length===0)throw new Error("search json expression must be a non-empty string");let r="__"+e+"__";if(Uv.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),Uv.isEmpty(this.__ala__.res[r])){let n=t7(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(r7,"searchJSON")});var xv=N((mOe,Hv)=>{"use strict";var nr=require("moment"),kR="YYYY-MM-DDTHH:mm:ss.SSSZZ";nr.suppressDeprecationWarnings=!0;Hv.exports={current_date:a(()=>nr().utc().format("YYYY-MM-DD"),"current_date"),current_time:a(()=>nr().utc().format("HH:mm:ss.SSS"),"current_time"),extract:a((e,t)=>{switch(t.toLowerCase()){case"year":return nr(e).utc().format("YYYY");case"month":return nr(e).utc().format("MM");case"day":return nr(e).utc().format("DD");case"hour":return nr(e).utc().format("HH");case"minute":return nr(e).utc().format("mm");case"second":return nr(e).utc().format("ss");case"millisecond":return nr(e).utc().format("SSS");default:break}},"extract"),date:a(e=>nr(e).utc().format(kR),"date"),date_format:a((e,t)=>nr(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>nr(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>nr(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=nr(e).utc(),s=nr(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>nr().utc().valueOf(),"now"),get_server_time:a(()=>nr().format(kR),"get_server_time"),offset_utc:a((e,t)=>nr(e).utc().utcOffset(t).format(kR),"offset_utc")}});var qv=N((TOe,Gv)=>{"use strict";var n7=require("@turf/area"),s7=require("@turf/length"),i7=require("@turf/circle"),o7=require("@turf/difference"),a7=require("@turf/distance"),c7=require("@turf/boolean-contains"),l7=require("@turf/boolean-equal"),u7=require("@turf/boolean-disjoint"),d7=require("@turf/helpers"),kv=M(),$e=te(),oo=W();Gv.exports={geoArea:_7,geoLength:f7,geoCircle:E7,geoDifference:h7,geoDistance:Fv,geoNear:p7,geoContains:m7,geoEqual:S7,geoCrosses:T7,geoConvert:g7};function _7(e){if($e.isEmpty(e))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return n7.default(e)}catch(t){return oo.trace(t,e),NaN}}a(_7,"geoArea");function f7(e,t){if($e.isEmpty(e))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return s7.default(e,{units:t||"kilometers"})}catch(r){return oo.trace(r,e),NaN}}a(f7,"geoLength");function E7(e,t,r){if($e.isEmpty(e))return NaN;if($e.isEmpty(t))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return i7.default(e,t,{units:r||"kilometers"})}catch(n){return oo.trace(n,e,t),NaN}}a(E7,"geoCircle");function h7(e,t){if($e.isEmpty(e))return NaN;if($e.isEmpty(t))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return o7(e,t)}catch(r){return oo.trace(r,e,t),NaN}}a(h7,"geoDifference");function Fv(e,t,r){if($e.isEmpty(e))return NaN;if($e.isEmpty(t))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return a7.default(e,t,{units:r||"kilometers"})}catch(n){return oo.trace(n,e,t),NaN}}a(Fv,"geoDistance");function p7(e,t,r,n){if($e.isEmpty(e)||$e.isEmpty(t))return!1;if($e.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return Fv(e,t,n)<=r}catch(s){return oo.trace(s,e,t),!1}}a(p7,"geoNear");function m7(e,t){if($e.isEmpty(e)||$e.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return c7.default(e,t)}catch(r){return oo.trace(r,e,t),!1}}a(m7,"geoContains");function S7(e,t){if($e.isEmpty(e)||$e.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return l7.default(e,t)}catch(r){return oo.trace(r,e,t),!1}}a(S7,"geoEqual");function T7(e,t){if($e.isEmpty(e)||$e.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return!u7.default(e,t)}catch(r){return oo.trace(r,e,t),!1}}a(T7,"geoCrosses");function g7(e,t,r){if($e.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if($e.isEmpty(t))throw new Error("geo_type is required");if($e.isEmpty(kv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(kv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=$e.autoCastJSON(e)),d7[t](e,r)}a(g7,"geoConvert")});var Ep=N((AOe,$v)=>{var Tc=Bv(),Gn=xv(),Ni=qv();$v.exports=e=>{e.aggr.mad=e.aggr.MAD=Tc.mad,e.aggr.mean=e.aggr.MEAN=Tc.mean,e.aggr.mode=e.aggr.MODE=Tc.mode,e.aggr.prod=e.aggr.PROD=Tc.prod,e.aggr.median=e.aggr.MEDIAN=Tc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Tc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Tc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Gn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Gn.current_time,e.fn.extract=e.fn.EXTRACT=Gn.extract,e.fn.date=e.fn.DATE=Gn.date,e.fn.date_format=e.fn.DATE_FORMAT=Gn.date_format,e.fn.date_add=e.fn.DATE_ADD=Gn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Gn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Gn.date_diff,e.fn.now=e.fn.NOW=Gn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Gn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Gn.get_server_time,e.fn.getdate=e.fn.GETDATE=Gn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Gn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Ni.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Ni.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Ni.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Ni.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Ni.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Ni.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Ni.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Ni.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Ni.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Ni.geoNear}});var Wv=N((ROe,Yv)=>{"use strict";var U_=require("lodash"),_n=require("alasql");_n.options.cache=!1;var A7=Ep(),Vv=require("clone"),hp=require("recursive-iterator"),Ue=W(),et=te(),Jl=Bn(),R7=M(),{hdb_errors:y7}=_e(),{getDatabases:Kv}=(Pe(),oe(lt)),b7="IS NULL",Ws="There was a problem performing this search. Please check the logs and try again.";A7(_n);var FR=class{static{a(this,"SQLSearch")}constructor(t,r){if(et.isEmpty(t))throw Ue.error("AST statement for SQL select process cannot be empty"),"statement cannot be null";this.statement=t,this.columns={},this.all_table_attributes=r,this.fetch_attributes=[],this.exact_search_values={},this.comparator_search_values={},this.tables=[],this.data={},this.has_aggregator=!1,this.has_ordinal=!1,this.has_outer_join=!1,this._getColumns(),this._getTables(),this._conditionsToFetchAttributeValues(),this._setAliasesForColumns(),et.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!et.isEmptyOrZeroLength(n))return Ue.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw Ue.error("Error thrown from checkEmptySQL in SQLSearch class method search."),Ue.error(n),new Error(Ws)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw Ue.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),Ue.error(n),new Error(Ws)}if(Object.keys(this.data).length===0)return Ue.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw Ue.error("Error thrown from processJoins in SQLSearch class method search."),Ue.error(n),new Error(Ws)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw Ue.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),Ue.error(n),new Error(Ws)}try{return t=await this._finalSQL(),t}catch(n){throw Ue.error("Error thrown from finalSQL in SQLSearch class method search."),Ue.error(n),new Error(Ws)}}_getColumns(){let t=new hp(this.statement);for(let{node:r,path:n}of t)r&&r.columnid&&(this.columns[n[0]]||(this.columns[n[0]]=[]),this.columns[n[0]].push(Vv(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=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(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&&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(b7)>-1&&this.tables.forEach(s=>{let i={columnid:Kv()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=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 Jl.getDataByHash(c);for(let _ of c.hash_values)d.get(_)&&!this.data[i].__merged_data[_]&&(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_))}catch(d){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(d),new Error(Ws)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async d=>{let _={...c};_.search_value=d;let E=await Jl.getDataByValue(_);for(let[f,h]of E)this.data[i].__merged_data[f]?this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]):(this.data[i].__merged_data[f]=[...n[i]],this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,f))}))}catch(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(d),new Error(Ws)}else if(!et.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!et.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let d=this.comparator_search_values[u].comparators;for(let _=0,E=d.length;_<E;_++){let f=d[_];c.search_attribute=f.attribute,c.search_value=f.search_value;let h=await Jl.getDataByValue(c,f.operation);if(l)for(let[T]of h)this.data[i].__merged_data[T]||(this.data[i].__merged_data[T]=[...n[i]],this._setMergedHashAttribute(i,T));else for(let[T,m]of h)this.data[i].__merged_data[T]?this._updateMergedAttribute(i,T,s.attribute,m[s.attribute]):(this.data[i].__merged_data[T]=[...n[i]],this._updateMergedAttribute(i,T,s.attribute,m[s.attribute]),this._setMergedHashAttribute(i,T))}}catch(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),Ue.error(d),new Error(Ws)}else try{c.search_attribute=s.attribute,c.search_value="*";let d=await Jl.getDataByValue(c);if(l)for(let[_]of d)this.data[i].__merged_data[_]||(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_));else for(let[_,E]of d)this.data[i].__merged_data[_]?this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]):(this.data[i].__merged_data[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]),this._setMergedHashAttribute(i,_))}catch(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),Ue.error(d),new Error(Ws)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof _n.yy.Column||(t=!1)}),t)}_updateOrderByToAliases(){this.statement.order.forEach(t=>{if(t.expression.aggregatorid){t.is_aggregator=!0;return}if(t.expression.value){t.is_ordinal=!0,this.has_ordinal=!0;return}else t.is_ordinal=!1;let r=this.statement.columns.filter(s=>{let i=s.aggregatorid?s.expression:s,o=s.aggregatorid?s.as_orig:i.as_orig;return t.expression.tableid?i.columnid_orig===t.expression.columnid_orig&&i.tableid_orig===t.expression.tableid_orig:i.columnid_orig===t.expression.columnid_orig||t.expression.columnid_orig===o});r[0]||r.push(this._findColumn(t.expression));let n=r[0];if(t.is_func=!!n.funcid,t.is_aggregator=!!n.aggregatorid,n.as)if(n.as&&!t.expression.tableid)t.expression.columnid=n.as,t.expression.columnid_orig=n.as_orig;else{let s=new _n.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new _n.yy.Column,t.expression),t.initial_select_column.as=`[${t.expression.columnid_orig}]`,t.expression.columnid=t.initial_select_column.as;return}if(!t.is_aggregator){let s=t.is_func?new _n.yy.FuncValue:new _n.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(f=>{f.joinmode&&f.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(f.table);let h=f.joinmode+" JOIN ? AS "+(f.as?f.as:f.table.tableid);f.on&&(h+=" ON "+f.on.toString()),i.push(h),t.push(Object.values(this.data[`${f.table.databaseid_orig}_${f.table.as?f.table.as_orig:f.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(f=>{let h=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__hash_name,T=f.as?f.as_orig:f.tableid_orig;o.push({key:`'${T}.${h}'`,schema:f.databaseid_orig,table:f.as?f.as_orig:f.tableid_orig,keys:new Set}),r.push(`${f.as?f.as:f.tableid}.\`${h}\` AS "${T}.${h}"`),c[f.as?f.as_orig:f.tableid_orig]=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let u="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(u="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(f=>{f.is_func?r.push(f.initial_select_column.toString()):f.initial_select_column.tableid?r.push(`${f.initial_select_column.tableid}.${f.initial_select_column.columnid} AS ${f.expression.columnid}`):r.push(`${f.initial_select_column.columnid} AS ${f.expression.columnid}`)}));let d="",_="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(d=this.statement.limit?"LIMIT "+this.statement.limit:"",_=this.statement.offset?"OFFSET "+this.statement.offset:"");let E=[];try{let f=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${u} ${d} ${_}`,h=this._convertColumnsToIndexes(f,s);E=await _n.promise(h,t),t=null}catch(f){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),Ue.error(f),new Error("There was a problem processing the data.")}if(E&&E.length>0){for(let f=0,h=E.length;f<h;f++){let T=E[f];o.forEach(m=>{T[m.key]!==null&&T[m.key]!==void 0&&m.keys.add(T[m.key])})}o.forEach(f=>{let h=Object.keys(this.data[`${f.schema}_${f.table}`].__merged_data),T=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 Jl.getDataByHash(c),u=s.columns.length;for(let d=0,_=o.length;d<_;d++){let E=o[d],f=l.get(E);for(let h=0;h<u;h++){let T=s.columns[h],m=f[T]===void 0?null:f[T];this.data[n].__merged_data[E].push(m)}}}}catch(r){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getData."),Ue.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__merged_data)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,l=o.aggregatorid?o.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===l}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();Ue.trace(`Final SQL: ${s}`),n=await _n.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),Ue.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),Ue.error(s),new Error("There was a problem running the generated sql.")}return n}_translateUndefinedValues(t){try{let r=[];for(let n of t){let s=Object.create(null);Object.keys(n).forEach(i=>{n[i]===void 0?s[i]=null:s[i]=n[i]}),r.push(s)}return r}catch(r){return Ue.error(y7.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),Ue.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],u=new RegExp(`${l}.\`${o}\``,"g"),d=`${l}.[${c}]`;n=n.replace(u,d)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),u=`[${c}]`;n=n.replace(l,u)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await Jl.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]={...r[s]}),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw Ue.error("There was an error when processing this SQL operation. Check your logs"),Ue.error(o),new Error(Ws)}}return Object.values(Object.values(this.data)[0].__merged_data)}};Yv.exports=FR});var Vr=N((bOe,jv)=>{"use strict";var O7=YD();jv.exports={searchByConditions:I7,searchByHash:w7,searchByValue:C7,search:D7};var GR=Bn(),{transformReq:qR}=te(),N7=Wv();async function I7(e){return qR(e),GR.searchByConditions(e)}a(I7,"searchByConditions");async function w7(e){qR(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of GR.searchByHash(e))r&&t.push(r);return t}a(w7,"searchByHash");async function C7(e){qR(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of GR.searchByValue(e))t.push(r);return t}a(C7,"searchByValue");function D7(e,t){try{let r=new O7(e);r.validate(),new N7(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(D7,"search")});var pp=N((NOe,zv)=>{"use strict";var P7=Bn();zv.exports={writeTransaction:L7};function L7(e,t,r){return P7.writeTransaction(e,t,r)}a(L7,"writeTransaction")});var Zv=N((COe,Xv)=>{"use strict";var M7=Vr(),U7=us(),Qv=W(),v7=un(),wOe=pp(),B7=require("clone"),VR=require("alasql"),H7=Ep(),Jv=require("util"),x7=Jv.promisify(U7.getTableSchema),k7=Jv.promisify(M7.search),F7=M(),$R=te();H7(VR);Xv.exports={update:q7};var G7="There was a problem performing this update. Please check the logs and try again.";async function q7({statement:e,hdb_user:t}){let r=await x7(e.table.databaseid,e.table.tableid),n=$7(e.columns);$R.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=B7(s),c=$R.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=VR.parse(l).statements[0],d=await k7(u),_=V7(n,d);return K7(o,_,t)}a(q7,"update");function $7(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=VR.compile(`SELECT ${r.expression.toString()} AS [${F7.FUNC_VAL}] FROM ?`)}),t}catch(t){throw Qv.error(t),new Error(G7)}}a($7,"createUpdateRecord");function V7(e,t){return $R.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(V7,"buildUpdateRecords");async function K7(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await v7.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){Qv.error(`Error delete new_attributes from update response: ${i}`)}return s}a(K7,"updateRecords")});var t0=N((MOe,e0)=>{var Y7=require("alasql"),W7=Vr(),j7=W(),z7=Bn(),YR=require("util"),KR=te(),Q7=M(),J7=us(),POe=pp(),LOe=un(),X7="record",Z7="successfully deleted",eee=YR.callbackify(see),tee=YR.promisify(W7.search),ree=YR.promisify(J7.getTableSchema);e0.exports={convertDelete:eee};function nee(e){return`${e.deleted_hashes.length} ${X7}${e.deleted_hashes.length===1?"":"s"} ${Z7}`}a(nee,"generateReturnMessage");async function see({statement:e,hdb_user:t}){let r=await ree(e.table.databaseid,e.table.tableid);KR.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=KR.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=Y7.parse(o).statements[0],l={operation:Q7.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await tee(c);let u=await z7.deleteRecords(l);return KR.isEmptyOrZeroLength(u.message)&&(u.message=nee(u)),delete u.txn_time,u}catch(u){throw j7.error(u),u.hdb_code?u.message:u}}a(see,"convertDelete")});var o0=N((vOe,i0)=>{"use strict";var iee=ro(),{hdb_errors:r0}=_e(),{getDatabases:n0}=(Pe(),oe(lt));i0.exports={checkSchemaExists:s0,checkSchemaTableExists:oee,schema_describe:iee};async function s0(e){if(!n0()[e])return r0.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(s0,"checkSchemaExists");async function oee(e,t){let r=await s0(e);if(r)return r;if(!n0()[e][t])return r0.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(oee,"checkSchemaTableExists")});var Xl=N((HOe,aee)=>{aee.exports={name:"harperdb",version:"4.4.25",description:"HarperDB is a distributed database, caching service, streaming broker, and application development platform focused on performance and ease of use.",keywords:["database","nosql","api","distributed","broker","mqtt","real-time","enterprise","Fastify","NATS","HarperDB","Harper","clustering","replication","REST","WebSockets","decentralized","server-sent events","document store"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{"minimum-node":"16.0.0","go-lang":"1.21.7","nats-server":"2.10.11"},exports:{".":"./index.js"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"SEE LICENSE IN LICENSE",scripts:{submodules:"git submodule update --init --recursive","cover:test":"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && nyc --no-clean --reporter=lcovonly npm run test:replication && nyc --no-clean --reporter=lcovonly npm run test:apitests && nyc --no-clean --reporter=lcovonly npm run test:resources && nyc --no-clean --reporter=lcovonly npm run test:logging && nyc --no-clean --reporter=lcovonly npm run test:upgrade && nyc --no-clean --reporter=lcovonly npm run test:nats && nyc --no-clean --reporter=lcovonly npm run test:cfserver && nyc --no-clean --reporter=lcovonly npm run test:hdbserver && nyc --no-clean --reporter=lcovonly npm run test:bin && nyc --no-clean --reporter=lcovonly npm run test:main && nyc --no-clean --reporter=lcovonly npm run test:security && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license",test:"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && npm run test:replication && npm run test:apitests && npm run test:resources && npm run test:logging && npm run test:upgrade && npm run test:nats && npm run test:cfserver && npm run test:hdbserver && npm run test:bin && npm run test:main && npm run test:security && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license","test:resources":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/resources/**/*.js' --config '../unitTests/.mocharc.json'","test:bin":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/bin/**/*.js' --config '../unitTests/.mocharc.json'","test:main":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","test:lmdbbridge":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --config '../unitTests/.mocharc.json'","test:lmdbutility":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --config '../unitTests/.mocharc.json'","test:hdbserver":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --config '../unitTests/.mocharc.json'","test:cfserver":"npm run submodules && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/fastifyRoutes/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","test:nats":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","test:upgrade":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --config '../unitTests/.mocharc.json'","test:apitests":"pm2 kill && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/apiTests/**/*-test.mjs' --config '../unitTests/.mocharc.json'","test:logging":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/logging/*.js' --config '../unitTests/.mocharc.json'","test:ci":" cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --retries 3 --config '../unitTests/.mocharc-main.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter","test:security":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/security/**/*.js' --config '../unitTests/.mocharc.json'","test:replication":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/replication/**/*.js' --config '../unitTests/.mocharc.json'","hdb-check":"./utility/devops/hdb-check.sh","download-prebuilds":"node ./utility/devops/build/download-prebuilds.js",prebuild:"date",postinstall:"node ./launchServiceScripts/launchInstallNATSServer.js",build_nats_dependency:"node ./utility/devops/nats/builder.js",coverage:"nyc --reporter=lcov npm test",format:"prettier .","format:fix":"npm run format -- --write",lint:"eslint .","lint:fix":"npm run lint -- --fix"},dependencies:{"@aws-sdk/client-s3":"3.717.0","@aws-sdk/lib-storage":"3.717.0","@endo/static-module-record":"^1.0.4","@fastify/autoload":"5.10.0","@fastify/compress":"~6.5.0","@fastify/cors":"~9.0.1","@fastify/static":"~7.0.4","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"4.1.10","cbor-x":"1.6.0",chalk:"4.1.2",chokidar:"^4.0.3","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.2",fastify:"~4.29.0","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.10.0","gunzip-maybe":"1.4.2","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.12.2","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.7",jsonwebtoken:"9.0.2",lmdb:"3.2.6",lodash:"4.17.21",mathjs:"11.12.0",minimist:"1.2.8",moment:"2.30.1","mqtt-packet":"~9.0.0",msgpackr:"1.11.2",nats:"2.19.0",needle:"3.3.1","node-forge":"^1.3.1","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.3",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.4.1",prompt:"1.3.0","properties-reader":"2.3.0","recursive-iterator":"3.3.0",semver:"7.5.4",send:"^1.1.0","serve-static":"2.1.0",ses:"1.1.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.24.5","tar-fs":"3.0.6",ulidx:"0.5.0",uuid:"10.0.0","validate.js":"0.13.1",ws:"8.18.0",yaml:"2.7.0"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"20.14.8","@typescript-eslint/eslint-plugin":"^7.18.0","@typescript-eslint/parser":"^7.18.0",axios:"1.7.5",chai:"4.4.1","chai-integer":"0.1.0",esbuild:"^0.24.2",eslint:"^8.57.1","eslint-config-prettier":"^9.1.0","eslint-plugin-sonarjs":"^3.0.1",eventsource:"^2.0.2","graphql-http":"^1.22.3","hook-std":"3.0.0","intercept-stdout":"0.1.2",mkcert:"1.5.1",mocha:"^11.0.1","mocha-teamcity-reporter":"^4.2.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.8",newman:"6.1.3","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"3.3.3",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0","source-map-support":"^0.5.21",typescript:"^5.7.2",undici:"^6.19.8","why-is-node-still-running":"^1.0.0"},overrides:{alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","segfault-handler":"^1.3.0","utf-8-validate":"^5.0.10"}}});var k_={};je(k_,{addAnalyticsListener:()=>x_,recordAction:()=>pr,recordActionBinary:()=>qn,setAnalyticsEnabled:()=>cee});function cee(e){h0=e}function pr(e,t,r,n,s){if(!h0)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=Tp.get(i);if(o)if(typeof e=="number"){let c=o.values,l=c.index++;if(l>=c.length){let u=c;o.values=c=new Float32Array(l*2),c.set(u),c.index=l+1}c[l]=e,o.total+=e}else if(typeof e=="boolean")e&&o.total++,o.count++;else if(typeof e=="function")o.count++;else throw new TypeError("Invalid metric value type "+typeof e);else{if(typeof e=="number")o={total:e,values:new Float32Array(4)},o.values.index=1,o.values[0]=e,o.total=e;else if(typeof e=="boolean")o={},o.total=e?1:0,o.count=1;else if(typeof e=="function")o={},o.count=1,o.callback=e;else throw new TypeError("Invalid metric value type "+typeof e);o.description={metric:t,path:r,method:n,type:s},Tp.set(i,o)}mp||lee()}function qn(e,t,r,n,s){pr(!!e,t,r,n,s)}function x_(e){S0.push(e)}function lee(){mp=performance.now(),setTimeout(async()=>{let e=performance.now()-mp;mp=0;let t=[],r={time:Date.now(),period:e,threadId:gc.threadId,metrics:t};for(let[s,i]of Tp){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,u=[],d;for(let _ of T0){let E=Math.floor(c*_),f=o[E-1];if(E>l){let h=E-l;if(f===d){let T=u[u.length-1];typeof T=="number"?u[u.length-1]={value:T,count:1+h}:T.count+=h}else u.push(h>1?{value:f,count:h}:f),d=f;l=E}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:u,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await g0()}let n=process.memoryUsage();t.push({metric:"memory",threadId:gc.threadId,byThread:!0,...n});for(let s of S0)s(t);Tp=new Map,gc.parentPort?gc.parentPort.postMessage({type:m0,report:r}):y0({report:r})},p0).unref()}async function uee(e,t=6e4){let r=zR(),n=A0(),s=new Promise(T=>{let m=performance.now();setImmediate(()=>{let g=performance.now();g-m>5e3&&(0,v_.warn)("Unusually high event queue latency on the main thread of "+Math.round(g-m)+"ms"),m=performance.now()}),n.primaryStore.prefetch([1],()=>{let g=performance.now();g-m>5e3&&(0,v_.warn)("Unusually high task queue latency on the main thread of "+Math.round(g-m)+"ms"),T(g-m)})}),i;for(let T of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(T.value?.time){i=T.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,u=[],d;for(let{key:T,value:m}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!m)continue;if(o){if(T>o+t)break}else o=T;d=T;let{metrics:g,threadId:S}=m;for(let y of g||[]){let{path:I,method:U,type:H,metric:X,count:Y,total:V,distribution:ne,threads:Q,...de}=y;Y||(Y=1);let j=X+(I?"-"+I:"");U!==void 0&&(j+="-"+U),H!==void 0&&(j+="-"+H);let ae=c.get(j);if(ae){if(ae.threads){let Ne=ae.threads[S];if(Ne)ae=Ne;else{ae.threads[S]={...de};continue}}ae.count||(ae.count=1);let Oe=ae.count;for(let Ne in de){let Me=de[Ne];typeof Me=="number"&&(ae[Ne]=(ae[Ne]*Oe+Me*Y)/(Oe+Y))}ae.count+=Y,V>=0&&(ae.total+=V,ae.ratio=ae.total/ae.count)}else ae={period:t,...y},delete ae.distribution,c.set(j,ae),ae.byThread&&(ae.threads=[],ae.threads[S]={...de},u.push(ae));if(ne){ne=ne.map(Ne=>typeof Ne=="number"?{value:Ne,count:1}:Ne);let Oe=l.get(j);Oe?Oe.push(...ne):l.set(j,ne)}}await g0()}for(let T of u){let{path:m,method:g,type:S,metric:y,count:I,total:U,distribution:H,threads:X,...Y}=T;X=X.filter(V=>V);for(let V in Y){if(typeof T[V]!="number")continue;let ne=0;for(let Q of X){let de=Q[V];typeof de=="number"&&(ne+=de)}T[V]=ne}T.count=X.length,delete T.threads,delete T.byThread}for(let[T,m]of l){let g=c.get(T);m.sort((Ne,Me)=>Ne.value>Me.value?1:-1);let S=g.count-1,y=[],I=0,U=0,H;for(let Ne of T0){let Me=S*Ne;for(;I<Me;)H=m[U++],I+=H.count,U===1&&I--;let Gr=m[U>1?U-2:0];H||(H=m[0]),y.push(H.value-(H.value-Gr.value)*(I-Me)/H.count)}let[X,Y,V,ne,Q,de,j,ae,Oe]=y;Object.assign(g,{p1:X,p10:Y,p25:V,median:ne,p75:Q,p90:de,p95:j,p99:ae,p999:Oe})}let _;for(let[T,m]of c)m.id=(0,Sp.getNextMonotonicTime)(),m.time=d,n.primaryStore.put(m.id,m,{append:!0}).then(g=>{g||n.primaryStore.put(m.id,m)}),_=!0;let E=Date.now(),{idle:f,active:h}=performance.eventLoopUtilization();if(_||h*10>f){let T=(0,Sp.getNextMonotonicTime)(),m={id:T,metric:"main-thread-utilization",idle:f-a0,active:h-c0,taskQueueLatency:await s,time:E,...process.memoryUsage()};n.primaryStore.put(T,m,{append:!0}).then(g=>{g||n.primaryStore.put(T,m)})}a0=f,c0=h}async function l0(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function zR(){return u0||(u0=Et({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function A0(){return d0||(d0=Et({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function fee(){R0=!0;let e=(0,H_.get)(jR.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await uee(p0,e),await l0(zR(),dee),await l0(A0(),_ee)},Math.min(e/2,2147483647)).unref()}function y0(e,t){let r=e.report;r.threadId=t?.threadId||gc.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(_0+=n.mean*n.count);r.totalBytesProcessed=_0,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(f0.get(t))}),f0.set(t,t.performance.eventLoopUtilization())),r.id=(0,Sp.getNextMonotonicTime)(),zR().primaryStore.put(r.id,r),R0||fee(),Eee&&(b0=pee(r))}async function pee(e){if(await b0,!Zo){let r=(0,B_.dirname)((0,v_.getLogFilePath)());try{Zo=await(0,WR.open)((0,B_.join)(r,"analytics.log"),"r+")}catch{Zo=await(0,WR.open)((0,B_.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 gc,E0,v_,B_,WR,Sp,H_,jR,Tp,h0,mp,p0,m0,S0,T0,a0,c0,g0,dee,_ee,u0,d0,R0,_0,f0,Eee,b0,Zo,hee,Ii=Ie(()=>{gc=require("worker_threads"),E0=L(dt());Pe();v_=L(W()),B_=require("path"),WR=require("fs/promises"),Sp=L(cn()),H_=L(se()),jR=L(M());qr();(0,H_.initSync)();Tp=new Map,h0=(0,H_.get)(jR.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)>-1;a(cee,"setAnalyticsEnabled");a(pr,"recordAction");it.recordAnalytics=pr;a(qn,"recordActionBinary");mp=0,p0=1e3,m0="analytics-report",S0=[];a(x_,"addAnalyticsListener");T0=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(lee,"sendAnalytics");a(uee,"aggregation");a0=0,c0=0,g0=a(()=>new Promise(setImmediate),"rest");a(l0,"cleanup");dee=36e5,_ee=31536e6;a(zR,"getRawAnalyticsTable");a(A0,"getAnalyticsTable");(0,E0.setChildListenerByType)(m0,y0);a(fee,"startScheduledTasks");_0=0,f0=new Map,Eee=!1;a(y0,"recordAnalytics");hee=1e6;a(pee,"logAnalytics")});var ey=N((QOe,B0)=>{"use strict";var{decode:mee}=require("msgpackr"),{isMainThread:WOe,parentPort:jOe,threadId:zOe}=require("worker_threads"),Rp=mr(),Zl=Ct(),XR=M(),jr=W(),JR=se(),See=M(),{onMessageByType:Tee}=dt(),w0=to(),{recordAction:O0,recordActionBinary:gee}=(Ii(),oe(k_)),{publishToStream:Aee}=Rp,{ConsumerEvents:N0}=require("nats"),Ree=Vr(),{promisify:yee}=require("util"),C0=yee(setTimeout),yp=1e4,bp,Ap,bee,Oee,D0,F_=new Map,eu=new Map;B0.exports={initialize:P0,ingestConsumer:ZR,setSubscription:Nee,setIgnoreOrigin:Cee,getDatabaseSubscriptions:wee,updateConsumer:L0};async function P0(){Tee(XR.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await L0(n)}),D0=!0,jr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await Rp.getNATSReferences();bp=e,Ap=e.info.server_name,bee=t,Oee=r}a(P0,"initialize");async function L0(e){if(e.status==="start"){let{js:t,jsm:r}=await M0(e.node_domain_name);ZR(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=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")),eu.get(e.node_domain_name)==="failed"&&eu.set(e.node_domain_name,"close")}}a(L0,"updateConsumer");var Op=new Map;function Nee(e,t,r){let n=Op.get(e);n||Op.set(e,n=new Map),n.set(t,r),D0||P0().then(Iee)}a(Nee,"setSubscription");async function Iee(){let e=await Ree.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+Zl.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions||[])if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await M0(r),!n))break;let{schema:o,table:c}=i,l=w0.createNatsTableStreamName(o,c);ZR(l,n,s,r)}}}a(Iee,"accessConsumers");async function M0(e){let t,r,n=1;for(;!r;)try{t=await bp.jetstream({domain:e}),r=await bp.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(eu.get(e)==="close")break;eu.set(e,"failed"),n%10===1&&jr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<yp?n++*100:yp;await C0(i)}return{js:t,jsm:r}}a(M0,"connectToRemoteJS");function wee(){return Op}a(wee,"getDatabaseSubscriptions");var U0;function Cee(e){U0=e}a(Cee,"setIgnoreOrigin");var v0=100,I0=new Array(v0),gp=0;async function ZR(e,t,r,n){let{connection:s}=await Rp.getNATSReferences();bp=s,Ap=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,Ap),jr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(eu.get(n)==="close")break;o%10===1&&jr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",u.message),u.code==="404"&&(jr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await Rp.createConsumer(r,e,Ap,new Date(Date.now()).toISOString()));let d=o++*100<yp?o++*100:yp;await C0(d)}let c=!1,l;for(;!c;){if(F_.get(e+n)==="close"||eu.get(n)==="close"){F_.delete(e+n),c=!0;continue}l=await i.consume({max_messages:JR.get(XR.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]=Dee(d).catch(_=>{jr.error(_)}),++gp>=v0&&(gp=0)}catch(d){d.message==="consumer deleted"?(jr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):jr.error("Error consuming clustering ingest, restarting consumer",d)}}}a(ZR,"ingestConsumer");async function Dee(e){let t=mee(e.data);O0(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),jr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=JR.get(XR.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(Zl.MSG_HEADERS.TRANSACTED_NODES)&&r.values(Zl.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(Zl.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!U0),gee(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(Zl.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:u,records:d,hash_values:_,__origin:E,expiresAt:f}=t;jr.trace("processing message:",o,c,u,(d?"records: "+d.map(U=>U?.id):"")+(_?"ids: "+_:""),"with sequence:",e.seq),jr.trace(`messageProcessor nats msg id: ${e.headers.get(Zl.MSG_HEADERS.NATS_MSG_ID)}`);let h;d||(d=_);let T=new Promise(U=>h=U),{timestamp:m,user:g,node_name:S}=E||{},y=Op.get(c)?.get(u);if(!y)throw new Error(`Missing table for replication message: ${u}`);if(o==="define_schema")t.type=o,t.onCommit=h,y.send(t);else if(d.length===1&&!l)y.send({type:QR(o),value:d[0],id:_?.[0],expiresAt:f,timestamp:m,table:u,onCommit:h,user:g,nodeName:S});else{let U=d.map((H,X)=>({type:QR(o),value:H,expiresAt:f,id:_?.[X],table:u}));for(;l;)U.push({type:QR(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;y.send({type:"transaction",writes:U,table:u,timestamp:m,onCommit:h,user:g,nodeName:S})}JR.get(See.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&Aee(e.subject.split(".").slice(0,-1).join("."),w0.createNatsTableStreamName(c,u),e.headers,e.data),await T;let I=Date.now()-m;m&&O0(I,"replication-latency",e.subject,o,"ingest")}catch(o){jr.error(o)}e.ack()}a(Dee,"messageProcessor");function QR(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(QR,"convertOperation")});var mr=N((nNe,Z0)=>{"use strict";var Or=se();Or.initSync();var Pee=require("fs-extra"),Lee=require("semver"),$_=require("path"),{monotonicFactory:Mee}=require("ulidx"),x0=Mee(),Uee=require("util"),k0=require("child_process"),vee=Uee.promisify(k0.exec),Bee=k0.spawn,Dr=Ct(),Je=M(),Np=te(),js=W(),Ip=to(),Hee=pp(),G_=wt(),{broadcast:xee,onMessageByType:kee,getWorkerIndex:Fee}=dt(),{isMainThread:F0}=require("worker_threads"),{Encoder:Gee,decode:sy}=require("msgpackr"),G0=new Gee,{isEmpty:bc}=Np,q0=xn(),XOe=48*36e11;F0&&kee(Je.ITC_EVENT_TYPES.RESTART,()=>{zr=void 0,yc=void 0});var{connect:qee,StorageType:$ee,RetentionPolicy:Vee,AckPolicy:iy,DeliverPolicy:oy,DiscardPolicy:Kee,NatsConnection:ZOe,JetStreamManager:eNe,JetStreamClient:tNe,StringCodec:rNe,JSONCodec:Yee,createInbox:ay,headers:Wee,ErrorCode:H0}=require("nats"),{PACKAGE_ROOT:jee}=M(),zee=Xl(),{recordAction:Qee}=(Ii(),oe(k_)),$0=Yee(),Jee="clustering",Xee=zee.engines[Dr.NATS_SERVER_NAME],Zee=$_.join(jee,"dependencies"),ny=$_.join(Zee,`${process.platform}-${process.arch}`,Dr.NATS_BINARY_NAME),ty,ry,q_,Ac,Rc;Z0.exports={runCommand:V0,checkNATSServerInstalled:ete,createConnection:cy,getConnection:V_,getJetStreamManager:K_,getJetStream:Y0,getNATSReferences:wi,getServerList:rte,createLocalStream:ly,listStreams:W0,deleteLocalStream:nte,getServerConfig:tu,listRemoteStreams:ste,viewStream:ite,viewStreamIterator:ote,publishToStream:ate,request:ute,reloadNATS:uy,reloadNATSHub:dte,reloadNATSLeaf:_te,extractServerName:lte,requestErrorHandler:fte,createLocalTableStream:J0,createTableStreams:pte,purgeTableStream:X0,purgeSchemaTableStreams:mte,getStreamInfo:Ste,updateLocalStreams:gte,closeConnection:tte,getJsmServerName:wp,addNatsMsgHeader:j0,clearClientCache:K0,updateRemoteConsumer:Ete,createConsumer:z0,updateConsumerIterator:hte};async function V0(e,t=void 0){let{stdout:r,stderr:n}=await vee(e,{cwd:t});if(n)throw new Error(n.replace(`
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((kge,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((qge,$C)=>{"use strict";var GC=require("fs-extra"),me=require("joi"),N2=require("os"),{boolean:He,string:It,number:tr,array:Qa}=me.types(),{totalmem:xC}=require("os"),za=require("path"),I2=W(),Tg=te(),Gge=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([Qa.items(It,{host:It.required(),port:sn},{hostname:It.required(),port:sn}).empty(null),Qa.items(It)]),mi,qC=!1;$C.exports={configValidator:v2,routesValidator:G2,route_constraints:ch};function v2(e,t=!1){if(qC=t,mi=e.rootPath,Tg.isEmpty(mi))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:Qa.optional().empty(null),databases:me.alternatives(It,Qa),enableRootCAs:He.optional(),copyTablesToCatchUp:He.optional()}).optional(),componentsRoot:s.optional(),clustering:_,localStudio:me.object({enabled:r}).required(),logging:me.object({auditAuthEvents:me.object({logFailed:He,logSuccessful:He}),file:He.required(),level:me.valid("notify","fatal","error","warn","info","debug","trace"),rotation:me.object({enabled:He.optional(),compress:He.optional(),interval:It.custom(k2).optional().empty(null),maxSize:It.custom(x2).optional().empty(null),path:It.optional().empty(null).default(Gd)}).required(),root:s,stdStreams:He.required(),auditLog:He.required()}).required(),operationsApi:me.object({network:me.object({cors:He.optional(),corsAccessList:Qa.optional(),headersTimeout:tr.min(1).optional(),keepAliveTimeout:tr.min(1).optional(),port:sn,domainSocket:me.optional().empty("hdb/operations-server").default(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:Qa.optional(),headersTimeout:tr.min(1).optional(),port:sn,securePort:sn,maxHeaderSize:tr.optional(),mtls:me.alternatives([He.optional(),me.object({user:It.optional(),certificateAuthority:i,required:He.optional()})]),threadRange:me.alternatives([Qa.optional(),It.optional()])}).required(),threads:me.alternatives(n.optional(),me.object({count:n.optional(),debug:me.alternatives(He.optional(),me.object({startingPort:tr.min(1).optional(),host:It.optional(),waitForDebugger:He.optional()})),maxHeapMemory:tr.min(0).optional()})),storage:me.object({writeAsync:He.required(),overlappingSync:He.optional(),caching:He.optional(),compression:me.alternatives([He.optional(),me.object({dictionary:It.optional(),threshold:tr.optional()})]),compactOnStart:He.optional(),compactOnStartKeepBackup:He.optional(),noReadAhead:He.optional(),path:l,prefetchWrites:He.optional(),maxFreeSpaceToLoad:tr.optional(),maxFreeSpaceToRetain:tr.optional()}).required(),ignoreScripts:He.optional(),tls:me.alternatives([me.array().items(d),d])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(v2,"configValidator");function B2(e){return 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(mi))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return za.join(mi,C2);case"logging.root":return za.join(mi,FC);case"clustering.leafServer.streams.path":return za.join(mi,"clustering","leaf");case"storage.path":let n=za.join(mi,kC.LEGACY_DATABASES_DIR_NAME);return GC.existsSync(n)?n:za.join(mi,kC.DATABASES_DIR_NAME);case"logging.rotation.path":return za.join(mi,FC);case"operationsApi.network.domainSocket":return r==null?null:za.join(mi,"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 Ja={};je(Ja,{server:()=>it});var VC,it,qr=Ie(()=>{VC=L(Ei()),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:Dl}=Dn(),{server:W2}=(qr(),oe(Ja)),{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:Pl,updateConfigValue:XC,updateConfigObject:n4,getConfiguration:o4,setConfiguration:a4,readConfigFile:bg,getClusteringRoutes:c4,initOldConfig:ZC,getConfigFromFile:l4,getConfigFilePath:Xa,addConfig:u4,deleteConfigFromFile:d4,getConfigObj:_4,resolvePath:Ag,getFlatConfigObj:f4});function Ag(e){if(e?.startsWith("~/"))return Ln.join(Er.getHomeDir(),e.slice(1));let t=se();return Ln.resolve(t.getHdbBasePath(),e)}a(Ag,"resolvePath");function e4(e,t=!1){let r=Vo(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=Pl(r.toJSON());let n;for(let c in e){let l=ks[c.toLowerCase()];if(l===Pn.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(u=>({[u]:e[c][u]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let u=l.split("_"),d=Rg(l,e[c]);l==="rootPath"&&d?.endsWith("/")&&(d=d.slice(0,-1));try{r.setIn([...u],d)}catch(_){hr.error(_)}}}n&&QC(r,n),yg(r,t);let s=r.toJSON();jt=Pl(s);let i=r.getIn(["rootPath"]),o=Ln.join(i,on.HDB_CONFIG_FILE);$r.createFileSync(o),$r.writeFileSync(o,String(r)),hr.trace(`Config file written to ${o}`)}a(e4,"createConfigFile");function 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=Pl(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 Xa(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(Xa,"getConfigFilePath");function dh(e=!1){if(jt===void 0||e){let t;if(!Er.noBootFile()){t=Er.getPropsFilePath();try{$r.accessSync(t,$r.constants.F_OK|$r.constants.R_OK)}catch(i){throw hr.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Xa(t),n;if(r.includes("config/settings.js"))try{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=Pl(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 Dl.CONFIG_VALIDATION("http.port and http.securePort cannot be the same value");if(r.operationsApi?.network?.port&&r.operationsApi?.network?.port===r.operationsApi?.network?.securePort)throw Dl.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=q2(r,t);if(n.error)throw Dl.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket),r?.clustering?.enabled&&e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path)}a(yg,"validateConfig");function n4(e,t){jt===void 0&&(jt={});let r=ks[e.toLowerCase()];if(r===void 0){hr.trace(`Unable to update config object because config param '${e}' does not exist`);return}jt[r.toLowerCase()]=t}a(n4,"updateConfigObject");function 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=Pl(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 Pl(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network={...e.http,...e.operationsApi.network}),e?.operationsApi&&(e.operationsApi.tls={...e.tls,...e.operationsApi.tls}),uh=e,r(e);function r(n){let s={};for(let i in n)if(n.hasOwnProperty(i)){if(typeof n[i]=="object"&&n[i]!==null&&!Array.isArray(n[i])&&!i4.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!Pn[l.toUpperCase()]&&ks[l]&&(s[ks[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Pl,"flattenConfig");function Rg(e,t){if(e===Pn.CLUSTERING_NODENAME||e===Pn.CLUSTERING_USER){if(t==null)return t;if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if($2(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Er.isObject(t)||t===null)return t;if(typeof t=="string"&&t.toLowerCase()==="true")return!0;if(typeof t=="string"&&t.toLowerCase()==="false")return!1}if(t===void 0||t.toLowerCase()==="undefined")return null;if(typeof t=="string"&&(t.startsWith("{")&&t.endsWith("}")||t.startsWith("[")&&t.endsWith("]")))try{return JSON.parse(t)}catch{}return Er.autoCast(t)}a(Rg,"castConfigValue");function o4(){let e=Er.getPropsFilePath(),t=Xa(e);return Vo(t).toJSON()}a(o4,"getConfiguration");async function a4(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return 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=Xa(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 Dl.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Er.isEmptyOrZeroLength(n)?[]:n;let s=KC(n);if(s)throw Dl.CONFIG_VALIDATION(s.message);if(!Er.isEmptyOrZeroLength(n)&&!Er.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Er.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw Dl.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(c4,"getClusteringRoutes");function 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(Xa());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await $r.writeFile(Xa(),String(r))}a(u4,"addConfig");function d4(e){let t=Xa(Er.getPropsFilePath()),r=Vo(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Ln.join(n,on.HDB_CONFIG_FILE);$r.writeFileSync(s,String(r))}a(d4,"deleteConfigFromFile");function _4(){return uh||(dh(),uh)}a(_4,"getConfigObj");function f4(){return jt||dh(),jt}a(f4,"getFlatConfigObj")});var se=N((iD,oD)=>{"use strict";var Og=require("fs-extra"),Za=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=Za.join(__dirname,"../../","unitTests");Qi[fh]=Za.join(l,"hdb_boot_properties.file"),Qe(De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Za.join(l,"settings.test")),Qe(De.HDB_SETTINGS_NAMES.INSTALL_USER,tD.userInfo()?tD.userInfo().username:void 0),Qe(De.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Qe(De.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Za.join(l,"envDir","log")),Qe(De.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Qe(De.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Qe(De.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Qe(De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Za.join(l,"envDir")),Qe(De.CONFIG_PARAMS.STORAGE_PATH,Za.join(l,"envDir")),s&&(Qe(De.CONFIG_PARAMS.HTTP_SECUREPORT,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,Za.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((Wge,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((Jge,SD)=>{"use strict";var w4=Dn().LMDB_ERRORS_ENUM,zge=require("lmdb"),C4=Ht(),Qge=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((Zge,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((rAe,yD)=>{"use strict";var tAe=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,Ll=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,y=[],I={table:null,database:null,properties:y};E.set(S,I);for(let Y of g.directives){if(Y.name.value==="table"){for(let ne of Y.arguments)I[ne.name.value]=ne.value.value;I.schema&&(I.database=I.schema),I.table||(I.table=S),I.audit&&(I.audit=I.audit!=="false"),I.attributes=I.properties,f.push(I)}if(Y.name.value==="sealed"&&(I.sealed=!0),Y.name.value==="splitSegments"&&(I.splitSegments=!0),Y.name.value==="replicate"&&(I.replicate=!0),Y.name.value==="export"){I.export=!0;for(let ne of Y.arguments)typeof I.export!="object"&&(I.export={}),I.export[ne.name.value]=ne.value.value}}let U=!1,X={};for(let Y of g.fields){let V=H(Y.type);V.name=Y.name.value,y.push(V),X[V.name]=void 0;for(let ne of Y.directives){let Q=ne.name.value;if(Q==="primaryKey")U?console.warn("Can not define two attributes as a primary key at",ne.loc):(V.isPrimaryKey=!0,U=!0);else if(Q==="indexed")V.indexed=!0;else if(Q==="computed"){for(let de of ne.arguments||[])if(de.name.value==="from"){let j=de.value.value;V.computed={from:m(j,de,X)},V.version==null&&(V.version=j)}else de.name.value==="version"&&(V.version=de.value.value);V.computed=V.computed||!0}else if(Q==="relationship"){let de={};for(let j of ne.arguments)de[j.name.value]=j.value.value;V.relationship=de}else if(Q==="createdTime")V.assignCreatedTime=!0;else if(Q==="updatedTime")V.assignUpdatedTime=!0;else if(Q==="expiresAt")V.expiresAt=!0;else if(Q==="allow"){let de=V.authorizedRoles=[];for(let j of ne.arguments)j.name.value==="role"&&de.push(j.value.value)}else server.knownGraphQLDirectives.includes(Q)&&console.warn(`@${Q} is an unknown directive, at`,ne.loc)}}I.type=S,S==="Query"&&(h=I)}function T(g){let S=E.get(g.type);S?(Object.defineProperty(g,"properties",{value:S.properties}),Object.defineProperty(g,"definition",{value:S})):g.type==="array"?T(g.elements):F4.includes(g.type)||(0,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,y){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()(y)}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:()=>ec});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 ec(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===LD)return MD(e);if(t.resolution)return t.resolution.then(()=>ec(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)+":"+ec(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function Mg(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),K4.test(e)?$4.parse(e):JSON.parse(e)):null}var 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 ec(t)}else yield ec(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(ec,"stringify");a(MD,"jsStringify");K4=/[[,:]\s*-?\d{16,}/;a(Mg,"parse")});var WD=N((uAe,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"),lAe=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((_Ae,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((EAe,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,tc.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let l=0;l<tc.length;l++){let u=tc[l].deref();(!u||u.isDone||u.isCommitted)&&tc.splice(l--,1)}},i.prototype.done.isTracked=!0}return e}function Jg(e,t,r){return function(n,s,i,o,c=-1,l,u,d="put",_,E){_||l==null?Ml=i?.localTime?Vg|eP:$g:Ml=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:Ml>0},T,m=0;try{let g=i?.residencyId,S=u?.residencyId;S&&(Yg=S,r_|=zg,m|=rc),g!==S&&(m|=nc,g||(g=0)),c&bh&&(m|=o_),u?.originatingOperation&&(m|=i_),_&&(h.ifVersion=T=i?.version??null);let y=e.put(n,s,h);if(l){let I=u?.user?.username;if(E&&(yh=e.encoder.encode(E)),e.encoder.hasStructureUpdate&&(m|=Oh,e.encoder.hasStructureUpdate=!1),_&&i?.localTime){let U=i?.localTime,H=r.get(U);if(H){let X=xt(H).previousLocalTime;return r.put(U,Ul(o,t,n,X,u?.nodeId??server.replication.getThisNodeId(r)??0,I,d,yh,m,S,g,f),{ifVersion:T}),y}}r.put(s_,Ul(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,I,d,yh,m,S,g,f,u?.originatingOperation),{append:d!=="invalidate",instructedWrite:!0,ifVersion:T})}return y}catch(g){throw g.message+=" id: "+n+" options: "+h,g}}}var XD,qg,Rh,s_,jg,Q4,t_,n_,J4,$g,ZD,X4,eP,Vg,bh,zg,Qg,Oh,Z4,yh,Ml,r_,Kg,Yg,Wg,tc,vl=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,Ml=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(Ml||r_>=0){let o=0,c=Ml;c&&(o+=8,Ml=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");tc=[];setInterval(()=>{for(let e=0;e<tc.length;e++){let t=tc[e].deref();!t||t.isDone||t.isCommitted?tc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(qg.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):qg.error("Read transaction detected that has been open too long (over one minute), make sure read transactions are quickly closed",t)),t.openTimer++):t.openTimer=1)}},15e3).unref();a(Jg,"getUpdateRecord")});var a_=N((TAe,nP)=>{"use strict";var rP=se(),tJ=M(),{RecordEncoder:rJ}=(vl(),oe(tP)),SAe=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((AAe,sP)=>{"use strict";var Un=se(),cs=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(cs.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Un.get(cs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Un.get(cs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Un.get(cs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Un.get(cs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Un.get(cs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Un.get(cs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Un.get(cs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Un.get(cs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Un.get(cs.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Un.get(cs.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Un.get(cs.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};sP.exports=Ih;Ih.MAX_DBS=1e4});var ht=N((yAe,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=ls(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++)ls(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=ls(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=ls(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=ls(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 ls(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,ls(e,Gs).putSync(t,c),e.dbis[t]=o,o}throw s}}a(fP,"createDBI");function ls(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(ls,"openDBI");function EJ(e,t){Ph(e,t),t=t.toString();let r=ls(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);ls(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],ls(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{ls(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:ls,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((OAe,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((IAe,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((CAe,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 ic=N((UAe,yP)=>{"use strict";var SJ=ht(),TJ=pP(),gJ=SP(),AJ=gP(),Si=cn(),u_=Dn().LMDB_ERRORS_ENUM,RJ=Ht(),Xi=M(),yJ=te(),bJ=require("uuid"),PAe=require("lmdb"),{handleHDBError:OJ,hdb_errors:NJ}=_e(),{OVERFLOW_MARKER:LAe,MAX_SEARCH_KEY_LENGTH:MAe}=RJ,AP=se();AP.initSync();var Lh=AP.get(Xi.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),aA=Xi.TIME_STAMP_NAMES_ENUM.CREATED_TIME,sc=Xi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function IJ(e,t,r,n,s=Si.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=Si.getIndexedValues(c),u=e.dbis[o];if(l){Lh&&u.prefetch(l.map(d=>({key:d,value:s})),Mh);for(let d=0,_=l.length;d<_;d++)u.put(l[d],s)}}Lh&&e.dbis[t].prefetch([s],Mh),e.dbis[t].put(s,n,n[sc])})}a(wJ,"insertRecord");function CJ(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(CJ,"removeSkippedRecords");function RP(e,t,r){let n=r>0;(n||!Number.isInteger(e[sc]))&&(e[sc]=r||(r=Si.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[aA]))&&(e[aA]=r||Si.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=Si.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=Si.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||Si.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[sc])&&u[sc]>r[sc])return!1;d&&s.original_records.push(u);let _,E=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let T=r[h],m=e.dbis[h];if(m===void 0)continue;let g=u[h];if(typeof T=="function"){let y=T([[u]]);Array.isArray(y)&&(T=y[0][Xi.FUNC_VAL],r[h]=T)}if(T===g)continue;let S=Si.getIndexedValues(g);if(S){Lh&&m.prefetch(S.map(y=>({key:y,value:n})),Mh);for(let y=0,I=S.length;y<I;y++)m.remove(S[y],n)}if(S=Si.getIndexedValues(T),S){Lh&&m.prefetch(S.map(y=>({key:y,value:n})),Mh);for(let y=0,I=S.length;y<I;y++)m.put(S[y],n)}}let f={...u,...r};c.put(n,f,f[sc])},"do_put");return l?_=c.ifVersion(n,l.version,E):_=c.ifNoExists(n,E),_.then(f=>f?!0:uA(e,t,r,n,s,i,o))}a(uA,"updateUpsertRecord");function LJ(e,t,r){if(Si.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((BAe,MJ)=>{MJ.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"}]},hdb_certificate:{hash_attribute:"name",name:"hdb_certificate",schema:"system",attributes:[{attribute:"name"},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var gi=N((HAe,NP)=>{"use strict";var OP=te(),bP=M(),Bl=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Ti=require("joi"),Wo={schema_format:{pattern:Bl,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},UJ=Ti.alternatives(Ti.string().min(1).max(Wo.schema_length.maximum).pattern(Bl).messages({"string.pattern.base":"{:#label} "+Wo.schema_format.message}),Ti.number(),Ti.array()).required(),vJ=Ti.alternatives(Ti.string().min(1).max(Wo.schema_length.maximum).pattern(Bl).messages({"string.pattern.base":"{:#label} "+Wo.schema_format.message}),Ti.number()),BJ=Ti.alternatives(Ti.string().min(1).max(Wo.schema_length.maximum).pattern(Bl).messages({"string.pattern.base":"{:#label} "+Wo.schema_format.message}),Ti.number()).required();function HJ(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>Wo.schema_length.maximum?`'${e}' maximum of 250 characters`:Bl.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(HJ,"checkValidTable");function xJ(e,t){return 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:Bl,hdb_schema_table:UJ,validateSchemaExists:xJ,validateTableExists:kJ,validateSchemaName:FJ,checkValidTable:HJ,hdb_database:vJ,hdb_table:BJ}});var Uh=N((kAe,IP)=>{var{common_validators:Ai}=gi(),__=Tt(),d_="is required",rr={database:{presence:!1,format:Ai.schema_format,length:Ai.schema_length},schema:{presence:!1,format:Ai.schema_format,length:Ai.schema_length},table:{presence:!0,format:Ai.schema_format,length:Ai.schema_length},attribute:{presence:!0,format:Ai.schema_format,length:Ai.schema_length},hash_attribute:{presence:!0,format:Ai.schema_format,length:Ai.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((GAe,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(($Ae,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((KAe,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((jAe,BP)=>{"use strict";var JJ=M(),EA=ht(),XJ=ic(),{getSystemSchemaPath:ZJ,getSchemaPath:e3}=gt(),WAe=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((QAe,xP)=>{var{hdb_table:a3,hdb_database:HP}=gi(),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((ZAe,FP)=>{"use strict";var eo=te(),kP=W(),XAe=pA(),{getDatabases:_3}=(Pe(),oe(lt)),{ClientError:oc}=_e();FP.exports=f3;function f3(e){if(eo.isEmpty(e))throw new oc("invalid update parameters defined.");if(eo.isEmptyOrZeroLength(e.schema))throw new oc("invalid schema specified.");if(eo.isEmptyOrZeroLength(e.table))throw new oc("invalid table specified.");if(!Array.isArray(e.records))throw new oc("records must be an array");let t=_3()[e.schema]?.[e.table];if(eo.isEmpty(t))throw new oc(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&eo.isEmptyOrZeroLength(o[r]))throw kP.error("a valid hash attribute must be provided with update record:",o),new oc("a valid hash attribute must be provided with update record, check log for more info");if(!eo.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw kP.error(`a valid hash value must be provided with ${e.operation} record:`,o),new oc(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!eo.isEmpty(o[r])&&o[r]!==""&&n.has(eo.autoCast(o[r]))&&(o.skip=!0),n.add(eo.autoCast(o[r]));for(let c in o)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}a(f3,"insertUpdateValidate")});var qP=N((tRe,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((nRe,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((iRe,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((cRe,XP)=>{"use strict";var aRe=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 us=N((_Re,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(),uRe=eL(rL.describeAll),dRe=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((ERe,aL)=>{"use strict";var qh=pA(),Cr=te(),U3=require("util"),$h=Bn(),v3=us(),sL=W(),{handleHDBError:ac,hdb_errors:B3}=_e(),{HTTP_STATUS_CODES:cc}=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 ac(new Error,t.message,cc.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw ac(new Error,r,cc.BAD_REQUEST);let n=await $h.createRecords(e);return Gh(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 ac(new Error,t.message,cc.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw ac(new Error,r,cc.BAD_REQUEST);let n=await $h.updateRecords(e);return Cr.isEmpty(n.existing_rows)?Gh(x3,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):Gh(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(G3,"updateData");async function q3(e){if(e.operation!=="upsert")throw ac(new Error,"invalid operation, must be upsert",cc.INTERNAL_SERVER_ERROR);let t=qh(e);if(t)throw ac(new Error,t.message,cc.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw ac(new Error,r,cc.BAD_REQUEST);let n=await $h.upsertRecords(e);return Gh(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((pRe,uL)=>{var V3=Tt(),RA=require("joi"),{hdb_table:K3,hdb_database:cL}=gi(),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((mRe,_L)=>{var j3=Tt(),bA=require("joi"),{hdb_table:z3,hdb_database:dL}=gi(),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((SRe,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 dc=N((gRe,TL)=>{"use strict";var pL=yA(),J3=fL(),lc=te(),hL=require("moment"),mL=W(),{promisify:X3,callbackify:Z3}=require("util"),uc=M(),eX=us(),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(lc.transformReq(e),!hL(e.date,hL.ISO_8601).isValid())throw jo(new Error,Vh.INVALID_DATE,zo.BAD_REQUEST,uc.LOG_LEVELS.ERROR,Vh.INVALID_DATE,!0);let n=lc.checkSchemaTableExist(e.schema,e.table);if(n)throw jo(new Error,n,zo.NOT_FOUND,uc.LOG_LEVELS.ERROR,n,!0);let s=await DA.deleteRecordsBefore(e);if(await CA(e.schema,e.table),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(lc.transformReq(e),isNaN(e.timestamp))throw jo(new Error,Vh.INVALID_VALUE("Timestamp"),zo.BAD_REQUEST,uc.LOG_LEVELS.ERROR,Vh.INVALID_VALUE("Timestamp"),!0);let r=lc.checkSchemaTableExist(e.schema,e.table);if(r)throw jo(new Error,r,zo.NOT_FOUND,uc.LOG_LEVELS.ERROR,r,!0);let n=await DA.deleteAuditLogsBefore(e);return await CA(e.schema,e.table),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);lc.transformReq(e);let r=lc.checkSchemaTableExist(e.schema,e.table);if(r)throw jo(new Error,r,zo.NOT_FOUND,uc.LOG_LEVELS.ERROR,r,!0);try{await CA(e.schema,e.table);let n=await DA.deleteRecords(e);return lc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${nX}`),n}catch(n){if(n.message===uc.SEARCH_NOT_FOUND_MESSAGE){let s=new tX;return s.message=uc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(SL,"deleteRecord")});var Kh=N((RRe,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((bRe,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((IRe,NL)=>{"use strict";var{platform:NRe}=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"},Hl={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},OX={[Hl.ERR]:1,[Hl.WRN]:2,[Hl.INF]:3,[Hl.DBG]:4,[Hl.TRC]:5},NX={debug:"-D",trace:"-DVV"};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:Hl,LOG_LEVEL_FLAGS:NX,LOG_LEVEL_HIERARCHY:OX}});var wL=N((CRe,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 _c=N((PRe,vL)=>{"use strict";var kl=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,xl="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 kl.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await xX();throw Yr.error(`Error writing fingerprint file to ${e}`),Yr.error(t),new Error("There was an error generating the fingerprint")}}a(HX,"generateFingerPrint");async function xX(){let e=wX(),t=DL.hash(e),r=HA();try{await kl.mkdirp(BA()),await kl.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw Yr.error(`Error writing fingerprint file to ${r}`),Yr.error(n),new Error("There was an error generating the fingerprint")}return t}a(xX,"writeFingerprint");function 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=kl.statSync(n)}catch(i){Yr.error(i)}if(s){let i;try{i=kl.readFileSync(n,"utf8")}catch{Yr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(LX),c=o[1];c=Buffer.concat([Buffer.from(c)],UX);let l=Buffer.concat([Buffer.from(i)],vX),u=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(xl),Yr.error(xl),new Error(xl)}let _;if(isNaN(d))try{_=JSON.parse(d),r.version=_.version,r.exp_date=_.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),_.ram_allocation&&(r.ram_allocation=_.ram_allocation)}catch{throw console.error(xl),Yr.error(xl),new Error(xl)}else r.exp_date=d;r.exp_date<IX().valueOf()&&(r.valid_date=!1),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=kl.readFileSync(BX(),"utf-8").split(Qo.NEW_LINE)}catch(r){r.code==="ENOENT"?Yr.debug("no license file found"):Yr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(CX.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=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((BRe,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:Gl,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=dc(),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(),MRe=se(),URe=_c(),KX=Zi(),{table:vRe}=(Pe(),oe(lt)),{handleHDBError:Ri,hdb_errors:YX}=_e(),{HTTP_STATUS_CODES:yi,AUTHENTICATION_ERROR_MSGS:kA,HDB_ERROR_MSGS:Fl}=YX,{UserEventMsg:VA}=qs(),FA=require("lodash"),{server:KA}=(qr(),oe(Ja)),WX=W();KA.getUser=(e,t)=>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 Ri(new Error,r.message,yi.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,Fl.ROLE_NAME_NOT_FOUND(t.role),yi.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw Ri(new Error,Fl.DUP_ROLES_FOUND(t.role),yi.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 Gl()}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,Fl.USER_ALREADY_EXISTS(t.username),yi.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=Fl.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Ke.error(c),Ri(new Error,c,yi.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=Fl.ALTER_USER_DUP_ROLES(t.role);throw Ke.error(c),Ri(new Error,c,yi.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 Gl()}catch(i){throw Ke.error("Got an error setting users to global"),Ke.error(i),i}return qA.signalUserChange(new VA(process.pid)),s}a(JX,"alterUser");function XX(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(XX,"isClusterUser");async function ZX(e){try{let t=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 Ri(new Error,Fl.USER_NOT_EXIST(e.username),yi.NOT_FOUND,void 0,void 0,!0);let n;try{n=await zX(r)}catch(s){throw Ke.error("Got an error deleting a user."),Ke.error(s),s}Ke.debug(n);try{await Gl()}catch(s){throw Ke.error("Got an error setting users to global."),Ke.error(s),s}return qA.signalUserChange(new VA(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(ZX,"dropUser");async function eZ(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=FA.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await jX(r)}catch(s){throw Ke.error("Got an error searching for a role."),Ke.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw Ke.error(r),r}return t}a(eZ,"userInfo");async function tZ(){let e;try{e=await zh()}catch(t){throw Ke.error("Got an error listing users."),Ke.error(t),t}try{e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token})}catch{throw new Error("there was an error massaging the user data")}return[...e.values()]}a(tZ,"listUsersExternal");async function zh(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await jh(e)}catch(o){throw Ke.error("Got an error searching for roles."),Ke.error(o),o}let r={};for(let o of t)r[o.id]=FA.cloneDeep(o);if(Object.keys(r).length===0)return null;let n={schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]},s;try{s=await jh(n)}catch(o){throw Ke.error("Got an error searching for users."),Ke.error(o),o}let i=new Map;for(let o of s)o=FA.cloneDeep(o),o.role=r[o.role],rZ(o.role),i.set(o.username,o);return i}catch(e){throw Ke.error("got an error listing users"),Ke.error(e),Hn.errorizeMessage(e)}return null}a(zh,"listUsers");function rZ(e){try{if(!e){Ke.error("invalid user role found.");return}e.permission.system||(e.permission.system={}),e.permission.system.tables||(e.permission.system.tables={});for(let t of Object.keys(KX)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){Ke.error("Got an error trying to set system permissions."),Ke.error(t)}}a(rZ,"appendSystemTablesToRole");async function Gl(){try{let e=await zh();global.hdb_users=e}catch(e){throw Ke.error(e),e}}a(Gl,"setUsersToGlobal");async function zL(e,t,r=!0){global.hdb_users||await Gl();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw Ri(new Error,kA.GENERIC_AUTH_FAIL,yi.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw Ri(new Error,kA.USER_INACTIVE,yi.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 Ri(new Error,kA.GENERIC_AUTH_FAIL,yi.UNAUTHORIZED,void 0,void 0,!0)}return s}a(zL,"findAndValidateUser");async function nZ(){global.hdb_users||await Gl();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(nZ,"getSuperUser");async function sZ(){let e=await zh(),t=VX.getConfigFromFile(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((FRe,tM)=>{"use strict";var fc=W(),kn=M(),iZ=KP(),xRe=us(),kRe=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){fc.error(t);return}fc.trace("ITC schemaHandler received schema event:",e),await iZ(e.message),await dZ(e.message)}a(uZ,"schemaHandler");async function dZ(e){try{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){fc.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){fc.warn(r)}let t=XL(e);if(t){fc.error(t);return}fc.trace(`ITC userHandler ${kn.HDB_ITC_CLIENT_PREFIX}${aZ.pid} received user event:`,e),await oZ.setUsersToGlobal();for(let r of ZL)r()}catch(t){fc.error(t)}}a(eM,"userHandler");eM.addListener=function(e){ZL.push(e)};tM.exports=lZ});var qs=N((YRe,nM)=>{"use strict";var qRe=W(),YA=te(),_Z=M(),{ITC_ERRORS:T_}=Dn(),{parentPort:$Re,threadId:fZ,isMainThread:EZ,workerData:VRe}=require("worker_threads"),{onMessageFromWorkers:hZ,broadcast:KRe,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((zRe,aM)=>{"use strict";var sM=M(),jRe=te(),Jh=W(),iM=qP(),ql,{sendItcEvent:oM}=qs();function gZ(e){try{Jh.info("signalSchemaChange called with message:",e),ql=ql||S_();let t=new iM(sM.ITC_EVENT_TYPES.SCHEMA,e);return ql.schema(t),oM(t)}catch(t){Jh.error(t)}}a(gZ,"signalSchemaChange");function AZ(e){try{Jh.trace("signalUserChange called with message:",e),ql=ql||S_();let t=new iM(sM.ITC_EVENT_TYPES.USER,e);return ql.user(t),oM(t)}catch(t){Jh.error(t)}}a(AZ,"signalUserChange");aM.exports={signalSchemaChange:gZ,signalUserChange:AZ}});var Xh=N((JRe,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 $l=N((ZRe,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((tye,dM)=>{"use strict";var LZ=$l(),MZ=M().OPERATIONS_ENUM,jA=class extends LZ{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(MZ.INSERT,r,n,s,i),this.records=t}};dM.exports=jA});var EM=N((nye,fM)=>{"use strict";var UZ=$l(),vZ=M().OPERATIONS_ENUM,zA=class extends UZ{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(vZ.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};fM.exports=zA});var pM=N((iye,hM)=>{"use strict";var BZ=$l(),HZ=M().OPERATIONS_ENUM,QA=class extends BZ{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(HZ.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};hM.exports=QA});var SM=N((aye,mM)=>{"use strict";var xZ=$l(),kZ=M().OPERATIONS_ENUM,JA=class extends xZ{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(kZ.DELETE,n,s,t,i),this.original_records=r}};mM.exports=JA});var g_=N((uye,RM)=>{"use strict";var lye=require("path"),TM=ht(),FZ=_M(),GZ=EM(),qZ=pM(),$Z=SM(),Vl=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,Vl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Vl.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Vl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Vl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),gM.isEmpty(s.user_name)||n.dbis[Vl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Vl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(YZ,"writeTransaction");function WZ(e,t){let r=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((fye,yM)=>{"use strict";var jZ=E_(),_ye=Jd(),A_=M(),zZ=Xd(),QZ=ic().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((hye,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((mye,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((Rye,PM)=>{"use strict";var CM=ht(),eR=cn(),tR=Dn().LMDB_ERRORS_ENUM,c5=Ht(),DM=W(),Tye=te(),l5=require("lmdb"),u5=wM(),d5=M(),{OVERFLOW_MARKER:gye,MAX_SEARCH_KEY_LENGTH:Aye}=c5,_5=d5.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function f5(e,t,r,n){if(eR.validateEnv(e),t===void 0)throw new Error(tR.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(tR.IDS_REQUIRED):new Error(tR.IDS_MUST_BE_ITERABLE);try{let s=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],y=h[g];if(y!=null)try{let I=eR.getIndexedValues(y);if(I)for(let U=0,H=I.length;U<H;U++)S.remove(I[U],o)}catch{DM.warn(`cannot delete from attribute: ${g}, ${y}:${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((bye,UM)=>{"use strict";var Kl=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(Kl.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Kl.isEmptyOrZeroLength(e.hash_values)&&!Kl.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Kl.isEmpty(l)||e.hash_values.push(l)}}if(Kl.isEmptyOrZeroLength(e.hash_values))return MM([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Kl.isEmptyOrZeroLength(e.records)){e.records=[];for(let c=0;c<e.hash_values.length;c++)e.records[c]={[n]:e.hash_values[c]}}let s=p5(e.schema,e.table),i=await h5.openEnvironment(s,e.table),o=await E5.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await m5(e,o)}catch(c){S5.error(`unable to write transaction due to ${c.message}`)}return 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((Iye,vM)=>{"use strict";var g5=M(),Nye=cn();function rR(e,t){let r=Object.create(null);if(t.length===1&&g5.SEARCH_WILDCARDS.indexOf(t[0])>=0)Object.assign(r,e);else for(let n=0;n<t.length;n++){let s=t[n],i=e[s];r[s]=i===void 0?null:i}return r}a(rR,"parseRow");function A5(e,t,r,n){let s=rR(r,e);n.push(s)}a(A5,"searchAll");function R5(e,t,r,n){let s=rR(r,e);n[t]=s}a(R5,"searchAllToMap");function y5(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(y5,"iterateDBI");function Ec(e,t,r,n,s){let i=Object.create(null);i[s]=e;let o;n===s?o=e:(o=t,n!==void 0&&(i[n]=o)),r[0].push(o),r[1].push(i)}a(Ec,"pushResults");function b5(e,t,r,n,s,i){t.toString().endsWith(e)&&Ec(t,r,n,s,i)}a(b5,"endsWith");function O5(e,t,r,n,s,i){t.toString().includes(e)&&Ec(t,r,n,s,i)}a(O5,"contains");function N5(e,t,r,n,s,i){t>e&&Ec(t,r,n,s,i)}a(N5,"greaterThanCompare");function I5(e,t,r,n,s,i){t>=e&&Ec(t,r,n,s,i)}a(I5,"greaterThanEqualCompare");function w5(e,t,r,n,s,i){t<e&&Ec(t,r,n,s,i)}a(w5,"lessThanCompare");function C5(e,t,r,n,s,i){t<=e&&Ec(t,r,n,s,i)}a(C5,"lessThanEqualCompare");vM.exports={parseRow:rR,searchAll:A5,searchAllToMap:R5,iterateDBI:y5,endsWith:b5,contains:O5,greaterThanCompare:N5,greaterThanEqualCompare:I5,lessThanCompare:w5,lessThanEqualCompare:C5,pushResults:Ec}});var Yl=N((Lye,qM)=>{"use strict";var Jo=ht(),Cye=W(),Fn=cn(),ep=Ht(),zt=Dn().LMDB_ERRORS_ENUM,Dye=te(),D5=M(),tp=nR(),{parseRow:P5}=tp,Pye=require("lmdb"),{OVERFLOW_MARKER:BM,MAX_SEARCH_KEY_LENGTH:L5}=ep;function HM(e,t,r,n=!1,s=void 0,i=void 0){return hc(e,t,r,(o,c)=>c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}))}a(HM,"iterateFullIndex");function y_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return hc(e,t,r,(d,_,E,f)=>{let S={transaction:d,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return f===r?(S.values=!1,_.getRange(S).map(y=>({value:y}))):_.getRange(S)})}a(y_,"iterateRangeBetween");function hc(e,t,r,n){let s=e.database||e,i=Jo.openDBI(s,r);i[ep.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&Jo.openDBI(s,t);let o;e.database?o=e:(o=e.useReadTransaction(),o.database=e);let c=n(o,i,s,t);return c.transaction=o,e.database||(c.onDone=()=>{o.done()}),c}a(hc,"setupTransaction");function 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 hc(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),hc(e,t,r,(c,l,u,d)=>(n=Fn.convertKeyValueToWrite(n),d===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(_=>({key:n,value:_}))))}a(H5,"equals");function x5(e,t,r){return Xo(e,t,r),Jo.openDBI(e,t).getValuesCount(r)}a(x5,"count");function k5(e,t,r,n,s=!1,i=void 0,o=void 0){return Xo(e,r,n),hc(e,null,r,(c,l)=>{n=Fn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let d;if(s===!0){let _;for(let E of l.getKeys({transaction:c,start:n}))if(!E.startsWith(n)){_=E;break}return _!==void 0&&(Number.isInteger(o)?o++:i++),d=l.getRange({transaction:c,start:_,end:void 0,reverse:s,limit:i,offset:o}).map(E=>{let{key:f}=E;if(f!==_){if(f.toString().startsWith(n))return E;if(u===!0)return d.DONE}}),d.filter(E=>E)}else return d=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(_=>{if(_.key.toString().startsWith(n))return _;if(u===!0)return d.DONE}),u?d:d.filter(_=>_)})}a(k5,"startsWith");function F5(e,t,r,n,s=!1,i=void 0,o=void 0){return 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),hc(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 hc(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 Wl=N((Uye,WM)=>{var $M=require("lodash"),VM=Tt(),xe=require("joi"),Q5=te(),{hdb_schema_table:O_,checkValidTable:KM,hdb_table:YM,hdb_database:np}=gi(),{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((Bye,jM)=>{"use strict";var n6=ht(),s6=Wl(),{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((xye,zM)=>{"use strict";var a6=Yl(),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 jl=N((Fye,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(($ye,JM)=>{"use strict";var qye=jl(),u6=Yl(),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((Kye,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((Wye,iU)=>{"use strict";var Wr=Yl(),f6=ht(),E6=te(),ke=Ht(),pc=M(),h6=Zi(),eU=Dn().LMDB_ERRORS_ENUM,{getSchemaPath:p6}=gt(),so=pc.SEARCH_WILDCARDS;async function m6(e,t,r){let n;e.schema===pc.SYSTEM_SCHEMA_NAME?n=h6[e.table]:n=global.hdb_schema[e.schema][e.table];let s=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 pc.VALUE_SEARCH_COMPARATORS.BETWEEN:return ke.SEARCH_TYPES.BETWEEN;case pc.VALUE_SEARCH_COMPARATORS.GREATER:return ke.SEARCH_TYPES.GREATER_THAN;case pc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return ke.SEARCH_TYPES.GREATER_THAN_EQUAL;case pc.VALUE_SEARCH_COMPARATORS.LESS:return ke.SEARCH_TYPES.LESS_THAN;case pc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return ke.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(eU.UNKNOWN_SEARCH_TYPE)}}a(sU,"createSearchTypeFromSearchObject");iU.exports={executeSearch:rU,createSearchTypeFromSearchObject:sU,prepSearch:m6,searchByType:nU}});var aU=N((Qye,oU)=>{"use strict";var zye=$s(),T6=Wl(),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((Zye,cU)=>{"use strict";var Xye=$s(),b6=Wl(),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((rbe,lU)=>{"use strict";var tbe=Ht(),cR=class{static{a(this,"SearchByConditionsObject")}constructor(t,r,n,s,i=void 0,o=void 0,c="and"){this.schema=t,this.table=r,this.get_attributes=n,this.limit=i,this.offset=o,this.conditions=s,this.operator=c}},lR=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},uR=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};lU.exports={SearchByConditionsObject:cR,SearchCondition:lR,SortAttribute:uR}});var hU=N((obe,EU)=>{"use strict";var sbe=uU().SearchByConditionsObject,C6=$s(),D6=Wl(),dR=Yl(),ip=Ht(),{Resource:ibe}=(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((cbe,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((ube,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((_be,OU)=>{"use strict";var K6=require("fs-extra"),Y6=$s(),W6=jl(),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((Ebe,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((mbe,wU)=>{"use strict";var o8=require("fs-extra"),op=ht(),{getTransactionAuditStorePath:a8}=gt(),pR=Ht(),pbe=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((gbe,DU)=>{"use strict";var SR=M(),CU=ht(),l8=ic(),{getSystemSchemaPath:u8,getSchemaPath:d8}=gt(),Tbe=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((Rbe,LU)=>{"use strict";var p8=E_(),m8=Xd(),S8=Xh(),C_=M(),T8=ic().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((bbe,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((Ibe,BU)=>{"use strict";var Nbe=vU(),N8=E_(),I8=Xd(),w8=Xh(),D_=M(),C8=ic().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((Cbe,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((Pbe,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((Ube,$U)=>{"use strict";var bR=ht(),{getTransactionAuditStorePath:H8}=gt(),Mbe=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((Bbe,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((kbe,WU)=>{"use strict";var K8=$s(),Y8=I_(),xbe=YU(),bi=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===bi.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(bi.SYSTEM_SCHEMA_NAME,bi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await z8(t)).filter(o=>o[bi.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[bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new Y8(bi.SYSTEM_SCHEMA_NAME,bi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return Q8(i)}a(e9,"dropAttributeFromSystem")});var ev=N((qbe,ZU)=>{"use strict";var IR=ht(),zl=Ht(),Gbe=cn(),wR=M(),zU=te(),{getTransactionAuditStorePath:t9}=gt(),r9=Yl(),ap=$l(),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,zl.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[zl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let s of r.getKeys({start:t[1]}))if(s!==t[1]){n=s;break}return r.getRange({start:t[0],end:n}).map(({value:s})=>Object.assign(new ap,s))}a(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[zl.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,zl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,zl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:_}of d){let E=Number(_);n.has(E)?n.get(E).push(u.toString()):n.set(E,[u.toString()])}}let s=Array.from(n.keys()),i=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[zl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let s=0;s<t.length;s++)try{let i=n.get(t[s]);if(i){let o=Object.assign(new ap,i);r.push(o)}}catch(i){n9.warn(i)}return r}catch(n){throw n}}a(XU,"batchSearchTransactions")});var rv=N((Ybe,tv)=>{"use strict";var{getSchemaPath:Vbe}=gt(),Kbe=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((jbe,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((Qbe,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,y){y.encoding="binary",y.encoder=void 0;let I=_.openDB(S,y),U=d.openDB(S,y);for(let{key:H,version:X,value:Y}of U.getRange({start:null,transaction:h,versions:U.useVersions}))E=I.put(H,Y,X),T++%g9===0&&(await new Promise(V=>setTimeout(V,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:S,value:y}of d.getRange({transaction:h,start:!1}))if(s.some(I=>S.startsWith?.(I+"/"))){f.put(S,y);let[,I]=S.split("/"),U=!I,H=new cv(!U,U);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((Xbe,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,mc,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");mc=class e{static{a(this,"DatabaseTransaction")}writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxnsUsed=1,this.readTxn.openTimer&&(this.readTxn.openTimer=0),PR.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(PR.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(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 mc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,MR.getNextMonotonicTime)())}getReadTxn(){}},K9=3e4;a(W9,"startMonitoringTxns");W9()});function Dt(e,t,r){if(!t)t=e,e={};else if(!e)e={};else if(e?.transaction?.open===1&&typeof t=="function")return t(e.transaction);if(typeof t!="function")throw new Error("Callback function must be provided to transaction");let n=e.transaction=new mc;e.timestamp&&(n.timestamp=e.timestamp),e.replicatedConfirmation&&(n.replicatedConfirmation=e.replicatedConfirmation),n[Fe]=e,e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var yv,Sc=Ie(()=>{yv=L(Ei());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=Oi(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 Oi(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(Wl()),Ks=L(_e());Pe();Cv=L(E_()),Ys=L(M()),UR=L(no()),vR=L(qs()),Dv=L(te());Sc();_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=Oi(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 Oi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Oi(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){Oi(t).dropTable()}createSchema(t){return Ql({database:t.schema,table:null}),UR.signalSchemaChange(new vR.SchemaEventMsg(process.pid,Ys.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await xR(t.schema),UR.signalSchemaChange(new vR.SchemaEventMsg(process.pid,Ys.OPERATIONS_ENUM.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,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=Oi(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=Oi(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){Oi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Oi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=Oi(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(Oi,"getTable");a(Nv,"createDeleteResponse");a(Iv,"groupRecordsInHistory")});var Bn=N((fOe,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((hOe,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((mOe,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((TOe,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((AOe,Vv)=>{var Tc=Hv(),Gn=kv(),Ni=$v();Vv.exports=e=>{e.aggr.mad=e.aggr.MAD=Tc.mad,e.aggr.mean=e.aggr.MEAN=Tc.mean,e.aggr.mode=e.aggr.MODE=Tc.mode,e.aggr.prod=e.aggr.PROD=Tc.prod,e.aggr.median=e.aggr.MEDIAN=Tc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Tc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Tc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Gn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Gn.current_time,e.fn.extract=e.fn.EXTRACT=Gn.extract,e.fn.date=e.fn.DATE=Gn.date,e.fn.date_format=e.fn.DATE_FORMAT=Gn.date_format,e.fn.date_add=e.fn.DATE_ADD=Gn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Gn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Gn.date_diff,e.fn.now=e.fn.NOW=Gn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Gn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Gn.get_server_time,e.fn.getdate=e.fn.GETDATE=Gn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Gn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Ni.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Ni.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Ni.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Ni.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Ni.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Ni.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Ni.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Ni.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Ni.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Ni.geoNear}});var jv=N((ROe,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(),Jl=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 Jl.getDataByHash(c);for(let _ of c.hash_values)d.get(_)&&!this.data[i].__merged_data[_]&&(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_))}catch(d){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(d),new Error(Ws)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async d=>{let _={...c};_.search_value=d;let E=await Jl.getDataByValue(_);for(let[f,h]of E)this.data[i].__merged_data[f]?this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]):(this.data[i].__merged_data[f]=[...n[i]],this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,f))}))}catch(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(d),new Error(Ws)}else if(!et.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!et.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let d=this.comparator_search_values[u].comparators;for(let _=0,E=d.length;_<E;_++){let f=d[_];c.search_attribute=f.attribute,c.search_value=f.search_value;let h=await Jl.getDataByValue(c,f.operation);if(l)for(let[T]of h)this.data[i].__merged_data[T]||(this.data[i].__merged_data[T]=[...n[i]],this._setMergedHashAttribute(i,T));else for(let[T,m]of h)this.data[i].__merged_data[T]?this._updateMergedAttribute(i,T,s.attribute,m[s.attribute]):(this.data[i].__merged_data[T]=[...n[i]],this._updateMergedAttribute(i,T,s.attribute,m[s.attribute]),this._setMergedHashAttribute(i,T))}}catch(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),Ue.error(d),new Error(Ws)}else try{c.search_attribute=s.attribute,c.search_value="*";let d=await Jl.getDataByValue(c);if(l)for(let[_]of d)this.data[i].__merged_data[_]||(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_));else for(let[_,E]of d)this.data[i].__merged_data[_]?this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]):(this.data[i].__merged_data[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]),this._setMergedHashAttribute(i,_))}catch(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),Ue.error(d),new Error(Ws)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof _n.yy.Column||(t=!1)}),t)}_updateOrderByToAliases(){this.statement.order.forEach(t=>{if(t.expression.aggregatorid){t.is_aggregator=!0;return}if(t.expression.value){t.is_ordinal=!0,this.has_ordinal=!0;return}else t.is_ordinal=!1;let r=this.statement.columns.filter(s=>{let i=s.aggregatorid?s.expression:s,o=s.aggregatorid?s.as_orig:i.as_orig;return t.expression.tableid?i.columnid_orig===t.expression.columnid_orig&&i.tableid_orig===t.expression.tableid_orig:i.columnid_orig===t.expression.columnid_orig||t.expression.columnid_orig===o});r[0]||r.push(this._findColumn(t.expression));let n=r[0];if(t.is_func=!!n.funcid,t.is_aggregator=!!n.aggregatorid,n.as)if(n.as&&!t.expression.tableid)t.expression.columnid=n.as,t.expression.columnid_orig=n.as_orig;else{let s=new _n.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new _n.yy.Column,t.expression),t.initial_select_column.as=`[${t.expression.columnid_orig}]`,t.expression.columnid=t.initial_select_column.as;return}if(!t.is_aggregator){let s=t.is_func?new _n.yy.FuncValue:new _n.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(f=>{f.joinmode&&f.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(f.table);let h=f.joinmode+" JOIN ? AS "+(f.as?f.as:f.table.tableid);f.on&&(h+=" ON "+f.on.toString()),i.push(h),t.push(Object.values(this.data[`${f.table.databaseid_orig}_${f.table.as?f.table.as_orig:f.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(f=>{let h=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__hash_name,T=f.as?f.as_orig:f.tableid_orig;o.push({key:`'${T}.${h}'`,schema:f.databaseid_orig,table:f.as?f.as_orig:f.tableid_orig,keys:new Set}),r.push(`${f.as?f.as:f.tableid}.\`${h}\` AS "${T}.${h}"`),c[f.as?f.as_orig:f.tableid_orig]=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let u="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(u="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(f=>{f.is_func?r.push(f.initial_select_column.toString()):f.initial_select_column.tableid?r.push(`${f.initial_select_column.tableid}.${f.initial_select_column.columnid} AS ${f.expression.columnid}`):r.push(`${f.initial_select_column.columnid} AS ${f.expression.columnid}`)}));let d="",_="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(d=this.statement.limit?"LIMIT "+this.statement.limit:"",_=this.statement.offset?"OFFSET "+this.statement.offset:"");let E=[];try{let f=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${u} ${d} ${_}`,h=this._convertColumnsToIndexes(f,s);E=await _n.promise(h,t),t=null}catch(f){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),Ue.error(f),new Error("There was a problem processing the data.")}if(E&&E.length>0){for(let f=0,h=E.length;f<h;f++){let T=E[f];o.forEach(m=>{T[m.key]!==null&&T[m.key]!==void 0&&m.keys.add(T[m.key])})}o.forEach(f=>{let h=Object.keys(this.data[`${f.schema}_${f.table}`].__merged_data),T=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 Jl.getDataByHash(c),u=s.columns.length;for(let d=0,_=o.length;d<_;d++){let E=o[d],f=l.get(E);for(let h=0;h<u;h++){let T=s.columns[h],m=f[T]===void 0?null:f[T];this.data[n].__merged_data[E].push(m)}}}}catch(r){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getData."),Ue.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__merged_data)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,l=o.aggregatorid?o.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===l}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();Ue.trace(`Final SQL: ${s}`),n=await _n.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),Ue.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),Ue.error(s),new Error("There was a problem running the generated sql.")}return n}_translateUndefinedValues(t){try{let r=[];for(let n of t){let s=Object.create(null);Object.keys(n).forEach(i=>{n[i]===void 0?s[i]=null:s[i]=n[i]}),r.push(s)}return r}catch(r){return Ue.error(y7.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),Ue.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],u=new RegExp(`${l}.\`${o}\``,"g"),d=`${l}.[${c}]`;n=n.replace(u,d)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),u=`[${c}]`;n=n.replace(l,u)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await Jl.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]={...r[s]}),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw Ue.error("There was an error when processing this SQL operation. Check your logs"),Ue.error(o),new Error(Ws)}}return Object.values(Object.values(this.data)[0].__merged_data)}};Wv.exports=FR});var Vr=N((bOe,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((NOe,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((COe,Zv)=>{"use strict";var M7=Vr(),U7=us(),Jv=W(),v7=un(),wOe=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((MOe,t0)=>{var Y7=require("alasql"),W7=Vr(),j7=W(),z7=Bn(),YR=require("util"),KR=te(),Q7=M(),J7=us(),POe=pp(),LOe=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((vOe,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 Xl=N((HOe,aee)=>{aee.exports={name:"harperdb",version:"4.4.26",description:"HarperDB is a distributed database, caching service, streaming broker, and application development platform focused on performance and ease of use.",keywords:["database","nosql","api","distributed","broker","mqtt","real-time","enterprise","Fastify","NATS","HarperDB","Harper","clustering","replication","REST","WebSockets","decentralized","server-sent events","document store"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{"minimum-node":"16.0.0","go-lang":"1.21.7","nats-server":"2.10.11"},exports:{".":"./index.js"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"SEE LICENSE IN LICENSE",scripts:{submodules:"git submodule update --init --recursive","cover:test":"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && nyc --no-clean --reporter=lcovonly npm run test:replication && nyc --no-clean --reporter=lcovonly npm run test:apitests && nyc --no-clean --reporter=lcovonly npm run test:resources && nyc --no-clean --reporter=lcovonly npm run test:logging && nyc --no-clean --reporter=lcovonly npm run test:upgrade && nyc --no-clean --reporter=lcovonly npm run test:nats && nyc --no-clean --reporter=lcovonly npm run test:cfserver && nyc --no-clean --reporter=lcovonly npm run test:hdbserver && nyc --no-clean --reporter=lcovonly npm run test:bin && nyc --no-clean --reporter=lcovonly npm run test:main && nyc --no-clean --reporter=lcovonly npm run test:security && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license",test:"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && npm run test:replication && npm run test:apitests && npm run test:resources && npm run test:logging && npm run test:upgrade && npm run test:nats && npm run test:cfserver && npm run test:hdbserver && npm run test:bin && npm run test:main && npm run test:security && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license","test:resources":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/resources/**/*.js' --config '../unitTests/.mocharc.json'","test:bin":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/bin/**/*.js' --config '../unitTests/.mocharc.json'","test:main":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","test:lmdbbridge":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --config '../unitTests/.mocharc.json'","test:lmdbutility":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --config '../unitTests/.mocharc.json'","test:hdbserver":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --config '../unitTests/.mocharc.json'","test:cfserver":"npm run submodules && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/fastifyRoutes/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","test:nats":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","test:upgrade":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --config '../unitTests/.mocharc.json'","test:apitests":"pm2 kill && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/apiTests/**/*-test.mjs' --config '../unitTests/.mocharc.json'","test:logging":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/logging/*.js' --config '../unitTests/.mocharc.json'","test:ci":" cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --retries 3 --config '../unitTests/.mocharc-main.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter","test:security":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/security/**/*.js' --config '../unitTests/.mocharc.json'","test:replication":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/replication/**/*.js' --config '../unitTests/.mocharc.json'","hdb-check":"./utility/devops/hdb-check.sh","download-prebuilds":"node ./utility/devops/build/download-prebuilds.js",prebuild:"date",postinstall:"node ./launchServiceScripts/launchInstallNATSServer.js",build_nats_dependency:"node ./utility/devops/nats/builder.js",coverage:"nyc --reporter=lcov npm test",format:"prettier .","format:fix":"npm run format -- --write",lint:"eslint .","lint:fix":"npm run lint -- --fix"},dependencies:{"@aws-sdk/client-s3":"3.717.0","@aws-sdk/lib-storage":"3.717.0","@endo/static-module-record":"^1.0.4","@fastify/autoload":"5.10.0","@fastify/compress":"~6.5.0","@fastify/cors":"~9.0.1","@fastify/static":"~7.0.4","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"4.1.10","cbor-x":"1.6.0",chalk:"4.1.2",chokidar:"^4.0.3","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.2",fastify:"~4.29.0","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.10.0","gunzip-maybe":"1.4.2","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.12.2","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.7",jsonwebtoken:"9.0.2",lmdb:"3.2.6",lodash:"4.17.21",mathjs:"11.12.0",minimist:"1.2.8",moment:"2.30.1","mqtt-packet":"~9.0.0",msgpackr:"1.11.2",nats:"2.19.0",needle:"3.3.1","node-forge":"^1.3.1","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.3",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.4.1",prompt:"1.3.0","properties-reader":"2.3.0","recursive-iterator":"3.3.0",semver:"7.5.4",send:"^1.1.0","serve-static":"2.1.0",ses:"1.1.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.24.5","tar-fs":"3.0.6",ulidx:"0.5.0",uuid:"10.0.0","validate.js":"0.13.1",ws:"8.18.0",yaml:"2.7.0"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"20.14.8","@typescript-eslint/eslint-plugin":"^7.18.0","@typescript-eslint/parser":"^7.18.0",axios:"1.7.5",chai:"4.4.1","chai-integer":"0.1.0",esbuild:"^0.24.2",eslint:"^8.57.1","eslint-config-prettier":"^9.1.0","eslint-plugin-sonarjs":"^3.0.1",eventsource:"^2.0.2","graphql-http":"^1.22.3","hook-std":"3.0.0","intercept-stdout":"0.1.2",mkcert:"1.5.1",mocha:"^11.0.1","mocha-teamcity-reporter":"^4.2.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.8",newman:"6.1.3","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"3.3.3",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0","source-map-support":"^0.5.21",typescript:"^5.7.2",undici:"^6.19.8","why-is-node-still-running":"^1.0.0"},overrides:{alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","segfault-handler":"^1.3.0","utf-8-validate":"^5.0.10"}}});var 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:gc.threadId,metrics:t};for(let[s,i]of Tp){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,u=[],d;for(let _ of 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:gc.threadId,byThread:!0,...n});for(let s of T0)s(t);Tp=new Map,gc.parentPort?gc.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 y of g||[]){let{path:I,method:U,type:H,metric:X,count:Y,total:V,distribution:ne,threads:Q,...de}=y;Y||(Y=1);let j=X+(I?"-"+I:"");U!==void 0&&(j+="-"+U),H!==void 0&&(j+="-"+H);let ae=c.get(j);if(ae){if(ae.threads){let Ne=ae.threads[S];if(Ne)ae=Ne;else{ae.threads[S]={...de};continue}}ae.count||(ae.count=1);let Oe=ae.count;for(let Ne in de){let Me=de[Ne];typeof Me=="number"&&(ae[Ne]=(ae[Ne]*Oe+Me*Y)/(Oe+Y))}ae.count+=Y,V>=0&&(ae.total+=V,ae.ratio=ae.total/ae.count)}else ae={period:t,...y},delete ae.distribution,c.set(j,ae),ae.byThread&&(ae.threads=[],ae.threads[S]={...de},u.push(ae));if(ne){ne=ne.map(Ne=>typeof Ne=="number"?{value:Ne,count:1}:Ne);let Oe=l.get(j);Oe?Oe.push(...ne):l.set(j,ne)}}await A0()}for(let T of u){let{path:m,method:g,type:S,metric:y,count:I,total:U,distribution:H,threads:X,...Y}=T;X=X.filter(V=>V);for(let V in Y){if(typeof T[V]!="number")continue;let ne=0;for(let Q of X){let de=Q[V];typeof de=="number"&&(ne+=de)}T[V]=ne}T.count=X.length,delete T.threads,delete T.byThread}for(let[T,m]of l){let g=c.get(T);m.sort((Ne,Me)=>Ne.value>Me.value?1:-1);let S=g.count-1,y=[],I=0,U=0,H;for(let Ne of g0){let Me=S*Ne;for(;I<Me;)H=m[U++],I+=H.count,U===1&&I--;let Gr=m[U>1?U-2:0];H||(H=m[0]),y.push(H.value-(H.value-Gr.value)*(I-Me)/H.count)}let[X,Y,V,ne,Q,de,j,ae,Oe]=y;Object.assign(g,{p1:X,p10:Y,p25:V,median:ne,p75:Q,p90:de,p95:j,p99:ae,p999:Oe})}let _;for(let[T,m]of c)m.id=(0,Sp.getNextMonotonicTime)(),m.time=d,n.primaryStore.put(m.id,m,{append:!0}).then(g=>{g||n.primaryStore.put(m.id,m)}),_=!0;let E=Date.now(),{idle:f,active:h}=performance.eventLoopUtilization();if(_||h*10>f){let T=(0,Sp.getNextMonotonicTime)(),m={id:T,metric:"main-thread-utilization",idle:f-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||gc.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 gc,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,Ii=Ie(()=>{gc=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((QOe,H0)=>{"use strict";var{decode:mee}=require("msgpackr"),{isMainThread:WOe,parentPort:jOe,threadId:zOe}=require("worker_threads"),Rp=mr(),Zl=Ct(),XR=M(),jr=W(),JR=se(),See=M(),{onMessageByType:Tee}=dt(),C0=to(),{recordAction:N0,recordActionBinary:gee}=(Ii(),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,eu=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")),eu.get(e.node_domain_name)==="failed"&&eu.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+Zl.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(eu.get(e)==="close")break;eu.set(e,"failed"),n%10===1&&jr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<yp?n++*100:yp;await 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(eu.get(n)==="close")break;o%10===1&&jr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",u.message),u.code==="404"&&(jr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await Rp.createConsumer(r,e,Ap,new Date(Date.now()).toISOString()));let d=o++*100<yp?o++*100:yp;await D0(d)}let c=!1,l;for(;!c;){if(G_.get(e+n)==="close"||eu.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(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&&!v0),gee(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(Zl.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:u,records:d,hash_values:_,__origin:E,expiresAt:f}=t;jr.trace("processing message:",o,c,u,(d?"records: "+d.map(U=>U?.id):"")+(_?"ids: "+_:""),"with sequence:",e.seq),jr.trace(`messageProcessor nats msg id: ${e.headers.get(Zl.MSG_HEADERS.NATS_MSG_ID)}`);let h;d||(d=_);let T=new Promise(U=>h=U),{timestamp:m,user:g,node_name:S}=E||{},y=Op.get(c)?.get(u);if(!y)throw new Error(`Missing table for replication message: ${u}`);if(o==="define_schema")t.type=o,t.onCommit=h,y.send(t);else if(d.length===1&&!l)y.send({type:QR(o),value:d[0],id:_?.[0],expiresAt:f,timestamp:m,table:u,onCommit:h,user:g,nodeName:S});else{let U=d.map((H,X)=>({type:QR(o),value:H,expiresAt:f,id:_?.[X],table:u}));for(;l;)U.push({type:QR(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;y.send({type:"transaction",writes:U,table:u,timestamp:m,onCommit:h,user:g,nodeName:S})}JR.get(See.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&Aee(e.subject.split(".").slice(0,-1).join("."),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((nNe,eB)=>{"use strict";var Or=se();Or.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:bc}=Np,$0=xn(),XOe=48*36e11;G0&&kee(Je.ITC_EVENT_TYPES.RESTART,()=>{zr=void 0,yc=void 0});var{connect:qee,StorageType:$ee,RetentionPolicy:Vee,AckPolicy:iy,DeliverPolicy:oy,DiscardPolicy:Kee,NatsConnection:ZOe,JetStreamManager:eNe,JetStreamClient:tNe,StringCodec:rNe,JSONCodec:Yee,createInbox:ay,headers:Wee,ErrorCode:x0}=require("nats"),{PACKAGE_ROOT:jee}=M(),zee=Xl(),{recordAction:Qee}=(Ii(),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,$_,Ac,Rc;eB.exports={runCommand:K0,checkNATSServerInstalled:ete,createConnection:cy,getConnection:K_,getJetStreamManager:Y_,getJetStream:W0,getNATSReferences:wi,getServerList:rte,createLocalStream:ly,listStreams:j0,deleteLocalStream:nte,getServerConfig:tu,listRemoteStreams:ste,viewStream:ite,viewStreamIterator:ote,publishToStream:ate,request:ute,reloadNATS:uy,reloadNATSHub:dte,reloadNATSLeaf:_te,extractServerName:lte,requestErrorHandler:fte,createLocalTableStream: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 ete(){try{await Pee.access(ny)}catch{return!1}let e=await V0(`${ny} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return Lee.eq(t,Xee)}a(ete,"checkNATSServerInstalled");async function cy(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await q0.getClusterUser();if(bc(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}js.trace("create nats connection called");let i=await qee({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:Or.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:Or.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:Or.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),js.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&js.error("Error with Nats client connection, connection closed",o),i===zr&&K0()}),i}a(cy,"createConnection");function K0(){zr=void 0,Ac=void 0,Rc=void 0,yc=void 0}a(K0,"clearClientCache");async function tte(){zr&&(await zr.drain(),zr=void 0,Ac=void 0,Rc=void 0,yc=void 0)}a(tte,"closeConnection");var zr,yc;async function V_(){return yc||(yc=cy(Or.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),zr=await yc),zr||yc}a(V_,"getConnection");async function K_(){if(Ac)return Ac;bc(zr)&&await V_();let{domain:e}=tu(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(bc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Ac=await zr.jetstreamManager({domain:e,timeout:6e4}),Ac}a(K_,"getJetStreamManager");async function Y0(){if(Rc)return Rc;bc(zr)&&await V_();let{domain:e}=tu(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(bc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Rc=zr.jetstream({domain:e,timeout:6e4}),Rc}a(Y0,"getJetStream");async function wi(){let e=zr||await V_(),t=Ac||await K_(),r=Rc||await Y0();return{connection:e,jsm:t,js:r}}a(wi,"getNATSReferences");async function rte(e){let t=Or.get(Je.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await q0.getClusterUser(),s=await cy(t,r,n),i=ay(),o=s.subscribe(i),c=[],l,u=(async()=>{for await(let d of o){let _=$0.decode(d.data);_.response_time=Date.now()-l,c.push(_)}})();return l=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await Np.async_set_timeout(e),await o.drain(),await s.close(),await u,c}a(rte,"getServerList");async function ly(e,t){let{jsm:r}=await wi(),n=Or.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Or.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=Or.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:$ee.File,retention:Vee.Limits,subjects:t,discard:Kee.Old,max_msgs:s,max_bytes:i,max_age:n})}a(ly,"createLocalStream");async function W0(){let{jsm:e}=await wi(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(W0,"listStreams");async function nte(e){let{jsm:t}=await wi();await t.streams.delete(e)}a(nte,"deleteLocalStream");async function ste(e){let{connection:t}=await wi(),r=[],n=ay(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push($0.decode(o.data))})();return await t.publish(`$JS.${e}.API.STREAM.LIST`,void 0,{reply:n}),await t.flush(),await s.drain(),await i,r}a(ste,"listRemoteStreams");async function ite(e,t=void 0,r=void 0){let{jsm:n,js:s}=await wi(),i=x0(),o={durable_name:i,ack_policy:iy.Explicit};t&&(o.deliver_policy=oy.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let u=[];for await(let d of l){let _=sy(d.data),E={nats_timestamp:d.info.timestampNanos,nats_sequence:d.info.streamSequence,entry:_};if(d.headers&&(E.origin=d.headers.get(Dr.MSG_HEADERS.ORIGIN)),u.push(E),d.ack(),d.info.pending===0)break}return await c.delete(),u}a(ite,"viewStream");async function*ote(e,t=void 0,r=void 0){let{jsm:n,js:s}=await wi(),i=x0(),o={durable_name:i,ack_policy:iy.Explicit};t&&(o.deliver_policy=oy.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let u of l){let d=sy(u.data);d[0]||(d=[d]);for(let _ of d){let E={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:_};u.headers&&(E.origin=u.headers.get(Dr.MSG_HEADERS.ORIGIN)),yield E}if(u.ack(),u.info.pending===0)break}await c.delete()}a(ote,"viewStreamIterator");async function ate(e,t,r,n){js.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=j0(n,r);let{js:s}=await wi(),i=await wp(),o=`${e}.${i}`,c=n instanceof Uint8Array?n:G0.encode(n);try{js.trace(`publishToStream publishing to subject: ${o}`),Qee(c.length,"bytes-sent",e,n.operation,"replication"),await s.publish(o,c,{headers:r})}catch(l){if(l.code&&l.code.toString()==="503")return Q0(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){js.trace(`publishToStream creating stream: ${t}`);let d=o.split(".");d[2]="*",await ly(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(ate,"publishToStream");function j0(e,t){t===void 0&&(t=Wee());let r=Or.get(Je.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Dr.MSG_HEADERS.ORIGIN)&&r&&t.append(Dr.MSG_HEADERS.ORIGIN,r),t}a(j0,"addNatsMsgHeader");function tu(e){e=e.toLowerCase();let t=$_.join(Or.get(Je.CONFIG_PARAMS.ROOTPATH),Jee);if(e===Je.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return bc(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 bc(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(tu,"getServerConfig");async function z0(e,t,r,n){try{await e.consumers.add(t,{ack_policy:iy.Explicit,durable_name:r,deliver_policy:oy.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(z0,"createConsumer");async function cte(e,t,r){await e.consumers.delete(t,r)}a(cte,"removeConsumer");function lte(e){return e.split(".")[1]}a(lte,"extractServerName");async function ute(e,t,r=6e4,n=ay()){if(!Np.isObject(t))throw new Error("data param must be an object");let s=G0.encode(t),{connection:i}=await wi(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return sy(c.data)}a(ute,"request");function uy(e){return new Promise(async(t,r)=>{let n=Bee(ny,["--signal",`reload=${e}`],{cwd:__dirname}),s,i;n.on("error",o=>{r(o)}),n.stdout.on("data",o=>{i+=o.toString()}),n.stderr.on("data",o=>{s+=o.toString()}),n.stderr.on("close",o=>{s&&r(s),t(i)})})}a(uy,"reloadNATS");async function dte(){let{pid_file_path:e}=tu(Je.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await uy(e)}a(dte,"reloadNATSHub");async function _te(){let{pid_file_path:e}=tu(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await uy(e)}a(_te,"reloadNATSLeaf");function fte(e,t,r){let n;switch(e.code){case H0.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case H0.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(fte,"requestErrorHandler");async function Ete(e,t){let r=t+Dr.SERVER_SUFFIX.LEAF,{connection:n}=await wi(),{jsm:s}=await Rte(r),{schema:i,table:o}=e,c=Ip.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await Q0(async()=>{if(e.subscribe===!0)await z0(s,c,n.info.server_name,l);else try{await cte(s,c,n.info.server_name)}catch(u){js.trace(u)}})}a(Ete,"updateRemoteConsumer");async function hte(e,t,r,n){let s=Ip.createNatsTableStreamName(e,t),i=r+Dr.SERVER_SUFFIX.LEAF,o={type:Je.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!F0&&Fee()<Or.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=ey();await c(o)}await xee(o),n==="stop"&&await Np.async_set_timeout(1e3)}a(hte,"updateConsumerIterator");function Q0(e){return Hee.writeTransaction(Je.SYSTEM_SCHEMA_NAME,Je.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(Q0,"exclusiveLock");async function J0(e,t){let r=Ip.createNatsTableStreamName(e,t),n=await wp(),s=Tte(e,t,n);await ly(r,[s])}a(J0,"createLocalTableStream");async function pte(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await J0(n,s)}}a(pte,"createTableStreams");async function X0(e,t,r=void 0){if(Or.get(Je.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=Ip.createNatsTableStreamName(e,t),{domain:s}=tu(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 mte(e,t){if(Or.get(Je.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await X0(e,t[r])}a(mte,"purgeSchemaTableStreams");async function Ste(e){return(await K_()).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(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 gte(){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=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=Or.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Or.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=Or.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}a(Ate,"updateStreamLimits");async function Rte(e){let t,r;try{t=await zr.jetstream({domain:e}),r=await zr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw js.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(Rte,"connectToRemoteJS")});var Oc=N(Dp=>{var Cp=W();for(let e of["trace","debug","info","warn","error","fatal","notify"])Cp.logsAtLevel(e)&&(Dp[e]=Cp[e]);Dp.loggerWithTag=e=>Cp.loggerWithTag(e,!0);Dp.setLogLevel=Cp.setLogLevel});function dy(e){let t=e.get(Pp),r=t?(0,ru.unpack)(t):null;r||(r={remoteNameToId:{}});let n=ot(),s=!1;r.nodeName=ot();let i=r.remoteNameToId;if(i[n]!==0){let o=0,c;for(let l in i){let u=i[l];u===0?c=l:u>o&&(o=u)}if(c){o++,i[c]=o;let l=[Symbol.for("seq"),o];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:W_(e)??1,nodes:[]})})}i[n]=0,e.putSync(Pp,(0,ru.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,ru.pack)(n)),i}function Lp(e,t){let r=dy(t),n=r.remoteNameToId,s=n[e];if(s==null){let i=0;for(let o in n){let c=n[o];c>i&&(i=c)}s=i+1,n[e]=s,t.putSync(Pp,(0,ru.pack)(r))}return eB.info?.("The remote node name map",e,n,s),s}var eB,ru,Pp,_y=Ie(()=>{eB=L(Oc());ds();ru=require("msgpackr"),Pp=Symbol.for("remote-ids");a(dy,"getIdMappingRecord");a(Y_,"exportIdMapping");a(tB,"remoteToLocalNodeId");a(Lp,"getIdOfRemoteNode")});var ea,fy=Ie(()=>{ea=class{constructor(t){this.error=t}static{a(this,"ErrorResource")}isError=!0;allowRead(){throw this.error}allowUpdate(){throw this.error}allowCreate(){throw this.error}allowDelete(){throw this.error}getId(){throw this.error}getContext(){throw this.error}get(){throw this.error}post(){throw this.error}put(){throw this.error}delete(){throw this.error}connect(){throw this.error}getResource(){return this}publish(){throw this.error}subscribe(){throw this.error}}});var sB={};je(sB,{Resources:()=>Mp,keyArrayToString:()=>nu,resetResources:()=>yte,resources:()=>Ci});function yte(){return Ci=new Mp}function nu(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var rB,nB,Mp,Ci,su=Ie(()=>{Sc();fy();rB=L(W()),nB=L(_e()),Mp=class extends Map{static{a(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,exportTypes:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s){let c=new nB.ServerError(`Conflicting paths for ${t}`);rB.default.error(c),i.Resource=new ea(c)}super.set(t,i);for(let[c,l]of this){let u=2;for(;(u=c.indexOf("/",u))>-1;){let d=this.get(c.slice(0,u));d&&(d.hasSubPaths=!0),u+=2}}}getMatch(t,r){let n=2,s;for(;(n=t.indexOf("/",n))>-1;){let c=t.slice(0,n),l=this.get(c);if(!l&&c.indexOf(".")>-1){let u=c.split(".");l=this.get(u[0])}if(l&&(!r||l.exportTypes?.[r]!==!1)){if(l.relativeURL=t.slice(n),!l.hasSubPaths)return l;s=l}n+=2}if(s)return s;let i=t.indexOf("?"),o=i>-1?t.slice(0,i):t;return s=this.get(o),!s&&o.indexOf(".")>-1&&(s=this.get(o.split(".")[0])),s&&(!r||s.exportTypes?.[r]!==!1)?s.relativeURL=i>-1?t.slice(i):"":s||(s=this.get(""),s&&(!r||s.exportTypes?.[r]!==!1)&&(t[0]!=="/"&&(t="/"+t),s.relativeURL=t)),s}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return Dt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(yte,"resetResources");a(nu,"keyArrayToString")});function py(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=oB,bte(e.primaryStore,e.auditStore)):(c=iB,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{aB(iB[i])})));let l=c[i]||(c[i]=[]);if(l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now()),s?.scope==="full-database")return;let u=l[o];u||(u=l[o]=new Map,u.envs=l,u.tableId=o,u.store=e.primaryStore),t=nu(t);let d=new hy(r);d.startTime=n;let _=u.get(t);return _?_.push(d):(u.set(t,_=[d]),_.tables=u,_.key=t),d.subscriptions=_,d}function aB(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),cB(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=xt(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,l=nu(c),u=0;do{let d=o.get(l);if(d){for(let E of d)if(!(u>0&&!(E.includeDescendants&&!(E.onlyChildren&&u>1)))){if(E.startTime>=n){(0,Ey.info)("omitting",c,E.startTime,n);continue}try{let f;E.supportsTransactions&&E.txnInProgress!==i.version&&(f=!0,E.txnInProgress||(r?r.push(E):r=[E]),E.txnInProgress=i.version),E.listener(c,i,n,f)}catch(f){console.error(f),(0,Ey.info)(f)}}}if(l==null)break;let _=l.lastIndexOf?.("/",l.length-2);_!==l.length-1&&u++,_>-1?l=l.slice(0,_+1):l=null}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function bte(e,t){let r=t||e,n=r.env;if(!n.hasAfterCommitListener){n.hasAfterCommitListener=!0;let s=n.path;r.on("aftercommit",({next:i,last:o,txnId:c})=>{let l=oB[s];if(!l)return;let u=a(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),l.txnTime=r.threadLocalWrites[0]||Date.now();try{aB(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function cB(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function lB(e){return e.nextTransaction||(py({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),cB(e)),e.nextTransaction}var Ey,iB,oB,hy,my=Ie(()=>{Ey=L(W());Ll();su();Ji();iB=Object.create(null),oB=Object.create(null);a(py,"addSubscription");hy=class extends Mn{static{a(this,"Subscription")}listener;subscriptions;startTime;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;if(t){let r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};a(aB,"notifyFromTransactionData");a(bte,"listenToCommits");a(cB,"nextTransaction");a(lB,"whenNextTransaction")});var hB={};je(hB,{commits_awaiting_replication:()=>au,getHDBNodeTable:()=>Sr,iterateRoutes:()=>z_,shouldReplicateToNode:()=>j_,subscribeToNodeUpdates:()=>cu});function Sr(){return uB||(uB=Et({table:"hdb_nodes",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"ca"},{attribute:"ca_info"},{attribute:"replicates"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function cu(e){Sr().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;EB.debug?.("adding node",n,"on node",ot()," on process",process.pid),server.nodes=server.nodes.filter(s=>s.name!==n),r.type==="put"&&n!==ot()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r)),(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function 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 Ote(){cu(e=>{ta({},(t,r)=>{let n=e.name,s=dB.get(n);if(s||dB.set(n,s=new Map),s.has(r))return;let i;for(let o in t)if(i=t[o].auditStore,i)break;if(i){let o=new Float64Array(i.getUserSharedBuffer(["replicated",r,n],new ArrayBuffer(8),{callback:a(()=>{let c=o[0],l=o.lastTime;for(let{txnTime:u,onConfirm:d}of au.get(r)||[])u>l&&u<=c&&d();o.lastTime=c},"callback")}));o.lastTime=0,s.set(r,o)}})})}function*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=iu.default.get(ou.CONFIG_PARAMS.REPLICATION_SECUREPORT)??(!iu.default.get(ou.CONFIG_PARAMS.REPLICATION_PORT)&&iu.default.get(ou.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||iu.default.get(ou.CONFIG_PARAMS.REPLICATION_PORT)||iu.default.get(ou.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT);let o=i?.lastIndexOf?.(":");o>0&&(i=+i.slice(o+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){_B.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{replicates:!t.subscriptions,url:r,subscription:t.subscriptions,routes:t.routes,start_time:t.startTime}}}var _B,fB,iu,ou,EB,uB,dB,au,lu=Ie(()=>{Pe();ds();lp();_B=require("worker_threads"),fB=L(_e()),iu=L(se()),ou=L(M()),EB=L(Oc());server.nodes=[];a(Sr,"getHDBNodeTable");a(cu,"subscribeToNodeUpdates");a(j_,"shouldReplicateToNode");dB=new Map;Av((e,t,r)=>{if(r>server.nodes.length)throw new fB.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);au||(au=new Map,Ote());let n=au.get(e);return n||(n=[],au.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(Ote,"startSubscriptionToReplications");a(z_,"iterateRoutes")});var gB={};je(gB,{connectedToNode:()=>Nc,disconnectedFromNode:()=>_u,ensureNode:()=>co,requestClusterStatus:()=>TB,startOnMainThread:()=>Ty});async function Ty(e){let t=0,r=ut();for(let i of Object.getOwnPropertyNames(r)){let o=r[i];for(let c in o){let l=o[c];if(l.auditStore){Up.set(i,W_(l.auditStore));break}}}Di.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??ra(),replicates:!0})}let l=o.trusted!==!1;if(c&&o.replicates==null&&(o.replicates=!0),i.find(u=>u.url===o.url))continue;s(o)}catch(c){console.error(c)}cu(s)});let n;function s(i,o=i?.name){let c=ot()&&o===ot()||ra()&&i?.url===ra();if(c){let _=!!i?.replicates;if(n!==void 0&&n!==_)for(let E of Sr().search([]))E.replicates&&E.name!==o&&s(E,E.name);n=_}if(_t.trace("Setting up node replication for",i),!i){for(let[_,E]of ao){let f;for(let[h,{worker:T,nodes:m}]of E){let g=m[0];if(g&&g.name==o){f=!0;for(let[S,{worker:y}]of E)E.delete(S),_t.warn("Node was deleted, unsubscribing from node",o,S,_),y?.postMessage({type:"unsubscribe-from-node",node:o,database:S,url:_});break}}if(f){ao.get(_).iterator.remove(),ao.delete(_);return}}return}if(c)return;if(!i.url){_t.info(`Node ${i.name} is missing url`);return}let l=ao.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(_t.info(`Added node ${i.name} at ${i.url} for process ${ot()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[_,E]of uu)if(i.url===E.url){uu.delete(_);break}uu.set(i.name,i)}let u=ut();if(l||(l=new Map,ao.set(i.url,l)),l.iterator=ta(e,(_,E,f)=>{f?d(E,!0):d(E,!1)}),i.subscriptions)for(let _ of i.subscriptions){let E=_.database||_.schema;u[E]||(_t.warn(`Database ${E} not found for node ${i.name}, making a subscription anyway`),d(E,!1))}function d(_,E){_t.trace("Setting up replication for database",_,"on node",i.name);let f=l.get(_),h,T=[{replicateByDefault:E,...i}];Up.has(_)&&(T.push({replicateByDefault:E,name:ot(),start_time:Up.get(_),end_time:Date.now(),replicates:!0}),Up.delete(_));let m=j_(i,_),g=Di.workers.filter(S=>S.name==="http");if(f?(h=f.worker,f.nodes=T):m&&(t=t%g.length,h=g[t++],l.set(_,{worker:h,nodes:T,url:i.url}),h?.on("exit",()=>{l.get(_)?.worker===h&&(l.delete(_),d(_,E))})),m)setTimeout(()=>{let S={type:"subscribe-to-node",database:_,nodes:T};h?h.postMessage(S):du(S)},Nte);else{_t.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[_],Sr().primaryStore.get(ot())?.replicates),Sr().primaryStore.get(ot())?.replicates||(n=!1);let S={type:"unsubscribe-from-node",database:_,url:i.url,name:i.name};h?h.postMessage(S):Bp(S)}}a(d,"onDatabase")}a(s,"onNodeUpdate"),_u=a(function(i){try{_t.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(uu.keys()),c=o.sort(),l=c.indexOf(i.name||zs(i.url));if(l===-1){_t.warn("Disconnected node not found in node map",i.name,o);return}let u=ao.get(i.url),d=u?.get(i.database);if(!d){_t.warn("Disconnected node not found in replication map",i.database,u);return}if(d.connected=!1,i.finished)return;let _=d.nodes[0];if(!(_.replicates===!0||_.replicates?.sends||_.subscriptions?.length))return;let E=(l+1)%c.length;for(;l!==E;){let f=c[E],h=uu.get(f);u=ao.get(h.url);let T=u?.get(i.database);if(!T){E=(E+1)%c.length;continue}let{worker:m,nodes:g}=T,S=!1;for(let y of d.nodes){if(g.some(I=>I.name===y.name)){_t.info(`Disconnected node is already failing over to ${f} for ${i.database}`);continue}g.push(y),S=!0}if(!S){_t.info(`Disconnected node ${i.name} has no nodes to fail over to ${f}`);return}d.redirectingTo=T,_t.info(`Failing over ${i.database} from ${i.name} to ${f}`),m?m.postMessage({type:"subscribe-to-node",database:i.database,nodes:g}):du({database:i.database,nodes:g});return}_t.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){_t.error("Error failing over node",o)}},"disconnectedFromNode"),Nc=a(function(i){let o=ao.get(i.url),c=o?.get(i.database);if(!c){_t.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,o);return}if(c.connected=!0,c.latency=i.latency,c.catchingUpFrom=i.lastSendTime,c.redirectingTo){let{worker:l,nodes:u}=c.redirectingTo,d=u.find(_=>_.name===i.name);c.redirectingTo=null,d&&(u.splice(u.indexOf(d),1),l?l.postMessage({type:"subscribe-to-node",database:i.database,nodes:u}):du({database:i.database,nodes:u}))}},"connectedToNode"),(0,Di.onMessageByType)("disconnected-from-node",_u),(0,Di.onMessageByType)("connected-to-node",Nc),(0,Di.onMessageByType)("request-cluster-status",TB)}function TB(e,t){let r=[];for(let[n,s]of uu)try{let i=ao.get(s.url);_t.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let o=[];if(i){for(let[l,{worker:u,connected:d,nodes:_,latency:E,catchingUpFrom:f}]of i)o.push({database:l,connected:d,latency:E,catching_up_from:f?new Date(f).toISOString():"up-to-date",thread_id:u?.threadId,nodes:_.map(h=>h.name)});let c=(0,Sy.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){_t.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function co(e,t){let r=Sr();e=e??zs(t.url),t.name=e;try{if(t.ca){let s=new SB.X509Certificate(t.ca);t.ca_info={issuer:s.issuer.replace(/\n/g," "),subject:s.subject.replace(/\n/g," "),subject_alt_name:s.subjectAltName,serial_number:s.serialNumber,valid_from:s.validFrom,valid_to:s.validTo}}}catch(s){_t.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(_t.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.put(t);else{t.replicates&&!pB.default.get(mB.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],o=(0,Sy.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let u of o)if((c.database??c.schema)===(u.database??u.schema)&&c.table===u.table){u.publish=c.publish,u.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...o,...i];break}_t.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Di,vp,_t,Sy,pB,mB,SB,Nte,ao,_u,Nc,uu,Up,Q_=Ie(()=>{Pe();Di=L(dt());ds();vp=require("worker_threads");lu();_t=L(W()),Sy=require("lodash"),pB=L(se()),mB=L(M()),SB=require("crypto"),Nte=200,ao=new Map,uu=new Map,Up=new Map;a(Ty,"startOnMainThread");a(TB,"requestClusterStatus");vp.parentPort&&(_u=a(e=>{vp.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),Nc=a(e=>{vp.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Di.onMessageByType)("subscribe-to-node",e=>{du(e)}),(0,Di.onMessageByType)("unsubscribe-from-node",e=>{Bp(e)}));a(co,"ensureNode")});var Hp=N((PNe,AB)=>{"use strict";var Ite=M().OPERATIONS_ENUM,gy=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=Ite.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};AB.exports=gy});var yB=N((MNe,RB)=>{"use strict";var wte={OPERATION:"operation",REFRESH:"refresh"},Ay=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},Ry=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};RB.exports={JWTTokens:Ay,TOKEN_TYPE_ENUM:wte,JWTRSAKeys:Ry}});var fu=N((vNe,IB)=>{"use strict";var X_=require("jsonwebtoken"),yy=require("fs-extra"),by=te(),_s=M(),{handleHDBError:fn,hdb_errors:Cte}=_e(),{HTTP_STATUS_CODES:En,AUTHENTICATION_ERROR_MSGS:hn}=Cte,J_=W(),bB=Kh(),Iy=xn(),Dte=un().update,Pte=Hp(),Lte=no(),{UserEventMsg:Mte}=qs(),na=se();na.initSync();var Oy=require("path"),{JWTTokens:Ute,JWTRSAKeys:vte,TOKEN_TYPE_ENUM:xp}=yB(),Bte=na.get(_s.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?na.get(_s.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",Hte=na.get(_s.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?na.get(_s.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",kp="RS256",Ny;IB.exports={createTokens:xte,validateOperationToken:Fte,refreshOperationToken:kte,validateRefreshToken:NB,getJWTRSAKeys:Z_};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 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:Hte,algorithm:kp,subject:xp.REFRESH}),l=bB.hash(c),u=new Pte(_s.SYSTEM_SCHEMA_NAME,_s.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:l}]),d,_;try{d=await Dte(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 Lte.signalUserChange(new Mte(process.pid)),new Ute(o,c)}a(xte,"createTokens");async function OB(e,t,r){return await X_.sign(e,{key:t,passphrase:r},{expiresIn:Bte,algorithm:kp,subject:xp.OPERATION})}a(OB,"signOperationToken");async function Z_(){if(Ny===void 0)try{let e=Oy.join(na.getHdbBasePath(),_s.LICENSE_KEY_DIR_NAME,_s.JWT_ENUM.JWT_PASSPHRASE_NAME),t=Oy.join(na.getHdbBasePath(),_s.LICENSE_KEY_DIR_NAME,_s.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=Oy.join(na.getHdbBasePath(),_s.LICENSE_KEY_DIR_NAME,_s.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 J_.error(e),fn(new Error,hn.NO_ENCRYPTION_KEYS,En.INTERNAL_SERVER_ERROR)}return Ny}a(Z_,"getJWTRSAKeys");async function kte(e){if(!e)throw fn(new Error,hn.INVALID_BODY,En.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw fn(new Error,hn.REFRESH_TOKEN_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);await NB(e.refresh_token);let t=await 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(kte,"refreshOperationToken");async function Fte(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(Fte,"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"),{watch:Gte}=require("chokidar"),pn=require("fs-extra"),Eu=require("node-forge"),UB=require("net"),{generateKeyPair:Cy,X509Certificate:lo,createPrivateKey:vB}=require("crypto"),qte=require("util");Cy=qte.promisify(Cy);var yt=Eu.pki,Qs=require("joi"),{v4:BB}=require("uuid"),{validateBySchema:My}=Tt(),pt=W(),Es=se(),hs=M(),{CONFIG_PARAMS:hu}=hs,Js=Sg(),{ClientError:ia}=_e(),wc=require("node:tls"),{relative:HB,join:$te}=require("node:path"),{CERT_PREFERENCE_APP:HNe,CERTIFICATE_VALUES:wB}=Js,Vte=ja(),Dy=wt(),CB=parseInt(process.version.slice(1))<20,{table:Kte,getDatabases:Yte,databases:wy}=(Pe(),oe(lt)),{getJWTRSAKeys:DB}=fu();Object.assign(XB,{generateKeys:By,updateConfigCert:KB,createCsr:Zte,signCertificate:ere,setCertTable:pu,loadCertificates:qB,reviewSelfSignedCert:xy,createTLSSelector:jB,listCertificates:QB,addCertificate:ore,removeCertificate:cre,createNatsCerts:nre,generateCertsKeys:rre,getReplicationCert:tf,getReplicationCertAuth:Xte,renewSelfSigned:sre,hostnamesFromCert:JB,getKey:lre});var{urlToNodeName:xB,getThisNodeUrl:Wte,getThisNodeName:Gp,clearThisNodeName:jte}=(ds(),oe(ca)),{readFileSync:zte,statSync:kB}=require("node:fs"),xNe=se(),{getTicketKeys:Qte,onMessageFromWorkers:Jte}=dt(),sa=W(),{isMainThread:FB}=require("worker_threads"),{TLSSocket:GB,createSecureContext:kNe}=require("node:tls"),Uy=3650,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===hs.ITC_EVENT_TYPES.RESTART&&(Es.initSync(!0),await xy())});var Pr;function aa(){return Pr||(Pr=Yte().system.hdb_certificate,Pr||(Pr=Kte({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 lo(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(tf,"getReplicationCert");async function Xte(){aa();let e=(await tf()).options.cert,r=new lo(e).issuer.match(/CN=(.*)/)?.[1];return Pr.get(r)}a(Xte,"getReplicationCertAuth");var PB,oa=new Map;function qB(){if(PB)return;PB=!0;let e=[{configKey:hu.TLS},{configKey:hu.OPERATIONSAPI_TLS}];aa();let t=sr.dirname(Dy.getConfigFilePath()),r;for(let{configKey:n}of e){let s=Dy.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&HB($te(t,"keys"),o);c&&LB(o,l=>{oa.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&FB){let d;LB(u,_=>{if(wB.cert===_)return;let E=i.hostname??i.hostnames??i.host??i.hosts;E&&!Array.isArray(E)&&(E=[E]);let f=YB(u),h=new lo(f),T;try{T=ky(h)}catch(y){pt.error("error extracting common name from certificate",y);return}if(T==null){pt.error("error extracting common name from certificate");return}if(h.checkIssued(new lo(wB.cert)))return;let m=Pr.primaryStore.get(T),g=kB(u).mtimeMs,S=!m||m.is_self_signed?1:m.file_timestamp??m.__updatedtime__;if(m&&g<=S){g<S&&pt.info(`Certificate ${T} at ${u} is older (${new Date(g)}) than the certificate in the database (${S>1?new Date(S):"only self signed certificate available"})`);return}r=Pr.put({name:T,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:f,private_key_name:c,is_authority:l,hostnames:E,file_timestamp:g,details:{issuer:h.issuer.replace(/\n/g," "),subject:h.subject.replace(/\n/g," "),subject_alt_name:h.subjectAltName,serial_number:h.serialNumber,valid_from:h.validFrom,valid_to:h.validTo}})},l?"certificate authority":"certificate")}}}}}return r}a(qB,"loadCertificates");function LB(e,t,r){let n,s=a((i,o)=>{try{let c=o.mtimeMs;c&&c!==n&&(n&&FB&&pt.warn(`Reloading ${r}:`,i),n=c,t(YB(i)))}catch(c){pt.error(`Error loading ${r}:`,i,c)}},"loadFile");pn.existsSync(e)?s(e,kB(e)):pt.error(`${r} file not found:`,e),Gte(e,{persistent:!1}).on("change",s)}a(LB,"loadAndWatch");function Py(){let e=Wte();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 Zte(){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),Eu.pki.certificationRequestToPem(n)}a(Zte,"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 ere(e){let t={},r=sr.join(Es.getHdbBasePath(),hs.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;aa();for await(let d of Pr.search([]))if(d.is_authority&&!d.details.issuer.includes("HarperDB-Certificate-Authority")){if(oa.has(d.private_key_name)){n=oa.get(d.private_key_name),s=d;break}else if(d.private_key_name&&await pn.exists(sr.join(r,d.private_key_name))){n=pn.readFile(sr.join(r,d.private_key_name)),s=d;break}}if(!n){let d=await Ly();s=d.ca,n=d.private_key}n=yt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=yt.certificateFromPem(s.certificate);pt.info("Signing CSR with cert named",s.name);let o=yt.certificationRequestFromPem(e.csr);try{o.verify()}catch(d){return pt.error(d),new Error("Error verifying CSR: "+d.message)}let c=Eu.pki.createCertificate();c.serialNumber=Math.random().toString().slice(2,10),c.validity.notBefore=new Date;let l=new Date;c.validity.notAfter=l,c.validity.notAfter.setDate(l.getDate()+Uy),pt.info("sign cert setting validity:",c.validity),pt.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),pt.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=o.getAttribute({name:"extensionRequest"}).extensions;pt.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=o.publicKey,c.sign(n,Eu.md.sha256.create()),t.certificate=yt.certificateToPem(c)}else pt.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(ere,"signCertificate");async function tre(e,t){await pu({name:Gp(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await pu({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:yt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(tre,"createCertificateTable");async function pu(e){let t=new lo(e.certificate);e.details={issuer:t.issuer.replace(/\n/g," "),subject:t.subject.replace(/\n/g," "),subject_alt_name:t.subjectAltName,serial_number:t.serialNumber,valid_from:t.validFrom,valid_to:t.validTo},aa(),await Pr.patch(e)}a(pu,"setCertTable");async function By(){let e=await Cy("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:yt.publicKeyFromPem(e.publicKey),private_key:yt.privateKeyFromPem(e.privateKey)}}a(By,"generateKeys");async function Hy(e,t,r){let n=yt.createCertificate();if(!t){let o=await 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,Eu.md.sha256.create()),yt.certificateToPem(n)}a(Hy,"generateCertificates");async function Ly(){let e=await QB(),t;for(let r of e){if(!r.is_authority)continue;let n=await zB(r.private_key_name);if(r.private_key_name&&n&&new lo(r.certificate).checkPrivateKey(vB(n))){pt.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;pt.trace("No CA found with matching private key")}a(Ly,"getCertAuthority");async function VB(e,t,r=!0){let n=yt.createCertificate();n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+Uy);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${Es.get(hu.REPLICATION_HOSTNAME)??xB(Es.get(hu.REPLICATION_URL))??BB().split("-")[0]}`},...vy];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,Eu.md.sha256.create());let o=sr.join(Es.getHdbBasePath(),hs.LICENSE_KEY_DIR_NAME),c=sr.join(o,Js.PRIVATEKEY_PEM_NAME);return r&&await pn.writeFile(c,yt.privateKeyToPem(e)),n}a(VB,"generateCertAuthority");async function rre(){let{private_key:e,public_key:t}=await By(),r=await VB(e,t),n=await Hy(e,t,r);await tre(n,r),KB()}a(rre,"generateCertsKeys");async function nre(){let e=await Hy(yt.privateKeyFromPem(Js.CERTIFICATE_VALUES.key),void 0,yt.certificateFromPem(Js.CERTIFICATE_VALUES.cert)),t=sr.join(Es.getHdbBasePath(),hs.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(){jte(),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=Es.get(hu.TLS_PRIVATEKEY),n=sr.join(Es.getHdbBasePath(),hs.LICENSE_KEY_DIR_NAME),s,i=HB(n,r);try{s=yt.privateKeyFromPem(await pn.readFile(r))}catch(c){pt.warn("Unable to parse the TLS key",r,"A new key will be generated and used to create Certificate Authority",c),{private_key:s}=await By(),await pn.exists(sr.join(n,Js.PRIVATEKEY_PEM_NAME))&&(i=`privateKey${BB().split("-")[0]}.pem`),await pn.writeFile(sr.join(n,i),yt.privateKeyToPem(s))}let o=await VB(s,yt.setRsaPublicKey(s.n,s.e),!1);await pu({name:o.subject.getField("CN").value,uses:["https"],certificate:yt.certificateToPem(o),private_key_name:i,is_authority:!0,is_self_signed:!0})}if(!await 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 pu({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(xy,"reviewSelfSignedCert");function KB(){let e=Vte(Object.keys(hs.CONFIG_PARAM_MAP),!0),t=sr.join(Es.getHdbBasePath(),hs.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=hs.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:zte(e,"utf8")}a(YB,"readPEM");var MB=wc.createSecureContext;wc.createSecureContext=function(e){if(!e.cert||!e.key)return MB(e);let t={...e};delete t.key,delete t.cert;let r=MB(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var WB=wc.Server;wc.Server=function(e,t){return e.ALPNCallback&&(e.ALPNProtocols=null),WB.call(this,e,t)};wc.Server.prototype=WB.prototype;var ire=GB.prototype._init;GB.prototype._init=function(e,t){ire.call(this,e,t);let r=this;this._handle.oncertcb=function(n){let s=n.servername;r._SNICallback(s,(i,o)=>{this.sni_context=o?.context||o,this.certCbDone()})}};var Ic=new Map;function jB(e,t){let r=new Map,n,s=!1;return i.initialize=o=>i.ready?i.ready:(o&&(o.secureContexts=r,o.secureContextsListeners=[]),i.ready=new Promise((c,l)=>{async function u(){try{r.clear(),Ic.clear();let d=0;for await(let _ of wy.system.hdb_certificate.search([])){let E=_.certificate,f=new lo(E);_.is_authority&&(f.asString=E,Ic.set(f.subject,E))}for await(let _ of wy.system.hdb_certificate.search([]))try{if(_.is_authority)continue;let E=e==="operations-api",f=_.is_self_signed?1:2;E&&_.uses?.includes?.("operations")&&(f+=1);let h=await zB(_.private_key_name),T=_.certificate,m=new lo(T);if(Ic.has(m.issuer)&&(T+=`
15
- `+Ic.get(m.issuer)),!h||!T)throw new Error("Missing private key or certificate for secure server");let g={ciphers:_.ciphers,ticketKeys:Qte(),availableCAs:Ic,ca:t&&Array.from(Ic.values()),cert:T,key:h,key_file:_.private_key_name,is_self_signed:_.is_self_signed};o&&(g.sessionIdContext=o.sessionIdContext);let S=wc.createSecureContext(g);S.name=_.name,S.options=g,S.quality=f,S.certificateAuthorities=Array.from(Ic),S.certStart=T.toString().slice(0,100);let y=_.hostnames??JB(m);Array.isArray(y)||(y=[y]);let I;for(let U of y)if(U){U[0]==="*"&&(s=!0,U=U.slice(1)),U===Py()&&(f+=2),UB.isIP(U)&&(I=!0);let H=r.get(U)?.quality??0;f>H&&r.set(U,S)}else sa.error("No hostname found for certificate at",wc.certificate);sa.trace("Adding TLS",S.name,"for",o.ports||"client","cert named",_.name,"hostnames",y,"quality",f,"best quality",d),f>d&&(i.defaultContext=n=S,d=f,o&&(o.defaultContext=S))}catch(E){sa.error("Error applying TLS for",_.name,E)}o?.secureContextsListeners.forEach(_=>_()),c(n)}catch(d){l(d)}}a(u,"updateTLS"),wy.system.hdb_certificate.subscribe({listener:a(()=>setTimeout(()=>u(),1500).unref(),"listener"),omitCurrent:!0}),u()})),i;function i(o,c){sa.info("TLS requested for",o||"(no SNI)",this.isReplicationConnection);let l=o;for(;;){let d=r.get(l);if(d)return sa.debug("Found certificate for",o,d.certStart),d.replicationContext&&(this.isReplicationConnection||CB)&&(d=d.replicationContext),c(null,d);if(s&&l){let _=l.indexOf(".",1);_<0?l="":l=l.slice(_)}else break}o?sa.debug("No certificate found to match",o,"using the default certificate"):sa.debug("No SNI, using the default certificate",n?.name);let u=n;u?u.replicationContext&&(this.isReplicationConnection||CB)&&(u=u.replicationContext):sa.info("No default certificate found"),c(null,u)}a(i,"SNICallback")}a(jB,"createTLSSelector");async function zB(e){let t=oa.get(e);return!t&&e?await pn.readFile(sr.join(Es.get(hu.ROOTPATH),hs.LICENSE_KEY_DIR_NAME,e),"utf8"):t}a(zB,"getPrivateKeyByName");async function QB(){aa();let e=[];for await(let t of Pr.search([]))e.push(t);return e}a(QB,"listCertificates");async function ore(e){let t=My(e,Qs.object({name:Qs.string().required(),certificate:Qs.string().required(),is_authority:Qs.boolean().required(),private_key:Qs.string(),hosts:Qs.array(),uses:Qs.array()}));if(t)throw new ia(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,o=new lo(n),c=!1,l=!1,u;for(let[f,h]of oa)!s&&!c&&o.checkPrivateKey(vB(h))&&(c=!0,u=f),s&&s===h&&(l=!0,u=f);if(!i&&!s&&!c)throw new ia("A suitable private key was not found for this certificate");let d;if(!r){try{d=ky(o)}catch(f){pt.error(f)}if(d==null)throw new ia("Error extracting certificate common name, please provide a name parameter")}let _=are(r??d);s&&!c&&!l&&(await pn.writeFile(sr.join(Es.getHdbBasePath(),hs.LICENSE_KEY_DIR_NAME,_+".pem"),s),oa.set(_,s));let E={name:r??d,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&u||i&&s)&&(E.private_key_name=u??_+".pem"),await pu(E),"Successfully added certificate: "+_}a(ore,"addCertificate");function are(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(are,"sanitizeName");async function cre(e){let t=My(e,Qs.object({name:Qs.string().required()}));if(t)throw new ia(t.message);let{name:r}=e;aa();let n=await Pr.get(r);if(!n)throw new ia(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await Pr.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(pt.info("Removing private key named",s),await pn.remove(sr.join(Es.getHdbBasePath(),hs.LICENSE_KEY_DIR_NAME,s)))}return await Pr.delete(r),"Successfully removed "+r}a(cre,"removeCertificate");function ky(e){return e.subject.match(/CN=(.*)/)?.[1]}a(ky,"extractCommonName");function JB(e){return e.subjectAltName?e.subjectAltName.split(",").map(t=>{let r=t.indexOf(":");if(t=t.slice(r+1),t=t.trim(),t[0]==='"')try{t=JSON.parse(t)}catch{}return t.indexOf("=")>-1?t.match(/CN=([^,]*)/)?.[1]:t}).filter(t=>t):[ky(e)]}a(JB,"hostnamesFromCert");async function lre(e){if(e.bypass_auth!==!0)throw new ia("Unauthorized","401");let t=My(e,Qs.object({name:Qs.string().required()}));if(t)throw new ia(t.message);let{name:r}=e;if(r===".jwtPrivate")return(await DB()).private_key;if(r===".jwtPublic")return(await DB()).public_key;if(oa.get(r))return oa.get(e.name);throw new ia("Key not found")}a(lre,"getKey")});async function Ky(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=ot(),i;if(e.includes("wss://")){if(!Gy){let l=(0,hH.createTLSSelector)("operations-api"),u={secureContexts:null};await l.initialize(u),Gy=u.secureContexts}if(i=Gy.get(s),i&&fe.debug?.("Creating web socket for URL",e,"with certificate named:",i.name),!i&&n!==!1)throw new Error("Unable to find a valid certificate to use for replication to connect to "+e)}let o={};r&&(o.Authorization=r);let c={headers:o,localAddress:s?.startsWith("127.0")?s:void 0,servername:(0,mH.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,ALPNProtocols:["http/1.1","harperdb-replication"],rejectUnauthorized:n!==!1,secureContext:void 0};return i&&(c.secureContext=pH.createSecureContext({...i.options,ca:Array.from(Dc)})),new fH.WebSocket(e,"harperdb-replication-v1",c)}function Yp(e,t,r){let n=t.port||t.securePort,s=Vy.pid%1e3+"-"+EH.threadId+(n?"s:"+n:"c:"+t.url?.slice(-4))+" "+Math.random().toString().slice(2,3),i=0,o=Buffer.allocUnsafeSlow(1024),c=0,l=new DataView(o.buffer,0,1024),u=t.database,d=t.databaseSubscriptions||Cc,_,E,f=!1,h=t.subscription;h?.then&&h.then(ie=>h=ie);let T=t.tables||u&&ut()[u];if(!r){fe.error?.("No authorization provided"),is(1008,"Unauthorized");return}let m=new Map,g=[],S=r.name;S&&t.connection&&(t.connection.nodeName=S);let y,I,U,H,X,Y,V=1e3,ne,Q=0,de=0,j=0,ae=0;if(t.url){let ie=a(()=>{X&&j===e._socket?.bytesRead&&ae===e._socket?.bytesWritten?e.terminate():(X=performance.now(),e.ping(),j=e._socket?.bytesRead,ae=e._socket?.bytesWritten)},"send_ping");U=setInterval(ie,lH).unref(),ie()}else Oe();function Oe(){clearTimeout(H),j=e._socket?.bytesRead,ae=e._socket?.bytesWritten,H=setTimeout(()=>{j===e._socket?.bytesRead&&ae===e._socket?.bytesWritten&&(fe.warn?.(`Timeout waiting for ping from ${S}, terminating connection and reconnecting`),e.terminate())},lH*2).unref()}a(Oe,"resetPingTimer"),u&&Ka(u);let Ne,Me,Gr=[],wd=[],Fa,wn=[],Cd=[],Nl=[],Uw=150,jE=0,vt=0,Ga,qa,vs,Bs,zE;e.on("message",ie=>{Q=performance.now();try{let Se=ie.dataView=new Pc(ie.buffer,ie.byteOffset,ie.byteLength);if(ie[0]>127){let A=(0,ct.decode)(ie),[w,R,b]=A;switch(w){case eH:{if(R){if(S){if(S!==R){fe.error?.(s,`Node name mismatch, expecting to connect to ${S}, but peer reported name as ${R}, disconnecting`),e.send((0,ct.encode)([mu])),is(1008,"Node name mismatch");return}}else if(S=R,t.connection?.tentativeNode){let x=t.connection.tentativeNode;x.name=S,t.connection.tentativeNode=null,co(S,x)}if(t.connection&&(t.connection.nodeName=S),fe.debug?.(s,"received node name:",S,"db:",u),!u)try{Ka(u=A[2]),u==="system"&&(Ne=ta(t,(x,q)=>{Va(q)&&Ir(q)}),e.on("close",()=>{Ne?.remove()}))}catch(x){fe.warn?.(s,"Error setting database",x),e.send((0,ct.encode)([mu])),is(1008,x.message);return}$a()}break}case aH:{fe.debug?.(s,"Received table definitions for",R.map(x=>x.table));for(let x of R){let q=A[2];x.database=q;let ee;Va(q)&&(q==="system"?We[q]?.[x.table]||(ee=qy(x,We[q]?.[x.table])):ee=qy(x,We[q]?.[x.table]),_||(_=ee?.auditStore),T||(T=ut()?.[q]))}break}case mu:is();break;case sH:try{let x=r?.replicates||r?.subscribers||r?.name;server.operation(R,{user:r},!x).then(q=>{Array.isArray(q)&&(q={results:q}),q.requestId=R.requestId,e.send((0,ct.encode)([$p,q]))},q=>{e.send((0,ct.encode)([$p,{requestId:R.requestId,error:q instanceof Error?q.toString():q}]))})}catch(x){e.send((0,ct.encode)([$p,{requestId:R.requestId,error:x instanceof Error?x.toString():x}]))}break;case $p:let{resolve:D,reject:O}=m.get(R.requestId);R.error?O(new Error(R.error)):D(R),m.delete(R.requestId);break;case Fy:let B=A[3];T||(u?fe.error?.(s,"No tables found for",u):fe.error?.(s,"Database name never received"));let k=T[B];k=qy({table:B,database:u,attributes:R.attributes,schemaDefined:R.schemaDefined},k),Gr[b]={name:B,decoder:new ct.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:R.typedStructs,structures:R.structures}),getEntry(x){return k.primaryStore.getEntry(x)},rootStore:k.primaryStore.rootStore};break;case tH:zE=_?tB(S,R,_):new Map,Fa=A[2],fe.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${Fa}`);break;case rH:let C=b;Nl[C]=R;break;case oH:let F=["replicated",u,S];E||(E=new Float64Array(_.getUserSharedBuffer(F,new ArrayBuffer(8)))),E[0]=R,fe.trace?.(s,"received and broadcasting committed update",R),E.buffer.notify();break;case iH:y=R,h.send({type:"end_txn",localTime:y,remoteNodeIds:g});break;case nH:{let x=R,q;try{let ee=A[3],G=wd[b]||(wd[b]=T[A[4]]);if(!G)return fe.warn?.("Unknown table id trying to handle record request",b);let Re=G.primaryStore.getBinaryFast(Symbol.for("structures")),Ee=Re.length;if(Ee!==vt){vt=Ee;let re=(0,ct.decode)(Re);e.send((0,ct.encode)([Fy,{typedStructs:re.typed,structures:re.named},b,G.tableName]))}let Ae=G.primaryStore.getBinaryFast(ee);if(Ae){let re=G.primaryStore.decoder.decode(Ae,{valueAsBuffer:!0});q=(0,ct.encode)([qp,x,{value:re.value,expiresAt:re.expiresAt,version:re.version,residencyId:re.residencyId,nodeId:re.nodeId,user:re.user}])}else q=(0,ct.encode)([qp,x])}catch(ee){q=(0,ct.encode)([qp,x,{error:ee.message}])}e.send(q);break}case qp:{let{resolve:x,reject:q,tableId:ee,key:G}=m.get(A[1]),Re=A[2];if(Re?.error)q(new Error(Re.error));else if(Re){let Ee=Gr[ee].decoder.decode(Re.value);Re.value=Ee,Re.key=G,x(Re)}else x();m.delete(A[1]);break}case ZB:{Bs=R;let x,q,ee=!1;if(h){if(u!==h.databaseName&&!h.then){fe.error?.("Subscription request for wrong database",u,h.databaseName);return}}else h=d.get(u);if(fe.debug?.(s,"received subscription request for",u,"at",Bs),!h){let ce;h=new Promise(Ye=>{fe.debug?.("Waiting for subscription to database "+u),ce=Ye}),h.ready=ce,Cc.set(u,h)}if(r.name)q=Sr().subscribe(r.name),q.then(async ce=>{x=ce;for await(let Ye of x){let rt=Ye.value;if(!(rt?.replicates===!0||rt?.replicates?.receives||rt?.subscriptions?.some(Ze=>(Ze.database||Ze.schema)===u&&Ze.publish!==!1))){ee=!0,e.send((0,ct.encode)([mu])),is(1008,`Unauthorized database subscription to ${u}`);return}}},ce=>{fe.error?.(s,"Error subscribing to HDB nodes",ce)});else if(!(r?.role?.permission?.super_user||r.replicates)){e.send((0,ct.encode)([mu])),is(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"),_i(9),_i(Kp),Ya(ge=Ye),we()),i=c,Ee.txnTime=0;return}let rt=ce.nodeId,Ze=ce.tableId,st=re[Ze];if(!st&&(st=re[Ze]=Re(h.tableById[Ze]),!st))return fe.debug?.("Not subscribed to table",Ze);let Bt=st.table,ko=Bt.primaryStore,Yt=ko.encoder;(ce.extendedType&Oh||!Yt.typedStructs)&&(Yt._mergeStructures(Yt.getStructures()),Yt.typedStructs&&(Yt.lastTypedStructuresLength=Yt.typedStructs.length));let QE=Ae[rt];if(!(QE&&QE.startTime<Ye&&(!QE.endTime||QE.endTime>Ye)))return rf&&fe.trace?.(s,"skipping replication update",ce.recordId,"to:",S,"from:",rt,"subscribed:",Ae),vw();rf&&fe.trace?.(s,"sending replication update",ce.recordId,"to:",S,"from:",rt,"subscribed:",Ae);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"),we()),Ee.txnTime=ZT,i=c,Ya(ZT));let Wa=ce.residencyId,eg=ji(Wa,Bt),JE;if(eg&&!eg.includes(S)){let wl=ji(ce.previousResidencyId,Bt);if(wl&&!wl.includes(S)&&(ce.type==="put"||ce.type==="patch")||Bt.getResidencyById)return vw();let Md=ce.recordId;fe.trace?.(s,"sending invalidation",Md,S,"from",rt);let ng=0;Wa&&(ng|=rc),ce.previousResidencyId&&(ng|=nc);let sg,XE=null;for(let Bw in Bt.indices){if(!XE){if(sg=ce.getValue(ko,!0),!sg)break;XE={}}XE[Bw]=sg[Bw]}JE=Ul(ce.version,Ze,Md,null,rt,ce.user,ce.type==="put"||ce.type==="patch"?"invalidate":ce.type,Yt.encode(XE),ng,Wa,ce.previousResidencyId,ce.expiresAt)}function vw(){fe.trace?.(s,"skipping audit record",ce.recordId),Y||(Y=setTimeout(()=>{Y=null,(ge||0)+cH/2<K&&(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:Bt.attributes,schemaDefined:Bt.schemaDefined},Ze,st.table.tableName]))),Wa&&!Cd[Wa]&&(e.send((0,ct.encode)([rH,eg,Wa])),Cd[Wa]=!0),JE)_i(JE.length),Ld(JE);else{let wl=ce.encoded,Md=wl[0]===66?8:0;_i(wl.length-Md),Ld(wl,Md)}},"sendAuditRecord"),we=a(()=>{c-i>8?(e.send(o.subarray(i,c)),fe.debug?.(s,"Sent message, size:",c-i)):fe.debug?.(s,"skipping empty transaction")},"sendQueuedData");vs=new $y.EventEmitter,vs.once("close",()=>{ee=!0,x?.end()});for(let{startTime:ce}of Bs)ce<K&&(K=ce);(q||Promise.resolve()).then(async()=>{h=await h,_=h.auditStore,re=h.tableById.map(Re),Ae=[];for(let{name:Ye,startTime:rt,endTime:Ze}of Bs){let st=Lp(Ye,_);fe.debug?.("subscription to",Ye,"using local id",st,"starting",rt),Ae[st]={startTime:rt,endTime:Ze}}Ir(u),Ne||(Ne=Lc(Ye=>{Ye.databaseName===u&&Ir(u)}),Me=nf(Ye=>{Ye===u&&(e.send((0,ct.encode)([mu])),is())}),e.on("close",()=>{Ne?.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),is(1008,"Invalid sequence id"+K));let Ye;if(ce&&!ee&&(ce=!1,!(Yy(_)<=K)&&dH.default.get(_H.CONFIG_PARAMS.REPLICATION_COPYTABLESTOCATCHUP)!==!1&&server.nodes[0]?.name===S)){fe.info?.("Replicating all tables to",S);let Ze=K,st=Wp(_);for(let Bt in T){if(!Re(Bt))continue;let ko=T[Bt];for(let Yt of ko.primaryStore.getRange({snapshot:!1})){if(ee)return;Yt.localTime>=K&&(fe.trace?.(s,"Copying record from",u,Bt,Yt.key,Yt.localTime),Ze=Math.max(Yt.localTime,Ze),Ye=!0,Be({recordId:Yt.key,tableId:ko.tableId,type:"put",getValue(){return Yt.value},encoded:ko.primaryStore.getBinary(Yt.key),version:Yt.version,residencyId:Yt.residencyId,nodeId:st},Yt.localTime))}}K=Ze}for(let{key:rt,value:Ze}of _.getRange({start:K||1,exclusiveStart:!0,snapshot:!1})){if(ee)return;de=rt;let st=xt(Ze);Be(st,rt),e._socket.writableNeedDrain?await new Promise(Bt=>e._socket.once("drain",Bt)):await new Promise(setImmediate),vs.startTime=rt,Ye=!0}Ye&&Be({type:"end_txn"},K),de=0,await lB(_)}while(!ee)}).catch(ce=>{fe.error?.(s,"Error handling subscription to node",ce),is(1008,"Error handling subscription to node")});break}}return}Se.position=8;let tt=!0,v,p;do{let A=Se.readInt();if(A===9&&Se.getUint8(Se.position)==Kp){Se.position++,y=p=Se.readFloat64(),fe.trace?.("received remote sequence update",y,u);break}let w=Se.position,R=xt(ie,w,w+A),b=Gr[R.tableId];b||fe.error?.(`No table found with an id of ${R.tableId}`);let D;R.residencyId&&(D=Nl[R.residencyId],fe.trace?.(s,"received residency list",D,R.type,R.recordId));try{v={table:b.name,id:R.recordId,type:R.type,nodeId:zE.get(R.nodeId),residencyList:D,timestamp:R.version,value:R.getValue(b),user:R.user,beginTxn:tt,expiresAt:R.expiresAt}}catch(O){throw O.message+="typed structures for current decoder"+JSON.stringify(b.decoder.typedStructs),O}tt=!1,rf&&fe.trace?.(s,"received replication message",R.type,"id",v.id,"version",R.version,"nodeId",v.nodeId,"value",v.value),h.send(v),Se.position=w+A}while(Se.position<ie.byteLength);jE++,pr(ie.byteLength,"bytes-received",S+"."+u+"."+v.table,"replication","ingest"),jE>Uw&&!Ga&&(Ga=!0,e.pause()),h.send({type:"end_txn",localTime:y,remoteNodeIds:g,onCommit(){if(v){let A=Date.now()-v.timestamp;pr(A,"replication-latency",S+"."+u+"."+v.table,v.type,"ingest")}jE--,Ga&&(Ga=!1,e.resume()),!I&&p&&(fe.trace?.(s,"queuing confirmation of a commit at",p),setTimeout(()=>{e.send((0,ct.encode)([oH,I])),fe.trace?.(s,"sent confirmation of a commit at",I),I=null},ure)),I=p}})}catch(Se){fe.error?.(s,"Error handling incoming replication message",Se)}}),e.on("ping",Oe),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-X,Nc({name:S,database:u,url:t.url,lastSendTime:de,latency:t.connection.latency})),X=null}),e.on("close",(ie,Se)=>{clearInterval(U),clearTimeout(H),vs&&vs.emit("close"),qa&&qa.end();for(let[tt,{reject:v}]of m)v(new Error(`Connection closed ${Se?.toString()} ${ie}`));fe.debug?.(s,"closed",ie,Se?.toString())});function Ve(){}a(Ve,"recordRemoteNodeSequence");function is(ie,Se){e.isFinished=!0,e.close(ie,Se)}a(is,"close");function $a(){if(f||(f=!0,t.connection?.on("subscriptions-updated",$a)),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let ie=new Map;try{for(let v of h?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let p of v.value.nodes||[])p.lastTxnTime>(ie.get(p.id)??0)&&ie.set(p.id,p.lastTxnTime)}catch(v){if(!v.message.includes("Can not re"))throw v}let Se=t.connection?.nodeSubscriptions?.[0];g=[];let tt=t.connection?.nodeSubscriptions.map((v,p)=>{let A=[],{replicateByDefault:w}=v;if(v.subscriptions){for(let O of v.subscriptions)if(O.subscribe&&(O.schema||O.database)===u){let B=O.table;T?.[B]?.replicate!==!1&&A.push(B)}w=!1}else for(let O in T)(w?T[O].replicate===!1:T[O].replicate)&&A.push(O);let R=_&&Lp(v.name,_),b=h?.dbisDB?.get([Symbol.for("seq"),R])??1,D=Math.max(b?.seqId??1,(typeof v.start_time=="string"?new Date(v.start_time).getTime():v.start_time)??1);if(fe.debug?.("Starting time recorded in db",v.name,R,u,b?.seqId,"start time:",D),Se!==v){D>5e3&&(D-=5e3);let O=_&&Lp(Se.name,_),B=h?.dbisDB?.get([Symbol.for("seq"),O])??1;for(let k of B?.nodes||[])k.name===v.name&&(D=k.seqId,fe.debug?.("Using sequence id from proxy node",Se.name,D))}return g.push(R),ie.get(R)>D&&(D=ie.get(R),fe.debug?.("Updating start time from more recent txn recorded",Se.name,D)),{name:v.name,replicateByDefault:w,tables:A,startTime:D,endTime:v.end_time}});if(tt)if(fe.debug?.(s,"sending subscription request",tt,h?.dbisDB?.path),clearTimeout(ne),tt.length>0)e.send((0,ct.encode)([ZB,tt]));else{let v=a(()=>{let p=performance.now();ne=setTimeout(()=>{Q<=p?is(1008,"No nodes to subscribe to"):v()},V)},"schedule_close");v()}}a($a,"sendSubscriptionRequestUpdate");function ji(ie,Se){if(!ie)return;let tt=wn[ie];return tt||(tt=Se.getResidencyRecord(ie),wn[ie]=tt),tt}a(ji,"getResidence");function Va(ie){return!(la&&la!="*"&&!la[ie]&&!la.includes?.(ie)&&!la.some?.(Se=>Se.name===ie))}a(Va,"checkDatabaseAccess");function Ka(ie){if(h=h||d.get(ie),!Va(ie))throw new Error(`Access to database "${ie}" is not permitted`);h||fe.warn?.(`No database named "${ie}" was declared and registered`),_=h?.auditStore,T||(T=ut()?.[ie]);let Se=ot();if(Se===S)throw Se?new Error("Should not connect to self",Se):new Error("Node name not defined");return Dd(Se,ie),!0}a(Ka,"setDatabase");function Dd(ie,Se){let tt=ut()?.[Se],v=[];for(let p in tt){let A=tt[p];v.push({table:p,schemaDefined:A.schemaDefined,attributes:A.attributes.map(w=>({name:w.name,type:w.type,isPrimaryKey:w.isPrimaryKey}))})}fe.trace?.("Sending database info for node",ie,"database name",Se),e.send((0,ct.encode)([eH,ie,Se,v]))}a(Dd,"sendNodeDBName");function Ir(ie){let Se=ut()?.[ie],tt=[];for(let v in Se){if(Bs&&!Bs.some(A=>A.replicateByDefault?!A.tables.includes(v):A.tables.includes(v)))continue;let p=Se[v];tt.push({table:v,schemaDefined:p.schemaDefined,attributes:p.attributes.map(A=>({name:A.name,type:A.type,isPrimaryKey:A.isPrimaryKey}))})}e.send((0,ct.encode)([aH,tt,ie]))}a(Ir,"sendDBSchema");let Il=1,Pd=[];return{end(){qa&&qa.end(),vs&&vs.emit("close")},getRecord(ie){let Se=Il++;return new Promise((tt,v)=>{let p=[nH,Se,ie.table.tableId,ie.id];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(A){let{table:w,entry:R}=ie;tt(A),A&&w._recordRelocate(R,A)},reject:v})})},sendOperation(ie){let Se=Il++;return ie.requestId=Se,e.send((0,ct.encode)([sH,ie])),new Promise((tt,v)=>{m.set(Se,{resolve:tt,reject:v})})}};function _i(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 Ld(ie,Se=0,tt=ie.length){let v=tt-Se;xo(v),ie.copy(o,c,Se,tt),c+=v}function Ya(ie){xo(8),l.setFloat64(c,ie),c+=8}function xo(ie){if(ie+16>o.length-c){let Se=Buffer.allocUnsafeSlow(c+ie-i+65536>>10<<11);o.copy(Se,0,i,c),c=c-i,i=0,o=Se,l=new DataView(o.buffer,0,o.length)}}}function qy(e,t){let r=e.database??"data";if(r!=="data"&&!We[r]){fe.warn?.("Database not found",e.database);return}t||(t={});let n=!1,s=e.schemaDefined,i=t.attributes||[];for(let o=0;o<e.attributes?.length;o++){let c=e.attributes[o],l=i[o];(!l||l.name!==c.name||l.type!==c.type)&&(n=!0,s||(c.indexed=!0),i[o]=c)}return n?(fe.debug?.("(Re)creating",e),Et({table:e.table,database:e.database,schemaDefined:e.schemaDefined,attributes:i,...t})):t}var dH,_H,ct,fH,EH,fe,$y,hH,pH,Vy,mH,ZB,eH,tH,mu,rH,Fy,nH,qp,sH,$p,iH,oH,aH,SH,Cc,rf,cH,ure,lH,Gy,uH,Vp,TH=Ie(()=>{Pe();Ji();_y();my();ds();dH=L(se()),_H=L(M());vl();ct=require("msgpackr"),fH=require("ws"),EH=require("worker_threads"),fe=L(Oc());Q_();$y=require("events"),hH=L(Xs()),pH=L(require("node:tls"));lu();Vy=L(require("node:process")),mH=require("node:net");Ii();ZB=129,eH=140,tH=141,mu=142,rH=130,Fy=132,nH=133,qp=134,sH=136,$p=137,iH=143,oH=144,aH=145,SH=new Map,Cc=new Map,rf=!0,cH=300,ure=2,lH=3e4;a(Ky,"createWebSocket");uH=1e3,Vp=class extends $y.EventEmitter{constructor(r,n,s,i,o){super();this.url=r;this.subscription=n;this.databaseName=s;this.nodeName=i;this.authorization=o;this.nodeName=this.nodeName??zs(r)}static{a(this,"NodeReplicationConnection")}socket;startTime;retryTime=uH;retries=0;isConnected=!0;isFinished=!1;nodeSubscriptions=[];latency=0;replicateTablesByDefault;session;sessionResolve;sessionReject;async connect(){this.session||this.resetSession();let r=[];this.socket=await Ky(this.url,{serverName:this.nodeName,authorization:this.authorization});let n;fe.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${Vy.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),fe.info?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=uH,Nc({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=Yp(this.socket,{database:this.databaseName,subscription:this.subscription,url:this.url,connection:this},{replicates:!0}),this.sessionResolve(n)}),this.socket.on("error",s=>{s.code==="SELF_SIGNED_CERT_IN_CHAIN"?(fe.warn?.(`Can not connect to ${this.url}, this server does not have a certificate authority for the certificate provided by ${this.url}`),s.isHandled=!0):s.code!=="ECONNREFUSED"&&(s.code==="UNABLE_TO_VERIFY_LEAF_SIGNATURE"?fe.error?.(`Can not connect to ${this.url}, the certificate provided by ${this.url} is not trusted, this node needs to be added to the cluster, or a certificate authority needs to be added`):fe.error?.(`Error in connection to ${this.url} due to ${s.message}`)),this.sessionReject(s)}),this.socket.on("close",(s,i)=>{if(this.isConnected&&(_u({name:this.nodeName,database:this.databaseName,url:this.url,finished:this.socket.isFinished}),this.isConnected=!1),this.socket.isFinished){this.isFinished=!0,n?.end(),this.emit("finished");return}if(++this.retries%20===1){let o=i?.toString();fe.warn?.(`${n?"Disconnected from":"Failed to connect to"} ${this.url} (db: "${this.databaseName}"), due to ${o?'"'+o+'" ':""}(code: ${s})`)}n=null,this.resetSession(),setTimeout(()=>{this.connect()},this.retryTime).unref(),this.retryTime+=this.retryTime>>3})}resetSession(){this.session=new Promise((r,n)=>{this.sessionResolve=r,this.sessionReject=n})}subscribe(r,n){this.nodeSubscriptions=r,this.replicateTablesByDefault=n,this.emit("subscriptions-updated",r)}unsubscribe(){this.socket.isFinished=!0,this.socket.close(1008,"No longer subscribed")}getRecord(r){return this.session.then(n=>n.getRecord(r))}};a(Yp,"replicateOverWS");a(qy,"ensureTableIfChanged")});var ca={};je(ca,{clearThisNodeName:()=>Sre,disableReplication:()=>Ere,enabled_databases:()=>la,forEachReplicatedDatabase:()=>ta,getThisNodeId:()=>Wp,getThisNodeName:()=>ot,getThisNodeUrl:()=>ra,hostnameToUrl:()=>Jp,lastTimeInAuditStore:()=>W_,monitorNodeCAs:()=>IH,replicateOperation:()=>gre,replication_certificate_authorities:()=>Dc,sendOperationToNode:()=>of,servers:()=>_re,setReplicator:()=>CH,start:()=>fre,startOnMainThread:()=>Ty,subscribeToNode:()=>du,unsubscribeFromNode:()=>Bp,urlToNodeName:()=>zs});function fre(e){if(e.port||(e.port=ps.default.get(Mc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=ps.default.get(Mc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),!ot())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let n of z_(e))t.set(zs(n.url),n);hre(e),e={mtls:!0,isOperationsServer:!0,maxPayload:10*1024*1024*1024,...e};let r=it.ws(async(n,s,i,o)=>{if(s.headers.get("sec-websocket-protocol")!=="harperdb-replication-v1")return o(n,s,i);await i,n._socket.unref(),Yp(n,e,s?.user),n.on("error",c=>{c.code!=="ECONNREFUSED"&&Tr.error("Error in connection to "+this.url,c.message)})},e);e.runFirst=!0,it.http((n,s)=>{if(n.isWebSocket&&n.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){!n.authorized&&n._nodeRequest.socket.authorizationError&&Tr.error(`Incoming client connection from ${n.ip} did not have valid certificate, you may need turn on enableRootCAs in the config if you are using a publicly signed certificate, or add the CA to the server's trusted CAs`,n._nodeRequest.socket.authorizationError);let i=Sr().primaryStore;if(n.authorized&&n.peerCertificate.subject){let o=n.peerCertificate.subject,c=o&&(i.get(o.CN)||t.get(o.CN));c?n.user=c:Tr.warn(`No node found for certificate common name ${o.CN}, available nodes are ${Array.from(i.getRange({}).filter(({value:l})=>l).map(({key:l})=>l)).join(", ")} and routes ${Array.from(t.keys()).join(", ")}, connection will require credentials.`)}else{let o=i.get(n.ip)||t.get(n.ip);o?n.user=o:Tr.warn(`No node found for IP address ${n.ip}, available nodes are ${Array.from(new Set([...i.getKeys(),...t.keys()])).join(", ")}, connection will require credentials.`)}}return s(n)},e);for(let n of r)if(n.secureContexts){let s=a(()=>{let i=new Set(n.secureContexts.values());n.defaultContext&&i.add(n.defaultContext);for(let o of i)try{let c=Array.from(Dc);o.options.availableCAs&&c.push(...o.options.availableCAs.values());let l={...o.options,ca:c};o.replicationContext=Qp.createSecureContext(l)}catch(c){Tr.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),IH(s),ps.default.get(Mc.CONFIG_PARAMS.REPLICATION_ENABLEROOTCAS)!==!1&&s()}}function IH(e){let t=0;cu(r=>{r?.ca&&(Dc.add(r.ca),Dc.size!==t&&(t=Dc.size,e?.()))})}function Ere(e=!0){NH=e}function hre(e){NH||(ut(),la=e.databases,ta(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||Cc;for(let[s,i]of 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];CH(r,s,e),SH.get(s)?.forEach(i=>i(s))}}))}function CH(e,t,r){if(!t)return console.error(`Attempt to replicate non-existent table ${t.name} from database ${e}`);if(t.replicate===!1||t.sources?.some(s=>s.isReplicator))return;let n;t.sourcedFrom(class wH extends Lr{static{a(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||Cc,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(Tr.trace("Setting up replicator subscription to database",e),!o?.auditStore)return this.subscription=o=new Mn,i.set(e,o),o.tableById=c,o.auditStore=t.auditStore,o.dbisDB=t.dbisDB,o.databaseName=e,l&&l(o),o;this.subscription=o}static subscribeOnThisThread(i,o){return!0}static async load(i){if(i){let o=i.residencyId,c=i.residency||t.dbisDB.get([Symbol.for("residency_by_id"),o]);if(c){let l,u=new Set;do{let d;for(let E of c){let f=pre(E,wH.subscription,e);f?.isConnected&&!u.has(f)&&(!d||f.latency<d.latency)&&(d=f)}if(!d)throw l||new bH.ServerError("No connection to any other nodes are available",502);let _={requestId:dre++,table:t,entry:i,id:i.key};u.add(d);try{return await d.getRecord(_)}catch(E){if(d.isConnected)throw E;Tr.warn("Error in load from node",zp,E),l||(l=E)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function DH(e,t,r,n,s){let i=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 pre(e,t,r){let n=gH.get(e)?.get(r);if(n)return n;let s=Sr().primaryStore.get(e);return s?.url&&(n=DH(s.url,t,r,e,s.authorization),gH.set(e,sf.get(s.url))),n}async function of(e,t,r){r||(r={}),r.serverName=e.name;let n=await Ky(e.url,r),s=Yp(n,{},{});return new Promise((i,o)=>{n.on("open",()=>{i(s.sendOperation(t))}),n.on("error",c=>{o(c)}),n.on("close",c=>{Tr.info("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function du(e){try{OH.isMainThread&&Tr.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=Cc.get(e.database);if(!t){let n;t=new Promise(s=>{Tr.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,Cc.set(e.database,t)}let r=DH(e.nodes[0].url,t,e.database,e.nodes[0].name,e.nodes[0].authorization);e.nodes[0].name===void 0?r.tentativeNode=e.nodes[0]:r.nodeName=e.nodes[0].name,r.subscribe(e.nodes.filter(n=>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 mre(){if(Wy!==void 0)return Wy;let e=ps.default.get(Mc.CONFIG_PARAMS.OPERATIONSAPI_TLS_CERTIFICATE)||ps.default.get(Mc.CONFIG_PARAMS.TLS_CERTIFICATE);if(e)return Wy=new RH.X509Certificate((0,yH.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function ot(){return zp||(zp=ps.default.get("replication_hostname")??zs(ps.default.get("replication_url"))??mre()??AH("operationsapi_network_secureport")??AH("operationsapi_network_port")??"127.0.0.1")}function Sre(){zp=void 0}function AH(e){let t=ps.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function jp(e){let t=ps.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function Wp(e){return Y_(e)?.[ot()]}function ra(){let e=ps.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 nf(n=>{r(n)}),Lc((n,s)=>{r(n.databaseName)});function r(n){let s=We[n];Tr.trace("Checking replication status of ",n,e?.databases),e?.databases===void 0||e.databases==="*"||e.databases.includes(n)||e.databases.some?.(i=>i.name===n)||!s?t(s,n,!0):Tre(n)&&t(s,n,!1)}a(r,"forDatabase")}function Tre(e){let t=We[e];for(let r in t)if(t[r].replicate)return!0}function W_(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=>of(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 ps,Tr,RH,yH,Mc,Qp,bH,OH,NH,dre,_re,Dc,la,sf,gH,Wy,zp,ds=Ie(()=>{Pe();Vs();Ll();TH();qr();ps=L(se()),Tr=L(W()),RH=require("crypto"),yH=require("fs");Q_();lu();Mc=L(M());_y();Qp=L(require("node:tls")),bH=L(_e()),OH=require("worker_threads"),dre=1,_re=[],Dc=ps.default.get(Mc.CONFIG_PARAMS.REPLICATION_ENABLEROOTCAS)!==!1?new Set(Qp.rootCertificates):new Set;a(fre,"start");a(IH,"monitorNodeCAs");a(Ere,"disableReplication");a(hre,"assignReplicationSource");a(CH,"setReplicator");sf=new Map;a(DH,"getConnection");gH=new Map;a(pre,"getConnectionByName");a(of,"sendOperationToNode");a(du,"subscribeToNode");a(Bp,"unsubscribeFromNode");a(mre,"getCommonNameFromCert");a(ot,"getThisNodeName");a(Sre,"clearThisNodeName");Object.defineProperty(it,"hostname",{get(){return ot()}});a(AH,"getHostFromListeningPort");a(jp,"getPortFromListeningPort");a(Wp,"getThisNodeId");it.replication={getThisNodeId:Wp,exportIdMapping:Y_};a(ra,"getThisNodeUrl");a(Jp,"hostnameToUrl");a(zs,"urlToNodeName");a(ta,"forEachReplicatedDatabase");a(Tre,"hasExplicitlyReplicatedTable");a(W_,"lastTimeInAuditStore");a(gre,"replicateOperation")});var tm=N((EIe,vH)=>{"use strict";var Su=Uh(),Tu=o0(),Are=W(),Rre=require("uuid").v4,fIe=require("clone"),Zp=no(),gu=M(),yre=require("util"),ua=Bn(),{handleHDBError:mn,hdb_errors:bre}=_e(),{HDB_ERROR_MSGS:Xp,HTTP_STATUS_CODES:Sn}=bre,{SchemaEventMsg:em}=qs(),PH=mr(),{getDatabases:Ore}=(Pe(),oe(lt)),{transformReq:Au}=te(),{replicateOperation:LH}=(ds(),oe(ca));vH.exports={createSchema:Nre,createSchemaStructure:MH,createTable:Ire,createTableStructure:UH,createAttribute:Lre,dropSchema:wre,dropTable:Cre,dropAttribute:Dre,getBackup:Mre};async function Nre(e){let t=await MH(e);return Zp.signalSchemaChange(new em(process.pid,e.operation,e.schema)),t}a(Nre,"createSchema");async function MH(e){let t=Su.schema_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);if(Au(e),!await Tu.checkSchemaExists(e.schema))throw mn(new Error,Xp.SCHEMA_EXISTS_ERR(e.schema),Sn.BAD_REQUEST,gu.LOG_LEVELS.ERROR,Xp.SCHEMA_EXISTS_ERR(e.schema),!0);return await ua.createSchema(e),`database '${e.schema}' successfully created`}a(MH,"createSchemaStructure");async function Ire(e){return Au(e),e.hash_attribute=e.primary_key??e.hash_attribute,await UH(e)}a(Ire,"createTable");async function UH(e){let t=Su.create_table_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);if(Su.validateTableResidence(e.residence),!await Tu.checkSchemaTableExists(e.schema,e.table))throw mn(new Error,Xp.TABLE_EXISTS_ERR(e.schema,e.table),Sn.BAD_REQUEST,gu.LOG_LEVELS.ERROR,Xp.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:Rre(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await ua.createTable(n,e);else throw mn(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Sn.BAD_REQUEST);else await ua.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(UH,"createTableStructure");async function wre(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=Su.schema_object(e),n=t??r;if(n)throw mn(n,n.message,Sn.BAD_REQUEST,void 0,void 0,!0);Au(e);let s=await Tu.checkSchemaExists(e.schema);if(s)throw mn(new Error,s,Sn.NOT_FOUND,gu.LOG_LEVELS.ERROR,s,!0);let i=await Tu.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);await ua.dropSchema(e),Zp.signalSchemaChange(new em(process.pid,e.operation,e.schema)),await PH.purgeSchemaTableStreams(e.schema,o);let c=await LH(e);return c.message=`successfully deleted '${e.schema}'`,c}a(wre,"dropSchema");async function Cre(e){let t=Su.table_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);Au(e);let r=await Tu.checkSchemaTableExists(e.schema,e.table);if(r)throw mn(new Error,r,Sn.NOT_FOUND,gu.LOG_LEVELS.ERROR,r,!0);await ua.dropTable(e),await PH.purgeTableStream(e.schema,e.table);let n=await LH(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}a(Cre,"dropTable");async function Dre(e){let t=Su.attribute_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);Au(e);let r=await Tu.checkSchemaTableExists(e.schema,e.table);if(r)throw mn(new Error,r,Sn.NOT_FOUND,gu.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw mn(new Error,"You cannot drop a hash attribute",Sn.BAD_REQUEST,void 0,void 0,!0);if(gu.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw mn(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Sn.BAD_REQUEST,void 0,void 0,!0);try{return await ua.dropAttribute(e),Pre(e),Zp.signalSchemaChange(new em(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw Are.error(`Got an error deleting attribute ${yre.inspect(e)}.`),n}}a(Dre,"dropAttribute");function Pre(e){let t=Object.values(global.hdb_schema[e.schema][e.table].attributes);for(let r=0;r<t.length;r++)t[r].attribute===e.attribute&&global.hdb_schema[e.schema][e.table].attributes.splice(r,1)}a(Pre,"dropAttributeFromGlobal");async function Lre(e){Au(e);let t=Ore()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw mn(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Sn.BAD_REQUEST,void 0,void 0,!0);return await ua.createAttribute(e),Zp.signalSchemaChange(new em(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(Lre,"createAttribute");function Mre(e){return ua.getBackup(e)}a(Mre,"getBackup")});var HH=N((pIe,BH)=>{"use strict";var{OPERATIONS_ENUM:Ure}=M(),jy=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Ure.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};BH.exports=jy});var zy=N((TIe,qH)=>{"use strict";var vre=Bn(),SIe=HH(),rm=te(),nm=M(),Bre=se(),{handleHDBError:xH,hdb_errors:Hre}=_e(),{HDB_ERROR_MSGS:kH,HTTP_STATUS_CODES:FH}=Hre,xre=Object.values(nm.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),GH="To use this operation audit log must be enabled in harperdb-config.yaml";qH.exports=kre;async function kre(e){if(rm.isEmpty(e.schema))throw new Error(kH.SCHEMA_REQUIRED_ERR);if(rm.isEmpty(e.table))throw new Error(kH.TABLE_REQUIRED_ERR);if(!Bre.get(nm.CONFIG_PARAMS.LOGGING_AUDITLOG))throw xH(new Error,GH,FH.BAD_REQUEST,nm.LOG_LEVELS.ERROR,GH,!0);let t=rm.checkSchemaTableExist(e.schema,e.table);if(t)throw xH(new Error,t,FH.NOT_FOUND,nm.LOG_LEVELS.ERROR,t,!0);if(!rm.isEmpty(e.search_type)&&xre.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await vre.readAuditLog(e)}a(kre,"readAuditLog")});var VH=N((AIe,$H)=>{"use strict";var{OPERATIONS_ENUM:Fre}=M(),Qy=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Fre.GET_BACKUP,this.schema=t,this.table=r}};$H.exports=Qy});var WH=N((OIe,YH)=>{"use strict";var Gre=Bn(),yIe=VH(),Jy=te(),qre=M(),bIe=se(),{handleHDBError:$re,hdb_errors:Vre}=_e(),{HDB_ERROR_MSGS:KH,HTTP_STATUS_CODES:Kre}=Vre;YH.exports=Yre;async function Yre(e){if(Jy.isEmpty(e.schema))throw new Error(KH.SCHEMA_REQUIRED_ERR);if(Jy.isEmpty(e.table))throw new Error(KH.TABLE_REQUIRED_ERR);let t=Jy.checkSchemaTableExist(e.schema,e.table);if(t)throw $re(new Error,t,Kre.NOT_FOUND,qre.LOG_LEVELS.ERROR,t,!0);return await Gre.getBackup(read_audit_log_object)}a(Yre,"getBackup")});var ZH=N((IIe,XH)=>{var Ru=require("validate.js"),zH=Tt(),yu=M(),{handleHDBError:Wre,hdb_errors:jre}=_e(),{HDB_ERROR_MSGS:Qt,HTTP_STATUS_CODES:zre}=jre,Xy=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Qre={STRUCTURE_USER:"structure_user"},jH=Object.values(yu.ROLE_TYPES_ENUM),Jre="attribute_permissions",Xre="attribute_name",{PERMS_CRUD_ENUM:bu}=yu,Zre=[Jre,...Object.values(bu)],QH=[bu.READ,bu.INSERT,bu.UPDATE],ene=[Xre,...QH];function tne(e){let t=Xy();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,JH(e,t)}a(tne,"addRoleValidation");function rne(e){let t=Xy();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,JH(e,t)}a(rne,"alterRoleValidation");function nne(e){let t=Xy();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,zH.validateObject(e,t)}a(nne,"dropRoleValidation");var sne=["operation","role","id","permission","hdb_user","hdb_auth_header","access"];function JH(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)sne.includes(n[o])||s.push(n[o]);s.length>0&&ir(Qt.INVALID_ROLE_JSON_KEYS(s),r);let i=zH.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{ir(o,r)}),e.permission){let o=ine(e);o&&ir(o,r),jH.forEach(c=>{e.permission[c]&&!Ru.isBoolean(e.permission[c])&&ir(Qt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(jH.indexOf(o)<0){if(o===Qre.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let u=0,d=l.length;u<d;u++){let _=l[u];global.hdb_schema[_]||ir(Qt.SCHEMA_NOT_FOUND(_),r)}continue}ir(Qt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){ir(Qt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let u=c.tables[l];if(!l||!global.hdb_schema[o][l]){ir(Qt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(d=>{Zre.includes(d)||ir(Qt.INVALID_PERM_KEY(d),r,o,l)}),Object.values(bu).forEach(d=>{Ru.isDefined(u[d])?Ru.isBoolean(u[d])||ir(Qt.TABLE_PERM_NOT_BOOLEAN(d),r,o,l):ir(Qt.TABLE_PERM_MISSING(d),r,o,l)}),u.attribute_permissions===void 0){ir(Qt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){ir(Qt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}if(u.attribute_permissions){let d=global.hdb_schema[o][l].attributes.map(({attribute:E})=>E),_={read:!1,insert:!1,update:!1};for(let E in u.attribute_permissions){let f=u.attribute_permissions[E];if(Object.keys(f).forEach(T=>{!ene.includes(T)&&T!==bu.DELETE&&ir(Qt.INVALID_ATTR_PERM_KEY(T),r,o,l)}),!Ru.isDefined(f.attribute_name)){ir(Qt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=f.attribute_name;if(!d.includes(h)){ir(Qt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}QH.forEach(T=>{Ru.isDefined(f[T])?Ru.isBoolean(f[T])||ir(Qt.ATTR_PERM_NOT_BOOLEAN(T,h),r,o,l):ir(Qt.ATTR_PERM_MISSING(T,h),r,o,l)}),!_.read&&f.read===!0&&(_.read=!0),!_.insert&&f.insert===!0&&(_.insert=!0),!_.update&&f.update===!0&&(_.update=!0)}if(u.read===!1&&_.read===!0||u.insert===!1&&_.insert===!0||u.update===!1&&_.update===!0){let E=`${o}.${l}`;ir(Qt.MISMATCHED_TABLE_ATTR_PERMS(E),r,o,l)}}}}return one(r)}a(JH,"customValidate");XH.exports={addRoleValidation:tne,alterRoleValidation:rne,dropRoleValidation:nne};function ine(e){let{operation:t,permission:r}=e;if(t===yu.OPERATIONS_ENUM.ADD_ROLE||t===yu.OPERATIONS_ENUM.ALTER_ROLE){let n=r.super_user===!0,s=r.cluster_user===!0;if(Object.keys(r).length>1&&(n||s)){if(s&&n)return Qt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?yu.ROLE_TYPES_ENUM.SUPER_USER:yu.ROLE_TYPES_ENUM.CLUSTER_USER;return Qt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(ine,"validateNoSUPerms");function one(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:Qt.ROLE_PERMS_ERROR,...e};return Wre(new Error,n,zre.BAD_REQUEST)}else return null}a(one,"generateRolePermResponse");function ir(e,t,r,n){if(!r)t.main_permissions.push(e);else{let s=n?r+"_"+n:r;t.schema_permissions[s]?t.schema_permissions[s].push(e):t.schema_permissions[s]=[e]}}a(ir,"addPermError")});var cf=N((DIe,nx)=>{"use strict";var ex=un(),tx=Vr(),ane=dc(),eb=ZH(),tb=no(),CIe=require("uuid").v4,cne=require("util"),sm=M(),lne=te(),rb=tx.searchByValue,une=tx.searchByHash,dne=cne.promisify(ane.delete),_ne=$s(),fne=jl(),{hdb_errors:Ene,handleHDBError:Uc}=_e(),{HDB_ERROR_MSGS:rx,HTTP_STATUS_CODES:af}=Ene,{UserEventMsg:nb}=qs();nx.exports={addRole:hne,alterRole:pne,dropRole:mne,listRoles:Sne};function Zy(e){try{e.hdb_auth_header&&delete e.hdb_auth_header,e.HDB_INTERNAL_PATH&&delete e.HDB_INTERNAL_PATH,e.operation&&delete e.operation,e.hdb_user&&delete e.hdb_user}catch{}return e}a(Zy,"scrubRoleDetails");async function hne(e){let t=eb.addRoleValidation(e);if(t)throw t;e=Zy(e);let r={schema:"system",table:"hdb_role",search_attribute:"role",search_value:e.role,hash_attribute:"id",get_attributes:["*"]},n;try{n=Array.from(await rb(r)||[])}catch(i){throw Uc(i)}if(n&&n.length>0)throw Uc(new Error,rx.ROLE_ALREADY_EXISTS(e.role),af.CONFLICT,void 0,void 0,!0);e.id||(e.id=e.role);let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await ex.insert(s),tb.signalUserChange(new nb(process.pid)),e=Zy(e),e}a(hne,"addRole");async function pne(e){let t=eb.alterRoleValidation(e);if(t)throw t;e=Zy(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await ex.update(r)}catch(s){throw Uc(s)}if(n&&n?.message==="updated 0 of 1 records")throw Uc(new Error,"Invalid role id",af.BAD_REQUEST,void 0,void 0,!0);return await tb.signalUserChange(new nb(process.pid)),e}a(pne,"alterRole");async function mne(e){let t=eb.dropRoleValidation(e);if(t)throw Uc(new Error,t,af.BAD_REQUEST,void 0,void 0,!0);let r=new fne(sm.SYSTEM_SCHEMA_NAME,sm.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await une(r));if(n.length===0)throw Uc(new Error,rx.ROLE_NOT_FOUND,af.NOT_FOUND,void 0,void 0,!0);let s=new _ne(sm.SYSTEM_SCHEMA_NAME,sm.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await rb(s)),o=!1;if(lne.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw Uc(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,af.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await dne(c),tb.signalUserChange(new nb(process.pid)),`${n[0].role} successfully deleted`}a(mne,"dropRole");async function Sne(){return rb({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Sne,"listRoles")});var ax=N((LIe,ox)=>{"use strict";var Tne=se(),da=require("joi"),gne=Tt(),sx=require("moment"),Ane=require("fs-extra"),sb=require("path"),Rne=require("lodash"),lf=M(),{LOG_LEVELS:vc}=M(),yne="YYYY-MM-DD hh:mm:ss",bne=sb.resolve(__dirname,"../logs");ox.exports=function(e){return gne.validateBySchema(e,One)};var One=da.object({from:da.custom(ix),until:da.custom(ix),level:da.valid(vc.NOTIFY,vc.FATAL,vc.ERROR,vc.WARN,vc.INFO,vc.DEBUG,vc.TRACE),order:da.valid("asc","desc"),limit:da.number().min(1),start:da.number().min(0),log_name:da.custom(Nne)});function ix(e,t){if(sx(e,sx.ISO_8601).format(yne)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(ix,"validateDatetime");function Nne(e,t){if(Rne.invert(lf.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=Tne.get(lf.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?lf.LOG_NAMES.HDB:e,i=s===lf.LOG_NAMES.INSTALL?sb.join(bne,lf.LOG_NAMES.INSTALL):sb.join(n,s);return Ane.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(Nne,"validateReadLogPath")});var ob=N((UIe,lx)=>{"use strict";var im=M(),Ine=W(),wne=se(),Cne=ax(),ib=require("path"),cx=require("fs-extra"),{once:Dne}=require("events"),{handleHDBError:Pne,hdb_errors:Lne}=_e(),{PACKAGE_ROOT:Mne}=M(),Une=ib.join(Mne,"logs"),vne=1e3,Bne=200;lx.exports=Hne;async function Hne(e){let t=Cne(e);if(t)throw Pne(t,t.message,Lne.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=wne.get(im.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?im.LOG_NAMES.HDB:e.log_name,s=n===im.LOG_NAMES.INSTALL?ib.join(Une,im.LOG_NAMES.INSTALL):ib.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,l=c?new Date(e.from):void 0,u=e.until!==void 0,d=u?new Date(e.until):void 0,_=e.limit===void 0?vne:e.limit,E=e.order===void 0?void 0:e.order,f=e.start===void 0?0:e.start,h=f+_,T=0;E==="desc"&&!l&&!d&&(T=Math.max(cx.statSync(s).size-(h+5)*Bne,0));let m=cx.createReadStream(s,{start:T});m.on("error",H=>{Ine.error(H)});let g=0,S=[],y="",I;m.on("data",H=>{let X=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;H=y+H;let Y=0,V;for(;(V=X.exec(H))&&!m.destroyed;){I&&(I.message=H.slice(Y,V.index),U(I));let[ne,Q,de]=V,j=de.split("] ["),ae=j[0],Oe=j[1];j.splice(0,2),I={timestamp:Q,thread:ae,level:Oe,tags:j,message:""},Y=V.index+ne.length}y=H.slice(Y)}),m.on("end",H=>{m.destroyed||I&&(I.message=y.trim(),U(I))}),m.resume();function U(H){let X,Y,V;switch(!0){case(i&&c&&u):X=new Date(H.timestamp),Y=new Date(l),V=new Date(d),H.level===o&&X>=Y&&X<=V&&g<f?g++:H.level===o&&X>=Y&&X<=V&&(_a(H,E,S),g++,g===h&&m.destroy());break;case(i&&c):X=new Date(H.timestamp),Y=new Date(l),H.level===o&&X>=Y&&g<f?g++:H.level===o&&X>=Y&&(_a(H,E,S),g++,g===h&&m.destroy());break;case(i&&u):X=new Date(H.timestamp),V=new Date(d),H.level===o&&X<=V&&g<f?g++:H.level===o&&X<=V&&(_a(H,E,S),g++,g===h&&m.destroy());break;case(c&&u):X=new Date(H.timestamp),Y=new Date(l),V=new Date(d),X>=Y&&X<=V&&g<f?g++:X>=Y&&X<=V&&(_a(H,E,S),g++,g===h&&m.destroy());break;case i:H.level===o&&g<f?g++:H.level===o&&(_a(H,E,S),g++,g===h&&m.destroy());break;case c:X=new Date(H.timestamp),Y=new Date(l),X>=Y&&g<f?g++:X>=Y&&g>=f&&(_a(H,E,S),g++,g===h&&m.destroy());break;case u:X=new Date(H.timestamp),V=new Date(d),X<=V&&g<f?g++:X<=V&&g>=f&&(_a(H,E,S),g++,g===h&&m.destroy());break;default:g<f?g++:(_a(H,E,S),g++,g===h&&m.destroy())}}return a(U,"onLogMessage"),await Dne(m,"close"),S}a(Hne,"readLog");function _a(e,t,r){t==="desc"?xne(e,r):t==="asc"?kne(e,r):r.push(e)}a(_a,"pushLineToResult");function xne(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)>r?n=i+1:s=i}t.splice(n,0,e)}a(xne,"insertDescending");function kne(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)<r?n=i+1:s=i}t.splice(n,0,e)}a(kne,"insertAscending")});var om=N((FIe,fx)=>{"use strict";var ab=require("joi"),{string:Ou,boolean:ux,date:Fne}=ab.types(),Gne=Tt(),{validateSchemaExists:BIe,validateTableExists:HIe,validateSchemaName:xIe}=gi(),qne=M(),$ne=Ct(),dx=se();dx.initSync();var kIe=Ou.invalid(dx.get(qne.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern($ne.NATS_TERM_CONSTRAINTS_RX).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >","any.invalid":"'node_name' cannot be this nodes name"}).empty(null),_x={operation:Ou.valid("add_node","update_node","set_node_replication"),node_name:Ou.optional(),subscriptions:ab.array().items({table:Ou.optional(),schema:Ou.optional(),database:Ou.optional(),subscribe:ux.required(),publish:ux.required().custom(Kne),start_time:Fne.iso()})};function Vne(e){return Gne.validateBySchema(e,ab.object(_x))}a(Vne,"addUpdateNodeValidator");function Kne(e,t){if(t.state.ancestors[2].operation==="add_node"&&e===!1&&t.state.ancestors[0].subscribe===!1)return t.message(`'subscriptions[${t.state.path[1]}]' subscribe and/or publish must be set to true when adding a node`)}a(Kne,"checkForFalsy");fx.exports={addUpdateNodeValidator:Vne,validation_schema:_x}});var hx=N((qIe,Ex)=>{var Yne=Tt(),Wne={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};Ex.exports=function(e){return Yne.validateObject(e,Wne)}});var cb=N((VIe,Sx)=>{"use strict";var jne=hx(),Nu=require("passport"),zne=require("passport-local").Strategy,Qne=require("passport-http").BasicStrategy,Jne=require("util"),Xne=xn(),mx=Jne.callbackify(Xne.findAndValidateUser),$Ie=Dn(),Zne=M(),px=fu();Nu.use(new zne(function(e,t,r){mx(e,t,r)}));Nu.use(new Qne(function(e,t,r){mx(e,t,r)}));Nu.serializeUser(function(e,t){t(null,e)});Nu.deserializeUser(function(e,t){t(null,e)});function ese(e,t,r){if(e.raw?.user!==void 0)return r(null,e.raw.user);let n,s;if(e.headers?.authorization){let o=e.headers.authorization.split(" ");n=o[0],s=o[1]}function i(o,c){return o?r(o):c?r(null,c):r("Must login")}switch(a(i,"handleResponse"),n){case"Basic":Nu.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===Zne.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?px.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):px.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:Nu.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(ese,"authorize");function tse(e,t){let r=jne(e);if(r){t(r);return}let n={authorized:!0,messages:[]},s=e.user.role;if(!s?.permission)return t("Invalid role");let i=JSON.parse(s.permission);if(i.super_user)return t(null,n);if(!i[e.schema])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.schema} schema`),t(null,n);if(!i[e.schema].tables[e.table])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.table} table`),t(null,n);if(!i[e.schema].tables[e.table][e.operation])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.operation} on ${e.table} table`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&!e.attributes)return n.authorized=!1,n.messages.push(`${e.schema}.${e.table} has attribute permissions. Missing attributes to validate`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&e.attributes){let o=i[e.schema].tables[e.table].attribute_permissions;for(let c in o)e.attributes.indexOf(o[c].attribute_name)>-1&&!o[c][e.operation]&&(n.authorized=!1,n.messages.push(`Not authorized to ${e.operation} ${o[c].attribute_name} `))}return t(null,n)}a(tse,"checkPermissions");Sx.exports={authorize:ese,checkPermissions:tse}});var Iu=N((YIe,Tx)=>{"use strict";var lb=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},ub=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};Tx.exports={Node:lb,NodeSubscription:ub}});var Ax=N((jIe,gx)=>{"use strict";var rse=M().OPERATIONS_ENUM,db=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=rse.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};gx.exports=db});var uf=N((QIe,Rx)=>{"use strict";var _b=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},fb=class{static{a(this,"RemotePayloadSubscription")}constructor(t,r,n,s,i,o,c){this.schema=t,this.table=r,this.hash_attribute=n,this.publish=s,this.subscribe=i,this.start_time=o,c!==void 0&&(this.attributes=c)}};Rx.exports={RemotePayloadObject:_b,RemotePayloadSubscription:fb}});var bx=N((XIe,yx)=>{"use strict";var Eb=class{static{a(this,"TableSizeObject")}constructor(t,r,n=0,s=0,i=0,o=0){this.schema=t,this.table=r,this.table_size=n,this.record_count=s,this.transaction_log_size=i,this.transaction_log_record_count=o}};yx.exports=Eb});var Nx=N((swe,Ox)=>{"use strict";var nse=bx(),ewe=Ht(),twe=ht(),sse=W(),{getSchemaPath:rwe,getTransactionAuditStorePath:nwe}=gt(),{getDatabases:ise}=(Pe(),oe(lt));Ox.exports=ose;async function ose(e){let t=new nse;try{let r=ise()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats();t.schema=e.schema,t.table=e.name,t.record_count=n.entryCount,t.transaction_log_record_count=s.entryCount}catch(r){sse.warn(`unable to stat table dbi due to ${r}`)}return t}a(ose,"lmdbGetTableSize")});var wx=N((owe,Ix)=>{"use strict";var hb=class{static{a(this,"SystemInformationObject")}constructor(t,r,n,s,i,o,c){this.system=t,this.time=r,this.cpu=n,this.memory=s,this.disk=i,this.network=o,this.harperdb_processes=c}};Ix.exports=hb});var Cu=N((_we,Lx)=>{"use strict";var ase=require("fs-extra"),cse=require("path"),Qr=require("systeminformation"),fa=W(),Cx=mr(),cwe=Ct(),wu=M(),lse=Nx(),use=ro(),{getThreadInfo:Dx}=dt(),df=se();df.initSync();var dse=wx(),{openEnvironment:lwe}=ht(),{getSchemaPath:uwe}=gt(),{database:dwe,databases:pb}=(Pe(),oe(lt)),am;Lx.exports={getHDBProcessInfo:gb,getNetworkInfo:Rb,getDiskInfo:Ab,getMemoryInfo:Tb,getCPUInfo:Sb,getTimeInfo:mb,getSystemInformation:yb,systemInformation:_se,getTableSize:bb,getMetrics:Ob};function mb(){return Qr.time()}a(mb,"getTimeInfo");async function Sb(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:u,...d}=await Qr.cpu();d.cpu_speed=await Qr.cpuCurrentSpeed();let{raw_currentload:_,raw_currentload_idle:E,raw_currentload_irq:f,raw_currentload_nice:h,raw_currentload_system:T,raw_currentload_user:m,cpus:g,...S}=await Qr.currentLoad();return S.cpus=[],g.forEach(y=>{let{raw_load:I,raw_load_idle:U,raw_load_irq:H,raw_load_nice:X,raw_load_system:Y,raw_load_user:V,...ne}=y;S.cpus.push(ne)}),d.current_load=S,d}catch(e){return fa.error(`error in getCPUInfo: ${e}`),{}}}a(Sb,"getCPUInfo");async function Tb(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Qr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return fa.error(`error in getMemoryInfo: ${e}`),{}}}a(Tb,"getMemoryInfo");async function gb(){let e={core:[],clustering:[]};try{let t=await Qr.processes(),r;try{r=Number.parseInt(await ase.readFile(cse.join(df.get(wu.CONFIG_PARAMS.ROOTPATH),wu.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===wu.NODE_ERROR_CODES.ENOENT)fa.warn("Unable to locate 'hdb.pid' file, try stopping and starting HarperDB. This could be because HarperDB is not running.");else throw n}t.list.forEach(n=>{n.pid===r?e.core.push(n):n.name==="nats-server"&&e.clustering.push(n)});for(let n of e.core)for(let s of t.list)s.pid===n.parentPid&&(s.name==="PM2"||s.command==="PM2")&&(n.parent="PM2");return e}catch(t){return fa.error(`error in getHDBProcessInfo: ${t}`),e}}a(gb,"getHDBProcessInfo");async function Ab(){let e={};try{if(!df.get(wu.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Qr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...u}=await Qr.fsStats();return e.read_write=u,e.size=await Qr.fsSize(),e}catch(t){return fa.error(`error in getDiskInfo: ${t}`),e}}a(Ab,"getDiskInfo");async function Rb(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return df.get(wu.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await Qr.networkInterfaceDefault(),e.latency=await Qr.inetChecksite("google.com"),(await Qr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:u,ieee8021xState:d,carrier_changes:_,...E}=n;e.interfaces.push(E)}),(await Qr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)})),e}catch(t){return fa.error(`error in getNetworkInfo: ${t}`),e}}a(Rb,"getNetworkInfo");async function yb(){if(am!==void 0)return am;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Qr.osInfo();e=c;let l=await Qr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,am=e,am}catch(t){return fa.error(`error in getSystemInformation: ${t}`),e}}a(yb,"getSystemInformation");async function bb(){let e=[],t=await use.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await lse(n));return e}a(bb,"getTableSize");async function Ob(){let e={};for(let t in pb){let r=e[t]={},n=r.tables={};for(let s in pb[t])try{let i=pb[t][s];if(!r.readers&&(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[u,d,_]=l.trim().split(" ");return{pid:u,thread:d,txnid:_}}),i.auditStore)){let{treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:d,entryCount:_,overflowPages:E}=i.auditStore.getStats();r.audit={treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:d,entryCount:_,overflowPages:E}}let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){fa.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(Ob,"getMetrics");async function Px(){if(df.get(wu.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await Cx.getNATSReferences(),t=await Cx.listStreams(),r=[];for(let n of t){let s=[],i=await e.consumers.list(n.config.name);for await(let c of i)s.push({name:c.name,created:c.created,num_ack_pending:c.num_ack_pending,num_redelivered:c.num_redelivered,num_waiting:c.num_waiting,num_pending:c.num_pending});let o={stream_name:n.config.name,database:n.config.subjects[0].split(".")[1],table:n.config.subjects[0].split(".")[2],state:n.state,consumers:s};r.push(o)}return r}}a(Px,"getNatsStreamInfo");async function _se(e){let t=new dse;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await yb(),t.time=mb(),t.cpu=await Sb(),t.memory=await Tb(),t.disk=await Ab(),t.network=await Rb(),t.harperdb_processes=await gb(),t.table_size=await bb(),t.metrics=await Ob(),t.threads=await Dx(),t.replication=await Px(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await yb();break;case"time":t.time=mb();break;case"cpu":t.cpu=await Sb();break;case"memory":t.memory=await Tb();break;case"disk":t.disk=await Ab();break;case"network":t.network=await Rb();break;case"harperdb_processes":t.harperdb_processes=await gb();break;case"table_size":t.table_size=await bb();break;case"database_metrics":case"metrics":t.metrics=await Ob();break;case"threads":t.threads=await Dx();break;case"replication":t.replication=await Px();break;default:break}return t}a(_se,"systemInformation")});var Bc=N((Ewe,Mx)=>{"use strict";Mx.exports={version:fse,printVersion:Ese};var cm=Xl();function fse(){if(cm)return cm.version}a(fse,"version");function Ese(){cm&&console.log(`HarperDB Version ${cm.version}`)}a(Ese,"printVersion")});var Pi=N((Swe,Hx)=>{"use strict";var hse=un(),Nb=te(),pse=require("util"),Hc=M(),Ux=se();Ux.initSync();var mse=cb(),vx=Vr(),{Node:pwe,NodeSubscription:mwe}=Iu(),Sse=jl(),Tse=Ax(),{RemotePayloadObject:gse,RemotePayloadSubscription:Ase}=uf(),{handleHDBError:Rse,hdb_errors:yse}=_e(),{HTTP_STATUS_CODES:bse,HDB_ERROR_MSGS:Ose}=yse,Nse=$s(),Ise=Cu(),wse=Bc(),{getDatabases:Cse}=(Pe(),oe(lt)),Dse=pse.promisify(mse.authorize),Pse=vx.searchByHash,Lse=vx.searchByValue;Hx.exports={authHeaderToUser:Mse,isEmpty:Use,getNodeRecord:vse,upsertNodeRecord:Bse,buildNodePayloads:Hse,checkClusteringEnabled:xse,getAllNodeRecords:kse,getSystemInfo:Fse,reverseSubscription:Bx};async function Mse(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await Dse(t,null),e}a(Mse,"authHeaderToUser");function Use(e){return e==null}a(Use,"isEmpty");async function vse(e){let t=new Sse(Hc.SYSTEM_SCHEMA_NAME,Hc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return Pse(t)}a(vse,"getNodeRecord");async function Bse(e){let t=new Tse(Hc.SYSTEM_SCHEMA_NAME,Hc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return hse.upsert(t)}a(Bse,"upsertNodeRecord");function Bx(e){if(Nb.isEmpty(e.subscribe)||Nb.isEmpty(e.publish))throw new Error("Received invalid subscription object");let{schema:t,table:r,hash_attribute:n}=e,s={schema:t,table:r,hash_attribute:n};return e.subscribe===!0&&e.publish===!1?(s.subscribe=!1,s.publish=!0):e.subscribe===!1&&e.publish===!0?(s.subscribe=!0,s.publish=!1):(s.subscribe=e.subscribe,s.publish=e.publish),s}a(Bx,"reverseSubscription");function Hse(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:u}=c,d=Nb.getTableHashAttribute(l,u),{subscribe:_,publish:E}=Bx(c),f=Cse()[l]?.[u],h=new Ase(l,u,d,E,_,c.start_time,f.schemaDefined?f.attributes:void 0);s.push(h)}return new gse(r,t,s,n)}a(Hse,"buildNodePayloads");function xse(){if(!Ux.get(Hc.CONFIG_PARAMS.CLUSTERING_ENABLED))throw Rse(new Error,Ose.CLUSTERING_NOT_ENABLED,bse.BAD_REQUEST,void 0,void 0,!0)}a(xse,"checkClusteringEnabled");async function kse(){let e=new Nse(Hc.SYSTEM_SCHEMA_NAME,Hc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await Lse(e))}a(kse,"getAllNodeRecords");async function Fse(){let e=await Ise.getSystemInformation();return{hdb_version:wse.version(),node_version:e.node_version,platform:e.platform}}a(Fse,"getSystemInfo")});var Ib=N((gwe,Kx)=>{"use strict";var lm=mr(),xx=te(),kx=Ct(),Fx=M(),um=W(),Gx=tm(),Gse=I_(),{RemotePayloadObject:qse}=uf(),{handleHDBError:qx,hdb_errors:$se}=_e(),{HTTP_STATUS_CODES:$x}=$se,{NodeSubscription:Vx}=Iu();Kx.exports=Vse;async function Vse(e,t){let r;try{r=await lm.request(`${t}.${kx.REQUEST_SUFFIX}`,new qse(Fx.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),um.trace("Response from remote describe all request:",r)}catch(o){um.error(`addNode received error from describe all request to remote node: ${o}`);let c=lm.requestErrorHandler(o,"add_node",t);throw qx(new Error,c,$x.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===kx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw qx(new Error,o,$x.INTERNAL_SERVER_ERROR,"error",o)}let n=r.message,s=[],i=[];for(let o of e){let{table:c}=o,l=o.database??o.schema??"data";if(l===Fx.SYSTEM_SCHEMA_NAME){await lm.createLocalTableStream(l,c);let h=new Vx(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let u=xx.doesSchemaExist(l),d=n[l]!==void 0,_=c?xx.doesTableExist(l,c):!0,E=c?n?.[l]?.[c]!==void 0:!0;if(!u&&!d||!_&&!E){s.push(o);continue}if(!u&&d&&(um.trace(`addNode creating schema: ${l}`),await Gx.createSchema({operation:"create_schema",schema:l})),!_&&E){um.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new Gse(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await Gx.createTable(h)}await lm.createLocalTableStream(l,c);let f=new Vx(l,c,o.publish,o.subscribe);f.start_time=o.start_time,i.push(f)}return{added:i,skipped:s}}a(Vse,"reviewSubscriptions")});var xc={};je(xc,{addNodeBack:()=>zse,removeNodeBack:()=>Qse,setNode:()=>jse});async function jse(e){e.node_name&&!e.hostname&&(e.hostname=e.node_name),e.verify_tls!==void 0&&(e.rejectUnauthorized=e.verify_tls);let{url:t,hostname:r}=e;t?r||(r=e.hostname=zs(t)):t=Jp(r);let n=(0,Wx.validateBySchema)(e,Wse);if(n)throw(0,uo.handleHDBError)(n,n.message,Yse.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new uo.ClientError("url or hostname is required for remove_node operation");let f=r,h=Sr(),T=await h.get(f);if(!T)throw new uo.ClientError(f+" does not exist");try{await of({url:T.url},{operation:_f.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,ms.getReplicationCert)();let f=await(0,ms.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,ms.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:_f.OPERATIONS_ENUM.ADD_NODE_BACK,hostname:(0,jx.get)(_f.CONFIG_PARAMS.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:o,cert_auth:c,authorization:e.retain_authorization?e.authorization:null};if(e.subscriptions?l.subscriptions=e.subscriptions.map(Yx):l.subscriptions=null,e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let f=Yx(e);l.subscribe=f.subscribe,l.publish=f.publish}e?.authorization?.username&&e?.authorization?.password&&(e.authorization="Basic "+Buffer.from(e.authorization.username+":"+e.authorization.password).toString("base64"));let u,d;try{u=await of({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,ms.setCertTable)({name:Kse.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,ms.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,ms.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,ms.getReplicationCertAuth)();if(n.replicates){let i={url:ra(),ca:s?.certificate,replicates:!0,subscriptions:null};e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await co(ot(),i)}return await co(e.hostname,n),t.nodeName=ot(),t.usingCA=s?.certificate,$n.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function Qse(e){$n.trace("removeNodeBack received request:",e),await Sr().delete(e.name)}function Yx(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var ms,Wx,Du,jx,_f,$n,uo,Kse,Yse,Wse,kc=Ie(()=>{ms=L(Xs()),Wx=L(Tt()),Du=L(require("joi")),jx=L(se()),_f=L(M());Q_();lu();ds();$n=L(W()),uo=L(_e()),{pki:Kse}=require("node-forge"),{HTTP_STATUS_CODES:Yse}=uo.hdb_errors,Wse=Du.default.object({hostname:Du.default.string(),verify_tls:Du.default.boolean(),replicates:Du.default.boolean(),subscriptions:Du.default.array()});a(jse,"setNode");a(zse,"addNodeBack");a(Qse,"removeNodeBack");a(Yx,"reverseSubscription")});var hf=N((wwe,Qx)=>{"use strict";var{handleHDBError:dm,hdb_errors:Jse}=_e(),{HTTP_STATUS_CODES:_m}=Jse,{addUpdateNodeValidator:Xse}=om(),fm=W(),Em=M(),zx=Ct(),Zse=te(),ff=mr(),Ef=Pi(),wb=se(),eie=Ib(),{Node:tie,NodeSubscription:rie}=Iu(),{broadcast:nie}=dt(),{setNode:sie}=(kc(),oe(xc)),Nwe=se(),Iwe=M(),iie="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",oie="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",aie=wb.get(Em.CONFIG_PARAMS.CLUSTERING_NODENAME);Qx.exports=cie;async function cie(e,t=!1){if(fm.trace("addNode called with:",e),wb.get(Em.CONFIG_PARAMS.REPLICATION_URL)||wb.get(Em.CONFIG_PARAMS.REPLICATION_HOSTNAME))return sie(e);Ef.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 Ef.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=Ef.buildNodePayloads(s,aie,Em.OPERATIONS_ENUM.ADD_NODE,await Ef.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 ff.request(`${n}.${zx.REQUEST_SUFFIX}`,c)}catch(_){fm.error(`addNode received error from request: ${_}`);for(let f=0,h=s.length;f<h;f++){let T=s[f];T.publish=!1,T.subscribe=!1,await ff.updateRemoteConsumer(T,n)}let E=ff.requestErrorHandler(_,"add_node",n);throw dm(new Error,E,_m.INTERNAL_SERVER_ERROR,"error",E)}if(u.status===zx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let _=`Error returned from remote node ${n}: ${u.message}`;throw dm(new Error,_,_m.INTERNAL_SERVER_ERROR,"error",_)}fm.trace(u);for(let _=0,E=s.length;_<E;_++){let f=s[_];await ff.updateRemoteConsumer(f,n),f.subscribe===!0&&await ff.updateConsumerIterator(f.schema,f.table,n,"start")}let d=new tie(n,l,u.system_info);return await Ef.upsertNodeRecord(d),nie({type:"nats_update"}),i.length>0?o.message=oie:o.message=`Successfully added '${n}' to manifest`,o}a(cie,"addNode")});var Lb=N((Pwe,Xx)=>{"use strict";var{handleHDBError:Cb,hdb_errors:lie}=_e(),{HTTP_STATUS_CODES:Db}=lie,{addUpdateNodeValidator:uie}=om(),pf=W(),hm=M(),Jx=Ct(),Dwe=te(),mf=mr(),Sf=Pi(),Pb=se(),{cloneDeep:die}=require("lodash"),_ie=Ib(),{Node:fie,NodeSubscription:Eie}=Iu(),{broadcast:hie}=dt(),{setNode:pie}=(kc(),oe(xc)),mie="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",Sie="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Tie=Pb.get(hm.CONFIG_PARAMS.CLUSTERING_NODENAME);Xx.exports=gie;async function gie(e){if(pf.trace("updateNode called with:",e),Pb.get(hm.CONFIG_PARAMS.REPLICATION_URL)??Pb.get(hm.CONFIG_PARAMS.REPLICATION_HOSTNAME))return pie(e);Sf.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 Sf.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=Sf.buildNodePayloads(i,Tie,hm.OPERATIONS_ENUM.UPDATE_NODE,await Sf.getSystemInfo());for(let d=0,_=i.length;d<_;d++){let E=i[d];pf.trace(`updateNode updating work stream for node: ${r} subscription:`,E),i[d].start_time===void 0&&delete i[d].start_time}pf.trace("updateNode sending remote payload:",l);let u;try{u=await mf.request(`${r}.${Jx.REQUEST_SUFFIX}`,l)}catch(d){pf.error(`updateNode received error from request: ${d}`);let _=mf.requestErrorHandler(d,"update_node",r);throw Cb(new Error,_,Db.INTERNAL_SERVER_ERROR,"error",_)}if(u.status===Jx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${r}: ${u.message}`;throw Cb(new Error,d,Db.INTERNAL_SERVER_ERROR,"error",d)}pf.trace(u);for(let d=0,_=i.length;d<_;d++){let E=i[d];await mf.updateRemoteConsumer(E,r),E.subscribe===!0?await mf.updateConsumerIterator(E.schema,E.table,r,"start"):await mf.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 Sf.upsertNodeRecord(n),hie({type:"nats_update"})}a(Aie,"updateNodeTable")});var nk=N((Mwe,rk)=>{"use strict";var tk=require("joi"),{string:Zx}=tk.types(),Rie=Tt(),ek=M(),yie=se(),bie=Ct();rk.exports=Oie;function Oie(e){let t=Zx.invalid(yie.get(ek.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(bie.NATS_TERM_CONSTRAINTS_RX).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >","any.invalid":"'node_name' cannot be this nodes name"}).empty(null),r=tk.object({operation:Zx.valid(ek.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return Rie.validateBySchema(e,r)}a(Oie,"removeNodeValidator")});var gf=N((vwe,ck)=>{"use strict";var{handleHDBError:sk,hdb_errors:Nie}=_e(),{HTTP_STATUS_CODES:ik}=Nie,Iie=nk(),Tf=W(),ok=Pi(),wie=te(),Pu=M(),ak=Ct(),Mb=mr(),Ub=se(),{RemotePayloadObject:Cie}=uf(),{NodeSubscription:Die}=Iu(),Pie=N_(),Lie=dc(),{broadcast:Mie}=dt(),{setNode:Uie}=(kc(),oe(xc)),vie=Ub.get(Pu.CONFIG_PARAMS.CLUSTERING_NODENAME);ck.exports=Bie;async function Bie(e){if(Tf.trace("removeNode called with:",e),Ub.get(Pu.CONFIG_PARAMS.REPLICATION_URL)??Ub.get(Pu.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Uie(e);ok.checkClusteringEnabled();let t=Iie(e);if(t)throw sk(t,t.message,ik.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await ok.getNodeRecord(r);if(wie.isEmptyOrZeroLength(n))throw sk(new Error,`Node '${r}' was not found.`,ik.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new Cie(Pu.OPERATIONS_ENUM.REMOVE_NODE,vie,[]),i,o=!1;for(let l=0,u=n.subscriptions.length;l<u;l++){let d=n.subscriptions[l];d.subscribe===!0&&await Mb.updateConsumerIterator(d.schema,d.table,r,"stop");try{await Mb.updateRemoteConsumer(new Die(d.schema,d.table,!1,!1),r)}catch(_){Tf.error(_)}}try{i=await Mb.request(`${r}.${ak.REQUEST_SUFFIX}`,s),Tf.trace("Remove node reply from remote node:",r,i)}catch(l){Tf.error("removeNode received error from request:",l),o=!0}let c=new Pie(Pu.SYSTEM_SCHEMA_NAME,Pu.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Lie.deleteRecord(c),Mie({type:"nats_update"}),i?.status===ak.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(Tf.error("Error returned from remote node:",r,i?.message),`Successfully removed '${r}' from local manifest, however there was an error reaching remote node. Check the logs for more details.`):`Successfully removed '${r}' from manifest`}a(Bie,"removeNode")});var dk=N((Hwe,uk)=>{"use strict";var lk=require("joi"),{string:Hie,array:xie}=lk.types(),kie=Tt(),Fie=om();uk.exports=Gie;function Gie(e){let t=lk.object({operation:Hie.valid("configure_cluster").required(),connections:xie.items(Fie.validation_schema).required()});return kie.validateBySchema(e,t)}a(Gie,"configureClusterValidator")});var vb=N((kwe,pk)=>{"use strict";var _k=M(),pm=W(),qie=te(),$ie=se(),Vie=gf(),Kie=hf(),Yie=Pi(),Wie=dk(),{handleHDBError:fk,hdb_errors:jie}=_e(),{HTTP_STATUS_CODES:Ek}=jie,zie="Configure cluster complete.",Qie="Failed to configure the cluster. Check the logs for more details.",Jie="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";pk.exports=Xie;async function Xie(e){pm.trace("configure cluster called with:",e);let t=Wie(e);if(t)throw fk(t,t.message,Ek.BAD_REQUEST,void 0,void 0,!0);let r=await Yie.getAllNodeRecords(),n=[];if($ie.get(_k.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let d=0,_=r.length;d<_;d++){let E=await hk(Vie,{operation:_k.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[d].name},r[d].name);n.push(E)}pm.trace("All results from configure_cluster remove node:",n)}let s=[],i=e.connections.length;for(let d=0;d<i;d++){let _=e.connections[d],E=await hk(Kie,_,_.node_name);s.push(E)}pm.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,u=n.concat(s);for(let d=0,_=u.length;d<_;d++){let E=u[d];E.status==="rejected"&&(pm.error(E.node_name,E?.error?.message,E?.error?.stack),o.includes(E.node_name)||o.push(E.node_name)),(E?.result?.message?.includes?.("Successfully")||E?.result?.includes?.("Successfully"))&&(l=!0),!(typeof E.result=="string"&&E.result.includes("Successfully removed")||E.status==="rejected")&&c.push({node_name:E?.node_name,response:E?.result})}if(qie.isEmptyOrZeroLength(o))return{message:zie,connections:c};if(l)return{message:Jie,failed_nodes:o,connections:c};throw fk(new Error,Qie,Ek.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(Xie,"configureCluster");async function hk(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(hk,"functionWrapper")});var gk=N((Gwe,Tk)=>{"use strict";var Af=require("joi"),Zie=Tt(),{validateSchemaExists:mk,validateTableExists:eoe,validateSchemaName:Sk}=gi(),toe=Af.object({operation:Af.string().valid("purge_stream"),schema:Af.string().custom(mk).custom(Sk).optional(),database:Af.string().custom(mk).custom(Sk).optional(),table:Af.string().custom(eoe).required()});function roe(e){return Zie.validateBySchema(e,toe)}a(roe,"purgeStreamValidator");Tk.exports=roe});var Bb=N(($we,Ak)=>{"use strict";var{handleHDBError:noe,hdb_errors:soe}=_e(),{HTTP_STATUS_CODES:ioe}=soe,ooe=gk(),aoe=mr(),coe=Pi();Ak.exports=loe;async function loe(e){e.schema=e.schema??e.database;let t=ooe(e);if(t)throw noe(t,t.message,ioe.BAD_REQUEST,void 0,void 0,!0);coe.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await aoe.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(loe,"purgeStream")});var Sm=N((Kwe,wk)=>{"use strict";var xb=Pi(),uoe=mr(),mm=se(),Lu=M(),Fc=Ct(),doe=te(),Hb=W(),{RemotePayloadObject:_oe}=uf(),{ErrorCode:Rk}=require("nats"),{parentPort:yk}=require("worker_threads"),{onMessageByType:foe}=dt(),{getThisNodeName:Eoe}=(ds(),oe(ca)),{requestClusterStatus:hoe}=(Q_(),oe(gB)),bk=mm.get(Lu.CONFIG_PARAMS.CLUSTERING_ENABLED),Ok=mm.get(Lu.CONFIG_PARAMS.CLUSTERING_NODENAME);wk.exports={clusterStatus:poe,buildNodeStatus:Ik};var Nk;foe("cluster-status",async e=>{Nk(e)});async function poe(){if(mm.get(Lu.CONFIG_PARAMS.REPLICATION_URL)||mm.get(Lu.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;return yk?(yk.postMessage({type:"request-cluster-status"}),n=await new Promise(s=>{Nk=s})):n=hoe(),n.node_name=Eoe(),n.is_enabled=!0,n}let e={node_name:Ok,is_enabled:bk,connections:[]};if(!bk)return e;let t=await xb.getAllNodeRecords();if(doe.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(Ik(t[n],e.connections));return await Promise.allSettled(r),e}a(poe,"clusterStatus");async function Ik(e,t){let r=e.name,n=new _oe(Lu.OPERATIONS_ENUM.CLUSTER_STATUS,Ok,void 0,await xb.getSystemInfo()),s,i,o=Fc.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await uoe.request(Fc.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Fc.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=Fc.CLUSTER_STATUS_STATUSES.CLOSED,Hb.error(`Error getting node status from ${r} `,s))}catch(l){Hb.warn(`Error getting node status from ${r}`,l),l.code===Rk.NoResponders?o=Fc.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===Rk.Timeout?o=Fc.CLUSTER_STATUS_STATUSES.TIMEOUT:o=Fc.CLUSTER_STATUS_STATUSES.CLOSED}let c=new moe(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let l={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==Lu.PRE_4_0_0_VERSION&&await xb.upsertNodeRecord(l)}catch(l){Hb.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(Ik,"buildNodeStatus");function moe(e,t,r,n,s,i,o,c){this.node_name=e,this.status=t,this.ports={clustering:r,operations_api:n},this.latency_ms=s,this.uptime=i,this.subscriptions=o,this.system_info=c}a(moe,"NodeStatusObject")});var Fb=N((Wwe,Ck)=>{"use strict";var{handleHDBError:Soe,hdb_errors:Toe}=_e(),{HTTP_STATUS_CODES:goe}=Toe,Aoe=mr(),Roe=Pi(),kb=te(),Tm=require("joi"),yoe=Tt(),boe=2e3,Ooe=Tm.object({timeout:Tm.number().min(1),connected_nodes:Tm.boolean(),routes:Tm.boolean()});Ck.exports=Noe;async function Noe(e){Roe.checkClusteringEnabled();let t=yoe.validateBySchema(e,Ooe);if(t)throw Soe(t,t.message,goe.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||kb.autoCastBoolean(n),o=s===void 0||kb.autoCastBoolean(s),c={nodes:[]},l=await Aoe.getServerList(r??boe),u={};if(i)for(let d=0,_=l.length;d<_;d++){let E=l[d].statsz;E&&(u[l[d].server.name]=E.routes)}for(let d=0,_=l.length;d<_;d++){if(l[d].statsz)continue;let E=l[d].server,f=l[d].data;if(E.name.endsWith("-hub")){let h={name:E.name.slice(0,-4),response_time:l[d].response_time};i&&(h.connected_nodes=[],u[E.name]&&u[E.name].forEach(T=>{h.connected_nodes.includes(T.name.slice(0,-4))||h.connected_nodes.push(T.name.slice(0,-4))})),o&&(h.routes=f.cluster?.urls?f.cluster?.urls.map(T=>({host:T.split(":")[0],port:kb.autoCast(T.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(Noe,"clusterNetwork")});var Mk=N((zwe,Lk)=>{"use strict";var Gb=require("joi"),Dk=Tt(),{route_constraints:Pk}=gg();Lk.exports={setRoutesValidator:Ioe,deleteRoutesValidator:woe};function Ioe(e){let t=Gb.object({server:Gb.valid("hub","leaf"),routes:Pk.required()});return Dk.validateBySchema(e,t)}a(Ioe,"setRoutesValidator");function woe(e){let t=Gb.object({routes:Pk.required()});return Dk.validateBySchema(e,t)}a(woe,"deleteRoutesValidator")});var gm=N((Jwe,Fk)=>{"use strict";var _o=wt(),qb=te(),Ss=M(),Mu=se(),Uk=Mk(),{handleHDBError:vk,hdb_errors:Coe}=_e(),{HTTP_STATUS_CODES:Bk}=Coe,Hk="cluster routes successfully set",xk="cluster routes successfully deleted";Fk.exports={setRoutes:Poe,getRoutes:Loe,deleteRoutes:Moe};function Doe(e){let t=_o.getClusteringRoutes(),r=e.server==="hub"?t.hub_routes:t.leaf_routes,n=e.server==="hub"?t.leaf_routes:t.hub_routes,s=[],i=[];for(let o=0,c=e.routes.length;o<c;o++){let l=e.routes[o];l.port=qb.autoCast(l.port);let u=r.some(_=>_.host===l.host&&_.port===l.port),d=n.some(_=>_.host===l.host&&_.port===l.port);u||d?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?_o.updateConfigValue(Ss.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):_o.updateConfigValue(Ss.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:Hk,set:i,skipped:s}}a(Doe,"setRoutesNats");function Poe(e){let t=Uk.setRoutesValidator(e);if(t)throw vk(t,t.message,Bk.BAD_REQUEST,void 0,void 0,!0);if(Mu.get(Ss.CONFIG_PARAMS.CLUSTERING_ENABLED))return Doe(e);let r=[],n=[],s=Mu.get(Ss.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{kk(s,i)?n.push(i):(s.push(i),r.push(i))}),_o.updateConfigValue(Ss.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:Hk,set:r,skipped:n}}a(Poe,"setRoutes");function kk(e,t){return typeof t=="string"?e.includes(t):typeof t=="object"&&t!==null?e.some(r=>(r.host===t.host||r.hostname===t.hostname)&&r.port===t.port):!1}a(kk,"existsInArray");function Loe(){if(Mu.get(Ss.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=_o.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return Mu.get(Ss.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(Loe,"getRoutes");function Moe(e){let t=Uk.deleteRoutesValidator(e);if(t)throw vk(t,t.message,Bk.BAD_REQUEST,void 0,void 0,!0);if(Mu.get(Ss.CONFIG_PARAMS.CLUSTERING_ENABLED))return Uoe(e);let r=[],n=[],s=Mu.get(Ss.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{kk(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),_o.updateConfigValue(Ss.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:xk,deleted:r,skipped:n}}a(Moe,"deleteRoutes");function Uoe(e){let t=_o.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],o=!1,c=!1;for(let l=0,u=e.routes.length;l<u;l++){let d=e.routes[l],_=!1;for(let E=0,f=r.length;E<f;E++){let h=r[E];if(d.host===h.host&&d.port===h.port){r.splice(E,1),_=!0,o=!0,s.push(d);break}}if(!_){let E=!0;for(let f=0,h=n.length;f<h;f++){let T=n[f];if(d.host===T.host&&d.port===T.port){n.splice(f,1),c=!0,E=!1,s.push(d);break}}E&&i.push(d)}}return o&&(r=qb.isEmptyOrZeroLength(r)?null:r,_o.updateConfigValue(Ss.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=qb.isEmptyOrZeroLength(n)?null:n,_o.updateConfigValue(Ss.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:xk,deleted:s,skipped:i}}a(Uoe,"deleteRoutesNats")});var qk=N((Zwe,Gk)=>{"use strict";var Rf=require("alasql"),Gc=require("recursive-iterator"),Zs=W(),voe=te(),yf=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=>yf.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=>!yf.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][yf.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=>!yf.SEARCH_WILDCARDS.includes(u));c.forEach(({attribute_name:u})=>{let d=new Rf.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[yf.PERMS_CRUD_ENUM.READ])}a(Boe,"filterReadRestrictedAttrs");function Hoe(e,t,r,n,s){xoe(e,t,r,n,s)}a(Hoe,"interpretAST");function bf(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(bf,"addSchemaTableToMap");function xoe(e,t,r,n,s){if(!e){Zs.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Rf.yy.Insert?qoe(e,t,r):e instanceof Rf.yy.Select?koe(e,t,r,n,s):e instanceof Rf.yy.Update?Foe(e,t,r):e instanceof Rf.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=>{bf(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),bf(c.table,t,r,n,s)});let o=new Gc(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,u=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(u).has(l))if(r.has(l))l=r.get(l);else{Zs.info(`table specified as ${l} not found.`);return}t.get(u).get(l).indexOf(c.columnid)<0&&t.get(u).get(l).push(c.columnid)}if(e.where){let c=new Gc(e.where),l=e.from[0].tableid;for(let{node:u}of c)if(u&&u.columnid){let d=u.tableid?u.tableid:l;if(!t.get(i).has(d))if(r.has(d))d=r.get(d);else{Zs.info(`table specified as ${d} not found.`);continue}t.get(i).get(d).indexOf(u.columnid)<0&&t.get(i).get(d).push(u.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new Gc(c.on);for(let{node:u}of l)if(u&&u.columnid){let d=u.tableid,_=s.get(d);if(!t.get(_).has(d))if(r.has(d))d=r.get(d);else{Zs.info(`table specified as ${d} not found.`);continue}t.get(_).get(d).indexOf(u.columnid)<0&&t.get(_).get(d).push(u.columnid)}}),e.order){let c=new Gc(e.order);for(let{node:l}of c)if(l&&l.columnid){let u=l.tableid,d=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(d).has(u))if(r.has(u))u=r.get(u);else{Zs.info(`table specified as ${u} not found.`);return}t.get(d).get(u).indexOf(l.columnid)<0&&t.get(d).get(u).push(l.columnid)}}}a(koe,"getSelectAttributes");function Foe(e,t,r){if(!e){Zs.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new Gc(e.columns),s=e.table.databaseid;bf(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&Vb(e.table.tableid,s,i.columnid,t,r)}a(Foe,"getUpdateAttributes");function Goe(e,t,r){if(!e){Zs.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new Gc(e.where),s=e.table.databaseid;bf(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&Vb(e.table.tableid,s,i.columnid,t,r)}a(Goe,"getDeleteAttributes");function qoe(e,t,r){if(!e){Zs.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new Gc(e.columns),s=e.into.databaseid;bf(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&Vb(e.into.tableid,s,i.columnid,t,r)}a(qoe,"getInsertAttributes");function Vb(e,t,r,n,s){if(!n.get(t))return;let i=e;n.get(t).has(i)||(i=s.get(i)),n.get(t).get(i).push(r)}a(Vb,"pushAttribute");Gk.exports=$b});var Wb=N((tCe,Yk)=>{var Am=_c(),$k=require("chalk"),Vn=W(),Vk=require("prompt"),{promisify:$oe}=require("util"),Kb=M(),Voe=require("fs-extra"),Koe=require("path"),Yoe=te(),Woe=Bc(),Kk=se();Kk.initSync();var joe=require("moment"),zoe=$oe(Vk.get),Qoe=Koe.join(Kk.getHdbBasePath(),Kb.LICENSE_KEY_DIR_NAME,Kb.LICENSE_FILE_NAME,Kb.LICENSE_FILE_NAME);Yk.exports={getFingerprint:Xoe,setLicense:Joe,parseLicense:Yb,register:Zoe,getRegistrationInfo:tae};async function Joe(e){if(e&&e.key&&e.company){try{Vn.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await Yb(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw Vn.error(r),Vn.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(Joe,"setLicense");async function Xoe(){let e={};try{e=await Am.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw Vn.error(r),Vn.error(t),new Error(r)}return e}a(Xoe,"getFingerprint");async function Yb(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");Vn.info("Validating license input...");let r=Am.validateLicense(e,t);if(Vn.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(Vn.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(Vn.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{Vn.info("writing license to disk"),await Voe.writeFile(Qoe,JSON.stringify({license_key:e,company:t}))}catch(n){throw Vn.error("Failed to write License"),n}return"Registration successful."}a(Yb,"parseLicense");async function Zoe(){let e=await eae();return Yb(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(Zoe,"register");async function eae(){let e=await Am.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:$k.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:$k.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{Vk.start()}catch(n){Vn.error(n)}let r;try{r=await zoe(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(eae,"promptForRegistration");async function tae(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await Am.getLicense()}catch(r){throw Vn.error(`There was an error when searching licenses due to: ${r.message}`),r}if(Yoe.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=Woe.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=joe.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(tae,"getRegistrationInfo")});var jk=N((nCe,Wk)=>{"use strict";var rae=Ct(),jb=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,u,d,_,E,f,h){this.port=t,o===null&&(o=void 0),this.server_name=r+rae.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.reconnect_error_reports=100,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l},this.leafnodes={port:u,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:d,port:_,routes:E,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:f},HDB:{users:h}},this.system_account="SYS"}};Wk.exports=jb});var Jk=N((iCe,Qk)=>{"use strict";var zk=Ct(),zb=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,u,d,_){this.port=t,_===null&&(_=void 0),this.server_name=r+zk.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+zk.SERVER_SUFFIX.LEAF},this.tls={cert_file:u,key_file:d,ca_file:_,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:_,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:_,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:l,jetstream:"enabled"}},this.system_account="SYS"}};Qk.exports=zb});var Zk=N((aCe,Xk)=>{"use strict";var Qb=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};Xk.exports=Qb});var tF=N((lCe,eF)=>{"use strict";var nae=Ct(),Jb=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+nae.SERVER_SUFFIX.ADMIN,this.password=r}};eF.exports=Jb});var Om=N((dCe,sF)=>{"use strict";var qc=require("path"),$c=require("fs-extra"),sae=jk(),iae=Jk(),oae=Zk(),aae=tF(),Xb=xn(),vu=te(),Tn=wt(),ym=M(),Of=Ct(),{CONFIG_PARAMS:Jt}=ym,Bu=W(),Nf=se(),rF=to(),Zb=mr(),cae=Xs(),Uu="clustering",lae=1e4,nF=50;sF.exports={generateNatsConfig:dae,removeNatsConfig:_ae,getHubConfigPath:uae};function uae(){let e=Nf.get(Jt.ROOTPATH);return qc.join(e,Uu,Of.NATS_CONFIG_FILES.HUB_SERVER)}a(uae,"getHubConfigPath");async function dae(e=!1,t=void 0){let r=Nf.get(Jt.ROOTPATH);$c.ensureDirSync(qc.join(r,"clustering","leaf")),Nf.initSync();let n=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_CERT_AUTH),s=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_PRIVATEKEY),i=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_CERTIFICATE);!await $c.exists(i)&&!await $c.exists(!n)&&await cae.createNatsCerts();let o=qc.join(r,Uu,Of.PID_FILES.HUB),c=qc.join(r,Uu,Of.PID_FILES.LEAF),l=Tn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=qc.join(r,Uu,Of.NATS_CONFIG_FILES.HUB_SERVER),d=qc.join(r,Uu,Of.NATS_CONFIG_FILES.LEAF_SERVER),_=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_INSECURE),E=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_VERIFY),f=Tn.getConfigFromFile(Jt.CLUSTERING_NODENAME),h=Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await Zb.checkNATSServerInstalled()||bm("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let T=await Xb.listUsers(),m=Tn.getConfigFromFile(Jt.CLUSTERING_USER),g=await Xb.getClusterUser();(vu.isEmpty(g)||g.active!==!0)&&bm(`Invalid cluster user '${m}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await Rm(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await Rm(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await Rm(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),await Rm(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let S=[],y=[];for(let[ne,Q]of T.entries())Q.role?.role===ym.ROLE_TYPES_ENUM.CLUSTER_USER&&Q.active&&(S.push(new aae(Q.username,rF.decrypt(Q.hash))),y.push(new oae(Q.username,rF.decrypt(Q.hash))));let I=[],{hub_routes:U}=Tn.getClusteringRoutes();if(!vu.isEmptyOrZeroLength(U))for(let ne of U)I.push(`tls://${g.sys_name_encoded}:${g.uri_encoded_d_hash}@${ne.host}:${ne.port}`);let H=new sae(Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),f,o,i,s,n,_,E,h,Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NAME),Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),I,S,y);n==null&&(delete H.tls.ca_file,delete H.leafnodes.tls.ca_file),t=vu.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===ym.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await $c.writeJson(u,H),Bu.trace(`Hub server config written to ${u}`));let X=`tls://${g.sys_name_encoded}:${g.uri_encoded_d_hash}@0.0.0.0:${h}`,Y=`tls://${g.uri_encoded_name}:${g.uri_encoded_d_hash}@0.0.0.0:${h}`,V=new iae(Tn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT),f,c,l,[X],[Y],S,y,i,s,n,_);n==null&&delete V.tls.ca_file,(t===void 0||t===ym.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await $c.writeJson(d,V),Bu.trace(`Leaf server config written to ${d}`))}a(dae,"generateNatsConfig");async function Rm(e){let t=Nf.get(e);return vu.isEmpty(t)&&bm(`port undefined for '${e}'`),await vu.isPortTaken(t)&&bm(`'${e}' port '${t}' is is in use by another process, check to see if HarperDB is already running or another process is using this port.`),!0}a(Rm,"isPortAvailable");function bm(e){let t=`Error generating clustering config: ${e}`;Bu.error(t),console.error(t),process.exit(1)}a(bm,"generateNatsConfigError");async function _ae(e){let{port:t,config_file:r}=Zb.getServerConfig(e),{username:n,decrypt_hash:s}=await Xb.getClusterUser(),i=0,o=2e3;for(;i<nF;){try{let d=await Zb.createConnection(t,n,s,!1);if(d.protocol.connected===!0){d.close();break}}catch(d){Bu.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${d}`)}if(i++,i>=nF)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);let u=o*(i*2);u>3e4&&Bu.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await vu.async_set_timeout(u)}let c="0".repeat(lae),l=qc.join(Nf.get(Jt.ROOTPATH),Uu,r);await $c.writeFile(l,c),await $c.remove(l),Bu.notify(e,"started.")}a(_ae,"removeNatsConfig")});var uF=N((fCe,lF)=>{"use strict";var Kn=se(),fae=_c(),Ge=M(),If=Ct(),fo=require("path"),{PACKAGE_ROOT:Im}=M(),iF=se(),Nm=te(),Hu="/dev/null",Eae=fo.join(Im,"launchServiceScripts"),oF=fo.join(Im,"utility/scripts"),hae=fo.join(oF,Ge.HDB_RESTART_SCRIPT),aF=fo.resolve(Im,"dependencies",`${process.platform}-${process.arch}`,If.NATS_BINARY_NAME);function cF(){let t=fae.licenseSearch().ram_allocation||Ge.RAM_ALLOCATION_ENUM.DEFAULT,r=Ge.MEM_SETTING_KEY+t,n={[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return Nm.noBootFile()&&(n[Ge.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Nm.getEnvCliRootPath()),{name:Ge.PROCESS_DESCRIPTORS.HDB,script:Ge.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:Im}}a(cF,"generateMainServerConfig");var pae=9930;function mae(){Kn.initSync(!0);let e=Kn.get(Ge.CONFIG_PARAMS.ROOTPATH),t=fo.join(e,"clustering",If.NATS_CONFIG_FILES.HUB_SERVER),r=fo.join(Kn.get(Ge.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ge.LOG_NAMES.HDB),n=iF.get(Ge.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=If.LOG_LEVEL_FLAGS[Kn.get(Ge.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==pae?"-"+n:""),script:aF,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return Kn.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Hu,i.error_file=Hu),i}a(mae,"generateNatsHubServerConfig");var Sae=9940;function Tae(){Kn.initSync(!0);let e=Kn.get(Ge.CONFIG_PARAMS.ROOTPATH),t=fo.join(e,"clustering",If.NATS_CONFIG_FILES.LEAF_SERVER),r=fo.join(Kn.get(Ge.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ge.LOG_NAMES.HDB),n=iF.get(Ge.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=If.LOG_LEVEL_FLAGS[Kn.get(Ge.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==Sae?"-"+n:""),script:aF,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return Kn.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Hu,i.error_file=Hu),i}a(Tae,"generateNatsLeafServerConfig");function gae(){Kn.initSync();let e=fo.join(Kn.get(Ge.CONFIG_PARAMS.LOGGING_ROOT),Ge.LOG_NAMES.HDB),t={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:Ge.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:Eae,autorestart:!1};return Kn.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=Hu,t.error_file=Hu),t}a(gae,"generateClusteringUpgradeV4ServiceConfig");function Aae(){let e={[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.RESTART_HDB};return Nm.noBootFile()&&(e[Ge.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Nm.getEnvCliRootPath()),{...{name:Ge.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:oF},script:hae}}a(Aae,"generateRestart");function Rae(){return{apps:[cF()]}}a(Rae,"generateAllServiceConfigs");lF.exports={generateAllServiceConfigs:Rae,generateMainServerConfig:cF,generateRestart:Aae,generateNatsHubServerConfig:mae,generateNatsLeafServerConfig:Tae,generateClusteringUpgradeV4ServiceConfig:gae}});var xu=N((pCe,bF)=>{"use strict";var at=M(),yae=te(),ho=Om(),wm=mr(),Eo=Ct(),Ea=uF(),Cm=se(),Vc=W(),bae=Pi(),{startWorker:dF,onMessageFromWorkers:Oae}=dt(),Nae=Cu(),hCe=require("util"),Iae=require("child_process"),wae=require("fs"),{execFile:Cae}=Iae,Xe;bF.exports={enterPM2Mode:Dae,start:ha,stop:eO,reload:fF,restart:EF,list:tO,describe:mF,connect:po,kill:vae,startAllServices:Bae,startService:rO,getUniqueServicesList:SF,restartAllServices:Hae,isServiceRegistered:TF,reloadStopStart:gF,restartHdb:pF,deleteProcess:Mae,startClusteringProcesses:RF,startClusteringThreads:yF,isHdbRestartRunning:Uae,isClusteringRunning:kae,stopClustering:xae,reloadClustering:Fae,expectedRestartOfChildren:hF};var wf=!1;Oae(e=>{e.type==="restart"&&Cm.initSync(!0)});function Dae(){wf=!0}a(Dae,"enterPM2Mode");function po(){return Xe||(Xe=require("pm2")),new Promise((e,t)=>{Xe.connect((r,n)=>{r&&t(r),e(n)})})}a(po,"connect");var Jr,Pae=10,_F;function ha(e,t=!1){if(wf)return Lae(e);let r=Cae(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let o=Jr.indexOf(r);o>-1&&Jr.splice(o,1),!_F&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<Pae&&(wae.existsSync(ho.getHubConfigPath())?ha(e):(await ho.generateNatsConfig(!0),ha(e),await new Promise(c=>setTimeout(c,3e3)),await ho.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await ho.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=Cm.get(at.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,u=0,d;for(;l=c.exec(i);){if(l.index&&Eo.LOG_LEVEL_HIERARCHY[o]>=Eo.LOG_LEVEL_HIERARCHY[d||"info"]){let f=d===Eo.LOG_LEVELS.ERR||d===Eo.LOG_LEVELS.WRN?Vc.OUTPUTS.STDERR:Vc.OUTPUTS.STDOUT;Vc.logCustomLevel(d||"info",f,n,i.slice(u,l.index).trim())}let[_,E]=l;u=l.index+_.length,d=Eo.LOG_LEVELS[E]}if(Eo.LOG_LEVEL_HIERARCHY[o]>=Eo.LOG_LEVEL_HIERARCHY[d||"info"]){let _=d===Eo.LOG_LEVELS.ERR||d===Eo.LOG_LEVELS.WRN?Vc.OUTPUTS.STDERR:Vc.OUTPUTS.STDOUT;Vc.logCustomLevel(d||"info",_,n,i.slice(u).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!Jr&&(Jr=[],!t)){let i=a(()=>{_F=!0,Jr&&(Jr.map(o=>o.kill()),process.exit(0))},"kill_children");process.on("exit",i),process.on("SIGINT",i),process.on("SIGQUIT",i),process.on("SIGTERM",i)}Jr.push(r)}a(ha,"start");function Lae(e){return new Promise(async(t,r)=>{try{await po()}catch(n){r(n)}Xe.start(e,(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(s)})})}a(Lae,"startWithPM2");function eO(e){if(!wf){for(let t of Jr||[])t.name===e&&(Jr.splice(Jr.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await po()}catch(n){r(n)}Xe.stop(e,async(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.delete(e,(i,o)=>{i&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(o)})})})}a(eO,"stop");function fF(e){return new Promise(async(t,r)=>{try{await po()}catch(n){r(n)}Xe.reload(e,(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(s)})})}a(fF,"reload");function EF(e){if(!wf){hF();for(let t of Jr||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await po()}catch(n){r(n)}Xe.restart(e,(n,s)=>{Xe.disconnect(),t(s)})})}a(EF,"restart");function hF(){for(let e of Jr||[])e.config&&(e.config.restarts=0)}a(hF,"expectedRestartOfChildren");function Mae(e){return new Promise(async(t,r)=>{try{await po()}catch(n){r(n)}Xe.delete(e,(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(s)})})}a(Mae,"deleteProcess");async function pF(){await ha(Ea.generateRestart())}a(pF,"restartHdb");async function Uae(){let e=await tO();for(let t in e)if(e[t].name===at.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(Uae,"isHdbRestartRunning");function tO(){return new Promise(async(e,t)=>{try{await po()}catch(r){t(r)}Xe.list((r,n)=>{r&&(Xe.disconnect(),t(r)),Xe.disconnect(),e(n)})})}a(tO,"list");function mF(e){return new Promise(async(t,r)=>{try{await po()}catch(n){r(n)}Xe.describe(e,(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(s)})})}a(mF,"describe");function vae(){if(!wf){for(let e of Jr||[])e.kill();Jr=[];return}return new Promise(async(e,t)=>{try{await po()}catch(r){t(r)}Xe.killDaemon((r,n)=>{r&&(Xe.disconnect(),t(r)),Xe.disconnect(),e(n)})})}a(vae,"kill");async function Bae(){try{await RF(),await yF(),await ha(Ea.generateAllServiceConfigs())}catch(e){throw Xe?.disconnect(),e}}a(Bae,"startAllServices");async function rO(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case at.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Ea.generateMainServerConfig();break;case at.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Ea.generateNatsIngestServiceConfig();break;case at.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Ea.generateNatsReplyServiceConfig();break;case at.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Ea.generateNatsHubServerConfig(),await ha(r,t),await ho.removeNatsConfig(e);return;case at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Ea.generateNatsLeafServerConfig(),await ha(r,t),await ho.removeNatsConfig(e);return;case at.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Ea.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await ha(r)}catch(r){throw Xe?.disconnect(),r}}a(rO,"startService");async function SF(){try{let e=await tO(),t={};for(let r=0,n=e.length;r<n;r++){let s=e[r];t[s.name]===void 0&&(t[s.name]={name:s.name,exec_mode:s.pm2_env.exec_mode})}return t}catch(e){throw Xe?.disconnect(),e}}a(SF,"getUniqueServicesList");async function Hae(e=[]){try{let t=!1,r=await SF();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===at.PROCESS_DESCRIPTORS.HDB?t=!0:await EF(o))}t&&await gF(at.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Xe?.disconnect(),t}}a(Hae,"restartAllServices");async function TF(e){if(Jr?.find(r=>r.name===e))return!0;let t=await Nae.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(TF,"isServiceRegistered");async function gF(e){let t=Cm.get(at.CONFIG_PARAMS.THREADS_COUNT)??Cm.get(at.CONFIG_PARAMS.THREADS),r=await mF(e),n=yae.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await eO(e),await rO(e)):e===at.PROCESS_DESCRIPTORS.HDB?await pF():await fF(e)}a(gF,"reloadStopStart");var AF;async function RF(e=!1){for(let t in at.CLUSTERING_PROCESSES){let r=at.CLUSTERING_PROCESSES[t];await rO(r,e)}}a(RF,"startClusteringProcesses");async function yF(){AF=dF(at.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:at.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await wm.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await wm.updateLocalStreams();let e=await bae.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===at.PRE_4_0_0_VERSION){Vc.info("Starting clustering upgrade 4.0.0 process"),dF(at.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(yF,"startClusteringThreads");async function xae(){for(let e in at.CLUSTERING_PROCESSES)if(e!==at.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===at.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await AF.terminate();else{let t=at.CLUSTERING_PROCESSES[e];await eO(t)}}a(xae,"stopClustering");async function kae(){for(let e in at.CLUSTERING_PROCESSES){let t=at.CLUSTERING_PROCESSES[e];if(await TF(t)===!1)return!1}return!0}a(kae,"isClusteringRunning");async function Fae(){await ho.generateNatsConfig(!0),await wm.reloadNATSHub(),await wm.reloadNATSLeaf(),await ho.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await ho.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(Fae,"reloadClustering")});var iO={};je(iO,{compactOnStart:()=>Gae,copyDb:()=>DF});async function Gae(){pa.notify("Running compact on start"),console.log("Running compact on start");let e=(0,nO.get)(ma.CONFIG_PARAMS.ROOTPATH),t=new Map,r=ut();(0,sO.updateConfigValue)(ma.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1);try{for(let n in r){if(n==="system"||n.endsWith("-copy"))continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,Dm.join)(e,"backup",n+".mdb"),o=(0,Dm.join)(e,ma.DATABASES_DIR_NAME,n+"-copy.mdb"),c=0;try{c=await OF(n),console.log("Database",n,"before compact has a total record count of",c)}catch(l){pa.error("Error getting record count for database",n,l),console.error("Error getting record count for database",n,l)}t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await DF(n,o),console.log("Backing up",n,"to",i),await(0,Kc.move)(s,i,{overwrite:!0})}try{ku()}catch(n){pa.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n)}for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,Kc.move)(i,s,{overwrite:!0}),await(0,Kc.remove)((0,Dm.join)(e,ma.DATABASES_DIR_NAME,`${n}-copy.mdb-lock`));try{ku()}catch(n){pa.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n),process.exit(0)}}catch(n){pa.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,sO.updateConfigValue)(ma.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1);for(let[s,{db_path:i,backup_dest:o}]of t){console.error("Moving backup database",o,"back to",i);try{await(0,Kc.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw ku(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await OF(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){o=!1;let l=`There is a discrepancy between pre and post compact record count for database ${n}.
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(bc(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}js.trace("create nats connection called");let i=await qee({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:Or.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:Or.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:Or.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),js.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&js.error("Error with Nats client connection, connection closed",o),i===zr&&Y0()}),i}a(cy,"createConnection");function Y0(){zr=void 0,Ac=void 0,Rc=void 0,yc=void 0}a(Y0,"clearClientCache");async function tte(){zr&&(await zr.drain(),zr=void 0,Ac=void 0,Rc=void 0,yc=void 0)}a(tte,"closeConnection");var zr,yc;async function K_(){return yc||(yc=cy(Or.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),zr=await yc),zr||yc}a(K_,"getConnection");async function Y_(){if(Ac)return Ac;bc(zr)&&await K_();let{domain:e}=tu(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(bc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Ac=await zr.jetstreamManager({domain:e,timeout:6e4}),Ac}a(Y_,"getJetStreamManager");async function W0(){if(Rc)return Rc;bc(zr)&&await K_();let{domain:e}=tu(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(bc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Rc=zr.jetstream({domain:e,timeout:6e4}),Rc}a(W0,"getJetStream");async function wi(){let e=zr||await K_(),t=Ac||await Y_(),r=Rc||await W0();return{connection:e,jsm:t,js:r}}a(wi,"getNATSReferences");async function rte(e){let t=Or.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 wi(),n=Or.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Or.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=Or.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:$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 wi(),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 wi();await t.streams.delete(e)}a(nte,"deleteLocalStream");async function ste(e){let{connection:t}=await wi(),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 wi(),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 wi(),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 wi(),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=Or.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 tu(e){e=e.toLowerCase();let t=V_.join(Or.get(Je.CONFIG_PARAMS.ROOTPATH),Jee);if(e===Je.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return bc(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 bc(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(tu,"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 wi(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return sy(c.data)}a(ute,"request");function uy(e){return new Promise(async(t,r)=>{let n=Bee(ny,["--signal",`reload=${e}`],{cwd:__dirname}),s,i;n.on("error",o=>{r(o)}),n.stdout.on("data",o=>{i+=o.toString()}),n.stderr.on("data",o=>{s+=o.toString()}),n.stderr.on("close",o=>{s&&r(s),t(i)})})}a(uy,"reloadNATS");async function dte(){let{pid_file_path:e}=tu(Je.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await uy(e)}a(dte,"reloadNATSHub");async function _te(){let{pid_file_path:e}=tu(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await uy(e)}a(_te,"reloadNATSLeaf");function fte(e,t,r){let n;switch(e.code){case 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 wi(),{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()<Or.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(Or.get(Je.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=Ip.createNatsTableStreamName(e,t),{domain:s}=tu(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(Or.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=Or.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Or.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=Or.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}a(Ate,"updateStreamLimits");async function Rte(e){let t,r;try{t=await zr.jetstream({domain:e}),r=await zr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw js.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(Rte,"connectToRemoteJS")});var Oc=N(Dp=>{var Cp=W();for(let e of["trace","debug","info","warn","error","fatal","notify"])Cp.logsAtLevel(e)&&(Dp[e]=Cp[e]);Dp.loggerWithTag=e=>Cp.loggerWithTag(e,!0);Dp.setLogLevel=Cp.setLogLevel});function dy(e){let t=e.get(Pp),r=t?(0,ru.unpack)(t):null;r||(r={remoteNameToId:{}});let n=ot(),s=!1;r.nodeName=ot();let i=r.remoteNameToId;if(i[n]!==0){let o=0,c;for(let l in i){let u=i[l];u===0?c=l:u>o&&(o=u)}if(c){o++,i[c]=o;let l=[Symbol.for("seq"),o];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:j_(e)??1,nodes:[]})})}i[n]=0,e.putSync(Pp,(0,ru.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,ru.pack)(n)),i}function Lp(e,t){let r=dy(t),n=r.remoteNameToId,s=n[e];if(s==null){let i=0;for(let o in n){let c=n[o];c>i&&(i=c)}s=i+1,n[e]=s,t.putSync(Pp,(0,ru.pack)(r))}return tB.info?.("The remote node name map",e,n,s),s}var tB,ru,Pp,_y=Ie(()=>{tB=L(Oc());ds();ru=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:()=>nu,resetResources:()=>yte,resources:()=>Ci});function yte(){return Ci=new Mp}function nu(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var nB,sB,Mp,Ci,su=Ie(()=>{Sc();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(nu,"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=nu(t);let d=new hy(r);d.startTime=n;let _=u.get(t);return _?_.push(d):(u.set(t,_=[d]),_.tables=u,_.key=t),d.subscriptions=_,d}function 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=nu(c),u=0;do{let d=o.get(l);if(d){for(let E of d)if(!(u>0&&!(E.includeDescendants&&!(E.onlyChildren&&u>1)))){if(E.startTime>=n){(0,Ey.info)("omitting",c,E.startTime,n);continue}try{let f;E.supportsTransactions&&E.txnInProgress!==i.version&&(f=!0,E.txnInProgress||(r?r.push(E):r=[E]),E.txnInProgress=i.version),E.listener(c,i,n,f)}catch(f){console.error(f),(0,Ey.info)(f)}}}if(l==null)break;let _=l.lastIndexOf?.("/",l.length-2);_!==l.length-1&&u++,_>-1?l=l.slice(0,_+1):l=null}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function 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());Ll();su();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:()=>au,getHDBNodeTable:()=>Sr,iterateRoutes:()=>Q_,shouldReplicateToNode:()=>z_,subscribeToNodeUpdates:()=>cu});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 cu(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(){cu(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 au.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=iu.default.get(ou.CONFIG_PARAMS.REPLICATION_SECUREPORT)??(!iu.default.get(ou.CONFIG_PARAMS.REPLICATION_PORT)&&iu.default.get(ou.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||iu.default.get(ou.CONFIG_PARAMS.REPLICATION_PORT)||iu.default.get(ou.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT);let o=i?.lastIndexOf?.(":");o>0&&(i=+i.slice(o+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){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,iu,ou,hB,dB,_B,au,lu=Ie(()=>{Pe();ds();lp();fB=require("worker_threads"),EB=L(_e()),iu=L(se()),ou=L(M()),hB=L(Oc());server.nodes=[];a(Sr,"getHDBNodeTable");a(cu,"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})`);au||(au=new Map,Ote());let n=au.get(e);return n||(n=[],au.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(Ote,"startSubscriptionToReplications");a(Q_,"iterateRoutes")});var AB={};je(AB,{connectedToNode:()=>Nc,disconnectedFromNode:()=>_u,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}}}Di.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)}cu(s)});let n;function s(i,o=i?.name){let c=ot()&&o===ot()||ra()&&i?.url===ra();if(c){let _=!!i?.replicates;if(n!==void 0&&n!==_)for(let E of Sr().search([]))E.replicates&&E.name!==o&&s(E,E.name);n=_}if(_t.trace("Setting up node replication for",i),!i){for(let[_,E]of ao){let f;for(let[h,{worker:T,nodes:m}]of E){let g=m[0];if(g&&g.name==o){f=!0;for(let[S,{worker:y}]of E)E.delete(S),_t.warn("Node was deleted, unsubscribing from node",o,S,_),y?.postMessage({type:"unsubscribe-from-node",node:o,database:S,url:_});break}}if(f){ao.get(_).iterator.remove(),ao.delete(_);return}}return}if(c)return;if(!i.url){_t.info(`Node ${i.name} is missing url`);return}let l=ao.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(_t.info(`Added node ${i.name} at ${i.url} for process ${ot()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[_,E]of uu)if(i.url===E.url){uu.delete(_);break}uu.set(i.name,i)}let u=ut();if(l||(l=new Map,ao.set(i.url,l)),l.iterator=ta(e,(_,E,f)=>{f?d(E,!0):d(E,!1)}),i.subscriptions)for(let _ of i.subscriptions){let E=_.database||_.schema;u[E]||(_t.warn(`Database ${E} not found for node ${i.name}, making a subscription anyway`),d(E,!1))}function d(_,E){_t.trace("Setting up replication for database",_,"on node",i.name);let f=l.get(_),h,T=[{replicateByDefault:E,...i}];Up.has(_)&&(T.push({replicateByDefault:E,name:ot(),start_time:Up.get(_),end_time:Date.now(),replicates:!0}),Up.delete(_));let m=z_(i,_),g=Di.workers.filter(S=>S.name==="http");if(f?(h=f.worker,f.nodes=T):m&&(t=t%g.length,h=g[t++],l.set(_,{worker:h,nodes:T,url:i.url}),h?.on("exit",()=>{l.get(_)?.worker===h&&(l.delete(_),d(_,E))})),m)setTimeout(()=>{let S={type:"subscribe-to-node",database:_,nodes:T};h?h.postMessage(S):du(S)},Nte);else{_t.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[_],Sr().primaryStore.get(ot())?.replicates),Sr().primaryStore.get(ot())?.replicates||(n=!1);let S={type:"unsubscribe-from-node",database:_,url:i.url,name:i.name};h?h.postMessage(S):Bp(S)}}a(d,"onDatabase")}a(s,"onNodeUpdate"),_u=a(function(i){try{_t.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(uu.keys()),c=o.sort(),l=c.indexOf(i.name||zs(i.url));if(l===-1){_t.warn("Disconnected node not found in node map",i.name,o);return}let u=ao.get(i.url),d=u?.get(i.database);if(!d){_t.warn("Disconnected node not found in replication map",i.database,u);return}if(d.connected=!1,i.finished)return;let _=d.nodes[0];if(!(_.replicates===!0||_.replicates?.sends||_.subscriptions?.length))return;let E=(l+1)%c.length;for(;l!==E;){let f=c[E],h=uu.get(f);u=ao.get(h.url);let T=u?.get(i.database);if(!T){E=(E+1)%c.length;continue}let{worker:m,nodes:g}=T,S=!1;for(let y of d.nodes){if(g.some(I=>I.name===y.name)){_t.info(`Disconnected node is already failing over to ${f} for ${i.database}`);continue}g.push(y),S=!0}if(!S){_t.info(`Disconnected node ${i.name} has no nodes to fail over to ${f}`);return}d.redirectingTo=T,_t.info(`Failing over ${i.database} from ${i.name} to ${f}`),m?m.postMessage({type:"subscribe-to-node",database:i.database,nodes:g}):du({database:i.database,nodes:g});return}_t.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){_t.error("Error failing over node",o)}},"disconnectedFromNode"),Nc=a(function(i){let o=ao.get(i.url),c=o?.get(i.database);if(!c){_t.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,o);return}if(c.connected=!0,c.latency=i.latency,c.catchingUpFrom=i.lastSendTime,c.redirectingTo){let{worker:l,nodes:u}=c.redirectingTo,d=u.find(_=>_.name===i.name);c.redirectingTo=null,d&&(u.splice(u.indexOf(d),1),l?l.postMessage({type:"subscribe-to-node",database:i.database,nodes:u}):du({database:i.database,nodes:u}))}},"connectedToNode"),(0,Di.onMessageByType)("disconnected-from-node",_u),(0,Di.onMessageByType)("connected-to-node",Nc),(0,Di.onMessageByType)("request-cluster-status",gB)}function gB(e,t){let r=[];for(let[n,s]of uu)try{let i=ao.get(s.url);_t.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let o=[];if(i){for(let[l,{worker:u,connected:d,nodes:_,latency:E,catchingUpFrom:f}]of i)o.push({database:l,connected:d,latency:E,catching_up_from:f?new Date(f).toISOString():"up-to-date",thread_id:u?.threadId,nodes:_.map(h=>h.name)});let c=(0,Sy.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){_t.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function co(e,t){let r=Sr();e=e??zs(t.url),t.name=e;try{if(t.ca){let s=new 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 Di,vp,_t,Sy,mB,SB,TB,Nte,ao,_u,Nc,uu,Up,J_=Ie(()=>{Pe();Di=L(dt());ds();vp=require("worker_threads");lu();_t=L(W()),Sy=require("lodash"),mB=L(se()),SB=L(M()),TB=require("crypto"),Nte=200,ao=new Map,uu=new Map,Up=new Map;a(Ty,"startOnMainThread");a(gB,"requestClusterStatus");vp.parentPort&&(_u=a(e=>{vp.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),Nc=a(e=>{vp.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Di.onMessageByType)("subscribe-to-node",e=>{du(e)}),(0,Di.onMessageByType)("unsubscribe-from-node",e=>{Bp(e)}));a(co,"ensureNode")});var Hp=N((PNe,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((MNe,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 fu=N((vNe,wB)=>{"use strict";var Z_=require("jsonwebtoken"),yy=require("fs-extra"),by=te(),_s=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(_s.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?na.get(_s.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",Hte=na.get(_s.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?na.get(_s.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(_s.SYSTEM_SCHEMA_NAME,_s.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(),_s.LICENSE_KEY_DIR_NAME,_s.JWT_ENUM.JWT_PASSPHRASE_NAME),t=Oy.join(na.getHdbBasePath(),_s.LICENSE_KEY_DIR_NAME,_s.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=Oy.join(na.getHdbBasePath(),_s.LICENSE_KEY_DIR_NAME,_s.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"),{watch:Gte}=require("chokidar"),pn=require("fs-extra"),Eu=require("node-forge"),vB=require("net"),{generateKeyPair:Cy,X509Certificate:lo,createPrivateKey:BB}=require("crypto"),qte=require("util");Cy=qte.promisify(Cy);var yt=Eu.pki,Qs=require("joi"),{v4:HB}=require("uuid"),{validateBySchema:My}=Tt(),pt=W(),Es=se(),hs=M(),{CONFIG_PARAMS:hu}=hs,Js=Sg(),{ClientError:ia}=_e(),wc=require("node:tls"),{relative:xB,join:$te}=require("node:path"),{CERT_PREFERENCE_APP:HNe,CERTIFICATE_VALUES:CB}=Js,Vte=ja(),Dy=wt(),DB=parseInt(process.version.slice(1))<20,{table:Kte,getDatabases:Yte,databases:wy}=(Pe(),oe(lt)),{getJWTRSAKeys:PB}=fu();Object.assign(ZB,{generateKeys:By,updateConfigCert:YB,createCsr:Zte,signCertificate:ere,setCertTable:pu,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:Wte,getThisNodeName:Gp,clearThisNodeName:jte}=(ds(),oe(ca)),{readFileSync:zte,statSync:FB}=require("node:fs"),xNe=se(),{getTicketKeys:Qte,onMessageFromWorkers:Jte}=dt(),sa=W(),{isMainThread:GB}=require("worker_threads"),{TLSSocket:qB,createSecureContext:kNe}=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===hs.ITC_EVENT_TYPES.RESTART&&(Es.initSync(!0),await xy())});var Pr;function aa(){return Pr||(Pr=Yte().system.hdb_certificate,Pr||(Pr=Kte({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:hu.TLS},{configKey:hu.OPERATIONSAPI_TLS}];aa();let t=sr.dirname(Dy.getConfigFilePath()),r;for(let{configKey:n}of e){let s=Dy.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&xB($te(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(y){pt.error("error extracting common name from certificate",y);return}if(T==null){pt.error("error extracting common name from certificate");return}if(h.checkIssued(new lo(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=o.mtimeMs;c&&c!==n&&(n&&GB&&pt.warn(`Reloading ${r}:`,i),n=c,t(WB(i)))}catch(c){pt.error(`Error loading ${r}:`,i,c)}},"loadFile");pn.existsSync(e)?s(e,FB(e)):pt.error(`${r} file not found:`,e),Gte(e,{persistent:!1}).on("change",s)}a(MB,"loadAndWatch");function Py(){let e=Wte();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),Eu.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(Es.getHdbBasePath(),hs.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;aa();for await(let d of Pr.search([]))if(d.is_authority&&!d.details.issuer.includes("HarperDB-Certificate-Authority")){if(oa.has(d.private_key_name)){n=oa.get(d.private_key_name),s=d;break}else if(d.private_key_name&&await pn.exists(sr.join(r,d.private_key_name))){n=pn.readFile(sr.join(r,d.private_key_name)),s=d;break}}if(!n){let d=await Ly();s=d.ca,n=d.private_key}n=yt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=yt.certificateFromPem(s.certificate);pt.info("Signing CSR with cert named",s.name);let o=yt.certificationRequestFromPem(e.csr);try{o.verify()}catch(d){return pt.error(d),new Error("Error verifying CSR: "+d.message)}let c=Eu.pki.createCertificate();c.serialNumber=Math.random().toString().slice(2,10),c.validity.notBefore=new Date;let l=new Date;c.validity.notAfter=l,c.validity.notAfter.setDate(l.getDate()+Uy),pt.info("sign cert setting validity:",c.validity),pt.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),pt.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=o.getAttribute({name:"extensionRequest"}).extensions;pt.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=o.publicKey,c.sign(n,Eu.md.sha256.create()),t.certificate=yt.certificateToPem(c)}else pt.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(ere,"signCertificate");async function tre(e,t){await pu({name:Gp(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await pu({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:yt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(tre,"createCertificateTable");async function pu(e){let t=new lo(e.certificate);e.details={issuer:t.issuer.replace(/\n/g," "),subject:t.subject.replace(/\n/g," "),subject_alt_name:t.subjectAltName,serial_number:t.serialNumber,valid_from:t.validFrom,valid_to:t.validTo},aa(),await Pr.patch(e)}a(pu,"setCertTable");async function By(){let e=await Cy("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:yt.publicKeyFromPem(e.publicKey),private_key:yt.privateKeyFromPem(e.privateKey)}}a(By,"generateKeys");async function Hy(e,t,r){let n=yt.createCertificate();if(!t){let o=await 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,Eu.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-${Es.get(hu.REPLICATION_HOSTNAME)??kB(Es.get(hu.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,Eu.md.sha256.create());let o=sr.join(Es.getHdbBasePath(),hs.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(Es.getHdbBasePath(),hs.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(){jte(),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=Es.get(hu.TLS_PRIVATEKEY),n=sr.join(Es.getHdbBasePath(),hs.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 pu({name:o.subject.getField("CN").value,uses:["https"],certificate:yt.certificateToPem(o),private_key_name:i,is_authority:!0,is_self_signed:!0})}if(!await 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 pu({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(xy,"reviewSelfSignedCert");function YB(){let e=Vte(Object.keys(hs.CONFIG_PARAM_MAP),!0),t=sr.join(Es.getHdbBasePath(),hs.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=hs.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:zte(e,"utf8")}a(WB,"readPEM");var UB=wc.createSecureContext;wc.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=wc.Server;wc.Server=function(e,t){return e.ALPNCallback&&(e.ALPNProtocols=null),jB.call(this,e,t)};wc.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 Ic=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(),Ic.clear();let d=0;for await(let _ of wy.system.hdb_certificate.search([])){let E=_.certificate,f=new lo(E);_.is_authority&&(f.asString=E,Ic.set(f.subject,E))}for await(let _ of wy.system.hdb_certificate.search([]))try{if(_.is_authority)continue;let E=e==="operations-api",f=_.is_self_signed?1:2;E&&_.uses?.includes?.("operations")&&(f+=1);let h=await QB(_.private_key_name),T=_.certificate,m=new lo(T);if(Ic.has(m.issuer)&&(T+=`
15
+ `+Ic.get(m.issuer)),!h||!T)throw new Error("Missing private key or certificate for secure server");let g={ciphers:_.ciphers,ticketKeys:Qte(),availableCAs:Ic,ca:t&&Array.from(Ic.values()),cert:T,key:h,key_file:_.private_key_name,is_self_signed:_.is_self_signed};o&&(g.sessionIdContext=o.sessionIdContext);let S=wc.createSecureContext(g);S.name=_.name,S.options=g,S.quality=f,S.certificateAuthorities=Array.from(Ic),S.certStart=T.toString().slice(0,100);let y=_.hostnames??XB(m);Array.isArray(y)||(y=[y]);let I;for(let U of y)if(U){U[0]==="*"&&(s=!0,U=U.slice(1)),U===Py()&&(f+=2),vB.isIP(U)&&(I=!0);let H=r.get(U)?.quality??0;f>H&&r.set(U,S)}else sa.error("No hostname found for certificate at",wc.certificate);sa.trace("Adding TLS",S.name,"for",o.ports||"client","cert named",_.name,"hostnames",y,"quality",f,"best quality",d),f>d&&(i.defaultContext=n=S,d=f,o&&(o.defaultContext=S))}catch(E){sa.error("Error applying TLS for",_.name,E)}o?.secureContextsListeners.forEach(_=>_()),c(n)}catch(d){l(d)}}a(u,"updateTLS"),wy.system.hdb_certificate.subscribe({listener:a(()=>setTimeout(()=>u(),1500).unref(),"listener"),omitCurrent:!0}),u()})),i;function i(o,c){sa.info("TLS requested for",o||"(no SNI)",this.isReplicationConnection);let l=o;for(;;){let d=r.get(l);if(d)return sa.debug("Found certificate for",o,d.certStart),d.replicationContext&&(this.isReplicationConnection||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(Es.get(hu.ROOTPATH),hs.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(Es.getHdbBasePath(),hs.LICENSE_KEY_DIR_NAME,_+".pem"),s),oa.set(_,s));let E={name:r??d,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&u||i&&s)&&(E.private_key_name=u??_+".pem"),await pu(E),"Successfully added certificate: "+_}a(ore,"addCertificate");function are(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(are,"sanitizeName");async function cre(e){let t=My(e,Qs.object({name:Qs.string().required()}));if(t)throw new ia(t.message);let{name:r}=e;aa();let n=await Pr.get(r);if(!n)throw new ia(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await Pr.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(pt.info("Removing private key named",s),await pn.remove(sr.join(Es.getHdbBasePath(),hs.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(Dc)})),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||Cc,_,E,f=!1,h=t.subscription;h?.then&&h.then(ie=>h=ie);let T=t.tables||u&&ut()[u];if(!r){fe.error?.("No authorization provided"),is(1008,"Unauthorized");return}let m=new Map,g=[],S=r.name;S&&t.connection&&(t.connection.nodeName=S);let y,I,U,H,X,Y,V=1e3,ne,Q=0,de=0,j=0,ae=0;if(t.url){let ie=a(()=>{X&&j===e._socket?.bytesRead&&ae===e._socket?.bytesWritten?e.terminate():(X=performance.now(),e.ping(),j=e._socket?.bytesRead,ae=e._socket?.bytesWritten)},"send_ping");U=setInterval(ie,uH).unref(),ie()}else Oe();function Oe(){clearTimeout(H),j=e._socket?.bytesRead,ae=e._socket?.bytesWritten,H=setTimeout(()=>{j===e._socket?.bytesRead&&ae===e._socket?.bytesWritten&&(fe.warn?.(`Timeout waiting for ping from ${S}, terminating connection and reconnecting`),e.terminate())},uH*2).unref()}a(Oe,"resetPingTimer"),u&&Ka(u);let Ne,Me,Gr=[],Cd=[],Fa,wn=[],Dd=[],Nl=[],vw=150,jE=0,vt=0,Ga,qa,vs,Bs,zE;e.on("message",ie=>{Q=performance.now();try{let Se=ie.dataView=new Pc(ie.buffer,ie.byteOffset,ie.byteLength);if(ie[0]>127){let A=(0,ct.decode)(ie),[w,R,b]=A;switch(w){case 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)([mu])),is(1008,"Node name mismatch");return}}else if(S=R,t.connection?.tentativeNode){let x=t.connection.tentativeNode;x.name=S,t.connection.tentativeNode=null,co(S,x)}if(t.connection&&(t.connection.nodeName=S),fe.debug?.(s,"received node name:",S,"db:",u),!u)try{Ka(u=A[2]),u==="system"&&(Ne=ta(t,(x,q)=>{Va(q)&&Ir(q)}),e.on("close",()=>{Ne?.remove()}))}catch(x){fe.warn?.(s,"Error setting database",x),e.send((0,ct.encode)([mu])),is(1008,x.message);return}$a()}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;Va(q)&&(q==="system"?We[q]?.[x.table]||(ee=qy(x,We[q]?.[x.table])):ee=qy(x,We[q]?.[x.table]),_||(_=ee?.auditStore),T||(T=ut()?.[q]))}break}case mu:is();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 B=A[3];T||(u?fe.error?.(s,"No tables found for",u):fe.error?.(s,"Database name never received"));let k=T[B];k=qy({table:B,database:u,attributes:R.attributes,schemaDefined:R.schemaDefined},k),Gr[b]={name:B,decoder:new ct.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:R.typedStructs,structures:R.structures}),getEntry(x){return k.primaryStore.getEntry(x)},rootStore:k.primaryStore.rootStore};break;case rH:zE=_?rB(S,R,_):new Map,Fa=A[2],fe.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${Fa}`);break;case nH:let C=b;Nl[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:y=R,h.send({type:"end_txn",localTime:y,remoteNodeIds:g});break;case sH:{let x=R,q;try{let ee=A[3],G=Cd[b]||(Cd[b]=T[A[4]]);if(!G)return fe.warn?.("Unknown table id trying to handle record request",b);let Re=G.primaryStore.getBinaryFast(Symbol.for("structures")),Ee=Re.length;if(Ee!==vt){vt=Ee;let re=(0,ct.decode)(Re);e.send((0,ct.encode)([Fy,{typedStructs:re.typed,structures:re.named},b,G.tableName]))}let Ae=G.primaryStore.getBinaryFast(ee);if(Ae){let re=G.primaryStore.decoder.decode(Ae,{valueAsBuffer:!0});q=(0,ct.encode)([qp,x,{value:re.value,expiresAt:re.expiresAt,version:re.version,residencyId:re.residencyId,nodeId:re.nodeId,user:re.user}])}else q=(0,ct.encode)([qp,x])}catch(ee){q=(0,ct.encode)([qp,x,{error:ee.message}])}e.send(q);break}case qp:{let{resolve:x,reject:q,tableId:ee,key:G}=m.get(A[1]),Re=A[2];if(Re?.error)q(new Error(Re.error));else if(Re){let Ee=Gr[ee].decoder.decode(Re.value);Re.value=Ee,Re.key=G,x(Re)}else x();m.delete(A[1]);break}case 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,Cc.set(u,h)}if(r.name)q=Sr().subscribe(r.name),q.then(async ce=>{x=ce;for await(let Ye of x){let rt=Ye.value;if(!(rt?.replicates===!0||rt?.replicates?.receives||rt?.subscriptions?.some(Ze=>(Ze.database||Ze.schema)===u&&Ze.publish!==!1))){ee=!0,e.send((0,ct.encode)([mu])),is(1008,`Unauthorized database subscription to ${u}`);return}}},ce=>{fe.error?.(s,"Error subscribing to HDB nodes",ce)});else if(!(r?.role?.permission?.super_user||r.replicates)){e.send((0,ct.encode)([mu])),is(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"),_i(9),_i(Kp),Ya(ge=Ye),we()),i=c,Ee.txnTime=0;return}let rt=ce.nodeId,Ze=ce.tableId,st=re[Ze];if(!st&&(st=re[Ze]=Re(h.tableById[Ze]),!st))return fe.debug?.("Not subscribed to table",Ze);let Bt=st.table,ko=Bt.primaryStore,Yt=ko.encoder;(ce.extendedType&Oh||!Yt.typedStructs)&&(Yt._mergeStructures(Yt.getStructures()),Yt.typedStructs&&(Yt.lastTypedStructuresLength=Yt.typedStructs.length));let QE=Ae[rt];if(!(QE&&QE.startTime<Ye&&(!QE.endTime||QE.endTime>Ye)))return 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,Ya(ZT));let Wa=ce.residencyId,eg=ji(Wa,Bt),JE;if(eg&&!eg.includes(S)){let wl=ji(ce.previousResidencyId,Bt);if(wl&&!wl.includes(S)&&(ce.type==="put"||ce.type==="patch")||Bt.getResidencyById)return Bw();let Ud=ce.recordId;fe.trace?.(s,"sending invalidation",Ud,S,"from",rt);let ng=0;Wa&&(ng|=rc),ce.previousResidencyId&&(ng|=nc);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=Ul(ce.version,Ze,Ud,null,rt,ce.user,ce.type==="put"||ce.type==="patch"?"invalidate":ce.type,Yt.encode(XE),ng,Wa,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]))),Wa&&!Dd[Wa]&&(e.send((0,ct.encode)([nH,eg,Wa])),Dd[Wa]=!0),JE)_i(JE.length),Md(JE);else{let wl=ce.encoded,Ud=wl[0]===66?8:0;_i(wl.length-Ud),Md(wl,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),Ne||(Ne=Lc(Ye=>{Ye.databaseName===u&&Ir(u)}),Me=sf(Ye=>{Ye===u&&(e.send((0,ct.encode)([mu])),is())}),e.on("close",()=>{Ne?.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),is(1008,"Invalid sequence id"+K));let Ye;if(ce&&!ee&&(ce=!1,!(Yy(_)<=K)&&_H.default.get(fH.CONFIG_PARAMS.REPLICATION_COPYTABLESTOCATCHUP)!==!1&&server.nodes[0]?.name===S)){fe.info?.("Replicating all tables to",S);let Ze=K,st=Wp(_);for(let Bt in T){if(!Re(Bt))continue;let ko=T[Bt];for(let Yt of ko.primaryStore.getRange({snapshot:!1})){if(ee)return;Yt.localTime>=K&&(fe.trace?.(s,"Copying record from",u,Bt,Yt.key,Yt.localTime),Ze=Math.max(Yt.localTime,Ze),Ye=!0,Be({recordId:Yt.key,tableId:ko.tableId,type:"put",getValue(){return Yt.value},encoded:ko.primaryStore.getBinary(Yt.key),version:Yt.version,residencyId:Yt.residencyId,nodeId:st},Yt.localTime))}}K=Ze}for(let{key:rt,value:Ze}of _.getRange({start:K||1,exclusiveStart:!0,snapshot:!1})){if(ee)return;de=rt;let st=xt(Ze);Be(st,rt),e._socket.writableNeedDrain?await new Promise(Bt=>e._socket.once("drain",Bt)):await new Promise(setImmediate),vs.startTime=rt,Ye=!0}Ye&&Be({type:"end_txn"},K),de=0,await uB(_)}while(!ee)}).catch(ce=>{fe.error?.(s,"Error handling subscription to node",ce),is(1008,"Error handling subscription to node")});break}}return}Se.position=8;let tt=!0,v,p;do{let A=Se.readInt();if(A===9&&Se.getUint8(Se.position)==Kp){Se.position++,y=p=Se.readFloat64(),fe.trace?.("received remote sequence update",y,u);break}let w=Se.position,R=xt(ie,w,w+A),b=Gr[R.tableId];b||fe.error?.(`No table found with an id of ${R.tableId}`);let D;R.residencyId&&(D=Nl[R.residencyId],fe.trace?.(s,"received residency list",D,R.type,R.recordId));try{v={table:b.name,id:R.recordId,type:R.type,nodeId:zE.get(R.nodeId),residencyList:D,timestamp:R.version,value:R.getValue(b),user:R.user,beginTxn:tt,expiresAt:R.expiresAt}}catch(O){throw O.message+="typed structures for current decoder"+JSON.stringify(b.decoder.typedStructs),O}tt=!1,nf&&fe.trace?.(s,"received replication message",R.type,"id",v.id,"version",R.version,"nodeId",v.nodeId,"value",v.value),h.send(v),Se.position=w+A}while(Se.position<ie.byteLength);jE++,pr(ie.byteLength,"bytes-received",S+"."+u+"."+v.table,"replication","ingest"),jE>vw&&!Ga&&(Ga=!0,e.pause()),h.send({type:"end_txn",localTime:y,remoteNodeIds:g,onCommit(){if(v){let A=Date.now()-v.timestamp;pr(A,"replication-latency",S+"."+u+"."+v.table,v.type,"ingest")}jE--,Ga&&(Ga=!1,e.resume()),!I&&p&&(fe.trace?.(s,"queuing confirmation of a commit at",p),setTimeout(()=>{e.send((0,ct.encode)([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",Oe),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-X,Nc({name:S,database:u,url:t.url,lastSendTime:de,latency:t.connection.latency})),X=null}),e.on("close",(ie,Se)=>{clearInterval(U),clearTimeout(H),vs&&vs.emit("close"),qa&&qa.end();for(let[tt,{reject:v}]of m)v(new Error(`Connection closed ${Se?.toString()} ${ie}`));fe.debug?.(s,"closed",ie,Se?.toString())});function Ve(){}a(Ve,"recordRemoteNodeSequence");function is(ie,Se){e.isFinished=!0,e.close(ie,Se)}a(is,"close");function $a(){if(f||(f=!0,t.connection?.on("subscriptions-updated",$a)),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let ie=new Map;try{for(let v of h?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let p of v.value.nodes||[])p.lastTxnTime>(ie.get(p.id)??0)&&ie.set(p.id,p.lastTxnTime)}catch(v){if(!v.message.includes("Can not re"))throw v}let Se=t.connection?.nodeSubscriptions?.[0];g=[];let tt=t.connection?.nodeSubscriptions.map((v,p)=>{let A=[],{replicateByDefault:w}=v;if(v.subscriptions){for(let O of v.subscriptions)if(O.subscribe&&(O.schema||O.database)===u){let B=O.table;T?.[B]?.replicate!==!1&&A.push(B)}w=!1}else for(let O in T)(w?T[O].replicate===!1:T[O].replicate)&&A.push(O);let R=_&&Lp(v.name,_),b=h?.dbisDB?.get([Symbol.for("seq"),R])??1,D=Math.max(b?.seqId??1,(typeof v.start_time=="string"?new Date(v.start_time).getTime():v.start_time)??1);if(fe.debug?.("Starting time recorded in db",v.name,R,u,b?.seqId,"start time:",D),Se!==v){D>5e3&&(D-=5e3);let O=_&&Lp(Se.name,_),B=h?.dbisDB?.get([Symbol.for("seq"),O])??1;for(let k of B?.nodes||[])k.name===v.name&&(D=k.seqId,fe.debug?.("Using sequence id from proxy node",Se.name,D))}return g.push(R),ie.get(R)>D&&(D=ie.get(R),fe.debug?.("Updating start time from more recent txn recorded",Se.name,D)),{name:v.name,replicateByDefault:w,tables:A,startTime:D,endTime:v.end_time}});if(tt)if(fe.debug?.(s,"sending subscription request",tt,h?.dbisDB?.path),clearTimeout(ne),tt.length>0)e.send((0,ct.encode)([eH,tt]));else{let v=a(()=>{let p=performance.now();ne=setTimeout(()=>{Q<=p?is(1008,"No nodes to subscribe to"):v()},V)},"schedule_close");v()}}a($a,"sendSubscriptionRequestUpdate");function ji(ie,Se){if(!ie)return;let tt=wn[ie];return tt||(tt=Se.getResidencyRecord(ie),wn[ie]=tt),tt}a(ji,"getResidence");function Va(ie){return!(la&&la!="*"&&!la[ie]&&!la.includes?.(ie)&&!la.some?.(Se=>Se.name===ie))}a(Va,"checkDatabaseAccess");function Ka(ie){if(h=h||d.get(ie),!Va(ie))throw new Error(`Access to database "${ie}" is not permitted`);h||fe.warn?.(`No database named "${ie}" was declared and registered`),_=h?.auditStore,T||(T=ut()?.[ie]);let Se=ot();if(Se===S)throw Se?new Error("Should not connect to self",Se):new Error("Node name not defined");return Pd(Se,ie),!0}a(Ka,"setDatabase");function Pd(ie,Se){let tt=ut()?.[Se],v=[];for(let p in tt){let A=tt[p];v.push({table:p,schemaDefined:A.schemaDefined,attributes:A.attributes.map(w=>({name:w.name,type:w.type,isPrimaryKey:w.isPrimaryKey}))})}fe.trace?.("Sending database info for node",ie,"database name",Se),e.send((0,ct.encode)([tH,ie,Se,v]))}a(Pd,"sendNodeDBName");function Ir(ie){let Se=ut()?.[ie],tt=[];for(let v in Se){if(Bs&&!Bs.some(A=>A.replicateByDefault?!A.tables.includes(v):A.tables.includes(v)))continue;let p=Se[v];tt.push({table:v,schemaDefined:p.schemaDefined,attributes:p.attributes.map(A=>({name:A.name,type:A.type,isPrimaryKey:A.isPrimaryKey}))})}e.send((0,ct.encode)([cH,tt,ie]))}a(Ir,"sendDBSchema");let Il=1,Ld=[];return{end(){qa&&qa.end(),vs&&vs.emit("close")},getRecord(ie){let Se=Il++;return new Promise((tt,v)=>{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:v})})},sendOperation(ie){let Se=Il++;return ie.requestId=Se,e.send((0,ct.encode)([iH,ie])),new Promise((tt,v)=>{m.set(Se,{resolve:tt,reject:v})})}};function _i(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 v=tt-Se;xo(v),ie.copy(o,c,Se,tt),c+=v}function Ya(ie){xo(8),l.setFloat64(c,ie),c+=8}function xo(ie){if(ie+16>o.length-c){let Se=Buffer.allocUnsafeSlow(c+ie-i+65536>>10<<11);o.copy(Se,0,i,c),c=c-i,i=0,o=Se,l=new DataView(o.buffer,0,o.length)}}}function qy(e,t){let r=e.database??"data";if(r!=="data"&&!We[r]){fe.warn?.("Database not found",e.database);return}t||(t={});let n=!1,s=e.schemaDefined,i=t.attributes||[];for(let o=0;o<e.attributes?.length;o++){let c=e.attributes[o],l=i[o];(!l||l.name!==c.name||l.type!==c.type)&&(n=!0,s||(c.indexed=!0),i[o]=c)}return n?(fe.debug?.("(Re)creating",e),Et({table:e.table,database:e.database,schemaDefined:e.schemaDefined,attributes:i,...t})):t}var _H,fH,ct,EH,hH,fe,$y,pH,mH,Vy,SH,eH,tH,rH,mu,nH,Fy,sH,qp,iH,$p,oH,aH,cH,TH,Cc,nf,lH,ure,uH,Gy,dH,Vp,gH=Ie(()=>{Pe();Ji();_y();my();ds();_H=L(se()),fH=L(M());vl();ct=require("msgpackr"),EH=require("ws"),hH=require("worker_threads"),fe=L(Oc());J_();$y=require("events"),pH=L(Xs()),mH=L(require("node:tls"));lu();Vy=L(require("node:process")),SH=require("node:net");Ii();eH=129,tH=140,rH=141,mu=142,nH=130,Fy=132,sH=133,qp=134,iH=136,$p=137,oH=143,aH=144,cH=145,TH=new Map,Cc=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,Nc({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=Yp(this.socket,{database:this.databaseName,subscription:this.subscription,url:this.url,connection:this},{replicates:!0}),this.sessionResolve(n)}),this.socket.on("error",s=>{s.code==="SELF_SIGNED_CERT_IN_CHAIN"?(fe.warn?.(`Can not connect to ${this.url}, this server does not have a certificate authority for the certificate provided by ${this.url}`),s.isHandled=!0):s.code!=="ECONNREFUSED"&&(s.code==="UNABLE_TO_VERIFY_LEAF_SIGNATURE"?fe.error?.(`Can not connect to ${this.url}, the certificate provided by ${this.url} is not trusted, this node needs to be added to the cluster, or a certificate authority needs to be added`):fe.error?.(`Error in connection to ${this.url} due to ${s.message}`)),this.sessionReject(s)}),this.socket.on("close",(s,i)=>{if(this.isConnected&&(_u({name:this.nodeName,database:this.databaseName,url:this.url,finished:this.socket.isFinished}),this.isConnected=!1),this.socket.isFinished){this.isFinished=!0,n?.end(),this.emit("finished");return}if(++this.retries%20===1){let o=i?.toString();fe.warn?.(`${n?"Disconnected from":"Failed to connect to"} ${this.url} (db: "${this.databaseName}"), due to ${o?'"'+o+'" ':""}(code: ${s})`)}n=null,this.resetSession(),setTimeout(()=>{this.connect()},this.retryTime).unref(),this.retryTime+=this.retryTime>>3})}resetSession(){this.session=new Promise((r,n)=>{this.sessionResolve=r,this.sessionReject=n})}subscribe(r,n){this.nodeSubscriptions=r,this.replicateTablesByDefault=n,this.emit("subscriptions-updated",r)}unsubscribe(){this.socket.isFinished=!0,this.socket.close(1008,"No longer subscribed")}getRecord(r){return this.session.then(n=>n.getRecord(r))}};a(Yp,"replicateOverWS");a(qy,"ensureTableIfChanged")});var ca={};je(ca,{clearThisNodeName:()=>Sre,disableReplication:()=>Ere,enabled_databases:()=>la,forEachReplicatedDatabase:()=>ta,getThisNodeId:()=>Wp,getThisNodeName:()=>ot,getThisNodeUrl:()=>ra,hostnameToUrl:()=>Jp,lastTimeInAuditStore:()=>j_,monitorNodeCAs:()=>wH,replicateOperation:()=>gre,replication_certificate_authorities:()=>Dc,sendOperationToNode:()=>af,servers:()=>_re,setReplicator:()=>DH,start:()=>fre,startOnMainThread:()=>Ty,subscribeToNode:()=>du,unsubscribeFromNode:()=>Bp,urlToNodeName:()=>zs});function fre(e){if(e.port||(e.port=ps.default.get(Mc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=ps.default.get(Mc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),!ot())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let n of 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(Dc);o.options.availableCAs&&c.push(...o.options.availableCAs.values());let l={...o.options,ca:c};o.replicationContext=Qp.createSecureContext(l)}catch(c){Tr.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),wH(s),ps.default.get(Mc.CONFIG_PARAMS.REPLICATION_ENABLEROOTCAS)!==!1&&s()}}function wH(e){let t=0;cu(r=>{r?.ca&&(Dc.add(r.ca),Dc.size!==t&&(t=Dc.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||Cc;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||Cc,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(Tr.trace("Setting up replicator subscription to database",e),!o?.auditStore)return this.subscription=o=new Mn,i.set(e,o),o.tableById=c,o.auditStore=t.auditStore,o.dbisDB=t.dbisDB,o.databaseName=e,l&&l(o),o;this.subscription=o}static subscribeOnThisThread(i,o){return!0}static async load(i){if(i){let o=i.residencyId,c=i.residency||t.dbisDB.get([Symbol.for("residency_by_id"),o]);if(c){let l,u=new Set;do{let d;for(let E of c){let f=pre(E,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 du(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=Cc.get(e.database);if(!t){let n;t=new Promise(s=>{Tr.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,Cc.set(e.database,t)}let r=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=ps.default.get(Mc.CONFIG_PARAMS.OPERATIONSAPI_TLS_CERTIFICATE)||ps.default.get(Mc.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=ps.default.get("replication_hostname")??zs(ps.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=ps.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function jp(e){let t=ps.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=ps.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)}),Lc((n,s)=>{r(n.databaseName)});function r(n){let s=We[n];Tr.trace("Checking replication status of ",n,e?.databases),e?.databases===void 0||e.databases==="*"||e.databases.includes(n)||e.databases.some?.(i=>i.name===n)||!s?t(s,n,!0):Tre(n)&&t(s,n,!1)}a(r,"forDatabase")}function Tre(e){let t=We[e];for(let r in t)if(t[r].replicate)return!0}function 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 ps,Tr,yH,bH,Mc,Qp,OH,NH,IH,dre,_re,Dc,la,of,AH,Wy,zp,ds=Ie(()=>{Pe();Vs();Ll();gH();qr();ps=L(se()),Tr=L(W()),yH=require("crypto"),bH=require("fs");J_();lu();Mc=L(M());_y();Qp=L(require("node:tls")),OH=L(_e()),NH=require("worker_threads"),dre=1,_re=[],Dc=ps.default.get(Mc.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(du,"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((EIe,BH)=>{"use strict";var Su=Uh(),Tu=a0(),Are=W(),Rre=require("uuid").v4,fIe=require("clone"),Zp=no(),gu=M(),yre=require("util"),ua=Bn(),{handleHDBError:mn,hdb_errors:bre}=_e(),{HDB_ERROR_MSGS:Xp,HTTP_STATUS_CODES:Sn}=bre,{SchemaEventMsg:em}=qs(),LH=mr(),{getDatabases:Ore}=(Pe(),oe(lt)),{transformReq:Au}=te(),{replicateOperation:MH}=(ds(),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=Su.schema_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);if(Au(e),!await Tu.checkSchemaExists(e.schema))throw mn(new Error,Xp.SCHEMA_EXISTS_ERR(e.schema),Sn.BAD_REQUEST,gu.LOG_LEVELS.ERROR,Xp.SCHEMA_EXISTS_ERR(e.schema),!0);return await ua.createSchema(e),`database '${e.schema}' successfully created`}a(UH,"createSchemaStructure");async function Ire(e){return Au(e),e.hash_attribute=e.primary_key??e.hash_attribute,await vH(e)}a(Ire,"createTable");async function vH(e){let t=Su.create_table_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);if(Su.validateTableResidence(e.residence),!await Tu.checkSchemaTableExists(e.schema,e.table))throw mn(new Error,Xp.TABLE_EXISTS_ERR(e.schema,e.table),Sn.BAD_REQUEST,gu.LOG_LEVELS.ERROR,Xp.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:Rre(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await ua.createTable(n,e);else throw mn(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Sn.BAD_REQUEST);else await ua.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(vH,"createTableStructure");async function wre(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=Su.schema_object(e),n=t??r;if(n)throw mn(n,n.message,Sn.BAD_REQUEST,void 0,void 0,!0);Au(e);let s=await Tu.checkSchemaExists(e.schema);if(s)throw mn(new Error,s,Sn.NOT_FOUND,gu.LOG_LEVELS.ERROR,s,!0);let i=await Tu.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);await ua.dropSchema(e),Zp.signalSchemaChange(new em(process.pid,e.operation,e.schema)),await 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=Su.table_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);Au(e);let r=await Tu.checkSchemaTableExists(e.schema,e.table);if(r)throw mn(new Error,r,Sn.NOT_FOUND,gu.LOG_LEVELS.ERROR,r,!0);await ua.dropTable(e),await 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=Su.attribute_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);Au(e);let r=await Tu.checkSchemaTableExists(e.schema,e.table);if(r)throw mn(new Error,r,Sn.NOT_FOUND,gu.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw mn(new Error,"You cannot drop a hash attribute",Sn.BAD_REQUEST,void 0,void 0,!0);if(gu.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw mn(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Sn.BAD_REQUEST,void 0,void 0,!0);try{return await ua.dropAttribute(e),Pre(e),Zp.signalSchemaChange(new em(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw Are.error(`Got an error deleting attribute ${yre.inspect(e)}.`),n}}a(Dre,"dropAttribute");function Pre(e){let t=Object.values(global.hdb_schema[e.schema][e.table].attributes);for(let r=0;r<t.length;r++)t[r].attribute===e.attribute&&global.hdb_schema[e.schema][e.table].attributes.splice(r,1)}a(Pre,"dropAttributeFromGlobal");async function Lre(e){Au(e);let t=Ore()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw mn(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Sn.BAD_REQUEST,void 0,void 0,!0);return await ua.createAttribute(e),Zp.signalSchemaChange(new em(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(Lre,"createAttribute");function Mre(e){return ua.getBackup(e)}a(Mre,"getBackup")});var xH=N((pIe,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((TIe,$H)=>{"use strict";var vre=Bn(),SIe=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((AIe,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((OIe,WH)=>{"use strict";var Gre=Bn(),yIe=KH(),Jy=te(),qre=M(),bIe=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((IIe,ZH)=>{var Ru=require("validate.js"),QH=Tt(),yu=M(),{handleHDBError:Wre,hdb_errors:jre}=_e(),{HDB_ERROR_MSGS:Qt,HTTP_STATUS_CODES:zre}=jre,Xy=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Qre={STRUCTURE_USER:"structure_user"},zH=Object.values(yu.ROLE_TYPES_ENUM),Jre="attribute_permissions",Xre="attribute_name",{PERMS_CRUD_ENUM:bu}=yu,Zre=[Jre,...Object.values(bu)],JH=[bu.READ,bu.INSERT,bu.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]&&!Ru.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(bu).forEach(d=>{Ru.isDefined(u[d])?Ru.isBoolean(u[d])||ir(Qt.TABLE_PERM_NOT_BOOLEAN(d),r,o,l):ir(Qt.TABLE_PERM_MISSING(d),r,o,l)}),u.attribute_permissions===void 0){ir(Qt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){ir(Qt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}if(u.attribute_permissions){let d=global.hdb_schema[o][l].attributes.map(({attribute:E})=>E),_={read:!1,insert:!1,update:!1};for(let E in u.attribute_permissions){let f=u.attribute_permissions[E];if(Object.keys(f).forEach(T=>{!ene.includes(T)&&T!==bu.DELETE&&ir(Qt.INVALID_ATTR_PERM_KEY(T),r,o,l)}),!Ru.isDefined(f.attribute_name)){ir(Qt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=f.attribute_name;if(!d.includes(h)){ir(Qt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}JH.forEach(T=>{Ru.isDefined(f[T])?Ru.isBoolean(f[T])||ir(Qt.ATTR_PERM_NOT_BOOLEAN(T,h),r,o,l):ir(Qt.ATTR_PERM_MISSING(T,h),r,o,l)}),!_.read&&f.read===!0&&(_.read=!0),!_.insert&&f.insert===!0&&(_.insert=!0),!_.update&&f.update===!0&&(_.update=!0)}if(u.read===!1&&_.read===!0||u.insert===!1&&_.insert===!0||u.update===!1&&_.update===!0){let E=`${o}.${l}`;ir(Qt.MISMATCHED_TABLE_ATTR_PERMS(E),r,o,l)}}}}return one(r)}a(XH,"customValidate");ZH.exports={addRoleValidation:tne,alterRoleValidation:rne,dropRoleValidation:nne};function ine(e){let{operation:t,permission:r}=e;if(t===yu.OPERATIONS_ENUM.ADD_ROLE||t===yu.OPERATIONS_ENUM.ALTER_ROLE){let n=r.super_user===!0,s=r.cluster_user===!0;if(Object.keys(r).length>1&&(n||s)){if(s&&n)return Qt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?yu.ROLE_TYPES_ENUM.SUPER_USER:yu.ROLE_TYPES_ENUM.CLUSTER_USER;return Qt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(ine,"validateNoSUPerms");function one(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:Qt.ROLE_PERMS_ERROR,...e};return Wre(new Error,n,zre.BAD_REQUEST)}else return null}a(one,"generateRolePermResponse");function ir(e,t,r,n){if(!r)t.main_permissions.push(e);else{let s=n?r+"_"+n:r;t.schema_permissions[s]?t.schema_permissions[s].push(e):t.schema_permissions[s]=[e]}}a(ir,"addPermError")});var lf=N((DIe,sx)=>{"use strict";var tx=un(),rx=Vr(),ane=dc(),eb=ex(),tb=no(),CIe=require("uuid").v4,cne=require("util"),sm=M(),lne=te(),rb=rx.searchByValue,une=rx.searchByHash,dne=cne.promisify(ane.delete),_ne=$s(),fne=jl(),{hdb_errors:Ene,handleHDBError:Uc}=_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 Uc(i)}if(n&&n.length>0)throw Uc(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 Uc(s)}if(n&&n?.message==="updated 0 of 1 records")throw Uc(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 Uc(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 Uc(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 Uc(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((LIe,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:vc}=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(vc.NOTIFY,vc.FATAL,vc.ERROR,vc.WARN,vc.INFO,vc.DEBUG,vc.TRACE),order:da.valid("asc","desc"),limit:da.number().min(1),start:da.number().min(0),log_name:da.custom(Nne)});function 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((UIe,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=[],y="",I;m.on("data",H=>{let X=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;H=y+H;let Y=0,V;for(;(V=X.exec(H))&&!m.destroyed;){I&&(I.message=H.slice(Y,V.index),U(I));let[ne,Q,de]=V,j=de.split("] ["),ae=j[0],Oe=j[1];j.splice(0,2),I={timestamp:Q,thread:ae,level:Oe,tags:j,message:""},Y=V.index+ne.length}y=H.slice(Y)}),m.on("end",H=>{m.destroyed||I&&(I.message=y.trim(),U(I))}),m.resume();function U(H){let X,Y,V;switch(!0){case(i&&c&&u):X=new Date(H.timestamp),Y=new Date(l),V=new Date(d),H.level===o&&X>=Y&&X<=V&&g<f?g++:H.level===o&&X>=Y&&X<=V&&(_a(H,E,S),g++,g===h&&m.destroy());break;case(i&&c):X=new Date(H.timestamp),Y=new Date(l),H.level===o&&X>=Y&&g<f?g++:H.level===o&&X>=Y&&(_a(H,E,S),g++,g===h&&m.destroy());break;case(i&&u):X=new Date(H.timestamp),V=new Date(d),H.level===o&&X<=V&&g<f?g++:H.level===o&&X<=V&&(_a(H,E,S),g++,g===h&&m.destroy());break;case(c&&u):X=new Date(H.timestamp),Y=new Date(l),V=new Date(d),X>=Y&&X<=V&&g<f?g++:X>=Y&&X<=V&&(_a(H,E,S),g++,g===h&&m.destroy());break;case i:H.level===o&&g<f?g++:H.level===o&&(_a(H,E,S),g++,g===h&&m.destroy());break;case c:X=new Date(H.timestamp),Y=new Date(l),X>=Y&&g<f?g++:X>=Y&&g>=f&&(_a(H,E,S),g++,g===h&&m.destroy());break;case u:X=new Date(H.timestamp),V=new Date(d),X<=V&&g<f?g++:X<=V&&g>=f&&(_a(H,E,S),g++,g===h&&m.destroy());break;default:g<f?g++:(_a(H,E,S),g++,g===h&&m.destroy())}}return a(U,"onLogMessage"),await Dne(m,"close"),S}a(Hne,"readLog");function _a(e,t,r){t==="desc"?xne(e,r):t==="asc"?kne(e,r):r.push(e)}a(_a,"pushLineToResult");function xne(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)>r?n=i+1:s=i}t.splice(n,0,e)}a(xne,"insertDescending");function kne(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)<r?n=i+1:s=i}t.splice(n,0,e)}a(kne,"insertAscending")});var om=N((FIe,Ex)=>{"use strict";var ab=require("joi"),{string:Ou,boolean:dx,date:Fne}=ab.types(),Gne=Tt(),{validateSchemaExists:BIe,validateTableExists:HIe,validateSchemaName:xIe}=gi(),qne=M(),$ne=Ct(),_x=se();_x.initSync();var kIe=Ou.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:Ou.valid("add_node","update_node","set_node_replication"),node_name:Ou.optional(),subscriptions:ab.array().items({table:Ou.optional(),schema:Ou.optional(),database:Ou.optional(),subscribe: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((qIe,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((VIe,Tx)=>{"use strict";var jne=px(),Nu=require("passport"),zne=require("passport-local").Strategy,Qne=require("passport-http").BasicStrategy,Jne=require("util"),Xne=xn(),Sx=Jne.callbackify(Xne.findAndValidateUser),$Ie=Dn(),Zne=M(),mx=fu();Nu.use(new zne(function(e,t,r){Sx(e,t,r)}));Nu.use(new Qne(function(e,t,r){Sx(e,t,r)}));Nu.serializeUser(function(e,t){t(null,e)});Nu.deserializeUser(function(e,t){t(null,e)});function ese(e,t,r){if(e.raw?.user!==void 0)return r(null,e.raw.user);let n,s;if(e.headers?.authorization){let o=e.headers.authorization.split(" ");n=o[0],s=o[1]}function i(o,c){return o?r(o):c?r(null,c):r("Must login")}switch(a(i,"handleResponse"),n){case"Basic":Nu.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===Zne.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?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:Nu.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(ese,"authorize");function tse(e,t){let r=jne(e);if(r){t(r);return}let n={authorized:!0,messages:[]},s=e.user.role;if(!s?.permission)return t("Invalid role");let i=JSON.parse(s.permission);if(i.super_user)return t(null,n);if(!i[e.schema])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.schema} schema`),t(null,n);if(!i[e.schema].tables[e.table])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.table} table`),t(null,n);if(!i[e.schema].tables[e.table][e.operation])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.operation} on ${e.table} table`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&!e.attributes)return n.authorized=!1,n.messages.push(`${e.schema}.${e.table} has attribute permissions. Missing attributes to validate`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&e.attributes){let o=i[e.schema].tables[e.table].attribute_permissions;for(let c in o)e.attributes.indexOf(o[c].attribute_name)>-1&&!o[c][e.operation]&&(n.authorized=!1,n.messages.push(`Not authorized to ${e.operation} ${o[c].attribute_name} `))}return t(null,n)}a(tse,"checkPermissions");Tx.exports={authorize:ese,checkPermissions:tse}});var Iu=N((YIe,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((jIe,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((QIe,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((XIe,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((swe,Nx)=>{"use strict";var nse=Ox(),ewe=Ht(),twe=ht(),sse=W(),{getSchemaPath:rwe,getTransactionAuditStorePath:nwe}=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((owe,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 Cu=N((_we,Mx)=>{"use strict";var ase=require("fs-extra"),cse=require("path"),Qr=require("systeminformation"),fa=W(),Dx=mr(),cwe=Ct(),wu=M(),lse=Ix(),use=ro(),{getThreadInfo:Px}=dt(),_f=se();_f.initSync();var dse=Cx(),{openEnvironment:lwe}=ht(),{getSchemaPath:uwe}=gt(),{database:dwe,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(y=>{let{raw_load:I,raw_load_idle:U,raw_load_irq:H,raw_load_nice:X,raw_load_system:Y,raw_load_user:V,...ne}=y;S.cpus.push(ne)}),d.current_load=S,d}catch(e){return fa.error(`error in getCPUInfo: ${e}`),{}}}a(Sb,"getCPUInfo");async function Tb(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Qr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return fa.error(`error in getMemoryInfo: ${e}`),{}}}a(Tb,"getMemoryInfo");async function gb(){let e={core:[],clustering:[]};try{let t=await Qr.processes(),r;try{r=Number.parseInt(await ase.readFile(cse.join(_f.get(wu.CONFIG_PARAMS.ROOTPATH),wu.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===wu.NODE_ERROR_CODES.ENOENT)fa.warn("Unable to locate 'hdb.pid' file, try stopping and starting HarperDB. This could be because HarperDB is not running.");else throw n}t.list.forEach(n=>{n.pid===r?e.core.push(n):n.name==="nats-server"&&e.clustering.push(n)});for(let n of e.core)for(let s of t.list)s.pid===n.parentPid&&(s.name==="PM2"||s.command==="PM2")&&(n.parent="PM2");return e}catch(t){return fa.error(`error in getHDBProcessInfo: ${t}`),e}}a(gb,"getHDBProcessInfo");async function Ab(){let e={};try{if(!_f.get(wu.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Qr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...u}=await Qr.fsStats();return e.read_write=u,e.size=await Qr.fsSize(),e}catch(t){return fa.error(`error in getDiskInfo: ${t}`),e}}a(Ab,"getDiskInfo");async function Rb(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return _f.get(wu.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await Qr.networkInterfaceDefault(),e.latency=await Qr.inetChecksite("google.com"),(await Qr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:u,ieee8021xState:d,carrier_changes:_,...E}=n;e.interfaces.push(E)}),(await Qr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)})),e}catch(t){return fa.error(`error in getNetworkInfo: ${t}`),e}}a(Rb,"getNetworkInfo");async function yb(){if(am!==void 0)return am;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Qr.osInfo();e=c;let l=await Qr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,am=e,am}catch(t){return fa.error(`error in getSystemInformation: ${t}`),e}}a(yb,"getSystemInformation");async function bb(){let e=[],t=await use.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await lse(n));return e}a(bb,"getTableSize");async function Ob(){let e={};for(let t in pb){let r=e[t]={},n=r.tables={};for(let s in pb[t])try{let i=pb[t][s];if(!r.readers&&(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[u,d,_]=l.trim().split(" ");return{pid:u,thread:d,txnid:_}}),i.auditStore)){let{treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:d,entryCount:_,overflowPages:E}=i.auditStore.getStats();r.audit={treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:d,entryCount:_,overflowPages:E}}let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){fa.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(Ob,"getMetrics");async function Lx(){if(_f.get(wu.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 Bc=N((Ewe,Ux)=>{"use strict";Ux.exports={version:fse,printVersion:Ese};var cm=Xl();function fse(){if(cm)return cm.version}a(fse,"version");function Ese(){cm&&console.log(`HarperDB Version ${cm.version}`)}a(Ese,"printVersion")});var Pi=N((Swe,xx)=>{"use strict";var hse=un(),Nb=te(),pse=require("util"),Hc=M(),vx=se();vx.initSync();var mse=cb(),Bx=Vr(),{Node:pwe,NodeSubscription:mwe}=Iu(),Sse=jl(),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=Cu(),wse=Bc(),{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(Hc.SYSTEM_SCHEMA_NAME,Hc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return Pse(t)}a(vse,"getNodeRecord");async function Bse(e){let t=new Tse(Hc.SYSTEM_SCHEMA_NAME,Hc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return hse.upsert(t)}a(Bse,"upsertNodeRecord");function 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(Hc.CONFIG_PARAMS.CLUSTERING_ENABLED))throw Rse(new Error,Ose.CLUSTERING_NOT_ENABLED,bse.BAD_REQUEST,void 0,void 0,!0)}a(xse,"checkClusteringEnabled");async function kse(){let e=new Nse(Hc.SYSTEM_SCHEMA_NAME,Hc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await Lse(e))}a(kse,"getAllNodeRecords");async function Fse(){let e=await Ise.getSystemInformation();return{hdb_version:wse.version(),node_version:e.node_version,platform:e.platform}}a(Fse,"getSystemInfo")});var Ib=N((gwe,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}=Iu();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 xc={};je(xc,{addNodeBack:()=>zse,removeNodeBack:()=>Qse,setNode:()=>jse});async function jse(e){e.node_name&&!e.hostname&&(e.hostname=e.node_name),e.verify_tls!==void 0&&(e.rejectUnauthorized=e.verify_tls);let{url:t,hostname:r}=e;t?r||(r=e.hostname=zs(t)):t=Jp(r);let n=(0,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,ms.getReplicationCert)();let f=await(0,ms.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,ms.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,ms.setCertTable)({name:Kse.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,ms.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,ms.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,ms.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 ms,jx,Du,zx,ff,$n,uo,Kse,Yse,Wse,kc=Ie(()=>{ms=L(Xs()),jx=L(Tt()),Du=L(require("joi")),zx=L(se()),ff=L(M());J_();lu();ds();$n=L(W()),uo=L(_e()),{pki:Kse}=require("node-forge"),{HTTP_STATUS_CODES:Yse}=uo.hdb_errors,Wse=Du.default.object({hostname:Du.default.string(),verify_tls:Du.default.boolean(),replicates:Du.default.boolean(),subscriptions:Du.default.array()});a(jse,"setNode");a(zse,"addNodeBack");a(Qse,"removeNodeBack");a(Wx,"reverseSubscription")});var pf=N((wwe,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=Pi(),wb=se(),eie=Ib(),{Node:tie,NodeSubscription:rie}=Iu(),{broadcast:nie}=dt(),{setNode:sie}=(kc(),oe(xc)),Nwe=se(),Iwe=M(),iie="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",oie="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",aie=wb.get(Em.CONFIG_PARAMS.CLUSTERING_NODENAME);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((Pwe,Zx)=>{"use strict";var{handleHDBError:Cb,hdb_errors:lie}=_e(),{HTTP_STATUS_CODES:Db}=lie,{addUpdateNodeValidator:uie}=om(),mf=W(),hm=M(),Xx=Ct(),Dwe=te(),Sf=mr(),Tf=Pi(),Pb=se(),{cloneDeep:die}=require("lodash"),_ie=Ib(),{Node:fie,NodeSubscription:Eie}=Iu(),{broadcast:hie}=dt(),{setNode:pie}=(kc(),oe(xc)),mie="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",Sie="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Tie=Pb.get(hm.CONFIG_PARAMS.CLUSTERING_NODENAME);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((Mwe,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((vwe,lk)=>{"use strict";var{handleHDBError:ik,hdb_errors:Nie}=_e(),{HTTP_STATUS_CODES:ok}=Nie,Iie=sk(),gf=W(),ak=Pi(),wie=te(),Pu=M(),ck=Ct(),Mb=mr(),Ub=se(),{RemotePayloadObject:Cie}=df(),{NodeSubscription:Die}=Iu(),Pie=I_(),Lie=dc(),{broadcast:Mie}=dt(),{setNode:Uie}=(kc(),oe(xc)),vie=Ub.get(Pu.CONFIG_PARAMS.CLUSTERING_NODENAME);lk.exports=Bie;async function Bie(e){if(gf.trace("removeNode called with:",e),Ub.get(Pu.CONFIG_PARAMS.REPLICATION_URL)??Ub.get(Pu.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(Pu.OPERATIONS_ENUM.REMOVE_NODE,vie,[]),i,o=!1;for(let l=0,u=n.subscriptions.length;l<u;l++){let d=n.subscriptions[l];d.subscribe===!0&&await Mb.updateConsumerIterator(d.schema,d.table,r,"stop");try{await Mb.updateRemoteConsumer(new Die(d.schema,d.table,!1,!1),r)}catch(_){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(Pu.SYSTEM_SCHEMA_NAME,Pu.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((Hwe,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((kwe,mk)=>{"use strict";var fk=M(),pm=W(),qie=te(),$ie=se(),Vie=Af(),Kie=pf(),Yie=Pi(),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((Gwe,gk)=>{"use strict";var Rf=require("joi"),Zie=Tt(),{validateSchemaExists:Sk,validateTableExists:eoe,validateSchemaName:Tk}=gi(),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(($we,Rk)=>{"use strict";var{handleHDBError:noe,hdb_errors:soe}=_e(),{HTTP_STATUS_CODES:ioe}=soe,ooe=Ak(),aoe=mr(),coe=Pi();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((Kwe,Ck)=>{"use strict";var xb=Pi(),uoe=mr(),mm=se(),Lu=M(),Fc=Ct(),doe=te(),Hb=W(),{RemotePayloadObject:_oe}=df(),{ErrorCode:yk}=require("nats"),{parentPort:bk}=require("worker_threads"),{onMessageByType:foe}=dt(),{getThisNodeName:Eoe}=(ds(),oe(ca)),{requestClusterStatus:hoe}=(J_(),oe(AB)),Ok=mm.get(Lu.CONFIG_PARAMS.CLUSTERING_ENABLED),Nk=mm.get(Lu.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(Lu.CONFIG_PARAMS.REPLICATION_URL)||mm.get(Lu.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(Lu.OPERATIONS_ENUM.CLUSTER_STATUS,Nk,void 0,await xb.getSystemInfo()),s,i,o=Fc.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await uoe.request(Fc.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Fc.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=Fc.CLUSTER_STATUS_STATUSES.CLOSED,Hb.error(`Error getting node status from ${r} `,s))}catch(l){Hb.warn(`Error getting node status from ${r}`,l),l.code===yk.NoResponders?o=Fc.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===yk.Timeout?o=Fc.CLUSTER_STATUS_STATUSES.TIMEOUT:o=Fc.CLUSTER_STATUS_STATUSES.CLOSED}let c=new moe(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let l={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==Lu.PRE_4_0_0_VERSION&&await xb.upsertNodeRecord(l)}catch(l){Hb.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(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((Wwe,Dk)=>{"use strict";var{handleHDBError:Soe,hdb_errors:Toe}=_e(),{HTTP_STATUS_CODES:goe}=Toe,Aoe=mr(),Roe=Pi(),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((zwe,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((Jwe,Gk)=>{"use strict";var _o=wt(),qb=te(),Ss=M(),Mu=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(Ss.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):_o.updateConfigValue(Ss.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(Mu.get(Ss.CONFIG_PARAMS.CLUSTERING_ENABLED))return Doe(e);let r=[],n=[],s=Mu.get(Ss.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{Fk(s,i)?n.push(i):(s.push(i),r.push(i))}),_o.updateConfigValue(Ss.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(Mu.get(Ss.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=_o.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return Mu.get(Ss.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(Mu.get(Ss.CONFIG_PARAMS.CLUSTERING_ENABLED))return Uoe(e);let r=[],n=[],s=Mu.get(Ss.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{Fk(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),_o.updateConfigValue(Ss.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(Ss.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=qb.isEmptyOrZeroLength(n)?null:n,_o.updateConfigValue(Ss.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:kk,deleted:s,skipped:i}}a(Uoe,"deleteRoutesNats")});var $k=N((Zwe,qk)=>{"use strict";var yf=require("alasql"),Gc=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 Gc(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,u=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(u).has(l))if(r.has(l))l=r.get(l);else{Zs.info(`table specified as ${l} not found.`);return}t.get(u).get(l).indexOf(c.columnid)<0&&t.get(u).get(l).push(c.columnid)}if(e.where){let c=new Gc(e.where),l=e.from[0].tableid;for(let{node:u}of c)if(u&&u.columnid){let d=u.tableid?u.tableid:l;if(!t.get(i).has(d))if(r.has(d))d=r.get(d);else{Zs.info(`table specified as ${d} not found.`);continue}t.get(i).get(d).indexOf(u.columnid)<0&&t.get(i).get(d).push(u.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new Gc(c.on);for(let{node:u}of l)if(u&&u.columnid){let d=u.tableid,_=s.get(d);if(!t.get(_).has(d))if(r.has(d))d=r.get(d);else{Zs.info(`table specified as ${d} not found.`);continue}t.get(_).get(d).indexOf(u.columnid)<0&&t.get(_).get(d).push(u.columnid)}}),e.order){let c=new Gc(e.order);for(let{node:l}of c)if(l&&l.columnid){let u=l.tableid,d=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(d).has(u))if(r.has(u))u=r.get(u);else{Zs.info(`table specified as ${u} not found.`);return}t.get(d).get(u).indexOf(l.columnid)<0&&t.get(d).get(u).push(l.columnid)}}}a(koe,"getSelectAttributes");function Foe(e,t,r){if(!e){Zs.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new Gc(e.columns),s=e.table.databaseid;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 Gc(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 Gc(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((tCe,Wk)=>{var Am=_c(),Vk=require("chalk"),Vn=W(),Kk=require("prompt"),{promisify:$oe}=require("util"),Kb=M(),Voe=require("fs-extra"),Koe=require("path"),Yoe=te(),Woe=Bc(),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((nCe,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((iCe,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((aCe,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((lCe,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((dCe,iF)=>{"use strict";var qc=require("path"),$c=require("fs-extra"),sae=zk(),iae=Xk(),oae=eF(),aae=rF(),Xb=xn(),vu=te(),Tn=wt(),ym=M(),Nf=Ct(),{CONFIG_PARAMS:Jt}=ym,Bu=W(),If=se(),nF=to(),Zb=mr(),cae=Xs(),Uu="clustering",lae=1e4,sF=50;iF.exports={generateNatsConfig:dae,removeNatsConfig:_ae,getHubConfigPath:uae};function uae(){let e=If.get(Jt.ROOTPATH);return qc.join(e,Uu,Nf.NATS_CONFIG_FILES.HUB_SERVER)}a(uae,"getHubConfigPath");async function dae(e=!1,t=void 0){let r=If.get(Jt.ROOTPATH);$c.ensureDirSync(qc.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 $c.exists(i)&&!await $c.exists(!n)&&await cae.createNatsCerts();let o=qc.join(r,Uu,Nf.PID_FILES.HUB),c=qc.join(r,Uu,Nf.PID_FILES.LEAF),l=Tn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=qc.join(r,Uu,Nf.NATS_CONFIG_FILES.HUB_SERVER),d=qc.join(r,Uu,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();(vu.isEmpty(g)||g.active!==!0)&&bm(`Invalid cluster user '${m}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await Rm(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await Rm(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await Rm(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),await Rm(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let S=[],y=[];for(let[ne,Q]of T.entries())Q.role?.role===ym.ROLE_TYPES_ENUM.CLUSTER_USER&&Q.active&&(S.push(new aae(Q.username,nF.decrypt(Q.hash))),y.push(new oae(Q.username,nF.decrypt(Q.hash))));let I=[],{hub_routes:U}=Tn.getClusteringRoutes();if(!vu.isEmptyOrZeroLength(U))for(let ne of U)I.push(`tls://${g.sys_name_encoded}:${g.uri_encoded_d_hash}@${ne.host}:${ne.port}`);let H=new sae(Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),f,o,i,s,n,_,E,h,Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NAME),Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),I,S,y);n==null&&(delete H.tls.ca_file,delete H.leafnodes.tls.ca_file),t=vu.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===ym.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await $c.writeJson(u,H),Bu.trace(`Hub server config written to ${u}`));let X=`tls://${g.sys_name_encoded}:${g.uri_encoded_d_hash}@0.0.0.0:${h}`,Y=`tls://${g.uri_encoded_name}:${g.uri_encoded_d_hash}@0.0.0.0:${h}`,V=new iae(Tn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT),f,c,l,[X],[Y],S,y,i,s,n,_);n==null&&delete V.tls.ca_file,(t===void 0||t===ym.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await $c.writeJson(d,V),Bu.trace(`Leaf server config written to ${d}`))}a(dae,"generateNatsConfig");async function Rm(e){let t=If.get(e);return vu.isEmpty(t)&&bm(`port undefined for '${e}'`),await vu.isPortTaken(t)&&bm(`'${e}' port '${t}' is is in use by another process, check to see if HarperDB is already running or another process is using this port.`),!0}a(Rm,"isPortAvailable");function bm(e){let t=`Error generating clustering config: ${e}`;Bu.error(t),console.error(t),process.exit(1)}a(bm,"generateNatsConfigError");async function _ae(e){let{port:t,config_file:r}=Zb.getServerConfig(e),{username:n,decrypt_hash:s}=await Xb.getClusterUser(),i=0,o=2e3;for(;i<sF;){try{let d=await Zb.createConnection(t,n,s,!1);if(d.protocol.connected===!0){d.close();break}}catch(d){Bu.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${d}`)}if(i++,i>=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&&Bu.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await vu.async_set_timeout(u)}let c="0".repeat(lae),l=qc.join(If.get(Jt.ROOTPATH),Uu,r);await $c.writeFile(l,c),await $c.remove(l),Bu.notify(e,"started.")}a(_ae,"removeNatsConfig")});var dF=N((fCe,uF)=>{"use strict";var Kn=se(),fae=_c(),Ge=M(),wf=Ct(),fo=require("path"),{PACKAGE_ROOT:Im}=M(),oF=se(),Nm=te(),Hu="/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=Hu,i.error_file=Hu),i}a(mae,"generateNatsHubServerConfig");var Sae=9940;function Tae(){Kn.initSync(!0);let e=Kn.get(Ge.CONFIG_PARAMS.ROOTPATH),t=fo.join(e,"clustering",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=Hu,i.error_file=Hu),i}a(Tae,"generateNatsLeafServerConfig");function gae(){Kn.initSync();let e=fo.join(Kn.get(Ge.CONFIG_PARAMS.LOGGING_ROOT),Ge.LOG_NAMES.HDB),t={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:Ge.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:Eae,autorestart:!1};return Kn.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=Hu,t.error_file=Hu),t}a(gae,"generateClusteringUpgradeV4ServiceConfig");function Aae(){let e={[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.RESTART_HDB};return Nm.noBootFile()&&(e[Ge.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Nm.getEnvCliRootPath()),{...{name:Ge.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd: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 xu=N((pCe,OF)=>{"use strict";var at=M(),yae=te(),ho=Om(),wm=mr(),Eo=Ct(),Ea=dF(),Cm=se(),Vc=W(),bae=Pi(),{startWorker:_F,onMessageFromWorkers:Oae}=dt(),Nae=Cu(),hCe=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?Vc.OUTPUTS.STDERR:Vc.OUTPUTS.STDOUT;Vc.logCustomLevel(d||"info",f,n,i.slice(u,l.index).trim())}let[_,E]=l;u=l.index+_.length,d=Eo.LOG_LEVELS[E]}if(Eo.LOG_LEVEL_HIERARCHY[o]>=Eo.LOG_LEVEL_HIERARCHY[d||"info"]){let _=d===Eo.LOG_LEVELS.ERR||d===Eo.LOG_LEVELS.WRN?Vc.OUTPUTS.STDERR:Vc.OUTPUTS.STDOUT;Vc.logCustomLevel(d||"info",_,n,i.slice(u).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!Jr&&(Jr=[],!t)){let i=a(()=>{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){Vc.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(){pa.notify("Running compact on start"),console.log("Running compact on start");let e=(0,nO.get)(ma.CONFIG_PARAMS.ROOTPATH),t=new Map,r=ut();(0,sO.updateConfigValue)(ma.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1);try{for(let n in r){if(n==="system"||n.endsWith("-copy"))continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,Dm.join)(e,"backup",n+".mdb"),o=(0,Dm.join)(e,ma.DATABASES_DIR_NAME,n+"-copy.mdb"),c=0;try{c=await NF(n),console.log("Database",n,"before compact has a total record count of",c)}catch(l){pa.error("Error getting record count for database",n,l),console.error("Error getting record count for database",n,l)}t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await PF(n,o),console.log("Backing up",n,"to",i),await(0,Kc.move)(s,i,{overwrite:!0})}try{ku()}catch(n){pa.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n)}for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,Kc.move)(i,s,{overwrite:!0}),await(0,Kc.remove)((0,Dm.join)(e,ma.DATABASES_DIR_NAME,`${n}-copy.mdb-lock`));try{ku()}catch(n){pa.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n),process.exit(0)}}catch(n){pa.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,sO.updateConfigValue)(ma.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1);for(let[s,{db_path:i,backup_dest:o}]of t){console.error("Moving backup database",o,"back to",i);try{await(0,Kc.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw ku(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await 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}`;pa.error(l),console.error(l)}(0,nO.get)(ma.CONFIG_PARAMS.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||o===!1||(console.log("Removing backup",s),await(0,Kc.remove)(s))}}async function OF(e){let t=await(0,CF.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}async function DF(e,t){console.log("copyDb start");let r=ut()[e],n;for(let _ in r){n=r[_].primaryStore.rootStore;break}let s=n.dbisDb,i=n.auditStore,o=(0,NF.open)(new IF.default(t)),c=o.openDB(Pm.INTERNAL_DBIS_NAME),l,u=0,d=s.useReadTransaction();try{for(let{key:E,value:f}of s.getRange({transaction:d})){let h=f.is_hash_attribute||f.isPrimaryKey,T,m;if(h&&(T=f.compression,m=Lm(),m?f.compression=m:delete f.compression,T?.dictionary?.toString()===m?.dictionary?.toString()&&(T=null,m=null)),c.put(E,f),!(h||f.indexed))continue;let g=new wF.default(!h,h);g.encoding="binary",g.compression=T;let S=n.openDB(E,g);S.decoder=null,S.decoderCopies=!1,S.encoding="binary",g.compression=m;let y=o.openDB(E,g);y.encoder=null,console.log("copying",E,"from",e,"to",t),await _(S,y,h,d)}if(i){let E=n.openDB(Pm.AUDIT_STORE_NAME,Cf);console.log("copying audit log for",e,"to",t),_(i,E,!1,d)}async function _(E,f,h,T){let m=0,g=0,S=1e7,y=null;for(;S-- >0;)try{for(let I of E.getKeys({start:y,transaction:T}))try{y=I;let{value:U,version:H}=E.getEntry(I,{transaction:T});l=f.put(I,U,h?H:void 0),m++,T.openTimer&&(T.openTimer=0),g+=(I?.length||10)+U.length,u++>5e3&&(await l,console.log("copied",m,"entries",g,"bytes"),u=0)}catch(U){console.error("Error copying record",typeof I=="symbol"?"symbol":I,"from",e,"to",t,U)}console.log("finish copying, copied",m,"entries",g,"bytes");return}catch{if(typeof y=="string"){if(y==="z")return console.error("Reached end of dbi",y,"for",e,"to",t);y=y.slice(0,-2)+"z"}else if(typeof y=="number")y++;else return console.error("Unknown key type",y,"for",e,"to",t)}}a(_,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{d.done(),o.close()}}var NF,Dm,Kc,nO,IF,wF,Pm,ma,CF,sO,pa,oO=Ie(()=>{Pe();NF=require("lmdb"),Dm=require("path"),Kc=require("fs-extra"),nO=L(se()),IF=L(a_()),wF=L(o_()),Pm=L(Ht()),ma=L(M());Ji();CF=L(ro()),sO=L(wt()),pa=L(W());a(Gae,"compactOnStart");a(OF,"getTotalDBRecordCount");a(DF,"copyDb")});var qu=N((bCe,HF)=>{"use strict";var qae=require("minimist"),{isMainThread:cO,parentPort:Pf,threadId:ACe}=require("worker_threads"),Pt=M(),{PROCESS_DESCRIPTORS_VALIDATE:Fu}=Pt,Li=W(),lO=te(),Um=Om(),Mm=mr(),RCe=Ct(),UF=wt(),ei=xu(),PF=Cu(),{compactOnStart:$ae}=(oO(),oe(iO)),Vae=ja(),{restartWorkers:vm,onMessageByType:Kae}=dt(),{handleHDBError:Yae,hdb_errors:Wae}=_e(),{HTTP_STATUS_CODES:jae}=Wae,Lf=se(),{sendOperationToNode:LF,getThisNodeName:zae,monitorNodeCAs:Qae}=(ds(),oe(ca)),{getHDBNodeTable:yCe}=(lu(),oe(hB));Lf.initSync();var Df=`Restarting HarperDB. This may take up to ${Pt.RESTART_TIMEOUT_MS/1e3} seconds.`,Jae="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",MF="Clustering is not enabled so cannot be restarted",Xae="Invalid service",Gu,Ts;HF.exports={restart:vF,restartService:uO};cO&&Kae(Pt.ITC_EVENT_TYPES.RESTART,async(e,t)=>{e.workerType?await uO({service:e.workerType}):vF({operation:"restart"}),t.postMessage({type:"restart-complete"})});async function vF(e){Ts=Object.keys(e).length===0,Gu=await ei.isServiceRegistered(Pt.HDB_PROC_DESCRIPTOR);let t=qae(process.argv);if(t.service){await uO(t);return}if(Ts&&!Gu){console.error(Jae);return}if(Ts&&console.log(Df),Gu){ei.enterPM2Mode(),Li.notify(Df);let r=Vae(Object.keys(Pt.CONFIG_PARAM_MAP),!0);return lO.isEmptyOrZeroLength(Object.keys(r))||UF.updateConfigValue(void 0,void 0,r,!0,!0),Zae(),Df}return cO?(Li.notify(Df),Lf.get(Pt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await $ae(),process.env.HARPER_EXIT_ON_RESTART&&process.exit(0),setTimeout(()=>{vm()},50)):Pf.postMessage({type:Pt.ITC_EVENT_TYPES.RESTART}),Df}a(vF,"restart");async function uO(e){let{service:t}=e;if(Pt.PROCESS_DESCRIPTORS_VALIDATE[t]===void 0)throw Yae(new Error,Xae,jae.BAD_REQUEST,void 0,void 0,!0);if(ei.expectedRestartOfChildren(),Gu=await ei.isServiceRegistered(Pt.HDB_PROC_DESCRIPTOR),!cO){e.replicated&&Qae(),Pf.postMessage({type:Pt.ITC_EVENT_TYPES.RESTART,workerType:t}),Pf.ref(),await new Promise(s=>{Pf.on("message",i=>{i.type==="restart-complete"&&(s(),Pf.unref())})});let n;if(e.replicated){e.replicated=!1,n=[];for(let s of server.nodes){if(s.name===zae())continue;let{job_id:i}=await LF(s,e);n.push(await new Promise((o,c)=>{let u=2400,d=setInterval(async()=>{if(u--<=0){clearInterval(d);let f=new Error("Timed out waiting for restart job to complete");f.replicated=n,c(f)}let E=(await LF(s,{operation:"get_job",id:i})).results[0];if(E.status==="COMPLETE"&&(clearInterval(d),o({node:s.name,message:E.message})),E.status==="ERROR"){clearInterval(d);let f=new Error(E.message);f.replicated=n,c(f)}},250)}))}return{replicated:n}}return}let r;switch(t){case Fu.clustering:if(!Lf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=MF;break}Ts&&console.log("Restarting clustering"),Li.notify("Restarting clustering"),await BF();break;case Fu.clustering_config:case Fu["clustering config"]:if(!Lf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=MF;break}Ts&&console.log("Restarting clustering_config"),Li.notify("Restarting clustering_config"),await ei.reloadClustering();break;case"custom_functions":case"custom functions":case Fu.harperdb:case Fu.http_workers:case Fu.http:if(Ts&&!Gu){r=`Restart ${t} is not available from the CLI when running in non-pm2 mode. Either call restart ${t} from the API or stop and start HarperDB.`;break}Ts&&console.log("Restarting http_workers"),Li.notify("Restarting http_workers"),Ts?await ei.restart(Pt.HDB_PROC_DESCRIPTOR):await vm("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(Li.error(r),Ts&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(uO,"restartService");async function Zae(){await BF(),await ei.restart(Pt.HDB_PROC_DESCRIPTOR),await lO.async_set_timeout(2e3),Lf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await aO(),Ts&&(await Mm.closeConnection(),process.exit(0))}a(Zae,"restartPM2Mode");async function BF(){if(!UF.getConfigFromFile(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await PF.getHDBProcessInfo()).clustering.length===0)Li.trace("Clustering not running, restart will start clustering services"),await Um.generateNatsConfig(!0),await ei.startClusteringProcesses(),await ei.startClusteringThreads(),await aO(),Ts&&await Mm.closeConnection();else{await Um.generateNatsConfig(!0),Gu?(Li.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await ei.restart(Pt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await ei.restart(Pt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await PF.getHDBProcessInfo()).clustering.forEach(s=>{Li.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await lO.async_set_timeout(3e3),await aO(),await Mm.updateLocalStreams(),Ts&&await Mm.closeConnection(),Li.trace("Restart clustering restarting ingest and reply service threads");let t=vm(Pt.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=vm(Pt.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(BF,"restartClustering");async function aO(){await Um.removeNatsConfig(Pt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Um.removeNatsConfig(Pt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(aO,"removeNatsConfig")});var jF=N((ICe,WF)=>{"use strict";var NCe=require("lodash"),gn=M(),{handleHDBError:xF,hdb_errors:ece}=_e(),{HDB_ERROR_MSGS:tce,HTTP_STATUS_CODES:rce}=ece,dO=W();WF.exports={getRolePermissions:sce};var Yc=Object.create(null),nce=a(e=>({key:e,perms:{}}),"perms_template_obj"),qF=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),$F=a((e=!1,t=!1,r=!1,n=!1)=>({[gn.PERMS_CRUD_ENUM.READ]:e,[gn.PERMS_CRUD_ENUM.INSERT]:t,[gn.PERMS_CRUD_ENUM.UPDATE]:r,[gn.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),_O=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...$F(t,r,n,s)}),"table_perms_template"),kF=a((e,t=$F())=>({attribute_name:e,describe:YF(t),[Mf]:t[Mf],[fO]:t[fO],[EO]:t[EO]}),"attr_perms_template"),FF=a((e,t=!1)=>({attribute_name:e,describe:t,[Mf]:t}),"timestamp_attr_perms_template"),{READ:Mf,INSERT:fO,UPDATE:EO}=gn.PERMS_CRUD_ENUM,VF=Object.values(gn.PERMS_CRUD_ENUM),KF=[Mf,fO,EO];function sce(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r={...global.hdb_schema};delete r[gn.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(Yc[t]&&Yc[t].key===n)return Yc[t].perms;let s=ice(e,r);return Yc[t]?Yc[t].key=n:Yc[t]=nce(n),Yc[t].perms=s,s}catch(r){if(!e[gn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[gn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<gn.PERMS_UPDATE_RELEASE_TIMESTAMP){let n=`Role permissions for role '${t}' must be updated to align with new structure from the 2.2.0 release.`;throw dO.error(n),dO.debug(r),xF(new Error,tce.OUTDATED_PERMS_TRANSLATION_ERROR,rce.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
18
- ${r.stack}`;throw dO.error(n),xF(new Error)}}}a(sce,"getRolePermissions");function ice(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[gn.SYSTEM_SCHEMA_NAME]=n[gn.SYSTEM_SCHEMA_NAME],r.structure_user=n.structure_user;let s=Array.isArray(e.permission.structure_user)||e.permission.structure_user===!0?e.permission.structure_user:[];return Object.keys(t).forEach(i=>{if(s===!0||s.indexOf(i)>-1){r[i]=oce(t[i]);return}r[i]=qF(),n[i]?(n[i].describe&&(r[i].describe=!0),Object.keys(t[i]).forEach(o=>{if(n[i].tables[o]){let c=n[i].tables[o],l=t[i][o],u=ace(c,l);r[i].describe||VF.forEach(d=>{u[d]&&(r[i].describe=!0)}),r[i].tables[o]=u}else r[i].tables[o]=_O()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=_O()})}),r}a(ice,"translateRolePermissions");function oce(e){let t=qF(!0);return Object.keys(e).forEach(r=>{t.tables[r]=_O(!0,!0,!0,!0,!0)}),t}a(oce,"createStructureUserPermissions");function ace(e,t){let{attribute_permissions:r}=e;if(r?.length>0){let s={...e};s.attribute_permissions=[];let i=r.reduce((u,d)=>{let{attribute_name:_}=d,E=d;return gn.TIME_STAMP_NAMES.includes(_)&&(E=FF(_,d[Mf])),u[_]=E,u},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=kF(o);return t.attributes.forEach(({attribute:u})=>{if(i[u]){let d=i[u];d.describe=YF(d),s.attribute_permissions.push(d),c||cce(d,l)}else if(u!==o){let d;gn.TIME_STAMP_NAMES.includes(u)?d=FF(u):d=kF(u),s.attribute_permissions.push(d)}}),c||s.attribute_permissions.push(l),s.describe=GF(s),s}else return e.describe=GF(e),e}a(ace,"getTableAttrPerms");function GF(e){return VF.filter(t=>e[t]).length>0}a(GF,"getSchemaTableDescribePerm");function YF(e){return KF.filter(t=>e[t]).length>0}a(YF,"getAttributeDescribePerm");function cce(e,t){KF.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(cce,"checkForHashPerms")});var zF={};je(zF,{Headers:()=>mo,appendHeader:()=>Bm,mergeHeaders:()=>hO});function Bm(e,t,r,n){if(e.append)e.append(t,r,n);else if(e.set){let s=e.get(t);if(s)if(n)r=(typeof s=="string"?s:s.join(", "))+", "+r;else if(typeof s=="string")r=[s,r];else{s.push(r);return}return e.set(t,r)}else e[t]=(e[t]?e[t]+", ":"")+r}function hO(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new mo(e));for(let[r,n]of t)e.has(r)?r.toLowerCase()==="set-cookie"&&e.append?.(r,n,!0):e.set(r,n);return e}var mo,Uf=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 vf={};je(vf,{authentication:()=>rG,bypassAuth:()=>hce,login:()=>mce,logout:()=>Sce,start:()=>pce});function hce(){tG=!0}async function rG(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let f=e.isOperationsServer?_ce?dce:[]:uce?lce:[];if(f.includes(i)||f.includes("*")){if(e.method==="OPTIONS"){let h=Yn.get(gr.CONFIG_PARAMS.HTTP_CORSACCESSCONTROLALLOWHEADERS)??"Accept, Content-Type, Authorization",T=new mo([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers",h],["Access-Control-Allow-Origin",i]]);return Hm&&T.set("Access-Control-Allow-Credentials","true"),{status:200,headers:T}}o.push("Access-Control-Allow-Origin",i),Hm&&o.push("Access-Control-Allow-Credentials","true")}}let l,u;if(Hm){i||(i=r.host);let f=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.split(/;\s+/)||[];for(let T of h)if(T.startsWith(f)){let m=T.indexOf(";");l=T.slice(f.length,m===-1?T.length:m),u=await QF.get(l);break}e.session=u||(u={})}let d=a((f,h,T)=>{let m=new $u.AuthAuditLog(f,h,gr.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===gr.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,gr.AUTH_AUDIT_STATUS.SUCCESS,"mTLS")):(0,$u.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let _;if(!e.user)if(n){if(_=Wc.get(n),!_){let f=n.indexOf(" "),h=n.slice(0,f),T=n.slice(f+1),m,g;try{switch(h){case"Basic":let S=atob(T),y=S.indexOf(":");m=S.slice(0,y),g=S.slice(y+1),_=m||g?await it.getUser(m,g,e):null;break;case"Bearer":try{_=await(0,xm.validateOperationToken)(T)}catch(I){if(I.message==="invalid token")try{return await(0,xm.validateRefreshToken)(T),c({status:-1})}catch{throw I}}break}}catch(S){return Ece&&(Wc.get(T)||(Wc.set(T,T),d(m,gr.AUTH_AUDIT_STATUS.FAILURE,h))),c({status:401,body:jc({error:S.message},e)})}Wc.set(n,_),fce&&d(_.username,gr.AUTH_AUDIT_STATUS.SUCCESS,h)}e.user=_}else u?.user?e.user=await it.getUser(u.user,null,e):(tG&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,XF.getSuperUser)());Hm&&(e.session.update=function(f){if(!l){l=(0,ZF.v4)();let T=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${l}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",T):E?.headers?.set&&E.headers.set("Set-Cookie",T)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):E?.headers?.set&&(i&&E.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),E.headers.set("X-Hdb-Session","Secure"))),f.id=l,QF.put(f)},e.login=async function(f,h){e.user=await it.getUser(f,h,e),e.session.update({user:e.user&&(e.user.getId?.()??e.user.username)})});let E=await t(e);return E&&(E.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&Ci.loginPath?(E.status=302,E.headers.set("Location",Ci.loginPath(e))):E.headers.set("WWW-Authenticate","Basic")),c(E))}catch(l){throw c(l)}function c(l){let u=o.length;if(u>0){let d=l.headers;d||(l.headers=d=new mo);for(let _=0;_<u;){let E=o[_++];d.set(E,o[_++])}}return o=null,l}a(c,"applyResponseHeaders")}function pce({server:e,port:t,securePort:r}){e.http(rG,t||r?{port:t,securePort:r}:{port:"all"}),JF||(JF=!0,setInterval(()=>{Wc=new Map},Yn.get(gr.CONFIG_PARAMS.AUTHENTICATION_CACHETTL)).unref(),eG.user.addListener(()=>{Wc=new Map}))}async function mce(e){if(!e.baseRequest?.login)throw new Error("No session for login");return e.baseResponse.headers.set=(t,r)=>{e.fastifyResponse.header(t,r)},await e.baseRequest.login(e.username,e.password??""),"Login successful"}async function Sce(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var XF,xm,ZF,Yn,gr,$u,eG,pO,lce,uce,dce,_ce,QF,Hm,tG,fce,Ece,Wc,JF,km=Ie(()=>{XF=L(xn());qr();su();xm=L(fu());Pe();ZF=require("uuid"),Yn=L(se()),gr=L(M()),$u=L(W()),eG=L(m_());Uf();zc();pO=(0,$u.loggerWithTag)("auth-event");Yn.initSync();lce=Yn.get(gr.CONFIG_PARAMS.HTTP_CORSACCESSLIST),uce=Yn.get(gr.CONFIG_PARAMS.HTTP_CORS),dce=Yn.get(gr.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORSACCESSLIST),_ce=Yn.get(gr.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORS),QF=Et({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),Hm=Yn.get(gr.CONFIG_PARAMS.AUTHENTICATION_ENABLESESSIONS)??!0,tG=process.env.AUTHENTICATION_AUTHORIZELOCAL??Yn.get(gr.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,fce=Yn.get(gr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,Ece=Yn.get(gr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,Wc=new Map;it.onInvalidatedUser(()=>{Wc=new Map});a(hce,"bypassAuth");a(rG,"authentication");a(pce,"start");a(mce,"login");a(Sce,"logout")});var lG=N((BCe,cG)=>{"use strict";var ye=require("joi"),nG=require("fs-extra"),sG=require("path"),Wn=Tt(),iG=se(),oG=M(),aG=W(),{hdb_errors:Tce}=_e(),{HDB_ERROR_MSGS:Xr}=Tce,So=/^[a-zA-Z0-9-_]+$/,gce=/^[a-zA-Z0-9-_]+$/;cG.exports={getDropCustomFunctionValidator:Rce,setCustomFunctionValidator:yce,addComponentValidator:Ice,dropCustomFunctionProjectValidator:wce,packageComponentValidator:Cce,deployComponentValidator:Dce,setComponentFileValidator:bce,getComponentFileValidator:Nce,dropComponentFileValidator:Oce,addSSHKeyValidator:Pce,updateSSHKeyValidator:Lce,deleteSSHKeyValidator:Mce,setSSHKnownHostsValidator:Uce};function Fm(e,t,r){try{let n=iG.get(oG.CONFIG_PARAMS.COMPONENTSROOT),s=sG.join(n,t);return nG.existsSync(s)?e?t:r.message(Xr.PROJECT_EXISTS):e?r.message(Xr.NO_PROJECT):t}catch(n){return aG.error(n),r.message(Xr.VALIDATION_ERR)}}a(Fm,"checkProjectExists");function Bf(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(Bf,"checkFilePath");function Ace(e,t,r,n){try{let s=iG.get(oG.CONFIG_PARAMS.COMPONENTSROOT),i=sG.join(s,e,t,r+".js");return nG.existsSync(i)?r:n.message(Xr.NO_FILE)}catch(s){return aG.error(s),n.message(Xr.VALIDATION_ERR)}}a(Ace,"checkFileExists");function Rce(e){let t=ye.object({project:ye.string().pattern(So).custom(Fm.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),type:ye.string().valid("helpers","routes").required(),file:ye.string().pattern(So).custom(Ace.bind(null,e.project,e.type)).custom(Bf).required().messages({"string.pattern.base":Xr.BAD_FILE_NAME})});return Wn.validateBySchema(e,t)}a(Rce,"getDropCustomFunctionValidator");function yce(e){let t=ye.object({project:ye.string().pattern(So).custom(Fm.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),type:ye.string().valid("helpers","routes").required(),file:ye.string().custom(Bf).required(),function_content:ye.string().required()});return Wn.validateBySchema(e,t)}a(yce,"setCustomFunctionValidator");function bce(e){let t=ye.object({project:ye.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),file:ye.string().custom(Bf).required(),payload:ye.string().allow("").optional(),encoding:ye.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Wn.validateBySchema(e,t)}a(bce,"setComponentFileValidator");function Oce(e){let t=ye.object({project:ye.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),file:ye.string().custom(Bf).optional()});return Wn.validateBySchema(e,t)}a(Oce,"dropComponentFileValidator");function Nce(e){let t=ye.object({project:ye.string().required(),file:ye.string().custom(Bf).required(),encoding:ye.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Wn.validateBySchema(e,t)}a(Nce,"getComponentFileValidator");function Ice(e){let t=ye.object({project:ye.string().pattern(So).custom(Fm.bind(null,!1)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME})});return Wn.validateBySchema(e,t)}a(Ice,"addComponentValidator");function wce(e){let t=ye.object({project:ye.string().pattern(So).custom(Fm.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME})});return Wn.validateBySchema(e,t)}a(wce,"dropCustomFunctionProjectValidator");function Cce(e){let t=ye.object({project:ye.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),skip_node_modules:ye.boolean(),skip_symlinks:ye.boolean()});return Wn.validateBySchema(e,t)}a(Cce,"packageComponentValidator");function Dce(e){let t=ye.object({project:ye.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),package:ye.string().optional(),restart:ye.alternatives().try(ye.boolean(),ye.string().valid("rolling")).optional()});return Wn.validateBySchema(e,t)}a(Dce,"deployComponentValidator");function Pce(e){let t=ye.object({name:ye.string().pattern(gce).required().messages({"string.pattern.base":Xr.BAD_SSH_KEY_NAME}),key:ye.string().required(),host:ye.string().required(),hostname:ye.string().required(),known_hosts:ye.string().optional()});return Wn.validateBySchema(e,t)}a(Pce,"addSSHKeyValidator");function Lce(e){let t=ye.object({name:ye.string().required(),key:ye.string().required()});return Wn.validateBySchema(e,t)}a(Lce,"updateSSHKeyValidator");function Mce(e){let t=ye.object({name:ye.string().required()});return Wn.validateBySchema(e,t)}a(Mce,"deleteSSHKeyValidator");function Uce(e){let t=ye.object({known_hosts:ye.string().required()});return Wn.validateBySchema(e,t)}a(Uce,"setSSHKnownHostsValidator")});var kf=N((xCe,hG)=>{"use strict";var Gm=require("joi"),Sa=require("path"),Vu=require("fs-extra"),{exec:vce}=require("child_process"),Bce=require("util"),uG=Bce.promisify(vce),Qc=M(),{handleHDBError:Hf,hdb_errors:Hce}=_e(),{HTTP_STATUS_CODES:xf}=Hce,Jc=se(),xce=Tt(),Xc=W();Jc.initSync();var mO=Jc.get(Qc.CONFIG_PARAMS.COMPONENTSROOT),dG="npm install --force --omit=dev --json",kce=`${dG} --dry-run`,Fce=Jc.get(Qc.CONFIG_PARAMS.ROOTPATH),qm=Sa.join(Fce,"ssh");hG.exports={installModules:Vce,auditModules:Kce,installAllRootModules:Gce,uninstallRootModule:qce,linkHarperdb:$ce,runCommand:Ku};async function Gce(e=!1,t=Jc.get(Qc.CONFIG_PARAMS.ROOTPATH)){await $m();let r=!1,n=process.env;Vu.pathExistsSync(qm)&&Vu.readdirSync(qm).forEach(s=>{s.includes(".key")&&!r&&(n={GIT_SSH_COMMAND:"ssh -F "+Sa.join(qm,"config")+" -o UserKnownHostsFile="+Sa.join(qm,"known_hosts"),...process.env},r=!0)});try{let s=Jc.get(Qc.CONFIG_PARAMS.ROOTPATH),i=Sa.join(s,"node_modules","harperdb");Vu.lstatSync(i).isSymbolicLink()&&Vu.unlinkSync(i)}catch(s){s.code!=="ENOENT"&&Xc.error("Error removing symlink:",s)}await Ku(e?"npm install --force --ignore-scripts --no-bin-links":"npm install --force --no-bin-links",t,n)}a(Gce,"installAllRootModules");async function qce(e){await Ku(`npm uninstall ${e}`,Jc.get(Qc.CONFIG_PARAMS.ROOTPATH))}a(qce,"uninstallRootModule");async function $ce(){await $m(),await Ku(`npm link ${Qc.PACKAGE_ROOT}`,Jc.get(Qc.CONFIG_PARAMS.ROOTPATH))}a($ce,"linkHarperdb");async function Ku(e,t=void 0,r=process.env){let n,s;try{({stdout:n,stderr:s}=await uG(e,{cwd:t,env:r}))}catch(i){throw new Error(i.stderr.replace(`
17
+ Database backup has not been removed and can be found here: ${s}`;pa.error(l),console.error(l)}(0,nO.get)(ma.CONFIG_PARAMS.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||o===!1||(console.log("Removing backup",s),await(0,Kc.remove)(s))}}async function 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,S.decoderCopies=!1,S.encoding="binary",g.compression=m;let y=o.openDB(E,g);y.encoder=null,console.log("copying",E,"from",e,"to",t),await _(S,y,h,d)}if(i){let E=n.openDB(Pm.AUDIT_STORE_NAME,Df);console.log("copying audit log for",e,"to",t),_(i,E,!1,d)}async function _(E,f,h,T){let m=0,g=0,S=1e7,y=null;for(;S-- >0;)try{for(let I of E.getKeys({start:y,transaction:T}))try{y=I;let{value:U,version:H}=E.getEntry(I,{transaction:T});l=f.put(I,U,h?H:void 0),m++,T.openTimer&&(T.openTimer=0),g+=(I?.length||10)+U.length,u++>5e3&&(await l,console.log("copied",m,"entries",g,"bytes"),u=0)}catch(U){console.error("Error copying record",typeof I=="symbol"?"symbol":I,"from",e,"to",t,U)}console.log("finish copying, copied",m,"entries",g,"bytes");return}catch{if(typeof y=="string"){if(y==="z")return console.error("Reached end of dbi",y,"for",e,"to",t);y=y.slice(0,-2)+"z"}else if(typeof y=="number")y++;else return console.error("Unknown key type",y,"for",e,"to",t)}}a(_,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{d.done(),o.close()}}var IF,Dm,Kc,nO,wF,CF,Pm,ma,DF,sO,pa,oO=Ie(()=>{Pe();IF=require("lmdb"),Dm=require("path"),Kc=require("fs-extra"),nO=L(se()),wF=L(c_()),CF=L(a_()),Pm=L(Ht()),ma=L(M());Ji();DF=L(ro()),sO=L(wt()),pa=L(W());a(Gae,"compactOnStart");a(NF,"getTotalDBRecordCount");a(PF,"copyDb")});var qu=N((bCe,xF)=>{"use strict";var qae=require("minimist"),{isMainThread:cO,parentPort:Lf,threadId:ACe}=require("worker_threads"),Pt=M(),{PROCESS_DESCRIPTORS_VALIDATE:Fu}=Pt,Li=W(),lO=te(),Um=Om(),Mm=mr(),RCe=Ct(),vF=wt(),ei=xu(),LF=Cu(),{compactOnStart:$ae}=(oO(),oe(iO)),Vae=ja(),{restartWorkers:vm,onMessageByType:Kae}=dt(),{handleHDBError:Yae,hdb_errors:Wae}=_e(),{HTTP_STATUS_CODES:jae}=Wae,Mf=se(),{sendOperationToNode:MF,getThisNodeName:zae,monitorNodeCAs:Qae}=(ds(),oe(ca)),{getHDBNodeTable:yCe}=(lu(),oe(pB));Mf.initSync();var Pf=`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",Gu,Ts;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){Ts=Object.keys(e).length===0,Gu=await ei.isServiceRegistered(Pt.HDB_PROC_DESCRIPTOR);let t=qae(process.argv);if(t.service){await uO(t);return}if(Ts&&!Gu){console.error(Jae);return}if(Ts&&console.log(Pf),Gu){ei.enterPM2Mode(),Li.notify(Pf);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(),Pf}return cO?(Li.notify(Pf),Mf.get(Pt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await $ae(),process.env.HARPER_EXIT_ON_RESTART&&process.exit(0),setTimeout(()=>{vm()},50)):Lf.postMessage({type:Pt.ITC_EVENT_TYPES.RESTART}),Pf}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(),Gu=await ei.isServiceRegistered(Pt.HDB_PROC_DESCRIPTOR),!cO){e.replicated&&Qae(),Lf.postMessage({type:Pt.ITC_EVENT_TYPES.RESTART,workerType:t}),Lf.ref(),await new Promise(s=>{Lf.on("message",i=>{i.type==="restart-complete"&&(s(),Lf.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 Fu.clustering:if(!Mf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=UF;break}Ts&&console.log("Restarting clustering"),Li.notify("Restarting clustering"),await HF();break;case Fu.clustering_config:case Fu["clustering config"]:if(!Mf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=UF;break}Ts&&console.log("Restarting clustering_config"),Li.notify("Restarting clustering_config"),await ei.reloadClustering();break;case"custom_functions":case"custom functions":case Fu.harperdb:case Fu.http_workers:case Fu.http:if(Ts&&!Gu){r=`Restart ${t} is not available from the CLI when running in non-pm2 mode. Either call restart ${t} from the API or stop and start HarperDB.`;break}Ts&&console.log("Restarting http_workers"),Li.notify("Restarting http_workers"),Ts?await ei.restart(Pt.HDB_PROC_DESCRIPTOR):await vm("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(Li.error(r),Ts&&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),Mf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await aO(),Ts&&(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)Li.trace("Clustering not running, restart will start clustering services"),await Um.generateNatsConfig(!0),await ei.startClusteringProcesses(),await ei.startClusteringThreads(),await aO(),Ts&&await Mm.closeConnection();else{await Um.generateNatsConfig(!0),Gu?(Li.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=>{Li.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await lO.async_set_timeout(3e3),await aO(),await Mm.updateLocalStreams(),Ts&&await Mm.closeConnection(),Li.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((ICe,jF)=>{"use strict";var NCe=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 Yc=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),[Uf]:t[Uf],[fO]:t[fO],[EO]:t[EO]}),"attr_perms_template"),GF=a((e,t=!1)=>({attribute_name:e,describe:t,[Uf]:t}),"timestamp_attr_perms_template"),{READ:Uf,INSERT:fO,UPDATE:EO}=gn.PERMS_CRUD_ENUM,KF=Object.values(gn.PERMS_CRUD_ENUM),YF=[Uf,fO,EO];function sce(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r={...global.hdb_schema};delete r[gn.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(Yc[t]&&Yc[t].key===n)return Yc[t].perms;let s=ice(e,r);return Yc[t]?Yc[t].key=n:Yc[t]=nce(n),Yc[t].perms=s,s}catch(r){if(!e[gn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[gn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<gn.PERMS_UPDATE_RELEASE_TIMESTAMP){let n=`Role permissions for role '${t}' must be updated to align with new structure from the 2.2.0 release.`;throw dO.error(n),dO.debug(r),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[Uf])),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,vf=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 Bf={};je(Bf,{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=Yn.get(gr.CONFIG_PARAMS.HTTP_CORSACCESSCONTROLALLOWHEADERS)??"Accept, Content-Type, Authorization",T=new mo([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers",h],["Access-Control-Allow-Origin",i]]);return Hm&&T.set("Access-Control-Allow-Credentials","true"),{status:200,headers:T}}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 $u.AuthAuditLog(f,h,gr.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===gr.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,gr.AUTH_AUDIT_STATUS.SUCCESS,"mTLS")):(0,$u.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let _;if(!e.user)if(n){if(_=Wc.get(n),!_){let f=n.indexOf(" "),h=n.slice(0,f),T=n.slice(f+1),m,g;try{switch(h){case"Basic":let S=atob(T),y=S.indexOf(":");m=S.slice(0,y),g=S.slice(y+1),_=m||g?await it.getUser(m,g,e):null;break;case"Bearer":try{_=await(0,xm.validateOperationToken)(T)}catch(I){if(I.message==="invalid token")try{return await(0,xm.validateRefreshToken)(T),c({status:-1})}catch{throw I}}break}}catch(S){return Ece&&(Wc.get(T)||(Wc.set(T,T),d(m,gr.AUTH_AUDIT_STATUS.FAILURE,h))),c({status:401,body:jc({error:S.message},e)})}Wc.set(n,_),fce&&d(_.username,gr.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")&&Ci.loginPath?(E.status=302,E.headers.set("Location",Ci.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(()=>{Wc=new Map},Yn.get(gr.CONFIG_PARAMS.AUTHENTICATION_CACHETTL)).unref(),tG.user.addListener(()=>{Wc=new Map}))}async function mce(e){if(!e.baseRequest?.login)throw new Error("No session for login");return e.baseResponse.headers.set=(t,r)=>{e.fastifyResponse.header(t,r)},await e.baseRequest.login(e.username,e.password??""),"Login successful"}async function Sce(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var ZF,xm,eG,Yn,gr,$u,tG,pO,lce,uce,dce,_ce,JF,Hm,rG,fce,Ece,Wc,XF,km=Ie(()=>{ZF=L(xn());qr();su();xm=L(fu());Pe();eG=require("uuid"),Yn=L(se()),gr=L(M()),$u=L(W()),tG=L(S_());vf();zc();pO=(0,$u.loggerWithTag)("auth-event");Yn.initSync();lce=Yn.get(gr.CONFIG_PARAMS.HTTP_CORSACCESSLIST),uce=Yn.get(gr.CONFIG_PARAMS.HTTP_CORS),dce=Yn.get(gr.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORSACCESSLIST),_ce=Yn.get(gr.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORS),JF=Et({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),Hm=Yn.get(gr.CONFIG_PARAMS.AUTHENTICATION_ENABLESESSIONS)??!0,rG=process.env.AUTHENTICATION_AUTHORIZELOCAL??Yn.get(gr.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,fce=Yn.get(gr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,Ece=Yn.get(gr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,Wc=new Map;it.onInvalidatedUser(()=>{Wc=new Map});a(hce,"bypassAuth");a(nG,"authentication");a(pce,"start");a(mce,"login");a(Sce,"logout")});var uG=N((BCe,lG)=>{"use strict";var ye=require("joi"),sG=require("fs-extra"),iG=require("path"),Wn=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 Hf(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(Hf,"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=ye.object({project:ye.string().pattern(So).custom(Fm.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),type:ye.string().valid("helpers","routes").required(),file:ye.string().pattern(So).custom(Ace.bind(null,e.project,e.type)).custom(Hf).required().messages({"string.pattern.base":Xr.BAD_FILE_NAME})});return Wn.validateBySchema(e,t)}a(Rce,"getDropCustomFunctionValidator");function yce(e){let t=ye.object({project:ye.string().pattern(So).custom(Fm.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),type:ye.string().valid("helpers","routes").required(),file:ye.string().custom(Hf).required(),function_content:ye.string().required()});return Wn.validateBySchema(e,t)}a(yce,"setCustomFunctionValidator");function bce(e){let t=ye.object({project:ye.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),file:ye.string().custom(Hf).required(),payload:ye.string().allow("").optional(),encoding:ye.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Wn.validateBySchema(e,t)}a(bce,"setComponentFileValidator");function Oce(e){let t=ye.object({project:ye.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),file:ye.string().custom(Hf).optional()});return Wn.validateBySchema(e,t)}a(Oce,"dropComponentFileValidator");function Nce(e){let t=ye.object({project:ye.string().required(),file:ye.string().custom(Hf).required(),encoding:ye.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Wn.validateBySchema(e,t)}a(Nce,"getComponentFileValidator");function Ice(e){let t=ye.object({project:ye.string().pattern(So).custom(Fm.bind(null,!1)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME})});return Wn.validateBySchema(e,t)}a(Ice,"addComponentValidator");function wce(e){let t=ye.object({project:ye.string().pattern(So).custom(Fm.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME})});return Wn.validateBySchema(e,t)}a(wce,"dropCustomFunctionProjectValidator");function Cce(e){let t=ye.object({project:ye.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),skip_node_modules:ye.boolean(),skip_symlinks:ye.boolean()});return Wn.validateBySchema(e,t)}a(Cce,"packageComponentValidator");function Dce(e){let t=ye.object({project:ye.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),package:ye.string().optional(),restart:ye.alternatives().try(ye.boolean(),ye.string().valid("rolling")).optional()});return Wn.validateBySchema(e,t)}a(Dce,"deployComponentValidator");function Pce(e){let t=ye.object({name:ye.string().pattern(gce).required().messages({"string.pattern.base":Xr.BAD_SSH_KEY_NAME}),key:ye.string().required(),host:ye.string().required(),hostname:ye.string().required(),known_hosts:ye.string().optional()});return Wn.validateBySchema(e,t)}a(Pce,"addSSHKeyValidator");function Lce(e){let t=ye.object({name:ye.string().required(),key:ye.string().required()});return Wn.validateBySchema(e,t)}a(Lce,"updateSSHKeyValidator");function Mce(e){let t=ye.object({name:ye.string().required()});return Wn.validateBySchema(e,t)}a(Mce,"deleteSSHKeyValidator");function Uce(e){let t=ye.object({known_hosts:ye.string().required()});return Wn.validateBySchema(e,t)}a(Uce,"setSSHKnownHostsValidator")});var Ff=N((xCe,pG)=>{"use strict";var Gm=require("joi"),Sa=require("path"),Vu=require("fs-extra"),{exec:vce}=require("child_process"),Bce=require("util"),dG=Bce.promisify(vce),Qc=M(),{handleHDBError:xf,hdb_errors:Hce}=_e(),{HTTP_STATUS_CODES:kf}=Hce,Jc=se(),xce=Tt(),Xc=W();Jc.initSync();var mO=Jc.get(Qc.CONFIG_PARAMS.COMPONENTSROOT),_G="npm install --force --omit=dev --json",kce=`${_G} --dry-run`,Fce=Jc.get(Qc.CONFIG_PARAMS.ROOTPATH),qm=Sa.join(Fce,"ssh");pG.exports={installModules:Vce,auditModules:Kce,installAllRootModules:Gce,uninstallRootModule:qce,linkHarperdb:$ce,runCommand:Ku};async function Gce(e=!1,t=Jc.get(Qc.CONFIG_PARAMS.ROOTPATH)){await $m();let r=!1,n=process.env;Vu.pathExistsSync(qm)&&Vu.readdirSync(qm).forEach(s=>{s.includes(".key")&&!r&&(n={GIT_SSH_COMMAND:"ssh -F "+Sa.join(qm,"config")+" -o UserKnownHostsFile="+Sa.join(qm,"known_hosts"),...process.env},r=!0)});try{let s=Jc.get(Qc.CONFIG_PARAMS.ROOTPATH),i=Sa.join(s,"node_modules","harperdb");Vu.lstatSync(i).isSymbolicLink()&&Vu.unlinkSync(i)}catch(s){s.code!=="ENOENT"&&Xc.error("Error removing symlink:",s)}await Ku(e?"npm install --force --ignore-scripts --no-bin-links":"npm install --force --no-bin-links",t,n)}a(Gce,"installAllRootModules");async function qce(e){await Ku(`npm uninstall ${e}`,Jc.get(Qc.CONFIG_PARAMS.ROOTPATH))}a(qce,"uninstallRootModule");async function $ce(){await $m(),await Ku(`npm link ${Qc.PACKAGE_ROOT}`,Jc.get(Qc.CONFIG_PARAMS.ROOTPATH))}a($ce,"linkHarperdb");async function Ku(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
19
  `,""))}return s&&!s.includes("Debugger listening")&&!s.includes("warn using --force")&&Xc.error("Error running NPM command:",e,s),Xc.trace(n,s),n?.replace(`
20
- `,"")}a(Ku,"runCommand");async function Vce(e){let t="install_node_modules is deprecated. Dependencies are automatically installed on deploy, and install_node_modules can lead to inconsistent behavior";Xc.warn(t,e);let r=EG(e);if(r)throw Hf(r,r.message,xf.BAD_REQUEST);let{projects:n,dry_run:s}=e,i=s===!0?kce:dG;await $m(),await fG(n);let o={};for(let c=0,l=n.length;c<l;c++){let u=n[c];o[u]={npm_output:null,npm_error:null};let d=Sa.join(mO,u),_,E=null;try{let{stdout:f,stderr:h}=await uG(i,{cwd:d});_=f?f.replace(`
20
+ `,"")}a(Ku,"runCommand");async function Vce(e){let t="install_node_modules is deprecated. Dependencies are automatically installed on deploy, and install_node_modules can lead to inconsistent behavior";Xc.warn(t,e);let r=hG(e);if(r)throw xf(r,r.message,kf.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=Sa.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=_G(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 Xc.info(`finished installModules with response ${o}`),o.warning=t,o}a(Vce,"installModules");function _G(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(_G,"parseNPMStdErr");async function Kce(e){Xc.info(`starting auditModules for request: ${e}`);let t=EG(e);if(t)throw Hf(t,t.message,xf.BAD_REQUEST);let{projects:r}=e;await $m(),await fG(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=Sa.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=_G(l.stderr)}}return Xc.info(`finished auditModules with response ${n}`),n}a(Kce,"auditModules");async function $m(){return await Ku("npm -v"),!0}a($m,"checkNPMInstalled");async function fG(e){if(!Array.isArray(e)||e.length===0)throw Hf(new Error,"projects argument must be an array with at least 1 element",xf.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=Sa.join(mO,i.toString());if(!await Vu.pathExists(o)){t.push(i);continue}let l=Sa.join(o,"package.json");await Vu.pathExists(l)||r.push(i)}if(t.length>0)throw Hf(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,xf.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw Hf(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,xf.BAD_REQUEST,void 0,void 0,!0)}a(fG,"checkProjectPaths");function EG(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(EG,"modulesValidator")});var SO=N((FCe,AG)=>{"use strict";var gs=require("fs-extra"),Gf=require("path"),Ff=W(),pG=te(),Vm=M(),gG=se(),Yce=wt();AG.exports=Wce;async function Wce(){let e=jce(),t=gG.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(pG.isEmptyOrZeroLength(e))return;if(l.code!==Vm.NODE_ERROR_CODES.ENOENT)throw l;o=!1}if(!pG.isEmptyOrZeroLength(e)){for(let{name:l,package:u}of e){let d=SG(u);n.dependencies[l]=d+u}if(!o){Ff.notify("Installing components"),await TG(r,n,null),await mG(t,e);return}for(let{name:l,package:u}of e){let d=i.dependencies[l],_=SG(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 TG(r,n,i),await mG(t,e))}a(Wce,"installComponents");function mG(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(mG,"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 SG(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":Gf.extname(e)||gs.existsSync(e)?"file:":"github:"}a(SG,"getPkgPrefix");async function TG(e,t,r){Ff.trace("npm installing components package.json",t),gs.writeFileSync(e,JSON.stringify(t,null," "));try{await kf().installAllRootModules(gG.get(Vm.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?gs.writeFileSync(e,JSON.stringify(r,null," ")):gs.unlinkSync(e),n}}a(TG,"installPackages")});var OG={};je(OG,{packageDirectory:()=>zce});function zce(e,t={skip_node_modules:!1,skip_symlinks:!1}){return new Promise((r,n)=>{let s=[];yG.default.pack(e,{dereference:!t.skip_symlinks,ignore:t.skip_node_modules?i=>i.includes("node_modules")||i.includes((0,RG.join)("cache","webpack")):void 0}).pipe((0,bG.createGzip)()).on("data",i=>s.push(i)).on("end",()=>{r(Buffer.concat(s))}).on("error",n)})}var RG,yG,bG,NG=Ie(()=>{RG=require("path"),yG=L(require("tar-fs")),bG=require("node:zlib");a(zce,"packageDirectory")});var bO=N((KCe,DG)=>{var jm=require("clone"),zm=Tt(),Qce=te(),Ym=M(),$Ce=W(),TO=require("fs"),AO=require("joi"),{string:Wm}=AO.types(),{hdb_errors:Jce,handleHDBError:Km}=_e(),{HDB_ERROR_MSGS:VCe,HTTP_STATUS_CODES:gO}=Jce,{common_validators:Yu}=gi(),IG=" is required",Xce=["insert","update","upsert"],RO={database:{presence:!1,format:Yu.schema_format,length:Yu.schema_length},schema:{presence:!1,format:Yu.schema_format,length:Yu.schema_length},table:{presence:!0,format:Yu.schema_format,length:Yu.schema_length},action:{inclusion:{within:Xce,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},Zce={schema:Wm.required(),table:Wm.required(),action:Wm.valid("insert","update","upsert")},{AWS_ACCESS_KEY:ele,AWS_SECRET:tle,AWS_BUCKET:rle,AWS_FILE_KEY:nle,REGION:sle}=Ym.S3_BUCKET_AUTH_KEYS,ile={s3:{presence:!0},[`s3.${ele}`]:{presence:!0,type:"String"},[`s3.${tle}`]:{presence:!0,type:"String"},[`s3.${rle}`]:{presence:!0,type:"String"},[`s3.${nle}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${sle}`]:{presence:!0,type:"String"}},wG=jm(RO);wG.data.presence={message:IG};var CG=jm(RO);CG.file_path.presence={message:IG};var ole=Object.assign(jm(RO),ile),yO=jm(Zce);yO.csv_url=Wm.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();yO.passthrough_headers=AO.object();function ale(e){let t=zm.validateObject(e,wG);return Qm(e,t)}a(ale,"dataObject");function cle(e){let t=zm.validateBySchema(e,AO.object(yO));return Qm(e,t)}a(cle,"urlObject");function lle(e){let t=zm.validateObject(e,CG);return Qm(e,t)}a(lle,"fileObject");function ule(e){let t=zm.validateObject(e,ole);return Qm(e,t)}a(ule,"s3FileObject");function Qm(e,t){if(!t){let r=Qce.checkGlobalSchemaTable(e.schema,e.table);if(r)return Km(new Error,r,gO.BAD_REQUEST);if(e.operation===Ym.OPERATIONS_ENUM.CSV_FILE_LOAD)try{TO.accessSync(e.file_path,TO.constants.R_OK|TO.constants.F_OK)}catch(n){return n.code===Ym.NODE_ERROR_CODES.ENOENT?Km(n,`No such file or directory ${n.path}`,gO.BAD_REQUEST):n.code===Ym.NODE_ERROR_CODES.EACCES?Km(n,`Permission denied ${n.path}`,gO.BAD_REQUEST):Km(n)}}return t}a(Qm,"postValidateChecks");DG.exports={dataObject:ale,urlObject:cle,fileObject:lle,s3FileObject:ule}});var OO=N((WCe,PG)=>{"use strict";var qf=W(),Jm=M();async function dle(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(dle,"callOperationFunctionAsAwait");PG.exports={callOperationFunctionAsAwait:dle}});var NO=N((zCe,MG)=>{"use strict";var{S3:_le,GetObjectCommand:fle}=require("@aws-sdk/client-s3");MG.exports={getFileStreamFromS3:Ele,getS3AuthObj:LG};async function Ele(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 fle(r))).Body}a(Ele,"getFileStreamFromS3");function LG(e,t,r){return new _le({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(LG,"getS3AuthObj")});var vG=N((JCe,UG)=>{"use strict";var IO=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}},wO=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:IO,BulkLoadDataObject:wO}});var HG=N((ZCe,BG)=>{"use strict";var CO=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=CO});var kG=N((tDe,xG)=>{"use strict";var DO=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};xG.exports=DO});var LO=N((nDe,GG)=>{"use strict";var FG=HG(),hle=kG(),{HDB_ERROR_MSGS:ple}=Dn(),PO=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=ple.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 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 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=PO});var $G=N((iDe,qG)=>{"use strict";var MO=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};qG.exports=MO});var kO=N((dDe,oq)=>{"use strict";var Xm=un(),eS=bO(),mle=require("needle"),ti=M(),aDe=Ct(),Wu=te(),{handleHDBError:kt,hdb_errors:XG}=_e(),{HTTP_STATUS_CODES:Mr,HDB_ERROR_MSGS:Ar,CHECK_LOGS_WRAPPER:el}=XG,ju=W(),UO=require("papaparse");Wu.promisifyPapaParse();var ri=require("fs-extra"),Sle=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"),Tle=se(),ZG=OO(),gle=NO(),{BulkLoadFileObject:BO,BulkLoadDataObject:Ale}=vG(),HO=LO(),{verifyBulkLoadAttributePerms:eq}=tS(),cDe=$G(),lDe=mr(),uDe=to(),{databases:Rle}=(Pe(),oe(lt)),{coerceType:yle}=($f(),oe(FO)),zG="No records parsed from csv file.",Zc=`${Tle.get("HDB_ROOT")}/tmp`,{schema_regex:ble}=gi(),QG=1024*1024*2,JG=5e3,Ole={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};oq.exports={csvDataLoad:Nle,csvURLLoad:Ile,csvFileLoad:wle,importFromS3:Cle};async function Nle(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=UO.parse(e.data,{header:!0,skipEmptyLines:!0,transform:vO.bind(null,s),dynamicTyping:!1}),o=new HO;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 Ale(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 tl(s)}}a(Nle,"csvDataLoad");async function Ile(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=`${Zc}/${r}`;try{await Dle(e,r)}catch(s){throw ju.error(Ar.DOWNLOAD_FILE_ERR(r)+" - "+s),kt(s,el(Ar.DOWNLOAD_FILE_ERR(r)))}try{let s=new BO(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 xO(s);return await Zm(n),i}catch(s){throw await Zm(n),tl(s)}}a(Ile,"csvURLLoad");async function wle(e){let t=eS.fileObject(e);if(t)throw kt(t,t.message,Mr.BAD_REQUEST,void 0,void 0,!0);let r=new BO(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 xO(r)}catch(n){throw tl(n)}}a(wle,"csvFileLoad");async function Cle(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=Sle.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${Zc}/${s}`;let i=new BO(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user?.role?.permission);await Ple(s,e);let o=await xO(i);return await Zm(r),o}catch(n){throw await Zm(r),tl(n)}}a(Cle,"importFromS3");async function Dle(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await mle("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)}Mle(r,e.csv_url),await Lle(t,r.raw)}a(Dle,"downloadCSVFile");async function Ple(e,t){try{let r=`${Zc}/${e}`;await ri.mkdirp(Zc),await ri.writeFile(`${Zc}/${e}`,"",{flag:"a+"});let n=await ri.createWriteStream(r),s=await gle.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(){ju.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw ju.error(Ar.S3_DOWNLOAD_ERR+" - "+r),kt(r,el(Ar.S3_DOWNLOAD_ERR))}}a(Ple,"downloadFileFromS3");async function Lle(e,t){try{await ri.mkdirp(Zc),await ri.writeFile(`${Zc}/${e}`,t)}catch(r){throw ju.error(Ar.WRITE_TEMP_FILE_ERR),kt(r,el(Ar.DEFAULT_BULK_LOAD_ERR))}}a(Lle,"writeFileToTempFolder");async function Zm(e){if(e)try{await ri.access(e),await ri.unlink(e)}catch{ju.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(Zm,"deleteTempFile");function Mle(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(!Ole[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(Mle,"validateURLResponse");async function xO(e){try{let t;switch(e.file_type){case ti.VALID_S3_FILE_TYPES.CSV:t=await Ule(e);break;case ti.VALID_S3_FILE_TYPES.JSON:t=await vle(e);break;default:throw kt(new Error,Ar.DEFAULT_BULK_LOAD_ERR,Mr.BAD_REQUEST,ti.LOG_LEVELS.ERROR,Ar.INVALID_FILE_EXT_ERR(e))}return iq(t.records,t.number_written)}catch(t){throw tl(t)}}a(xO,"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;Wu.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Wu.isEmpty(c)&&!Wu.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,el(Ar.INSERT_CSV_ERR),Mr.INTERNAL_SERVER_ERROR,ti.LOG_LEVELS.ERROR,Ar.INSERT_CSV_ERR+" - "+c);r(l)}}a(rq,"insertChunk");async function Ule(e){let t={records:0,number_written:0},r=nq(e.schema,e.table);try{let n=new HO,s=ri.createReadStream(e.file_path,{highWaterMark:QG});s.setEncoding("utf8"),await UO.parsePromise(s,tq.bind(null,e,n),vO.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 UO.parsePromise(s,rq.bind(null,e,t),vO.bind(null,r)),s.destroy(),t}catch(n){throw kt(n,el(Ar.PAPA_PARSE_ERR),Mr.INTERNAL_SERVER_ERROR,ti.LOG_LEVELS.ERROR,Ar.PAPA_PARSE_ERR+n)}}a(Ule,"callPapaParse");function nq(e,t){let r=Rle[e][t].attributes,n=new Map;for(let s of r)s.type&&!s.computed&&!s.relationship&&n.set(s.name,i=>yle(i,s));return n}a(nq,"createTransformMap");function vO(e,t,r){let n=e.get(r);return n?n(t):Wu.autoCast(t)}a(vO,"typeFunction");async function vle(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new HO,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,el(Ar.INSERT_JSON_ERR),Mr.INTERNAL_SERVER_ERROR,ti.LOG_LEVELS.ERROR,Ar.INSERT_JSON_ERR+n)}}a(vle,"insertJson");async function sq(e){let t={};try{e.data&&e.data.length>0&&Ble(e.data[0])?t=await Hle(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",ju.info(t.message))}catch(r){throw tl(r)}return t}a(sq,"callBulkFileLoad");function Ble(e){let t=Object.keys(e);for(let r of t)if(!ble.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(Ble,"validateColumnNames");async function Hle(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,Ar.INVALID_ACTION_PARAM_ERR(n),Mr.BAD_REQUEST,ti.LOG_LEVELS.ERROR,Ar.INVALID_ACTION_PARAM_ERR(n))}try{let o=await i(s),c;switch(n){case"insert":c=o.inserted_hashes;break;case"update":c=o.update_hashes;break;case"upsert":c=o.upserted_hashes;break;default:break}if(Array.isArray(o.skipped_hashes)&&o.skipped_hashes.length>0){let d=global.hdb_schema[t][r].hash_attribute,_=e.length;for(;_--;)o.skipped_hashes.indexOf(e[_][d])>=0&&e.splice(_,1)}let l=Wu.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw tl(o)}}a(Hle,"bulkFileLoad");function iq(e,t){return`successfully loaded ${t} of ${e} records`}a(iq,"buildResponseMsg");function tl(e){return kt(e,el(Ar.DEFAULT_BULK_LOAD_ERR),Mr.INTERNAL_SERVER_ERROR,ti.LOG_LEVELS.ERROR,Ar.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(tl,"buildTopLevelErrMsg")});var cq=N((fDe,aq)=>{"use strict";var GO=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};aq.exports=GO});var dq=N((hDe,uq)=>{"use strict";var xle=M(),lq=require("moment"),kle=require("uuid").v4,qO=class{static{a(this,"JobObject")}constructor(){this.id=kle(),this.type=void 0,this.start_datetime=lq().valueOf(),this.created_datetime=lq().valueOf(),this.end_datetime=void 0,this.status=xle.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};uq.exports=qO});var $O=N((mDe,fq)=>{"use strict";var As=require("joi"),_q=Tt();fq.exports={readTransactionLogValidator:Fle,deleteTransactionLogsBeforeValidator:Gle};function Fle(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(Fle,"readTransactionLogValidator");function Gle(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(Gle,"deleteTransactionLogsBeforeValidator")});var VO=N((TDe,Aq)=>{"use strict";var qle=require("uuid").v4,Sq=un(),Tq=Vr(),$le=$s(),Vle=jl(),Kle=cq(),bt=M(),Yle=dq(),Wle=Hp(),ni=W(),jle=Qd(),zu=te(),{promisify:zle}=require("util"),rl=require("moment"),Qle=nS(),rS=bO(),Eq=yA(),{deleteTransactionLogsBeforeValidator:Jle}=$O(),{handleHDBError:hq,hdb_errors:Xle,ClientError:Zle}=_e(),{HTTP_STATUS_CODES:pq}=Xle,mq=Tq.searchByValue,eue=Tq.searchByHash,tue=Sq.insert,rue=zle(Qle.evaluateSQL),nue=Sq.update;Aq.exports={addJob:oue,updateJob:cue,handleGetJob:sue,handleGetJobsByStartDate:iue,getJobById:gq};async function sue(e){if(e.id===void 0)throw new Zle("'id' is required");let t=await gq(e.id);return zu.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(sue,"handleGetJob");async function iue(e){try{let t=await aue(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=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 ni.error(r),new Error(r)}}a(iue,"handleGetJobsByStartDate");async function oue(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||zu.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=Jle(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 Yle;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 $le(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=qle();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 jle(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),u;try{u=await tue(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(oue,"addJob");async function aue(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 Kle(n,e.hdb_user);try{return await rue(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(aue,"getJobsInDateRange");async function gq(e){if(zu.isEmptyOrZeroLength(e))return zu.errorizeMessage("Invalid job ID specified.");let t=new Vle(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await eue(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return ni.error(n),zu.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(gq,"getJobById");async function cue(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(zu.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 Wle(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await nue(t),r}a(cue,"updateJob")});var oS=N((ADe,Iq)=>{"use strict";var KO=M(),Vf=mr(),Rq=te(),yq=se(),bq=to(),Oq=W(),{handleHDBError:sS,hdb_errors:lue}=_e(),{HTTP_STATUS_CODES:iS}=lue,{readTransactionLogValidator:uue,deleteTransactionLogsBeforeValidator:due}=$O(),Nq=Bn(),_ue="Logs successfully deleted from transaction log.",fue="All logs successfully deleted from transaction log.";Iq.exports={readTransactionLog:Eue,deleteTransactionLogsBefore:pue};async function Eue(e){let t=uue(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(KO.CONFIG_PARAMS.CLUSTERING_ENABLED)?await hue(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(Eue,"readTransactionLog");async function*hue(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===KO.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(hue,"readTransactionLogNats");async function pue(e){let t=due(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(KO.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=_ue,_,E=new Date(l.state.last_ts).getTime();return s>E?(_=l.state.last_seq+1,d=fue):_=(await Vf.viewStream(o,parseInt(s),1))[0].nats_sequence,await Vf.purgeTableStream(r,n,{seq:_}),d}a(pue,"deleteTransactionLogsBefore")});var vq=N((yDe,Uq)=>{"use strict";var wq=te(),Rr=M(),mue=require("moment"),aS=kO(),Kf=W(),Cq=VO(),Dq=cS(),Pq=dc(),Lq=dt(),Sue=oS(),Tue=qu(),{parentPort:gue,isMainThread:Mq}=require("worker_threads"),{onMessageByType:Aue}=dt(),YO=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function Rue(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 Rr.JOB_TYPE_ENUM.csv_file_load:await Mi(e,aS.csvFileLoad);break;case Rr.JOB_TYPE_ENUM.csv_url_load:await Mi(e,aS.csvURLLoad);break;case Rr.JOB_TYPE_ENUM.csv_data_load:await Mi(e,aS.csvDataLoad);break;case Rr.JOB_TYPE_ENUM.import_from_s3:await Mi(e,aS.importFromS3);break;case Rr.JOB_TYPE_ENUM.empty_trash:break;case Rr.JOB_TYPE_ENUM.export_local:await Mi(e,Dq.export_local);break;case Rr.JOB_TYPE_ENUM.export_to_s3:await Mi(e,Dq.export_to_s3);break;case Rr.JOB_TYPE_ENUM.delete_files_before:case Rr.JOB_TYPE_ENUM.delete_records_before:await Mi(e,Pq.deleteFilesBefore);break;case Rr.JOB_TYPE_ENUM.delete_audit_logs_before:await Mi(e,Pq.deleteAuditLogsBefore);break;case Rr.JOB_TYPE_ENUM.delete_transaction_logs_before:await Mi(e,Sue.deleteTransactionLogsBefore);break;case Rr.JOB_TYPE_ENUM.restart_service:return await Mi(e,Tue.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(Rue,"parseMessage");async function Mi(e,t){try{e.job.status=Rr.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=mue().valueOf(),await Cq.updateJob(e.job),await yue(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=Rr.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(Mi,"runJob");async function yue(e){Kf.trace("launching job thread:",e),Mq?Lq.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Rr.PROCESS_NAME_ENV_PROP]:`JOB-${e}`}}):gue.postMessage({type:Rr.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(yue,"launchJobThread");Mq&&Aue(Rr.ITC_EVENT_TYPES.START_JOB,async(e,t)=>{try{Lq.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Rr.PROCESS_NAME_ENV_PROP]:`JOB-${e.jobId}`}})}catch(r){Kf.error(r)}});Uq.exports={parseMessage:Rue,RunnerMessage:YO}});var Hq=N((ODe,Bq)=>{"use strict";var WO=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};Bq.exports=WO});var eN=N((wDe,ZO)=>{"use strict";var fS=Vr(),QO=nS(),lS=kO(),To=tm(),uS=ro(),Wf=dc(),bue=zy(),Yf=xn(),dS=cf(),Lt=tN(),_S=W(),Oue=ob(),Nue=hf(),xq=Lb(),Iue=gf(),wue=vb(),Cue=Bb(),Due=Sm(),Pue=Fb(),jO=gm(),kq=cS(),Lue=tS(),JO=VO(),$=M(),{hdb_errors:zf,handleHDBError:jf}=_e(),{HTTP_STATUS_CODES:Fq}=zf,zO=Wb(),Gq=qu(),Jq=require("util"),Ju=un(),Mue=us(),Uue=Cu(),qq=vq(),$q=fu(),Vq=(km(),oe(vf)),Kq=wt(),Yq=oS(),Wq=kf(),{setServerUtilities:vue}=($f(),oe(FO)),{CONTEXT:IDe}=(Vs(),oe(_R)),{_assignPackageExport:Bue}=Ei(),{transformReq:Hue}=te(),{server:xue}=(qr(),oe(Ja)),Zr=_S.loggerWithTag("operation"),Qu=Xs(),jq=(kc(),oe(xc)),kue=OO(),zq=fS.searchByHash,Fue=fS.searchByValue,Gue=Jq.promisify(fS.search),que=Jq.promisify(QO.evaluateSQL),$ue={[$.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 kue.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return $ue[e.body.operation]&&Mue.setSchemaDataToGlobal(n=>{n&&Zr.error(n)}),r}a(Xq,"processLocalTransaction");var Qq=Kue();ZO.exports={chooseOperation:Zq,getOperationFunction:e$,operation:XO,processLocalTransaction:Xq,executeJob:Rs};vue(ZO.exports);xue.operation=XO;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=QO.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=QO.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=Lue.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");Bue("operation",XO);function XO(e,t,r){e.hdb_user=t?.user,e.bypass_auth=!r;let n=Zq(e);return Xq({body:e},n)}a(XO,"operation");async function Vue(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 Ju.insert(i);break;case $.OPERATIONS_ENUM.UPDATE:o=await Ju.update(i);break;case $.OPERATIONS_ENUM.UPSERT:o=await Ju.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(Vue,"catchup");async function Rs(e){Hue(e);let t,r;try{r=await JO.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 Kue(){let e=new Map;return e.set($.OPERATIONS_ENUM.INSERT,new J(Ju.insert)),e.set($.OPERATIONS_ENUM.UPDATE,new J(Ju.update)),e.set($.OPERATIONS_ENUM.UPSERT,new J(Ju.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(Fue)),e.set($.OPERATIONS_ENUM.SEARCH,new J(Gue)),e.set($.OPERATIONS_ENUM.SQL,new J(que)),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(Oue)),e.set($.OPERATIONS_ENUM.ADD_NODE,new J(Nue)),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(Iue)),e.set($.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new J(wue)),e.set($.OPERATIONS_ENUM.PURGE_STREAM,new J(Cue)),e.set($.OPERATIONS_ENUM.SET_CONFIGURATION,new J(Kq.setConfiguration)),e.set($.OPERATIONS_ENUM.CLUSTER_STATUS,new J(Due.clusterStatus)),e.set($.OPERATIONS_ENUM.CLUSTER_NETWORK,new J(Pue)),e.set($.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new J(jO.setRoutes)),e.set($.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new J(jO.getRoutes)),e.set($.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new J(jO.deleteRoutes)),e.set($.OPERATIONS_ENUM.EXPORT_TO_S3,new J(Rs,kq.export_to_s3)),e.set($.OPERATIONS_ENUM.CREATE_CSR,new J(Qu.createCsr)),e.set($.OPERATIONS_ENUM.SIGN_CERTIFICATE,new J(Qu.signCertificate)),e.set($.OPERATIONS_ENUM.LIST_CERTIFICATES,new J(Qu.listCertificates)),e.set($.OPERATIONS_ENUM.ADD_CERTIFICATES,new J(Qu.addCertificate)),e.set($.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new J(Qu.removeCertificate)),e.set($.OPERATIONS_ENUM.GET_KEY,new J(Qu.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(JO.handleGetJobsByStartDate)),e.set($.OPERATIONS_ENUM.GET_JOB,new J(JO.handleGetJob)),e.set($.OPERATIONS_ENUM.GET_FINGERPRINT,new J(zO.getFingerprint)),e.set($.OPERATIONS_ENUM.SET_LICENSE,new J(zO.setLicense)),e.set($.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new J(zO.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(Vue)),e.set($.OPERATIONS_ENUM.SYSTEM_INFORMATION,new J(Uue.systemInformation)),e.set($.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new J(Rs,Wf.deleteAuditLogsBefore)),e.set($.OPERATIONS_ENUM.READ_AUDIT_LOG,new J(bue)),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(Kue,"initializeOperationFunctionMap")});var tN=N(s$=>{"use strict";var Te=require("fs-extra"),rN=require("fast-glob"),be=require("path"),Yue=require("tar-fs"),Wue=require("gunzip-maybe"),DDe=require("uuid").v4,nN=require("normalize-path"),An=lG(),Gt=W(),ft=M(),Ft=se(),ES=wt(),jue=te(),{PACKAGE_ROOT:zue}=M(),{handleHDBError:qt,hdb_errors:Que}=_e(),{basename:Jue}=require("path"),Xue=SO(),r$=se(),Zue=M(),{Readable:ede}=require("stream"),{isMainThread:tde}=require("worker_threads"),{HDB_ERROR_MSGS:nl,HTTP_STATUS_CODES:$t}=Que,n$=dt(),{replicateOperation:si}=(ds(),oe(ca)),{packageDirectory:rde}=(NG(),oe(OG)),t$=kf(),nde=be.join(zue,"application-template"),PDe=be.join(Ft.get(ft.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),"tmp"),sde=Ft.get(ft.CONFIG_PARAMS.ROOTPATH),Ta=be.join(sde,"ssh"),go=be.join(Ta,"known_hosts");function ide(){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,nl.FUNCTION_STATUS,$t.INTERNAL_SERVER_ERROR,Gt.ERR,t)}return e}a(ide,"customFunctionsStatus");function ode(){Gt.trace("getting custom api endpoints");let e={},t=Ft.get(ft.CONFIG_PARAMS.COMPONENTSROOT);try{rN.sync(nN(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:rN.sync(nN(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:rN.sync(nN(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw qt(new Error,nl.GET_FUNCTIONS,$t.INTERNAL_SERVER_ERROR,Gt.ERR,r)}return e}a(ode,"getCustomFunctions");function ade(e){e.project&&(e.project=be.parse(e.project).name),e.file&&(e.file=be.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=be.join(r,n,s,i+".js");try{return Te.readFileSync(o,{encoding:"utf8"})}catch(c){throw qt(new Error,nl.GET_FUNCTION,$t.INTERNAL_SERVER_ERROR,Gt.ERR,c)}}a(ade,"getCustomFunction");async function cde(e){e.project&&(e.project=be.parse(e.project).name),e.file&&(e.file=be.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(be.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,nl.SET_FUNCTION,$t.INTERNAL_SERVER_ERROR,Gt.ERR,c)}}a(cde,"setCustomFunction");async function lde(e){e.project&&(e.project=be.parse(e.project).name),e.file&&(e.file=be.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(be.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,nl.DROP_FUNCTION,$t.INTERNAL_SERVER_ERROR,Gt.ERR,o)}}a(lde,"dropCustomFunction");async function ude(e){e.project&&(e.project=be.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=be.join(r,n);Te.mkdirSync(s,{recursive:!0}),Te.copySync(nde,s);let i=await si(e);return i.message=`Successfully added project: ${n}`,i}catch(s){throw qt(new Error,nl.ADD_FUNCTION,$t.INTERNAL_SERVER_ERROR,Gt.ERR,s)}}a(ude,"addComponent");async function dde(e){e.project&&(e.project=be.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(!jue.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=be.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,nl.DROP_FUNCTION_PROJECT,$t.INTERNAL_SERVER_ERROR,Gt.ERR,i)}}a(dde,"dropCustomFunctionProject");async function _de(e){e.project&&(e.project=be.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(be.join(r,n))}catch(o){if(o.code!==ft.NODE_ERROR_CODES.ENOENT)throw o;try{s=await Te.realpath(be.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 rde(s,e)).toString("base64");return{project:n,payload:i}}a(_de,"packageComponent");async function fde(e){e.project?e.project=be.parse(e.project).name:e.package&&(e.project=Ede(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=be.join(r,n),i="file:"+c,await Te.emptyDir(c);let T=ede.from(s instanceof Buffer?s:Buffer.from(s,"base64"));await new Promise((S,y)=>{T.pipe(Wue()).pipe(Yue.extract(c,{finish:S})).on("error",y)});let m=await Te.readdir(c);m.length===1&&m[0]==="package"&&(await Te.copy(be.join(c,"package"),c),await Te.remove(be.join(c,"package")));let g=be.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 Xue();let T=r$.get(Zue.CONFIG_PARAMS.ROOTPATH);c=be.join(T,"node_modules",n)}if(tde)return;let l=new Map;l.isWorker=!0;let u=(Jf(),oe(Qf)),d;u.setErrorReporter(T=>d=T);let _=Jue(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 eN().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(fde,"deployComponent");function Ede(e){if(e.startsWith("git+ssh://"))return be.basename(e.split("#")[0].replace(/\.git$/,""));if(e.startsWith("http://")||e.startsWith("https://"))return be.basename(new URL(e.replace(/\.git$/,"")).pathname);if(e.startsWith("file://"))try{let{name:t}=JSON.parse(Te.readFileSync(be.join(e,"package.json"),"utf8"));return be.basename(t)}catch{}return be.basename(e)}a(Ede,"getProjectNameFromPackage");async function hde(){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=be.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:be.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(be.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(hde,"getComponents");async function pde(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"?be.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(be.join(n,e.project,e.file));return{message:await Te.readFile(be.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 '${be.join(e.project,e.file)}'`):i}}a(pde,"getComponentFile");async function mde(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=be.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(mde,"setComponentFile");async function Sde(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?be.join(r,n):r,i=be.join(Ft.get(ft.CONFIG_PARAMS.COMPONENTSROOT),s),o=be.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=be.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(Sde,"dropComponent");async function Tde(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=be.join(Ta,r+".key"),l=be.join(Ta,"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}
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 Xc.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){Xc.info(`starting auditModules for request: ${e}`);let t=hG(e);if(t)throw xf(t,t.message,kf.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=Sa.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=fG(l.stderr)}}return Xc.info(`finished auditModules with response ${n}`),n}a(Kce,"auditModules");async function $m(){return await Ku("npm -v"),!0}a($m,"checkNPMInstalled");async function EG(e){if(!Array.isArray(e)||e.length===0)throw xf(new Error,"projects argument must be an array with at least 1 element",kf.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=Sa.join(mO,i.toString());if(!await Vu.pathExists(o)){t.push(i);continue}let l=Sa.join(o,"package.json");await Vu.pathExists(l)||r.push(i)}if(t.length>0)throw xf(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,kf.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw xf(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,kf.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((FCe,RG)=>{"use strict";var gs=require("fs-extra"),qf=require("path"),Gf=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=qf.join(t,"package.json"),n={dependencies:{harperdb:"file:"+Vm.PACKAGE_ROOT}},s=qf.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){Gf.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){Gf.info(`Error checking ${u}/package.json modification time`,E);break}}}for(let l in i.dependencies)n.dependencies[l]===void 0&&(Gf.notify("Removing component",l),c=!0);c&&(Gf.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=qf.join(e,"node_modules",r),s=qf.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:":qf.extname(e)||gs.existsSync(e)?"file:":"github:"}a(TG,"getPkgPrefix");async function gG(e,t,r){Gf.trace("npm installing components package.json",t),gs.writeFileSync(e,JSON.stringify(t,null," "));try{await Ff().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 NG={};je(NG,{packageDirectory:()=>zce});function zce(e,t={skip_node_modules:!1,skip_symlinks:!1}){return new Promise((r,n)=>{let s=[];bG.default.pack(e,{dereference:!t.skip_symlinks,ignore:t.skip_node_modules?i=>i.includes("node_modules")||i.includes((0,yG.join)("cache","webpack")):void 0}).pipe((0,OG.createGzip)()).on("data",i=>s.push(i)).on("end",()=>{r(Buffer.concat(s))}).on("error",n)})}var yG,bG,OG,IG=Ie(()=>{yG=require("path"),bG=L(require("tar-fs")),OG=require("node:zlib");a(zce,"packageDirectory")});var bO=N((KCe,PG)=>{var jm=require("clone"),zm=Tt(),Qce=te(),Ym=M(),$Ce=W(),TO=require("fs"),AO=require("joi"),{string:Wm}=AO.types(),{hdb_errors:Jce,handleHDBError:Km}=_e(),{HDB_ERROR_MSGS:VCe,HTTP_STATUS_CODES:gO}=Jce,{common_validators:Yu}=gi(),wG=" is required",Xce=["insert","update","upsert"],RO={database:{presence:!1,format:Yu.schema_format,length:Yu.schema_length},schema:{presence:!1,format:Yu.schema_format,length:Yu.schema_length},table:{presence:!0,format:Yu.schema_format,length:Yu.schema_length},action:{inclusion:{within:Xce,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},Zce={schema:Wm.required(),table:Wm.required(),action:Wm.valid("insert","update","upsert")},{AWS_ACCESS_KEY:ele,AWS_SECRET:tle,AWS_BUCKET:rle,AWS_FILE_KEY:nle,REGION:sle}=Ym.S3_BUCKET_AUTH_KEYS,ile={s3:{presence:!0},[`s3.${ele}`]:{presence:!0,type:"String"},[`s3.${tle}`]:{presence:!0,type:"String"},[`s3.${rle}`]:{presence:!0,type:"String"},[`s3.${nle}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${sle}`]:{presence:!0,type:"String"}},CG=jm(RO);CG.data.presence={message:wG};var DG=jm(RO);DG.file_path.presence={message:wG};var ole=Object.assign(jm(RO),ile),yO=jm(Zce);yO.csv_url=Wm.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();yO.passthrough_headers=AO.object();function ale(e){let t=zm.validateObject(e,CG);return Qm(e,t)}a(ale,"dataObject");function cle(e){let t=zm.validateBySchema(e,AO.object(yO));return Qm(e,t)}a(cle,"urlObject");function lle(e){let t=zm.validateObject(e,DG);return Qm(e,t)}a(lle,"fileObject");function ule(e){let t=zm.validateObject(e,ole);return Qm(e,t)}a(ule,"s3FileObject");function Qm(e,t){if(!t){let r=Qce.checkGlobalSchemaTable(e.schema,e.table);if(r)return Km(new Error,r,gO.BAD_REQUEST);if(e.operation===Ym.OPERATIONS_ENUM.CSV_FILE_LOAD)try{TO.accessSync(e.file_path,TO.constants.R_OK|TO.constants.F_OK)}catch(n){return n.code===Ym.NODE_ERROR_CODES.ENOENT?Km(n,`No such file or directory ${n.path}`,gO.BAD_REQUEST):n.code===Ym.NODE_ERROR_CODES.EACCES?Km(n,`Permission denied ${n.path}`,gO.BAD_REQUEST):Km(n)}}return t}a(Qm,"postValidateChecks");PG.exports={dataObject:ale,urlObject:cle,fileObject:lle,s3FileObject:ule}});var OO=N((WCe,LG)=>{"use strict";var $f=W(),Jm=M();async function dle(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")?($f.info(i.message),i):i.http_resp_msg?($f.error(`Error calling operation: ${e.name}`),$f.error(i.http_resp_msg),i):($f.error(`Error calling operation: ${e.name}`),$f.error(i),i)}}a(dle,"callOperationFunctionAsAwait");LG.exports={callOperationFunctionAsAwait:dle}});var NO=N((zCe,UG)=>{"use strict";var{S3:_le,GetObjectCommand:fle}=require("@aws-sdk/client-s3");UG.exports={getFileStreamFromS3:Ele,getS3AuthObj:MG};async function Ele(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await MG(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new fle(r))).Body}a(Ele,"getFileStreamFromS3");function MG(e,t,r){return new _le({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(MG,"getS3AuthObj")});var BG=N((JCe,vG)=>{"use strict";var IO=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}},wO=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};vG.exports={BulkLoadFileObject:IO,BulkLoadDataObject:wO}});var xG=N((ZCe,HG)=>{"use strict";var CO=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}};HG.exports=CO});var FG=N((tDe,kG)=>{"use strict";var DO=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};kG.exports=DO});var LO=N((nDe,qG)=>{"use strict";var GG=xG(),hle=FG(),{HDB_ERROR_MSGS:ple}=Dn(),PO=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=ple.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 GG(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 GG(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}};qG.exports=PO});var VG=N((iDe,$G)=>{"use strict";var MO=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};$G.exports=MO});var kO=N((dDe,aq)=>{"use strict";var Xm=un(),eS=bO(),mle=require("needle"),ti=M(),aDe=Ct(),Wu=te(),{handleHDBError:kt,hdb_errors:ZG}=_e(),{HTTP_STATUS_CODES:Mr,HDB_ERROR_MSGS:Ar,CHECK_LOGS_WRAPPER:el}=ZG,ju=W(),UO=require("papaparse");Wu.promisifyPapaParse();var ri=require("fs-extra"),Sle=require("path"),{chain:KG}=require("stream-chain"),YG=require("stream-json/streamers/StreamArray"),WG=require("stream-json/utils/Batch"),jG=require("stream-chain/utils/comp"),{finished:zG}=require("stream"),Tle=se(),eq=OO(),gle=NO(),{BulkLoadFileObject:BO,BulkLoadDataObject:Ale}=BG(),HO=LO(),{verifyBulkLoadAttributePerms:tq}=tS(),cDe=VG(),lDe=mr(),uDe=to(),{databases:Rle}=(Pe(),oe(lt)),{coerceType:yle}=(Vf(),oe(FO)),QG="No records parsed from csv file.",Zc=`${Tle.get("HDB_ROOT")}/tmp`,{schema_regex:ble}=gi(),JG=1024*1024*2,XG=5e3,Ole={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};aq.exports={csvDataLoad:Nle,csvURLLoad:Ile,csvFileLoad:wle,importFromS3:Cle};async function Nle(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=sq(e.schema,e.table),i=UO.parse(e.data,{header:!0,skipEmptyLines:!0,transform:vO.bind(null,s),dynamicTyping:!1}),o=new HO;e.hdb_user&&e.hdb_user?.role&&e.hdb_user?.role?.permission&&e.hdb_user?.role?.permission?.super_user!==!0&&tq(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 Ale(e.action,e.schema,e.table,i.data);return n=await eq.callOperationFunctionAsAwait(iq,l,null),n.message===QG?QG:oq(n.records,n.number_written)}catch(s){throw tl(s)}}a(Nle,"csvDataLoad");async function Ile(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=`${Zc}/${r}`;try{await Dle(e,r)}catch(s){throw ju.error(Ar.DOWNLOAD_FILE_ERR(r)+" - "+s),kt(s,el(Ar.DOWNLOAD_FILE_ERR(r)))}try{let s=new BO(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 xO(s);return await Zm(n),i}catch(s){throw await Zm(n),tl(s)}}a(Ile,"csvURLLoad");async function wle(e){let t=eS.fileObject(e);if(t)throw kt(t,t.message,Mr.BAD_REQUEST,void 0,void 0,!0);let r=new BO(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 xO(r)}catch(n){throw tl(n)}}a(wle,"csvFileLoad");async function Cle(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=Sle.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${Zc}/${s}`;let i=new BO(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user?.role?.permission);await Ple(s,e);let o=await xO(i);return await Zm(r),o}catch(n){throw await Zm(r),tl(n)}}a(Cle,"importFromS3");async function Dle(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await mle("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)}Mle(r,e.csv_url),await Lle(t,r.raw)}a(Dle,"downloadCSVFile");async function Ple(e,t){try{let r=`${Zc}/${e}`;await ri.mkdirp(Zc),await ri.writeFile(`${Zc}/${e}`,"",{flag:"a+"});let n=await ri.createWriteStream(r),s=await gle.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(){ju.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw ju.error(Ar.S3_DOWNLOAD_ERR+" - "+r),kt(r,el(Ar.S3_DOWNLOAD_ERR))}}a(Ple,"downloadFileFromS3");async function Lle(e,t){try{await ri.mkdirp(Zc),await ri.writeFile(`${Zc}/${e}`,t)}catch(r){throw ju.error(Ar.WRITE_TEMP_FILE_ERR),kt(r,el(Ar.DEFAULT_BULK_LOAD_ERR))}}a(Lle,"writeFileToTempFolder");async function Zm(e){if(e)try{await ri.access(e),await ri.unlink(e)}catch{ju.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(Zm,"deleteTempFile");function Mle(e,t){if(e.statusCode!==ZG.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(!Ole[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(Mle,"validateURLResponse");async function xO(e){try{let t;switch(e.file_type){case ti.VALID_S3_FILE_TYPES.CSV:t=await Ule(e);break;case ti.VALID_S3_FILE_TYPES.JSON:t=await vle(e);break;default:throw kt(new Error,Ar.DEFAULT_BULK_LOAD_ERR,Mr.BAD_REQUEST,ti.LOG_LEVELS.ERROR,Ar.INVALID_FILE_EXT_ERR(e))}return oq(t.records,t.number_written)}catch(t){throw tl(t)}}a(xO,"fileLoad");async function rq(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&&tq(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(rq,"validateChunk");async function nq(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;Wu.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Wu.isEmpty(c)&&!Wu.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 eq.callOperationFunctionAsAwait(iq,c,null);t.records+=l.records,t.number_written+=l.number_written,s&&s.resume()}catch(c){let l=kt(c,el(Ar.INSERT_CSV_ERR),Mr.INTERNAL_SERVER_ERROR,ti.LOG_LEVELS.ERROR,Ar.INSERT_CSV_ERR+" - "+c);r(l)}}a(nq,"insertChunk");async function Ule(e){let t={records:0,number_written:0},r=sq(e.schema,e.table);try{let n=new HO,s=ri.createReadStream(e.file_path,{highWaterMark:JG});s.setEncoding("utf8"),await UO.parsePromise(s,rq.bind(null,e,n),vO.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:JG}),s.setEncoding("utf8"),await UO.parsePromise(s,nq.bind(null,e,t),vO.bind(null,r)),s.destroy(),t}catch(n){throw kt(n,el(Ar.PAPA_PARSE_ERR),Mr.INTERNAL_SERVER_ERROR,ti.LOG_LEVELS.ERROR,Ar.PAPA_PARSE_ERR+n)}}a(Ule,"callPapaParse");function sq(e,t){let r=Rle[e][t].attributes,n=new Map;for(let s of r)s.type&&!s.computed&&!s.relationship&&n.set(s.name,i=>yle(i,s));return n}a(sq,"createTransformMap");function vO(e,t,r){let n=e.get(r);return n?n(t):Wu.autoCast(t)}a(vO,"typeFunction");async function vle(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new HO,s=KG([ri.createReadStream(e.file_path,{encoding:"utf-8"}),YG.withParser(),c=>c.value,new WG({batchSize:XG}),jG(async c=>{await rq(e,n,r,c)})]);await new Promise((c,l)=>{zG(s,u=>{u?l(u):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw kt(new Error,i,Mr.BAD_REQUEST);let o=KG([ri.createReadStream(e.file_path,{encoding:"utf-8"}),YG.withParser(),c=>c.value,new WG({batchSize:XG}),jG(async c=>{await nq(e,t,r,c)})]);return await new Promise((c,l)=>{zG(o,u=>{u?l(u):c()}),o.resume()}),t}catch(n){throw kt(n,el(Ar.INSERT_JSON_ERR),Mr.INTERNAL_SERVER_ERROR,ti.LOG_LEVELS.ERROR,Ar.INSERT_JSON_ERR+n)}}a(vle,"insertJson");async function iq(e){let t={};try{e.data&&e.data.length>0&&Ble(e.data[0])?t=await Hle(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",ju.info(t.message))}catch(r){throw tl(r)}return t}a(iq,"callBulkFileLoad");function Ble(e){let t=Object.keys(e);for(let r of t)if(!ble.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(Ble,"validateColumnNames");async function Hle(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,Ar.INVALID_ACTION_PARAM_ERR(n),Mr.BAD_REQUEST,ti.LOG_LEVELS.ERROR,Ar.INVALID_ACTION_PARAM_ERR(n))}try{let o=await i(s),c;switch(n){case"insert":c=o.inserted_hashes;break;case"update":c=o.update_hashes;break;case"upsert":c=o.upserted_hashes;break;default:break}if(Array.isArray(o.skipped_hashes)&&o.skipped_hashes.length>0){let d=global.hdb_schema[t][r].hash_attribute,_=e.length;for(;_--;)o.skipped_hashes.indexOf(e[_][d])>=0&&e.splice(_,1)}let l=Wu.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw tl(o)}}a(Hle,"bulkFileLoad");function oq(e,t){return`successfully loaded ${t} of ${e} records`}a(oq,"buildResponseMsg");function tl(e){return kt(e,el(Ar.DEFAULT_BULK_LOAD_ERR),Mr.INTERNAL_SERVER_ERROR,ti.LOG_LEVELS.ERROR,Ar.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(tl,"buildTopLevelErrMsg")});var lq=N((fDe,cq)=>{"use strict";var GO=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};cq.exports=GO});var _q=N((hDe,dq)=>{"use strict";var xle=M(),uq=require("moment"),kle=require("uuid").v4,qO=class{static{a(this,"JobObject")}constructor(){this.id=kle(),this.type=void 0,this.start_datetime=uq().valueOf(),this.created_datetime=uq().valueOf(),this.end_datetime=void 0,this.status=xle.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};dq.exports=qO});var $O=N((mDe,Eq)=>{"use strict";var As=require("joi"),fq=Tt();Eq.exports={readTransactionLogValidator:Fle,deleteTransactionLogsBeforeValidator:Gle};function Fle(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 fq.validateBySchema(e,t)}a(Fle,"readTransactionLogValidator");function Gle(e){let t=As.object({schema:As.string(),database:As.string(),table:As.string().required(),timestamp:As.date().timestamp().required()});return fq.validateBySchema(e,t)}a(Gle,"deleteTransactionLogsBeforeValidator")});var VO=N((TDe,Rq)=>{"use strict";var qle=require("uuid").v4,Tq=un(),gq=Vr(),$le=$s(),Vle=jl(),Kle=lq(),bt=M(),Yle=_q(),Wle=Hp(),ni=W(),jle=Jd(),zu=te(),{promisify:zle}=require("util"),rl=require("moment"),Qle=nS(),rS=bO(),hq=yA(),{deleteTransactionLogsBeforeValidator:Jle}=$O(),{handleHDBError:pq,hdb_errors:Xle,ClientError:Zle}=_e(),{HTTP_STATUS_CODES:mq}=Xle,Sq=gq.searchByValue,eue=gq.searchByHash,tue=Tq.insert,rue=zle(Qle.evaluateSQL),nue=Tq.update;Rq.exports={addJob:oue,updateJob:cue,handleGetJob:sue,handleGetJobsByStartDate:iue,getJobById:Aq};async function sue(e){if(e.id===void 0)throw new Zle("'id' is required");let t=await Aq(e.id);return zu.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(sue,"handleGetJob");async function iue(e){try{let t=await aue(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=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 ni.error(r),new Error(r)}}a(iue,"handleGetJobsByStartDate");async function oue(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||zu.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=hq(e,"date");break;case bt.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=hq(e,"timestamp");break;case bt.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=Jle(e);break;case bt.OPERATIONS_ENUM.RESTART_SERVICE:if(bt.PROCESS_DESCRIPTORS_VALIDATE[e.service]===void 0)throw pq(new Error,"Invalid service",mq.BAD_REQUEST,void 0,void 0,!0);break;default:break}if(n)throw pq(n,n.message,mq.BAD_REQUEST,void 0,void 0,!0);let s=new Yle;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 $le(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await Sq(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=qle();try{o=await Sq(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 jle(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),u;try{u=await tue(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(oue,"addJob");async function aue(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 Kle(n,e.hdb_user);try{return await rue(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(aue,"getJobsInDateRange");async function Aq(e){if(zu.isEmptyOrZeroLength(e))return zu.errorizeMessage("Invalid job ID specified.");let t=new Vle(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await eue(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return ni.error(n),zu.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(Aq,"getJobById");async function cue(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(zu.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 Wle(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await nue(t),r}a(cue,"updateJob")});var oS=N((ADe,wq)=>{"use strict";var KO=M(),Kf=mr(),yq=te(),bq=se(),Oq=to(),Nq=W(),{handleHDBError:sS,hdb_errors:lue}=_e(),{HTTP_STATUS_CODES:iS}=lue,{readTransactionLogValidator:uue,deleteTransactionLogsBeforeValidator:due}=$O(),Iq=Bn(),_ue="Logs successfully deleted from transaction log.",fue="All logs successfully deleted from transaction log.";wq.exports={readTransactionLog:Eue,deleteTransactionLogsBefore:pue};async function Eue(e){let t=uue(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=yq.checkSchemaTableExist(e.database,e.table);if(r)throw sS(new Error,r,iS.NOT_FOUND,void 0,void 0,!0);return bq.get(KO.CONFIG_PARAMS.CLUSTERING_ENABLED)?await hue(e):(Nq.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)),Iq.readAuditLog(e))}a(Eue,"readTransactionLog");async function*hue(e){let t=Oq.createNatsTableStreamName(e.database,e.table),r=await Kf.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===KO.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(hue,"readTransactionLogNats");async function pue(e){let t=due(e);if(t)throw sS(t,t.message,iS.BAD_REQUEST,void 0,void 0,!0);if(e.database=e.database??e.schema??"data",!bq.get(KO.CONFIG_PARAMS.CLUSTERING_ENABLED))return Nq.info("Delete transaction logs called for Plexus"),Iq.deleteAuditLogsBefore(e);let{database:r,table:n,timestamp:s}=e,i=yq.checkSchemaTableExist(r,n);if(i)throw sS(new Error,i,iS.NOT_FOUND,void 0,void 0,!0);let o=Oq.createNatsTableStreamName(r,n),{jsm:c}=await Kf.getNATSReferences(),l=await Kf.getStreamInfo(o),u=new Date(l.state.first_ts).getTime();if(s<=u)return`No transactions exist before: ${s}`;let d=_ue,_,E=new Date(l.state.last_ts).getTime();return s>E?(_=l.state.last_seq+1,d=fue):_=(await Kf.viewStream(o,parseInt(s),1))[0].nats_sequence,await Kf.purgeTableStream(r,n,{seq:_}),d}a(pue,"deleteTransactionLogsBefore")});var Bq=N((yDe,vq)=>{"use strict";var Cq=te(),Rr=M(),mue=require("moment"),aS=kO(),Yf=W(),Dq=VO(),Pq=cS(),Lq=dc(),Mq=dt(),Sue=oS(),Tue=qu(),{parentPort:gue,isMainThread:Uq}=require("worker_threads"),{onMessageByType:Aue}=dt(),YO=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function Rue(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(Cq.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(Cq.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case Rr.JOB_TYPE_ENUM.csv_file_load:await Mi(e,aS.csvFileLoad);break;case Rr.JOB_TYPE_ENUM.csv_url_load:await Mi(e,aS.csvURLLoad);break;case Rr.JOB_TYPE_ENUM.csv_data_load:await Mi(e,aS.csvDataLoad);break;case Rr.JOB_TYPE_ENUM.import_from_s3:await Mi(e,aS.importFromS3);break;case Rr.JOB_TYPE_ENUM.empty_trash:break;case Rr.JOB_TYPE_ENUM.export_local:await Mi(e,Pq.export_local);break;case Rr.JOB_TYPE_ENUM.export_to_s3:await Mi(e,Pq.export_to_s3);break;case Rr.JOB_TYPE_ENUM.delete_files_before:case Rr.JOB_TYPE_ENUM.delete_records_before:await Mi(e,Lq.deleteFilesBefore);break;case Rr.JOB_TYPE_ENUM.delete_audit_logs_before:await Mi(e,Lq.deleteAuditLogsBefore);break;case Rr.JOB_TYPE_ENUM.delete_transaction_logs_before:await Mi(e,Sue.deleteTransactionLogsBefore);break;case Rr.JOB_TYPE_ENUM.restart_service:return await Mi(e,Tue.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(Rue,"parseMessage");async function Mi(e,t){try{e.job.status=Rr.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=mue().valueOf(),await Dq.updateJob(e.job),await yue(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):Yf.error(`There was an error running ${t.name} job with id ${e.job.id}`),Yf.error(n),e.job.message=n,e.job.status=Rr.JOB_STATUS_ENUM.ERROR;try{await Dq.updateJob(e.job)}catch(s){throw Yf.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(Mi,"runJob");async function yue(e){Yf.trace("launching job thread:",e),Uq?Mq.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Rr.PROCESS_NAME_ENV_PROP]:`JOB-${e}`}}):gue.postMessage({type:Rr.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(yue,"launchJobThread");Uq&&Aue(Rr.ITC_EVENT_TYPES.START_JOB,async(e,t)=>{try{Mq.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Rr.PROCESS_NAME_ENV_PROP]:`JOB-${e.jobId}`}})}catch(r){Yf.error(r)}});vq.exports={parseMessage:Rue,RunnerMessage:YO}});var xq=N((ODe,Hq)=>{"use strict";var WO=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};Hq.exports=WO});var eN=N((wDe,ZO)=>{"use strict";var fS=Vr(),QO=nS(),lS=kO(),To=tm(),uS=ro(),jf=dc(),bue=zy(),Wf=xn(),dS=lf(),Lt=tN(),_S=W(),Oue=ob(),Nue=pf(),kq=Lb(),Iue=Af(),wue=vb(),Cue=Bb(),Due=Sm(),Pue=Fb(),jO=gm(),Fq=cS(),Lue=tS(),JO=VO(),$=M(),{hdb_errors:Qf,handleHDBError:zf}=_e(),{HTTP_STATUS_CODES:Gq}=Qf,zO=Wb(),qq=qu(),Xq=require("util"),Ju=un(),Mue=us(),Uue=Cu(),$q=Bq(),Vq=fu(),Kq=(km(),oe(Bf)),Yq=wt(),Wq=oS(),jq=Ff(),{setServerUtilities:vue}=(Vf(),oe(FO)),{CONTEXT:IDe}=(Vs(),oe(_R)),{_assignPackageExport:Bue}=Ei(),{transformReq:Hue}=te(),{server:xue}=(qr(),oe(Ja)),Zr=_S.loggerWithTag("operation"),Qu=Xs(),zq=(kc(),oe(xc)),kue=OO(),Qq=fS.searchByHash,Fue=fS.searchByValue,Gue=Xq.promisify(fS.search),que=Xq.promisify(QO.evaluateSQL),$ue={[$.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=xq();async function Zq(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 kue.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return $ue[e.body.operation]&&Mue.setSchemaDataToGlobal(n=>{n&&Zr.error(n)}),r}a(Zq,"processLocalTransaction");var Jq=Kue();ZO.exports={chooseOperation:e$,getOperationFunction:t$,operation:XO,processLocalTransaction:Zq,executeJob:Rs};vue(ZO.exports);xue.operation=XO;function e$(e){let t;try{t=t$(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=QO.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=QO.checkASTPermissions(e,i);if(o)throw Zr.error(`${Gq.FORBIDDEN} from operation ${e.operation}`),Zr.warn(`User '${e.hdb_user?.username}' is not permitted to ${e.operation}`),zf(new Error,o,Qf.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=Lue.verifyPerms(i,s);if(o)throw Zr.error(`${Gq.FORBIDDEN} from operation ${e.operation}`),Zr.warn(`User '${i.hdb_user?.username}' is not permitted to ${i.operation}`),zf(new Error,o,Qf.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw zf(s,"There was an error when trying to choose an operation path")}return r}a(e$,"chooseOperation");function t$(e){if(Zr.trace(`getOperationFunction with operation: ${e.operation}`),Jq.has(e.operation))return Jq.get(e.operation);throw zf(new Error,Qf.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),Qf.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(t$,"getOperationFunction");Bue("operation",XO);function XO(e,t,r){e.hdb_user=t?.user,e.bypass_auth=!r;let n=e$(e);return Zq({body:e},n)}a(XO,"operation");async function Vue(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 Ju.insert(i);break;case $.OPERATIONS_ENUM.UPDATE:o=await Ju.update(i);break;case $.OPERATIONS_ENUM.UPSERT:o=await Ju.upsert(i);break;case $.OPERATIONS_ENUM.DELETE:o=await jf.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(Vue,"catchup");async function Rs(e){Hue(e);let t,r;try{r=await JO.addJob(e),t=r.createdJob,Zr.info("addJob result",r);let n=new $q.RunnerMessage(t,e);return{message:await $q.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),zf(n,s)}}a(Rs,"executeJob");function Kue(){let e=new Map;return e.set($.OPERATIONS_ENUM.INSERT,new J(Ju.insert)),e.set($.OPERATIONS_ENUM.UPDATE,new J(Ju.update)),e.set($.OPERATIONS_ENUM.UPSERT,new J(Ju.upsert)),e.set($.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new J(fS.searchByConditions)),e.set($.OPERATIONS_ENUM.SEARCH_BY_HASH,new J(Qq)),e.set($.OPERATIONS_ENUM.SEARCH_BY_ID,new J(Qq)),e.set($.OPERATIONS_ENUM.SEARCH_BY_VALUE,new J(Fue)),e.set($.OPERATIONS_ENUM.SEARCH,new J(Gue)),e.set($.OPERATIONS_ENUM.SQL,new J(que)),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(jf.deleteRecord)),e.set($.OPERATIONS_ENUM.ADD_USER,new J(Wf.addUser)),e.set($.OPERATIONS_ENUM.ALTER_USER,new J(Wf.alterUser)),e.set($.OPERATIONS_ENUM.DROP_USER,new J(Wf.dropUser)),e.set($.OPERATIONS_ENUM.LIST_USERS,new J(Wf.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(Wf.userInfo)),e.set($.OPERATIONS_ENUM.READ_LOG,new J(Oue)),e.set($.OPERATIONS_ENUM.ADD_NODE,new J(Nue)),e.set($.OPERATIONS_ENUM.UPDATE_NODE,new J(kq)),e.set($.OPERATIONS_ENUM.SET_NODE_REPLICATION,new J(kq)),e.set($.OPERATIONS_ENUM.REMOVE_NODE,new J(Iue)),e.set($.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new J(wue)),e.set($.OPERATIONS_ENUM.PURGE_STREAM,new J(Cue)),e.set($.OPERATIONS_ENUM.SET_CONFIGURATION,new J(Yq.setConfiguration)),e.set($.OPERATIONS_ENUM.CLUSTER_STATUS,new J(Due.clusterStatus)),e.set($.OPERATIONS_ENUM.CLUSTER_NETWORK,new J(Pue)),e.set($.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new J(jO.setRoutes)),e.set($.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new J(jO.getRoutes)),e.set($.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new J(jO.deleteRoutes)),e.set($.OPERATIONS_ENUM.EXPORT_TO_S3,new J(Rs,Fq.export_to_s3)),e.set($.OPERATIONS_ENUM.CREATE_CSR,new J(Qu.createCsr)),e.set($.OPERATIONS_ENUM.SIGN_CERTIFICATE,new J(Qu.signCertificate)),e.set($.OPERATIONS_ENUM.LIST_CERTIFICATES,new J(Qu.listCertificates)),e.set($.OPERATIONS_ENUM.ADD_CERTIFICATES,new J(Qu.addCertificate)),e.set($.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new J(Qu.removeCertificate)),e.set($.OPERATIONS_ENUM.GET_KEY,new J(Qu.getKey)),e.set($.OPERATIONS_ENUM.ADD_NODE_BACK,new J(zq.addNodeBack)),e.set($.OPERATIONS_ENUM.REMOVE_NODE_BACK,new J(zq.removeNodeBack)),e.set($.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new J(Rs,jf.deleteFilesBefore)),e.set($.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new J(Rs,jf.deleteFilesBefore)),e.set($.OPERATIONS_ENUM.EXPORT_LOCAL,new J(Rs,Fq.export_local)),e.set($.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new J(JO.handleGetJobsByStartDate)),e.set($.OPERATIONS_ENUM.GET_JOB,new J(JO.handleGetJob)),e.set($.OPERATIONS_ENUM.GET_FINGERPRINT,new J(zO.getFingerprint)),e.set($.OPERATIONS_ENUM.SET_LICENSE,new J(zO.setLicense)),e.set($.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new J(zO.getRegistrationInfo)),e.set($.OPERATIONS_ENUM.RESTART,new J(qq.restart)),e.set($.OPERATIONS_ENUM.RESTART_SERVICE,new J(Rs,qq.restartService)),e.set($.OPERATIONS_ENUM.CATCHUP,new J(Vue)),e.set($.OPERATIONS_ENUM.SYSTEM_INFORMATION,new J(Uue.systemInformation)),e.set($.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new J(Rs,jf.deleteAuditLogsBefore)),e.set($.OPERATIONS_ENUM.READ_AUDIT_LOG,new J(bue)),e.set($.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new J(Vq.createTokens)),e.set($.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new J(Vq.refreshOperationToken)),e.set($.OPERATIONS_ENUM.LOGIN,new J(Kq.login)),e.set($.OPERATIONS_ENUM.LOGOUT,new J(Kq.logout)),e.set($.OPERATIONS_ENUM.GET_CONFIGURATION,new J(Yq.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(Wq.readTransactionLog)),e.set($.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new J(Rs,Wq.deleteTransactionLogsBefore)),e.set($.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new J(jq.installModules)),e.set($.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new J(jq.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(Kue,"initializeOperationFunctionMap")});var tN=N(i$=>{"use strict";var Te=require("fs-extra"),rN=require("fast-glob"),be=require("path"),Yue=require("tar-fs"),Wue=require("gunzip-maybe"),DDe=require("uuid").v4,nN=require("normalize-path"),An=uG(),Gt=W(),ft=M(),Ft=se(),ES=wt(),jue=te(),{PACKAGE_ROOT:zue}=M(),{handleHDBError:qt,hdb_errors:Que}=_e(),{basename:Jue}=require("path"),Xue=SO(),n$=se(),Zue=M(),{Readable:ede}=require("stream"),{isMainThread:tde}=require("worker_threads"),{HDB_ERROR_MSGS:nl,HTTP_STATUS_CODES:$t}=Que,s$=dt(),{replicateOperation:si}=(ds(),oe(ca)),{packageDirectory:rde}=(IG(),oe(NG)),r$=Ff(),nde=be.join(zue,"application-template"),PDe=be.join(Ft.get(ft.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),"tmp"),sde=Ft.get(ft.CONFIG_PARAMS.ROOTPATH),Ta=be.join(sde,"ssh"),go=be.join(Ta,"known_hosts");function ide(){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,nl.FUNCTION_STATUS,$t.INTERNAL_SERVER_ERROR,Gt.ERR,t)}return e}a(ide,"customFunctionsStatus");function ode(){Gt.trace("getting custom api endpoints");let e={},t=Ft.get(ft.CONFIG_PARAMS.COMPONENTSROOT);try{rN.sync(nN(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:rN.sync(nN(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:rN.sync(nN(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw qt(new Error,nl.GET_FUNCTIONS,$t.INTERNAL_SERVER_ERROR,Gt.ERR,r)}return e}a(ode,"getCustomFunctions");function ade(e){e.project&&(e.project=be.parse(e.project).name),e.file&&(e.file=be.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=be.join(r,n,s,i+".js");try{return Te.readFileSync(o,{encoding:"utf8"})}catch(c){throw qt(new Error,nl.GET_FUNCTION,$t.INTERNAL_SERVER_ERROR,Gt.ERR,c)}}a(ade,"getCustomFunction");async function cde(e){e.project&&(e.project=be.parse(e.project).name),e.file&&(e.file=be.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(be.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,nl.SET_FUNCTION,$t.INTERNAL_SERVER_ERROR,Gt.ERR,c)}}a(cde,"setCustomFunction");async function lde(e){e.project&&(e.project=be.parse(e.project).name),e.file&&(e.file=be.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(be.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,nl.DROP_FUNCTION,$t.INTERNAL_SERVER_ERROR,Gt.ERR,o)}}a(lde,"dropCustomFunction");async function ude(e){e.project&&(e.project=be.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=be.join(r,n);Te.mkdirSync(s,{recursive:!0}),Te.copySync(nde,s);let i=await si(e);return i.message=`Successfully added project: ${n}`,i}catch(s){throw qt(new Error,nl.ADD_FUNCTION,$t.INTERNAL_SERVER_ERROR,Gt.ERR,s)}}a(ude,"addComponent");async function dde(e){e.project&&(e.project=be.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(!jue.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=be.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,nl.DROP_FUNCTION_PROJECT,$t.INTERNAL_SERVER_ERROR,Gt.ERR,i)}}a(dde,"dropCustomFunctionProject");async function _de(e){e.project&&(e.project=be.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(be.join(r,n))}catch(o){if(o.code!==ft.NODE_ERROR_CODES.ENOENT)throw o;try{s=await Te.realpath(be.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 rde(s,e)).toString("base64");return{project:n,payload:i}}a(_de,"packageComponent");async function fde(e){e.project?e.project=be.parse(e.project).name:e.package&&(e.project=Ede(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=be.join(r,n),i="file:"+c,await Te.emptyDir(c);let T=ede.from(s instanceof Buffer?s:Buffer.from(s,"base64"));await new Promise((S,y)=>{T.pipe(Wue()).pipe(Yue.extract(c,{finish:S})).on("error",y)});let m=await Te.readdir(c);m.length===1&&m[0]==="package"&&(await Te.copy(be.join(c,"package"),c),await Te.remove(be.join(c,"package")));let g=be.join(c,"node_modules");o?await r$.runCommand(o,c):Te.existsSync(g)||await r$.installAllRootModules(!1,c)}else{await ES.addConfig(n,{package:i}),await Xue();let T=n$.get(Zue.CONFIG_PARAMS.ROOTPATH);c=be.join(T,"node_modules",n)}if(tde)return;let l=new Map;l.isWorker=!0;let u=(Xf(),oe(Jf)),d;u.setErrorReporter(T=>d=T);let _=Jue(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)s$.restartWorkers("http"),h.message=`Successfully deployed: ${n}, restarting HarperDB`;else if(f){let m=await eN().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(fde,"deployComponent");function Ede(e){if(e.startsWith("git+ssh://"))return be.basename(e.split("#")[0].replace(/\.git$/,""));if(e.startsWith("http://")||e.startsWith("https://"))return be.basename(new URL(e.replace(/\.git$/,"")).pathname);if(e.startsWith("file://"))try{let{name:t}=JSON.parse(Te.readFileSync(be.join(e,"package.json"),"utf8"));return be.basename(t)}catch{}return be.basename(e)}a(Ede,"getProjectNameFromPackage");async function hde(){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=be.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:be.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(be.sep).slice(-1).pop(),entries:[]}),n=(Xf(),oe(Jf)).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(hde,"getComponents");async function pde(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"?be.join(n$.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(be.join(n,e.project,e.file));return{message:await Te.readFile(be.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 '${be.join(e.project,e.file)}'`):i}}a(pde,"getComponentFile");async function mde(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=be.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(mde,"setComponentFile");async function Sde(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?be.join(r,n):r,i=be.join(Ft.get(ft.CONFIG_PARAMS.COMPONENTSROOT),s),o=be.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=be.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?(s$.restartWorkers("http"),l.message=`Successfully dropped: ${s}, restarting HarperDB`):l.message=`Successfully dropped: ${s}`,l}a(Sde,"dropComponent");async function Tde(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=be.join(Ta,r+".key"),l=be.join(Ta,"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
28
  IdentitiesOnly yes`;await Te.pathExists(l)?await Te.appendFile(l,`
29
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(Tde,"addSSHKey");async function gde(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=be.join(Ta,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(gde,"updateSSHKey");async function Ade(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=be.join(Ta,r+".key"),s=be.join(Ta,"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(Ade,"deleteSSHKey");async function Rde(e){let t=[];return await Te.pathExists(Ta)&&(await Te.readdir(Ta)).forEach(r=>{r!="known_hosts"&&r!="config"&&t.push({name:r.split(".")[0]})}),t}a(Rde,"listSSHKeys");async function yde(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(yde,"setSSHKnownHosts");async function bde(e){return await Te.pathExists(go)?{known_hosts:await Te.readFile(go,"utf8")}:{known_hosts:null}}a(bde,"getSSHKnownHosts");Object.assign(s$,{customFunctionsStatus:ide,getCustomFunctions:ode,getCustomFunction:ade,setCustomFunction:cde,dropCustomFunction:lde,addComponent:ude,dropCustomFunctionProject:dde,packageComponent:_de,deployComponent:fde,getComponents:hde,getComponentFile:pde,setComponentFile:mde,dropComponent:Sde,addSSHKey:Tde,updateSSHKey:gde,deleteSSHKey:Ade,listSSHKeys:Rde,setSSHKnownHosts:yde,getSSHKnownHosts:bde})});var tS=N((BDe,A$)=>{"use strict";var sN=un(),hS=Vr(),ys=tm(),eE=ro(),iN=dc(),Ode=zy(),Nde=WH(),tE=xn(),pS=cf(),yr=W(),Ide=ob(),wde=hf(),Cde=Lb(),Dde=gf(),Pde=vb(),Lde=Bb(),Mde=Sm(),Ude=Fb(),oN=gm(),Ao=te(),vde=qk(),aN=Wb(),a$=qu(),en=M(),c$=jF(),Bde=Cu(),l$=fu(),u$=(km(),oe(vf)),d$=wt(),or=tN(),Hde=require("alasql"),_$=oS(),f$=kf(),Xu=Xs(),E$=(kc(),oe(xc)),h$=LO(),{handleHDBError:Rn,hdb_errors:p$}=_e(),{addNodeBack:UDe,removeNodeBack:vDe}=(kc(),oe(xc)),{HDB_ERROR_MSGS:Ur,HTTP_STATUS_CODES:Xf}=p$,z=new Map,m$="delete",ga="insert",Ro="read",sl="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},xde={insert:!0,delete:!0,deleteRecord:!0,update:!0,updateData:!0,upsert:!0,upsertData:!0},kde="catchup",Fde="handleGetJob",Gde="handleGetJobsByStartDate",mS={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},qde=[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(sN.insert.name,new Z(!1,[ga]));z.set(sN.update.name,new Z(!1,[sl]));z.set(sN.upsert.name,new Z(!1,[ga,sl]));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,[ga]));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(iN.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(Ide.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(oN.setRoutes.name,new Z(!0,[]));z.set(oN.getRoutes.name,new Z(!0,[]));z.set(oN.deleteRoutes.name,new Z(!0,[]));z.set(d$.setConfiguration.name,new Z(!0,[]));z.set(Mde.clusterStatus.name,new Z(!0,[]));z.set(Ude.name,new Z(!0,[]));z.set(aN.getFingerprint.name,new Z(!0,[]));z.set(aN.setLicense.name,new Z(!0,[]));z.set(iN.deleteFilesBefore.name,new Z(!0,[]));z.set(iN.deleteAuditLogsBefore.name,new Z(!0,[]));z.set(a$.restart.name,new Z(!0,[]));z.set(a$.restartService.name,new Z(!0,[]));z.set(Ode.name,new Z(!0,[]));z.set(Nde.name,new Z(!0,[Ro]));z.set(Bde.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(Xu.createCsr.name,new Z(!0,[]));z.set(Xu.signCertificate.name,new Z(!0,[]));z.set(Xu.listCertificates.name,new Z(!0,[]));z.set(Xu.addCertificate.name,new Z(!0,[]));z.set(Xu.removeCertificate.name,new Z(!0,[]));z.set(Xu.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(aN.getRegistrationInfo.name,new Z(!1,[]));z.set(tE.userInfo.name,new Z(!1,[]));z.set(eE.describeAll.name,new Z(!1,[]));z.set(Fde,new Z(!1,[]));z.set(Gde,new Z(!0,[]));z.set(kde,new Z(!0,[]));z.set(mS.CSV_DATA_LOAD,new Z(!1,[ga,sl]));z.set(mS.CSV_URL_LOAD,new Z(!1,[ga,sl]));z.set(mS.CSV_FILE_LOAD,new Z(!1,[ga,sl]));z.set(mS.IMPORT_FROM_S3,new Z(!1,[ga,sl]));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,[ga]));z.set(en.VALID_SQL_OPS_ENUM.UPDATE,new Z(!1,[sl]));A$.exports={verifyPerms:Vde,verifyPermsAst:$de,verifyBulkLoadAttributePerms:Yde};function $de(e,t,r){if(Ao.isEmptyOrZeroLength(e))throw yr.info("verify_perms_ast has an empty user parameter"),Rn(new Error);if(Ao.isEmptyOrZeroLength(t))throw yr.info("verify_perms_ast has an empty user parameter"),Rn(new Error);if(Ao.isEmptyOrZeroLength(r))throw yr.info("verify_perms_ast has a null operation parameter"),Rn(new Error);try{let n=new h$,s=new vde(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw yr.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 Hde.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=lN(t.role.permission,E,_[f]);cN(h,T,r,_[f],E,n)}}),n.getPermsResponse())}catch(n){throw Rn(n)}}a($de,"verifyPermsAst");function Vde(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw yr.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 yr.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&&xde[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(qde.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=Kde(e),h=lN(e.hdb_user?.role?.permission,s,i);return cN(f,h,r,i,s,c,n),c.getPermsResponse()}a(Vde,"verifyPerms");function g$(e,t,r,n,s){if(Ao.arrayHasEmptyValues([e,t,r]))throw yr.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 yr.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 yr.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)&&(yr.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 yr.error(f),yr.error(E),Rn(p$.CHECK_LOGS_WRAPPER(f))}}}return r.size<2?n.getPermsResponse():null}a(g$,"hasPermissions");function cN(e,t,r,n,s,i,o){if(!e||!t)throw yr.info("no attributes specified in checkAttributePerms."),Rn(new Error);let c=z.get(r).perms;if(!c||c==="")throw yr.info(`no permissions found for ${r} in checkAttributePerms().`),Rn(new Error);if(Ao.isEmptyOrZeroLength(t))return yr.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(cN,"checkAttributePerms");function Kde(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){yr.info(r)}return t}a(Kde,"getRecordAttributes");function lN(e,t,r){let n=new Map;if(Ao.isEmpty(e))return yr.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{yr.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(lN,"getAttributePermissions");function Yde(e,t,r,n,s,i,o){let c=new Set(i),l=lN(e,n,s);cN(c,l,t,s,n,o,r)}a(Yde,"verifyBulkLoadAttributePerms")});var nS=N((xDe,N$)=>{"use strict";N$.exports={evaluateSQL:i_e,processAST:O$,convertSQLToAST:b$,checkASTPermissions:y$};var Wde=un(),R$=require("util"),jde=R$.callbackify(Wde.insert),zde=Vr().search,Qde=Zv().update,Jde=R$.callbackify(Qde),Xde=t0().convertDelete,Aa=require("alasql"),Zde=tS(),SS=W(),e_e=Ep(),t_e=te(),rE=M(),{hdb_errors:r_e,handleHDBError:uN}=_e(),{HTTP_STATUS_CODES:dN}=r_e;e_e(Aa);var n_e=403,s_e="There was a problem performing this insert. Please check the logs and try again.",_N=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function i_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 Aa.yy.Insert?n=s.into.databaseid:s instanceof Aa.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof Aa.yy.Update||s instanceof Aa.yy.Delete?n=s.table.databaseid:SS.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof Aa.yy.Select)&&t_e.isEmptyOrZeroLength(n))return t("No schema specified",null)}O$(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(i_e,"evaluateSQL");function y$(e,t){let r;try{r=Zde.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 _N;if(!e)throw uN(new Error,"The 'sql' parameter is missing from the request body",dN.BAD_REQUEST);try{let r=e.trim(),n=Aa.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
31
- `);throw n[1]?uN(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,dN.BAD_REQUEST):uN(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",dN.BAD_REQUEST)}return t}a(b$,"convertSQLToAST");function O$(e,t,r){try{let n=o_e;if(!e.bypass_auth&&!t.permissions_checked){let i=y$(e,t);if(i&&i.length>0)return r(n_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=zde,s=t.ast.statements[0];break;case rE.VALID_SQL_OPS_ENUM.INSERT:n=a_e;break;case rE.VALID_SQL_OPS_ENUM.UPDATE:n=Jde;break;case rE.VALID_SQL_OPS_ENUM.DELETE:n=Xde;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 o_e(e,t){SS.info(e),t("unknown sql statement")}a(o_e,"nullFunction");function a_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=c_e(i,e.values)}catch(o){return r(o)}jde(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(a_e,"convertInsert");function c_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]]=Aa.compile(`SELECT ${s.toString()} AS [${rE.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw SS.error(r),new Error(s_e)}}a(c_e,"createDataObjects")});var cS=N((FDe,v$)=>{"use strict";var EN=Vr(),l_e=nS(),u_e=NO(),{AsyncParser:d_e,Transform:__e}=require("json2csv"),sE=require("stream"),jn=te(),fN=require("fs-extra"),f_e=require("path"),bs=W(),{promisify:C$}=require("util"),nE=te(),{handleHDBError:ar,hdb_errors:E_e}=_e(),{HDB_ERROR_MSGS:yn,HTTP_STATUS_CODES:cr}=E_e,{streamAsJSON:h_e}=(Ug(),oe(MD)),{Upload:p_e}=require("@aws-sdk/lib-storage"),I$=["search_by_value","search_by_hash","sql","search_by_conditions"],w$=["json","csv"],D$="json",P$="csv",m_e="Successfully exported JSON locally.",S_e="Successfully exported CSV locally.",T_e=1e3,g_e=EN.searchByHash,A_e=EN.searchByValue,R_e=C$(l_e.evaluateSQL),y_e=C$(sE.finished);v$.exports={export_to_s3:I_e,export_local:b_e,toCsvStream:L$};async function b_e(e){bs.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=M$(e);if(!jn.isEmpty(t))throw bs.error(t),ar(new Error,t,cr.BAD_REQUEST,void 0,void 0,!0);if(jn.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=(jn.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(f_e.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=jn.buildFolderPath(e.path,r);await O_e(e.path);let s=await U$(e);return await N_e(n,e.format,s)}a(b_e,"export_local");async function O_e(e){if(bs.trace("in confirmPath"),jn.isEmptyOrZeroLength(e))throw ar(new Error,`Invalid path: ${e}`,cr.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await fN.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(O_e,"confirmPath");async function N_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=fN.createWriteStream(e);return h_e(r).pipe(n),await y_e(n),{message:m_e,path:e}}else if(t===P$){let n=fN.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 d_e(i,c).fromInput(s).toOutput(n).promise(!1),{message:S_e,path:e}}throw ar(new Error,yn.INVALID_VALUE("format"),cr.BAD_REQUEST)}a(N_e,"saveToLocal");async function I_e(e){if(!e.s3||Object.keys(e.s3).length===0)throw ar(new Error,yn.MISSING_VALUE("S3 object"),cr.BAD_REQUEST);if(jn.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw ar(new Error,yn.MISSING_VALUE("aws_access_key_id"),cr.BAD_REQUEST);if(jn.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw ar(new Error,yn.MISSING_VALUE("aws_secret_access_key"),cr.BAD_REQUEST);if(jn.isEmptyOrZeroLength(e.s3.bucket))throw ar(new Error,yn.MISSING_VALUE("bucket"),cr.BAD_REQUEST);if(jn.isEmptyOrZeroLength(e.s3.key))throw ar(new Error,yn.MISSING_VALUE("key"),cr.BAD_REQUEST);if(jn.isEmptyOrZeroLength(e.s3.region))throw ar(new Error,yn.MISSING_VALUE("region"),cr.BAD_REQUEST);let t=M$(e);if(!jn.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 u_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&&_%T_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 p_e({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(I_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 __e(n,s);return r.pipe(i)}a(L$,"toCsvStream");function M$(e){if(bs.trace("in exportCoreValidation"),jn.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(jn.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=A_e;break;case"search_by_hash":t=g_e;break;case"search_by_conditions":t=EN.searchByConditions;break;case"sql":t=R_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:()=>TN,findBestSerializer:()=>AS,getDeserializer:()=>bo,registerContentHandlers:()=>gN,serialize:()=>aE,serializeMessage:()=>jc});function w_e(e){try{return e?.[0]===123?SN(e):e}catch{return e}}function gN(e){e.register(D_e,{serializers:[{regex:/^application\/json$/,serializer:Xd},{regex:/^application\/cbor$/,serializer:a(function(t){return new il.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,Ui.encodeIter)(t,oE)):(0,Ui.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,Ui.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,il.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}),mN.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 jc(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 P_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 M_e(e){return L_e.includes(e)}function U_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=U_e(e),n=r.type&&tn.get(r.type)?.deserialize||v_e(r);return t?s=>P_e(s).then(n):n}function v_e(e){return e.type.startsWith("text/")?(e.parameters?.charset&&!M_e(e.parameters.charset)&&mN.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 SN(t)}catch{}return{contentType:e.type||"application/octet-stream",data:t}}}function B_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,Ui,il,yo,x$,gS,k$,hN,pN,F$,mN,G$,iE,SN,oE,tn,TN,B$,q$,C_e,D_e,H$,L_e,zc=Ie(()=>{Ug();TS=L(cS()),Ui=require("msgpackr"),il=require("cbor-x"),yo=require("zlib"),x$=L(_e()),gS=require("stream");qr();k$=L(Ei()),hN=L(se()),pN=L(M()),F$=L(require("yaml")),mN=L(Oc()),G$=hN.default.get(pN.CONFIG_PARAMS.SERIALIZATION_BIGINT)!==!1,iE=G$?ec:JSON.stringify,SN=G$?Mg:JSON.parse,oE={useRecords:!1,useToJSON:!0},tn=new Map,TN=tn;it.contentTypes=TN;(0,k$._assignPackageExport)("contentTypes",TN);tn.set("application/json",{serializeStream:Xd,serialize:iE,deserialize(e){return SN(e)},q:.8});B$=new il.Encoder(oE);tn.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new il.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,Ui.encodeIter)(e,oE)):(0,Ui.pack)(e)},serialize:Ui.pack,deserialize:Ui.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(B_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+`
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(Tde,"addSSHKey");async function gde(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=be.join(Ta,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(gde,"updateSSHKey");async function Ade(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=be.join(Ta,r+".key"),s=be.join(Ta,"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(Ade,"deleteSSHKey");async function Rde(e){let t=[];return await Te.pathExists(Ta)&&(await Te.readdir(Ta)).forEach(r=>{r!="known_hosts"&&r!="config"&&t.push({name:r.split(".")[0]})}),t}a(Rde,"listSSHKeys");async function yde(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(yde,"setSSHKnownHosts");async function bde(e){return await Te.pathExists(go)?{known_hosts:await Te.readFile(go,"utf8")}:{known_hosts:null}}a(bde,"getSSHKnownHosts");Object.assign(i$,{customFunctionsStatus:ide,getCustomFunctions:ode,getCustomFunction:ade,setCustomFunction:cde,dropCustomFunction:lde,addComponent:ude,dropCustomFunctionProject:dde,packageComponent:_de,deployComponent:fde,getComponents:hde,getComponentFile:pde,setComponentFile:mde,dropComponent:Sde,addSSHKey:Tde,updateSSHKey:gde,deleteSSHKey:Ade,listSSHKeys:Rde,setSSHKnownHosts:yde,getSSHKnownHosts:bde})});var tS=N((BDe,R$)=>{"use strict";var sN=un(),hS=Vr(),ys=tm(),tE=ro(),iN=dc(),Ode=zy(),Nde=jH(),rE=xn(),pS=lf(),yr=W(),Ide=ob(),wde=pf(),Cde=Lb(),Dde=Af(),Pde=vb(),Lde=Bb(),Mde=Sm(),Ude=Fb(),oN=gm(),Ao=te(),vde=$k(),aN=Wb(),c$=qu(),en=M(),l$=zF(),Bde=Cu(),u$=fu(),d$=(km(),oe(Bf)),_$=wt(),or=tN(),Hde=require("alasql"),f$=oS(),E$=Ff(),Xu=Xs(),h$=(kc(),oe(xc)),p$=LO(),{handleHDBError:Rn,hdb_errors:m$}=_e(),{addNodeBack:UDe,removeNodeBack:vDe}=(kc(),oe(xc)),{HDB_ERROR_MSGS:Ur,HTTP_STATUS_CODES:Zf}=m$,z=new Map,S$="delete",ga="insert",Ro="read",sl="update",eE="describe",o$=tE.describeSchema.name,a$=tE.describeTable.name,T$={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},xde={insert:!0,delete:!0,deleteRecord:!0,update:!0,updateData:!0,upsert:!0,upsertData:!0},kde="catchup",Fde="handleGetJob",Gde="handleGetJobsByStartDate",mS={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},qde=[ys.createTable.name,ys.createAttribute.name,ys.dropTable.name,ys.dropAttribute.name],g$={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(sN.insert.name,new Z(!1,[ga]));z.set(sN.update.name,new Z(!1,[sl]));z.set(sN.upsert.name,new Z(!1,[ga,sl]));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,[ga]));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(tE.describeSchema.name,new Z(!1,[Ro]));z.set(tE.describeTable.name,new Z(!1,[Ro]));z.set(iN.deleteRecord.name,new Z(!1,[S$]));z.set(rE.addUser.name,new Z(!0,[]));z.set(rE.alterUser.name,new Z(!0,[]));z.set(rE.dropUser.name,new Z(!0,[]));z.set(rE.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(Ide.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(oN.setRoutes.name,new Z(!0,[]));z.set(oN.getRoutes.name,new Z(!0,[]));z.set(oN.deleteRoutes.name,new Z(!0,[]));z.set(_$.setConfiguration.name,new Z(!0,[]));z.set(Mde.clusterStatus.name,new Z(!0,[]));z.set(Ude.name,new Z(!0,[]));z.set(aN.getFingerprint.name,new Z(!0,[]));z.set(aN.setLicense.name,new Z(!0,[]));z.set(iN.deleteFilesBefore.name,new Z(!0,[]));z.set(iN.deleteAuditLogsBefore.name,new Z(!0,[]));z.set(c$.restart.name,new Z(!0,[]));z.set(c$.restartService.name,new Z(!0,[]));z.set(Ode.name,new Z(!0,[]));z.set(Nde.name,new Z(!0,[Ro]));z.set(Bde.systemInformation.name,new Z(!0,[]));z.set(_$.getConfiguration.name,new Z(!0,[]));z.set(f$.readTransactionLog.name,new Z(!0,[]));z.set(f$.deleteTransactionLogsBefore.name,new Z(!0,[]));z.set(E$.installModules.name,new Z(!0,[]));z.set(E$.auditModules.name,new Z(!0,[]));z.set(Xu.createCsr.name,new Z(!0,[]));z.set(Xu.signCertificate.name,new Z(!0,[]));z.set(Xu.listCertificates.name,new Z(!0,[]));z.set(Xu.addCertificate.name,new Z(!0,[]));z.set(Xu.removeCertificate.name,new Z(!0,[]));z.set(Xu.getKey.name,new Z(!0,[]));z.set(h$.addNodeBack.name,new Z(!0,[]));z.set(h$.removeNodeBack.name,new Z(!0,[]));z.set(u$.createTokens.name,new Z(!1,[]));z.set(u$.refreshOperationToken.name,new Z(!1,[]));z.set(d$.login.name,new Z(!1,[]));z.set(d$.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(aN.getRegistrationInfo.name,new Z(!1,[]));z.set(rE.userInfo.name,new Z(!1,[]));z.set(tE.describeAll.name,new Z(!1,[]));z.set(Fde,new Z(!1,[]));z.set(Gde,new Z(!0,[]));z.set(kde,new Z(!0,[]));z.set(mS.CSV_DATA_LOAD,new Z(!1,[ga,sl]));z.set(mS.CSV_URL_LOAD,new Z(!1,[ga,sl]));z.set(mS.CSV_FILE_LOAD,new Z(!1,[ga,sl]));z.set(mS.IMPORT_FROM_S3,new Z(!1,[ga,sl]));z.set(g$.EXPORT_TO_S3,new Z(!0,[]));z.set(g$.EXPORT_LOCAL,new Z(!0,[]));z.set(en.VALID_SQL_OPS_ENUM.DELETE,new Z(!1,[S$]));z.set(en.VALID_SQL_OPS_ENUM.SELECT,new Z(!1,[Ro]));z.set(en.VALID_SQL_OPS_ENUM.INSERT,new Z(!1,[ga]));z.set(en.VALID_SQL_OPS_ENUM.UPDATE,new Z(!1,[sl]));R$.exports={verifyPerms:Vde,verifyPermsAst:$de,verifyBulkLoadAttributePerms:Yde};function $de(e,t,r){if(Ao.isEmptyOrZeroLength(e))throw yr.info("verify_perms_ast has an empty user parameter"),Rn(new Error);if(Ao.isEmptyOrZeroLength(t))throw yr.info("verify_perms_ast has an empty user parameter"),Rn(new Error);if(Ao.isEmptyOrZeroLength(r))throw yr.info("verify_perms_ast has a null operation parameter"),Rn(new Error);try{let n=new p$,s=new vde(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw yr.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&&T$[r])throw Rn(new Error,Ur.DROP_SYSTEM,Zf.FORBIDDEN);if(c&&!l)return null;let u=l$.getRolePermissions(t.role);t.role.permission=u,!c&&e instanceof Hde.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(u));for(let _=0;_<i.length;_++){let E=s.getTablesBySchemaName(i[_]);E&&o.set(i[_],E)}let d=A$(t,r,o,n);return d||(o.forEach((_,E)=>{for(let f=0;f<_.length;f++){let h=s.getAttributesBySchemaTableName(E,_[f]),T=lN(t.role.permission,E,_[f]);cN(h,T,r,_[f],E,n)}}),n.getPermsResponse())}catch(n){throw Rn(n)}}a($de,"verifyPermsAst");function Vde(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw yr.info("null required parameter in verifyPerms"),Rn(new Error,Ur.DEFAULT_INVALID_REQUEST,Zf.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 p$;if(Ao.isEmptyOrZeroLength(e.hdb_user?.role)||Ao.isEmptyOrZeroLength(e.hdb_user?.role?.permission))return yr.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&&xde[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&&T$[r])throw Rn(new Error,Ur.DROP_SYSTEM,Zf.FORBIDDEN);if(l&&!d||u===!0&&(r===ys.createSchema.name||r===ys.dropSchema.name))return null;if(qde.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 _=l$.getRolePermissions(e.hdb_user?.role);if(e.hdb_user?.role&&(e.hdb_user.role.permission=_),r===o$||r===a$){if(s===en.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(Ur.SCHEMA_PERM_ERROR(s));if(!_.super_user){if(r===o$&&(!_[s]||!_[s][eE]))return c.handleInvalidItem(Ur.SCHEMA_NOT_FOUND(s));if(r===a$&&(!_[s]||!_[s].tables[i]||!_[s].tables[i][eE]))return c.handleInvalidItem(Ur.TABLE_NOT_FOUND(s,i))}}let E=A$(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=Kde(e),h=lN(e.hdb_user?.role?.permission,s,i);return cN(f,h,r,i,s,c,n),c.getPermsResponse()}a(Vde,"verifyPerms");function A$(e,t,r,n,s){if(Ao.arrayHasEmptyValues([e,t,r]))throw yr.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 yr.info(`operation ${t} not found.`),Rn(new Error,Ur.OP_NOT_FOUND(t),Zf.BAD_REQUEST);if(z.get(t)&&z.get(t).requires_su)return yr.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][eE]===!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(!_||_[eE]===!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)&&(yr.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 yr.error(f),yr.error(E),Rn(m$.CHECK_LOGS_WRAPPER(f))}}}return r.size<2?n.getPermsResponse():null}a(A$,"hasPermissions");function cN(e,t,r,n,s,i,o){if(!e||!t)throw yr.info("no attributes specified in checkAttributePerms."),Rn(new Error);let c=z.get(r).perms;if(!c||c==="")throw yr.info(`no permissions found for ${r} in checkAttributePerms().`),Rn(new Error);if(Ao.isEmptyOrZeroLength(t))return yr.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(_[eE]===!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,Zf.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(cN,"checkAttributePerms");function Kde(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){yr.info(r)}return t}a(Kde,"getRecordAttributes");function lN(e,t,r){let n=new Map;if(Ao.isEmpty(e))return yr.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{yr.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(lN,"getAttributePermissions");function Yde(e,t,r,n,s,i,o){let c=new Set(i),l=lN(e,n,s);cN(c,l,t,s,n,o,r)}a(Yde,"verifyBulkLoadAttributePerms")});var nS=N((xDe,I$)=>{"use strict";I$.exports={evaluateSQL:i_e,processAST:N$,convertSQLToAST:O$,checkASTPermissions:b$};var Wde=un(),y$=require("util"),jde=y$.callbackify(Wde.insert),zde=Vr().search,Qde=e0().update,Jde=y$.callbackify(Qde),Xde=r0().convertDelete,Aa=require("alasql"),Zde=tS(),SS=W(),e_e=Ep(),t_e=te(),nE=M(),{hdb_errors:r_e,handleHDBError:uN}=_e(),{HTTP_STATUS_CODES:dN}=r_e;e_e(Aa);var n_e=403,s_e="There was a problem performing this insert. Please check the logs and try again.",_N=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function i_e(e,t){let r=e.parsed_sql_object;if(!r){r=O$(e.sql);let n,s=r.ast.statements[0];if(s instanceof Aa.yy.Insert?n=s.into.databaseid:s instanceof Aa.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof Aa.yy.Update||s instanceof Aa.yy.Delete?n=s.table.databaseid:SS.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof Aa.yy.Select)&&t_e.isEmptyOrZeroLength(n))return t("No schema specified",null)}N$(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(i_e,"evaluateSQL");function b$(e,t){let r;try{r=Zde.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(b$,"checkASTPermissions");function O$(e){let t=new _N;if(!e)throw uN(new Error,"The 'sql' parameter is missing from the request body",dN.BAD_REQUEST);try{let r=e.trim(),n=Aa.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
31
+ `);throw n[1]?uN(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,dN.BAD_REQUEST):uN(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",dN.BAD_REQUEST)}return t}a(O$,"convertSQLToAST");function N$(e,t,r){try{let n=o_e;if(!e.bypass_auth&&!t.permissions_checked){let i=b$(e,t);if(i&&i.length>0)return r(n_e,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case nE.VALID_SQL_OPS_ENUM.SELECT:n=zde,s=t.ast.statements[0];break;case nE.VALID_SQL_OPS_ENUM.INSERT:n=a_e;break;case nE.VALID_SQL_OPS_ENUM.UPDATE:n=Jde;break;case nE.VALID_SQL_OPS_ENUM.DELETE:n=Xde;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(N$,"processAST");function o_e(e,t){SS.info(e),t("unknown sql statement")}a(o_e,"nullFunction");function a_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=c_e(i,e.values)}catch(o){return r(o)}jde(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(a_e,"convertInsert");function c_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]]=Aa.compile(`SELECT ${s.toString()} AS [${nE.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw SS.error(r),new Error(s_e)}}a(c_e,"createDataObjects")});var cS=N((FDe,B$)=>{"use strict";var EN=Vr(),l_e=nS(),u_e=NO(),{AsyncParser:d_e,Transform:__e}=require("json2csv"),iE=require("stream"),jn=te(),fN=require("fs-extra"),f_e=require("path"),bs=W(),{promisify:D$}=require("util"),sE=te(),{handleHDBError:ar,hdb_errors:E_e}=_e(),{HDB_ERROR_MSGS:yn,HTTP_STATUS_CODES:cr}=E_e,{streamAsJSON:h_e}=(Ug(),oe(UD)),{Upload:p_e}=require("@aws-sdk/lib-storage"),w$=["search_by_value","search_by_hash","sql","search_by_conditions"],C$=["json","csv"],P$="json",L$="csv",m_e="Successfully exported JSON locally.",S_e="Successfully exported CSV locally.",T_e=1e3,g_e=EN.searchByHash,A_e=EN.searchByValue,R_e=D$(l_e.evaluateSQL),y_e=D$(iE.finished);B$.exports={export_to_s3:I_e,export_local:b_e,toCsvStream:M$};async function b_e(e){bs.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=U$(e);if(!jn.isEmpty(t))throw bs.error(t),ar(new Error,t,cr.BAD_REQUEST,void 0,void 0,!0);if(jn.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=(jn.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(f_e.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=jn.buildFolderPath(e.path,r);await O_e(e.path);let s=await v$(e);return await N_e(n,e.format,s)}a(b_e,"export_local");async function O_e(e){if(bs.trace("in confirmPath"),jn.isEmptyOrZeroLength(e))throw ar(new Error,`Invalid path: ${e}`,cr.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await fN.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(O_e,"confirmPath");async function N_e(e,t,r){if(bs.trace("in saveToLocal"),sE.isEmptyOrZeroLength(e))throw ar(new Error,yn.INVALID_VALUE("file_path"),cr.BAD_REQUEST,void 0,void 0,!0);if(sE.isEmptyOrZeroLength(t))throw ar(new Error,yn.INVALID_VALUE("Source format"),cr.BAD_REQUEST,void 0,void 0,!0);if(sE.isEmpty(r))throw ar(new Error,yn.NOT_FOUND("Data"),cr.BAD_REQUEST,void 0,void 0,!0);if(t===P$){let n=fN.createWriteStream(e);return h_e(r).pipe(n),await y_e(n),{message:m_e,path:e}}else if(t===L$){let n=fN.createWriteStream(e),s=iE.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(d=>({label:d,value:d})));let c={objectMode:!0};return await new d_e(i,c).fromInput(s).toOutput(n).promise(!1),{message:S_e,path:e}}throw ar(new Error,yn.INVALID_VALUE("format"),cr.BAD_REQUEST)}a(N_e,"saveToLocal");async function I_e(e){if(!e.s3||Object.keys(e.s3).length===0)throw ar(new Error,yn.MISSING_VALUE("S3 object"),cr.BAD_REQUEST);if(jn.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw ar(new Error,yn.MISSING_VALUE("aws_access_key_id"),cr.BAD_REQUEST);if(jn.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw ar(new Error,yn.MISSING_VALUE("aws_secret_access_key"),cr.BAD_REQUEST);if(jn.isEmptyOrZeroLength(e.s3.bucket))throw ar(new Error,yn.MISSING_VALUE("bucket"),cr.BAD_REQUEST);if(jn.isEmptyOrZeroLength(e.s3.key))throw ar(new Error,yn.MISSING_VALUE("key"),cr.BAD_REQUEST);if(jn.isEmptyOrZeroLength(e.s3.region))throw ar(new Error,yn.MISSING_VALUE("region"),cr.BAD_REQUEST);let t=U$(e);if(!jn.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 v$(e)}catch(l){throw bs.error(l),l}let n,s=await u_e.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new iE.PassThrough;if(e.format===L$){i=e.s3.key+".csv";let l=M$(r,r.getColumns?.());l.on("error",u=>{throw u}),l.pipe(o)}else if(e.format===P$){i=e.s3.key+".json";let l=new iE.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&&_%T_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 p_e({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(I_e,"export_to_s3");function M$(e,t){let r=iE.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 __e(n,s);return r.pipe(i)}a(M$,"toCsvStream");function U$(e){if(bs.trace("in exportCoreValidation"),jn.isEmpty(e.format))return"format missing";if(C$.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${C$.join(", ")}`;let t=e.search_operation.operation;if(jn.isEmpty(t))return"search_operation.operation missing";if(w$.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${w$.join(", ")}`}a(U$,"exportCoreValidation");async function v$(e){bs.trace("in getRecords");let t,r;if(sE.isEmpty(e.search_operation)||sE.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=A_e;break;case"search_by_hash":t=g_e;break;case"search_by_conditions":t=EN.searchByConditions;break;case"sql":t=R_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(v$,"getRecords")});var V$={};je(V$,{contentTypes:()=>TN,findBestSerializer:()=>AS,getDeserializer:()=>bo,registerContentHandlers:()=>gN,serialize:()=>cE,serializeMessage:()=>jc});function w_e(e){try{return e?.[0]===123?SN(e):e}catch{return e}}function gN(e){e.register(D_e,{serializers:[{regex:/^application\/json$/,serializer:Zd},{regex:/^application\/cbor$/,serializer:a(function(t){return new il.EncoderStream(aE).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,Ui.encodeIter)(t,aE)):(0,Ui.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,Ui.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,il.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 k$.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 cE(e,t,r){let n=x$&&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}),mN.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>x$?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,yo.brotliCompress)(s,(c,l)=>{c?o(c):i(l)}))):s}function jc(e,t){if(e?.contentType!=null&&e.data!=null)return e.data;if(!t)return oE(e);let r=t.serialize;if(r)return r(e);let n=AS(t);return r=t.serialize=n.serializer.serialize,r(e)}function P_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 M_e(e){return L_e.includes(e)}function U_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=U_e(e),n=r.type&&tn.get(r.type)?.deserialize||v_e(r);return t?s=>P_e(s).then(n):n}function v_e(e){return e.type.startsWith("text/")?(e.parameters?.charset&&!M_e(e.parameters.charset)&&mN.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 SN(t)}catch{}return{contentType:e.type||"application/octet-stream",data:t}}}function B_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,Ui,il,yo,k$,gS,F$,hN,pN,G$,mN,q$,oE,SN,aE,tn,TN,H$,$$,C_e,D_e,x$,L_e,zc=Ie(()=>{Ug();TS=L(cS()),Ui=require("msgpackr"),il=require("cbor-x"),yo=require("zlib"),k$=L(_e()),gS=require("stream");qr();F$=L(Ei()),hN=L(se()),pN=L(M()),G$=L(require("yaml")),mN=L(Oc()),q$=hN.default.get(pN.CONFIG_PARAMS.SERIALIZATION_BIGINT)!==!1,oE=q$?ec:JSON.stringify,SN=q$?Mg:JSON.parse,aE={useRecords:!1,useToJSON:!0},tn=new Map,TN=tn;it.contentTypes=TN;(0,F$._assignPackageExport)("contentTypes",TN);tn.set("application/json",{serializeStream:Zd,serialize:oE,deserialize(e){return SN(e)},q:.8});H$=new il.Encoder(aE);tn.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new il.EncoderStream(aE).end(e)},serialize:H$.encode,deserialize:H$.decode,q:1});tn.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?gS.Readable.from((0,Ui.encodeIter)(e,aE)):(0,Ui.pack)(e)},serialize:Ui.pack,deserialize:Ui.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 G$.stringify(e,{aliasDuplicateObjects:!1})},q:.7});tn.set("text/event-stream",{serializeStream:a(function(e){return gS.Readable.from(B_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=oE(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: ${iE(e)}
36
+ `}else return typeof e=="object"?`data: ${oE(e)}
37
37
 
38
38
  `:`data: ${e}
39
39
 
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:Xd,serialize:iE,deserialize:w_e,q:.5};tn.set("*/*",q$);tn.set("",q$);a(w_e,"tryJSONParse");a(gN,"registerContentHandlers");C_e=require("fastify-plugin"),D_e=C_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$=hN.default.get(pN.CONFIG_PARAMS.HTTP_COMPRESSIONTHRESHOLD);a(aE,"serialize");a(jc,"serializeMessage");a(P_e,"streamToBuffer");L_e=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(M_e,"isBufferEncoding");a(U_e,"parseContentType");a(bo,"getDeserializer");a(v_e,"deserializerUnknownType");a(B_e,"transformIterable")});var RN={};je(RN,{start:()=>K_e});function H_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 vi("Request body must be an object.");if(!("query"in e))throw new vi("Request body must contain a `query` field.");if(typeof e.query!="string")throw new vi("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new vi("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new vi("Request body `operationName` field must be a string.")}function AN(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 x_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:AN(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=>x_e(n,t,r))}function k_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:AN(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 F_e(e,t){return e.flatMap(r=>k_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 G_e(e,t,r,n){let i=Ci.getMatch(e.name.value,"graphql").Resource,o={select:J$(e.selectionSet,r),conditions:F_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 AN(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 q_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 $_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=q_e(e.variableDefinitions,t),i=await Promise.all(RS(e.selectionSet,r).map(c=>G_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(H_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 $_e(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function V_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 vi("Method Not Allowed",405,{Allow:"GET, POST"})}}function K_e(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await V_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 vi)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 vi)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,vi,Z$=Ie(()=>{Le=L(require("graphql"));zc();su();a(H_e,"assertExecutableDefinitionNode");a(V$,"assertRequestParams");a(AN,"processIntValueNode");a(Y$,"processFloatValueNode");a(W$,"processVariableNode");a(j$,"isObject");a(z$,"transformObjectIntoQueryCondition");a(x_e,"processObjectFieldNode");a(Q$,"processObjectValueNode");a(k_e,"processArgumentNode");a(F_e,"buildConditionsQuery");a(RS,"fillInFragments");a(J$,"buildSelectQuery");a(G_e,"processFieldNode");a(X$,"processConstValueNode");a(q_e,"resolveVariables");a($_e,"executeOperation");a(K$,"resolver");vr=class extends Error{static{a(this,"GraphQLQueryingError")}},vi=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a(V_e,"graphqlQueryingHandler");a(K_e,"start")});var yN={};je(yN,{start:()=>rV,startOnMainThread:()=>j_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(Y_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 W_e(i)}}}async function W_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,Y_e,j_e,nV=Ie(()=>{Pe();yS=L(cf()),eV=require("yaml"),tV=require("lodash"),Y_e=["super_user","cluster_user","structure_user"];a(rV,"start");a(W_e,"ensureRole");j_e=rV});async function bS(e){let t=(0,oV.pathToFileURL)(e).toString();return z_e?(cE||(cE=Q_e(X_e)),(await(await cE).import(t)).namespace):import(t)}async function Q_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:J_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:zn,databases:We})}};let n=await(0,sV.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),cE}function J_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 X_e(){return{Resource:Lr,tables:zn}}var sV,iV,oV,z_e,cE,bN=Ie(()=>{Vs();Pe();sV=require("fs/promises"),iV=require("path"),oV=require("url"),z_e=!1;a(bS,"secureImport");a(Q_e,"getCompartment");a(J_e,"secureOnlyFetch");a(X_e,"getGlobalVars")});var NN={};je(NN,{handleFile:()=>Z_e});async function Z_e(e,t,r,n){let s=new Map,i=await bS(r);c(i.default)&&n.set((0,ON.dirname)(t),i.default),o(i,(0,ON.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 ON,aV=Ie(()=>{bN();ON=require("path");a(Z_e,"handleFile")});var wN={};je(wN,{start:()=>efe});function efe({resources:e}){e.set("login",IN),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var IN,cV=Ie(()=>{Vs();a(efe,"start");IN=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 DN(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?DN(_.conditions,_.operator,r,n,s,i,o,c):td(_,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",y=d(h.conditions,!S,f);return S?(I,U)=>y.some(H=>H(I,U)):(I,U)=>y.every(H=>H(I,U))}let m=(h.attribute||h[0])===r.primaryKey,g=dE(h,r,i,c,m,f);return E&&T<_.length-1&&f&&(f=lfe(r.primaryStore,h.estimated_count,f)),g}).filter(Boolean)}a(d,"mapConditionsToFilters")}function td(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],y=Hi(n.attributes,S);if(y.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=y.definition?.tableClass||y.elements?.definition?.tableClass,U=new Map,H=td({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,I,s,U);if(y.relationship.to){i[o[0]]=U;let X=!!Hi(I.attributes,y.relationship.to)?.elements;H=ife(H,y,I.primaryStore,X,U)}if(y.relationship.from){let X=a(Y=>(Y?.key!==void 0&&(Y=Y.key),td({attribute:y.relationship.from,value:Y},t,r,n,s,U)),"searchEntry");y.elements?(i[o[0]]=U,H=ofe(H,y,I.primaryStore,U,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(PN[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]=Bi.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:y,value:I}){return this?.isSync?I&&h(I)?y:Ra.SKIP:new Promise((U,H)=>setImmediate(()=>{try{U(I&&h(I)?y:Ra.SKIP)}catch(X){H(X)}}))}:y=>y.value==null&&!(y.metadataFlags&(Ns|ba))?Ra.SKIP:y);return S.hasEntries=!0,S}else return m?m.getRange(g).map(h?function({key:S,value:y}){let I;return typeof S=="string"&&S.length>Os.MAX_SEARCH_KEY_LENGTH?I=n.primaryStore.get(y):I={[o]:S},this.isSync?h(I)?y:Ra.SKIP:new Promise((U,H)=>setImmediate(()=>{try{U(h(I)?y: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:y}){return this.isSync?y&&h(y)?S:Ra.SKIP:new Promise((I,U)=>setImmediate(()=>{try{I(y&&h(y)?S:Ra.SKIP)}catch(H){U(H)}}))})}function Hi(e,t){if(Array.isArray(t))if(t.length>1){let r=Hi(e,t[0]),n=(r?.definition?.tableClass||r?.elements?.definition?.tableClass)?.attributes??r?.properties;return n?Hi(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 ife(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 ofe(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],_=Hi(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,y)=>{let I,U;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}U=T(S,r,y),I=U?.value}else I=S[d];return I?Array.isArray(I)?I.some(h):h(I,U):!1},"recordFilter");return g}}switch(l instanceof Date&&(l=l.getTime()),PN[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,Bi.compareKeys)(d,l[0])>=0&&(0,Bi.compareKeys)(d,l[1])<=0,!0);case"gt":return u(c,d=>(0,Bi.compareKeys)(d,l)>0);case"ge":return u(c,d=>(0,Bi.compareKeys)(d,l)>=0);case"lt":return u(c,d=>(0,Bi.compareKeys)(d,l)<0);case"le":return u(c,d=>(0,Bi.compareKeys)(d,l)<=0);case"ne":return u(c,d=>(0,Bi.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 y=S[d],I;if(typeof y!="object"||!y||f?I=_(y):Array.isArray(y)?I=y.some(_):y instanceof Date&&(I=_(y.getTime())),E&&(m++,!I&&!g.idFilter&&++T/m*(i-m)>h)){let U=td(e,r.transaction.getReadTxn(),!1,t).map(rd),H=new Set(U);g.idFilter=X=>H.has(rd(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=PN[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=Hi(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=nfe*Oo(e.primaryStore)+1:n==="between"?r.estimated_count=rfe*Oo(e.primaryStore)+1:n==="sort"?r.estimated_count=Oo(e.primaryStore)+1:r.estimated_count=tfe*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(ya=e,Zu.lastIndex=0,afe.test(e))try{let t=lE(new ed,"");if(bn!==ya.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 '${ya}'`,t}else return new URLSearchParams(e)}function lE(e,t){let r=Zu,n,s,i,o,c,l=decodeURIComponent,u;for(;n=r.exec(ya);){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=sfe[_],l=CN[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"(":Zu.lastIndex=bn;let f=lE(d?[]:new ed,")");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}`)}ya[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");Zu.lastIndex=bn,E=lE([],"}"),E.name=d,e.push(E),ya[bn]===","?r.lastIndex=++bn:o=!0;break;case"[":Zu.lastIndex=bn,d?(E=lE(new ed,"]"),E.name=d):E=lE(e.conditions?new ed:[],"]"),e.conditions?(OS(e,u),e.conditions.push(E),s=null):e.push(E),ya[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?cfe:Zu,r.lastIndex=bn),bn===ya.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 rd(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 lfe(e,t,r){return t*r/Oo(e)}var On,Os,Bi,Ra,tfe,rfe,nfe,sfe,CN,PN,afe,Zu,cfe,bn,ya,ed,ol,_E=Ie(()=>{On=L(_e()),Os=L(Ht()),Bi=require("ordered-binary"),Ra=require("lmdb");$f();tfe=.3,rfe=.1,nfe=.05,sfe={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},CN={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(DN,"executeConditions");a(td,"searchByIndex");a(Hi,"findAttribute");a(ife,"joinTo");a(ofe,"joinFrom");PN={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");afe=/[()[\]|!<>.]|(=\w*=)/,Zu=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,cfe=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/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");ed=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(rd,"flattenKey");a(Oo,"estimatedEntryCount");a(lfe,"intersectionEstimate");ol=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});function mV(e){let t={openapi:ufe,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:y,name:I,elements:U,relationship:H,definition:X}of o){if(H)y==="array"?u[I]={type:"array",items:{$ref:Oa+U.type}}:u[I]={$ref:Oa+y};else{let Y=X??U?.definition;if(Y){if(!t.components.schemas[Y.type]){let V={};Y.properties.forEach(ne=>{V[ne.name]=new vN(LN[ne.type],ne.type)}),t.components.schemas[Y.type]=new hV(V)}y==="array"?u[I]={type:"array",items:{$ref:Oa+Y.type}}:u[I]={$ref:Oa+Y.type}}else y==="array"?U.type==="Any"||U.type=="ID"?u[I]={type:"array",items:{format:U.type}}:u[I]={type:"array",items:new vN(LN[U.type],U.type)}:y==="Any"||y=="ID"?u[I]={format:y}:u[I]=new vN(LN[y],y)}d.push(new BN(I,"query",u[I]))}let _=Object.keys(u),E=new BN(c,"path",{format:"ID"});E.required=!0,E.description="primary key of record";let f=new BN("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 dfe(i,r,"create a new record auto-assigning a primary key")),m&&(t.paths[S]||(t.paths[S]={}),t.paths[S].get=new MN(d,r,{200:new UN({$ref:Oa+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 MN([E],r,{200:new UN({$ref:Oa+i})},"retrieve a record by its primary key")),T&&(t.paths[S]||(t.paths[S]={}),t.paths[S].put=new _fe([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 MN([E,f],r,{200:new UN({enum:_})},"used to retrieve the specified property of the specified record"))}return t}function dfe(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:Oa+e}}}},this.security=t,this.responses={200:{description:HN,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function MN(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function UN(e){this.description=HN,this.content={"application/json":{schema:e}}}function fV(){this.description="successfully processed request, no content returned to client"}function _fe(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:Oa+r}}}},this.responses={200:{description:HN}}}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 vN(e,t){this.type=e,this.format=t}function BN(e,t,r){this.name=e,this.in=t,this.schema=r}var pV,ufe,LN,Oa,HN,SV=Ie(()=>{pV=L(Bc()),ufe="3.0.3",LN={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},Oa="#/components/schemas/",HN="successful operation";a(mV,"generateJsonApi");a(dfe,"Post");a(MN,"Get");a(UN,"Response200");a(fV,"Response204");a(_fe,"Put");a(EV,"Delete");a(hV,"ResourceSchema");a(vN,"Type");a(BN,"Parameter")});var CS={};je(CS,{parseHeaderValue:()=>kN,start:()=>hfe});async function Efe(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 ol(m.relativeURL),c.async=!0,l=m.Resource}if(l?.isCaching){let m=r["cache-control"];if(m){let g=kN(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=kN(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 nd.ClientError(m,400)}if(e.authorize=!0,o===TV&&s==="GET"){if(e?.user?.role?.permission?.super_user)return mV(wS);throw new nd.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 nd.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new nd.ServerError(`Method ${s} is not recognized`,501)}}),E=200,f;if(_==null)E=s==="GET"||s==="HEAD"?404:204,xN.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){ffe[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),xN.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?xi.warn(o):xi.info(o):xi.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 hfe(e){xN=e,!gV&&(gV=!0,wS=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return Efe(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{fE++;let s=new Mn;AV||(AV=!0,x_(l=>{fE>0&&l.push({metric:"ws-connections",connections:fE,byThread:!0})}));let i;t.on("error",l=>{i=!0,xi.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 ol(u.relativeURL),_=u.Resource;c=(await Dt(r,()=>_.connect(d,s,r)))[Symbol.asyncIterator]();let f;for(;!(f=await c.next()).done;){let h=jc(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?xi.warn(l):xi.info(l):xi.error(l),t.close(pfe[l.statusCode]||1011,l.toString())}t.close()},e))}function kN(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 xi,nd,Br,ffe,xN,TV,gV,wS,AV,fE,pfe,RV=Ie(()=>{zc();Ii();xi=L(W()),nd=L(_e());_E();Ll();Sc();Uf();SV();_E();Br=new Uint8Array(8),ffe=new Float64Array(Br.buffer,0,1),xN={},TV="openapi";a(Efe,"http");fE=0;a(hfe,"start");pfe={401:3e3,403:3003};a(kN,"parseHeaderValue")});var FN=N((TPe,bV)=>{var{recordAction:DS,recordActionBinary:yV}=(Ii(),oe(k_)),mfe=require("fastify-plugin"),Sfe=200;bV.exports=mfe(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=Sfe;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((gPe,IV)=>{"use strict";var GN=M(),Tfe=te(),EE=W(),{handleHDBError:qN,hdb_errors:PS}=_e(),{isMainThread:gfe}=require("worker_threads"),{Readable:Afe}=require("stream"),OV=require("os"),Rfe=require("util"),yfe=cb(),bfe=Rfe.promisify(yfe.authorize),NV=eN(),{createGzip:Ofe,constants:Nfe}=require("zlib");function Ife(e){let t=`Found an uncaught exception with message: ${e.message}. ${OV.EOL}Stack: ${e.stack} ${OV.EOL}Terminating ${gfe?"HDB":"thread"}.`;console.error(t),EE.fatal(t),process.exit(1)}a(Ife,"handleServerUncaughtException");function wfe(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(wfe,"serverErrorHandler");function Cfe(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(Tfe.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(Cfe,"reqBodyValidationHandler");function Dfe(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?bfe(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(Dfe,"authHandler");async function Pfe(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 Afe&&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(Ofe({level:Nfe.Z_BEST_SPEED})))}return s}catch(s){throw EE.error(s),s}}a(Pfe,"handlePostRequest");IV.exports={authHandler:Dfe,handlePostRequest:Pfe,handleServerUncaughtException:Ife,serverErrorHandler:wfe,reqBodyValidationHandler:Cfe}});var PV=N((RPe,DV)=>{"use strict";var Lfe=require("fastify-plugin"),{handlePostRequest:wV,authHandler:Mfe,reqBodyValidationHandler:Ufe}=LS();async function vfe(e){e.decorate("hdbCore",{preValidation:[Ufe,Mfe],request:a(t=>CV(wV(t,response)),"request"),requestWithoutAuthentication:a((t,r)=>CV(wV(t,r,!0)),"requestWithoutAuthentication")})}a(vfe,"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=Lfe(vfe)});var MV=N((OPe,LV)=>{"use strict";var bPe=require("fs"),MS=se();MS.initSync();var{CONFIG_PARAMS:$N}=M(),Bfe=1024*1024*1024;function Hfe(e){let t=MS.get($N.HTTP_TIMEOUT),r=MS.get($N.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:Bfe,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,maxParamLength:MS.get($N.HTTP_MAXPARAMLENGTH)??1e3,https:e}}a(Hfe,"getServerOptions");LV.exports=Hfe});var BV=N((IPe,vV)=>{"use strict";var VN=se();VN.initSync();var{CONFIG_PARAMS:UV}=M();function xfe(){let e=VN.get(UV.HTTP_CORSACCESSLIST),t=VN.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(xfe,"getCORSOptions");vV.exports=xfe});var kV=N((CPe,xV)=>{"use strict";var HV=se();HV.initSync();var kfe=M();function Ffe(){return HV.get(kfe.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(Ffe,"getHeaderTimeoutConfig");xV.exports=Ffe});var YN={};je(YN,{customFunctionsServer:()=>$fe,ready:()=>e1,start:()=>qfe});function qfe(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,KN.dirname)(s),l=(0,KN.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!FV.has(c)){FV.add(c);try{o.register(Kfe(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 $fe(){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 Vfe();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 Vfe(){try{mt.info("Custom Functions starting configuration."),await jV.setUsersToGlobal(),mt.info("Custom Functions completed configuration.")}catch(e){mt.error(e)}}function Kfe(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(Gfe),await r.after(),gN(r),mt.info("Custom Functions completed buildServer."),r}function e1(){if(No)return No.then?No.then(e=>e.ready()):No.ready()}var KN,GV,qV,$V,VV,KV,YV,WV,mt,Gfe,jV,zV,QV,JV,XV,No,FV,t1=Ie(()=>{KN=require("path"),GV=require("fs"),qV=L(require("fastify")),$V=L(require("@fastify/cors")),VV=L(FN()),KV=L(require("@fastify/autoload")),YV=L(se()),WV=L(M()),mt=L(W()),Gfe=L(PV()),jV=L(xn()),zV=L(MV()),QV=L(BV()),JV=L(kV()),XV=L(LS());zc();qr();FV=new Set;a(qfe,"start");a($fe,"customFunctionsServer");a(Vfe,"setUp");a(Kfe,"buildRouteFolder");a(ZV,"buildServer");a(e1,"ready")});var WN={};je(WN,{start:()=>Yfe});function Yfe(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(Yfe,"start")});var JN={};je(JN,{Request:()=>jN,createReuseportFd:()=>US});var c1,jN,zN,QN,US,vS=Ie(()=>{c1=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,c1.platform)()!="win32"&&(US=require("node-unix-socket").createReuseportFd)});var ZN=N((BPe,l1)=>{"use strict";var hE=se();hE.initSync();var sd=require("fs-extra"),XN=require("path"),id=M(),Wfe=require("crypto"),jfe=require("uuid").v4;l1.exports=zfe;function zfe(){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=jfe(),i=Wfe.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(zfe,"checkJWTTokenExist")});var d1=N((xPe,u1)=>{"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}};u1.exports={HdbInfoInsertObject:eI}});var E1=N((FPe,f1)=>{"use strict";var _1=M(),tI=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:tI}});var BS=N((qPe,p1)=>{"use strict";var Is=require("prompt"),od=require("chalk"),h1=W(),ii=require("os"),rI=ja(),nI=["yes","y"];async function Qfe(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 h1.error("There was an error when prompting user about an upgrade."),h1.error(s),!1}return nI.includes(n.CONFIRM_UPGRADE)}a(Qfe,"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 Xfe(){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(Xfe,"upgradeCertsPrompt");p1.exports={forceUpdatePrompt:Qfe,forceDowngradePrompt:Jfe,upgradeCertsPrompt:Xfe}});var iI=N((VPe,m1)=>{"use strict";var sI=class{static{a(this,"UpgradeDirective")}constructor(t){this.version=t,this.sync_functions=[],this.async_functions=[]}};m1.exports=sI});var T1=N((QPe,S1)=>{"use strict";var Zfe=te(),eEe=wt(),YPe=W(),WPe=require("path"),jPe=require("fs"),zPe=M();S1.exports={getOldPropsValue:tEe};function tEe(e,t,r=!1){let n=t.getRaw(e);return Zfe.isNotEmptyAndHasValue(n)?n:r?eEe.getDefaultConfig(e):""}a(tEe,"getOldPropsValue")});var y1=N((XPe,R1)=>{"use strict";var Na=require("path"),Ia=require("fs-extra"),rEe=require("properties-reader"),nEe=iI(),lr=W(),{getOldPropsValue:St}=T1(),{HDB_SETTINGS_NAMES:he,CONFIG_PARAMS:al}=M(),cl=wt(),HS=se(),g1=te(),ki=M(),oI=new nEe("3.1.0"),A1=[];function sEe(){let e=rEe(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()}});$$={type:"application/json",serializeStream:Zd,serialize:oE,deserialize:w_e,q:.5};tn.set("*/*",$$);tn.set("",$$);a(w_e,"tryJSONParse");a(gN,"registerContentHandlers");C_e=require("fastify-plugin"),D_e=C_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");x$=hN.default.get(pN.CONFIG_PARAMS.HTTP_COMPRESSIONTHRESHOLD);a(cE,"serialize");a(jc,"serializeMessage");a(P_e,"streamToBuffer");L_e=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(M_e,"isBufferEncoding");a(U_e,"parseContentType");a(bo,"getDeserializer");a(v_e,"deserializerUnknownType");a(B_e,"transformIterable")});var RN={};je(RN,{start:()=>K_e});function H_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 K$(e){if(typeof e!="object"||e===null)throw new vi("Request body must be an object.");if(!("query"in e))throw new vi("Request body must contain a `query` field.");if(typeof e.query!="string")throw new vi("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new vi("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new vi("Request body `operationName` field must be a string.")}function AN(e){return parseInt(e.value,10)}function W$(e){return parseFloat(e.value)}function j$(e,t,r){let n=r.get(e.name.value);return z$(n)?Q$(n,t):{attribute:t,value:n}}function z$(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function Q$(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],z$(n)?Q$(n,t):{attribute:t,value:n}))}function x_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:AN(e.value)};case Le.Kind.FLOAT:return{attribute:t,value:W$(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:t,value:e.value.value};case Le.Kind.VARIABLE:return j$(e.value,t,r);case Le.Kind.OBJECT:return J$(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 J$(e,t,r){return e.fields.flatMap(n=>x_e(n,t,r))}function k_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:AN(e.value)};case Le.Kind.FLOAT:return{attribute:e.name.value,value:W$(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Le.Kind.VARIABLE:return j$(e.value,e.name.value,t);case Le.Kind.OBJECT:return J$(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 F_e(e,t){return e.flatMap(r=>k_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 X$(e,t){return RS(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:X$(r.selectionSet,t)}:r.name.value)}async function G_e(e,t,r,n){let i=Ci.getMatch(e.name.value,"graphql").Resource,o={select:X$(e.selectionSet,r),conditions:F_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 Z$(e){switch(e.kind){case Le.Kind.NULL:return null;case Le.Kind.INT:return AN(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]:Z$(r.value),...t}),{});case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new vr(`Value type, ${e.kind}, is not supported.`)}}function q_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=Z$(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 $_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=q_e(e.variableDefinitions,t),i=await Promise.all(RS(e.selectionSet,r).map(c=>G_e(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function Y$({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(H_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 $_e(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function V_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 K$(r),Y$(r,e)}case"POST":{let r=await bo(e.headers.get("content-type"),!0)(e._nodeRequest);return K$(r),Y$(r,e)}default:throw new vi("Method Not Allowed",405,{Allow:"GET, POST"})}}function K_e(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await V_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 vi)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 vi)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,vi,eV=Ie(()=>{Le=L(require("graphql"));zc();su();a(H_e,"assertExecutableDefinitionNode");a(K$,"assertRequestParams");a(AN,"processIntValueNode");a(W$,"processFloatValueNode");a(j$,"processVariableNode");a(z$,"isObject");a(Q$,"transformObjectIntoQueryCondition");a(x_e,"processObjectFieldNode");a(J$,"processObjectValueNode");a(k_e,"processArgumentNode");a(F_e,"buildConditionsQuery");a(RS,"fillInFragments");a(X$,"buildSelectQuery");a(G_e,"processFieldNode");a(Z$,"processConstValueNode");a(q_e,"resolveVariables");a($_e,"executeOperation");a(Y$,"resolver");vr=class extends Error{static{a(this,"GraphQLQueryingError")}},vi=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a(V_e,"graphqlQueryingHandler");a(K_e,"start")});var yN={};je(yN,{start:()=>nV,startOnMainThread:()=>j_e});function nV({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,tV.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(Y_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 W_e(i)}}}async function W_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,rV.isEqual)(i,e)?void 0:(e.id=r.id,(0,yS.alterRole)(e))}return(0,yS.addRole)(e)}var yS,tV,rV,Y_e,j_e,sV=Ie(()=>{Pe();yS=L(lf()),tV=require("yaml"),rV=require("lodash"),Y_e=["super_user","cluster_user","structure_user"];a(nV,"start");a(W_e,"ensureRole");j_e=nV});async function bS(e){let t=(0,aV.pathToFileURL)(e).toString();return z_e?(lE||(lE=Q_e(X_e)),(await(await lE).import(t)).namespace):import(t)}async function Q_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"}),lE=new Compartment({console,Math,Date,fetch:J_e,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,oV.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:zn,databases:We})}};let n=await(0,iV.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),lE}function J_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 X_e(){return{Resource:Lr,tables:zn}}var iV,oV,aV,z_e,lE,bN=Ie(()=>{Vs();Pe();iV=require("fs/promises"),oV=require("path"),aV=require("url"),z_e=!1;a(bS,"secureImport");a(Q_e,"getCompartment");a(J_e,"secureOnlyFetch");a(X_e,"getGlobalVars")});var NN={};je(NN,{handleFile:()=>Z_e});async function Z_e(e,t,r,n){let s=new Map,i=await bS(r);c(i.default)&&n.set((0,ON.dirname)(t),i.default),o(i,(0,ON.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 ON,cV=Ie(()=>{bN();ON=require("path");a(Z_e,"handleFile")});var wN={};je(wN,{start:()=>efe});function efe({resources:e}){e.set("login",IN),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var IN,lV=Ie(()=>{Vs();a(efe,"start");IN=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 DN(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?DN(_.conditions,_.operator,r,n,s,i,o,c):td(_,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",y=d(h.conditions,!S,f);return S?(I,U)=>y.some(H=>H(I,U)):(I,U)=>y.every(H=>H(I,U))}let m=(h.attribute||h[0])===r.primaryKey,g=_E(h,r,i,c,m,f);return E&&T<_.length-1&&f&&(f=lfe(r.primaryStore,h.estimated_count,f)),g}).filter(Boolean)}a(d,"mapConditionsToFilters")}function td(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],y=Hi(n.attributes,S);if(y.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=y.definition?.tableClass||y.elements?.definition?.tableClass,U=new Map,H=td({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,I,s,U);if(y.relationship.to){i[o[0]]=U;let X=!!Hi(I.attributes,y.relationship.to)?.elements;H=ife(H,y,I.primaryStore,X,U)}if(y.relationship.from){let X=a(Y=>(Y?.key!==void 0&&(Y=Y.key),td({attribute:y.relationship.from,value:Y},t,r,n,s,U)),"searchEntry");y.elements?(i[o[0]]=U,H=ofe(H,y,I.primaryStore,U,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(PN[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]=Bi.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=_E(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??_E(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??_E(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:y,value:I}){return this?.isSync?I&&h(I)?y:Ra.SKIP:new Promise((U,H)=>setImmediate(()=>{try{U(I&&h(I)?y:Ra.SKIP)}catch(X){H(X)}}))}:y=>y.value==null&&!(y.metadataFlags&(Ns|ba))?Ra.SKIP:y);return S.hasEntries=!0,S}else return m?m.getRange(g).map(h?function({key:S,value:y}){let I;return typeof S=="string"&&S.length>Os.MAX_SEARCH_KEY_LENGTH?I=n.primaryStore.get(y):I={[o]:S},this.isSync?h(I)?y:Ra.SKIP:new Promise((U,H)=>setImmediate(()=>{try{U(h(I)?y: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:y}){return this.isSync?y&&h(y)?S:Ra.SKIP:new Promise((I,U)=>setImmediate(()=>{try{I(y&&h(y)?S:Ra.SKIP)}catch(H){U(H)}}))})}function Hi(e,t){if(Array.isArray(t))if(t.length>1){let r=Hi(e,t[0]),n=(r?.definition?.tableClass||r?.elements?.definition?.tableClass)?.attributes??r?.properties;return n?Hi(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 ife(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 ofe(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 _E(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],_=Hi(t.attributes,d),E=_.definition?.tableClass||_.elements.definition?.tableClass,f=n?.[d],h=_E({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,y)=>{let I,U;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}U=T(S,r,y),I=U?.value}else I=S[d];return I?Array.isArray(I)?I.some(h):h(I,U):!1},"recordFilter");return g}}switch(l instanceof Date&&(l=l.getTime()),PN[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,Bi.compareKeys)(d,l[0])>=0&&(0,Bi.compareKeys)(d,l[1])<=0,!0);case"gt":return u(c,d=>(0,Bi.compareKeys)(d,l)>0);case"ge":return u(c,d=>(0,Bi.compareKeys)(d,l)>=0);case"lt":return u(c,d=>(0,Bi.compareKeys)(d,l)<0);case"le":return u(c,d=>(0,Bi.compareKeys)(d,l)<=0);case"ne":return u(c,d=>(0,Bi.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 y=S[d],I;if(typeof y!="object"||!y||f?I=_(y):Array.isArray(y)?I=y.some(_):y instanceof Date&&(I=_(y.getTime())),E&&(m++,!I&&!g.idFilter&&++T/m*(i-m)>h)){let U=td(e,r.transaction.getReadTxn(),!1,t).map(rd),H=new Set(U);g.idFilter=X=>H.has(rd(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=PN[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=Hi(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=nfe*Oo(e.primaryStore)+1:n==="between"?r.estimated_count=rfe*Oo(e.primaryStore)+1:n==="sort"?r.estimated_count=Oo(e.primaryStore)+1:r.estimated_count=tfe*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(ya=e,Zu.lastIndex=0,afe.test(e))try{let t=uE(new ed,"");if(bn!==ya.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 '${ya}'`,t}else return new URLSearchParams(e)}function uE(e,t){let r=Zu,n,s,i,o,c,l=decodeURIComponent,u;for(;n=r.exec(ya);){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=uV}else{if(l=decodeURIComponent,i="equals",!d)throw new SyntaxError("attribute must be specified before equality comparator");s=dE(d)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=sfe[_],l=CN[i]?uV:decodeURIComponent,!d)throw new SyntaxError(`attribute must be specified before comparator ${_}`);s=dE(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"&&dV(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(dE(d)),s=void 0;break;case"(":Zu.lastIndex=bn;let f=uE(d?[]:new ed,")");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=_V(f);break;default:throw new SyntaxError(`unknown query function call ${d}`)}ya[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");Zu.lastIndex=bn,E=uE([],"}"),E.name=d,e.push(E),ya[bn]===","?r.lastIndex=++bn:o=!0;break;case"[":Zu.lastIndex=bn,d?(E=uE(new ed,"]"),E.name=d):E=uE(e.conditions?new ed:[],"]"),e.conditions?(OS(e,u),e.conditions.push(E),s=null):e.push(E),ya[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"&&dV(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(dE(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?cfe:Zu,r.lastIndex=bn),bn===ya.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 dE(e){return e.indexOf(".")>-1?e.split(".").map(dE):decodeURIComponent(e)}function uV(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 dV(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 _V(e){let t=fV(e[0]);return e.length>1&&(t.next=_V(e.slice(1))),t}function fV(e){if(Array.isArray(e)){let t=fV(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 rd(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 lfe(e,t,r){return t*r/Oo(e)}var On,Os,Bi,Ra,tfe,rfe,nfe,sfe,CN,PN,afe,Zu,cfe,bn,ya,ed,ol,fE=Ie(()=>{On=L(_e()),Os=L(Ht()),Bi=require("ordered-binary"),Ra=require("lmdb");Vf();tfe=.3,rfe=.1,nfe=.05,sfe={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},CN={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(DN,"executeConditions");a(td,"searchByIndex");a(Hi,"findAttribute");a(ife,"joinTo");a(ofe,"joinFrom");PN={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(_E,"filterByType");a(NS,"estimateCondition");afe=/[()[\]|!<>.]|(=\w*=)/,Zu=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,cfe=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(IS,"parseQuery");a(uE,"parseBlock");a(OS,"assignOperator");a(dE,"decodeProperty");a(uV,"typedDecoding");a(dV,"wildcardDecoding");a(_V,"toSortObject");a(fV,"toSortEntry");ed=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(rd,"flattenKey");a(Oo,"estimatedEntryCount");a(lfe,"intersectionEstimate");ol=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});function SV(e){let t={openapi:ufe,info:{title:"HarperDB HTTP REST interface",version:(0,mV.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:y,name:I,elements:U,relationship:H,definition:X}of o){if(H)y==="array"?u[I]={type:"array",items:{$ref:Oa+U.type}}:u[I]={$ref:Oa+y};else{let Y=X??U?.definition;if(Y){if(!t.components.schemas[Y.type]){let V={};Y.properties.forEach(ne=>{V[ne.name]=new vN(LN[ne.type],ne.type)}),t.components.schemas[Y.type]=new pV(V)}y==="array"?u[I]={type:"array",items:{$ref:Oa+Y.type}}:u[I]={$ref:Oa+Y.type}}else y==="array"?U.type==="Any"||U.type=="ID"?u[I]={type:"array",items:{format:U.type}}:u[I]={type:"array",items:new vN(LN[U.type],U.type)}:y==="Any"||y=="ID"?u[I]={format:y}:u[I]=new vN(LN[y],y)}d.push(new BN(I,"query",u[I]))}let _=Object.keys(u),E=new BN(c,"path",{format:"ID"});E.required=!0,E.description="primary key of record";let f=new BN("property","path",{enum:_});f.required=!0,t.components.schemas[i]=new pV(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 dfe(i,r,"create a new record auto-assigning a primary key")),m&&(t.paths[S]||(t.paths[S]={}),t.paths[S].get=new MN(d,r,{200:new UN({$ref:Oa+i})},"search for records by the specified property name and value pairs")),g&&(t.paths[S]||(t.paths[S]={}),t.paths[S].delete=new hV(d,r,"delete all the records that match the provided query",{204:new EV})),S="/"+s+"/{"+c+"}",m&&(t.paths[S]={},t.paths[S].get=new MN([E],r,{200:new UN({$ref:Oa+i})},"retrieve a record by its primary key")),T&&(t.paths[S]||(t.paths[S]={}),t.paths[S].put=new _fe([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 hV([E],r,"delete a record with the given primary key",{204:new EV})),m&&f.schema.enum.length>0&&(S="/"+s+"/{"+c+"}.{property}",t.paths[S]={},t.paths[S].get=new MN([E,f],r,{200:new UN({enum:_})},"used to retrieve the specified property of the specified record"))}return t}function dfe(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:Oa+e}}}},this.security=t,this.responses={200:{description:HN,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function MN(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function UN(e){this.description=HN,this.content={"application/json":{schema:e}}}function EV(){this.description="successfully processed request, no content returned to client"}function _fe(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:Oa+r}}}},this.responses={200:{description:HN}}}function hV(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function pV(e){this.type="object",this.properties=e}function vN(e,t){this.type=e,this.format=t}function BN(e,t,r){this.name=e,this.in=t,this.schema=r}var mV,ufe,LN,Oa,HN,TV=Ie(()=>{mV=L(Bc()),ufe="3.0.3",LN={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},Oa="#/components/schemas/",HN="successful operation";a(SV,"generateJsonApi");a(dfe,"Post");a(MN,"Get");a(UN,"Response200");a(EV,"Response204");a(_fe,"Put");a(hV,"Delete");a(pV,"ResourceSchema");a(vN,"Type");a(BN,"Parameter")});var CS={};je(CS,{parseHeaderValue:()=>kN,start:()=>hfe});async function Efe(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!==gV){let m=wS.getMatch(o,n?"sse":"rest");if(!m)return t(e);e.handlerPath=m.path,c=new ol(m.relativeURL),c.async=!0,l=m.Resource}if(l?.isCaching){let m=r["cache-control"];if(m){let g=kN(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=kN(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 nd.ClientError(m,400)}if(e.authorize=!0,o===gV&&s==="GET"){if(e?.user?.role?.permission?.super_user)return SV(wS);throw new nd.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 nd.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new nd.ServerError(`Method ${s} is not recognized`,501)}}),E=200,f;if(_==null)E=s==="GET"||s==="HEAD"?404:204,xN.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=cE(_.data,e,_)),_}else if(f=e.lastModified){ffe[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),xN.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=cE(_,e,h),s==="HEAD"&&(h.body=void 0)),h}catch(o){o.statusCode?o.statusCode===500?xi.warn(o):xi.info(o):xi.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=cE(o.contentType?o:o.toString(),e,c),c}}function hfe(e){xN=e,!AV&&(AV=!0,wS=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return Efe(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{EE++;let s=new Mn;RV||(RV=!0,k_(l=>{EE>0&&l.push({metric:"ws-connections",connections:EE,byThread:!0})}));let i;t.on("error",l=>{i=!0,xi.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",()=>{EE--,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:EE}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let d=new ol(u.relativeURL),_=u.Resource;c=(await Dt(r,()=>_.connect(d,s,r)))[Symbol.asyncIterator]();let f;for(;!(f=await c.next()).done;){let h=jc(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?xi.warn(l):xi.info(l):xi.error(l),t.close(pfe[l.statusCode]||1011,l.toString())}t.close()},e))}function kN(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 xi,nd,Br,ffe,xN,gV,AV,wS,RV,EE,pfe,yV=Ie(()=>{zc();Ii();xi=L(W()),nd=L(_e());fE();Ll();Sc();vf();TV();fE();Br=new Uint8Array(8),ffe=new Float64Array(Br.buffer,0,1),xN={},gV="openapi";a(Efe,"http");EE=0;a(hfe,"start");pfe={401:3e3,403:3003};a(kN,"parseHeaderValue")});var FN=N((TPe,OV)=>{var{recordAction:DS,recordActionBinary:bV}=(Ii(),oe(F_)),mfe=require("fastify-plugin"),Sfe=200;OV.exports=mfe(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),bV(s.raw.statusCode<400,"success",u,_,d),bV(1,"response_"+s.raw.statusCode,u,_,d);let E=Sfe;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((gPe,wV)=>{"use strict";var GN=M(),Tfe=te(),hE=W(),{handleHDBError:qN,hdb_errors:PS}=_e(),{isMainThread:gfe}=require("worker_threads"),{Readable:Afe}=require("stream"),NV=require("os"),Rfe=require("util"),yfe=cb(),bfe=Rfe.promisify(yfe.authorize),IV=eN(),{createGzip:Ofe,constants:Nfe}=require("zlib");function Ife(e){let t=`Found an uncaught exception with message: ${e.message}. ${NV.EOL}Stack: ${e.stack} ${NV.EOL}Terminating ${gfe?"HDB":"thread"}.`;console.error(t),hE.fatal(t),process.exit(1)}a(Ife,"handleServerUncaughtException");function wfe(e,t,r){if(hE[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(wfe,"serverErrorHandler");function Cfe(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(Tfe.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(Cfe,"reqBodyValidationHandler");function Dfe(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?bfe(e,t).then(s=>{n=s,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(s=>{hE.warn(s),hE.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(Dfe,"authHandler");async function Pfe(e,t,r=!1){let n;try{e.body.bypass_auth&&delete e.body.bypass_auth,n=IV.chooseOperation(e.body);let s=await IV.processLocalTransaction(e,n);if(s instanceof Afe&&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(Ofe({level:Nfe.Z_BEST_SPEED})))}return s}catch(s){throw hE.error(s),s}}a(Pfe,"handlePostRequest");wV.exports={authHandler:Dfe,handlePostRequest:Pfe,handleServerUncaughtException:Ife,serverErrorHandler:wfe,reqBodyValidationHandler:Cfe}});var LV=N((RPe,PV)=>{"use strict";var Lfe=require("fastify-plugin"),{handlePostRequest:CV,authHandler:Mfe,reqBodyValidationHandler:Ufe}=LS();async function vfe(e){e.decorate("hdbCore",{preValidation:[Ufe,Mfe],request:a(t=>DV(CV(t,response)),"request"),requestWithoutAuthentication:a((t,r)=>DV(CV(t,r,!0)),"requestWithoutAuthentication")})}a(vfe,"hdbCore");async function DV(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(DV,"convertAsyncIterators");PV.exports=Lfe(vfe)});var UV=N((OPe,MV)=>{"use strict";var bPe=require("fs"),MS=se();MS.initSync();var{CONFIG_PARAMS:$N}=M(),Bfe=1024*1024*1024;function Hfe(e){let t=MS.get($N.HTTP_TIMEOUT),r=MS.get($N.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:Bfe,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,maxParamLength:MS.get($N.HTTP_MAXPARAMLENGTH)??1e3,https:e}}a(Hfe,"getServerOptions");MV.exports=Hfe});var HV=N((IPe,BV)=>{"use strict";var VN=se();VN.initSync();var{CONFIG_PARAMS:vV}=M();function xfe(){let e=VN.get(vV.HTTP_CORSACCESSLIST),t=VN.get(vV.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(xfe,"getCORSOptions");BV.exports=xfe});var FV=N((CPe,kV)=>{"use strict";var xV=se();xV.initSync();var kfe=M();function Ffe(){return xV.get(kfe.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(Ffe,"getHeaderTimeoutConfig");kV.exports=Ffe});var YN={};je(YN,{customFunctionsServer:()=>$fe,ready:()=>t1,start:()=>qfe});function qfe(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){No||(No=e1(t),it.http((await No).server));let o=await No,c=(0,KN.dirname)(s),l=(0,KN.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!GV.has(c)){GV.add(c);try{o.register(Kfe(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:t1}}async function $fe(){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 Vfe();let e=WV.get(jV.CONFIG_PARAMS.HTTP_SECUREPORT)>0,t;try{t=No=await e1(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 Vfe(){try{mt.info("Custom Functions starting configuration."),await zV.setUsersToGlobal(),mt.info("Custom Functions completed configuration.")}catch(e){mt.error(e)}}function Kfe(e,t){return async function(r){try{mt.info("Custom Functions starting buildRoutes"),mt.trace("Loading fastify routes folder "+e),(0,qV.existsSync)(e)&&r.register(YV.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 e1(e){mt.info("Custom Functions starting buildServer.");let t=(0,QV.default)(e),r=(0,$V.default)(t);r.server.headersTimeout=(0,XV.default)(),r.setErrorHandler(ZV.serverErrorHandler);let n=(0,JV.default)();return n&&r.register(VV.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,l){r.server.emit("unhandled",c.raw,l.raw)}),o()}),r.register(KV.default),await r.register(Gfe),await r.after(),gN(r),mt.info("Custom Functions completed buildServer."),r}function t1(){if(No)return No.then?No.then(e=>e.ready()):No.ready()}var KN,qV,$V,VV,KV,YV,WV,jV,mt,Gfe,zV,QV,JV,XV,ZV,No,GV,r1=Ie(()=>{KN=require("path"),qV=require("fs"),$V=L(require("fastify")),VV=L(require("@fastify/cors")),KV=L(FN()),YV=L(require("@fastify/autoload")),WV=L(se()),jV=L(M()),mt=L(W()),Gfe=L(LV()),zV=L(xn()),QV=L(UV()),JV=L(HV()),XV=L(FV()),ZV=L(LS());zc();qr();GV=new Set;a(qfe,"start");a($fe,"customFunctionsServer");a(Vfe,"setUp");a(Kfe,"buildRouteFolder");a(e1,"buildServer");a(t1,"ready")});var WN={};je(WN,{start:()=>Yfe});function Yfe(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,a1.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){s1||(s1=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=n1.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,i1.default)(s,(0,o1.realpathSync)(o))}}return i(s)},{runFirst:!0})),n1.set(r,n)}}}var i1,o1,a1,n1,s1,c1=Ie(()=>{i1=L(require("send")),o1=require("fs"),a1=L(require("serve-static")),n1=new Map;a(Yfe,"start")});var JN={};je(JN,{Request:()=>jN,createReuseportFd:()=>US});var l1,jN,zN,QN,US,vS=Ie(()=>{l1=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,l1.platform)()!="win32"&&(US=require("node-unix-socket").createReuseportFd)});var ZN=N((BPe,u1)=>{"use strict";var pE=se();pE.initSync();var sd=require("fs-extra"),XN=require("path"),id=M(),Wfe=require("crypto"),jfe=require("uuid").v4;u1.exports=zfe;function zfe(){if(pE.getHdbBasePath()!==void 0){let e=XN.join(pE.getHdbBasePath(),id.LICENSE_KEY_DIR_NAME,id.JWT_ENUM.JWT_PRIVATE_KEY_NAME),t=XN.join(pE.getHdbBasePath(),id.LICENSE_KEY_DIR_NAME,id.JWT_ENUM.JWT_PUBLIC_KEY_NAME),r=XN.join(pE.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=jfe(),i=Wfe.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(zfe,"checkJWTTokenExist")});var _1=N((xPe,d1)=>{"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}};d1.exports={HdbInfoInsertObject:eI}});var h1=N((FPe,E1)=>{"use strict";var f1=M(),tI=class{static{a(this,"UpgradeObject")}constructor(t,r){this[f1.UPGRADE_JSON_FIELD_NAMES_ENUM.DATA_VERSION]=t,this[f1.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION]=r}};E1.exports={UpgradeObject:tI}});var BS=N((qPe,m1)=>{"use strict";var Is=require("prompt"),od=require("chalk"),p1=W(),ii=require("os"),rI=ja(),nI=["yes","y"];async function Qfe(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 p1.error("There was an error when prompting user about an upgrade."),p1.error(s),!1}return nI.includes(n.CONFIRM_UPGRADE)}a(Qfe,"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 Xfe(){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(Xfe,"upgradeCertsPrompt");m1.exports={forceUpdatePrompt:Qfe,forceDowngradePrompt:Jfe,upgradeCertsPrompt:Xfe}});var iI=N((VPe,S1)=>{"use strict";var sI=class{static{a(this,"UpgradeDirective")}constructor(t){this.version=t,this.sync_functions=[],this.async_functions=[]}};S1.exports=sI});var g1=N((QPe,T1)=>{"use strict";var Zfe=te(),eEe=wt(),YPe=W(),WPe=require("path"),jPe=require("fs"),zPe=M();T1.exports={getOldPropsValue:tEe};function tEe(e,t,r=!1){let n=t.getRaw(e);return Zfe.isNotEmptyAndHasValue(n)?n:r?eEe.getDefaultConfig(e):""}a(tEe,"getOldPropsValue")});var b1=N((XPe,y1)=>{"use strict";var Na=require("path"),Ia=require("fs-extra"),rEe=require("properties-reader"),nEe=iI(),lr=W(),{getOldPropsValue:St}=g1(),{HDB_SETTINGS_NAMES:he,CONFIG_PARAMS:al}=M(),cl=wt(),HS=se(),A1=te(),ki=M(),oI=new nEe("3.1.0"),R1=[];function sEe(){let e=rEe(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)}
@@ -106,11 +106,11 @@ ${he.CUSTOM_FUNCTIONS_PORT_KEY} = ${cl.getDefaultConfig(al.HTTP_PORT)}
106
106
  ${he.CUSTOM_FUNCTIONS_DIRECTORY_KEY} = ${Na.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
108
  ${he.MAX_CUSTOM_FUNCTION_PROCESSES} = ${cl.getDefaultConfig(al.HTTP_THREADS)}
109
- `,n=HS.get("settings_path"),s=Na.dirname(n),i=Na.join(s,"3_1_0_upgrade_settings.bak");try{lr.info(`Backing up old settings file to: ${i}`),Ia.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}'`),Ia.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),Ia.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(sEe,"updateSettingsFile_3_1_0");function iEe(){let e=Na.join(g1.getHomeDir(),ki.HDB_HOME_DIR_NAME,ki.LICENSE_KEY_DIR_NAME,ki.LICENSE_FILE_NAME),t=Na.join(g1.getHomeDir(),ki.HDB_HOME_DIR_NAME,ki.LICENSE_KEY_DIR_NAME,ki.REG_KEY_FILE_NAME),r=Na.join(HS.getHdbBasePath(),ki.LICENSE_KEY_DIR_NAME,ki.LICENSE_FILE_NAME),n=Na.join(r,ki.LICENSE_FILE_NAME),s=Na.join(r,ki.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),Ia.mkdirpSync(r);try{Ia.accessSync(e);try{let c="Moving licence file";console.log(c),lr.info(c),Ia.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{Ia.accessSync(t);try{let c="Moving registration file";console.log(c),lr.info(c),Ia.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(iEe,"moveLicenseFiles");oI.sync_functions.push(sEe);oI.sync_functions.push(iEe);A1.push(oI);R1.exports=A1});var w1=N((eLe,I1)=>{"use strict";var Qn=ht(),{insertRecords:oEe}=ic(),aEe=cn(),wa=Ht(),cEe=te(),Io=W(),lEe=te(),Fi=require("fs-extra"),wo=require("path"),uEe=require("cli-progress"),pE=require("assert"),dEe=require("pino"),_Ee=se();I1.exports=fEe;var xS,b1,kS,aI,rn,mE=!1;async function fEe(e=!0){return xS=_Ee.getHdbBasePath(),b1=wo.join(xS,"schema"),kS=wo.join(xS,"4_0_0_upgrade_tmp"),aI=wo.join(xS,"transactions"),console.info("Reindexing upgrade started for schemas"),Io.notify("Reindexing upgrade started for schemas"),await O1(b1,!1,e),await Fi.pathExists(aI)&&(console.info(`
109
+ `,n=HS.get("settings_path"),s=Na.dirname(n),i=Na.join(s,"3_1_0_upgrade_settings.bak");try{lr.info(`Backing up old settings file to: ${i}`),Ia.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}'`),Ia.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),Ia.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(sEe,"updateSettingsFile_3_1_0");function iEe(){let e=Na.join(A1.getHomeDir(),ki.HDB_HOME_DIR_NAME,ki.LICENSE_KEY_DIR_NAME,ki.LICENSE_FILE_NAME),t=Na.join(A1.getHomeDir(),ki.HDB_HOME_DIR_NAME,ki.LICENSE_KEY_DIR_NAME,ki.REG_KEY_FILE_NAME),r=Na.join(HS.getHdbBasePath(),ki.LICENSE_KEY_DIR_NAME,ki.LICENSE_FILE_NAME),n=Na.join(r,ki.LICENSE_FILE_NAME),s=Na.join(r,ki.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),Ia.mkdirpSync(r);try{Ia.accessSync(e);try{let c="Moving licence file";console.log(c),lr.info(c),Ia.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{Ia.accessSync(t);try{let c="Moving registration file";console.log(c),lr.info(c),Ia.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(iEe,"moveLicenseFiles");oI.sync_functions.push(sEe);oI.sync_functions.push(iEe);R1.push(oI);y1.exports=R1});var C1=N((eLe,w1)=>{"use strict";var Qn=ht(),{insertRecords:oEe}=ic(),aEe=cn(),wa=Ht(),cEe=te(),Io=W(),lEe=te(),Fi=require("fs-extra"),wo=require("path"),uEe=require("cli-progress"),mE=require("assert"),dEe=require("pino"),_Ee=se();w1.exports=fEe;var xS,O1,kS,aI,rn,SE=!1;async function fEe(e=!0){return xS=_Ee.getHdbBasePath(),O1=wo.join(xS,"schema"),kS=wo.join(xS,"4_0_0_upgrade_tmp"),aI=wo.join(xS,"transactions"),console.info("Reindexing upgrade started for schemas"),Io.notify("Reindexing upgrade started for schemas"),await N1(O1,!1,e),await Fi.pathExists(aI)&&(console.info(`
110
110
 
111
- Reindexing upgrade started for transaction logs`),Io.notify("Reindexing upgrade started for transaction logs"),await O1(aI,!0,e)),Io.notify("Reindexing upgrade complete"),"Reindexing for 4.0.0 upgrade complete"+(mE?", but errors occurred":"")}a(fEe,"reindexUpgrade");async function O1(e,t,r){let n=await Fi.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 Fi.readdir(c),u=l.length;for(let d=0;d<u;d++){let _=l[d];if(_!==".DS_Store"&&Fi.statSync(wo.join(c,_)).isDirectory())try{await EEe(o,_,t),rn.info(`Reindexing started for ${o}.${_}`),Io.notify(`${t?"Transaction":"Schema"} reindexing started for ${o}.${_}`),await pEe(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 Fi.rm(kS,{recursive:!0})}catch{}}a(O1,"processTables");async function EEe(e,t,r){let s=`${e}_${t}_${r?"transaction_reindex":"schema_reindex"}.log`,i=wo.join(kS,s);await Fi.ensureDir(kS),await Fi.writeFile(i,""),rn=dEe({level:"debug",formatters:{bindings(){}}},i)}a(EEe,"initPinoLogger");var hEe=20;async function pEe(e,t,r,n,s){let i;try{i=await Qn.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=TEe(i.dbis),c=Qn.openDBI(i,o),l=Object.keys(i.dbis),u=Qn.statDBI(i,o);rn.info(`Old environment stats: ${JSON.stringify(u)}`);let d=new uEe.SingleBar({format:`${e}.${t} |{bar}| {percentage}% || {value}/{total} records`,barCompleteChar:"\u2588",barIncompleteChar:"\u2591",hideCursor:!0,clearOnComplete:!1});d.start(u.entryCount,0,{});let _=await Qn.createEnvironment(r,t,!1);Qn.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>hEe&&await f();await f()}catch(S){throw mE=!0,rn.error(S),S}async function f(){let S,y=E.map(({value:U})=>U);n?S=await Promise.all(y.map(U=>mEe(_,U))):S=await oEe(_,o,l.filter(U=>U!=="__blob__"),y,!1);for(let U=0,H=E.length;U<H;U++){let{key:X,value:Y}=E[U];rn.info(`Record hash value: ${X} hash: ${o}`);let V;n?V=S[U]:V=S.written_hashes.indexOf(X)>-1,pE(V,!0),SEe(_,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=Qn.statDBI(i,o),T=Qn.statDBI(_,o);if(rn.info(`Old stats entry count: ${h.entryCount}. New stats entry count: ${T.entryCount}`),pE.deepStrictEqual(h.entryCount,T.entryCount),await Qn.closeEnvironment(i),await Qn.closeEnvironment(_),delete global.lmdb_map[`${e}.${t}`],s){let S=wo.join(r,t),y=wo.join(S,"data.mdb"),I=wo.join(S,"lock.mdb");await Fi.unlink(y),await Fi.unlink(I),await Fi.rmdir(S),rn.info(`Deleted old environment files from schema folder: ${y}, ${I}`)}let m=await Qn.openEnvironment(r,t),g=Qn.statDBI(m,o);rn.info(`New stats: ${JSON.stringify(T)}. New stats after move: ${JSON.stringify(g)}`),pE.deepStrictEqual(g.entryCount,T.entryCount),await Qn.closeEnvironment(m),delete global.lmdb_map[`${e}.${t}`]}a(pEe,"processTable");async function mEe(e,t){Qn.initializeDBIs(e,wa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,wa.TRANSACTIONS_DBIS);let r=t.timestamp;return e.dbis[wa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(r,()=>{e.dbis[wa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(r,t),lEe.isEmpty(t.user_name)||e.dbis[wa.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(t.user_name,r);for(let n of t.hash_values)e.dbis[wa.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(n,r)})}a(mEe,"insertTransaction");function SEe(e,t,r,n){let i=e.dbis[t].get(r);pE.deepStrictEqual(typeof i,"object");let o;if(n){let c={[wa.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME]:i.user_name,[wa.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&&!cEe.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(SEe,"validateIndices");function N1(e,t,r,n){try{let s=!1,i=aEe.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 TEe(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(TEe,"getHashDBI")});var M1=N((nLe,L1)=>{"use strict";var FS=require("path"),Ca=require("fs-extra"),gEe=iI(),ll=W(),C1=wt(),cI=se(),oi=M(),GS=te(),AEe=require("properties-reader"),REe=$s(),yEe=Hp(),bEe=Vr(),rLe=require("util"),OEe=bEe.searchByValue,NEe=un(),IEe=gm(),wEe=Ct(),CEe=w1(),D1=Xs(),DEe=BS(),gE=new gEe("4.0.0"),P1=[],SE,TE;async function PEe(){try{if(await DEe.upgradeCertsPrompt()){if(console.log("Generating new certificates."),SE){let t=GS.changeExtension(SE,".bak");await Ca.move(SE,t)}if(TE){let t=GS.changeExtension(TE,".bak");await Ca.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(PEe,"generateNewKeys");async function LEe(){console.log("Updating HarperDB nodes."),ll.info("Updating HarperDB nodes.");let e=[];try{let t=new REe(oi.SYSTEM_SCHEMA_NAME,oi.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*","name",["*"]),r=Array.from(await OEe(t)),n=[];for(let i=0,o=r.length;i<o;i++){let c=r[i];if(!wEe.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 yEe(oi.SYSTEM_SCHEMA_NAME,oi.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,n);await NEe.update(s)}catch(t){throw console.error("There was a problem updating the hdb_nodes table. Please check the log for details."),t}try{IEe.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(LEe,"updateNodes");async function MEe(){let e=cI.get(oi.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);if(!e.includes(FS.join("config","settings.js"))){ll.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),ll.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{ll.info(`Backing up old settings file to: ${s}`),console.log(`Backing up old settings file to: ${s}`),Ca.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{ll.info(`Creating new/upgraded settings file at '${i}'`),console.log(`Creating new/upgraded settings file at '${i}'`),ll.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();Ca.accessSync(o,Ca.constants.F_OK|Ca.constants.R_OK);let l=AEe(o).get(oi.HDB_SETTINGS_NAMES.INSTALL_USER),u=`settings_path = ${i}
112
- install_user = ${l}`;try{Ca.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{Ca.removeSync(r),console.log(d),ll.info(d)}catch(_){throw console.error("There was a problem deleting the old settings file and directory. Please check the log for details."),_}}a(MEe,"updateSettingsFile_4_0_0");gE.async_functions.push(MEe);gE.async_functions.push(PEe);gE.async_functions.push(CEe);gE.async_functions.push(LEe);P1.push(gE);L1.exports=P1});var lI=N((iLe,H1)=>{"use strict";var ul=te(),UEe=M(),U1=W(),{DATA_VERSION:vEe,UPGRADE_VERSION:BEe}=UEe.UPGRADE_JSON_FIELD_NAMES_ENUM,v1=y1(),qS=M1(),dl=new Map;v1&&v1.forEach(e=>{dl.set(e.version,e)});qS&&qS.forEach(e=>{dl.set(e.version,e)});qS&&qS.forEach(e=>{dl.set(e.version,e)});function HEe(){return[...dl.keys()].sort(ul.compareVersions)}a(HEe,"getSortedVersions");function B1(e){let t=e[vEe],r=e[BEe];return ul.isEmptyOrZeroLength(t)||ul.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."),[]):[...dl.keys()].sort(ul.compareVersions).filter(function(n){return ul.compareVersions(n,t)>0&&ul.compareVersions(n,r)<=0})}a(B1,"getVersionsForUpgrade");function xEe(e){return B1(e).length>0}a(xEe,"hasUpgradesRequired");function kEe(e){return ul.isEmptyOrZeroLength(e)?null:dl.has(e)?dl.get(e):null}a(kEe,"getDirectiveByVersion");H1.exports={getSortedVersions:HEe,getDirectiveByVersion:kEe,getVersionsForUpgrade:B1,hasUpgradesRequired:xEe}});var VS=N((aLe,q1)=>{"use strict";var FEe=require("util"),uI=require("chalk"),GEe=require("os"),k1=un(),qEe=Vr(),Jn=M(),F1=d1(),_I=wA(),{UpgradeObject:x1}=E1(),{forceDowngradePrompt:$Ee}=BS(),VEe=Bc(),$S=W(),ad=te(),fI=us(),KEe=(Pe(),oe(lt)),YEe=lI(),WEe=FEe.promisify(fI.setSchemaDataToGlobal),jEe=qEe.searchByValue,zEe="info_id",QEe="2.9.9",JEe="3.0.0";async function XEe(e){let t=new F1.HdbInfoInsertObject(1,e,e),r=new _I.InsertObject(Jn.OPERATIONS_ENUM.INSERT,Jn.SYSTEM_SCHEMA_NAME,Jn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,Jn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,[t]);return fI.setSchemaDataToGlobal(),k1.insert(r)}a(XEe,"insertHdbInstallInfo");async function dI(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 _I.InsertObject(Jn.OPERATIONS_ENUM.INSERT,Jn.SYSTEM_SCHEMA_NAME,Jn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,Jn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,[t]);return await WEe(),k1.insert(o)}a(dI,"insertHdbUpgradeInfo");async function G1(){let e=new _I.NoSQLSeachObject(Jn.SYSTEM_SCHEMA_NAME,Jn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,zEe,Jn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,["*"],"*"),t=[];try{t=Array.from(await jEe(e))}catch(r){console.error(r)}return t}a(G1,"getAllHdbInfoRecords");async function ZEe(){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(ZEe,"getLatestHdbInfoRecord");async function ehe(){$S.info("Checking if HDB software has been updated");try{let e=VEe.version(),t=await ZEe(),r;if(ad.isEmpty(t))r=QEe;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.${GEe.EOL}${Jn.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 $Ee(new x1(r,e))?await dI(e.toString()):(console.log("Cancelled downgrade, closing HarperDB"),process.exit(0)))}if(fI.setSchemaDataToGlobal(),the(r),e.toString()===r.toString())return;let n=new x1(r,e);if(YEe.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(ehe,"getVersionUpdateInfo");function the(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 ${Jn.HDB_SUPPORT_ADDRESS}`;if(!("hdb_info"in KEe.databases.system))throw console.log(t),new Error(t);if(!ad.isEmpty(e)&&e<JEe)throw console.log(t),new Error(t)}a(the,"checkIfInstallIsSupported");q1.exports={insertHdbInstallInfo:XEe,insertHdbUpgradeInfo:dI,getVersionUpdateInfo:ehe}});var Y1=N((lLe,K1)=>{"use strict";var KS=require("joi"),{boolean:rhe,string:EI,number:nhe}=KS.types(),$1=require("fs-extra"),AE=M(),V1=require("path"),she=Tt();K1.exports=ihe;function ihe(e){let t=EI.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),r=KS.object({[AE.INSTALL_PROMPTS.ROOTPATH]:KS.custom(ohe),[AE.INSTALL_PROMPTS.OPERATIONSAPI_NETWORK_PORT]:KS.alternatives([nhe.min(0),EI]).allow("null",null),[AE.INSTALL_PROMPTS.TC_AGREEMENT]:EI.valid("yes","YES","Yes"),[AE.INSTALL_PROMPTS.CLUSTERING_NODENAME]:t,[AE.INSTALL_PROMPTS.CLUSTERING_ENABLED]:rhe});return she.validateBySchema(e,r)}a(ihe,"installValidator");function ohe(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(ohe,"validateRootAvailable")});var j1=N((dLe,W1)=>{"use strict";var{mkdirpSync:ahe,copySync:che}=require("fs-extra"),Da=require("path"),cd=M(),pI=W(),lhe=Bn(),hI=Zi(),uhe=gt();W1.exports=dhe;async function dhe(e){pI.trace("Mounting HarperDB"),_l(e),_l(Da.join(e,"backup")),_l(Da.join(e,"keys")),_l(Da.join(e,"keys",cd.LICENSE_FILE_NAME)),_l(Da.join(e,"log")),_l(Da.join(e,"database")),_l(Da.join(e,"components")),che(Da.resolve(cd.PACKAGE_ROOT,"./utility/install/README.md"),Da.join(e,"README.md")),await _he()}a(dhe,"mountHdb");async function _he(){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{uhe.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 lhe.createTable(n,i)}catch(i){throw pI.error(`issue creating environment for ${cd.SYSTEM_SCHEMA_NAME}.${n}: ${i}`),i}}}a(_he,"createLMDBTables");function _l(e){ahe(e,{mode:cd.HDB_FILE_PERMISSIONS}),pI.info(`Directory ${e} created`)}a(_l,"makeDirectory")});var cK=N((hLe,aK)=>{"use strict";var SI=require("os"),Z1=require("inquirer"),Cs=require("fs-extra"),fhe=require("properties-reader"),El=require("chalk"),qi=require("path"),Ehe=require("human-readable-ids").hri,hhe=require("ora"),phe=require("yaml"),ur=W(),Pa=se(),RE=te(),WS=ja(),eK=VS(),tK=Bc(),ue=M(),{CONFIG_PARAM_MAP:fLe,CONFIG_PARAMS:Mt}=ue,mhe=Y1(),She=j1(),TI=wt(),The=xn(),ghe=cf(),Ahe=ZN(),Rhe=us(),yhe=require("util").promisify,bhe=yhe(Rhe.setSchemaDataToGlobal),z1=Xs(),fl=a(e=>e,"PROMPT_ANSWER_TRANSFORMER"),xr=a(e=>El.magenta.bold(e),"HDB_PROMPT_MSG"),Ohe="https://harperdb.io/legal/end-user-license-agreement",La=SI.EOL,Co="",Nhe="yes",Q1="Starting HarperDB install...",J1="HarperDB installation was successful.",X1="Terms & Conditions acceptance is required to proceed with installation. Exiting install...",Ihe="An out of date version of HarperDB is already installed.",mI="It appears that HarperDB is already installed. Exiting install...",whe="Aborting install",ELe=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])$/),Che=new RegExp(/^[^\s.,*>]+$/),Dhe=SI.homedir(),Phe=qi.join(Dhe,ue.HDB_ROOT_DIR_NAME),Lhe="HDB_ADMIN",Mhe="CLUSTER_USER",Uhe="dev",vhe="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:"},Ma=WS([ue.INSTALL_PROMPTS.HDB_CONFIG]),Gi,rK=!1,gI=!1,nK=!1;aK.exports={install:sK,updateConfigEnv:Yhe,setIgnoreExisting:Whe};sK.createSuperUser=oK;async function sK(){console.log(xr(La+Q1+La)),ur.notify(Q1);let e;Ma[ue.INSTALL_PROMPTS.HDB_CONFIG]&&(e=Bhe());let t=xhe();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=mhe(t);if(r)throw r.message;await khe(),await Fhe(t);let n=await Hhe(t);Gi=n[ue.INSTALL_PROMPTS.ROOTPATH],Ma[ue.INSTALL_PROMPTS.HDB_CONFIG]&&qi.dirname(Ma[ue.INSTALL_PROMPTS.HDB_CONFIG])===Gi&&(rK=!0),!gI&&!Ma[ue.INSTALL_PROMPTS.HDB_CONFIG]&&await Cs.pathExists(qi.join(Gi,ue.HDB_CONFIG_FILE))&&(console.error(mI),process.exit());let s=hhe({prefixText:xr("Installing"),color:"magenta",spinner:"simpleDots"});if(s.start(),RE.isEmpty(Gi))throw new Error("Installer should have the HDB root param at the stage it is in but it does not.");Pa.setHdbBasePath(Gi),await She(Gi),await Ghe(),await qhe(n),ur.initLogSettings(!0),await oK(n),await Vhe(n),await z1.updateConfigCert(),await z1.generateCertsKeys(),await Khe(),Ahe(),s.stop(),console.log(xr(La+J1+La)),ur.notify(J1)}a(sK,"install");function Bhe(){let e=phe.parseDocument(Cs.readFileSync(Ma[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(Bhe,"getConfigFromFile");async function Hhe(e){ur.trace("Getting install prompts and params.");let t,r=[{type:"input",transformer:fl,when:Do(e[ue.INSTALL_PROMPTS.ROOTPATH],Hr.DESTINATION),name:ue.INSTALL_PROMPTS.ROOTPATH,prefix:Co,default:Phe,validate:a(async s=>ws(s)?ws(s):await Cs.pathExists(qi.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:fl,when:Do(e[ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],Hr.HDB_USERNAME),name:ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME,prefix:Co,default:Lhe,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:fl,when:Do(e[ue.INSTALL_PROMPTS.DEFAULTS_MODE],Hr.DEFAULTS_MODE),name:ue.INSTALL_PROMPTS.DEFAULTS_MODE,prefix:Co,default:Uhe,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:fl,when:Do(e[ue.INSTALL_PROMPTS.REPLICATION_HOSTNAME],Hr.REPLICATION_HOSTNAME),prefix:Co,default:vhe,message:xr(Hr.REPLICATION_HOSTNAME)}),RE.autoCastBoolean(e[ue.INSTALL_PROMPTS.CLUSTERING_ENABLED])===!0){let s=[{type:"input",transformer:fl,when:Do(e[ue.INSTALL_PROMPTS.CLUSTERING_NODENAME],Hr.NODE_NAME),name:ue.INSTALL_PROMPTS.CLUSTERING_NODENAME,prefix:Co,default:Ehe.random(),validate:a(i=>Che.test(i)?!0:"Invalid node name, must not contain ., * or >","validate"),message:xr(Hr.NODE_NAME)},{type:"input",transformer:fl,when:Do(e[ue.INSTALL_PROMPTS.CLUSTERING_USER],Hr.CLUSTER_USERNAME),name:ue.INSTALL_PROMPTS.CLUSTERING_USER,prefix:Co,default:Mhe,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(Hhe,"installPrompts");function Do(e,t){return e!==void 0?(t.includes("password")?(console.log(`${xr(t)} ${El.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 xhe(){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(xhe,"checkForPromptOverride");async function khe(){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=fhe(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&&RE.noBootFile()&&(r=!0),r&&!gI){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(La+El.magenta.bold(Ihe)),console.log(El.magenta.bold(s)),ur.error(s)}else console.log(La+El.magenta.bold(mI)),ur.error(mI);process.exit(0)}}a(khe,"checkForExistingInstall");async function Fhe(e){ur.info("Asking for terms agreement.");let t=`Terms & Conditions can be found at ${Ohe}${La}and can be viewed by typing or copying and pasting the URL into your web browser.${La}I agree to the HarperDB Terms and Conditions: (yes/no)`,r={prefix:Co,transformer:fl,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:El.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()!==Nhe&&(console.log(El.yellow(X1)),ur.error(X1),process.exit(0))}a(Fhe,"termsAgreement");async function Ghe(){let e=qi.join(Gi,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=RE.getHomeDir(),s=qi.join(n,ue.HDB_HOME_DIR_NAME),i=qi.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=qi.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}Pa.setProperty(ue.HDB_SETTINGS_NAMES.INSTALL_USER,`${t}`),Pa.setProperty(ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,e),Pa.setProperty(Pa.BOOT_PROPS_FILE_PATH,o)}}a(Ghe,"createBootPropertiesFile");async function qhe(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{Ma[ue.INSTALL_PROMPTS.HDB_CONFIG]||TI.createConfigFile(t),Pa.initSync()}catch(r){$he(r)}}a(qhe,"createConfigFile");function $he(e){ur.error(`Error creating HarperDB config file. Rolling back install - ${e}`),console.error(e),console.error(whe);let t=qi.resolve(Pa.get(Pa.BOOT_PROPS_FILE_PATH),"../");t&&Cs.removeSync(t),Gi&&(rK?Cs.readdirSync(Gi,{withFileTypes:!0}).forEach(n=>{let s=qi.join(n.path,n.name);s!==Ma[ue.INSTALL_PROMPTS.HDB_CONFIG]&&Cs.removeSync(s)}):Cs.removeSync(Gi)),process.exit(1)}a($he,"rollbackInstall");async function iK(e,t){ur.trace("Creating admin user"),await bhe();let r;try{r=await ghe.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 The.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 Vhe(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(Vhe,"createClusterUser");async function Khe(){let e=tK.version();if(e)await eK.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(Khe,"insertHdbVersionInfo");function Yhe(e){Ma[ue.INSTALL_PROMPTS.HDB_CONFIG]=e}a(Yhe,"updateConfigEnv");function Whe(e){gI=e}a(Whe,"setIgnoreExisting")});var dK=N((mLe,uK)=>{"use strict";var AI=te(),Xn=W(),lK=lI();uK.exports={processDirectives:jhe};async function jhe(e){console.log("Starting upgrade process...");let t=lK.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}`;Xn.notify(c),console.log(c);let l=[],u=[];try{l=zhe(o.sync_functions)}catch(d){throw Xn.error(`Error while running an upgrade script for ${o.version}`),d}try{u=await Qhe(o.async_functions)}catch(d){throw Xn.error(`Error while running an upgrade script for ${o.version}`),d}n.push(...l,...u)}return n}a(jhe,"processDirectives");function zhe(e){if(AI.isEmptyOrZeroLength(e))return Xn.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return Xn.info("Passed parameter is not an array"),[];let t=[];for(let r of e){if(Xn.info(`Running function ${r.name}`),!(r instanceof Function)){Xn.info("Variable being processed is not a function");continue}let n=r();Xn.info(n),t.push(n)}return t}a(zhe,"runSyncFunctions");async function Qhe(e){if(AI.isEmptyOrZeroLength(e))return Xn.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return Xn.info("Passed parameter is not an array"),[];let t=[],r=e.length;for(let n=0;n<r;n++){let s=e[n];if(Xn.info(`Running function ${s.name}`),!(s instanceof Function)){Xn.info("Variable being processed is not a function");continue}let i=await s();Xn.info(i),t.push(i)}return t}a(Qhe,"runAsyncFunctions");function Jhe(e){if(AI.isEmptyOrZeroLength(e))return[];let t=[];for(let r of e){let n=lK.getDirectiveByVersion(r);n&&t.push(n)}return t}a(Jhe,"getUpgradeDirectivesToInstall")});var SK=N((TLe,mK)=>{"use strict";var jS=se();jS.initSync();var hK=require("chalk"),_K=require("fs-extra"),Lo=W(),Po=M(),fK=Bc(),Xhe=dK(),RI=te(),pK=VS(),Zhe=BS(),EK=hg(),epe=us(),tpe=require("util").promisify,rpe=tpe(epe.setSchemaDataToGlobal),yI,{UPGRADE_VERSION:zS}=Po.UPGRADE_JSON_FIELD_NAMES_ENUM;mK.exports={upgrade:npe};async function npe(e){await rpe(),yI===void 0&&(yI=xu()),_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 spe();let n,s=0;try{n=await Zhe.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 ipe(t),yE(`HarperDB was successfully upgraded to version ${t[zS]}`,Po.LOG_LEVELS.INFO)}a(npe,"upgrade");async function spe(){let e=!1,t=await EK.findPs(Po.HDB_PROC_NAME);if(RI.isEmptyOrZeroLength(t)||(e=!0),!e){let r=await EK.findPs("hdb_express");RI.isEmptyOrZeroLength(r)||(e=!0)}if(!e){let r=await yI.list();RI.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(spe,"checkIfRunning");async function ipe(e){try{await Xhe.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(ipe,"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((ALe,RK)=>{"use strict";var{promises:OI,createReadStream:ope,createWriteStream:ape}=require("fs"),{createGzip:cpe}=require("zlib"),{promisify:lpe}=require("util"),{pipeline:upe}=require("stream"),dpe=lpe(upe),_pe=require("path"),pl=se();pl.initSync();var hl=W(),{CONFIG_PARAMS:bE,ITC_EVENT_TYPES:fpe}=M(),{onMessageFromWorkers:Epe}=dt(),hpe=6e4,ppe="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",mpe="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",bI,gK;RK.exports=AK;Epe(e=>{e.type===fpe.RESTART&&(pl.initSync(!0),clearInterval(gK),pl.get(bE.LOGGING_ROTATION_ENABLED)&&AK())});async function AK(){try{let e=hl.getLogFilePath(),t=pl.get(bE.LOGGING_ROTATION_MAXSIZE),r=pl.get(bE.LOGGING_ROTATION_INTERVAL);if(!t&&!r){hl.error(ppe);return}let n=pl.get(bE.LOGGING_ROTATION_PATH);if(!n){hl.error(mpe);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,hl.trace("Log rotate enabled, maxSize:",t,"interval:",r),gK=setInterval(async()=>{if(s){let o;o=await OI.stat(e),o.size>=s&&await TK(e,n)}i&&Date.now()/6e4-bI>=i&&(await TK(e,n),bI=Date.now()/6e4)},hpe).unref()}catch(e){hl.error(e)}}a(AK,"logRotator");async function TK(e,t){let r=pl.get(bE.LOGGING_ROTATION_COMPRESS),n=_pe.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.${r?"log.gz":"log"}`);r?(await dpe(ope(e),cpe(),ape(n)),await OI.unlink(e)):await OI.rename(e,n),hl.closeLogFile(),hl.notify(`hdb.log rotated, old log moved to ${n}`)}a(TK,"moveLogFile")});var PK=N(DK=>{"use strict";var pe=se();pe.initSync();var yLe=qu(),Xt=M(),Zn=W(),Mo=require("fs-extra"),Uo=require("path"),Spe=require("systeminformation"),Tpe=ZN(),{install:gpe}=cK(),NI=require("chalk"),Ape=Xl(),vo=te(),II=wt(),OK=ja(),bK=Om(),Rpe=SK(),ype=yK(),{compactOnStart:bpe}=(oO(),oe(iO)),Ope=require("minimist"),Npe=Xs(),{PACKAGE_ROOT:Ipe,CONFIG_PARAMS:Ce}=M(),{startHTTPThreads:wpe,startSocketServer:bLe,mostIdleRouting:OLe,remoteAffinityRouting:NLe}=(wI(),oe(LK)),Cpe=VS(),{isMainThread:Dpe}=require("worker_threads"),ILe=Zi(),wLe=ro(),CLe=mR(),DLe=I_(),QS=M(),$i,ld,NK=!1,Ppe="Upgrade complete. Starting HarperDB.",Lpe="Got an error while trying to upgrade your HarperDB instance. Exiting HarperDB.",Mpe="HarperDB not found, starting install process.",Upe="There was an error during install, check install_log.log for more details. Exiting.",vpe="HarperDB successfully started.";function Bpe(){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(Bpe,"addExitListeners");async function IK(e=!1,t=!1){if(console.log(NI.magenta("Starting HarperDB...")),Zn.suppressLogging?.(()=>{console.log(NI.magenta(""+Mo.readFileSync(Uo.join(Ipe,"utility/install/ascii_logo.txt"))))}),await CK()===!1){console.log(Mpe);try{await gpe()}catch(o){console.error(Upe,o),Zn.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))&&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 Mo.readFile(Uo.join(pe.get(Xt.CONFIG_PARAMS.ROOTPATH),Xt.HDB_PID_FILE),"utf8")),c=await Spe.processes();for(let l of c.list)if(l.pid===o){n?r=!0:console.log("HarperDB appears to be already running.");break}}catch{}$i===void 0&&($i=xu()),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 $i.startClusteringProcesses(!0),process.exit()),Bpe(),await Mo.writeFile(Uo.join(pe.get(QS.CONFIG_PARAMS.ROOTPATH),QS.HDB_PID_FILE),`${process.pid}`),Zn.info("HarperDB PID",process.pid);let s;try{let o=await Cpe.getVersionUpdateInfo();o!==void 0&&(s=o[Xt.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION],await Rpe.upgrade(o),console.log(Ppe))}catch(o){s?(console.error(`Got an error while trying to upgrade your HarperDB instance to version ${s}. Exiting HarperDB.`,o),Zn.error(o)):(console.error(Lpe,o),Zn.error(o)),process.exit(1)}Tpe(),kpe(),await Npe.reviewSelfSignedCert(),vo.autoCastBoolean(pe.get(Xt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&Dpe&&await bK.generateNatsConfig(t)}a(IK,"initialize");async function Hpe(e=!1){try{ld=Ope(process.argv),ld.ROOTPATH&&II.updateConfigObject("settings_path",Uo.join(ld.ROOTPATH,Xt.HDB_CONFIG_FILE)),await IK(e,!0),pe.get(Xt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await bpe();let t=process.env.IS_SCRIPTED_SERVICE&&!ld.service;vo.autoCastBoolean(pe.get(Xt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&(t||await $i.startClusteringProcesses(),await $i.startClusteringThreads()),await wpe(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 ype(),t||wK()}catch(t){console.error(t),Zn.error(t),process.exit(1)}}a(Hpe,"main");function wK(){Zn.suppressLogging(()=>{console.log(NI.magenta(`HarperDB ${Ape.version} successfully started`))}),Zn.notify(vpe)}a(wK,"started");async function xpe(e=!0){NK=!e;try{$i===void 0&&($i=xu()),$i.enterPM2Mode(),await IK(),vo.autoCastBoolean(pe.get(Xt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&await $i.startClusteringProcesses(),await $i.startService(Xt.PROCESS_DESCRIPTORS.HDB),wK(),e&&process.exit(0)}catch(t){console.error(t),Zn.error(t),process.exit(1)}}a(xpe,"launch");function kpe(){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),Zn.error(s)}}a(kpe,"writeLicenseFromVars");Object.assign(DK,{launch:xpe,main:Hpe,isHdbInstalled:CK,startupLog:Fpe});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 Zn.error(`Error checking for HDB install - ${e}`),e}return!0}a(CK,"isHdbInstalled");function Fpe(e){let r=a(f=>f.padEnd(20),"pad"),n=`
111
+ Reindexing upgrade started for transaction logs`),Io.notify("Reindexing upgrade started for transaction logs"),await N1(aI,!0,e)),Io.notify("Reindexing upgrade complete"),"Reindexing for 4.0.0 upgrade complete"+(SE?", but errors occurred":"")}a(fEe,"reindexUpgrade");async function N1(e,t,r){let n=await Fi.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 Fi.readdir(c),u=l.length;for(let d=0;d<u;d++){let _=l[d];if(_!==".DS_Store"&&Fi.statSync(wo.join(c,_)).isDirectory())try{await EEe(o,_,t),rn.info(`Reindexing started for ${o}.${_}`),Io.notify(`${t?"Transaction":"Schema"} reindexing started for ${o}.${_}`),await pEe(o,_,c,t,r),rn.info(`Reindexing completed for ${o}.${_}`),Io.notify(`Reindexing completed for ${o}.${_}`)}catch(E){SE=!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(!SE)try{await Fi.rm(kS,{recursive:!0})}catch{}}a(N1,"processTables");async function EEe(e,t,r){let s=`${e}_${t}_${r?"transaction_reindex":"schema_reindex"}.log`,i=wo.join(kS,s);await Fi.ensureDir(kS),await Fi.writeFile(i,""),rn=dEe({level:"debug",formatters:{bindings(){}}},i)}a(EEe,"initPinoLogger");var hEe=20;async function pEe(e,t,r,n,s){let i;try{i=await Qn.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=TEe(i.dbis),c=Qn.openDBI(i,o),l=Object.keys(i.dbis),u=Qn.statDBI(i,o);rn.info(`Old environment stats: ${JSON.stringify(u)}`);let d=new uEe.SingleBar({format:`${e}.${t} |{bar}| {percentage}% || {value}/{total} records`,barCompleteChar:"\u2588",barIncompleteChar:"\u2591",hideCursor:!0,clearOnComplete:!1});d.start(u.entryCount,0,{});let _=await Qn.createEnvironment(r,t,!1);Qn.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>hEe&&await f();await f()}catch(S){throw SE=!0,rn.error(S),S}async function f(){let S,y=E.map(({value:U})=>U);n?S=await Promise.all(y.map(U=>mEe(_,U))):S=await oEe(_,o,l.filter(U=>U!=="__blob__"),y,!1);for(let U=0,H=E.length;U<H;U++){let{key:X,value:Y}=E[U];rn.info(`Record hash value: ${X} hash: ${o}`);let V;n?V=S[U]:V=S.written_hashes.indexOf(X)>-1,mE(V,!0),SEe(_,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=Qn.statDBI(i,o),T=Qn.statDBI(_,o);if(rn.info(`Old stats entry count: ${h.entryCount}. New stats entry count: ${T.entryCount}`),mE.deepStrictEqual(h.entryCount,T.entryCount),await Qn.closeEnvironment(i),await Qn.closeEnvironment(_),delete global.lmdb_map[`${e}.${t}`],s){let S=wo.join(r,t),y=wo.join(S,"data.mdb"),I=wo.join(S,"lock.mdb");await Fi.unlink(y),await Fi.unlink(I),await Fi.rmdir(S),rn.info(`Deleted old environment files from schema folder: ${y}, ${I}`)}let m=await Qn.openEnvironment(r,t),g=Qn.statDBI(m,o);rn.info(`New stats: ${JSON.stringify(T)}. New stats after move: ${JSON.stringify(g)}`),mE.deepStrictEqual(g.entryCount,T.entryCount),await Qn.closeEnvironment(m),delete global.lmdb_map[`${e}.${t}`]}a(pEe,"processTable");async function mEe(e,t){Qn.initializeDBIs(e,wa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,wa.TRANSACTIONS_DBIS);let r=t.timestamp;return e.dbis[wa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(r,()=>{e.dbis[wa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(r,t),lEe.isEmpty(t.user_name)||e.dbis[wa.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(t.user_name,r);for(let n of t.hash_values)e.dbis[wa.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(n,r)})}a(mEe,"insertTransaction");function SEe(e,t,r,n){let i=e.dbis[t].get(r);mE.deepStrictEqual(typeof i,"object");let o;if(n){let c={[wa.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME]:i.user_name,[wa.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&&!cEe.isEmptyOrZeroLength(l))if(n&&c==="hash_value")for(let u=0,d=l.length;u<d;u++){let _=l[u];I1(e,c,_,r)}else I1(e,c,l,r)}a(SEe,"validateIndices");function I1(e,t,r,n){try{let s=!1,i=aEe.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}`),mE.deepStrictEqual(s,!0)}catch(s){SE=!0,rn.error(s),console.error(s)}}a(I1,"validateIndex");function TEe(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(TEe,"getHashDBI")});var U1=N((nLe,M1)=>{"use strict";var FS=require("path"),Ca=require("fs-extra"),gEe=iI(),ll=W(),D1=wt(),cI=se(),oi=M(),GS=te(),AEe=require("properties-reader"),REe=$s(),yEe=Hp(),bEe=Vr(),rLe=require("util"),OEe=bEe.searchByValue,NEe=un(),IEe=gm(),wEe=Ct(),CEe=C1(),P1=Xs(),DEe=BS(),AE=new gEe("4.0.0"),L1=[],TE,gE;async function PEe(){try{if(await DEe.upgradeCertsPrompt()){if(console.log("Generating new certificates."),TE){let t=GS.changeExtension(TE,".bak");await Ca.move(TE,t)}if(gE){let t=GS.changeExtension(gE,".bak");await Ca.move(gE,t)}await P1.generateKeys()}else console.log("Using existing certificates."),P1.updateConfigCert(TE,gE,void 0)}catch(e){throw console.error("There was a problem generating new keys. Please check the log for details."),e}}a(PEe,"generateNewKeys");async function LEe(){console.log("Updating HarperDB nodes."),ll.info("Updating HarperDB nodes.");let e=[];try{let t=new REe(oi.SYSTEM_SCHEMA_NAME,oi.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*","name",["*"]),r=Array.from(await OEe(t)),n=[];for(let i=0,o=r.length;i<o;i++){let c=r[i];if(!wEe.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 yEe(oi.SYSTEM_SCHEMA_NAME,oi.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,n);await NEe.update(s)}catch(t){throw console.error("There was a problem updating the hdb_nodes table. Please check the log for details."),t}try{IEe.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(LEe,"updateNodes");async function MEe(){let e=cI.get(oi.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);if(!e.includes(FS.join("config","settings.js"))){ll.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),ll.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{ll.info(`Backing up old settings file to: ${s}`),console.log(`Backing up old settings file to: ${s}`),Ca.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{ll.info(`Creating new/upgraded settings file at '${i}'`),console.log(`Creating new/upgraded settings file at '${i}'`),ll.info("Updating env variables with new settings values");let _=D1.initOldConfig(e);TE=_[oi.CONFIG_PARAMS.TLS_CERTIFICATE.toLowerCase()],gE=_[oi.CONFIG_PARAMS.TLS_PRIVATEKEY.toLowerCase()],D1.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();Ca.accessSync(o,Ca.constants.F_OK|Ca.constants.R_OK);let l=AEe(o).get(oi.HDB_SETTINGS_NAMES.INSTALL_USER),u=`settings_path = ${i}
112
+ install_user = ${l}`;try{Ca.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{Ca.removeSync(r),console.log(d),ll.info(d)}catch(_){throw console.error("There was a problem deleting the old settings file and directory. Please check the log for details."),_}}a(MEe,"updateSettingsFile_4_0_0");AE.async_functions.push(MEe);AE.async_functions.push(PEe);AE.async_functions.push(CEe);AE.async_functions.push(LEe);L1.push(AE);M1.exports=L1});var lI=N((iLe,x1)=>{"use strict";var ul=te(),UEe=M(),v1=W(),{DATA_VERSION:vEe,UPGRADE_VERSION:BEe}=UEe.UPGRADE_JSON_FIELD_NAMES_ENUM,B1=b1(),qS=U1(),dl=new Map;B1&&B1.forEach(e=>{dl.set(e.version,e)});qS&&qS.forEach(e=>{dl.set(e.version,e)});qS&&qS.forEach(e=>{dl.set(e.version,e)});function HEe(){return[...dl.keys()].sort(ul.compareVersions)}a(HEe,"getSortedVersions");function H1(e){let t=e[vEe],r=e[BEe];return ul.isEmptyOrZeroLength(t)||ul.isEmptyOrZeroLength(r)?(v1.info(`There is an issue with the version data in your instance of HDB. Current version data: ${e}`),v1.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."),[]):[...dl.keys()].sort(ul.compareVersions).filter(function(n){return ul.compareVersions(n,t)>0&&ul.compareVersions(n,r)<=0})}a(H1,"getVersionsForUpgrade");function xEe(e){return H1(e).length>0}a(xEe,"hasUpgradesRequired");function kEe(e){return ul.isEmptyOrZeroLength(e)?null:dl.has(e)?dl.get(e):null}a(kEe,"getDirectiveByVersion");x1.exports={getSortedVersions:HEe,getDirectiveByVersion:kEe,getVersionsForUpgrade:H1,hasUpgradesRequired:xEe}});var VS=N((aLe,$1)=>{"use strict";var FEe=require("util"),uI=require("chalk"),GEe=require("os"),F1=un(),qEe=Vr(),Jn=M(),G1=_1(),_I=wA(),{UpgradeObject:k1}=h1(),{forceDowngradePrompt:$Ee}=BS(),VEe=Bc(),$S=W(),ad=te(),fI=us(),KEe=(Pe(),oe(lt)),YEe=lI(),WEe=FEe.promisify(fI.setSchemaDataToGlobal),jEe=qEe.searchByValue,zEe="info_id",QEe="2.9.9",JEe="3.0.0";async function XEe(e){let t=new G1.HdbInfoInsertObject(1,e,e),r=new _I.InsertObject(Jn.OPERATIONS_ENUM.INSERT,Jn.SYSTEM_SCHEMA_NAME,Jn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,Jn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,[t]);return fI.setSchemaDataToGlobal(),F1.insert(r)}a(XEe,"insertHdbInstallInfo");async function dI(e){let t,r=await q1(),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 G1.HdbInfoInsertObject(i,e,e);let o=new _I.InsertObject(Jn.OPERATIONS_ENUM.INSERT,Jn.SYSTEM_SCHEMA_NAME,Jn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,Jn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,[t]);return await WEe(),F1.insert(o)}a(dI,"insertHdbUpgradeInfo");async function q1(){let e=new _I.NoSQLSeachObject(Jn.SYSTEM_SCHEMA_NAME,Jn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,zEe,Jn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,["*"],"*"),t=[];try{t=Array.from(await jEe(e))}catch(r){console.error(r)}return t}a(q1,"getAllHdbInfoRecords");async function ZEe(){let e=await q1();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(ZEe,"getLatestHdbInfoRecord");async function ehe(){$S.info("Checking if HDB software has been updated");try{let e=VEe.version(),t=await ZEe(),r;if(ad.isEmpty(t))r=QEe;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.${GEe.EOL}${Jn.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 $Ee(new k1(r,e))?await dI(e.toString()):(console.log("Cancelled downgrade, closing HarperDB"),process.exit(0)))}if(fI.setSchemaDataToGlobal(),the(r),e.toString()===r.toString())return;let n=new k1(r,e);if(YEe.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(ehe,"getVersionUpdateInfo");function the(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 ${Jn.HDB_SUPPORT_ADDRESS}`;if(!("hdb_info"in KEe.databases.system))throw console.log(t),new Error(t);if(!ad.isEmpty(e)&&e<JEe)throw console.log(t),new Error(t)}a(the,"checkIfInstallIsSupported");$1.exports={insertHdbInstallInfo:XEe,insertHdbUpgradeInfo:dI,getVersionUpdateInfo:ehe}});var W1=N((lLe,Y1)=>{"use strict";var KS=require("joi"),{boolean:rhe,string:EI,number:nhe}=KS.types(),V1=require("fs-extra"),RE=M(),K1=require("path"),she=Tt();Y1.exports=ihe;function ihe(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(ohe),[RE.INSTALL_PROMPTS.OPERATIONSAPI_NETWORK_PORT]:KS.alternatives([nhe.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]:rhe});return she.validateBySchema(e,r)}a(ihe,"installValidator");function ohe(e,t){if(V1.existsSync(K1.join(e,"system/hdb_user/data.mdb"))||V1.existsSync(K1.join(e,"system/hdb_user.mdb")))return t.message(`'${e}' is already in use. Please enter a different path.`)}a(ohe,"validateRootAvailable")});var z1=N((dLe,j1)=>{"use strict";var{mkdirpSync:ahe,copySync:che}=require("fs-extra"),Da=require("path"),cd=M(),pI=W(),lhe=Bn(),hI=Zi(),uhe=gt();j1.exports=dhe;async function dhe(e){pI.trace("Mounting HarperDB"),_l(e),_l(Da.join(e,"backup")),_l(Da.join(e,"keys")),_l(Da.join(e,"keys",cd.LICENSE_FILE_NAME)),_l(Da.join(e,"log")),_l(Da.join(e,"database")),_l(Da.join(e,"components")),che(Da.resolve(cd.PACKAGE_ROOT,"./utility/install/README.md"),Da.join(e,"README.md")),await _he()}a(dhe,"mountHdb");async function _he(){let e=w_(),t=Object.keys(hI);for(let r=0;r<t.length;r++){let n=t[r],s=hI[n].hash_attribute;try{uhe.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 lhe.createTable(n,i)}catch(i){throw pI.error(`issue creating environment for ${cd.SYSTEM_SCHEMA_NAME}.${n}: ${i}`),i}}}a(_he,"createLMDBTables");function _l(e){ahe(e,{mode:cd.HDB_FILE_PERMISSIONS}),pI.info(`Directory ${e} created`)}a(_l,"makeDirectory")});var lK=N((hLe,cK)=>{"use strict";var SI=require("os"),eK=require("inquirer"),Cs=require("fs-extra"),fhe=require("properties-reader"),El=require("chalk"),qi=require("path"),Ehe=require("human-readable-ids").hri,hhe=require("ora"),phe=require("yaml"),ur=W(),Pa=se(),yE=te(),WS=ja(),tK=VS(),rK=Bc(),ue=M(),{CONFIG_PARAM_MAP:fLe,CONFIG_PARAMS:Mt}=ue,mhe=W1(),She=z1(),TI=wt(),The=xn(),ghe=lf(),Ahe=ZN(),Rhe=us(),yhe=require("util").promisify,bhe=yhe(Rhe.setSchemaDataToGlobal),Q1=Xs(),fl=a(e=>e,"PROMPT_ANSWER_TRANSFORMER"),xr=a(e=>El.magenta.bold(e),"HDB_PROMPT_MSG"),Ohe="https://harperdb.io/legal/end-user-license-agreement",La=SI.EOL,Co="",Nhe="yes",J1="Starting HarperDB install...",X1="HarperDB installation was successful.",Z1="Terms & Conditions acceptance is required to proceed with installation. Exiting install...",Ihe="An out of date version of HarperDB is already installed.",mI="It appears that HarperDB is already installed. Exiting install...",whe="Aborting install",ELe=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])$/),Che=new RegExp(/^[^\s.,*>]+$/),Dhe=SI.homedir(),Phe=qi.join(Dhe,ue.HDB_ROOT_DIR_NAME),Lhe="HDB_ADMIN",Mhe="CLUSTER_USER",Uhe="dev",vhe="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:"},Ma=WS([ue.INSTALL_PROMPTS.HDB_CONFIG]),Gi,nK=!1,gI=!1,sK=!1;cK.exports={install:iK,updateConfigEnv:Yhe,setIgnoreExisting:Whe};iK.createSuperUser=aK;async function iK(){console.log(xr(La+J1+La)),ur.notify(J1);let e;Ma[ue.INSTALL_PROMPTS.HDB_CONFIG]&&(e=Bhe());let t=xhe();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&&(sK=!0,t[ue.INSTALL_PROMPTS.DEFAULTS_MODE]="prod");let r=mhe(t);if(r)throw r.message;await khe(),await Fhe(t);let n=await Hhe(t);Gi=n[ue.INSTALL_PROMPTS.ROOTPATH],Ma[ue.INSTALL_PROMPTS.HDB_CONFIG]&&qi.dirname(Ma[ue.INSTALL_PROMPTS.HDB_CONFIG])===Gi&&(nK=!0),!gI&&!Ma[ue.INSTALL_PROMPTS.HDB_CONFIG]&&await Cs.pathExists(qi.join(Gi,ue.HDB_CONFIG_FILE))&&(console.error(mI),process.exit());let s=hhe({prefixText:xr("Installing"),color:"magenta",spinner:"simpleDots"});if(s.start(),yE.isEmpty(Gi))throw new Error("Installer should have the HDB root param at the stage it is in but it does not.");Pa.setHdbBasePath(Gi),await She(Gi),await Ghe(),await qhe(n),ur.initLogSettings(!0),await aK(n),await Vhe(n),await Q1.updateConfigCert(),await Q1.generateCertsKeys(),await Khe(),Ahe(),s.stop(),console.log(xr(La+X1+La)),ur.notify(X1)}a(iK,"install");function Bhe(){let e=phe.parseDocument(Cs.readFileSync(Ma[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(Bhe,"getConfigFromFile");async function Hhe(e){ur.trace("Getting install prompts and params.");let t,r=[{type:"input",transformer:fl,when:Do(e[ue.INSTALL_PROMPTS.ROOTPATH],Hr.DESTINATION),name:ue.INSTALL_PROMPTS.ROOTPATH,prefix:Co,default:Phe,validate:a(async s=>ws(s)?ws(s):await Cs.pathExists(qi.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:fl,when:Do(e[ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],Hr.HDB_USERNAME),name:ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME,prefix:Co,default:Lhe,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:fl,when:Do(e[ue.INSTALL_PROMPTS.DEFAULTS_MODE],Hr.DEFAULTS_MODE),name:ue.INSTALL_PROMPTS.DEFAULTS_MODE,prefix:Co,default:Uhe,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(sK||r.push({type:"input",name:ue.INSTALL_PROMPTS.REPLICATION_HOSTNAME,transformer:fl,when:Do(e[ue.INSTALL_PROMPTS.REPLICATION_HOSTNAME],Hr.REPLICATION_HOSTNAME),prefix:Co,default:vhe,message:xr(Hr.REPLICATION_HOSTNAME)}),yE.autoCastBoolean(e[ue.INSTALL_PROMPTS.CLUSTERING_ENABLED])===!0){let s=[{type:"input",transformer:fl,when:Do(e[ue.INSTALL_PROMPTS.CLUSTERING_NODENAME],Hr.NODE_NAME),name:ue.INSTALL_PROMPTS.CLUSTERING_NODENAME,prefix:Co,default:Ehe.random(),validate:a(i=>Che.test(i)?!0:"Invalid node name, must not contain ., * or >","validate"),message:xr(Hr.NODE_NAME)},{type:"input",transformer:fl,when:Do(e[ue.INSTALL_PROMPTS.CLUSTERING_USER],Hr.CLUSTER_USERNAME),name:ue.INSTALL_PROMPTS.CLUSTERING_USER,prefix:Co,default:Mhe,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 eK.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(Hhe,"installPrompts");function Do(e,t){return e!==void 0?(t.includes("password")?(console.log(`${xr(t)} ${El.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 xhe(){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(xhe,"checkForPromptOverride");async function khe(){ur.trace("Checking for existing install.");let e=yE.getPropsFilePath(),t=await Cs.pathExists(e),r;if(t){ur.trace(`Install found an existing boot prop file at:${e}`);let n=fhe(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&&yE.noBootFile()&&(r=!0),r&&!gI){if(ur.trace(`Install found existing HDB config at:${e}`),await tK.getVersionUpdateInfo()){let s=`Please use \`harperdb upgrade\` to update to ${rK.version()}. Exiting install...`;console.log(La+El.magenta.bold(Ihe)),console.log(El.magenta.bold(s)),ur.error(s)}else console.log(La+El.magenta.bold(mI)),ur.error(mI);process.exit(0)}}a(khe,"checkForExistingInstall");async function Fhe(e){ur.info("Asking for terms agreement.");let t=`Terms & Conditions can be found at ${Ohe}${La}and can be viewed by typing or copying and pasting the URL into your web browser.${La}I agree to the HarperDB Terms and Conditions: (yes/no)`,r={prefix:Co,transformer:fl,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:El.yellow("Please enter 'yes' or 'no'"),"validate")},n=await eK.prompt([r]);n[ue.INSTALL_PROMPTS.TC_AGREEMENT]&&n[ue.INSTALL_PROMPTS.TC_AGREEMENT].toLowerCase()!==Nhe&&(console.log(El.yellow(Z1)),ur.error(Z1),process.exit(0))}a(Fhe,"termsAgreement");async function Ghe(){let e=qi.join(Gi,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=yE.getHomeDir(),s=qi.join(n,ue.HDB_HOME_DIR_NAME),i=qi.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=qi.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}Pa.setProperty(ue.HDB_SETTINGS_NAMES.INSTALL_USER,`${t}`),Pa.setProperty(ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,e),Pa.setProperty(Pa.BOOT_PROPS_FILE_PATH,o)}}a(Ghe,"createBootPropertiesFile");async function qhe(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{Ma[ue.INSTALL_PROMPTS.HDB_CONFIG]||TI.createConfigFile(t),Pa.initSync()}catch(r){$he(r)}}a(qhe,"createConfigFile");function $he(e){ur.error(`Error creating HarperDB config file. Rolling back install - ${e}`),console.error(e),console.error(whe);let t=qi.resolve(Pa.get(Pa.BOOT_PROPS_FILE_PATH),"../");t&&Cs.removeSync(t),Gi&&(nK?Cs.readdirSync(Gi,{withFileTypes:!0}).forEach(n=>{let s=qi.join(n.path,n.name);s!==Ma[ue.INSTALL_PROMPTS.HDB_CONFIG]&&Cs.removeSync(s)}):Cs.removeSync(Gi)),process.exit(1)}a($he,"rollbackInstall");async function oK(e,t){ur.trace("Creating admin user"),await bhe();let r;try{r=await ghe.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 The.addUser(t)}catch(n){throw n.message=`Error creating user - ${n}`,n}}a(oK,"createAdminUser");async function aK(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 oK(t,r),delete e[ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],delete e[ue.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]}a(aK,"createSuperUser");async function Vhe(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 oK({role:"cluster_user",permission:{cluster_user:!0}},t),delete e[ue.INSTALL_PROMPTS.CLUSTERING_USER],delete e[ue.INSTALL_PROMPTS.CLUSTERING_PASSWORD]}a(Vhe,"createClusterUser");async function Khe(){let e=rK.version();if(e)await tK.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(Khe,"insertHdbVersionInfo");function Yhe(e){Ma[ue.INSTALL_PROMPTS.HDB_CONFIG]=e}a(Yhe,"updateConfigEnv");function Whe(e){gI=e}a(Whe,"setIgnoreExisting")});var _K=N((mLe,dK)=>{"use strict";var AI=te(),Xn=W(),uK=lI();dK.exports={processDirectives:jhe};async function jhe(e){console.log("Starting upgrade process...");let t=uK.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}`;Xn.notify(c),console.log(c);let l=[],u=[];try{l=zhe(o.sync_functions)}catch(d){throw Xn.error(`Error while running an upgrade script for ${o.version}`),d}try{u=await Qhe(o.async_functions)}catch(d){throw Xn.error(`Error while running an upgrade script for ${o.version}`),d}n.push(...l,...u)}return n}a(jhe,"processDirectives");function zhe(e){if(AI.isEmptyOrZeroLength(e))return Xn.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return Xn.info("Passed parameter is not an array"),[];let t=[];for(let r of e){if(Xn.info(`Running function ${r.name}`),!(r instanceof Function)){Xn.info("Variable being processed is not a function");continue}let n=r();Xn.info(n),t.push(n)}return t}a(zhe,"runSyncFunctions");async function Qhe(e){if(AI.isEmptyOrZeroLength(e))return Xn.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return Xn.info("Passed parameter is not an array"),[];let t=[],r=e.length;for(let n=0;n<r;n++){let s=e[n];if(Xn.info(`Running function ${s.name}`),!(s instanceof Function)){Xn.info("Variable being processed is not a function");continue}let i=await s();Xn.info(i),t.push(i)}return t}a(Qhe,"runAsyncFunctions");function Jhe(e){if(AI.isEmptyOrZeroLength(e))return[];let t=[];for(let r of e){let n=uK.getDirectiveByVersion(r);n&&t.push(n)}return t}a(Jhe,"getUpgradeDirectivesToInstall")});var TK=N((TLe,SK)=>{"use strict";var jS=se();jS.initSync();var pK=require("chalk"),fK=require("fs-extra"),Lo=W(),Po=M(),EK=Bc(),Xhe=_K(),RI=te(),mK=VS(),Zhe=BS(),hK=hg(),epe=us(),tpe=require("util").promisify,rpe=tpe(epe.setSchemaDataToGlobal),yI,{UPGRADE_VERSION:zS}=Po.UPGRADE_JSON_FIELD_NAMES_ENUM;SK.exports={upgrade:npe};async function npe(e){await rpe(),yI===void 0&&(yI=xu()),fK.existsSync(jS.get(jS.BOOT_PROPS_FILE_PATH))||(bE("The hdb_boot_properties file was not found. Please install HDB.",Po.LOG_LEVELS.ERROR),process.exit(1)),fK.existsSync(jS.get(Po.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))||(bE("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 mK.getVersionUpdateInfo(),t||(console.log("HarperDB version is current"),process.exit(0))),bE(`This version of HarperDB is ${EK.version()}`,Po.LOG_LEVELS.INFO);let r=t[zS]?t[zS]:EK.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 spe();let n,s=0;try{n=await Zhe.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 ipe(t),bE(`HarperDB was successfully upgraded to version ${t[zS]}`,Po.LOG_LEVELS.INFO)}a(npe,"upgrade");async function spe(){let e=!1,t=await hK.findPs(Po.HDB_PROC_NAME);if(RI.isEmptyOrZeroLength(t)||(e=!0),!e){let r=await hK.findPs("hdb_express");RI.isEmptyOrZeroLength(r)||(e=!0)}if(!e){let r=await yI.list();RI.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(pK.red(r)),Lo.error(r),process.exit(1)}}a(spe,"checkIfRunning");async function ipe(e){try{await Xhe.processDirectives(e)}catch(t){throw bE("There was an error during the data upgrade. Please check the logs.",Po.LOG_LEVELS.ERROR),t}try{await mK.insertHdbUpgradeInfo(e[zS])}catch(t){Lo.error("Error updating the 'hdb_info' system table."),Lo.error(t)}}a(ipe,"runUpgrade");function bE(e,t=void 0){t||(t=Lo.info),Lo[t](e),console.log(pK.magenta(e))}a(bE,"printToLogAndConsole")});var bK=N((ALe,yK)=>{"use strict";var{promises:OI,createReadStream:ope,createWriteStream:ape}=require("fs"),{createGzip:cpe}=require("zlib"),{promisify:lpe}=require("util"),{pipeline:upe}=require("stream"),dpe=lpe(upe),_pe=require("path"),pl=se();pl.initSync();var hl=W(),{CONFIG_PARAMS:OE,ITC_EVENT_TYPES:fpe}=M(),{onMessageFromWorkers:Epe}=dt(),hpe=6e4,ppe="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",mpe="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",bI,AK;yK.exports=RK;Epe(e=>{e.type===fpe.RESTART&&(pl.initSync(!0),clearInterval(AK),pl.get(OE.LOGGING_ROTATION_ENABLED)&&RK())});async function RK(){try{let e=hl.getLogFilePath(),t=pl.get(OE.LOGGING_ROTATION_MAXSIZE),r=pl.get(OE.LOGGING_ROTATION_INTERVAL);if(!t&&!r){hl.error(ppe);return}let n=pl.get(OE.LOGGING_ROTATION_PATH);if(!n){hl.error(mpe);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,hl.trace("Log rotate enabled, maxSize:",t,"interval:",r),AK=setInterval(async()=>{if(s){let o;o=await OI.stat(e),o.size>=s&&await gK(e,n)}i&&Date.now()/6e4-bI>=i&&(await gK(e,n),bI=Date.now()/6e4)},hpe).unref()}catch(e){hl.error(e)}}a(RK,"logRotator");async function gK(e,t){let r=pl.get(OE.LOGGING_ROTATION_COMPRESS),n=_pe.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.${r?"log.gz":"log"}`);r?(await dpe(ope(e),cpe(),ape(n)),await OI.unlink(e)):await OI.rename(e,n),hl.closeLogFile(),hl.notify(`hdb.log rotated, old log moved to ${n}`)}a(gK,"moveLogFile")});var LK=N(PK=>{"use strict";var pe=se();pe.initSync();var yLe=qu(),Xt=M(),Zn=W(),Mo=require("fs-extra"),Uo=require("path"),Spe=require("systeminformation"),Tpe=ZN(),{install:gpe}=lK(),NI=require("chalk"),Ape=Xl(),vo=te(),II=wt(),NK=ja(),OK=Om(),Rpe=TK(),ype=bK(),{compactOnStart:bpe}=(oO(),oe(iO)),Ope=require("minimist"),Npe=Xs(),{PACKAGE_ROOT:Ipe,CONFIG_PARAMS:Ce}=M(),{startHTTPThreads:wpe,startSocketServer:bLe,mostIdleRouting:OLe,remoteAffinityRouting:NLe}=(wI(),oe(MK)),Cpe=VS(),{isMainThread:Dpe}=require("worker_threads"),ILe=Zi(),wLe=ro(),CLe=mR(),DLe=w_(),QS=M(),$i,ld,IK=!1,Ppe="Upgrade complete. Starting HarperDB.",Lpe="Got an error while trying to upgrade your HarperDB instance. Exiting HarperDB.",Mpe="HarperDB not found, starting install process.",Upe="There was an error during install, check install_log.log for more details. Exiting.",vpe="HarperDB successfully started.";function Bpe(){if(!IK){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(Bpe,"addExitListeners");async function wK(e=!1,t=!1){if(console.log(NI.magenta("Starting HarperDB...")),Zn.suppressLogging?.(()=>{console.log(NI.magenta(""+Mo.readFileSync(Uo.join(Ipe,"utility/install/ascii_logo.txt"))))}),await DK()===!1){console.log(Mpe);try{await gpe()}catch(o){console.error(Upe,o),Zn.error(o),process.exit(1)}}if(!e){let o=NK(Object.keys(Xt.CONFIG_PARAM_MAP),!0);!vo.isEmpty(o)&&!vo.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 Mo.readFile(Uo.join(pe.get(Xt.CONFIG_PARAMS.ROOTPATH),Xt.HDB_PID_FILE),"utf8")),c=await Spe.processes();for(let l of c.list)if(l.pid===o){n?r=!0:console.log("HarperDB appears to be already running.");break}}catch{}$i===void 0&&($i=xu()),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 OK.generateNatsConfig(),await $i.startClusteringProcesses(!0),process.exit()),Bpe(),await Mo.writeFile(Uo.join(pe.get(QS.CONFIG_PARAMS.ROOTPATH),QS.HDB_PID_FILE),`${process.pid}`),Zn.info("HarperDB PID",process.pid);let s;try{let o=await Cpe.getVersionUpdateInfo();o!==void 0&&(s=o[Xt.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION],await Rpe.upgrade(o),console.log(Ppe))}catch(o){s?(console.error(`Got an error while trying to upgrade your HarperDB instance to version ${s}. Exiting HarperDB.`,o),Zn.error(o)):(console.error(Lpe,o),Zn.error(o)),process.exit(1)}Tpe(),kpe(),await Npe.reviewSelfSignedCert(),vo.autoCastBoolean(pe.get(Xt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&Dpe&&await OK.generateNatsConfig(t)}a(wK,"initialize");async function Hpe(e=!1){try{ld=Ope(process.argv),ld.ROOTPATH&&II.updateConfigObject("settings_path",Uo.join(ld.ROOTPATH,Xt.HDB_CONFIG_FILE)),await wK(e,!0),pe.get(Xt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await bpe();let t=process.env.IS_SCRIPTED_SERVICE&&!ld.service;vo.autoCastBoolean(pe.get(Xt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&(t||await $i.startClusteringProcesses(),await $i.startClusteringThreads()),await wpe(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 ype(),t||CK()}catch(t){console.error(t),Zn.error(t),process.exit(1)}}a(Hpe,"main");function CK(){Zn.suppressLogging(()=>{console.log(NI.magenta(`HarperDB ${Ape.version} successfully started`))}),Zn.notify(vpe)}a(CK,"started");async function xpe(e=!0){IK=!e;try{$i===void 0&&($i=xu()),$i.enterPM2Mode(),await wK(),vo.autoCastBoolean(pe.get(Xt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&await $i.startClusteringProcesses(),await $i.startService(Xt.PROCESS_DESCRIPTORS.HDB),CK(),e&&process.exit(0)}catch(t){console.error(t),Zn.error(t),process.exit(1)}}a(xpe,"launch");function kpe(){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}=NK(["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),Zn.error(s)}}a(kpe,"writeLicenseFromVars");Object.assign(PK,{launch:xpe,main:Hpe,isHdbInstalled:DK,startupLog:Fpe});async function DK(){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 Zn.error(`Error checking for HDB install - ${e}`),e}return!0}a(DK,"isHdbInstalled");function Fpe(e){let r=a(f=>f.padEnd(20),"pad"),n=`
114
114
  `;pe.get(Ce.REPLICATION_HOSTNAME)&&(n+=`${r("Hostname:")}${pe.get(Ce.REPLICATION_HOSTNAME)}
115
115
  `),pe.get(Ce.REPLICATION_URL)&&(n+=`${r("Replication Url:")}${pe.get(Ce.REPLICATION_URL)}
116
116
  `),n+=`${r("Worker Threads:")}${pe.get(Ce.THREADS_COUNT)}
@@ -126,8 +126,8 @@ Reindexing upgrade started for transaction logs`),Io.notify("Reindexing upgrade
126
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
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(Ce.LOGGING_STDSTREAMS)&&Zn.logsAtLevel("info")&&Zn.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(Fpe,"startupLog")});var xI=N(Bo=>{"use strict";var{isMainThread:CI,parentPort:wE,threadId:XS,workerData:Gpe}=require("worker_threads"),{Socket:qpe,createServer:$pe}=require("net"),{createServer:Vpe,IncomingMessage:Kpe}=require("http"),{createServer:Ype}=require("https"),{unlinkSync:FK,existsSync:Wpe}=require("fs"),Nn=W(),At=se(),Zt=M(),{server:CE}=(qr(),oe(Ja)),{WebSocketServer:jpe}=require("ws"),{createServer:zpe}=require("node:tls"),{getTicketKeys:Qpe,restartNumber:Jpe,getWorkerIndex:ud}=dt(),{Headers:DI,appendHeader:Xpe}=(Uf(),oe(zF)),{recordAction:OE,recordActionBinary:MK}=(Ii(),oe(k_)),{Request:GK,createReuseportFd:IE}=(vS(),oe(JN)),{checkMemoryLimit:Zpe}=_c(),{createTLSSelector:qK}=Xs(),{resolvePath:$K}=wt(),{startupLog:eme}=PK(),{Readable:UK}=require("node:stream"),tme=Ei(),VK=At.get(Zt.CONFIG_PARAMS.THREADS_DEBUG);if(VK){let e;if(CI)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&&ud()>=0&&(e=t+ud())}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&&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:MLe,CONFIG_PARAMS:rme}=Zt;At.initSync();var nme=At.get(rme.HTTP_SESSIONAFFINITY),Vi={},PI=new Map;Bo.registerServer=vI;Bo.httpServer=HI;Bo.deliverSocket=UI;Bo.startServers=KK;Bo.listenOnPorts=YK;Bo.globals=tme;Bo.when_components_loaded=null;CE.http=HI;CE.request=ime;CE.socket=ome;CE.ws=ame;CE.upgrade=zK;var NE={},JS={},ZS={},LI=[];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)UI(n,r,s);else if(t.requestId)sme(t);else if(t.type===Zt.ITC_EVENT_TYPES.SHUTDOWN){Nn.trace("received shutdown request",XS);for(let i in Vi){let o=Vi[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)&&Zn.logsAtLevel("info")&&Zn.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(Fpe,"startupLog")});var xI=N(Bo=>{"use strict";var{isMainThread:CI,parentPort:CE,threadId:XS,workerData:Gpe}=require("worker_threads"),{Socket:qpe,createServer:$pe}=require("net"),{createServer:Vpe,IncomingMessage:Kpe}=require("http"),{createServer:Ype}=require("https"),{unlinkSync:GK,existsSync:Wpe}=require("fs"),Nn=W(),At=se(),Zt=M(),{server:DE}=(qr(),oe(Ja)),{WebSocketServer:jpe}=require("ws"),{createServer:zpe}=require("node:tls"),{getTicketKeys:Qpe,restartNumber:Jpe,getWorkerIndex:ud}=dt(),{Headers:DI,appendHeader:Xpe}=(vf(),oe(QF)),{recordAction:NE,recordActionBinary:UK}=(Ii(),oe(F_)),{Request:qK,createReuseportFd:wE}=(vS(),oe(JN)),{checkMemoryLimit:Zpe}=_c(),{createTLSSelector:$K}=Xs(),{resolvePath:VK}=wt(),{startupLog:eme}=LK(),{Readable:vK}=require("node:stream"),tme=Ei(),KK=At.get(Zt.CONFIG_PARAMS.THREADS_DEBUG);if(KK){let e;if(CI)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&&ud()>=0&&(e=t+ud())}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&&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:MLe,CONFIG_PARAMS:rme}=Zt;At.initSync();var nme=At.get(rme.HTTP_SESSIONAFFINITY),Vi={},PI=new Map;Bo.registerServer=vI;Bo.httpServer=HI;Bo.deliverSocket=UI;Bo.startServers=YK;Bo.listenOnPorts=WK;Bo.globals=tme;Bo.when_components_loaded=null;DE.http=HI;DE.request=ime;DE.socket=ome;DE.ws=ame;DE.upgrade=QK;var IE={},JS={},ZS={},LI=[];function YK(){return Bo.when_components_loaded=nT().loadRootComponents(!0).then(()=>{CE?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)UI(n,r,s);else if(t.requestId)sme(t);else if(t.type===Zt.ITC_EVENT_TYPES.SHUTDOWN){Nn.trace("received shutdown request",XS);for(let i in Vi){let o=Vi[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(At.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&ud()==0)try{FK($K(At.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,XS),o.cantCleanupProperly||Nn.warn("Had to forcefully exit the thread",XS),process.exit(0)},5e3).unref()})}if(VK||process.env.DEV_MODE)try{require("inspector").close()}catch(i){Nn.info("Could not close debugger",i)}}}).ref();let e;IE&&!nme&&(e=YK()),Promise.resolve(e).then(()=>{if(ud()===0)try{eme(PI)}catch(t){console.error("Error displaying start-up log",t)}wE?.postMessage({type:Zt.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(KK,"startServers");function YK(){let e=[];for(let t in Vi){let r=Vi[t];if(t.includes?.("/")&&ud()==0){Wpe(t)&&FK(t),e.push(new Promise((o,c)=>{r.listen({path:t},()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),Nn.info("Domain socket listening on "+t)}).on("error",c)}));continue}let n,s=At.get(Zt.CONFIG_PARAMS.HTTP_THREADRANGE);if(s){let o=typeof s=="string"?s.split("-"):s,c=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(YK,"listenOnPorts");!CI&&!Gpe?.noServerStart&&KK();function UI(e,t,r){let n=e?.read?e:new qpe({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=Vi[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=Vi[t];c?(typeof c=="function"?c(n):c.emit("connection",n),r&&n.emit("data",r)):o<5?i(o+1):(Nn.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a(UI,"deliverSocket");var vK=new Map;function sme(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=vK.get(s),r){case"connection":i=UI(void 0,t),vK.set(s,i),i.write=(c,l,u)=>(wE.postMessage({requestId:s,event:"data",data:c.toString("latin1")}),u&&u(),!0),i.end=(c,l,u)=>(wE.postMessage({requestId:s,event:"end",data:c?.toString("latin1")}),u&&u(),!0);let o=i.destroy;i.destroy=()=>{o.call(i),wE.postMessage({requestId:s,event:"destroy"})};break;case"data":i._readableState.destroyed||i.emit("data",Buffer.from(n,"latin1"));break;case"drain":i._readableState.destroyed||i.emit("drain",{});break;case"end":i._readableState.destroyed||i.emit("end",{});break;case"error":i._readableState.destroyed||i.emit("error",{});break}}a(sme,"proxyRequest");var{getComponentName:eT}=(Jf(),oe(Qf));function vI(e,t,r=!0){t||(t=At.get(Zt.CONFIG_PARAMS.HTTP_PORT));let n=Vi[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 Vi[t]=e;e.on("unhandled",kK)}a(vI,"registerServer");function BI(e){let t=[],r=e?.securePort;return r&&t.push({port:r,secure:!0}),r=e?.port,r&&t.push({port:r,secure:!1}),t.length===0&&(t=[],At.get(Zt.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:At.get(Zt.CONFIG_PARAMS.HTTP_PORT),secure:At.get(Zt.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),At.get(Zt.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:At.get(Zt.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&At.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:$K(At.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)),secure:!1}),t}a(BI,"getPorts");function HI(e,t){let r=[];for(let{port:n,secure:s}of BI(t))r.push(WK(n,s,t?.isOperationsServer,t?.mtls)),typeof e=="function"?LI[t?.runFirst?"unshift":"push"]({listener:e,port:t?.port||n}):(e.isSecure=s,vI(e,n,!1)),ZS[n]=rT(LI,n);return r}a(HI,"httpServer");function tT(e,t){let r=PI.get(e)??[];PI.set(e,[...r,t])}a(tT,"setPortServerMap");function WK(e,t,r,n){if(tT(e,{protocol_name:t?"HTTPS":"HTTP",name:eT()}),!JS[e]){let s=r?"operationsApi_network":"http",i=At.get(s+"_keepAliveTimeout"),o=At.get(s+"_timeout"),c=At.get(s+"_headersTimeout"),l={noDelay:!0,keepAliveTimeout:i,headersTimeout:c,requestTimeout:o,highWaterMark:128*1024,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,maxHeaderSize:At.get(Zt.CONFIG_PARAMS.HTTP_MAXHEADERSIZE)},u=At.get(s+"_mtls"),d=At.get(s+"_mtls_required");t&&Object.assign(l,{allowHTTP1:!0,rejectUnauthorized:!!d,requestCert:!!(u||n),ticketKeys:Qpe(),SNICallback:qK(r?"operations-api":"server",u),ALPNCallback:a(function(f){return f.protocols.includes("harperdb-replication")&&(this.isReplicationConnection=!0),"http/1.1"},"ALPNCallback"),ALPNProtocols:null});let _=Zpe(),E=JS[e]=(t?Ype:Vpe)(l,async(f,h)=>{try{let m=performance.now(),g=new GK(f,h);r&&(g.isOperationsServer=!0);let S=await ZS[e](g);if(!S){if(g._nodeResponse.statusCode)return;S=jK(g)}if(S.headers?.set||(S.headers=new DI(S.headers)),_?S.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):S.headers?.set?.("Server","HarperDB"),S.status===-1){for(let ne of S.headers||[])h.setHeader(ne[0],ne[1]);return f.baseRequest=g,h.baseResponse=S,JS[e].emit("unhandled",f,h)}let y=S.status||200,I=performance.now(),U=I-m,H=S.body,X;if(!S.handlesHeaders){let ne=S.headers||new DI;H?H.length>=0&&(typeof H=="string"?ne.set("Content-Length",Buffer.byteLength(H)):ne.set("Content-Length",H.length),X=!0):(ne.set("Content-Length","0"),X=!0);let Q=`hdb;dur=${U.toFixed(2)}`;S.wasCacheMiss&&(Q+=", miss"),Xpe(ne,"Server-Timing",Q,!0),h.headersSent||h.writeHead(y,ne&&(ne[Symbol.iterator]?Array.from(ne):ne)),X&&h.end(H)}let Y=g.handlerPath,V=g.method;if(OE(U,"duration",Y,V,S.wasCacheMiss==null?void 0:S.wasCacheMiss?"cache-miss":"cache-hit"),MK(y<400,"success",Y,V),MK(1,"response_"+y,Y,V),!X)if(H instanceof ReadableStream&&(H=UK.fromWeb(H)),(H[Symbol.iterator]||H[Symbol.asyncIterator])&&(H=UK.from(H)),H?.pipe){H.pipe(h),H.destroy&&h.on("close",()=>{H.destroy()});let ne=0;H.on("data",Q=>{ne+=Q.length}),H.on("end",()=>{OE(performance.now()-I,"transfer",Y,V),OE(ne,"bytes-sent",Y,V)})}else H?.then?H.then(ne=>{h.end(ne)},T):h.end(H)}catch(m){T(m)}function T(m){let g=m.headers;h.writeHead(m.statusCode||500,g&&(g[Symbol.iterator]?Array.from(g):g)),h.end(m.toString()),m.statusCode?m.statusCode===500?Nn.warn(m):Nn.info(m):Nn.error(m)}a(T,"onError")});i>=0&&(E.keepAliveTimeout=i),c>=0&&(E.headersTimeout=c),t&&(E.ports||(E.ports=[]),E.ports.push(e),l.SNICallback.initialize(E),u&&(E.mtlsConfig=u),E.on("secureConnection",f=>{f._parent.startTime&&OE(performance.now()-f._parent.startTime,"tls-handshake",e),OE(f.isSessionReused(),"tls-reused",e)}),E.isSecure=!0),vI(E,e)}return JS[e]}a(WK,"getHTTPServer");function rT(e,t){let r=jK;for(let n=e.length;n>0;){let{listener:s,port:i}=e[--n];if(i===t||i==="all"){let o=r;r=a((...c)=>s(...c,o),"next_callback")}}return r}a(rT,"makeCallbackChain");function jK(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new DI}}a(jK,"unhandled");function ime(e,t){HI(e,{requestOnly:!0,...t})}a(ime,"onRequest");function ome(e,t){let r;if(t.securePort){tT(t.securePort,{protocol_name:"TLS",name:eT()});let n=qK("server",t.mtls);r=zpe({rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,SNICallback:n},e),n.initialize(r),Vi[t.securePort]=r}return t.port&&(tT(t.port,{protocol_name:"TCP",name:eT()}),r=$pe(e,{noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600}),Vi[t.port]=r),r}a(ome,"onSocket");Object.defineProperty(Kpe.prototype,"upgrade",{get(){return"connection"in this.headers&&"upgrade"in this.headers&&this.headers.connection.toLowerCase().includes("upgrade")&&this.headers.upgrade.toLowerCase()=="websocket"},set(e){}});var BK=[],MI={};function zK(e,t){for(let{port:r}of BI(t))BK[t?.runFirst?"unshift":"push"]({listener:e,port:r}),MI[r]=rT(BK,r)}a(zK,"onUpgrade");var HK=[],xK={};function ame(e,t){let r=[];for(let{port:n,secure:s}of BI(t)){tT(n,{protocol_name:s?"WSS":"WS",name:eT()});let i=WK(n,s,t?.isOperationsServer,t?.mtls);NE[n]||(NE[n]=new jpe({noServer:!0,maxPayload:t.maxPayload??100*1024*1024}),NE[n].on("connection",(o,c)=>{let l=new GK(c);l.isWebSocket=!0;let u=ZS[n](l);xK[n](o,l,u)}),zK((o,c,l,u)=>o.__harperdb_request_upgraded?u(o,c,l):NE[n].handleUpgrade(o,c,l,d=>{o.__harperdb_request_upgraded=!0,u(o,c,l),NE[n].emit("connection",d,o)}),{port:n}),i.on("upgrade",(o,c,l)=>{MI[n]&&MI[n](o,c,l)})),r.push(i),HK[t?.runFirst?"unshift":"push"]({listener:e,port:n}),xK[n]=rT(HK,n),ZS[n]=rT(LI,n)}return r}a(ame,"onWebSocket");function kK(e,t){t.writeHead(404),t.end(`Not found
133
- `)}a(kK,"defaultNotFound")});var LK={};je(LK,{startHTTPThreads:()=>lme,startSocketServer:()=>$I,updateWorkerIdleness:()=>nY});async function lme(e=2,t){try{if(t)GI(0,1,!0);else{let{loadRootComponents:r}=nT();if(e===0)return(0,Ds.setMainIsWorker)(!0),await xI().startServers(),Promise.resolve([]);await r()}rY();for(let r=0;r<e;r++)GI(r,e);return Promise.all(tY)}finally{(0,Ds.threadsHaveStarted)()}}function rY(){let e=(0,ZK.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),FI=setInterval(()=>{oT.notify(e)},cme).unref())}function GI(e,t=1,r){if(kI++,(0,Ds.startWorker)("server/threads/threadServer.js",{name: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)});tY.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)eY[c.localPort](null,c)}}}),r){let n=setInterval(()=>{qI?qI=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,Ds.shutdownWorkers)(),kI=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function $I(e=0,t){if(typeof e=="string")try{(0,aT.existsSync)(e)&&(0,aT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=ume:r=dme(t):r=VI;let n=(0,fd.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);if(n._handle){n._handle.onconnection=eY[e]=function(i,o){r.readsData||(o.reading=!1,o.readStop()),qI=!0,r(o,(c,l)=>{if(!c){if(QK){let d=o._socket||new fd.Socket({handle:o,writable:!0,readable:!0});QK.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});Eme(d,c,e)}pr(!0,"socket-routed")})};let s=Xl();oT.info(`HarperDB ${s.version} Server running on port ${e}`)}return n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function VI(e,t){let r,n=0;for(let s of 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 ume(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 dme(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 nY(){sT=0;for(let e of dd)e.expectedIdle=e.recentELU.idle+_me,e.requests=1;dd.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function Eme(e,t,r){let n=fme++;t.postMessage({port:r,requestId:n,event:"connection"}),e.on("data",s=>{let i=s.toString("latin1");t.postMessage({port:r,requestId:n,data:i,event:"data"})}).on("close",s=>{t.postMessage({port:r,requestId:n,event:"close",hadError:s})}).on("error",s=>{t.postMessage({port:r,requestId:n,event:"error",error:s})}).on("drain",s=>{t.postMessage({port:r,requestId:n,event:"drain",error:s})}).on("end",()=>{t.postMessage({port:r,requestId:n,event:"end"})}).resume(),iT.set(n,s=>{s.event=="data"&&e.write(Buffer.from(s.data,"latin1")),s.event=="end"&&(e.end(s.data&&Buffer.from(s.data,"latin1")),iT.delete(n)),s.event=="destroy"&&(e.destroy(),iT.delete(n))})}var Ds,fd,hd,oT,aT,XK,ZK,dd,_d,eY,QK,kI,tY,FI,cme,qI,sT,JK,Ed,_me,iT,fme,wI=Ie(()=>{Ds=L(dt()),fd=require("net"),hd=L(M()),oT=L(W()),aT=require("fs");Ii();XK=require("worker_threads"),ZK=L(_c()),dd=[],_d=[],eY=[],kI=0,tY=[];XK.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,Ds.onMessageFromWorkers)(e=>{e.type===hd.ITC_EVENT_TYPES.RESTART&&FI&&(clearInterval(FI),rY())}));cme=6e5;a(lme,"startHTTPThreads");a(rY,"licenseWarning");a(GI,"startHTTPWorker");a($I,"startSocketServer");sT=0;a(VI,"findMostIdleWorker");JK=36e5,Ed=new Map;a(ume,"findByRemoteAddressAffinity");a(dme,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of Ed)r.lastUsed+JK<e&&Ed.delete(t)},JK).unref();_me=1e3;a(nY,"updateWorkerIdleness");(0,Ds.setMonitorListener)(nY);iT=new Map,fme=1;a(Eme,"proxySocket")});var aY=N(($Le,oY)=>{"use strict";var hme=require("cluster"),ml=se();ml.initSync();var iY=M(),xLe=require("util"),Ho=W(),kLe=require("fs"),pme=require("fastify"),FLe=Xl(),mme=require("@fastify/cors"),Sme=require("@fastify/compress"),Tme=require("@fastify/static"),gme=FN(),Ame=require("path"),{PACKAGE_ROOT:Rme}=M(),yme=us(),bme=te(),Ome=xn(),Nme=_c(),{server:Ime}=(qr(),oe(Ja)),{node_request_key:GLe}=(vS(),oe(JN)),{authHandler:wme,handlePostRequest:Cme,serverErrorHandler:Dme,reqBodyValidationHandler:Pme}=LS(),qLe=require("net"),{registerContentHandlers:Lme}=(zc(),oe($$)),Mme=6e4,Ume=1024*1024*1024,vme="TRUE",{CONFIG_PARAMS:DE}=iY,pd;oY.exports={hdbServer:sY,start:sY};async function sY(e){try{Ho.debug("In Fastify server"+process.cwd()),Ho.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Ho.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=hme.isMaster,await Bme();let t=e.securePort>0;pd=Hme(t),await pd.ready(),e||(e={}),e.isOperationsServer=!0;try{Ime.http(pd.server,e),pd.server.closeIdleConnections||await pd.listen({port:0,host:"::"})}catch(r){throw pd.close(),Ho.error(r),Ho.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),Ho.fatal(t),process.exit(1)}}a(sY,"operationsServer");async function Bme(){Ho.trace("Configuring HarperDB process."),yme.setSchemaDataToGlobal(),await Ome.setUsersToGlobal(),await Nme.getLicense()}a(Bme,"setUp");function Hme(e){Ho.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=xme(e),r=pme(t);r.server.headersTimeout=Fme(),r.setErrorHandler(Dme);let n=kme();n&&r.register(mme,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,u){r.server.emit("unhandled",l.raw,u.raw)}),c()}),r.register(gme),r.register(Sme),r.register(Tme,{root:Ame.join(Rme,"studio/build-local")}),Lme(r);let s=ml.get(iY.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!bme.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[Pme,wme],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),Cme(i,o)}),r.get("/health",()=>"HarperDB is running."),Ho.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(Hme,"buildServer");function xme(e){let t=ml.get(DE.OPERATIONSAPI_NETWORK_TIMEOUT),r=ml.get(DE.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:Ume,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(xme,"getServerOptions");function kme(){let e=ml.get(DE.OPERATIONSAPI_NETWORK_CORS),t=ml.get(DE.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===vme)&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},t&&t.length>0&&t[0]!==null&&t[0]!=="*"&&(r.origin=(n,s)=>s(null,t.indexOf(n)!==-1))),r}a(kme,"getCORSOpts");function Fme(){return ml.get(DE.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??Mme}a(Fme,"getHeaderTimeoutConfig")});var QI={};je(QI,{disableNATS:()=>qme,publishToStream:()=>uT,setNATSReplicator:()=>KI,setPublishToStream:()=>$me,setSubscription:()=>zI,start:()=>Gme});function Gme(){PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_ENABLED)&&Kme()}function qme(e=!0){_Y=e}function $me(e,t){uT=e,zI=t}function Kme(){if(_Y||process.env._DISABLE_NATS)return;let e=ut(),t=Object.keys(e);t.push("system");for(let r of t){let n=e[r];for(let s in n){let i=n[s];KI(s,r,i)}}Lc((r,n)=>{KI(r.tableName,r.databaseName,r),n&&EY(r)}),!cY&&(cY=!0)}function KI(e,t,r){if(t==="system"&&Yme.includes(e))return;if(!r)return console.error(`Attempt to replicate non-existent table ${e} from database ${t}`);if(r.sources.some(s=>s?.isNATSReplicator))return;r.sourcedFrom(class extends Lr{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this[ze],record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this[ze]})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this[ze],record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this[ze],record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this[ze]})}static defineSchema(i){EY(i)}static subscribe(){let i=new Mn;return zI(t,e,i),i}static subscribeOnThisThread(i){return i<(PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??Vme)}static isEqual(i){return i.isNATSReplicator}static isNATSReplicator=!0;static shouldReceiveInvalidations=!0},{intermediateSource:!0});function n(s){let i=s?.transaction?.nats;if(!i)if(s?.transaction){s.transaction.nats=i=new cT(s.transaction,s);let o=s.transaction;for(;o.next;)o=o.next;o.next=s.transaction.nats,i.user=s.user,i.context=s}else i=fY;return i}a(n,"getNATSTransaction")}function EY(e){let t=PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_NODENAME);uT(`${WI.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,jI.createNatsTableStreamName)(e.databaseName,e.tableName),void 0,{operation:"define_schema",schema:e.databaseName,table:e.tableName,attributes:e.attributes,__origin:{timestamp:Date.now(),node_name:t}})}var lY,WI,jI,uY,dY,PE,LE,lT,_Y,uT,zI,Vme,fY,cY,Yme,cT,YI,hY=Ie(()=>{Pe();Vs();lY=L(mr()),WI=L(Ct()),jI=L(to());Ll();uY=L(ey()),dY=L(cn()),PE=L(se()),LE=L(M()),lT=L(W());a(Gme,"start");a(qme,"disableNATS");uT=lY.publishToStream,zI=uY.setSubscription;a($me,"setPublishToStream");Vme=2;a(Kme,"assignReplicationSource");Yme=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(KI,"setNATSReplicator");a(EY,"publishSchema");cT=class{constructor(t,r){this.transaction=t;this.options=r}static{a(this,"NATSTransaction")}user;writes_by_db=new Map;addWrite(t,r){r.expiresAt=this.context?.expiresAt;let n=this.writes_by_db.get(t);n||this.writes_by_db.set(t,n=[]),n.push(r)}commit({timestamp:t}){let r=PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],l,u;for(let d of i){let _=d.table,E=d.operation=="put"?"upsert":d.operation;l||(lT.trace(`Sending transaction event ${E}`),u=l={operation:E,schema:s,table:_,__origin:{user:this.user?.username,timestamp:t,node_name:r}},l.hash_values=c,E!=="delete"&&E!=="invalidate"&&(l.records=o)),l.table===_&&l.operation===E?(o.push(d.record),c.push(d.id)):u=u.next={operation:E,table:_,id:d.id,record:d.record},d.expiresAt&&(u.expiresAt=d.expiresAt)}l&&n.push(uT(`${WI.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,jI.createNatsTableStreamName)(s,l.table),void 0,l)?.catch(d=>{throw lT.error("An error has occurred trying to replicate transaction",l,d),d.statusCode=504,d}))}return Promise.all(n)}},YI=class extends cT{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,dY.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};fY=new YI});async function gY({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await JI.get(e,{returnNonexistent:!0});i=new ew(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await JI.get(e);o&&o.delete()}i=new _T(e,t)}return n&&(n.id=e,n.user={username:t?.username},ME.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function XI(){return dT++,dT>65500&&(dT=1),dT}function ZI(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=Ci.getMatch(n,"mqtt");if(!i)throw new Error(`Can not publish to topic ${n} as it does not exist, no resource has been defined to handle this topic`);e.url=i.relativeURL;let o=i.Resource;return Dt(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var mY,Ua,SY,TY,pY,JI,ME,dT,_T,ew,AY=Ie(()=>{Pe();su();mY=L(cn()),Ua=L(W());Sc();SY=L(dt()),TY=L(xI());qr();pY=100,JI=Et({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),ME=Et({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,SY.getWorkerIndex)()===0&&(async()=>{await TY.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of ME.search({})){let t=e.data,r={...e};r.user?.username&&(r.user=await it.getUser(r.user.username));try{await ZI(r,t,r)}catch{(0,Ua.warn)("Failed to publish will",t)}ME.delete(e.id)}})();a(gY,"getSession");dT=1;a(XI,"getNextMessageId");_T=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;request;socket;subscriptions=[];awaitingAcks;sessionWasPresent;keepalive;keepaliveTimer;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),l,u;if(c>-1?(l=s.slice(c),u=s.slice(0,c)):u=s,!u)throw new Error("No topic provided");if(u.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let d=this.subscriptions.find(g=>g.topic===s),_;d?(_=i>0,d.end(),this.subscriptions.splice(this.subscriptions.indexOf(d),1)):_=i===2;let E={search:l,async:!0,user:this.user,startTime:o,omitCurrent:_,url:""};o&&(0,Ua.trace)("Resuming subscription from",s,"from",o);let f=Ci.getMatch(u,"mqtt");if(!f){let g=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw g.statusCode=404,g}if(E.url=f.relativeURL,E.url.indexOf("+")>-1||E.url.indexOf("#")>-1){let g=E.url.slice(1);if(g.indexOf("#")>-1&&g.indexOf("#")!==g.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(E.isCollection=!0,g.indexOf("+")===g.length-1)E.onlyChildren=!0,E.url="/"+g.slice(0,g.length-1);else{let S=g.split("/"),y;for(let H=0;H<S.length;H++)if(S[H].indexOf("+")>-1)if(S[H]==="+")y=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&y)throw new Error("Filters can not be combined");let I=!0;S[S.length-1]==="#"&&(S.length--,I=!1),y&&(n=a(H=>{let X=H.id;if(!Array.isArray(X))if(X?.indexOf?.("/")>-1)X=X.split("/");else return!1;if(I&&X.length!==S.length)return!1;for(let Y=0;Y<S.length;Y++)if(S[Y]!=="+"&&S[Y]!==X[Y])return!1;return!0},"filter"));let U=S.indexOf("+");E.url="/"+(U>-1?S.slice(0,U):S).concat("").join("/")}}let h=f.path,T=f.Resource,m=await Dt(E,async()=>{let g=this.createContext();g.topic=s,g.retainHandling=i;let S=await T.subscribe(E,g);if(!S)return;if(!S[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let y=(async()=>{for await(let I of S)try{let U;if(I.type&&I.type!=="put"&&I.type!=="delete"&&I.type!=="message"&&I.type!=="patch"||n&&!n(I))continue;r?(I.topic=s,U=this.needsAcknowledge(I)):(I.acknowledge?.(),U=XI());let H=I.id;if(Array.isArray(H)&&(H=nu(H)),H==null&&(H=""),await this.listener(h+"/"+H,I.value,U,t)===!1)break;this.awaitingAcks?.size>pY?await new Promise(Y=>setTimeout(Y,this.awaitingAcks.size-pY)):await new Promise(setImmediate)}catch(U){(0,Ua.warn)(U)}})();return S});if(m)return m.topic=s,m.qos=t.qos,this.subscriptions.push(m),m}resume(){}needsAcknowledge(t){let r=XI();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,{acknowledge:t.acknowledge})),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r.acknowledge())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),this.subscriptions.splice(this.subscriptions.indexOf(r),1),!0}async publish(t,r){return ZI(t,r,this.createContext())}createContext(){let t={session:this,socket:this.socket,user:this.user,authorize:!0};return this.request&&(t.request=this.request,t.url=this.request.url,t.headers=this.request.headers),t}setListener(t){this.listener=t}disconnect(t){this.keepaliveTimer&&clearTimeout(this.keepaliveTimer);let r=this.createContext();Dt(r,async()=>{try{if(!t){let n=await ME.get(this.sessionId);n?.doesExist()&&await ZI(n,n.data,r)}}finally{await ME.delete(this.sessionId)}}).catch(n=>{(0,Ua.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}receivedPacket(){this.keepalive&&(clearTimeout(this.keepaliveTimer),this.keepaliveTimer=setTimeout(()=>{this.socket?.destroy?this.socket.destroy(new Error("Keepalive timeout")):this.socket?.terminate()},this.keepalive*1500))}};a(ZI,"publish");ew=class extends _T{static{a(this,"DurableSubscriptionsSession")}sessionRecord;constructor(t,r,n){super(t,r),this.sessionRecord=n||{id:t,subscriptions:[]}}async resume(){for(let t of this.sessionRecord.subscriptions||[])await this.resumeSubscription({omitCurrent:!0,topic:t.topic,qos:t.qos,startTime:t.startTime},!0,t.acks?r=>!t.acks.includes(r.localTime):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=XI(),n={topic:t.topic,timestamp:t.localTime};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks?.get(t);if(!r)return;this.awaitingAcks?.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,Ua.trace)("Received ack",n,r.timestamp),this.sessionRecord.update();return}}for(let s of this.sessionRecord.subscriptions)s.topic===n&&(s.startTime=r.timestamp);this.sessionRecord.update()}async addSubscription(t,r){await this.resumeSubscription(t,r);let{qos:n,startTime:s}=t;return n>0&&!s&&this.saveSubscriptions(),t.qos}removeSubscription(t){let r=this.subscriptions.find(s=>s.topic===t),n=super.removeSubscription(t);return r.qos>0&&this.saveSubscriptions(),n}saveSubscriptions(){this.sessionRecord.subscriptions=this.subscriptions.map(t=>{let r=t.startTime;return r||(r=t.startTime=(0,mY.getNextMonotonicTime)()),(0,Ua.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),JI.put(this.sessionRecord)}}});var rw={};je(rw,{bypassAuth:()=>Wme,start:()=>jme});function Wme(){NY=!0}function jme({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new OY.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c=[],l=r?.mtls;return n&&(c=e.ws((u,d,_,E)=>{if(d.headers.get("sec-websocket-protocol")!=="mqtt")return E(u,d,_);o.events.emit("connection",u),dr.debug?.("Received WebSocket connection for MQTT from",u._socket.remoteAddress);let{onMessage:f,onClose:h}=yY(u,T=>{u.send(T)},d,Promise.resolve(_).then(()=>d?.user),o);u.on("message",f),u.on("close",h),u.on("error",T=>{dr.info?.("WebSocket error",T)})},{...n})),(t||s)&&c.push(e.socket(async u=>{let d;if(o.events.emit("connection",u),dr.debug?.(`Received ${u.getCertificate?"SSL":"TCP"} connection for MQTT from ${u.remoteAddress}`),l){if(u.authorized)try{let f=l.user;if(f!==null){(f===void 0||f==="Common Name"||f==="CN")&&(f=u.getPeerCertificate().subject.CN);try{d=await e.getUser(f,null,null),(0,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&&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,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=gY({user:n,..._}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(V){return dr.error?.(V),s.events.emit("auth-failed",_,e,V),qn(!1,"connection","mqtt","connect"),m({cmd:"connack",reasonCode:V.code||5,returnCode:V.code||128})}s.events.emit("connected",o,e),qn(!0,"connection","mqtt","connect"),m({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0}),o.setListener((V,ne,Q,de)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",V);let j=V.indexOf("/",1),ae=j>0?V.slice(0,j):V;m({cmd:"publish",topic:V,payload:S(ne),messageId:Q||Math.floor(Math.random()*1e8),qos:de.qos},ae);let Oe=e._socket??e;return Oe.writableNeedDrain?new Promise(Ne=>Oe.once("drain",Ne)):!Oe.closed}catch(j){return dr.error?.(j),o?.disconnect(),s.sessions.delete(o),!1}}),o.sessionWasPresent&&await o.resume();break;case"subscribe":let y=[];for(let V of _.subscriptions){let ne;try{let Q=await o.addSubscription(V,V.qos>=1);ne=Q?Q.qos||0:c.protocolVersion<5?128:143}catch(Q){s.events.emit("error",Q,e,V,o),Q.statusCode?Q.statusCode===500?dr.warn?.(Q):dr.info?.(Q):dr.error?.(Q),ne=c.protocolVersion<5?128:Q.statusCode===403?135:Q.statusCode===404?143:128}y.push(ne)}await o.committed,m({cmd:"suback",granted:y,messageId:_.messageId});break;case"unsubscribe":{let V=[];for(let ne of _.unsubscriptions)V.push(o.removeSubscription(ne)?0:17);m({cmd:"unsuback",granted:V,messageId:_.messageId});break}case"pubrel":m({cmd:"pubcomp",messageId:_.messageId,reasonCode:0});return;case"publish":let I=_.qos===2?"pubrec":"puback",U=e.deserialize||(e.deserialize=bo(r?.headers.get?.("content-type"))),X=(_.payload?.length||0)>0?U(_.payload):void 0,Y;try{Y=await o.publish(_,X)}catch(V){s.events.emit("error",V,e,_,o),dr.warn?.(V),_.qos>0&&m({cmd:I,messageId:_.messageId,reasonCode:128},_.topic);break}_.qos>0&&m({cmd:I,messageId:_.messageId,reasonCode:Y===!1?144:0},_.topic);break;case"pubrec":m({cmd:"pubrel",messageId:_.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(_.messageId);break;case"pingreq":m({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),qn(!0,"connection","mqtt","disconnect"),dr.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(y){s.events.emit("error",y,e,_,o),dr.error?.(y),m({cmd:"disconnect"})}function m(y,I){let U=(0,hT.generate)(y,c);t(U),pr(U.length,"bytes-sent",I,g(y),"mqtt")}a(m,"sendPacket");function g(y){return y.qos>0?y.cmd+",qos="+y.qos:y.cmd}a(g,"packetMethodName");function S(y){return jc(y,r)}a(S,"serialize")}),l.on("error",_=>{dr.warn("MQTT parsing error, closing connection:",_.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:u,onClose:d}}var hT,bY,md,kr,tw,OY,ET,dr,NY,RY,fT,IY=Ie(()=>{hT=require("mqtt-packet");AY();bY=L(xn());zc();Ii();qr();md=L(se()),kr=L(M()),tw=L(Oc()),OY=require("events"),ET=(0,tw.loggerWithTag)("auth-event"),dr=(0,tw.loggerWithTag)("mqtt"),NY=(0,md.get)(kr.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(Wme,"bypassAuth");a(jme,"start");fT=0;a(yY,"onSocket")});var Qf={};je(Qf,{component_errors:()=>Td,getComponentName:()=>Zme,loadComponent:()=>ST,loadComponentDirectories:()=>UY,setErrorReporter:()=>Xme});function UY(e,t){t&&(sw=t),e&&(iw=e);let r=[];if((0,Nt.existsSync)(nw)){let s=(0,Nt.readdirSync)(nw,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,Ot.join)(nw,o);r.push(ST(c,sw,"hdb",!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(ST(n,sw,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{MY=!0})}function Xme(e){UE=e}async function ST(e,t,r,n,s,i){let o=(0,Nt.realpathSync)(e);if(pT.has(o))return pT.get(o);pT.set(o,!0),s&&(iw=s);try{let c;n&&(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,CY.parseDocument)((0,Nt.readFileSync)(l,"utf8")).toJSON():c=ow;let u=(0,Ot.join)(e,"node_modules","harperdb");try{Sl.isMainThread&&(n||(0,Nt.existsSync)(u)&&(0,Nt.realpathSync)(Ad.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)(Ad.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,U;for(;!(0,Nt.existsSync)(U=(0,Ot.join)(I,"node_modules",E));)if(I=(0,Ot.dirname)(I),I.length<(0,LY.getHdbBasePath)().length){U=null;break}if(U)h=await ST(U,t,r,!1),_=!0;else throw new Error(`Unable to find package ${E}:${T}`)}else h=Jme[E];if(!h)continue;let m=a(I=>(I.origin=r,Et(I)),"ensureTable"),g=f.network||(f.port||f.securePort)&&f,S=g?.securePort||g?.https&&g.port,y=!g?.https&&g?.port;if(Sl.isMainThread&&(h=await h.startOnMainThread?.({server:it,ensureTable:m,port:y,securePort:S,resources:t,...f})||h,n&&g))for(let I of[y,S])try{if(+I&&!wY.includes(I)){let U=aw.get(Ad.CONFIG_PARAMS.HTTP_SESSIONAFFINITY);U&&Sd.default.warn("Session affinity is not recommended and may cause memory leaks"),(U||!US)&&(wY.push(I),$I(I,U))}}catch(U){console.error("Error listening on socket",I,U,E)}if(t.isWorker&&(h=await h.start?.({server:it,ensureTable:m,port:y,securePort:S,resources:t,...f})||h),iw.set(h,!0),(h.handleFile||h.handleDirectory||h.setupFile||h.setupDirectory)&&f.files!=null){if(f.files.includes(".."))throw(0,PY.handleHDBError)("Can not reference parent directories");let I=(0,Ot.join)(e,f.files).replace(/\\/g,"/"),U=I.indexOf("/*");if(U>-1&&f.files!==ow[E]?.files&&!(0,Nt.existsSync)(I.slice(0,U)))throw new Error(`The path '${I.slice(0,U)}' does not exist and cannot be used as the base of the resolved 'files' path value '${f.files}'`);let H=(0,Ot.basename)(e),X=f.path||"/";X=X.startsWith("/")?X:X.startsWith("./")?"/"+H+X.slice(2):X==="."?"/"+H:"/"+H+"/"+X;let Y,V,ne;if(f.root){let de=f.root;de.startsWith("/")&&(de=de.slice(1)),de.endsWith("/")&&(de=de.slice(0,-1)),de+="/",V=(0,Ot.join)(e,de)}else(ne=I.indexOf("/*"))>-1?(V=I.slice(0,ne+1),Y=(0,Ot.relative)(e,V)):f.files.indexOf("/")>-1&&(V=I.slice(0,I.lastIndexOf("/")+1),Y=(0,Ot.relative)(e,V));let Q=!1;if(Sl.isMainThread&&h.setupDirectory&&(Q=await h.setupDirectory?.(X,V,t)),t.isWorker&&h.handleDirectory&&(Q=await h.handleDirectory?.(X,V,t)),Q){_=!0;continue}for(let de of await(0,DY.default)(I,{onlyFiles:!1,objectMode:!0})){let{path:j,dirent:ae}=de;_=!0;let Oe=(0,Ot.relative)(e,j).replace(/\\/g,"/");if(Y)if(Oe.startsWith(Y))Oe=Oe.slice(Y.length+1);else throw new Error(`The root path '${f.root}' does not reference a valid part of the file path '${Oe}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let Ne=X+(X.endsWith("/")?"":"/")+Oe;try{if(ae.isFile()){let Me=await Qme(j);Sl.isMainThread&&await h.setupFile?.(Me,Ne,j,t),t.isWorker&&await h.handleFile?.(Me,Ne,j,t)}else Sl.isMainThread&&await h.setupDirectory?.(Ne,j,t),t.isWorker&&await h.handleDirectory?.(Ne,j,t)}catch(Me){Me.message=`Could not load ${ae.isFile()?"file":"directory"} '${j}'${f.module?" using '"+f.module+"'":""} for application '${e}' due to: ${Me.message}`,UE?.(Me),((0,gd.getWorkerIndex)()===0?console:Sd.default).error(Me),t.set(f.path||"/",new ea(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 ea(m),null,!0),Td.set(n?E:(0,Ot.basename)(e),m.message)}}if(mT=d,Sl.isMainThread&&!MY&&i&&(0,gd.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,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 ea(c))}}var Nt,Ot,Sl,CY,aw,Ad,DY,gd,Sd,PY,LY,zme,TT,Qme,nw,iw,MY,sw,Td,Jme,ow,wY,pT,UE,mT,Zme,Jf=Ie(()=>{Nt=require("fs"),Ot=require("path"),Sl=require("worker_threads"),CY=require("yaml"),aw=L(se()),Ad=L(M());ND();Z$();nV();aV();cV();RV();t1();a1();DY=L(require("fast-glob")),gd=L(dt()),Sd=L(W());bN();qr();PY=L(_e());Pe();wI();LY=L(se()),zme=L(aY());km();hY();ds();IY();TT=L(wt());vS();fy();({readFile:Qme}=Nt.promises),nw=(0,TT.resolvePath)(aw.get(Ad.CONFIG_PARAMS.COMPONENTSROOT)),iw=new Map,Td=new Map;a(UY,"loadComponentDirectories");Jme={REST:CS,rest:CS,graphql:RN,graphqlSchema:Pg,roles:yN,jsResource:NN,fastifyRoutes:YN,login:wN,static:WN,operationsApi:zme,customFunctions:{},http:{},clustering:QI,replication:ca,authentication:vf,mqtt:rw},ow={rest:!0,graphql:!0,graphqlSchema:{files:"*.graphql"},roles:{files:"roles.yaml"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(ow,"static",{value:{files:"web/**"}});wY=[],pT=new Map;a(Xme,"setErrorReporter");Zme=a(()=>mT,"getComponentName");a(ST,"loadComponent")});var nT=N((mMe,BY)=>{var{isMainThread:vY}=require("worker_threads"),{getTables:eSe,getDatabases:hMe,table:pMe}=(Pe(),oe(lt)),{loadComponentDirectories:tSe,loadComponent:rSe}=(Jf(),oe(Qf)),{resetResources:nSe}=(su(),oe(sB)),sSe=SO(),iSe=wt(),{dirname:oSe}=require("path"),{getConnection:aSe}=mr(),cSe=se(),{CONFIG_PARAMS:lSe}=M(),{loadCertificates:uSe}=Xs(),cw=new Map;async function dSe(e=!1){!vY&&cSe.get(lSe.CLUSTERING_ENABLED)&&aSe();try{vY&&await sSe()}catch(n){console.error(n)}let t=nSe();eSe(),t.isWorker=e,await uSe(),await rSe(oSe(iSe.getConfigFilePath()),t,"hdb",!0,cw),await tSe(cw,t);let r=[];for(let[n]of cw)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(dSe,"loadRootComponents");BY.exports.loadRootComponents=dSe});var dt=N((TMe,ci)=>{"use strict";var{Worker:_Se,MessageChannel:fSe,parentPort:Ki,isMainThread:fw,threadId:ESe,workerData:Yi}=require("worker_threads"),{PACKAGE_ROOT:hSe}=M(),{join:FY,isAbsolute:pSe,extname:mSe}=require("path"),{server:GY}=(qr(),oe(Ja)),{watch:SSe,readdir:TSe}=require("fs/promises"),{totalmem:HY}=require("os"),vE=M(),qY=se(),ai=W(),{randomBytes:gSe}=require("crypto"),{_assignPackageExport:ASe}=Ei(),RSe=M(),xY=1024*1024,va=[],Ps=[],ySe=50,Ew=1e4,bSe="restart",$Y="request_thread_info",VY="resource_report",KY="thread_info",YY="added-port",OSe="ack",lw;ASe("threads",Ps);ci.exports={startWorker:uw,restartWorkers:pw,shutdownWorkers:DSe,workers:va,setMonitorListener:xSe,onMessageFromWorkers:PSe,onMessageByType:ZY,broadcast:MSe,broadcastWithAcknowledgement:vSe,setChildListenerByType:CSe,getWorkerIndex:WY,getWorkerCount:jY,getTicketKeys:QY,setMainIsWorker:ISe,setTerminateTimeout:NSe,restartNumber:Yi?.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};ci.exports.whenThreadsStarted=new Promise(e=>{ci.exports.threadsHaveStarted=e});var hw;function NSe(e){Ew=e}a(NSe,"setTerminateTimeout");function WY(){return Yi?Yi.workerIndex:hw?0:void 0}a(WY,"getWorkerIndex");function jY(){return Yi?Yi.workerCount:hw?1:void 0}a(jY,"getWorkerCount");function ISe(e){hw=e,ci.exports.threadsHaveStarted()}a(ISe,"setMainIsWorker");var zY=1,gT;function QY(){return gT||(gT=fw?gSe(48):Yi.ticketKeys,gT)}a(QY,"getTicketKeys");Object.defineProperty(GY,"workerIndex",{get(){return WY()}});Object.defineProperty(GY,"workerCount",{get(){return jY()}});var JY={[$Y](e,t){BSe(t)},[VY](e,t){HSe(t,e)}};function uw(e,t={}){let r=process.constrainedMemory?.()||HY();r=Math.min(r,HY(),2e4*xY);let n=qY.get(vE.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/xY/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let l of Ps){let u=new fSe;u.existingPort=l,i.push(u),o.push(u.port2)}mSe(e)||(e+=".js");let c=new _Se(pSe(e)?e:FY(hSe,e),{resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps"],argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(l=>l.existingPort.threadId),workerIndex:t.workerIndex,workerCount:zY=t.threadCount,name:t.name,restartNumber:ci.exports.restartNumber,ticketKeys:QY()},transferList:o,...t});for(let{port1:l,existingPort:u}of i)u.postMessage({type:YY,port:l,threadId:c.threadId},[l]);return RT(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>uw(e,t),c.on("error",l=>{ai.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{va.splice(va.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<ySe?(t.unexpectedRestarts=c.unexpectedRestarts+1,uw(e,t)):ai.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{JY[l.type]?.(l,c)}),va.push(c),FSe(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(uw,"startWorker");var wSe=[vE.THREAD_TYPES.HTTP];async function pw(e=null,t=Math.max(zY>3,1),r=!0){if(fw){try{process.chdir(process.cwd())}catch(o){ai.error("Unable to reestablish current working directory",o)}if(r){let{loadRootComponents:o}=nT();await o()}ci.exports.restartNumber++,t<1&&(t=t*va.length);let n=[],s=[];for(let o of va.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;ai.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:ci.exports.restartNumber,type:vE.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=wSe.indexOf(o.name)>-1,l=new Promise(u=>{let d=setTimeout(()=>{ai.warn("Thread did not voluntarily terminate, terminating from the outside",o.threadId),o.terminate()},Ew*2).unref();o.on("exit",()=>{clearTimeout(d),n.splice(n.indexOf(l)),!c&&r&&o.startCopy(),u()})});if(n.push(l),c&&r){let u=o.startCopy(),d=new Promise(_=>{let E=a(f=>{f.type===RSe.ITC_EVENT_TYPES.CHILD_STARTED&&(ai.trace("Worker has started",u.threadId),_(),s.splice(s.indexOf(d)),u.off("message",E))},"startListener");ai.trace("Waiting for worker to start",u.threadId),u.on("message",E)});s.push(d),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=qu();r&&(e==="http"||!e)&&qY.get(vE.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else Ki.postMessage({type:bSe,workerType:e})}a(pw,"restartWorkers");function CSe(e,t){JY[e]=t}a(CSe,"setChildListenerByType");function DSe(e){return pw(e,1/0,!1)}a(DSe,"shutdownWorkers");var XY=[];function PSe(e){XY.push(e)}a(PSe,"onMessageFromWorkers");var dw=new Map;function ZY(e,t){let r=dw.get(e);r||dw.set(e,r=[]),r.push(t)}a(ZY,"onMessageByType");var LSe=10;async function MSe(e,t){let r=0;for(let n of Ps)try{n.postMessage(e),r++>LSe&&(r=0,await new Promise(setImmediate))}catch(s){ai.error("Unable to send message to worker",s)}t&&tW(e,null)}a(MSe,"broadcast");var AT=new Map,USe=1;function vSe(e){return new Promise(t=>{let r=0;for(let n of Ps)try{let s=USe++,i=a(()=>{AT.delete(s),--r===0&&t(),n!==Ki&&--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){ai.error("Unable to send message to worker",s)}r===0&&t()})}a(vSe,"broadcastWithAcknowledgement");function BSe(e){e.postMessage({type:KY,workers:eW()})}a(BSe,"sendThreadInfo");function eW(){let e=Date.now();return va.map(t=>({threadId:t.threadId,name:t.name,heapTotal:t.resources?.heapTotal,heapUsed:t.resources?.heapUsed,externalMemory:t.resources?.external,arrayBuffers:t.resources?.arrayBuffers,sinceLastUpdate:e-t.resources?.updated,...t.recentELU}))}a(eW,"getChildWorkerInfo");function HSe(e,t){e.resources=t,e.resources.updated=Date.now()}a(HSe,"recordResourceReport");var _w;function xSe(e){_w=e}a(xSe,"setMonitorListener");var kSe=1e3,kY=!1;function FSe(){kY||(kY=!0,setInterval(()=>{for(let e of va){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}_w&&_w()},kSe).unref())}a(FSe,"startMonitoring");var GSe=1e3;if(Ki&&Yi?.addPorts){RT(Ki);for(let e=0,t=Yi.addPorts.length;e<t;e++){let r=Yi.addPorts[e];r.threadId=Yi.addThreadIds[e],RT(r)}setInterval(()=>{let e=process.memoryUsage();Ki.postMessage({type:VY,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},GSe).unref(),lw=a(()=>new Promise((e,t)=>{Ki.on("message",r),Ki.postMessage({type:$Y});function r(n){n.type===KY&&(Ki.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else lw=eW;ci.exports.getThreadInfo=lw;function RT(e,t){Ps.push(e),e.on("message",r=>{if(r.type===YY)r.port.threadId=r.threadId,RT(r.port);else if(r.type===OSe){let n=AT.get(r.id);n&&n()}else tW(r,e)}).on("close",()=>{Ps.splice(Ps.indexOf(e),1)}).on("exit",()=>{Ps.splice(Ps.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(RT,"addPort");function tW(e,t){for(let n of XY)n(e,t);let r=dw.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){ai.error(s)}}a(tW,"notifyMessageListeners");if(fw){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await TSe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(FY(s,o.name));try{for await(let{filename:o}of SSe(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await pw(),console.log("Reloaded HarperDB components, changed files:",Array.from(r)),r.clear()},100)}catch(o){console.warn("Error trying to watch component directory",s,o)}},"watch_dir");ci.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else Ki.on("message",async e=>{let{type:t}=e;t===vE.ITC_EVENT_TYPES.SHUTDOWN&&(ci.exports.restartNumber=e.restartNumber,Ki.unref(),setTimeout(()=>{ai.warn("Thread did not voluntarily terminate",ESe),process.exit(0)},Ew).unref())})});var uv={};je(uv,{AUDIT_STORE_OPTIONS:()=>Cf,Decoder:()=>Pc,HAS_CURRENT_RESIDENCY_ID:()=>rc,HAS_EXPIRATION_EXTENDED_TYPE:()=>i_,HAS_ORIGINATING_OPERATION:()=>s_,HAS_PREVIOUS_RESIDENCY_ID:()=>nc,REMOTE_SEQUENCE_UPDATE:()=>Kp,createAuditEntry:()=>Ul,getLastRemoved:()=>Yy,openAuditStore:()=>IT,readAuditEntry:()=>xt,removeAuditEntry:()=>wT,setAuditRetention:()=>$Se,transactionKeyEncoder:()=>dW});function IT(e){let t=e.auditStore=e.openDB(mw.AUDIT_STORE_NAME,{create:!1,...Cf});t||(t=e.auditStore=e.openDB(mw.AUDIT_STORE_NAME,Cf),nW(t,1)),t.rootStore=e;let r=[];t.addDeleteRemovalCallback=function(i,o){return r[i]=o,t.deleteCallbacks=r,{remove(){delete r[i]}}};let n=null;function s(i=yT){clearTimeout(n),n=setTimeout(async()=>{if(t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let o=0,c,l;try{for(let{key:u,value:d}of t.getRange({start:1,snapshot:!1,end:Date.now()-Sw}))if(c=wT(t,u,d),l=u,await new Promise(setImmediate),++o>=qSe){i=10;break}await c}finally{o===0?i=Math.min(i<<1,Sw/10):nW(t,l),s(i)}},i).unref()}if(a(s,"scheduleAuditCleanup"),t.scheduleAuditCleanup=s,(0,HE.getWorkerIndex)()===(0,HE.getWorkerCount)()-1&&s(yT),(0,HE.getWorkerIndex)()===0&&!rW)for(let i of t.getKeys({reverse:!0,limit:1}))i>Date.now()&&(rW=!0,NT.error("The current time is before the last recorded entry in the audit log. Time reversal can undermine the integrity of data tracking and certificate validation and the time must be corrected."));return t}function wT(e,t,r){if((VSe(r)&15)===Tw){let n=xt(r),s=n.tableId;e.deleteCallbacks?.[s]?.(n.recordId)}return e.remove(t)}function nW(e,t){gw[0]=t,e.put(Symbol.for("last-removed"),_W)}function Yy(e){let t=e.get(Symbol.for("last-removed"));if(t)return _W.set(t),gw[0]}function $Se(e,t=yT){Sw=e,yT=t}function Ul(e,t,r,n,s,i,o,c,l,u,d,_,E){let f=fW[o];if(!f)throw new Error(`Invalid audit entry type ${o}`);let h=1;if(n&&(n>1?Ba.setFloat64(0,n):Ls.set(jg),h=9),l){if(l&16761087)throw new Error("Illegal extended type");h++}g(s),g(t),m(r),Ba.setFloat64(h,e),h+=8,l&rc&&g(u),l&nc&&g(d),l&i_&&(Ba.setFloat64(h,_),h+=8),l&s_&&g(EW[E]),i?m(i):Ls[h++]=0,l?Ba.setUint16(n?8:0,f|l|32768):Ls[n?8:0]=f;let T=Ls.subarray(0,h);if(c)return Buffer.concat([T,c]);return T;function m(S){let y=h;h+=1,h=(0,Tl.writeKey)(S,Ls,h);let I=h-y-1;I>127?I>16383?(NT.error("Key or username was too large for audit entry",S),h=y+1,Ls[y]=0):(Ls.copyWithin(y+2,y+1,h),Ba.setUint16(y,I|32768),h++):Ls[y]=I}function g(S){S<128?Ls[h++]=S:S<16384?(Ba.setUint16(h,S|32768),h+=2):S<1056964608?(Ba.setUint32(h,S|3221225472),h+=4):(Ls[h]=255,Ba.setUint32(h+1,S),h+=5)}}function VSe(e){let t=0;e[0]==66&&(t=8);let r=e[t];if(r<128)return r;let n=e.dataView||(e.dataView=new Pc(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function xt(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new Pc(e.buffer,e.byteOffset,e.byteLength));n.position=t;let s;e[n.position]==66&&(s=n.readFloat64());let i=n.readInt(),o=n.readInt(),c=n.readInt(),l=n.readInt(),u=n.position,d=n.position+=l,_=n.readFloat64(),E,f,h,T;if(i&rc&&(E=n.readInt()),i&nc&&(f=n.readInt()),i&i_&&(h=n.readFloat64()),i&s_){let S=n.readInt();T=EW[S]}l=n.readInt();let m=n.position,g=n.position+=l;return{type:fW[i&7],tableId:c,nodeId:o,get recordId(){return(0,Tl.readKey)(e,u,d)},getBinaryRecordId(){return e.subarray(u,d)},version:_,previousLocalTime:s,get user(){return g>m?(0,Tl.readKey)(e,m,g):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(S,y,I){if(i&bT||i&BE&&!y)return S.decoder.decode(e.subarray(n.position,r));if(i&BE&&I)return Aw(S.getEntry(this.recordId),I,S)},getBinaryValue(){return i&(bT|BE)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:E,previousResidencyId:f,expiresAt:h,originatingOperation:T}}catch(n){return NT.error("Reading audit entry error",n,e),{}}}var Tl,OT,mw,lW,HE,uW,NT,Ls,Ba,dW,Cf,Sw,qSe,gw,_W,yT,rW,bT,BE,sW,Tw,iW,oW,aW,cW,Kp,rc,nc,s_,i_,fW,EW,Pc,Ji=Ie(()=>{Tl=require("ordered-binary"),OT=L(se()),mw=L(Ht()),lW=L(M()),HE=L(dt()),uW=L(te());vl();NT=L(W());CT();(0,OT.initSync)();Ls=Buffer.alloc(2816),Ba=new DataView(Ls.buffer,Ls.byteOffset,2816),dW={writeKey(e,t,r){return e===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,Tl.writeKey)(e,t,r)},readKey(e,t,r){return e[t]===66?(e.dataView||(e.dataView=new DataView(e.buffer,e.byteOffset,e.byteLength))).getFloat64(t):(0,Tl.readKey)(e,t,r)}},Cf={encoding:"binary",keyEncoder:dW},Sw=(0,uW.convertToMS)((0,OT.get)(lW.CONFIG_PARAMS.LOGGING_AUDITRETENTION))||86400*3,qSe=1e3,gw=new Float64Array(1),_W=new Uint8Array(gw.buffer),yT=1e4,rW=!1;a(IT,"openAuditStore");a(wT,"removeAuditEntry");a(nW,"updateLastRemoved");a(Yy,"getLastRemoved");a($Se,"setAuditRetention");bT=16,BE=32,sW=1,Tw=2,iW=3,oW=4,aW=5,cW=6,Kp=11,rc=512,nc=1024,s_=2048,i_=4096,fW={put:sW|bT,[sW]:"put",delete:Tw,[Tw]:"delete",message:iW|bT,[iW]:"message",invalidate:oW|BE,[oW]:"invalidate",patch:aW|BE,[aW]:"patch",relocate:cW,[cW]:"relocate"},EW={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};a(Ul,"createAuditEntry");a(VSe,"readAction");a(xt,"readAuditEntry");Pc=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t;return t=this.getUint8(this.position++),t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch(t){throw t.message=`Error reading float64: ${t.message} at position ${this.position}`,t}}}});var Rw={};je(Rw,{add:()=>DT,applyReverse:()=>hW,getRecordAtTime:()=>Aw,rebuildUpdateBefore:()=>PT});function DT(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n+BigInt(r.value):isNaN(e[t])?e[t]=r.value:e[t]=n+r.value}function PT(e,t,r){let n=null;for(let s in e)if(s in t){let i=t[s];if(i?.__op__){let o=e[s];if(o?.__op__)if(o.__op__===i.__op__)n||(n={}),n[s]=o;else throw new Error("Can not merge updates with different operations");else n||(n={}),n[s]=o,DT(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function hW(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=KSe[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=pW}}function Aw(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),u=xt(l);switch(u.type){case"put":s=u.getValue(r);break;case"patch":hW(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===pW&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),u=xt(l),d;switch(u.type){case"put":d=u.getValue(r);break;case"patch":d=u.getValue(r);break}for(let _ in d)o[_]&&(s[_]=d[_],o[_]=!1,c--);i=u.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var KSe,pW,CT=Ie(()=>{Ji();a(DT,"add");DT.reverse=function(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n-BigInt(r.value):isNaN(e[t])||(e[t]=n-r.value)};KSe={add:DT};a(PT,"rebuildUpdateBefore");a(hW,"applyReverse");pW={};a(Aw,"getRecordAtTime")});function es(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}`);es(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}`);es(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 ${_}`);es(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}`);es(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}`);es(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}`);es(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}`);es(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}`);es(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}`);es(this)[c]=d},"set");break;case"Any":case void 0:l=a(function(d){es(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}`);es(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");es(this)[o]=c}),i("deleteProperty",function(o){es(this)[o]=void 0}),i("toJSON",function(){let o=this[_r],c;for(let u in o){c||(c={...this[ve]});let d=o[u];if(d?.__op__){let _=c[u];d=d.update(_)}c[u]=d}return Object.keys(this).length>0&&(c||(c={...this[ve]}),Object.assign(c,this)),c||this[ve]}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty);function i(o,c){Object.defineProperty(r,o,{value:c,configurable:!0})}a(i,"setMethod")}function SW(e,t){let r;switch(e.constructor){case Object:return t?((r=t.TrackedObject)||(t.TrackedObject=r=class{static{a(this,"TrackedObject")}constructor(s){if(s?.[ve])throw new Error("Can not track an already tracked object, check for circular references");this[ve]=s}},BT(r,t)),new r(e)):new LT(e);case Array:let n=new UT(e.length);n[ve]=e;for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=SW(o,t?.elements)),n[s]=o}return n;default:return e}}function dp(e){let t=e[_r],r;for(let s in t){r||(r={...e[ve]});let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=dp(i);r[s]=i}return Object.keys(e).length>0&&(r||(r={...e[ve]}),Object.assign(r,e)),r||e[ve]}function Al(e,t=e[_r]){let r;if(mW.call(e,ve)&&e.constructor===Array&&!Object.isFrozen(e)){r=e;for(let n=0,s=e.length;n<s;n++){let i=e[n];if(i&&typeof i=="object"){let o=Al(i);o!==i&&r===e&&(r=e.slice(0)),i=o}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r={...e[ve]});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=Rw[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=Al(s);r[n]=s}return r?Object.freeze(r):mW.call(e,ve)?e[ve]:e}function MT(e){let t=e[ve];if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[gl]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.[ve]===s){if(MT(i))return!0}else return!0}}else{let r=e[_r];if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s[ve]===i){if(MT(s))return!0}else return!0}else return!0}}return!1}var Ms,_r,LT,mW,gl,UT,vT,_p=Ie(()=>{Vs();Ms=L(_e());CT();_r=Symbol("own-data");a(es,"getChanges");a(BT,"assignTrackedAccessors");a(SW,"trackObject");LT=class{static{a(this,"GenericTrackedObject")}constructor(t){if(t?.[ve])throw new Error("Can not track an already tracked object, check for circular references");this[ve]=t}};BT(LT,{});a(dp,"collapseData");mW=Object.prototype.hasOwnProperty;a(Al,"updateAndFreeze");a(MT,"hasChanges");gl=Symbol.for("has-array-changes"),UT=class extends Array{static{a(this,"TrackedArray")}[gl];constructor(t){super(t)}splice(...t){return this[gl]=!0,super.splice(...t)}push(...t){return this[gl]=!0,super.push(...t)}pop(){return this[gl]=!0,super.pop()}unshift(...t){return this[gl]=!0,super.unshift(...t)}shift(){return this[gl]=!0,super.shift()}};UT.prototype.constructor=Array;vT=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var _R={};je(_R,{CONTEXT:()=>Fe,ID_PROPERTY:()=>ze,IS_COLLECTION:()=>li,MultiPartId:()=>xT,RECORD_PROPERTY:()=>ve,Resource:()=>Lr,snake_case:()=>WSe,transformForSelect:()=>kT});function WSe(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function TW(e,t){if(Rl=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(Rl=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new xT;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Rl=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return Rl=!0,null;e[e.length-1]==="/"&&(Rl=!0)}return t.coerceId(decodeURIComponent(e))}function ts(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,l,u,d;if(r?(o?(d=i,o=o[Fe]||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(d=s,c=d[this.primaryKey]??null,o=i[Fe]||i):d=i:(d=s,s=void 0,c=d[ze]??d[this.primaryKey]),c===null&&(u=!0)):i?o=i[Fe]||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="object"&&s){if(l=s,typeof(c=s.url)=="string"){let f=c.indexOf("?");if(f>-1){let T=this.parseQuery(c.slice(f+1));l?T&&(l=Object.assign(T,l)):l=T,c=c.slice(0,f)}let h=this.parsePath(c,o,l);h?.id!==void 0?(h.query&&(l?l=Object.assign(h.query,l):l=h.query),u=h.isCollection,c=h.id):c=h}else if(s[Symbol.iterator]){c=[],u=!0;for(let f of s){if(typeof f=="object"&&f)break;c.push(f)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=null,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new ol(c),c==null&&(u=!0);o||(o={});let _;if(l?.ensureLoaded!=null||l?.async||u?(_={...t},l?.ensureLoaded!=null&&(_.ensureLoaded=l.ensureLoaded),l?.async&&(_.async=l.async),u&&(_.isCollection=!0)):_=t,o.transaction){let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)}else return Dt(o,()=>{let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)},_);function E(f){if(o.authorize){o.authorize=!1;let h=t.type==="read"?f.allowRead(o.user,l,o):t.type==="update"?f.doesExist?.()===!1?f.allowCreate(o.user,d,o):f.allowUpdate(o.user,d,o):t.type==="create"?f.allowCreate(o.user,d,o):f.allowDelete(o.user,l,o);if(h?.then)return h.then(T=>{if(!T)throw new HT(o.user);return typeof d?.then=="function"?d.then(m=>e(f,l,o,m)):e(f,l,o,d)});if(!h)throw new HT(o.user)}return typeof d?.then=="function"?d.then(h=>e(f,l,o,h)):e(f,l,o,d)}a(E,"authorizeActionOnResource")}}function rs(e,t){let r=new RW.ClientError(`The ${e.constructor.name} does not have a ${t} method implemented`,405);r.allow=[],r.method=t;for(let n of["get","put","post","delete","query","move","copy"])typeof e[n]=="function"&&r.allow.push(n);throw r}function yw(e,t,r){let n=e[ve];if(n){let s=e[_r];return i=>{let o,c;return e.hasOwnProperty(i)&&typeof(o=e[i])!="function"?o:s&&i in s?s[i]:(c=t?.[i])?c(e,r):n[i]}}else return t?s=>{let i=t[s];return i?i(e,r):e[s]}:s=>e[s]}function kT(e,t){let r=t?.propertyResolvers,n=t[Fe],s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):yw(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(c);let u=[],d=i(yw(l,r,n));for(let _ of e)u.push(d(_));return u},"transform");let o=e.forceNulls;return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(E=>E&&typeof E=="object"?c(E):E);let u={},d=i(yw(l,r,n)),_;for(let E of e){let f=d(E);f===void 0&&o&&(f=null),f?.then?(_||(_=[]),_.push(f.then(h=>u[E.name||E]=h))):u[E.name||E]=f}return _?Promise.all(_).then(()=>u):u},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(o){return c=>{if(typeof c=="string")return o(c);if(typeof c=="object")if(c.name){s||(s={});let l=s[c.name];if(!l){let d=r[c.name]?.definition?.tableClass;l=s[c.name]=kT(c.select||c,d)}let u=o(c.name);return l(u)}else return o(c);else return c}}a(i,"handleProperty")}var gW,AW,RW,Fe,ze,li,ve,YSe,Lr,HT,Rl,xT,Vs=Ie(()=>{gW=require("crypto");Ll();AW=L(Ei()),RW=L(_e());_p();Sc();_E();Fe=Symbol.for("context"),ze=Symbol.for("primary-key"),li=Symbol("is-collection"),ve=Symbol("stored-record"),YSe={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Lr=class{static{a(this,"Resource")}static transactions;constructor(t,r){this[ze]=t;let n=r?.[Fe];this[Fe]=n!==void 0?n:r||null}static get=ts(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=ts(function(t,r,n,s){if(Array.isArray(s)&&t[li]){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):rs(t,"put")},{hasContent:!0,type:"update"});static patch=ts(function(t,r,n,s){return t.patch?t.patch(s,r):rs(t,"patch")},{hasContent:!0,type:"update"});static delete=ts(function(t,r,n,s){return t.delete?t.delete(r):rs(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):rs(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=ts(function(t,r,n,s){return t.invalidate?t.invalidate(r):rs(t,"delete")},{hasContent:!1,type:"update"});static post=ts(function(t,r,n,s){return t[ze]!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=ts(function(t,r,n,s){return t.connect?t.connect(s,r):rs(t,"connect")},{hasContent:!0,type:"read"});static subscribe=ts(function(t,r,n,s){return t.subscribe?t.subscribe(r):rs(t,"subscribe")},{type:"read"});static publish=ts(function(t,r,n,s){return t[ze]!=null&&t.update?.(),t.publish?t.publish(s,r):rs(t,"publish")},{hasContent:!0,type:"create"});static search=ts(function(t,r,n,s){let i=t.search?t.search(r):rs(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=ts(function(t,r,n,s){return t.search?t.search(s,r):rs(t,"search")},{hasContent:!0,type:"read"});static copy=ts(function(t,r,n,s){return t.copy?t.copy(s,r):rs(t,"copy")},{hasContent:!0,type:"create"});static move=ts(function(t,r,n,s){return t.move?t.move(s,r):rs(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this[li])return(await this.constructor.create(this[ze],t,this[Fe]))[ze];rs(this,"post")}static isCollection(t){return t?.[li]}static coerceId(t){return t}static parseQuery(t){return IS(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1);t=t.slice(0,s);let c=r?.headers&&YSe[o];if(c)r.requestedContentType=c;else if(n)n.property=o;else return{query:{property:o},id:TW(t,this),isCollection:Rl}}let i=TW(t,this);return Rl?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r[Fe],o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let u=l.asMap.get(t);if(s=u?.find(d=>d.constructor===c),s)return s;u||l.asMap.set(t,u=[]),u.push(s=new c(t,i))}else{if(s=l.find(u=>u[ze]===t&&u.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let u=new Map;for(let d of l){let _=d[ze],E=u.get(_);E?E.push(d):u.set(_,[d])}i.resourceCache.length=0,i.resourceCache.asMap=u}}}else s=new c(t,i);return o&&(s[li]=!0),s}subscribe(t){return new Mn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new Mn}allowRead(t){return t?.role.permission.super_user}allowUpdate(t){return t?.role.permission.super_user}allowCreate(t){return t?.role.permission.super_user}allowDelete(t){return t?.role.permission.super_user}getId(){return this[ze]}getContext(){return this[Fe]}};Lr.prototype[Fe]=null;(0,AW._assignPackageExport)("Resource",Lr);a(WSe,"snake_case");HT=class extends Error{static{a(this,"AccessError")}constructor(t){t?(super("Unauthorized access to resource"),this.statusCode=403):(super("Must login"),this.statusCode=401)}};a(TW,"pathToId");xT=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(ts,"transactional");a(rs,"missingMethod");a(yw,"selectFromObject");a(kT,"transformForSelect")});var FO={};je(FO,{EVICTED:()=>ba,INVALIDATED:()=>Ns,coerceType:()=>GT,makeTable:()=>VT,setServerUtilities:()=>rTe,updateResource:()=>qT});function VT(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:l,schemaDefined:u,dbisDB:d,sealed:_,splitSegments:E,replicate:f}=e,{expirationMS:h,evictionMS:T,audit:m,trackDeletes:g}=e,{attributes:S}=e;S||(S=[]);let y=Jg(i,n,l),I,U,H={},X=Promise.resolve(),Y,V,ne;for(let v of S)(v.assignCreatedTime||v.name==="__createdtime__")&&(Y=v),(v.assignUpdatedTime||v.name==="__updatedtime__")&&(V=v),v.expiresAt&&(ne=v),v.isPrimaryKey&&(H=v);let Q,de=[],j=[],ae=1,Oe=2,Ne={},Me={},Gr=864e5,wd,Fa,wn,Cd=!1,Nl,Uw=new Map,jE=new Map,vt,Ga,qa=yd.get(Us.CONFIG_PARAMS.REPLICATION_DATABASES);if(Array.isArray(qa)){for(let v of qa)if(v.name===c&&v.replicateTo>=0){Ga=v.replicateTo;break}}let vs=i.getRange({start:!1,end:!1}).constructor,Bs=10,zE=6;m&&ie();class Ve extends Lr{static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=m;static databasePath=o;static databaseName=c;static attributes=S;static replicate=f;static sealed=_;static splitSegments=E??!0;static createdTimeProperty=Y;static updatedTimeProperty=V;static propertyResolvers;static userResolvers={};static sources=[];static get expirationMS(){return h}static dbisDB=d;static schemaDefined=u;static sourcedFrom(p,A){if(A&&(this.sourceOptions=A,(A.expiration||A.eviction||A.scanInterval)&&this.setTTLExpiration(A)),A?.intermediateSource)p.intermediateSource=!0,this.sources.unshift(p);else{if(this.sources.some(O=>!O.intermediateSource)){if(this.sources.some(O=>O.name===p.name))return;throw new Error("Can not have multiple canonical (non-intermediate) sources")}this.sources.push(p)}U=U||p.get&&(!p.get.reliesOnPrototype||p.prototype.get),I=I||p.load;let w=a(O=>{let B=this.sources;if(B=B.filter(k=>k.intermediateSource&&k[O]&&(!k[O].reliesOnPrototype||k.prototype[O])),B.length>0)if(B.length===1){let k=B[0];return(C,F,x)=>{if(C?.source!==k)return k[O](F,x,C)}}else return(k,C,F)=>{let x=[];for(let q of B){if(k?.source===q)break;x.push(q[O](C,F,k))}return Promise.all(x)}},"getApplyToIntermediateSource"),R=this.sources[this.sources.length-1];R.intermediateSource&&(R={});let b=a(O=>{if(R[O]&&(!R[O].reliesOnPrototype||R.prototype[O]))return(B,k,C)=>{if(!B?.source)return R[O](k,C,B)}},"getApplyToCanonicalSource");Ne={put:b("put"),patch:b("patch"),delete:b("delete"),publish:b("publish")},Me={put:w("put"),patch:w("patch"),delete:w("delete"),publish:w("publish"),invalidate:w("invalidate")};let D=R.shouldRevalidateEvents;return(async()=>{let O=!1,B,k=a(async(C,F)=>{let x=C.value,q=C.table?We[c][C.table]:Ve;if(c===Us.SYSTEM_SCHEMA_NAME&&(C.table===Us.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||C.table===Us.SYSTEM_TABLE_NAMES.USER_TABLE_NAME)&&(O=!0),C.id===void 0&&(C.id=x[q.primaryKey],C.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(C));C.source=p;let ee={residencyId:tt(C.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:C.nodeId},G=await q.getResource(C.id,F,ee);switch(C.type){case"put":return D?G._writeInvalidate(ee):G._writeUpdate(x,!0,ee);case"patch":return D?G._writeInvalidate(ee):G._writeUpdate(x,!1,ee);case"delete":return G._writeDelete(ee);case"publish":return G._writePublish(x,ee);case"invalidate":return G._writeInvalidate(ee);case"relocate":return G._writeRelocate(ee);default:qe.default.error?.("Unknown operation",C.type,C.id)}},"writeUpdate");try{let C=p.subscribe;C&&g==null&&(g=!0);let F={crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0},x=p.subscribeOnThisThread?p.subscribeOnThisThread((0,yl.getWorkerIndex)(),F):(0,yl.getWorkerIndex)()===0,q=C&&x&&await p.subscribe?.(F);if(q){let ee;for await(let G of q)try{if(!(G.type==="transaction"?G.writes[0]:G)){qe.default.error?.("Bad subscription event",G);continue}if(G.source=p,G.type==="end_txn"){if(ee?.resolve(),G.localTime&&B!==G.localTime){if(G.remoteNodeIds?.length>0){let Ae=[Symbol.for("seq"),G.remoteNodeIds[0]],re=d.get(Ae),K=re?.nodes;K||(K=[]);for(let Be of G.remoteNodeIds.slice(1)){let we=K.find(ce=>ce.id===Be);K=K.filter(ce=>ce.id!==Be||ce===we),we||(we={id:Be,seqId:0},K.push(we)),we.seqId=Math.max(re?.seqId??1,G.localTime),Be===ee?.nodeId&&(we.lastTxnTime=G.timestamp)}let ge=Math.max(re?.seqId??1,G.localTime);qe.default.trace?.("Received txn",c,ge,G.localTime,G.remoteNodeIds),d.put(Ae,{seqId:ge,nodes:K})}B=G.localTime}G.onCommit&&ee?.committed.then(G.onCommit);continue}if(ee)if(G.beginTxn)ee.resolve();else{ee.write_promises.push(k(G,ee));continue}!G.timestamp&&G.version&&(G.timestamp=G.version);let Ee=Dt(G,()=>{if(G.type==="transaction"){let Ae=[];for(let re of G.writes)try{Ae.push(k(re,G))}catch(K){throw K.message+=" writing "+JSON.stringify(re)+" of event "+JSON.stringify(G),K}return Promise.all(Ae)}else if(G.type==="define_schema"){let Ae=this.attributes.slice(0),re;for(let K of G.attributes)Ae.find(ge=>ge.name===K.name)||(Ae.push(K),re=!0);re&&(Et({table:s,database:c,attributes:Ae,origin:"cluster"}),GE.signalSchemaChange(new qE.SchemaEventMsg(process.pid,Us.OPERATIONS_ENUM.CREATE_TABLE,c,s)))}else return G.beginTxn?(ee=G,ee.write_promises=[k(G,G)],new Promise(Ae=>{ee.resolve=()=>Ae(Promise.all(ee.write_promises))})):k(G,G)});ee&&(ee.committed=Ee),O&&Ee&&!Ee?.waitingForUserChange&&(Ee.then(()=>GE.signalUserChange(new qE.UserEventMsg(process.pid))),Ee.waitingForUserChange=!0),G.onCommit&&(Ee?Ee.then(G.onCommit):G.onCommit())}catch(Re){qe.default.error?.("error in subscription handler",Re)}}}catch(C){qe.default.error?.(C)}})(),this}static get isCaching(){return U}static get shouldRevalidateEvents(){return this.prototype.get!==Ve.prototype.get}static getResource(p,A,w){let R=super.getResource(p,A,w);if(p!=null){ji(p);try{if(R.hasOwnProperty(ve))return R;if(typeof p=="object"&&p&&!Array.isArray(p))throw new Error(`Invalid id ${JSON.stringify(p)}`);let b=!w?.async||i.cache?.get?.(p),D=Ir(A),O=D.getReadTxn();if(O?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return Va(p,A,{transaction:O,ensureLoaded:w?.ensureLoaded},b,B=>{if(B?qT(R,B):R[ve]=null,A.onlyIfCached&&A.noCacheStore){if(!R.doesExist())throw new Nr.ServerError("Entry is not cached",504)}else if(w?.ensureLoaded){let k=Dd(p,B,A,R);if(k)return D?.disregardReadTxn(),R[bw]=!0,Nw(k,C=>(qT(R,C),R))}return R})}catch(b){throw b.message.includes("Unable to serialize object")&&(b.message+=": "+JSON.stringify(p)),b}}return R}ensureLoaded(){let p=Dd(this[ze],this[Fr],this[Fe]);if(p)return this[bw]=!0,Nw(p,A=>{this[Fr]=A,this[ve]=A.value,this[kE]=A.version})}static getNewId(){let p=H?.type;if(p==="String"||p==="ID")return super.getNewId();if(!vt){let b=i.getEntry(Symbol.for("id_allocation")),D=b?.value,O;if(D&&D.nodeName===server.hostname&&(!sTe(i)||D.pid===process.pid)){let B=D.start,k=D.end;O=B;for(let C of i.getKeys({start:k,end:B,limit:1,reverse:!0}))O=C}else D=R(b?.version??null),O=D.start;vt=new BigInt64Array([BigInt(O)+1n]),vt=new BigInt64Array(i.getUserSharedBuffer("id",vt.buffer)),vt.maxSafeId=D.end}let A=Number(Atomics.add(vt,0,1n)),w=p==="Int"?512:1048576;if(A+w>=vt.maxSafeId){let b=a(D=>{vt.maxSafeId=A+(p==="Int"?1023:4194303);let O=(p==="Int"?Math.pow(2,31):Math.pow(2,49))-1,B=D?void 0:i.useReadTransaction(),k=Number(vt[0]);for(let x of i.getKeys({start:k+1,end:O,limit:1,transaction:B}))O=x;B?.done();let{value:C,version:F}=i.getEntry(Symbol.for("id_allocation"));if(vt.maxSafeId<O){if(C.end>vt.maxSafeId-100)return;qe.default.info?.("New id allocation",A,vt.maxSafeId,F),i.put(Symbol.for("id_allocation"),{start:C.start,end:vt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),F)}else{qe.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${vt.maxSafeId}, but id of ${O} detected`);let x=R(F);x.alreadyUpdated||Atomics.store(vt,0,BigInt(x.start+1)),vt.maxSafeId=x.end}},"updateEnd");A+w===vt.maxSafeId?setImmediate(b):A+100>=vt.maxSafeId&&(qe.default.warn?.(`Synchronous id allocation required on table ${s}${p=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>b(!0)))}return A;function R(b){let D=(p==="Int"?Math.pow(2,31):Math.pow(2,49))-1,O=D/4,B,k,C=!1,F,x;do{F=Math.floor(Math.random()*D),x={start:F,end:F+(p==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},B=0;for(let q of i.getKeys({start:F,limit:1,reverse:!0}))B=q;k=D;for(let q of i.getKeys({start:F+1,end:D,limit:1}))k=q;O*=.875,O<1e3&&!C&&(C=!0,qe.default.error?.(`Id allocation in table ${s} is very dense, limited safe range of numbers to allocate ids in${p==="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`,F,B,k,O))}while(!(O<k-F&&(O<F-B||B===0)));return i.transactionSync(()=>{let q=i.getEntry(Symbol.for("id_allocation"));return(q?.version??null)==b?(qe.default.info?.("Allocated new id range",x),i.put(Symbol.for("id_allocation"),x,Date.now()),x):(qe.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...q.value})})}}static setTTLExpiration(p){if(typeof p=="number")h=p*1e3,T||(T=0);else if(p&&typeof p=="object")h=p.expiration*1e3,T=(p.eviction||0)*1e3,Gr=p.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(h<0)throw new Error("Expiration can not be negative");Gr=Gr||(h+T)/4,xo()}static getResidencyRecord(p){return d.get([Symbol.for("residency_by_id"),p])}static setResidency(p){Ve.getResidency=p}static setResidencyById(p){Ve.getResidencyById=p}static getResidency(p,A,w){if(Ve.getResidencyById)return Ve.getResidencyById(p[t]);let R=Ga;if(A.replicateTo!=null){if(Array.isArray(A.replicateTo))return A.replicateTo.includes(server.hostname)?A.replicateTo:[server.hostname,...A.replicateTo];A.replicateTo>=0&&(R=A.replicateTo)}if(R>=0&&server.nodes){let b=[server.hostname];if(w)b.push(...w.slice(0,R));else{let D=server.nodes.map(k=>k.name),O=Math.floor(D.length*Math.random());b.push(...D.slice(O,O+R));let B=O+R-D.length;B>0&&b.push(...D.slice(0,B))}return b}}static enableAuditing(p=!0){m=p,p&&ie(),Ve.audit=p}static coerceId(p){return p===""?null:GT(p,H)}static async dropTable(){if(delete We[c][s],c===o){for(let p of S)d.remove(Ve.tableName+"/"+p.name),r[p.name]?.drop();d.remove(Ve.tableName+"/"),i.drop(),await d.committed}else console.log("legacy dropTable"),await i.close(),await fs.remove(data_path),await fs.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));GE.signalSchemaChange(new qE.SchemaEventMsg(process.pid,Us.OPERATIONS_ENUM.DROP_TABLE,c,s))}get(p){if(typeof p=="string")return this.getProperty(p);if(this[li])return this.search(p);if(this[ze]===null){if(p?.conditions)return this.search(p);let A=Ve.getRecordCount();return{recordCount:A.recordCount,estimatedRecordRange:A.estimatedRange,records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:S}}if(p?.property)return this.getProperty(p.property);if(this.doesExist()||p?.ensureLoaded===!1||this[Fe]?.returnNonexistent)return this}allowRead(p,A){let w=Ka(p);if(w?.read){if(w.isSuperUser)return!0;let R=w.attribute_permissions,b=A?.select;if(R?.length>0||Cd&&b){if(A||(A={}),b){let D=R?.length>0&&Ow(R,"read");A.select=b.map(O=>{let B=O.name||O;if(!D||D[B]){let k=wn[B]?.definition?.tableClass;if(k){if(O.name||(O={name:O}),!k.prototype.allowRead.call(null,p,O))return!1;if(!O.select)return O.name}return O}}).filter(Boolean)}else A.select=R.filter(D=>D.read&&!wn[D.attribute_name]).map(D=>D.attribute_name);return A}else return!0}}allowUpdate(p,A){let w=Ka(p);if(w?.update){let R=w.attribute_permissions;if(R?.length>0){let b=Ow(R,"update");for(let D in A)if(!b[D])return!1;for(let D of R){let O=D.attribute_name;!D.update&&!(O in A)&&(A[O]=this.getProperty(O))}}return Ya(this[Fe])}}allowCreate(p,A){if(this[li]){let w=Ka(p);if(w?.insert){let R=w.attribute_permissions;if(R?.length>0){let b=Ow(R,"insert");for(let D in A)if(!b[D])return!1;return Ya(this[Fe])}else return Ya(this[Fe])}}else return this.allowUpdate(p,{})}allowDelete(p){return Ka(p)?.delete&&Ya(this[Fe])}update(p,A){if(!Ir(this[Fe]))throw new Error("Can not update a table resource outside of a transaction");if(p===!1)return this;let R;return typeof p=="object"&&p&&(A?(Object.isFrozen(p)&&(p={...p}),this[ve]={},this[_r]=p):(R=this[_r],R&&(p=Object.assign(R,p)),this[_r]=R=p)),this._writeUpdate(this[_r],A),this}addTo(p,A){if(typeof A=="number"||typeof A=="bigint")this[xE]===bW?this.set(p,(+this.getProperty(p)||0)+A):(this[xE]||this.update(),this.set(p,new vT(A)));else throw new Error("Can not add a non-numeric value")}subtractFrom(p,A){if(typeof A=="number")return this.addTo(p,-A);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this[Fr]}invalidate(){this._writeInvalidate()}_writeInvalidate(p){let A=this[Fe],w=this[ze];ji(w),Ir(this[Fe]).addWrite({key:w,store:i,invalidated:!0,entry:this[Fr],before:Ne.invalidate?.bind(this,A,w),beforeIntermediate:Me.invalidate?.bind(this,A,w),commit:a((b,D)=>{if(_i(b,D,p?.nodeId)<=0)return;let O=null;for(let B in r)O||(O={}),O[B]=this.getProperty(B);qe.default.trace?.(`Invalidating entry id: ${w}, timestamp: ${new Date(b).toISOString()}`),y(w,O,this[Fr],b,Ns,m,{user:A?.user,residencyId:p?.residencyId,nodeId:p?.nodeId},"invalidate")},"commit")})}_writeRelocate(p){let A=this[Fe],w=this[ze];ji(w),Ir(this[Fe]).addWrite({key:w,store:i,invalidated:!0,entry:this[Fr],before:Ne.relocate?.bind(this,A,w),beforeIntermediate:Me.relocate?.bind(this,A,w),commit:a((b,D)=>{if(_i(b,D,p?.nodeId)<=0)return;let O=Ve.getResidencyRecord(p.residencyId),B=0,k=null,C=D?.value;if(O&&!O.includes(server.hostname)){for(let F in r)k||(k={}),k[F]=C(F);B=Ns}else k=C;qe.default.trace?.(`Relocating entry id: ${w}, timestamp: ${new Date(b).toISOString()}`),y(w,k,this[Fr],b,B,m,{user:A.user,residencyId:p.residencyId,nodeId:p.nodeId,expiresAt:p.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(p,A){let w={previousResidency:this.getResidencyRecord(p.residencyId),isRelocation:!0},R=this.getResidency(A.value,w),b;if(R){if(!Array.isArray(R))throw new Error("Residency must be an array, but was: "+R);if(!R.includes(server.hostname))return;b=tt(R)}let O=y(p.key,A.value,p,p.version,0,!0,{residencyId:b,expiresAt:A.expiresAt},"relocate",!1,null)}static evict(p,A,w){let R=this.Source,b;if(!((U||m)&&(!A||(b=i.getEntry(p),!b||!A)||b.version!==w))){if(U){if(i.hasLock(p,b.version))return;let D;for(let O in r)D||(D={}),D[O]=A[O];if(D)return y(p,D,b,w,ba,null,null,null,!0)}return i.ifVersion(p,w,()=>{$a(p,A,null)}),m?y(p,null,b,w,ba,null,null,null,!0):i.remove(p,w)}}lock(){throw new Error("Not yet implemented")}static operation(p,A){return p.table||=s,p.schema||=c,LW.operation(p,A)}put(p){this.update(p,!0)}patch(p){this.update(p,!1)}_writeUpdate(p,A,w){let R=this[Fe],b=Ir(R),D=this[ze];ji(D);let O=this[Fr];this[xE]=A?bW:ZSe;let B={key:D,store:i,entry:O,nodeName:R?.nodeName,validate:a(k=>{p||(p=this[_r]),A||p&&MT(this[_r]===p?this:p)?R?.source||(b.checkOverloaded(),this.validate(p,!A),V&&(p[V.name]=V.type==="Date"?new Date(k):V.type==="String"?new Date(k).toISOString():k),A&&(t&&p[t]!==D&&(p[t]=D),Y&&(O?.value?p[Y.name]=O?.value[Y.name]:p[Y.name]=Y.type==="Date"?new Date(k):Y.type==="String"?new Date(k).toISOString():k),p=Al(p))):b.removeWrite(B)},"validate"),before:A?Ne.put?()=>Ne.put(R,D,p):null:Ne.patch?()=>Ne.patch(R,D,p):Ne.put?()=>Ne.put(R,D,Al(this)):null,beforeIntermediate:A?Me.put?()=>Me.put(R,D,p):null:Me.patch?()=>Me.patch(R,D,p):Me.put?()=>Me.put(R,D,Al(this)):null,commit:a((k,C,F)=>{if(F){if(R&&C?.version>(R.lastModified||0)&&(R.lastModified=C.version),this[Fr]=C,C?.value?.[ve])throw new Error("Can not assign a record to a record, check for circular references");A||(this[ve]=C?.value??null)}this[_r]=void 0,this[kE]=k;let x=C?.value,q=p;this[xE]=0;let ee=_i(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=_i(k,{version:ge,localTime:K},w?.nodeId),ee===0)return;if(ee>0)continue}if(ce.type==="patch")Be.push(ce),G=p;else if(ce.type==="put"||ce.type==="delete")return}K=ce.previousLocalTime}Be.sort((we,ce)=>we.version-ce.version);for(let we of Be){let ce=we.getValue(i);if(q=PT(q,ce,A),qe.default.debug?.("Rebuilding update with future patch:",q),!q)return}}else{if(A)return;q=PT(q,x,A),qe.default.debug?.("Rebuilding update without audit:",q)}let Re;if(A?Re=q:(this[ve]=x,Re=Al(this,q)),this[ve]=Re,Re?.[ve])throw new Error("Can not assign a record to a record, check for circular references");let Ee;if(w?.residencyId!=null)Ee=w.residencyId;else{O?.residencyId&&(R.previousResidency=Ve.getResidencyRecord(O.residencyId));let K=Ve.getResidency(Re,R);if(K){if(!Array.isArray(K))throw new Error("Residency must be an array, got: "+K);K.includes(server.hostname)||K.push(server.hostname)}Ee=tt(K)}A||(G=p);let Ae=R?.expiresAt??(h?h+Date.now():-1);qe.default.trace?.(`Saving record with id: ${D}, timestamp: ${new Date(k).toISOString()}${Ae?", expires at: "+new Date(Ae).toISOString():""}${C?", replaces entry from: "+new Date(C.version).toISOString():", new entry"}`,Re),$a(D,x,Re);let re=A?"put":"patch";y(D,Re,C,k,0,m,{user:R?.user,residencyId:Ee,expiresAt:Ae,nodeId:w?.nodeId,originatingOperation:R?.originatingOperation},re,!1,G),R.expiresAt&&xo()},"commit")};b.addWrite(B)}async delete(p){if(typeof p=="string")return this.deleteProperty(p);if(this[li]){for await(let A of this.search(p))(await Ve.getResource(A[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(p);return}return this[ve]?this._writeDelete(p):!1}_writeDelete(p){let A=Ir(this[Fe]),w=this[ze];ji(w);let R=this[Fe];return A.addWrite({key:w,store:i,resource:this,nodeName:R?.nodeName,before:Ne.delete?.bind(this,R,w),beforeIntermediate:Me.delete?.bind(this,R,w),commit:a((b,D,O)=>{let B=D?.value;O&&(R&&D?.version>(R.lastModified||0)&&(R.lastModified=D.version),qT(this,D)),!(_i(b,D,p?.nodeId)<=0)&&($a(this[ze],B),qe.default.trace?.(`Deleting record with id: ${w}, txn timestamp: ${new Date(b).toISOString()}`),m||g?(y(w,null,this[Fr],b,0,m,{user:R?.user,nodeId:p?.nodeId},"delete"),m||xo()):i.remove(this[ze]))},"commit")}),!0}search(p){let A=this[Fe],w=Ir(A);if(!p)throw new Error("No query provided");let R=p.conditions;R?R.length===void 0&&(R=R[Symbol.iterator]?Array.from(R):[R]):R=Array.isArray(p)?p:p[Symbol.iterator]?Array.from(p):[],this[ze]&&(R=[{attribute:null,comparator:Array.isArray(this[ze])?"prefix":"starts_with",value:this[ze]}].concat(R));let b,D={};function O(K,ge){let Be;switch(ge){case"and":case void 0:if(K.length<1)throw new Error('An "and" operator requires at least one condition');Be=!0;break;case"or":if(K.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+ge)}for(let we of K){if(we.conditions){we.conditions=O(we.conditions,we.operator);continue}let ce=we[0]??we.attribute,Ye=ce==null?H:Hi(S,ce);if(Ye)(Ye.type||CN[we.comparator])&&(we[1]===void 0?we.value=k(we.value,Ye):we[1]=k(we[1],Ye));else if(ce!=null)throw(0,Nr.handleHDBError)(new Error,`${ce} is not a defined attribute`,404);if(we.chainedConditions)if(we.chainedConditions.length===1&&(!we.operator||we.operator=="and")){let rt=we.chainedConditions[0],Ze,st;if(rt.comparator==="gt"||rt.comparator==="greater_than"||rt.comparator==="ge"||rt.comparator==="greater_than_equal"?(Ze=we,st=rt):(Ze=rt,st=we),Ze.comparator!=="lt"&&Ze.comparator!=="less_than"&&Ze.comparator!=="le"&&Ze.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let Bt=st.comparator==="ge"||st.comparator==="greater_than_equal",ko=Ze.comparator==="le"||Ze.comparator==="less_than_equal";we.comparator=(Bt?"ge":"gt")+(ko?"le":"lt"),we.value=[st.value,Ze.value]}else throw new Error("Multiple chained conditions are not currently supported")}return K}a(O,"prepareConditions");function B(K,ge){if(p.enforceExecutionOrder)return K;for(let Be of K)Be.conditions&&(Be.conditions=B(Be.conditions,Be.operator));return K.length>1&&ge!=="or"?(0,DW.sortBy)(K,NS(Ve)):K}a(B,"orderConditions");function k(K,ge){return Array.isArray(K)?K.map(Be=>GT(Be,ge)):GT(K,ge)}a(k,"coerceTypedValues");let C=p.operator;(R.length>0||C)&&(R=O(R,C));let F=typeof p.sort=="object"&&p.sort,x;if(F&&C!=="or"){let K=F.attribute;if(K==null)throw new Nr.ClientError("Sort requires an attribute");if(b=R.find(ge=>rd(ge.attribute)===rd(K)),!b){let ge=Hi(S,K);if(!ge)throw(0,Nr.handleHDBError)(new Error,`${Array.isArray(K)?K.join("."):K} is not a defined attribute`,404);if(ge.indexed)b={attribute:K,comparator:"sort"},R.push(b);else if(R.length===0&&!p.allowFullScan)throw(0,Nr.handleHDBError)(new Error,`${Array.isArray(K)?K.join("."):K} is not indexed and not combined with any other conditions`,404)}b&&(b.descending=!!F.descending)}R=B(R,C),F&&(b&&R[0]===b?F.next&&(x={dbOrderedAttribute:F.attribute,attribute:F.next.attribute,descending:F.next.descending,next:F.next.next}):(b&&R.splice(R.indexOf(b),1),x=F));let q=p.select;if(R.length===0&&(R=[{attribute:t,comparator:"greater_than",value:!0}]),p.explain)return{conditions:R,operator:C,postOrdering:x,selectApplied:!!q};let ee=w.useReadTxn(),G=DN(R,C,Ve,ee,p,A,(K,ge)=>Pd(K,q,A,ee,ge),D),Re=p.ensureLoaded!==!1;x||(G=re(G));let Ee=Ve.transformEntryForSelect(q,A,ee,D,Re,!0),Ae=Ve.transformToOrderedSelect(G,q,x,ee,A,Ee);function re(K){return p.offset||p.limit!==void 0?K.slice(p.offset,p.limit!==void 0?(p.offset||0)+p.limit:void 0):K}return a(re,"applyOffset"),x&&(Ae=re(Ae)),Ae.onDone=()=>{Ae.onDone=null,w.doneReadTxn()},Ae.selectApplied=!0,Ae.getColumns=()=>{if(q){let K=[];for(let ge of q)ge==="*"?K.push(...S.map(Be=>Be.name)):K.push(ge.name||ge);return K}return S.filter(K=>!K.computed&&!K.relationship).map(K=>K.name)},Ae}static transformToOrderedSelect(p,A,w,R,b,D){let O=new vs;if(w){p=Pd(p,A,R,b,null);let B;O.iterate=function(){let C,F=p[Symbol.asyncIterator]?p[Symbol.asyncIterator]():p[Symbol.iterator](),x,q=w.dbOrderedAttribute,ee,G,Re=!0;function Ee(re){let K=re.next&&Ee(re.next),ge=re.descending;return(Be,we)=>{let ce=Il(Be,re.attribute,R),Ye=Il(we,re.attribute,R),rt=ge?(0,bl.compareKeys)(Ye,ce):(0,bl.compareKeys)(ce,Ye);return rt===0?K?.(Be,we)||0:rt}}a(Ee,"createComparator");let Ae=Ee(w);return{async next(){let re;if(C)if(re=C.next(),re.done){if(x)return O.onDone&&O.onDone(),re}else return{value:await D.call(this,re.value)};B=[],ee&&B.push(ee);do if(re=await F.next(),re.done){if(x=!0,B.length)break;return O.onDone&&O.onDone(),re}else{let K=re.value;if(K?.then&&(K=await K),q){let ge=Il(K,q,R);if(Re)Re=!1,G=ge;else if(ge!==G){G=ge,ee=K;break}}B.push(K)}while(!0);return w.isGrouped,B.sort(Ae),C=B[Symbol.iterator](),re=C.next(),re.done?(O.onDone&&O.onDone(),re):{value:await D.call(this,re.value)}},return(){O.onDone&&O.onDone(),F.return()},throw(){O.onDone&&O.onDone(),F.throw()}}};let k=a(C=>{if(typeof A=="object"&&Array.isArray(C.attribute))for(let F=0;F<A.length;F++){let x=A[F],q;if(x.name===C.attribute[0]){for(q=x.sort||(x.sort={});q.next;)q=q.next;q.attribute=C.attribute.slice(1),q.descending=C.descending}else x===C.attribute[0]&&(A[F]=q={name:x,sort:{attribute:C.attribute.slice(1),descending:C.descending}})}C.next&&k(C.next)},"applySortingOnSelect");k(w)}else O.iterate=(p[Symbol.asyncIterator]||p[Symbol.iterator]).bind(p),O=O.map(function(B){try{let k=D.call(this,B);return typeof k?.catch=="function"?k.catch(C=>{throw C.partialObject={[t]:B.key},C}):k}catch(k){throw k.partialObject={[t]:B.key},k}});return O}static transformEntryForSelect(p,A,w,R,b,D){if(p&&(p===t||p?.length===1&&p[0]===t&&Array.isArray(p))){let C=a(F=>(A?.transaction?.stale&&(A.transaction.stale=!1),F?.key??F),"transform");return p===t?C:p.asArray?F=>[C(F)]:F=>({[t]:C(F)})}let O;b&&U&&!(typeof p=="string"?[p]:p)?.every(C=>{let F;return typeof C=="object"?F=C.name:F=C,r[F]||F===t})&&(O=!0);let B,k=a(function(C){let F;if(A?.transaction?.stale&&(A.transaction.stale=!1),C!=null){if(F=C.value||C.deref?.()?.value,!F&&(C.key===void 0||C.deref)||C.metadataFlags&Ns){if(C.metadataFlags&Ns&&A.replicateFrom===!1&&D&&C.residencyId)return Ha.SKIP;if(C=Va(C.key??C,A,{transaction:w,lazy:p?.length<4,ensureLoaded:b},this?.isSync,x=>x),C?.then)return C.then(k.bind(this));F=C?.value}if(O&&C?.metadataFlags&(Ns|ba)||C?.expiresAt!=null&&C?.expiresAt<Date.now()){if(A.onlyIfCached&&A.noCacheStore)return{[t]:C.key,message:"This entry has expired"};let x=Dd(C.key??C,C,A);if(x?.then)return x.then(k)}}if(F==null)return D?Ha.SKIP:F;if(p&&!(p[0]==="*"&&p.length===1)){let x,q=a((G,Re)=>{let Ee;typeof G=="object"?Ee=G.name:Ee=G;let Ae=wn?.[Ee],re;if(Ae){let K=R?.[Ee];if(K)if(K.hasMappings){let Be=Ae.from?F[Ae.from]:rd(C.key);re=K.get(Be),re||(re=[])}else re=K.fromRecord?.(F);else re=Ae(F,A,C);let ge=a(Be=>{if(Be&&typeof Be=="object"){let we=Ae.definition?.tableClass||Ve;B||(B={});let ce=B[Ee]||(B[Ee]=we.transformEntryForSelect(Ee===G?null:G.select||(Array.isArray(G)?G:null),A,w,K,b));if(Array.isArray(Be)){let Ye=[],rt=we.transformToOrderedSelect(Be,G.select,typeof G.sort=="object"&&G.sort,A,w,ce)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),Ze=a(Bt=>{for(;!Bt.done;){if(Bt?.then)return Bt.then(Ze);Ye.push(Bt.value),Bt=rt.next()}Re(Ye,Ee)},"nextValue"),st=Ze(rt.next());st&&(x||(x=[]),x.push(st));return}else if(Be=ce.call(this,Be),Be?.then){x||(x=[]),x.push(Be.then(Ye=>Re(Ye,Ee)));return}}Re(Be,Ee)},"handleResolvedValue");re?.then?(x||(x=[]),x.push(re.then(ge))):ge(re);return}else re=F[Ee],re&&typeof re=="object"&&Ee!==G&&(re=Ve.transformEntryForSelect(G.select||G,A,w,null)({value:re}));Re(re,Ee)},"selectAttribute"),ee;if(typeof p=="string")q(p,G=>{ee=G});else if(Array.isArray(p))if(p.asArray)ee=[],p.forEach((G,Re)=>{G==="*"?p[Re]=F:q(G,Ee=>ee[Re]=Ee)});else{ee={};let G=p.forceNulls;for(let Re of p)if(Re==="*")for(let Ee in F)ee[Ee]=F[Ee];else q(Re,(Ee,Ae)=>{Ee===void 0&&G&&(Ee=null),ee[Ae]=Ee})}else throw new Nr.ClientError("Invalid select"+p);return x?Promise.all(x).then(()=>ee):ee}return F},"transform");return k}async subscribe(p){if(!l)throw new Error("Can not subscribe to a table without an audit log");m||Et({table:s,database:c,schemaDefined:u,attributes:S,audit:!0}),p||(p={});let A=!p.rawEvents,w=[],R=this,b=py(Ve,this[ze]??null,function(O,B,k,C){try{let F=B.getValue?.(i,A),x=B.type;if(!F&&x==="patch"&&A){let ee=i.getEntry(O);ee?.version===B.version?F=ee.value:F=B.getValue?.(i,!0,k),x="put"}let q={id:O,localTime:k,value:F,version:B.version,type:x,beginTxn:C};w?w.push(q):this.send(q)}catch(F){qe.default.error?.(F)}},p.startTime||0,p),D=(async()=>{this[li]&&(b.includeDescendants=!0,p.onlyChildren&&(b.onlyChildren=!0)),p.supportsTransactions&&(b.supportsTransactions=!0);let O=this[ze],B=p.previousCount;B>1e3&&(B=1e3);let k=p.startTime;if(this[li]){if(k){if(B)throw new Nr.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:C,value:F}of l.getRange({start:k,exclusiveStart:!0,snapshot:!1})){let x=xt(F);if(x.tableId!==n)continue;let q=x.recordId;if(O==null||wW(O,q)){let ee=x.getValue(i,A,C);if(b.send({id:q,localTime:C,value:ee,version:x.version,type:x.type}),b.queue?.length>NW&&await b.waitForDrain()===!1)return}b.startTime=C}}else if(B){let C=[];for(let{key:F,value:x}of l.getRange({start:"z",end:!1,reverse:!0}))try{let q=xt(x);if(q.tableId!==n)continue;let ee=q.recordId;if(O==null||wW(O,ee)){let G=q.getValue(i,A,F);if(C.push({id:ee,localTime:F,value:G,version:q.version,type:q.type}),--B<=0)break}}catch(q){qe.default.error("Error getting history entry",F,q)}for(let F=C.length;F>0;)b.send(C[--F]);C[0]&&(b.startTime=C[0].localTime)}else if(!p.omitCurrent){for(let{key:C,value:F,version:x,localTime:q}of i.getRange({start:O??!1,end:O==null?void 0:[O,bl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(F&&(b.send({id:C,localTime:q,value:F,version:x,type:"put"}),b.queue?.length>NW&&await b.waitForDrain()===!1))return}}else{B&&!k&&(k=0);let C=this[Fr]?.localTime;if(C===Qg&&(i.cache?.delete(O),this[Fr]=i.getEntry(O),qe.default.trace?.("re-retrieved record",C,this[Fr]?.localTime),C=this[Fr]?.localTime),qe.default.trace?.("Subscription from",k,"from",O,C),k<C){let F=[],x=C;do{let q=l.get(x);if(q){p.omitCurrent=!0;let ee=xt(q),G=ee.getValue(i,A,x);A&&(ee.type="put"),F.push({id:O,value:G,localTime:x,...ee}),x=ee.previousLocalTime}else break;B&&B--}while(x>k&&B!==0);for(let q=F.length;q>0;)b.send(F[--q]);b.startTime=C}!p.omitCurrent&&this.doesExist()&&b.send({id:O,localTime:C,value:this[ve],version:this[kE],type:"put"})}for(let C of w)b.send(C);w=null})();return p.listener&&b.on("data",p.listener),b}static subscribeOnThisThread(p,A){return p===0||A?.crossThreads===!1}doesExist(){return!!(this[ve]||this[xE])}publish(p,A){this._writePublish(p,A)}_writePublish(p,A){let w=Ir(this[Fe]),R=this[ze]||null;R!=null&&ji(R);let b=this[Fe];w.addWrite({key:R,store:i,entry:this[Fr],nodeName:b?.nodeName,validate:a(()=>{b?.source||(w.checkOverloaded(),this.validate(p))},"validate"),before:Ne.publish?.bind(this,b,R,p),beforeIntermediate:Me.publish?.bind(this,b,R,p),commit:a((D,O,B)=>{O===void 0&&g&&!m&&xo(),qe.default.trace?.(`Publishing message to id: ${R}, timestamp: ${new Date(D).toISOString()}`),y(R,O?.value??null,O,O?.version||D,0,!0,{user:b?.user,residencyId:A?.residencyId,expiresAt:b?.expiresAt,nodeId:A?.nodeId},"message",!1,p)},"commit")})}validate(p,A){let w,R=a((b,D,O)=>{if(D.type&&b!=null)if(A&&b.__op__&&(b=b.value),D.properties){typeof b!="object"&&(w||(w=[])).push(`Value ${ui(b)} in property ${O} must be an object${D.type?" ("+D.type+")":""}`);let B=D.properties;for(let k=0,C=B.length;k<C;k++){let F=B[k],x=R(b[F.name],F,O+"."+F.name);x&&(b[F.name]=x)}if(D.sealed&&b!=null&&typeof b=="object")for(let k in b)B.find(C=>C.name===k)||(w||(w=[])).push(`Property ${k} is not allowed within object in property ${O}`)}else switch(D.type){case"Int":(typeof b!="number"||b>>0!==b)&&(w||(w=[])).push(`Value ${ui(b)} in property ${O} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof b!="number"||!(Math.floor(b)===b&&Math.abs(b)<=9007199254740992))&&(w||(w=[])).push(`Value ${ui(b)} in property ${O} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof b!="number"&&(w||(w=[])).push(`Value ${ui(b)} in property ${O} must be a number`);break;case"ID":typeof b=="string"||b?.length>0&&b.every?.(B=>typeof B=="string")||(w||(w=[])).push(`Value ${ui(b)} in property ${O} must be a string, or an array of strings`);break;case"String":typeof b!="string"&&(w||(w=[])).push(`Value ${ui(b)} in property ${O} must be a string`);break;case"Boolean":typeof b!="boolean"&&(w||(w=[])).push(`Value ${ui(b)} in property ${O} must be a boolean`);break;case"Date":if(!(b instanceof Date)){if(typeof b=="string"||typeof b=="number")return new Date(b);(w||(w=[])).push(`Value ${ui(b)} in property ${O} must be a Date`)}break;case"BigInt":if(typeof b!="bigint"){if(typeof b=="string"||typeof b=="number")return BigInt(b);(w||(w=[])).push(`Value ${ui(b)} in property ${O} must be a bigint`)}break;case"Bytes":b instanceof Uint8Array||(w||(w=[])).push(`Value ${ui(b)} in property ${O} must be a Buffer or Uint8Array`);break;case"array":if(Array.isArray(b)){if(D.elements)for(let B=0,k=b.length;B<k;B++){let C=b[B],F=R(C,D.elements,O+"[*]");F&&(b[B]=F)}}else(w||(w=[])).push(`Value ${ui(b)} in property ${O} must be a Buffer or Uint8Array`);break}D.nullable===!1&&b==null&&(w||(w=[])).push(`Property ${O} is required (and not does not allow null values)`)},"validateValue");for(let b=0,D=S.length;b<D;b++){let O=S[b];if(!(O.relationship||O.computed)&&(!A||O.name in p)){let B=R(p[O.name],O,O.name);B&&(p[O.name]=B)}}if(_)for(let b in p)S.find(D=>D.name===b)||(w||(w=[])).push(`Property ${b} is not allowed`);if(w)throw new Nr.ClientError(w.join(". "))}getUpdatedTime(){return this[kE]}wasLoadedFromSource(){return U?!!this[bw]:void 0}static async addAttributes(p){let A=S.slice(0);for(let w of p){if(!w.name)throw new Nr.ClientError("Attribute name is required");if(w.name.match(/[`/]/))throw new Nr.ClientError("Attribute names cannot include backticks or forward slashes");(0,PW.validateAttribute)(w.name),A.push(w)}return Et({table:s,database:c,schemaDefined:u,attributes:A}),Ve.indexingOperation}static async removeAttributes(p){let A=S.filter(w=>!p.includes(w.name));return Et({table:s,database:c,schemaDefined:u,attributes:A}),Ve.indexingOperation}static getSize(){let p=i.getStats();return(p.treeBranchPageCount+p.treeLeafPageCount+p.overflowPages)*p.pageSize}static getAuditSize(){let p=l?.getStats();return p&&(p.treeBranchPageCount+p.treeLeafPageCount+p.overflowPages)*p.pageSize}static getRecordCount(p){let A=i.getStats().entryCount,w=1e3/2,R=performance.now(),b=Math.floor(A/2),D=p?.exactCount,O=0,B=0,k;for(let{value:C}of i.getRange({start:!0,lazy:!0}))if(C!=null&&O++,B++,!D&&B<b&&performance.now()-R>w){k=B;break}if(k){let C=O;O=0;for(let{value:re}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:k}))re!=null&&O++;let F=k*2,x=(O+C)/F,q=Math.pow((O-C+1)/k/2,2)+x*(1-x)/F,ee=Math.max(Math.sqrt(q)*A,1),G=Math.round(x*A),Re=Math.max(G-1.96*ee,O+C),Ee=Math.min(G+1.96*ee,A),Ae=Math.pow(10,Math.round(Math.log10(ee)));return Ae>G&&(Ae=Ae/10),O=Math.round(G/Ae)*Ae,{recordCount:O,estimatedRange:[Math.round(Re),Math.round(Ee)]}}return{recordCount:O}}static updatedAttributes(){wn=this.propertyResolvers={$id:a((p,A,w)=>({value:w.key}),"$id"),$updatedtime:a((p,A,w)=>w.version,"$updatedtime"),$record:a((p,A,w)=>w?{value:p}:p,"$record")};for(let p of this.attributes){p.resolve=null;let A=p.relationship,w=p.computed;if(A)if(p.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),w&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),Cd=!0,A.to)p.elements?.definition?(wn[p.name]=p.resolve=(R,b,D)=>{let O=R[A.from?A.from:t],B=p.elements.definition.tableClass;return D?td({attribute:A.to,value:O},Ir(b).getReadTxn(),!1,B,!1).asArray:B.search([{attribute:A.to,value:O}],b).asArray},p.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},p.resolve.definition=p.elements.definition,A.from&&(p.resolve.from=A.from)):console.error(`The one-to-many/many-to-many relationship property "${p.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(A.from){let R=p.definition||p.elements?.definition;R?(wn[p.name]=p.resolve=(b,D,O)=>{let B=b[A.from];if(B!==void 0){if(p.elements){let k,C=B?.map(F=>{let x=O?R.tableClass.primaryStore.getEntry(F,{transaction:Ir(D).getReadTxn()}):R.tableClass.get(F,D);return x?.then&&(k=!0),x});return A.filterMissing?k?Promise.all(C).then(F=>F.filter(CW)):C.filter(CW):k?Promise.all(C):C}return O?R.tableClass.primaryStore.getEntry(B,{transaction:Ir(D).getReadTxn()}):R.tableClass.get(B,D)}},p.set=(b,D)=>{if(Array.isArray(D)){let O=D.map(B=>B[ze]||B[R.tableClass.primaryKey]);b[A.from]=O}else{let O=D[ze]||D[R.tableClass.primaryKey];b[A.from]=O}},p.resolve.definition=p.definition||p.elements?.definition,p.resolve.from=A.from):console.error(`The relationship property "${p.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${p.name}" in table "${s}" must use either "from" or "to" arguments`);else w&&(typeof w.from=="function"&&this.setComputedAttribute(p.name,w.from),wn[p.name]=p.resolve=(R,b,D)=>{let O=typeof w.from=="string"?R[w.from]:R,B=this.userResolvers[p.name];if(B)return B(O,b,D);qe.default.warn(`Computed attribute "${p.name}" does not have a function assigned to it. Please use setComputedAttribute('${p.name}', resolver) to assign a resolver function.`),this.userResolvers[p.name]=()=>{}})}BT(this,this)}static setComputedAttribute(p,A){let w=Hi(S,p);if(!w){console.error(`The attribute "${p}" does not exist in the table "${s}"`);return}if(!w.computed){console.error(`The attribute "${p}" is not defined as computed in the table "${s}"`);return}this.userResolvers[p]=A}static async deleteHistory(p=0,A=!1){let w;for(let{key:R,value:b}of l.getRange({start:0,end:p}))await Rd(),xt(b).tableId===n&&(w=wT(l,R,b));if(A)for(let{key:R,value:b,localTime:D}of i.getRange({start:0,versions:!0}))await Rd(),b===null&&D<p&&(w=i.remove(R));await w}static async*getHistory(p=0,A=1/0){for(let{key:w,value:R}of l.getRange({start:p||1,end:A})){await Rd();let b=xt(R);b.tableId===n&&(yield{id:b.recordId,localTime:w,version:b.version,type:b.type,value:b.getValue(i,!0,w),user:b.user,operation:b.originatingOperation})}}static async getHistoryOfRecord(p){let A=[];if(p==null)throw new Error("An id is required");let w=i.getEntry(p);if(!w)return A;let R=w.localTime;if(!R)throw new Error("The entry does not have a local audit time");let b=0;do{await Rd();let D=l.get(R);if(D){let O=xt(D);A.push({id:O.recordId,localTime:R,version:O.version,type:O.type,value:O.getValue(i,!0,R),user:O.user}),R=O.previousLocalTime}else break}while(b<1e3&&R);return A.reverse()}static cleanup(){Q?.remove()}}Ve.updatedAttributes();let is=Ve.prototype;return is[XSe]=!0,h&&Ve.setTTLExpiration(h/1e3),ne&&Se(),Ve;function $a(v,p,A){let w;for(let R in r){let b=r[R],D=b.isIndexing,O=wn[R],B=A&&(O?O(A):A[R]),k=p&&(O?O(p):p[R]);if(B===k&&!D)continue;w=!0;let C=b.indexNulls,F=(0,FE.getIndexedValues)(B,C),x=(0,FE.getIndexedValues)(k,C);if(x?.length>0){let q=new Set(x);if(F=F?F.filter(ee=>{if(q.has(ee))q.delete(ee);else return!0}):[],x=Array.from(q),(x.length>0||F.length>0)&&yW){let ee=x.concat(F).map(G=>({key:G,value:v}));b.prefetch(ee,IW)}for(let ee=0,G=x.length;ee<G;ee++)b.remove(x[ee],v)}else F?.length>0&&yW&&b.prefetch(F.map(q=>({key:q,value:v})),IW);if(F)for(let q=0,ee=F.length;q<ee;q++)b.put(F[q],v)}return w}a($a,"updateIndices");function ji(v){switch(typeof v){case"number":return!0;case"string":if(v.length<659)return!0;if(v.length>OW)throw new Error("Primary key size is too large: "+v.length);break;case"object":if(v===null)throw new Error("Invalid primary key of null");break;case"bigint":if(v<2n**64n&&v>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof v)}if((0,bl.writeKey)(v,eTe,0)>OW)throw new Error("Primary key size is too large: "+v.length);return!0}a(ji,"checkValidId");function Va(v,p,A,w,R){if(Ve.getResidencyById&&A.ensureLoaded&&p?.replicateFrom!==!1){let D=Ve.getResidencyById(v);if(D&&!D.includes(server.hostname)&&I)return I({key:v,residency:D}).then(R)}let b=a(()=>{if(p?.transaction?.stale&&(p.transaction.stale=!1),A.transaction?.isDone)return R(null,v);let D=i.getEntry(v,A);return D?.residencyId&&D.metadataFlags&Ns&&I&&A.ensureLoaded&&p?.replicateFrom!==!1?I(D).then(O=>R(O,v)):(D&&p&&(D?.version>(p.lastModified||0)&&(p.lastModified=D.version),D?.localTime&&!p.lastRefreshed&&(p.lastRefreshed=D.localTime)),R(D,v))},"whenPrefetched");return w?b():ae>0?(ae--,b()):new Promise((D,O)=>{ae===0?(ae--,i.prefetch([v],()=>{B(),k()})):(de.push(v),j.push(k),de.length>zE&&(ae--,B()));function B(){if(de.length>0){let C=j;i.prefetch(de,()=>{ae===-1?B():ae++;for(let F of C)F()}),de=[],j=[],Oe>2&&Oe--}else ae=Oe,Oe<Bs&&Oe++}a(B,"prefetch");function k(){try{D(b())}catch(C){O(C)}}a(k,"load")})}a(Va,"loadLocalRecord");function Ka(v){if(!v?.role)return;let p=v.role.permission;if(p.super_user)return tTe;let A=p[c],w,R=A?.tables;if(R)return R[s];if(c==="data"&&(w=p[s])&&!w.tables)return w}a(Ka,"getTablePermissions");function Dd(v,p,A,w){if(U){let R=!1;if(A.noCache?R=!0:(p?(!p.value||p.metadataFlags&(Ns|ba)||p.expiresAt!=null&&p.expiresAt<Date.now())&&(R=!0):R=!0,qn(!R,"cache-hit",s)),R){let b=Ld(v,p,A).then(D=>(D?.value?.[ve]&&qe.default.error?.("Can not assign a record with a record property"),A&&(D?.version>(A.lastModified||0)&&(A.lastModified=D.version),A.lastRefreshed=Date.now()),D));if(A?.onlyIfCached||p?.value&&w?.allowStaleWhileRevalidate?.(p,v)){if(b.catch(D=>qe.default.warn?.(D)),A?.onlyIfCached&&!w.doesExist())throw new Nr.ServerError("Entry is not cached",504);return}else return b}}else if(p?.value&&p.expiresAt!=null&&p.expiresAt<Date.now())return Ve.evict(p.key,p.value,p.version),p.value=null,{then(R){return R(p)}}}a(Dd,"ensureLoadedFromSource");function Ir(v){let p=v?.transaction;if(p){if(!p.lmdbDb)return p.lmdbDb=i,p;do{if(p.lmdbDb?.path===i.path)return p;let A=p.next;if(!A)return p=p.next=new mc,p.lmdbDb=i,p;p=A}while(!0)}else return new cp}a(Ir,"txnForContext");function Il(v,p,A){if(!v)return;let w=v.value||i.getEntry(v.key)?.value;if(typeof p=="object"){let b=wn,D=w;for(let O=0,B=p.length;O<B;O++){let k=p[O],C=b?.[k];D=C&&D?C(D,A,!0)?.value:D?.[k],b=C?.definition?.tableClass?.propertyResolvers}return D}let R=wn[p];return R?R(w,A):w[p]}a(Il,"getAttributeValue");function Pd(v,p,A,w,R){let b=R?.length,D={transaction:w,lazy:b>0||typeof p=="string"||p?.length<4,alwaysPrefetch:!0},O;function B(k,C){let F=k?.value;if(!F)return Ha.SKIP;for(let x=0;x<b;x++)if(!O?.includes(x)&&!R[x](F,k))return Ha.SKIP;return C!==void 0&&(k.key=C),k}if(a(B,"processEntry"),b>0||!v.hasEntries){let k=v.map(C=>{if(O=null,typeof C=="object"&&C?.key!==void 0)return b>0?B(C):C;if(C==null)return Ha.SKIP;for(let F=0;F<b;F++){let q=R[F].idFilter;if(q){if(!q(C))return Ha.SKIP;O||(O=[]),O.push(F)}}return Va(C,A,D,!1,B)});return Array.isArray(v)&&(k=k.filter(C=>C!==Ha.SKIP)),k.hasEntries=!0,k}return v}a(Pd,"transformToEntries");function _i(v,p,A=server.replication?.getThisNodeId(l)){if(v<=p?.version){if(p?.version===v&&A!==void 0){let w=server.replication?.exportIdMapping(l),R=p.localTime,b=R&&l.get(R);if(b){let D,O,B=xt(b);for(let k in w)w[k]===A&&(D=k),w[k]===B.nodeId&&(O=k);if(D>O)return 1;if(D===O)return 0}}return-1}return 1}a(_i,"precedesExistingVersion");async function Ld(v,p,A){let w=p?.metadataFlags,R=p?.version,b,D;if(!i.attemptLock(v,R,()=>{clearTimeout(D);let C=i.getEntry(v);!C||!C.value||C.metadataFlags&(Ns|ba)?b(Ld(v,i.getEntry(v),A)):b(C)}))return new Promise(C=>{b=C,D=setTimeout(()=>{i.unlock(v,R)},JSe)});let O=p?.value,B={requestContext:A,replacingRecord:O,replacingEntry:p,replacingVersion:R,noCacheStore:!1,source:null,resourceCache:A?.resourceCache},k=A?.responseHeaders;return new Promise((C,F)=>{let x;Nw(Dt(B,async q=>{let ee=performance.now(),G,Re,Ee;try{for(let ge of Ve.sources)if(ge.get&&(!ge.get.reliesOnPrototype||ge.prototype.get)){if(ge.available?.(p)===!1)continue;if(B.source=ge,G=await ge.get(v,B),G)break}Ee=w&Ns;let re=B.lastModified||Ee&&R;Re=Ee||re>R||!O,re||(re=(0,FE.getNextMonotonicTime)());let K=performance.now()-ee;if(pr(K,"cache-resolution",s,null,"success"),k&&Bm(k,"Server-Timing",`cache-resolve;dur=${K.toFixed(2)}`,!0),q.timestamp=re,h&&B.expiresAt==null&&(B.expiresAt=Date.now()+h),G){if(typeof G!="object")throw new Error("Only objects can be cached and stored in tables");if(G.status>0&&G.headers)if(G.status>=300)if(G.status===304)G=O,re=R;else throw new Nr.ServerError(G.body||"Error from source",G.status);else G=G.body;typeof G.toJSON=="function"&&(G=G.toJSON()),t&&G[t]!==v&&(G[t]=v)}x=!0,C({key:v,version:re,value:G})}catch(re){re.message+=` while resolving record ${v} for ${s}`,O&&((re.code==="ECONNRESET"||re.code==="ECONNREFUSED"||re.code==="EAI_AGAIN")&&!A?.mustRevalidate||A?.staleIfError&&(re.statusCode===500||re.statusCode===502||re.statusCode===503||re.statusCode===504))?(C({key:v,version:R,value:O}),qe.default.trace?.(re.message,"(returned stale record)")):F(re);let K=performance.now()-ee;pr(K,"cache-resolution",s,null,"fail"),k&&Bm(k,"Server-Timing",`cache-resolve;dur=${K.toFixed(2)}`,!0),B.transaction.abort();return}if(A?.noCacheStore||B.noCacheStore){B.transaction.abort();return}Ir(B).addWrite({key:v,store:i,entry:p,nodeName:"source",commit:a((re,K)=>{if(K?.version!==R)return;let ge=$a(v,O,G);G?(Me.put?.(B,v,G),qe.default.trace?.(`Writing resolved record from source with id: ${v}, timestamp: ${new Date(re).toISOString()}`),y(v,G,K,re,0,m&&Re||null,{user:B?.user,expiresAt:B.expiresAt},"put",!!Ee)):K&&(Me.delete?.(B,v),qe.default.trace?.(`Deleting resolved record from source with id: ${v}, timestamp: ${new Date(re).toISOString()}`),m||g?y(v,null,K,re,0,m&&Re||null,{user:B?.user},"delete",!!Ee):i.remove(v,R))},"commit")})}),()=>{i.unlock(v,R)},q=>{i.unlock(v,R),x&&qe.default.error?.("Error committing cache update",q)})})}a(Ld,"getFromSource");function Ya(v){if(!v||v.user?.role?.permission?.super_user)return!0;if(v.replicateTo)throw new Nr.ClientError("Can not specify replication parameters without super user permissions",403);if(v.replicatedConfirmation)throw new Nr.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}a(Ya,"checkContextPermissions");function xo(){if(Gr!==wd&&(wd=Gr,(0,yl.getWorkerIndex)()===(0,yl.getWorkerCount)()-1)){if(Fa&&clearTimeout(Fa),!Gr)return;let v=new Date;v.setMonth(0),v.setDate(1),v.setHours(0),v.setMinutes(0),v.setSeconds(0);let p=Math.ceil((Date.now()-v.getTime())/Gr)*Gr+v.getTime(),A=a(w=>{qe.default.trace?.(`Scheduled next cleanup scan at ${new Date(w)}ms`),Fa=setTimeout(()=>X=X.then(async()=>{if(A(Math.max(w+Gr,Date.now())),i.rootStore.status!=="open"){clearTimeout(Fa);return}let R=50,b=new Array(R),D=0;qe.default.info?.(`Starting cleanup scan for ${s}`);try{let O=0;for(let{key:B,value:k,version:C,expiresAt:F}of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let x;k===null&&!m&&C+QSe<Date.now()?x=i.remove(B,C):F!=null&&F+T<Date.now()&&(x=Ve.evict(B,k,C),O++),x&&(await b[D],b[D]=x.catch(q=>{qe.default.error?.("Cleanup error",q)}),++D>=R&&(D=0)),await Rd()}qe.default.info?.(`Finished cleanup scan for ${s}, evicted ${O} entries`)}catch(O){qe.default.warn?.(`Error in cleanup scan for ${s}:`,O)}}),Math.min(w-Date.now(),2147483647)).unref()},"startNextTimer");A(p)}}a(xo,"scheduleCleanup");function ie(){Q=l?.addDeleteRemovalCallback(n,v=>{let p=i.getEntry(v);p?.value===null&&i.remove(v,p.version)})}a(ie,"addDeleteRemoval");function Se(){(0,yl.getWorkerIndex)()===0&&setInterval(async()=>{if(!Nl){Nl=!0;try{let v=ne.name,p=r[v];if(!p)throw new Error(`expiresAt attribute ${ne} must be indexed`);for(let A of p.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let w of p.getValues(A)){let R=i.getEntry(w);R?.value?R.value[v]<Date.now()&&Ve.evict(w,R.value,R.version):i.ifVersion(w,R?.version,()=>p.remove(A,w))}await Rd()}}catch(v){qe.default.error?.("Error in evicting old records",v)}finally{Nl=!1}}},zSe).unref()}a(Se,"runRecordExpirationEviction");function tt(v){if(v){let p=v.join(","),A=d.get([Symbol.for("residency_by_set"),p]);return A||(d.put([Symbol.for("residency_by_set"),p],A=Math.floor(Math.random()*2147483647)),d.put([Symbol.for("residency_by_id"),A],v),A)}}a(tt,"getResidencyId")}function Ow(e,t){let r=e.attr_object||(e.attr_object={}),n=r[t];if(n)return n;n=r[t]=Object.create(null);for(let s of e)n[s.attribute_name]=s[t];return n}function IW(){}function rTe(e){LW=e}function GT(e,t){let r=t?.type;if(e===null)return e;if(e===""&&r&&r!=="String"&&r!=="Any")return null;try{switch(r){case"Int":case"Long":if(e[0]==="$")return FT(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return FT(+e);case"Float":return e==="null"?null:FT(+e);case"BigInt":return e==="null"?null:BigInt(e);case"Boolean":return e==="true"?!0:e==="false"?!1:e;case"Date":if(isNaN(e)){if(e==="null")return null;nTe.test(e)||(e+="Z");let n=new Date(e);return FT(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,$T.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function FT(e){if(isNaN(e))throw new SyntaxError;return e}function wW(e,t){if(e==null)return!0;if(!Array.isArray(t))return e===t||t.startsWith?.(e);if(Array.isArray(e)){let r=e.length;if(e[r-1]===null&&r--,t.length>=r){for(let n=0;n<r;n++)if(t[n]!==e[n])return!1;return!0}return!1}else if(t[0]===e)return!0}function Nw(e,t,r){return e?.then?e.then(t,r):t(e)}function qT(e,t){e[Fr]=t,e[ve]=t?.value??null,e[kE]=t?.version}function CW(e){return e!=null}function ui(e){try{return JSON.stringify(e)}catch{return e}}function sTe(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var Us,Ha,FE,DW,PW,yd,Nr,GE,qE,qe,bl,yl,$T,jSe,LW,zSe,QSe,yW,JSe,kE,XSe,Fr,xE,bW,ZSe,bw,Ns,ba,eTe,OW,NW,tTe,zMe,nTe,Rd,$f=Ie(()=>{Us=L(M()),Ha=require("lmdb"),FE=L(cn()),DW=require("lodash"),PW=L(Jd());Vs();lp();yd=L(se());my();Nr=L(_e()),GE=L(no()),qE=L(qs());Pe();_E();qe=L(Oc());_p();Sc();bl=require("ordered-binary"),yl=L(dt());Ji();$T=L(te());vl();Ii();CT();Uf();jSe=new Uint8Array(9);jSe[8]=192;zSe=6e4,QSe=864e5;yd.initSync();yW=yd.get(Us.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),JSe=1e4,kE=Symbol.for("version"),XSe=Symbol.for("incremental-update"),Fr=Symbol("entry"),xE=Symbol("is-saving"),bW=1,ZSe=2,bw=Symbol("loaded-from-source"),Ns=1,ba=8,eTe=Buffer.allocUnsafeSlow(8192),OW=1978,NW=100,tTe={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},zMe=(0,$T.convertToMS)(yd.get(Us.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(VT,"makeTable");a(Ow,"attributesAsObject");a(IW,"noop");a(rTe,"setServerUtilities");nTe=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(GT,"coerceType");a(FT,"rejectNaN");a(wW,"isDescendantId");Rd=a(()=>new Promise(setImmediate),"rest");a(Nw,"when");a(qT,"updateResource");a(CW,"exists");a(ui,"stringify");a(sTe,"hasOtherProcesses")});var lt={};je(lt,{database:()=>Ql,databases:()=>We,dropDatabase:()=>xR,dropTableMeta:()=>lTe,getDatabases:()=>ut,getDefaultCompression:()=>Lm,getTables:()=>iTe,onRemovedDB:()=>nf,onUpdatedTable:()=>Lc,readMetaDb:()=>$E,resetDatabases:()=>ku,table:()=>Et,tables:()=>zn});function iTe(){return jT||ut(),zn||{}}function ut(){if(jT)return We;jT=!0,Nd=new Map;let e=(0,er.getHdbBasePath)()&&(0,Ut.join)((0,er.getHdbBasePath)(),br.DATABASES_DIR_NAME),t=(0,er.get)(br.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)(br.CONFIG_PARAMS.STORAGE_PATH)||e&&((0,ns.existsSync)(e)?e:(0,Ut.join)((0,er.getHdbBasePath)(),br.LEGACY_DATABASES_DIR_NAME)),!e)return;if((0,ns.existsSync)(e))for(let n of(0,ns.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,ns.existsSync)((0,Od.getBaseSchemaPath)())){for(let n of(0,ns.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,ns.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,ns.existsSync)(i))for(let c of(0,ns.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,ns.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")&&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 zn)delete zn[i];delete zn[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 ku(){jT=!1;for(let[,e]of xa)e.needsDeletion=!0;ut();for(let[e,t]of xa)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),xa.delete(e),delete We[t.databaseName],KE.forEach(r=>r(t.databaseName)));return We}function $E(e,t,r=Cw,n,s){let i=new Iw.default(e,!1);try{let o=xa.get(e);o?o.needsDeletion=!1:(o=(0,Id.open)(i),xa.set(e,o));let c=new Ol.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(KT.INTERNAL_DBIS_NAME,c)),u=o.auditStore;u||(n?(0,ns.existsSync)(n)&&(i.path=n,u=(0,Id.open)(i),u.isLegacy=!0):u=IT(o));let d=BW(r),_=d[zT],E=new Map;for(let{key:f,value:h}of l.getRange({start:!1})){let[T,m]=f.toString().split("/");m===""?m=h.name:m||(m=T,T=t,h.name||(h.name=m,h.indexed=!h.is_hash_attribute)),_?.add(T);let g=E.get(T);g||E.set(T,g={attributes:[]}),(m==null||h.is_hash_attribute)&&(g.primary=h),m!=null&&g.attributes.push(h),Object.defineProperty(h,"key",{value:f,configurable:!0})}for(let[f,h]of E){let{attributes:T,primary:m}=h;if(!m){for(let j of T)if(j.is_hash_attribute||j.isPrimaryKey){m=j;break}if(!m){Vt.warn(`Unable to find a primary key attribute on table ${f}, with attributes: ${JSON.stringify(T)}`);continue}}let g=d[f],S={},y=[],I,U,H=typeof m.audit=="boolean"?m.audit:(0,er.get)(br.CONFIG_PARAMS.LOGGING_AUDITLOG),X=m.trackDeletes,Y=m.expiration,V=m.eviction,ne=m.sealed,Q=m.splitSegments,de=m.replicate;if(g)S=g.indices,y=g.attributes,g.schemaVersion++;else{I=m.tableId,I?I>=(l.get(bd)||0)&&(l.putSync(bd,I+1),Vt.info(`Updating next table id (it was out of sync) to ${I+1} for ${f}`)):(m.tableId=I=l.get(bd),I||(I=1),Vt.debug("Table {table_name} missing an id, assigning {table_id}"),l.putSync(bd,I+1),l.putSync(m.key,m));let j=new Ol.default(!m.is_hash_attribute,m.is_hash_attribute);if(j.compression=m.compression,j.compression){let ae=(0,er.get)(br.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||vW;j.compression.threshold=ae}U=Nh(o.openDB(m.key,j)),o.databaseName=r,U.rootStore=o,U.tableId=I}for(let j of T){j.attribute=j.name;try{if(!j.is_hash_attribute&&(j.indexed||j.attribute&&!j.name)){if(!S[j.name]){let Oe=new Ol.default(!j.is_hash_attribute,j.is_hash_attribute);S[j.name]=o.openDB(j.key,Oe),S[j.name].indexNulls=j.indexNulls}let ae=y.find(Oe=>Oe.name===j.name);ae?y.splice(y.indexOf(ae),1,j):y.push(j)}}catch(ae){Vt.error("Error trying to update attribute",j,y,S,ae)}}if(!g){g=HW(d,f,VT({primaryStore:U,auditStore:u,audit:H,sealed:ne,splitSegments:Q,replicate:de,expirationMS:Y&&Y*1e3,evictionMS:V&&V*1e3,trackDeletes:X,tableName:f,tableId:I,primaryKey:m.name,databasePath:s?r+"/"+f:r,databaseName:r,indices:S,attributes:T,schemaDefined:m.schemaDefined,dbisDB:l})),g.schemaVersion=1;for(let j of VE)j(g)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function BW(e){let t=We[e];if(t||(e==="data"?t=We[e]=zn: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 HW(e,t,r){return e[t]=r,r}function Ql({database:e,table:t}){e||(e=Cw),ut();let r=BW(e),n=(0,Ut.join)((0,er.getHdbBasePath)(),br.DATABASES_DIR_NAME),s=(0,er.get)(br.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)(br.CONFIG_PARAMS.STORAGE_PATH)||((0,ns.existsSync)(n)?n:(0,Ut.join)((0,er.getHdbBasePath)(),br.LEGACY_DATABASES_DIR_NAME));let o=(0,Ut.join)(n,(i?t:e)+".mdb"),c=xa.get(o);if(!c||c.status==="closed"){let l=new Iw.default(o,!1);c=(0,Id.open)(l),xa.set(o,c)}return c.auditStore||(c.auditStore=IT(c)),c}async function xR(e){if(!We[e])throw new Error("Schema does not exist");let t=We[e],r;for(let n in t)r=t[n].primaryStore.rootStore,xa.delete(r.path),r.status==="open"&&(await r.close(),await YE.remove(r.path));if(r||(r=Ql({database:e,table:null}),r.status==="open"&&(await r.close(),await YE.remove(r.path))),e==="data"){for(let n in zn)delete zn[n];delete zn[zT]}delete We[e],KE.forEach(n=>n(e))}function Et(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:o,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:_,schemaDefined:E,origin:f}=e;r||(r=Cw);let h=Ql({database:r,table:t}),T=We[r];Vt.trace(`Defining ${t} in ${r}`);let m=T?.[t];if(h.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let g,S,y;E==null&&(E=!0);let I=new Ol.default(!1);for(let Q of o)Q.attribute&&!Q.name?(Q.name=Q.attribute,Q.indexed=!0):Q.attribute=Q.name,Q.expiresAt&&(Q.indexed=!0);let U,H;if(m){if(g=m.primaryKey,m.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);u==null&&(u=m.splitSegments),m.attributes.splice(0,m.attributes.length,...o)}else{let Q=h.auditStore;S=o.find(Oe=>Oe.isPrimaryKey)||{},g=S.name,S.is_hash_attribute=S.isPrimaryKey=!0,S.schemaDefined=E,S.compression=Lm(),_&&(S.trackDeletes=!0),c=S.audit=typeof c=="boolean"?c:(0,er.get)(br.CONFIG_PARAMS.LOGGING_AUDITLOG),n&&(S.expiration=n),s&&(S.eviction=s),u??=!1,S.splitSegments=u,typeof l=="boolean"&&(S.sealed=l),typeof d=="boolean"&&(S.replicate=d),f&&(S.origins?S.origins.includes(f)||S.origins.push(f):S.origins=[f]),Vt.trace(`${t} table loading, opening primary store`);let de=new Ol.default(!1,!0);de.compression=S.compression;let j=t+"/";if(y=h.dbisDb=h.openDB(KT.INTERNAL_DBIS_NAME,I),ne(),y.get(j))return H&&H(),ku(),Et(e);let ae=Nh(h.openDB(j,de));h.databaseName=r,ae.rootStore=h,ae.tableId=y.get(bd),Vt.trace(`Assigning new table id ${ae.tableId} for ${t}`),ae.tableId||(ae.tableId=1),y.put(bd,ae.tableId+1),S.tableId=ae.tableId,m=HW(T,t,VT({primaryStore:ae,auditStore:Q,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:_,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:g,tableName:t,tableId:ae.tableId,databasePath:r,databaseName:r,indices:{},attributes:o,schemaDefined:E,dbisDB:y})),m.schemaVersion=1,U=!0,y.put(j,S)}let X=m.indices;y=y||(h.dbisDb=h.openDB(KT.INTERNAL_DBIS_NAME,I)),m.dbisDB=y;let Y=[];for(let{key:Q,value:de}of y.getRange({start:!0})){let[j,ae]=Q.toString().split("/");if(ae===""&&(ae=de.name),ae){if(j!==t)continue}else continue;let Oe=o.find(Me=>Me.name===ae),Ne=!Oe?.indexed&&de.indexed&&!de.isPrimaryKey;if((!Oe||Ne)&&(ne(),U=!0,Oe||y.remove(Q),Ne)){let Me=m.indices[j];Me&&Y.push(Me)}}let V=[];try{for(let Q of o||[]){if((Q.relationship||Q.computed)&&(U=!0,Q.relationship))continue;let de=t+"/"+(Q.name||"");Object.defineProperty(Q,"key",{value:de,configurable:!0});let j=y.get(de);if(Q.isPrimaryKey){if(j=j||y.get(de=t+"/")||{},c!==void 0&&c!==m.audit||l!==void 0&&l!==m.sealed||d!==void 0&&d!==m.replicate||(+n||void 0)!==(+j.expiration||void 0)||(+s||void 0)!==(+j.eviction||void 0)){let Oe={...j};typeof c=="boolean"&&(c&&m.enableAuditing(c),Oe.audit=c),n&&(Oe.expiration=+n),s&&(Oe.eviction=+s),l!==void 0&&(Oe.sealed=l),d!==void 0&&(Oe.replicate=d),U=!0,ne(),y.put(de,Oe)}continue}j?.attribute&&!j.name&&(j.indexed=!0);let ae=!j||j.type!==Q.type||j.indexed!==Q.indexed||j.nullable!==Q.nullable||j.version!==Q.version||JSON.stringify(j.properties)!==JSON.stringify(Q.properties)||JSON.stringify(j.elements)!==JSON.stringify(Q.elements);if(Q.indexed){let Oe=new Ol.default(!0,!1),Ne=h.openDB(de,Oe);(ae||j.indexingPID&&j.indexingPID!==process.pid||j.restartNumber<WE.workerData?.restartNumber)&&(U=!0,ne(),j=y.get(de),(ae||j.indexingPID&&j.indexingPID!==process.pid||j.restartNumber<WE.workerData?.restartNumber)&&(U=!0,Q.indexNulls===void 0&&(Q.indexNulls=!0),m.primaryStore.getStats().entryCount>0&&(Q.lastIndexedKey=j?.lastIndexedKey??void 0,Q.indexingPID=process.pid,Ne.isIndexing=!0,Object.defineProperty(Q,"dbi",{value:Ne}),V.push(Q))),y.put(de,Q)),j?.indexNulls&&Q.indexNulls===void 0&&(Q.indexNulls=!0),Ne.indexNulls=Q.indexNulls,X[Q.name]=Ne}else ae&&(U=!0,ne(),y.put(de,Q))}}finally{H&&H()}if(U&&(m.schemaVersion++,m.updatedAttributes()),Vt.trace(`${t} table loading, running index`),V.length>0||Y.length>0?m.indexingOperation=cTe(m,V,Y):U&&YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"schema-change",m.databaseName,m.tableName)),m.origin=f,U)for(let Q of VE)Q(m,f!=="cluster");return(n||s||i)&&m.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),Vt.trace(`${t} table loaded`),m;function ne(){H||h.transactionSync(()=>({then(Q){H=Q}}))}a(ne,"startTxn")}async function cTe(e,t,r){try{Vt.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o={},c=0,l=t.length;if(await new Promise(u=>setImmediate(u)),l>0){let u;for(let _ of t)(0,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]),y=(0,MW.getIndexedValues)(S);if(y)for(let I=0,U=y.length;I<U;I++)T.dbi.put(y[I],_)}catch(g){o[m]||(o[m]=!0,Vt.error(`Error indexing attribute ${m}`,g))}}}),s.then(()=>d--,h=>{d--,Vt.error(h)}),WE.workerData&&WE.workerData.restartNumber!==UW.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=_,e.dbisDB.put(h.key,h);if(i)return}d>oTe?await s:d>aTe&&await new Promise(h=>setImmediate(h))}for(let _ of t)delete _.lastIndexedKey,delete _.indexingPID,_.dbi.isIndexing=!1,s=e.dbisDB.put(_.key,_)}await s,await YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),Vt.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){Vt.error("Error in indexing",n)}}function lTe({table:e,database:t}){let r=Ql({database:t,table:e}),n=[],s=r.dbisDb;for(let i of s.getKeys({start:e+"/",end:e+"0"}))n.push(s.remove(i));return Promise.all(n)}function Lc(e){return VE.push(e),{remove(){let t=VE.indexOf(e);t>-1&&VE.splice(t,1)}}}function nf(e){return KE.push(e),{remove(){let t=KE.indexOf(e);t>-1&&KE.splice(t,1)}}}function Lm(){let e=(0,er.get)(br.CONFIG_PARAMS.STORAGE_COMPRESSION),t=(0,er.get)(br.CONFIG_PARAMS.STORAGE_COMPRESSION_DICTIONARY),r=(0,er.get)(br.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,Id,Ut,ns,Od,Ol,Iw,br,YE,ww,MW,YT,WT,WE,Vt,UW,Cw,zT,vW,zn,We,bd,VE,KE,jT,xa,Nd,oTe,aTe,Pe=Ie(()=>{er=L(se()),KT=L(Ht()),Id=require("lmdb"),Ut=require("path"),ns=require("fs"),Od=L(gt());$f();Ol=L(o_()),Iw=L(a_()),br=L(M()),YE=L(require("fs-extra")),ww=L(Ei()),MW=L(cn()),YT=L(no()),WT=L(qs()),WE=require("worker_threads"),Vt=L(W()),UW=L(dt());Ji();vl();Cw="data",zT=Symbol("defined-tables"),vW=((0,er.get)(br.CONFIG_PARAMS.STORAGE_PAGESIZE)||4096)-60;(0,er.initSync)();zn=Object.create(null),We=Object.create(null);(0,ww._assignPackageExport)("databases",We);(0,ww._assignPackageExport)("tables",zn);bd=Symbol.for("next-table-id"),VE=[],KE=[],xa=new Map;a(iTe,"getTables");a(ut,"getDatabases");a(ku,"resetDatabases");a($E,"readMetaDb");a(BW,"ensureDB");a(HW,"setTable");a(Ql,"database");a(xR,"dropDatabase");a(Et,"table");oTe=1e3,aTe=10;a(cTe,"runIndexing");a(lTe,"dropTableMeta");a(Lc,"onUpdatedTable");a(nf,"onRemovedDB");a(Lm,"getDefaultCompression")});var te=N((sUe,JW)=>{"use strict";var ka=require("path"),qW=require("fs-extra"),In=W(),xW=require("fs-extra"),QT=require("os"),uTe=require("net"),dTe=require("recursive-iterator"),Kt=M(),_Te=hg(),kW=require("papaparse"),JT=require("moment"),{inspect:fTe}=require("util"),FW=require("is-number"),nUe=require("lodash"),ETe=require("minimist"),hTe=require("https"),pTe=require("http"),{hdb_errors:XT}=_e(),mTe=/^((\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d\.\d+([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z)))$/,$W=require("util").promisify(setTimeout),STe=100,TTe=5,gTe="",ATe=4,GW={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};JW.exports={isEmpty:ss,isEmptyOrZeroLength:Wi,arrayHasEmptyValues:bTe,arrayHasEmptyOrZeroLengthValues:OTe,buildFolderPath:NTe,isBoolean:VW,errorizeMessage:RTe,stripFileExtension:wTe,autoCast:CTe,autoCastJSON:KW,autoCastJSONDeep:Pw,removeDir:DTe,compareVersions:PTe,isCompatibleDataVersion:LTe,escapeRawValue:MTe,unescapeValue:UTe,stringifyProps:vTe,timeoutPromise:HTe,isClusterOperation:kTe,getClusterUser:GTe,checkGlobalSchemaTable:FTe,getHomeDir:WW,getPropsFilePath:BTe,promisifyPapaParse:qTe,removeBOM:jW,createEventPromise:$Te,checkProcessRunning:VTe,checkSchemaTableExist:KTe,checkSchemaExists:zW,checkTableExists:QW,getStartOfTomorrowInSeconds:YTe,getLimitKey:WTe,isObject:ITe,isNotEmptyAndHasValue:yTe,autoCasterIsNumberCheck:YW,backtickASTSchemaItems:jTe,isPortTaken:xTe,createForkArgs:zTe,autoCastBoolean:QTe,async_set_timeout:$W,getTableHashAttribute:JTe,doesSchemaExist:XTe,doesTableExist:ZTe,stringifyObj:ege,ms_to_time:tge,changeExtension:rge,getEnvCliRootPath:Lw,noBootFile:nge,httpRequest:sge,transformReq:ige,convertToMS:oge,PACKAGE_ROOT:Kt.PACKAGE_ROOT};function RTe(e){return e instanceof Error?e:new Error(e)}a(RTe,"errorizeMessage");function ss(e){return e==null}a(ss,"isEmpty");function yTe(e){return!ss(e)&&(e||e===0||e===""||VW(e))}a(yTe,"isNotEmptyAndHasValue");function Wi(e){return ss(e)||e.length===0||e.size===0}a(Wi,"isEmptyOrZeroLength");function bTe(e){if(ss(e))return!0;for(let t=0;t<e.length;t++)if(ss(e[t]))return!0;return!1}a(bTe,"arrayHasEmptyValues");function OTe(e){if(Wi(e))return!0;for(let t=0;t<e.length;t++)if(Wi(e[t]))return!0;return!1}a(OTe,"arrayHasEmptyOrZeroLengthValues");function NTe(...e){try{return e.join(ka.sep)}catch{console.error(e)}}a(NTe,"buildFolderPath");function VW(e){return ss(e)?!1:e===!0||e===!1}a(VW,"isBoolean");function ITe(e){return ss(e)?!1:typeof e=="object"}a(ITe,"isObject");function wTe(e){return Wi(e)?gTe:e.slice(0,-ATe)}a(wTe,"stripFileExtension");function CTe(e){return ss(e)||e===""||typeof e!="string"?e:GW[e]!==void 0?GW[e]:YW(e)===!0?Number(e):mTe.test(e)?new Date(e):e}a(CTe,"autoCast");function KW(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(KW,"autoCastJSON");function Pw(e){if(e&&typeof e=="object"){if(Array.isArray(e))for(let t=0,r=e.length;t<r;t++){let n=e[t],s=Pw(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=Pw(r);n!==r&&(e[t]=n)}return e}else return KW(e)}a(Pw,"autoCastJSONDeep");function YW(e){if(e.startsWith("0.")&&FW(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&FW(e))}a(YW,"autoCasterIsNumberCheck");async function DTe(e){if(Wi(e))throw new Error(`Directory path: ${e} does not exist`);try{await xW.emptyDir(e),await xW.remove(e)}catch(t){throw In.error(`Error removing files in ${e} -- ${t}`),t}}a(DTe,"removeDir");function PTe(e,t){if(Wi(e)){In.info("Invalid current version sent as parameter.");return}if(Wi(t)){In.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,o=s.replace(n,"").split("."),c=i.replace(n,"").split("."),l=Math.min(o.length,c.length);for(let u=0;u<l;u++)if(r=parseInt(o[u],10)-parseInt(c[u],10),r)return r;return o.length-c.length}a(PTe,"compareVersions");function LTe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(LTe,"isCompatibleDataVersion");function MTe(e){if(ss(e))return e;let t=String(e);return t==="."?Kt.UNICODE_PERIOD:t===".."?Kt.UNICODE_PERIOD+Kt.UNICODE_PERIOD:t.replace(Kt.FORWARD_SLASH_REGEX,Kt.UNICODE_FORWARD_SLASH)}a(MTe,"escapeRawValue");function UTe(e){if(ss(e))return e;let t=String(e);return t===Kt.UNICODE_PERIOD?".":t===Kt.UNICODE_PERIOD+Kt.UNICODE_PERIOD?"..":String(e).replace(Kt.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(UTe,"unescapeValue");function vTe(e,t){if(ss(e))return In.info("Properties object is null"),"";let r="";return e.each(function(n,s){try{if(t&&t[n]){let i=t[n];for(let o of i)r+=";"+o+QT.EOL}!Wi(n)&&n[0]===";"?r+=" "+n+s+QT.EOL:Wi(n)||(r+=n+"="+s+QT.EOL)}catch{In.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(vTe,"stringifyProps");function WW(){let e;try{e=QT.homedir()}catch{e=process.env.HOME}return e}a(WW,"getHomeDir");function BTe(){let e=ka.join(WW(),Kt.HDB_HOME_DIR_NAME,Kt.BOOT_PROPS_FILE_NAME);return qW.existsSync(e)||(e=ka.join(__dirname,"../","hdb_boot_properties.file")),e}a(BTe,"getPropsFilePath");function HTe(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:a(function(){clearTimeout(r)},"cancel")}}a(HTe,"timeoutPromise");async function xTe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=uTe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(xTe,"isPortTaken");function kTe(e){try{return Kt.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){In.error(`Error checking operation against cluster ops ${t}`)}return!1}a(kTe,"isClusterOperation");function FTe(e,t){let r=(Pe(),oe(lt)).getDatabases();if(!r[e])return XT.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return XT.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(FTe,"checkGlobalSchemaTable");function GTe(e,t){if(ss(t)){In.warn("No CLUSTERING_USER defined, clustering disabled");return}if(ss(e)||Wi(e)){In.warn("No users to search.");return}let r;try{let n=e.get(t);n&&n.role.permission.cluster_user===!0&&n.active===!0&&(r=n)}catch(n){In.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){In.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(GTe,"getClusterUser");function qTe(){kW.parsePromise=function(e,t,r){return new Promise(function(n,s){kW.parse(e,{header:!0,transformHeader:jW,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(qTe,"promisifyPapaParse");function jW(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(jW,"removeBOM");function $Te(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;In.info(`Got cluster status event response: ${fTe(s)}`);try{i.cancel()}catch{In.error("Error trying to cancel timeout.")}n(s)})})}a($Te,"createEventPromise");async function VTe(e){let t=!0,r=0;do await $W(STe*r++),(await _Te.findPs(e)).length>0&&(t=!1);while(t&&r<TTe);if(t)throw new Error(`process ${e} was not started`)}a(VTe,"checkProcessRunning");function KTe(e,t){let r=zW(e);if(r)return r;let n=QW(e,t);if(n)return n}a(KTe,"checkSchemaTableExist");function zW(e){let{getDatabases:t}=(Pe(),oe(lt));if(!t()[e])return XT.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(zW,"checkSchemaExists");function QW(e,t){let{getDatabases:r}=(Pe(),oe(lt));if(!r()[e][t])return XT.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(QW,"checkTableExists");function YTe(){let e=JT().utc().add(1,Kt.MOMENT_DAYS_TAG).startOf(Kt.MOMENT_DAYS_TAG).unix(),t=JT().utc().unix();return e-t}a(YTe,"getStartOfTomorrowInSeconds");function WTe(){return JT().utc().format("DD-MM-YYYY")}a(WTe,"getLimitKey");function jTe(e){try{let t=new dTe(e);for(let{node:r}of t)r&&(r.columnid&&typeof r.columnid!="string"&&(r.columnid=r.columnid.toString()),r.columnid&&!r.columnid.startsWith("`")&&(r.columnid_orig=r.columnid,r.columnid=`\`${r.columnid}\``),r.tableid&&!r.tableid.startsWith("`")&&(r.tableid_orig=r.tableid,r.tableid=`\`${r.tableid}\``),r.databaseid&&!r.databaseid.startsWith("`")&&(r.databaseid_orig=r.databaseid,r.databaseid=`\`${r.databaseid}\``),r.as&&typeof r.as=="string"&&!r.as.startsWith("[")&&(r.as_orig=r.as,r.as=`\`${r.as}\``))}catch(t){In.error("Got an error back ticking items."),In.error(t)}}a(jTe,"backtickASTSchemaItems");function zTe(e){return[e]}a(zTe,"createForkArgs");function QTe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(QTe,"autoCastBoolean");function JTe(e,t){let{getDatabases:r}=(Pe(),oe(lt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(JTe,"getTableHashAttribute");function XTe(e){let{getDatabases:t}=(Pe(),oe(lt));return t()[e]!==void 0}a(XTe,"doesSchemaExist");function ZTe(e,t){let{getDatabases:r}=(Pe(),oe(lt));return r()[e]?.[t]!==void 0}a(ZTe,"doesTableExist");function ege(e){try{return JSON.stringify(e)}catch{return e}}a(ege,"stringifyObj");function tge(e){let t=JT.duration(e),r=t.seconds()>0?t.seconds()+"s":"",n=t.minutes()>0?t.minutes()+"m ":"",s=t.hours()>0?t.hours()+"h ":"",i=t.days()>0?t.days()+"d ":"";return(t.years()>0?t.years()+"y ":"")+i+s+n+r}a(tge,"ms_to_time");function rge(e,t){let r=ka.basename(e,ka.extname(e));return ka.join(ka.dirname(e),r+t)}a(rge,"changeExtension");function Lw(){if(process.env[Kt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[Kt.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=ETe(process.argv);if(e[Kt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[Kt.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(Lw,"getEnvCliRootPath");var Dw;function nge(){if(Dw)return Dw;let e=Lw();if(Lw()&&qW.pathExistsSync(ka.join(e,Kt.HDB_CONFIG_FILE)))return Dw=!0,!0}a(nge,"noBootFile");function sge(e,t){let r;return e.protocol==="http:"?r=pTe:r=hTe,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8"),o.body="",o.on("data",c=>{o.body+=c}),o.on("end",()=>{n(o)})});i.on("error",o=>{s(o)}),i.write(t instanceof Buffer?t:JSON.stringify(t)),i.end()})}a(sge,"httpRequest");function ige(e){if(!e.schema&&!e.database){e.schema=Kt.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(ige,"transformReq");function oge(e){let t=0;if(typeof e=="number"&&(t=e),typeof e=="string")switch(t=parseFloat(e),e.slice(-1)){case"M":t*=86400*30;break;case"D":case"d":t*=86400;break;case"H":case"h":t*=3600;break;case"m":t*=60;break}return t*1e3}a(oge,"convertToMS")});var ZW=N((aUe,XW)=>{"use strict";var Mw=M(),age=te(),cge=Pi(),di=W(),lge=Sm(),uge=hf(),oUe=xu(),dge=us(),_ge=gf(),fge=require("semver/functions/gte"),Ege=3e4,hge=7;XW.exports=pge;async function pge(){try{di.notify("Starting update nodes. This process will attempt to update any node connections the need to be reestablished after a 4.0.0 upgrade"),await dge.setSchemaDataToGlobalAsync();let e=await cge.getAllNodeRecords(),t=[];for(let r=0,n=e.length;r<n;r++){let s=e[r];s.system_info.hdb_version===Mw.PRE_4_0_0_VERSION&&t.push(mge(s))}await Promise.allSettled(t),di.notify("Shutting down 4.0.0 clustering upgrade process")}catch(e){throw di.error(e),e}}a(pge,"updateAllNodes");async function mge(e){try{let{name:t,subscriptions:r}=e;di.notify("Running 4.0.0 update on node:",t);let n=!1,s=0;for(;s<hge;){let i=[];if(await lge.buildNodeStatus(e,i),di.trace("Received status:",i[0].status,"from node:",t),i[0].status==="open"&&fge(i[0].system_info.hdb_version,"4.0.0")){di.notify("Received open status from node:",t,"calling add node");let o={operation:Mw.OPERATIONS_ENUM.ADD_NODE,node_name:t,subscriptions:r};await uge(o,!0),di.notify("Successfully added node",t),n=!0;break}s=(Date.now()-e.__updatedtime__)/(1e3*60*60*24),di.trace("Update node has been running for",s,"days. Calling node status again for node:",t),await age.async_set_timeout(Ege)}n||(di.error("4.0.0 node update was unable to update connection to node:",t),di.error("Removing following node record from hdb_nodes",e),await _ge({operation:Mw.OPERATIONS_ENUM.REMOVE_NODE,node_name:t}))}catch(t){throw di.error(t),t}}a(mge,"updateNode")});var Sge=ZW();(async()=>{try{await Sge()}catch(e){console.error("Error launching 4.0.0 node update"),console.error(e),process.exit(1)}})();
132
+ `))}},25).unref()}o.close?.(()=>{if(At.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&ud()==0)try{GK(VK(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(KK||process.env.DEV_MODE)try{require("inspector").close()}catch(i){Nn.info("Could not close debugger",i)}}}).ref();let e;wE&&!nme&&(e=WK()),Promise.resolve(e).then(()=>{if(ud()===0)try{eme(PI)}catch(t){console.error("Error displaying start-up log",t)}CE?.postMessage({type:Zt.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(YK,"startServers");function WK(){let e=[];for(let t in Vi){let r=Vi[t];if(t.includes?.("/")&&ud()==0){Wpe(t)&&GK(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=ud();if(c<o[0]||c>o[1])continue}let i;try{let o=t.lastIndexOf(":");o>0?wE?n={fd:wE(+t.slice(o+1).replace(/[\[\]]/g,""),t.slice(0,o))}:n={host:+t.slice(o+1).replace(/[\[\]]/g,""),port:t.slice(0,o)}:wE?n={fd:wE(+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(WK,"listenOnPorts");!CI&&!Gpe?.noServerStart&&YK();function UI(e,t,r){let n=e?.read?e:new qpe({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=Vi[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=Vi[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 BK=new Map;function sme(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=BK.get(s),r){case"connection":i=UI(void 0,t),BK.set(s,i),i.write=(c,l,u)=>(CE.postMessage({requestId:s,event:"data",data:c.toString("latin1")}),u&&u(),!0),i.end=(c,l,u)=>(CE.postMessage({requestId:s,event:"end",data:c?.toString("latin1")}),u&&u(),!0);let o=i.destroy;i.destroy=()=>{o.call(i),CE.postMessage({requestId:s,event:"destroy"})};break;case"data":i._readableState.destroyed||i.emit("data",Buffer.from(n,"latin1"));break;case"drain":i._readableState.destroyed||i.emit("drain",{});break;case"end":i._readableState.destroyed||i.emit("end",{});break;case"error":i._readableState.destroyed||i.emit("error",{});break}}a(sme,"proxyRequest");var{getComponentName:eT}=(Xf(),oe(Jf));function vI(e,t,r=!0){t||(t=At.get(Zt.CONFIG_PARAMS.HTTP_PORT));let n=Vi[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",FK),s.on("unhandled",(i,o)=>{e.cantCleanupProperly&&(n.cantCleanupProperly=!0),e.emit("request",i,o)}),n.lastServer=e}else Vi[t]=e;e.on("unhandled",FK)}a(vI,"registerServer");function BI(e){let t=[],r=e?.securePort;return r&&t.push({port:r,secure:!0}),r=e?.port,r&&t.push({port:r,secure:!1}),t.length===0&&(t=[],At.get(Zt.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:At.get(Zt.CONFIG_PARAMS.HTTP_PORT),secure:At.get(Zt.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),At.get(Zt.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:At.get(Zt.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&At.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:VK(At.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)),secure:!1}),t}a(BI,"getPorts");function HI(e,t){let r=[];for(let{port:n,secure:s}of BI(t))r.push(jK(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 jK(e,t,r,n){if(tT(e,{protocol_name:t?"HTTPS":"HTTP",name:eT()}),!JS[e]){let s=r?"operationsApi_network":"http",i=At.get(s+"_keepAliveTimeout"),o=At.get(s+"_timeout"),c=At.get(s+"_headersTimeout"),l={noDelay:!0,keepAliveTimeout:i,headersTimeout:c,requestTimeout:o,highWaterMark:128*1024,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,maxHeaderSize:At.get(Zt.CONFIG_PARAMS.HTTP_MAXHEADERSIZE)},u=At.get(s+"_mtls"),d=At.get(s+"_mtls_required");t&&Object.assign(l,{allowHTTP1:!0,rejectUnauthorized:!!d,requestCert:!!(u||n),ticketKeys:Qpe(),SNICallback:$K(r?"operations-api":"server",u),ALPNCallback:a(function(f){return f.protocols.includes("harperdb-replication")&&(this.isReplicationConnection=!0),"http/1.1"},"ALPNCallback"),ALPNProtocols:null});let _=Zpe(),E=JS[e]=(t?Ype:Vpe)(l,async(f,h)=>{try{let m=performance.now(),g=new qK(f,h);r&&(g.isOperationsServer=!0);let S=await ZS[e](g);if(!S){if(g._nodeResponse.statusCode)return;S=zK(g)}if(S.headers?.set||(S.headers=new DI(S.headers)),_?S.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):S.headers?.set?.("Server","HarperDB"),S.status===-1){for(let ne of S.headers||[])h.setHeader(ne[0],ne[1]);return f.baseRequest=g,h.baseResponse=S,JS[e].emit("unhandled",f,h)}let y=S.status||200,I=performance.now(),U=I-m,H=S.body,X;if(!S.handlesHeaders){let ne=S.headers||new DI;H?H.length>=0&&(typeof H=="string"?ne.set("Content-Length",Buffer.byteLength(H)):ne.set("Content-Length",H.length),X=!0):(ne.set("Content-Length","0"),X=!0);let Q=`hdb;dur=${U.toFixed(2)}`;S.wasCacheMiss&&(Q+=", miss"),Xpe(ne,"Server-Timing",Q,!0),h.headersSent||h.writeHead(y,ne&&(ne[Symbol.iterator]?Array.from(ne):ne)),X&&h.end(H)}let Y=g.handlerPath,V=g.method;if(NE(U,"duration",Y,V,S.wasCacheMiss==null?void 0:S.wasCacheMiss?"cache-miss":"cache-hit"),UK(y<400,"success",Y,V),UK(1,"response_"+y,Y,V),!X)if(H instanceof ReadableStream&&(H=vK.fromWeb(H)),(H[Symbol.iterator]||H[Symbol.asyncIterator])&&(H=vK.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",()=>{NE(performance.now()-I,"transfer",Y,V),NE(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&&NE(performance.now()-f._parent.startTime,"tls-handshake",e),NE(f.isSessionReused(),"tls-reused",e)}),E.isSecure=!0),vI(E,e)}return JS[e]}a(jK,"getHTTPServer");function rT(e,t){let r=zK;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 zK(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new DI}}a(zK,"unhandled");function ime(e,t){HI(e,{requestOnly:!0,...t})}a(ime,"onRequest");function ome(e,t){let r;if(t.securePort){tT(t.securePort,{protocol_name:"TLS",name:eT()});let n=$K("server",t.mtls);r=zpe({rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,SNICallback:n},e),n.initialize(r),Vi[t.securePort]=r}return t.port&&(tT(t.port,{protocol_name:"TCP",name:eT()}),r=$pe(e,{noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600}),Vi[t.port]=r),r}a(ome,"onSocket");Object.defineProperty(Kpe.prototype,"upgrade",{get(){return"connection"in this.headers&&"upgrade"in this.headers&&this.headers.connection.toLowerCase().includes("upgrade")&&this.headers.upgrade.toLowerCase()=="websocket"},set(e){}});var HK=[],MI={};function QK(e,t){for(let{port:r}of BI(t))HK[t?.runFirst?"unshift":"push"]({listener:e,port:r}),MI[r]=rT(HK,r)}a(QK,"onUpgrade");var xK=[],kK={};function ame(e,t){let r=[];for(let{port:n,secure:s}of BI(t)){tT(n,{protocol_name:s?"WSS":"WS",name:eT()});let i=jK(n,s,t?.isOperationsServer,t?.mtls);IE[n]||(IE[n]=new jpe({noServer:!0,maxPayload:t.maxPayload??100*1024*1024}),IE[n].on("connection",(o,c)=>{let l=new qK(c);l.isWebSocket=!0;let u=ZS[n](l);kK[n](o,l,u)}),QK((o,c,l,u)=>o.__harperdb_request_upgraded?u(o,c,l):IE[n].handleUpgrade(o,c,l,d=>{o.__harperdb_request_upgraded=!0,u(o,c,l),IE[n].emit("connection",d,o)}),{port:n}),i.on("upgrade",(o,c,l)=>{MI[n]&&MI[n](o,c,l)})),r.push(i),xK[t?.runFirst?"unshift":"push"]({listener:e,port:n}),kK[n]=rT(xK,n),ZS[n]=rT(LI,n)}return r}a(ame,"onWebSocket");function FK(e,t){t.writeHead(404),t.end(`Not found
133
+ `)}a(FK,"defaultNotFound")});var MK={};je(MK,{startHTTPThreads:()=>lme,startSocketServer:()=>$I,updateWorkerIdleness:()=>sY});async function lme(e=2,t){try{if(t)GI(0,1,!0);else{let{loadRootComponents:r}=nT();if(e===0)return(0,Ds.setMainIsWorker)(!0),await xI().startServers(),Promise.resolve([]);await r()}nY();for(let r=0;r<e;r++)GI(r,e);return Promise.all(rY)}finally{(0,Ds.threadsHaveStarted)()}}function nY(){let e=(0,eY.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),FI=setInterval(()=>{oT.notify(e)},cme).unref())}function GI(e,t=1,r){if(kI++,(0,Ds.startWorker)("server/threads/threadServer.js",{name: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)});rY.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)tY[c.localPort](null,c)}}}),r){let n=setInterval(()=>{qI?qI=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,Ds.shutdownWorkers)(),kI=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function $I(e=0,t){if(typeof e=="string")try{(0,aT.existsSync)(e)&&(0,aT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=ume:r=dme(t):r=VI;let n=(0,fd.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);if(n._handle){n._handle.onconnection=tY[e]=function(i,o){r.readsData||(o.reading=!1,o.readStop()),qI=!0,r(o,(c,l)=>{if(!c){if(JK){let d=o._socket||new fd.Socket({handle:o,writable:!0,readable:!0});JK.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});Eme(d,c,e)}pr(!0,"socket-routed")})};let s=Xl();oT.info(`HarperDB ${s.version} Server running on port ${e}`)}return n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function VI(e,t){let r,n=0;for(let s of 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 ume(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 dme(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 sY(){sT=0;for(let e of dd)e.expectedIdle=e.recentELU.idle+_me,e.requests=1;dd.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function Eme(e,t,r){let n=fme++;t.postMessage({port:r,requestId:n,event:"connection"}),e.on("data",s=>{let i=s.toString("latin1");t.postMessage({port:r,requestId:n,data:i,event:"data"})}).on("close",s=>{t.postMessage({port:r,requestId:n,event:"close",hadError:s})}).on("error",s=>{t.postMessage({port:r,requestId:n,event:"error",error:s})}).on("drain",s=>{t.postMessage({port:r,requestId:n,event:"drain",error:s})}).on("end",()=>{t.postMessage({port:r,requestId:n,event:"end"})}).resume(),iT.set(n,s=>{s.event=="data"&&e.write(Buffer.from(s.data,"latin1")),s.event=="end"&&(e.end(s.data&&Buffer.from(s.data,"latin1")),iT.delete(n)),s.event=="destroy"&&(e.destroy(),iT.delete(n))})}var Ds,fd,hd,oT,aT,ZK,eY,dd,_d,tY,JK,kI,rY,FI,cme,qI,sT,XK,Ed,_me,iT,fme,wI=Ie(()=>{Ds=L(dt()),fd=require("net"),hd=L(M()),oT=L(W()),aT=require("fs");Ii();ZK=require("worker_threads"),eY=L(_c()),dd=[],_d=[],tY=[],kI=0,rY=[];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),nY())}));cme=6e5;a(lme,"startHTTPThreads");a(nY,"licenseWarning");a(GI,"startHTTPWorker");a($I,"startSocketServer");sT=0;a(VI,"findMostIdleWorker");XK=36e5,Ed=new Map;a(ume,"findByRemoteAddressAffinity");a(dme,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of Ed)r.lastUsed+XK<e&&Ed.delete(t)},XK).unref();_me=1e3;a(sY,"updateWorkerIdleness");(0,Ds.setMonitorListener)(sY);iT=new Map,fme=1;a(Eme,"proxySocket")});var cY=N(($Le,aY)=>{"use strict";var hme=require("cluster"),ml=se();ml.initSync();var oY=M(),xLe=require("util"),Ho=W(),kLe=require("fs"),pme=require("fastify"),FLe=Xl(),mme=require("@fastify/cors"),Sme=require("@fastify/compress"),Tme=require("@fastify/static"),gme=FN(),Ame=require("path"),{PACKAGE_ROOT:Rme}=M(),yme=us(),bme=te(),Ome=xn(),Nme=_c(),{server:Ime}=(qr(),oe(Ja)),{node_request_key:GLe}=(vS(),oe(JN)),{authHandler:wme,handlePostRequest:Cme,serverErrorHandler:Dme,reqBodyValidationHandler:Pme}=LS(),qLe=require("net"),{registerContentHandlers:Lme}=(zc(),oe(V$)),Mme=6e4,Ume=1024*1024*1024,vme="TRUE",{CONFIG_PARAMS:PE}=oY,pd;aY.exports={hdbServer:iY,start:iY};async function iY(e){try{Ho.debug("In Fastify server"+process.cwd()),Ho.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Ho.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=hme.isMaster,await Bme();let t=e.securePort>0;pd=Hme(t),await pd.ready(),e||(e={}),e.isOperationsServer=!0;try{Ime.http(pd.server,e),pd.server.closeIdleConnections||await pd.listen({port:0,host:"::"})}catch(r){throw pd.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(iY,"operationsServer");async function Bme(){Ho.trace("Configuring HarperDB process."),yme.setSchemaDataToGlobal(),await Ome.setUsersToGlobal(),await Nme.getLicense()}a(Bme,"setUp");function Hme(e){Ho.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=xme(e),r=pme(t);r.server.headersTimeout=Fme(),r.setErrorHandler(Dme);let n=kme();n&&r.register(mme,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,u){r.server.emit("unhandled",l.raw,u.raw)}),c()}),r.register(gme),r.register(Sme),r.register(Tme,{root:Ame.join(Rme,"studio/build-local")}),Lme(r);let s=ml.get(oY.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!bme.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[Pme,wme],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),Cme(i,o)}),r.get("/health",()=>"HarperDB is running."),Ho.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(Hme,"buildServer");function xme(e){let t=ml.get(PE.OPERATIONSAPI_NETWORK_TIMEOUT),r=ml.get(PE.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:Ume,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(xme,"getServerOptions");function kme(){let e=ml.get(PE.OPERATIONSAPI_NETWORK_CORS),t=ml.get(PE.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===vme)&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},t&&t.length>0&&t[0]!==null&&t[0]!=="*"&&(r.origin=(n,s)=>s(null,t.indexOf(n)!==-1))),r}a(kme,"getCORSOpts");function Fme(){return ml.get(PE.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??Mme}a(Fme,"getHeaderTimeoutConfig")});var QI={};je(QI,{disableNATS:()=>qme,publishToStream:()=>uT,setNATSReplicator:()=>KI,setPublishToStream:()=>$me,setSubscription:()=>zI,start:()=>Gme});function Gme(){LE.default.get(ME.default.CONFIG_PARAMS.CLUSTERING_ENABLED)&&Kme()}function qme(e=!0){fY=e}function $me(e,t){uT=e,zI=t}function Kme(){if(fY||process.env._DISABLE_NATS)return;let e=ut(),t=Object.keys(e);t.push("system");for(let r of t){let n=e[r];for(let s in n){let i=n[s];KI(s,r,i)}}Lc((r,n)=>{KI(r.tableName,r.databaseName,r),n&&hY(r)}),!lY&&(lY=!0)}function KI(e,t,r){if(t==="system"&&Yme.includes(e))return;if(!r)return console.error(`Attempt to replicate non-existent table ${e} from database ${t}`);if(r.sources.some(s=>s?.isNATSReplicator))return;r.sourcedFrom(class extends Lr{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this[ze],record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this[ze]})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this[ze],record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this[ze],record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this[ze]})}static defineSchema(i){hY(i)}static subscribe(){let i=new Mn;return zI(t,e,i),i}static subscribeOnThisThread(i){return i<(LE.default.get(ME.default.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??Vme)}static isEqual(i){return i.isNATSReplicator}static isNATSReplicator=!0;static shouldReceiveInvalidations=!0},{intermediateSource:!0});function n(s){let i=s?.transaction?.nats;if(!i)if(s?.transaction){s.transaction.nats=i=new cT(s.transaction,s);let o=s.transaction;for(;o.next;)o=o.next;o.next=s.transaction.nats,i.user=s.user,i.context=s}else i=EY;return i}a(n,"getNATSTransaction")}function hY(e){let t=LE.default.get(ME.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 uY,WI,jI,dY,_Y,LE,ME,lT,fY,uT,zI,Vme,EY,lY,Yme,cT,YI,pY=Ie(()=>{Pe();Vs();uY=L(mr()),WI=L(Ct()),jI=L(to());Ll();dY=L(ey()),_Y=L(cn()),LE=L(se()),ME=L(M()),lT=L(W());a(Gme,"start");a(qme,"disableNATS");uT=uY.publishToStream,zI=dY.setSubscription;a($me,"setPublishToStream");Vme=2;a(Kme,"assignReplicationSource");Yme=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(KI,"setNATSReplicator");a(hY,"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=LE.default.get(ME.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,_Y.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};EY=new YI});async function AY({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},UE.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=Ci.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 SY,Ua,TY,gY,mY,JI,UE,dT,_T,ew,RY=Ie(()=>{Pe();su();SY=L(cn()),Ua=L(W());Sc();TY=L(dt()),gY=L(xI());qr();mY=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"}]}}]}),UE=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,TY.getWorkerIndex)()===0&&(async()=>{await gY.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of UE.search({})){let t=e.data,r={...e};r.user?.username&&(r.user=await it.getUser(r.user.username));try{await ZI(r,t,r)}catch{(0,Ua.warn)("Failed to publish will",t)}UE.delete(e.id)}})();a(AY,"getSession");dT=1;a(XI,"getNextMessageId");_T=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;request;socket;subscriptions=[];awaitingAcks;sessionWasPresent;keepalive;keepaliveTimer;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),l,u;if(c>-1?(l=s.slice(c),u=s.slice(0,c)):u=s,!u)throw new Error("No topic provided");if(u.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let d=this.subscriptions.find(g=>g.topic===s),_;d?(_=i>0,d.end(),this.subscriptions.splice(this.subscriptions.indexOf(d),1)):_=i===2;let E={search:l,async:!0,user:this.user,startTime:o,omitCurrent:_,url:""};o&&(0,Ua.trace)("Resuming subscription from",s,"from",o);let f=Ci.getMatch(u,"mqtt");if(!f){let g=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw g.statusCode=404,g}if(E.url=f.relativeURL,E.url.indexOf("+")>-1||E.url.indexOf("#")>-1){let g=E.url.slice(1);if(g.indexOf("#")>-1&&g.indexOf("#")!==g.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(E.isCollection=!0,g.indexOf("+")===g.length-1)E.onlyChildren=!0,E.url="/"+g.slice(0,g.length-1);else{let S=g.split("/"),y;for(let H=0;H<S.length;H++)if(S[H].indexOf("+")>-1)if(S[H]==="+")y=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&y)throw new Error("Filters can not be combined");let I=!0;S[S.length-1]==="#"&&(S.length--,I=!1),y&&(n=a(H=>{let X=H.id;if(!Array.isArray(X))if(X?.indexOf?.("/")>-1)X=X.split("/");else return!1;if(I&&X.length!==S.length)return!1;for(let Y=0;Y<S.length;Y++)if(S[Y]!=="+"&&S[Y]!==X[Y])return!1;return!0},"filter"));let U=S.indexOf("+");E.url="/"+(U>-1?S.slice(0,U):S).concat("").join("/")}}let h=f.path,T=f.Resource,m=await Dt(E,async()=>{let g=this.createContext();g.topic=s,g.retainHandling=i;let S=await T.subscribe(E,g);if(!S)return;if(!S[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let y=(async()=>{for await(let I of S)try{let U;if(I.type&&I.type!=="put"&&I.type!=="delete"&&I.type!=="message"&&I.type!=="patch"||n&&!n(I))continue;r?(I.topic=s,U=this.needsAcknowledge(I)):(I.acknowledge?.(),U=XI());let H=I.id;if(Array.isArray(H)&&(H=nu(H)),H==null&&(H=""),await this.listener(h+"/"+H,I.value,U,t)===!1)break;this.awaitingAcks?.size>mY?await new Promise(Y=>setTimeout(Y,this.awaitingAcks.size-mY)):await new Promise(setImmediate)}catch(U){(0,Ua.warn)(U)}})();return S});if(m)return m.topic=s,m.qos=t.qos,this.subscriptions.push(m),m}resume(){}needsAcknowledge(t){let r=XI();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,{acknowledge:t.acknowledge})),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r.acknowledge())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),this.subscriptions.splice(this.subscriptions.indexOf(r),1),!0}async publish(t,r){return ZI(t,r,this.createContext())}createContext(){let t={session:this,socket:this.socket,user:this.user,authorize:!0};return this.request&&(t.request=this.request,t.url=this.request.url,t.headers=this.request.headers),t}setListener(t){this.listener=t}disconnect(t){this.keepaliveTimer&&clearTimeout(this.keepaliveTimer);let r=this.createContext();Dt(r,async()=>{try{if(!t){let n=await UE.get(this.sessionId);n?.doesExist()&&await ZI(n,n.data,r)}}finally{await UE.delete(this.sessionId)}}).catch(n=>{(0,Ua.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}receivedPacket(){this.keepalive&&(clearTimeout(this.keepaliveTimer),this.keepaliveTimer=setTimeout(()=>{this.socket?.destroy?this.socket.destroy(new Error("Keepalive timeout")):this.socket?.terminate()},this.keepalive*1500))}};a(ZI,"publish");ew=class extends _T{static{a(this,"DurableSubscriptionsSession")}sessionRecord;constructor(t,r,n){super(t,r),this.sessionRecord=n||{id:t,subscriptions:[]}}async resume(){for(let t of this.sessionRecord.subscriptions||[])await this.resumeSubscription({omitCurrent:!0,topic:t.topic,qos:t.qos,startTime:t.startTime},!0,t.acks?r=>!t.acks.includes(r.localTime):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=XI(),n={topic:t.topic,timestamp:t.localTime};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks?.get(t);if(!r)return;this.awaitingAcks?.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,Ua.trace)("Received ack",n,r.timestamp),this.sessionRecord.update();return}}for(let s of this.sessionRecord.subscriptions)s.topic===n&&(s.startTime=r.timestamp);this.sessionRecord.update()}async addSubscription(t,r){await this.resumeSubscription(t,r);let{qos:n,startTime:s}=t;return n>0&&!s&&this.saveSubscriptions(),t.qos}removeSubscription(t){let r=this.subscriptions.find(s=>s.topic===t),n=super.removeSubscription(t);return r.qos>0&&this.saveSubscriptions(),n}saveSubscriptions(){this.sessionRecord.subscriptions=this.subscriptions.map(t=>{let r=t.startTime;return r||(r=t.startTime=(0,SY.getNextMonotonicTime)()),(0,Ua.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),JI.put(this.sessionRecord)}}});var rw={};je(rw,{bypassAuth:()=>Wme,start:()=>jme});function Wme(){IY=!0}function jme({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new NY.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}=bY(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&&IY&&u.remoteAddress.includes("127.0.0.1")&&(d=await(0,OY.getSuperUser)(),dr.debug?.("Auto-authorizing local connection",d?.username));let{onMessage:_,onClose:E}=bY(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 bY(e,t,r,n,s){yY||(yY=!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,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=AY({user:n,..._}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(V){return dr.error?.(V),s.events.emit("auth-failed",_,e,V),qn(!1,"connection","mqtt","connect"),m({cmd:"connack",reasonCode:V.code||5,returnCode:V.code||128})}s.events.emit("connected",o,e),qn(!0,"connection","mqtt","connect"),m({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0}),o.setListener((V,ne,Q,de)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",V);let j=V.indexOf("/",1),ae=j>0?V.slice(0,j):V;m({cmd:"publish",topic:V,payload:S(ne),messageId:Q||Math.floor(Math.random()*1e8),qos:de.qos},ae);let Oe=e._socket??e;return Oe.writableNeedDrain?new Promise(Ne=>Oe.once("drain",Ne)):!Oe.closed}catch(j){return dr.error?.(j),o?.disconnect(),s.sessions.delete(o),!1}}),o.sessionWasPresent&&await o.resume();break;case"subscribe":let y=[];for(let V of _.subscriptions){let ne;try{let Q=await o.addSubscription(V,V.qos>=1);ne=Q?Q.qos||0:c.protocolVersion<5?128:143}catch(Q){s.events.emit("error",Q,e,V,o),Q.statusCode?Q.statusCode===500?dr.warn?.(Q):dr.info?.(Q):dr.error?.(Q),ne=c.protocolVersion<5?128:Q.statusCode===403?135:Q.statusCode===404?143:128}y.push(ne)}await o.committed,m({cmd:"suback",granted:y,messageId:_.messageId});break;case"unsubscribe":{let V=[];for(let ne of _.unsubscriptions)V.push(o.removeSubscription(ne)?0:17);m({cmd:"unsuback",granted:V,messageId:_.messageId});break}case"pubrel":m({cmd:"pubcomp",messageId:_.messageId,reasonCode:0});return;case"publish":let I=_.qos===2?"pubrec":"puback",U=e.deserialize||(e.deserialize=bo(r?.headers.get?.("content-type"))),X=(_.payload?.length||0)>0?U(_.payload):void 0,Y;try{Y=await o.publish(_,X)}catch(V){s.events.emit("error",V,e,_,o),dr.warn?.(V),_.qos>0&&m({cmd:I,messageId:_.messageId,reasonCode:128},_.topic);break}_.qos>0&&m({cmd:I,messageId:_.messageId,reasonCode:Y===!1?144:0},_.topic);break;case"pubrec":m({cmd:"pubrel",messageId:_.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(_.messageId);break;case"pingreq":m({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),qn(!0,"connection","mqtt","disconnect"),dr.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(y){s.events.emit("error",y,e,_,o),dr.error?.(y),m({cmd:"disconnect"})}function m(y,I){let U=(0,hT.generate)(y,c);t(U),pr(U.length,"bytes-sent",I,g(y),"mqtt")}a(m,"sendPacket");function g(y){return y.qos>0?y.cmd+",qos="+y.qos:y.cmd}a(g,"packetMethodName");function S(y){return jc(y,r)}a(S,"serialize")}),l.on("error",_=>{dr.warn("MQTT parsing error, closing connection:",_.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:u,onClose:d}}var hT,OY,md,kr,tw,NY,ET,dr,IY,yY,fT,wY=Ie(()=>{hT=require("mqtt-packet");RY();OY=L(xn());zc();Ii();qr();md=L(se()),kr=L(M()),tw=L(Oc()),NY=require("events"),ET=(0,tw.loggerWithTag)("auth-event"),dr=(0,tw.loggerWithTag)("mqtt"),IY=(0,md.get)(kr.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(Wme,"bypassAuth");a(jme,"start");fT=0;a(bY,"onSocket")});var Jf={};je(Jf,{component_errors:()=>Td,getComponentName:()=>Zme,loadComponent:()=>ST,loadComponentDirectories:()=>vY,setErrorReporter:()=>Xme});function vY(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(()=>{UY=!0})}function Xme(e){vE=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,DY.parseDocument)((0,Nt.readFileSync)(l,"utf8")).toJSON():c=ow;let u=(0,Ot.join)(e,"node_modules","harperdb");try{Sl.isMainThread&&(n||(0,Nt.existsSync)(u)&&(0,Nt.realpathSync)(Ad.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)(Ad.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,U;for(;!(0,Nt.existsSync)(U=(0,Ot.join)(I,"node_modules",E));)if(I=(0,Ot.dirname)(I),I.length<(0,MY.getHdbBasePath)().length){U=null;break}if(U)h=await ST(U,t,r,!1),_=!0;else throw new Error(`Unable to find package ${E}:${T}`)}else h=Jme[E];if(!h)continue;let m=a(I=>(I.origin=r,Et(I)),"ensureTable"),g=f.network||(f.port||f.securePort)&&f,S=g?.securePort||g?.https&&g.port,y=!g?.https&&g?.port;if(Sl.isMainThread&&(h=await h.startOnMainThread?.({server:it,ensureTable:m,port:y,securePort:S,resources:t,...f})||h,n&&g))for(let I of[y,S])try{if(+I&&!CY.includes(I)){let U=aw.get(Ad.CONFIG_PARAMS.HTTP_SESSIONAFFINITY);U&&Sd.default.warn("Session affinity is not recommended and may cause memory leaks"),(U||!US)&&(CY.push(I),$I(I,U))}}catch(U){console.error("Error listening on socket",I,U,E)}if(t.isWorker&&(h=await h.start?.({server:it,ensureTable:m,port:y,securePort:S,resources:t,...f})||h),iw.set(h,!0),(h.handleFile||h.handleDirectory||h.setupFile||h.setupDirectory)&&f.files!=null){if(f.files.includes(".."))throw(0,LY.handleHDBError)("Can not reference parent directories");let I=(0,Ot.join)(e,f.files).replace(/\\/g,"/"),U=I.indexOf("/*");if(U>-1&&f.files!==ow[E]?.files&&!(0,Nt.existsSync)(I.slice(0,U)))throw new Error(`The path '${I.slice(0,U)}' does not exist and cannot be used as the base of the resolved 'files' path value '${f.files}'`);let H=(0,Ot.basename)(e),X=f.path||"/";X=X.startsWith("/")?X:X.startsWith("./")?"/"+H+X.slice(2):X==="."?"/"+H:"/"+H+"/"+X;let Y,V,ne;if(f.root){let de=f.root;de.startsWith("/")&&(de=de.slice(1)),de.endsWith("/")&&(de=de.slice(0,-1)),de+="/",V=(0,Ot.join)(e,de)}else(ne=I.indexOf("/*"))>-1?(V=I.slice(0,ne+1),Y=(0,Ot.relative)(e,V)):f.files.indexOf("/")>-1&&(V=I.slice(0,I.lastIndexOf("/")+1),Y=(0,Ot.relative)(e,V));let Q=!1;if(Sl.isMainThread&&h.setupDirectory&&(Q=await h.setupDirectory?.(X,V,t)),t.isWorker&&h.handleDirectory&&(Q=await h.handleDirectory?.(X,V,t)),Q){_=!0;continue}for(let de of await(0,PY.default)(I,{onlyFiles:!1,objectMode:!0})){let{path:j,dirent:ae}=de;_=!0;let Oe=(0,Ot.relative)(e,j).replace(/\\/g,"/");if(Y)if(Oe.startsWith(Y))Oe=Oe.slice(Y.length+1);else throw new Error(`The root path '${f.root}' does not reference a valid part of the file path '${Oe}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let Ne=X+(X.endsWith("/")?"":"/")+Oe;try{if(ae.isFile()){let Me=await Qme(j);Sl.isMainThread&&await h.setupFile?.(Me,Ne,j,t),t.isWorker&&await h.handleFile?.(Me,Ne,j,t)}else Sl.isMainThread&&await h.setupDirectory?.(Ne,j,t),t.isWorker&&await h.handleDirectory?.(Ne,j,t)}catch(Me){Me.message=`Could not load ${ae.isFile()?"file":"directory"} '${j}'${f.module?" using '"+f.module+"'":""} for application '${e}' due to: ${Me.message}`,vE?.(Me),((0,gd.getWorkerIndex)()===0?console:Sd.default).error(Me),t.set(f.path||"/",new ea(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}`,vE?.(m),((0,gd.getWorkerIndex)()===0?console:Sd.default).error(m),t.set(f.path||"/",new ea(m),null,!0),Td.set(n?E:(0,Ot.basename)(e),m.message)}}if(mT=d,Sl.isMainThread&&!UY&&i&&(0,gd.watchDir)(e,async()=>vY()),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?`;vE?.(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}`,vE?.(c),t.set("",new ea(c))}}var Nt,Ot,Sl,DY,aw,Ad,PY,gd,Sd,LY,MY,zme,TT,Qme,nw,iw,UY,sw,Td,Jme,ow,CY,pT,vE,mT,Zme,Xf=Ie(()=>{Nt=require("fs"),Ot=require("path"),Sl=require("worker_threads"),DY=require("yaml"),aw=L(se()),Ad=L(M());ID();eV();sV();cV();lV();yV();r1();c1();PY=L(require("fast-glob")),gd=L(dt()),Sd=L(W());bN();qr();LY=L(_e());Pe();wI();MY=L(se()),zme=L(cY());km();pY();ds();wY();TT=L(wt());vS();fy();({readFile:Qme}=Nt.promises),nw=(0,TT.resolvePath)(aw.get(Ad.CONFIG_PARAMS.COMPONENTSROOT)),iw=new Map,Td=new Map;a(vY,"loadComponentDirectories");Jme={REST:CS,rest:CS,graphql:RN,graphqlSchema:Pg,roles:yN,jsResource:NN,fastifyRoutes:YN,login:wN,static:WN,operationsApi:zme,customFunctions:{},http:{},clustering:QI,replication:ca,authentication:Bf,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/**"}});CY=[],pT=new Map;a(Xme,"setErrorReporter");Zme=a(()=>mT,"getComponentName");a(ST,"loadComponent")});var nT=N((mMe,HY)=>{var{isMainThread:BY}=require("worker_threads"),{getTables:eSe,getDatabases:hMe,table:pMe}=(Pe(),oe(lt)),{loadComponentDirectories:tSe,loadComponent:rSe}=(Xf(),oe(Jf)),{resetResources:nSe}=(su(),oe(iB)),sSe=SO(),iSe=wt(),{dirname:oSe}=require("path"),{getConnection:aSe}=mr(),cSe=se(),{CONFIG_PARAMS:lSe}=M(),{loadCertificates:uSe}=Xs(),cw=new Map;async function dSe(e=!1){!BY&&cSe.get(lSe.CLUSTERING_ENABLED)&&aSe();try{BY&&await sSe()}catch(n){console.error(n)}let t=nSe();eSe(),t.isWorker=e,await uSe(),await rSe(oSe(iSe.getConfigFilePath()),t,"hdb",!0,cw),await tSe(cw,t);let r=[];for(let[n]of cw)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(dSe,"loadRootComponents");HY.exports.loadRootComponents=dSe});var dt=N((TMe,ci)=>{"use strict";var{Worker:_Se,MessageChannel:fSe,parentPort:Ki,isMainThread:Ew,threadId:ESe,workerData:Yi}=require("worker_threads"),{PACKAGE_ROOT:hSe}=M(),{join:GY,isAbsolute:pSe,extname:mSe}=require("path"),{server:qY}=(qr(),oe(Ja)),{watch:SSe,readdir:TSe}=require("fs/promises"),{totalmem:xY}=require("os"),Rd=M(),lw=se(),ai=W(),{randomBytes:gSe}=require("crypto"),{_assignPackageExport:ASe}=Ei(),RSe=M(),kY=1024*1024,va=[],Ps=[],ySe=50,hw=1e4,bSe="restart",$Y="request_thread_info",VY="resource_report",KY="thread_info",YY="added-port",OSe="ack",uw;ASe("threads",Ps);ci.exports={startWorker:dw,restartWorkers:mw,shutdownWorkers:DSe,workers:va,setMonitorListener:xSe,onMessageFromWorkers:PSe,onMessageByType:ZY,broadcast:MSe,broadcastWithAcknowledgement:vSe,setChildListenerByType:CSe,getWorkerIndex:WY,getWorkerCount:jY,getTicketKeys:QY,setMainIsWorker:ISe,setTerminateTimeout:NSe,restartNumber:Yi?.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};ci.exports.whenThreadsStarted=new Promise(e=>{ci.exports.threadsHaveStarted=e});var pw;function NSe(e){hw=e}a(NSe,"setTerminateTimeout");function WY(){return Yi?Yi.workerIndex:pw?0:void 0}a(WY,"getWorkerIndex");function jY(){return Yi?Yi.workerCount:pw?1:void 0}a(jY,"getWorkerCount");function ISe(e){pw=e,ci.exports.threadsHaveStarted()}a(ISe,"setMainIsWorker");var zY=1,gT;function QY(){return gT||(gT=Ew?gSe(48):Yi.ticketKeys,gT)}a(QY,"getTicketKeys");Object.defineProperty(qY,"workerIndex",{get(){return WY()}});Object.defineProperty(qY,"workerCount",{get(){return jY()}});var JY={[$Y](e,t){BSe(t)},[VY](e,t){HSe(t,e)}};function dw(e,t={}){let r=process.constrainedMemory?.()||xY();r=Math.min(r,xY(),2e4*kY);let n=lw.get(Rd.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/kY/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let u of Ps){let d=new fSe;d.existingPort=u,i.push(d),o.push(d.port2)}mSe(e)||(e+=".js");let c=["--enable-source-maps"];lw.get(Rd.CONFIG_PARAMS.THREADS_HEAPSNAPSHOTNEARLIMIT)&&c.push("--heapsnapshot-near-heap-limit=1");let l=new _Se(pSe(e)?e:GY(hSe,e),{resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:c,argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(u=>u.existingPort.threadId),workerIndex:t.workerIndex,workerCount:zY=t.threadCount,name:t.name,restartNumber:ci.exports.restartNumber,ticketKeys:QY()},transferList:o,...t});for(let{port1:u,existingPort:d}of i)d.postMessage({type:YY,port:u,threadId:l.threadId},[u]);return RT(l,!0),l.unexpectedRestarts=t.unexpectedRestarts||0,l.startCopy=()=>dw(e,t),l.on("error",u=>{ai.error(`Worker index ${t.workerIndex} error:`,u)}),l.on("exit",u=>{va.splice(va.indexOf(l),1),!l.wasShutdown&&t.autoRestart!==!1&&(l.unexpectedRestarts<ySe?(t.unexpectedRestarts=l.unexpectedRestarts+1,dw(e,t)):ai.error(`Thread has been restarted ${l.restarts} times and will not be restarted`))}),l.on("message",u=>{JY[u.type]?.(u,l)}),va.push(l),FSe(),t.onStarted&&t.onStarted(l),l.name=t.name,l}a(dw,"startWorker");var wSe=[Rd.THREAD_TYPES.HTTP];async function mw(e=null,t=Math.max(zY>3,1),r=!0){if(Ew){try{process.chdir(process.cwd())}catch(o){ai.error("Unable to reestablish current working directory",o)}if(r){let{loadRootComponents:o}=nT();await o()}ci.exports.restartNumber++,t<1&&(t=t*va.length);let n=[],s=[];for(let o of va.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;ai.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:ci.exports.restartNumber,type:Rd.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=wSe.indexOf(o.name)>-1,l=new Promise(u=>{let d=setTimeout(()=>{ai.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===RSe.ITC_EVENT_TYPES.CHILD_STARTED&&(ai.trace("Worker has started",u.threadId),_(),s.splice(s.indexOf(d)),u.off("message",E))},"startListener");ai.trace("Waiting for worker to start",u.threadId),u.on("message",E)});s.push(d),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=qu();r&&(e==="http"||!e)&&lw.get(Rd.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else Ki.postMessage({type:bSe,workerType:e})}a(mw,"restartWorkers");function CSe(e,t){JY[e]=t}a(CSe,"setChildListenerByType");function DSe(e){return mw(e,1/0,!1)}a(DSe,"shutdownWorkers");var XY=[];function PSe(e){XY.push(e)}a(PSe,"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 LSe=10;async function MSe(e,t){let r=0;for(let n of Ps)try{n.postMessage(e),r++>LSe&&(r=0,await new Promise(setImmediate))}catch(s){ai.error("Unable to send message to worker",s)}t&&tW(e,null)}a(MSe,"broadcast");var AT=new Map,USe=1;function vSe(e){return new Promise(t=>{let r=0;for(let n of Ps)try{let s=USe++,i=a(()=>{AT.delete(s),--r===0&&t(),n!==Ki&&--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){ai.error("Unable to send message to worker",s)}r===0&&t()})}a(vSe,"broadcastWithAcknowledgement");function BSe(e){e.postMessage({type:KY,workers:eW()})}a(BSe,"sendThreadInfo");function eW(){let e=Date.now();return va.map(t=>({threadId:t.threadId,name:t.name,heapTotal:t.resources?.heapTotal,heapUsed:t.resources?.heapUsed,externalMemory:t.resources?.external,arrayBuffers:t.resources?.arrayBuffers,sinceLastUpdate:e-t.resources?.updated,...t.recentELU}))}a(eW,"getChildWorkerInfo");function HSe(e,t){e.resources=t,e.resources.updated=Date.now()}a(HSe,"recordResourceReport");var fw;function xSe(e){fw=e}a(xSe,"setMonitorListener");var kSe=1e3,FY=!1;function FSe(){FY||(FY=!0,setInterval(()=>{for(let e of va){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}fw&&fw()},kSe).unref())}a(FSe,"startMonitoring");var GSe=1e3;if(Ki&&Yi?.addPorts){RT(Ki);for(let e=0,t=Yi.addPorts.length;e<t;e++){let r=Yi.addPorts[e];r.threadId=Yi.addThreadIds[e],RT(r)}setInterval(()=>{let e=process.memoryUsage();Ki.postMessage({type:VY,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},GSe).unref(),uw=a(()=>new Promise((e,t)=>{Ki.on("message",r),Ki.postMessage({type:$Y});function r(n){n.type===KY&&(Ki.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else uw=eW;ci.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===OSe){let n=AT.get(r.id);n&&n()}else tW(r,e)}).on("close",()=>{Ps.splice(Ps.indexOf(e),1)}).on("exit",()=>{Ps.splice(Ps.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(RT,"addPort");function tW(e,t){for(let n of XY)n(e,t);let r=_w.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){ai.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 TSe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(GY(s,o.name));try{for await(let{filename:o}of SSe(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await 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");ci.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else Ki.on("message",async e=>{let{type:t}=e;t===Rd.ITC_EVENT_TYPES.SHUTDOWN&&(ci.exports.restartNumber=e.restartNumber,Ki.unref(),setTimeout(()=>{ai.warn("Thread did not voluntarily terminate",ESe),process.exit(0)},hw).unref())})});var dv={};je(dv,{AUDIT_STORE_OPTIONS:()=>Df,Decoder:()=>Pc,HAS_CURRENT_RESIDENCY_ID:()=>rc,HAS_EXPIRATION_EXTENDED_TYPE:()=>o_,HAS_ORIGINATING_OPERATION:()=>i_,HAS_PREVIOUS_RESIDENCY_ID:()=>nc,REMOTE_SEQUENCE_UPDATE:()=>Kp,createAuditEntry:()=>Ul,getLastRemoved:()=>Yy,openAuditStore:()=>IT,readAuditEntry:()=>xt,removeAuditEntry:()=>wT,setAuditRetention:()=>$Se,transactionKeyEncoder:()=>dW});function IT(e){let t=e.auditStore=e.openDB(Sw.AUDIT_STORE_NAME,{create:!1,...Df});t||(t=e.auditStore=e.openDB(Sw.AUDIT_STORE_NAME,Df),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>=qSe){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((VSe(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 $Se(e,t=yT){Tw=e,yT=t}function Ul(e,t,r,n,s,i,o,c,l,u,d,_,E){let f=fW[o];if(!f)throw new Error(`Invalid audit entry type ${o}`);let h=1;if(n&&(n>1?Ba.setFloat64(0,n):Ls.set(jg),h=9),l){if(l&16761087)throw new Error("Illegal extended type");h++}g(s),g(t),m(r),Ba.setFloat64(h,e),h+=8,l&rc&&g(u),l&nc&&g(d),l&o_&&(Ba.setFloat64(h,_),h+=8),l&i_&&g(EW[E]),i?m(i):Ls[h++]=0,l?Ba.setUint16(n?8:0,f|l|32768):Ls[n?8:0]=f;let T=Ls.subarray(0,h);if(c)return Buffer.concat([T,c]);return T;function m(S){let y=h;h+=1,h=(0,Tl.writeKey)(S,Ls,h);let I=h-y-1;I>127?I>16383?(NT.error("Key or username was too large for audit entry",S),h=y+1,Ls[y]=0):(Ls.copyWithin(y+2,y+1,h),Ba.setUint16(y,I|32768),h++):Ls[y]=I}function g(S){S<128?Ls[h++]=S:S<16384?(Ba.setUint16(h,S|32768),h+=2):S<1056964608?(Ba.setUint32(h,S|3221225472),h+=4):(Ls[h]=255,Ba.setUint32(h+1,S),h+=5)}}function VSe(e){let t=0;e[0]==66&&(t=8);let r=e[t];if(r<128)return r;let n=e.dataView||(e.dataView=new Pc(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function xt(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new Pc(e.buffer,e.byteOffset,e.byteLength));n.position=t;let s;e[n.position]==66&&(s=n.readFloat64());let i=n.readInt(),o=n.readInt(),c=n.readInt(),l=n.readInt(),u=n.position,d=n.position+=l,_=n.readFloat64(),E,f,h,T;if(i&rc&&(E=n.readInt()),i&nc&&(f=n.readInt()),i&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,Tl.readKey)(e,u,d)},getBinaryRecordId(){return e.subarray(u,d)},version:_,previousLocalTime:s,get user(){return g>m?(0,Tl.readKey)(e,m,g):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(S,y,I){if(i&bT||i&BE&&!y)return S.decoder.decode(e.subarray(n.position,r));if(i&BE&&I)return 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 Tl,OT,Sw,lW,HE,uW,NT,Ls,Ba,dW,Df,Tw,qSe,Aw,_W,yT,rW,bT,BE,sW,gw,iW,oW,aW,cW,Kp,rc,nc,i_,o_,fW,EW,Pc,Ji=Ie(()=>{Tl=require("ordered-binary"),OT=L(se()),Sw=L(Ht()),lW=L(M()),HE=L(dt()),uW=L(te());vl();NT=L(W());CT();(0,OT.initSync)();Ls=Buffer.alloc(2816),Ba=new DataView(Ls.buffer,Ls.byteOffset,2816),dW={writeKey(e,t,r){return e===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,Tl.writeKey)(e,t,r)},readKey(e,t,r){return e[t]===66?(e.dataView||(e.dataView=new DataView(e.buffer,e.byteOffset,e.byteLength))).getFloat64(t):(0,Tl.readKey)(e,t,r)}},Df={encoding:"binary",keyEncoder:dW},Tw=(0,uW.convertToMS)((0,OT.get)(lW.CONFIG_PARAMS.LOGGING_AUDITRETENTION))||86400*3,qSe=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($Se,"setAuditRetention");bT=16,BE=32,sW=1,gw=2,iW=3,oW=4,aW=5,cW=6,Kp=11,rc=512,nc=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(Ul,"createAuditEntry");a(VSe,"readAction");a(xt,"readAuditEntry");Pc=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t;return t=this.getUint8(this.position++),t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch(t){throw t.message=`Error reading float64: ${t.message} at position ${this.position}`,t}}}});var 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=KSe[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=pW}}function 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 KSe,pW,CT=Ie(()=>{Ji();a(DT,"add");DT.reverse=function(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n-BigInt(r.value):isNaN(e[t])||(e[t]=n-r.value)};KSe={add:DT};a(PT,"rebuildUpdateBefore");a(hW,"applyReverse");pW={};a(Rw,"getRecordAtTime")});function es(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}`);es(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}`);es(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 ${_}`);es(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}`);es(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}`);es(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}`);es(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}`);es(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}`);es(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}`);es(this)[c]=d},"set");break;case"Any":case void 0:l=a(function(d){es(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}`);es(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");es(this)[o]=c}),i("deleteProperty",function(o){es(this)[o]=void 0}),i("toJSON",function(){let o=this[_r],c;for(let u in o){c||(c={...this[ve]});let d=o[u];if(d?.__op__){let _=c[u];d=d.update(_)}c[u]=d}return Object.keys(this).length>0&&(c||(c={...this[ve]}),Object.assign(c,this)),c||this[ve]}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty);function i(o,c){Object.defineProperty(r,o,{value:c,configurable:!0})}a(i,"setMethod")}function SW(e,t){let r;switch(e.constructor){case Object:return t?((r=t.TrackedObject)||(t.TrackedObject=r=class{static{a(this,"TrackedObject")}constructor(s){if(s?.[ve])throw new Error("Can not track an already tracked object, check for circular references");this[ve]=s}},BT(r,t)),new r(e)):new LT(e);case Array:let n=new UT(e.length);n[ve]=e;for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=SW(o,t?.elements)),n[s]=o}return n;default:return e}}function dp(e){let t=e[_r],r;for(let s in t){r||(r={...e[ve]});let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=dp(i);r[s]=i}return Object.keys(e).length>0&&(r||(r={...e[ve]}),Object.assign(r,e)),r||e[ve]}function Al(e,t=e[_r]){let r;if(mW.call(e,ve)&&e.constructor===Array&&!Object.isFrozen(e)){r=e;for(let n=0,s=e.length;n<s;n++){let i=e[n];if(i&&typeof i=="object"){let o=Al(i);o!==i&&r===e&&(r=e.slice(0)),i=o}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r={...e[ve]});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=yw[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=Al(s);r[n]=s}return r?Object.freeze(r):mW.call(e,ve)?e[ve]:e}function MT(e){let t=e[ve];if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[gl]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.[ve]===s){if(MT(i))return!0}else return!0}}else{let r=e[_r];if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s[ve]===i){if(MT(s))return!0}else return!0}else return!0}}return!1}var Ms,_r,LT,mW,gl,UT,vT,_p=Ie(()=>{Vs();Ms=L(_e());CT();_r=Symbol("own-data");a(es,"getChanges");a(BT,"assignTrackedAccessors");a(SW,"trackObject");LT=class{static{a(this,"GenericTrackedObject")}constructor(t){if(t?.[ve])throw new Error("Can not track an already tracked object, check for circular references");this[ve]=t}};BT(LT,{});a(dp,"collapseData");mW=Object.prototype.hasOwnProperty;a(Al,"updateAndFreeze");a(MT,"hasChanges");gl=Symbol.for("has-array-changes"),UT=class extends Array{static{a(this,"TrackedArray")}[gl];constructor(t){super(t)}splice(...t){return this[gl]=!0,super.splice(...t)}push(...t){return this[gl]=!0,super.push(...t)}pop(){return this[gl]=!0,super.pop()}unshift(...t){return this[gl]=!0,super.unshift(...t)}shift(){return this[gl]=!0,super.shift()}};UT.prototype.constructor=Array;vT=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var _R={};je(_R,{CONTEXT:()=>Fe,ID_PROPERTY:()=>ze,IS_COLLECTION:()=>li,MultiPartId:()=>xT,RECORD_PROPERTY:()=>ve,Resource:()=>Lr,snake_case:()=>WSe,transformForSelect:()=>kT});function WSe(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function TW(e,t){if(Rl=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(Rl=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new xT;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Rl=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return Rl=!0,null;e[e.length-1]==="/"&&(Rl=!0)}return t.coerceId(decodeURIComponent(e))}function ts(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,l,u,d;if(r?(o?(d=i,o=o[Fe]||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(d=s,c=d[this.primaryKey]??null,o=i[Fe]||i):d=i:(d=s,s=void 0,c=d[ze]??d[this.primaryKey]),c===null&&(u=!0)):i?o=i[Fe]||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="object"&&s){if(l=s,typeof(c=s.url)=="string"){let f=c.indexOf("?");if(f>-1){let T=this.parseQuery(c.slice(f+1));l?T&&(l=Object.assign(T,l)):l=T,c=c.slice(0,f)}let h=this.parsePath(c,o,l);h?.id!==void 0?(h.query&&(l?l=Object.assign(h.query,l):l=h.query),u=h.isCollection,c=h.id):c=h}else if(s[Symbol.iterator]){c=[],u=!0;for(let f of s){if(typeof f=="object"&&f)break;c.push(f)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=null,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new ol(c),c==null&&(u=!0);o||(o={});let _;if(l?.ensureLoaded!=null||l?.async||u?(_={...t},l?.ensureLoaded!=null&&(_.ensureLoaded=l.ensureLoaded),l?.async&&(_.async=l.async),u&&(_.isCollection=!0)):_=t,o.transaction){let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)}else return Dt(o,()=>{let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)},_);function E(f){if(o.authorize){o.authorize=!1;let h=t.type==="read"?f.allowRead(o.user,l,o):t.type==="update"?f.doesExist?.()===!1?f.allowCreate(o.user,d,o):f.allowUpdate(o.user,d,o):t.type==="create"?f.allowCreate(o.user,d,o):f.allowDelete(o.user,l,o);if(h?.then)return h.then(T=>{if(!T)throw new HT(o.user);return typeof d?.then=="function"?d.then(m=>e(f,l,o,m)):e(f,l,o,d)});if(!h)throw new HT(o.user)}return typeof d?.then=="function"?d.then(h=>e(f,l,o,h)):e(f,l,o,d)}a(E,"authorizeActionOnResource")}}function rs(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,li,ve,YSe,Lr,HT,Rl,xT,Vs=Ie(()=>{gW=require("crypto");Ll();AW=L(Ei()),RW=L(_e());_p();Sc();fE();Fe=Symbol.for("context"),ze=Symbol.for("primary-key"),li=Symbol("is-collection"),ve=Symbol("stored-record"),YSe={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Lr=class{static{a(this,"Resource")}static transactions;constructor(t,r){this[ze]=t;let n=r?.[Fe];this[Fe]=n!==void 0?n:r||null}static get=ts(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=ts(function(t,r,n,s){if(Array.isArray(s)&&t[li]){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):rs(t,"put")},{hasContent:!0,type:"update"});static patch=ts(function(t,r,n,s){return t.patch?t.patch(s,r):rs(t,"patch")},{hasContent:!0,type:"update"});static delete=ts(function(t,r,n,s){return t.delete?t.delete(r):rs(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):rs(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=ts(function(t,r,n,s){return t.invalidate?t.invalidate(r):rs(t,"delete")},{hasContent:!1,type:"update"});static post=ts(function(t,r,n,s){return t[ze]!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=ts(function(t,r,n,s){return t.connect?t.connect(s,r):rs(t,"connect")},{hasContent:!0,type:"read"});static subscribe=ts(function(t,r,n,s){return t.subscribe?t.subscribe(r):rs(t,"subscribe")},{type:"read"});static publish=ts(function(t,r,n,s){return t[ze]!=null&&t.update?.(),t.publish?t.publish(s,r):rs(t,"publish")},{hasContent:!0,type:"create"});static search=ts(function(t,r,n,s){let i=t.search?t.search(r):rs(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=ts(function(t,r,n,s){return t.search?t.search(s,r):rs(t,"search")},{hasContent:!0,type:"read"});static copy=ts(function(t,r,n,s){return t.copy?t.copy(s,r):rs(t,"copy")},{hasContent:!0,type:"create"});static move=ts(function(t,r,n,s){return t.move?t.move(s,r):rs(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this[li])return(await this.constructor.create(this[ze],t,this[Fe]))[ze];rs(this,"post")}static isCollection(t){return t?.[li]}static coerceId(t){return t}static parseQuery(t){return IS(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1);t=t.slice(0,s);let c=r?.headers&&YSe[o];if(c)r.requestedContentType=c;else if(n)n.property=o;else return{query:{property:o},id:TW(t,this),isCollection:Rl}}let i=TW(t,this);return Rl?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r[Fe],o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let u=l.asMap.get(t);if(s=u?.find(d=>d.constructor===c),s)return s;u||l.asMap.set(t,u=[]),u.push(s=new c(t,i))}else{if(s=l.find(u=>u[ze]===t&&u.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let u=new Map;for(let d of l){let _=d[ze],E=u.get(_);E?E.push(d):u.set(_,[d])}i.resourceCache.length=0,i.resourceCache.asMap=u}}}else s=new c(t,i);return o&&(s[li]=!0),s}subscribe(t){return new Mn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new Mn}allowRead(t){return t?.role.permission.super_user}allowUpdate(t){return t?.role.permission.super_user}allowCreate(t){return t?.role.permission.super_user}allowDelete(t){return t?.role.permission.super_user}getId(){return this[ze]}getContext(){return this[Fe]}};Lr.prototype[Fe]=null;(0,AW._assignPackageExport)("Resource",Lr);a(WSe,"snake_case");HT=class extends Error{static{a(this,"AccessError")}constructor(t){t?(super("Unauthorized access to resource"),this.statusCode=403):(super("Must login"),this.statusCode=401)}};a(TW,"pathToId");xT=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(ts,"transactional");a(rs,"missingMethod");a(bw,"selectFromObject");a(kT,"transformForSelect")});var FO={};je(FO,{EVICTED:()=>ba,INVALIDATED:()=>Ns,coerceType:()=>GT,makeTable:()=>VT,setServerUtilities:()=>rTe,updateResource:()=>qT});function VT(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:l,schemaDefined:u,dbisDB:d,sealed:_,splitSegments:E,replicate:f}=e,{expirationMS:h,evictionMS:T,audit:m,trackDeletes:g}=e,{attributes:S}=e;S||(S=[]);let y=Jg(i,n,l),I,U,H={},X=Promise.resolve(),Y,V,ne;for(let v of S)(v.assignCreatedTime||v.name==="__createdtime__")&&(Y=v),(v.assignUpdatedTime||v.name==="__updatedtime__")&&(V=v),v.expiresAt&&(ne=v),v.isPrimaryKey&&(H=v);let Q,de=[],j=[],ae=1,Oe=2,Ne={},Me={},Gr=864e5,Cd,Fa,wn,Dd=!1,Nl,vw=new Map,jE=new Map,vt,Ga,qa=bd.get(Us.CONFIG_PARAMS.REPLICATION_DATABASES);if(Array.isArray(qa)){for(let v of qa)if(v.name===c&&v.replicateTo>=0){Ga=v.replicateTo;break}}let vs=i.getRange({start:!1,end:!1}).constructor,Bs=10,zE=6;m&&ie();class Ve extends Lr{static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=m;static databasePath=o;static databaseName=c;static attributes=S;static replicate=f;static sealed=_;static splitSegments=E??!0;static createdTimeProperty=Y;static updatedTimeProperty=V;static propertyResolvers;static userResolvers={};static sources=[];static get expirationMS(){return h}static dbisDB=d;static schemaDefined=u;static sourcedFrom(p,A){if(A&&(this.sourceOptions=A,(A.expiration||A.eviction||A.scanInterval)&&this.setTTLExpiration(A)),A?.intermediateSource)p.intermediateSource=!0,this.sources.unshift(p);else{if(this.sources.some(O=>!O.intermediateSource)){if(this.sources.some(O=>O.name===p.name))return;throw new Error("Can not have multiple canonical (non-intermediate) sources")}this.sources.push(p)}U=U||p.get&&(!p.get.reliesOnPrototype||p.prototype.get),I=I||p.load;let w=a(O=>{let B=this.sources;if(B=B.filter(k=>k.intermediateSource&&k[O]&&(!k[O].reliesOnPrototype||k.prototype[O])),B.length>0)if(B.length===1){let k=B[0];return(C,F,x)=>{if(C?.source!==k)return k[O](F,x,C)}}else return(k,C,F)=>{let x=[];for(let q of B){if(k?.source===q)break;x.push(q[O](C,F,k))}return Promise.all(x)}},"getApplyToIntermediateSource"),R=this.sources[this.sources.length-1];R.intermediateSource&&(R={});let b=a(O=>{if(R[O]&&(!R[O].reliesOnPrototype||R.prototype[O]))return(B,k,C)=>{if(!B?.source)return R[O](k,C,B)}},"getApplyToCanonicalSource");Ne={put:b("put"),patch:b("patch"),delete:b("delete"),publish:b("publish")},Me={put:w("put"),patch:w("patch"),delete:w("delete"),publish:w("publish"),invalidate:w("invalidate")};let D=R.shouldRevalidateEvents;return(async()=>{let O=!1,B,k=a(async(C,F)=>{let x=C.value,q=C.table?We[c][C.table]:Ve;if(c===Us.SYSTEM_SCHEMA_NAME&&(C.table===Us.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||C.table===Us.SYSTEM_TABLE_NAMES.USER_TABLE_NAME)&&(O=!0),C.id===void 0&&(C.id=x[q.primaryKey],C.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(C));C.source=p;let ee={residencyId:tt(C.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:C.nodeId},G=await q.getResource(C.id,F,ee);switch(C.type){case"put":return D?G._writeInvalidate(ee):G._writeUpdate(x,!0,ee);case"patch":return D?G._writeInvalidate(ee):G._writeUpdate(x,!1,ee);case"delete":return G._writeDelete(ee);case"publish":case"message":return G._writePublish(x,ee);case"invalidate":return G._writeInvalidate(ee);case"relocate":return G._writeRelocate(ee);default:qe.default.error?.("Unknown operation",C.type,C.id)}},"writeUpdate");try{let C=p.subscribe;C&&g==null&&(g=!0);let F={crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0},x=p.subscribeOnThisThread?p.subscribeOnThisThread((0,yl.getWorkerIndex)(),F):(0,yl.getWorkerIndex)()===0,q=C&&x&&await p.subscribe?.(F);if(q){let ee;for await(let G of q)try{if(!(G.type==="transaction"?G.writes[0]:G)){qe.default.error?.("Bad subscription event",G);continue}if(G.source=p,G.type==="end_txn"){if(ee?.resolve(),G.localTime&&B!==G.localTime){if(G.remoteNodeIds?.length>0){let Ae=[Symbol.for("seq"),G.remoteNodeIds[0]],re=d.get(Ae),K=re?.nodes;K||(K=[]);for(let Be of G.remoteNodeIds.slice(1)){let we=K.find(ce=>ce.id===Be);K=K.filter(ce=>ce.id!==Be||ce===we),we||(we={id:Be,seqId:0},K.push(we)),we.seqId=Math.max(re?.seqId??1,G.localTime),Be===ee?.nodeId&&(we.lastTxnTime=G.timestamp)}let ge=Math.max(re?.seqId??1,G.localTime);qe.default.trace?.("Received txn",c,ge,G.localTime,G.remoteNodeIds),d.put(Ae,{seqId:ge,nodes:K})}B=G.localTime}G.onCommit&&ee?.committed.then(G.onCommit);continue}if(ee)if(G.beginTxn)ee.resolve();else{ee.write_promises.push(k(G,ee));continue}!G.timestamp&&G.version&&(G.timestamp=G.version);let Ee=Dt(G,()=>{if(G.type==="transaction"){let Ae=[];for(let re of G.writes)try{Ae.push(k(re,G))}catch(K){throw K.message+=" writing "+JSON.stringify(re)+" of event "+JSON.stringify(G),K}return Promise.all(Ae)}else if(G.type==="define_schema"){let Ae=this.attributes.slice(0),re;for(let K of G.attributes)Ae.find(ge=>ge.name===K.name)||(Ae.push(K),re=!0);re&&(Et({table:s,database:c,attributes:Ae,origin:"cluster"}),GE.signalSchemaChange(new qE.SchemaEventMsg(process.pid,Us.OPERATIONS_ENUM.CREATE_TABLE,c,s)))}else return G.beginTxn?(ee=G,ee.write_promises=[k(G,G)],new Promise(Ae=>{ee.resolve=()=>Ae(Promise.all(ee.write_promises))})):k(G,G)});ee&&(ee.committed=Ee),O&&Ee&&!Ee?.waitingForUserChange&&(Ee.then(()=>GE.signalUserChange(new qE.UserEventMsg(process.pid))),Ee.waitingForUserChange=!0),G.onCommit&&(Ee?Ee.then(G.onCommit):G.onCommit())}catch(Re){qe.default.error?.("error in subscription handler",Re)}}}catch(C){qe.default.error?.(C)}})(),this}static get isCaching(){return U}static get shouldRevalidateEvents(){return this.prototype.get!==Ve.prototype.get}static getResource(p,A,w){let R=super.getResource(p,A,w);if(p!=null){ji(p);try{if(R.hasOwnProperty(ve))return R;if(typeof p=="object"&&p&&!Array.isArray(p))throw new Error(`Invalid id ${JSON.stringify(p)}`);let b=!w?.async||i.cache?.get?.(p),D=Ir(A),O=D.getReadTxn();if(O?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return Va(p,A,{transaction:O,ensureLoaded:w?.ensureLoaded},b,B=>{if(B?qT(R,B):R[ve]=null,A.onlyIfCached&&A.noCacheStore){if(!R.doesExist())throw new Nr.ServerError("Entry is not cached",504)}else if(w?.ensureLoaded){let k=Pd(p,B,A,R);if(k)return D?.disregardReadTxn(),R[Ow]=!0,Iw(k,C=>(qT(R,C),R))}return R})}catch(b){throw b.message.includes("Unable to serialize object")&&(b.message+=": "+JSON.stringify(p)),b}}return R}ensureLoaded(){let p=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 b=i.getEntry(Symbol.for("id_allocation")),D=b?.value,O;if(D&&D.nodeName===server.hostname&&(!sTe(i)||D.pid===process.pid)){let B=D.start,k=D.end;O=B;for(let C of i.getKeys({start:k,end:B,limit:1,reverse:!0}))O=C}else D=R(b?.version??null),O=D.start;vt=new BigInt64Array([BigInt(O)+1n]),vt=new BigInt64Array(i.getUserSharedBuffer("id",vt.buffer)),vt.maxSafeId=D.end}let A=Number(Atomics.add(vt,0,1n)),w=p==="Int"?512:1048576;if(A+w>=vt.maxSafeId){let b=a(D=>{vt.maxSafeId=A+(p==="Int"?1023:4194303);let O=(p==="Int"?Math.pow(2,31):Math.pow(2,49))-1,B=D?void 0:i.useReadTransaction(),k=Number(vt[0]);for(let x of i.getKeys({start:k+1,end:O,limit:1,transaction:B}))O=x;B?.done();let{value:C,version:F}=i.getEntry(Symbol.for("id_allocation"));if(vt.maxSafeId<O){if(C.end>vt.maxSafeId-100)return;qe.default.info?.("New id allocation",A,vt.maxSafeId,F),i.put(Symbol.for("id_allocation"),{start:C.start,end:vt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),F)}else{qe.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${vt.maxSafeId}, but id of ${O} detected`);let x=R(F);x.alreadyUpdated||Atomics.store(vt,0,BigInt(x.start+1)),vt.maxSafeId=x.end}},"updateEnd");A+w===vt.maxSafeId?setImmediate(b):A+100>=vt.maxSafeId&&(qe.default.warn?.(`Synchronous id allocation required on table ${s}${p=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>b(!0)))}return A;function R(b){let D=(p==="Int"?Math.pow(2,31):Math.pow(2,49))-1,O=D/4,B,k,C=!1,F,x;do{F=Math.floor(Math.random()*D),x={start:F,end:F+(p==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},B=0;for(let q of i.getKeys({start:F,limit:1,reverse:!0}))B=q;k=D;for(let q of i.getKeys({start:F+1,end:D,limit:1}))k=q;O*=.875,O<1e3&&!C&&(C=!0,qe.default.error?.(`Id allocation in table ${s} is very dense, limited safe range of numbers to allocate ids in${p==="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`,F,B,k,O))}while(!(O<k-F&&(O<F-B||B===0)));return i.transactionSync(()=>{let q=i.getEntry(Symbol.for("id_allocation"));return(q?.version??null)==b?(qe.default.info?.("Allocated new id range",x),i.put(Symbol.for("id_allocation"),x,Date.now()),x):(qe.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...q.value})})}}static setTTLExpiration(p){if(typeof p=="number")h=p*1e3,T||(T=0);else if(p&&typeof p=="object")h=p.expiration*1e3,T=(p.eviction||0)*1e3,Gr=p.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(h<0)throw new Error("Expiration can not be negative");Gr=Gr||(h+T)/4,xo()}static getResidencyRecord(p){return d.get([Symbol.for("residency_by_id"),p])}static setResidency(p){Ve.getResidency=p}static setResidencyById(p){Ve.getResidencyById=p}static getResidency(p,A,w){if(Ve.getResidencyById)return Ve.getResidencyById(p[t]);let R=Ga;if(A.replicateTo!=null){if(Array.isArray(A.replicateTo))return A.replicateTo.includes(server.hostname)?A.replicateTo:[server.hostname,...A.replicateTo];A.replicateTo>=0&&(R=A.replicateTo)}if(R>=0&&server.nodes){let b=[server.hostname];if(w)b.push(...w.slice(0,R));else{let D=server.nodes.map(k=>k.name),O=Math.floor(D.length*Math.random());b.push(...D.slice(O,O+R));let B=O+R-D.length;B>0&&b.push(...D.slice(0,B))}return b}}static enableAuditing(p=!0){m=p,p&&ie(),Ve.audit=p}static coerceId(p){return p===""?null:GT(p,H)}static async dropTable(){if(delete We[c][s],c===o){for(let p of S)d.remove(Ve.tableName+"/"+p.name),r[p.name]?.drop();d.remove(Ve.tableName+"/"),i.drop(),await d.committed}else console.log("legacy dropTable"),await i.close(),await fs.remove(data_path),await fs.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));GE.signalSchemaChange(new qE.SchemaEventMsg(process.pid,Us.OPERATIONS_ENUM.DROP_TABLE,c,s))}get(p){if(typeof p=="string")return this.getProperty(p);if(this[li])return this.search(p);if(this[ze]===null){if(p?.conditions)return this.search(p);let A=Ve.getRecordCount();return{recordCount:A.recordCount,estimatedRecordRange:A.estimatedRange,records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:S}}if(p?.property)return this.getProperty(p.property);if(this.doesExist()||p?.ensureLoaded===!1||this[Fe]?.returnNonexistent)return this}allowRead(p,A){let w=Ka(p);if(w?.read){if(w.isSuperUser)return!0;let R=w.attribute_permissions,b=A?.select;if(R?.length>0||Dd&&b){if(A||(A={}),b){let D=R?.length>0&&Nw(R,"read");A.select=b.map(O=>{let B=O.name||O;if(!D||D[B]){let k=wn[B]?.definition?.tableClass;if(k){if(O.name||(O={name:O}),!k.prototype.allowRead.call(null,p,O))return!1;if(!O.select)return O.name}return O}}).filter(Boolean)}else A.select=R.filter(D=>D.read&&!wn[D.attribute_name]).map(D=>D.attribute_name);return A}else return!0}}allowUpdate(p,A){let w=Ka(p);if(w?.update){let R=w.attribute_permissions;if(R?.length>0){let b=Nw(R,"update");for(let D in A)if(!b[D])return!1;for(let D of R){let O=D.attribute_name;!D.update&&!(O in A)&&(A[O]=this.getProperty(O))}}return Ya(this[Fe])}}allowCreate(p,A){if(this[li]){let w=Ka(p);if(w?.insert){let R=w.attribute_permissions;if(R?.length>0){let b=Nw(R,"insert");for(let D in A)if(!b[D])return!1;return Ya(this[Fe])}else return Ya(this[Fe])}}else return this.allowUpdate(p,{})}allowDelete(p){return Ka(p)?.delete&&Ya(this[Fe])}update(p,A){if(!Ir(this[Fe]))throw new Error("Can not update a table resource outside of a transaction");if(p===!1)return this;let R;return typeof p=="object"&&p&&(A?(Object.isFrozen(p)&&(p={...p}),this[ve]={},this[_r]=p):(R=this[_r],R&&(p=Object.assign(R,p)),this[_r]=R=p)),this._writeUpdate(this[_r],A),this}addTo(p,A){if(typeof A=="number"||typeof A=="bigint")this[xE]===bW?this.set(p,(+this.getProperty(p)||0)+A):(this[xE]||this.update(),this.set(p,new vT(A)));else throw new Error("Can not add a non-numeric value")}subtractFrom(p,A){if(typeof A=="number")return this.addTo(p,-A);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this[Fr]}invalidate(){this._writeInvalidate()}_writeInvalidate(p){let A=this[Fe],w=this[ze];ji(w),Ir(this[Fe]).addWrite({key:w,store:i,invalidated:!0,entry:this[Fr],before:Ne.invalidate?.bind(this,A,w),beforeIntermediate:Me.invalidate?.bind(this,A,w),commit:a((b,D)=>{if(_i(b,D,p?.nodeId)<=0)return;let O=null;for(let B in r)O||(O={}),O[B]=this.getProperty(B);qe.default.trace?.(`Invalidating entry id: ${w}, timestamp: ${new Date(b).toISOString()}`),y(w,O,this[Fr],b,Ns,m,{user:A?.user,residencyId:p?.residencyId,nodeId:p?.nodeId},"invalidate")},"commit")})}_writeRelocate(p){let A=this[Fe],w=this[ze];ji(w),Ir(this[Fe]).addWrite({key:w,store:i,invalidated:!0,entry:this[Fr],before:Ne.relocate?.bind(this,A,w),beforeIntermediate:Me.relocate?.bind(this,A,w),commit:a((b,D)=>{if(_i(b,D,p?.nodeId)<=0)return;let O=Ve.getResidencyRecord(p.residencyId),B=0,k=null,C=D?.value;if(O&&!O.includes(server.hostname)){for(let F in r)k||(k={}),k[F]=C(F);B=Ns}else k=C;qe.default.trace?.(`Relocating entry id: ${w}, timestamp: ${new Date(b).toISOString()}`),y(w,k,this[Fr],b,B,m,{user:A.user,residencyId:p.residencyId,nodeId:p.nodeId,expiresAt:p.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(p,A){let w={previousResidency:this.getResidencyRecord(p.residencyId),isRelocation:!0},R=this.getResidency(A.value,w),b;if(R){if(!Array.isArray(R))throw new Error("Residency must be an array, but was: "+R);if(!R.includes(server.hostname))return;b=tt(R)}let O=y(p.key,A.value,p,p.version,0,!0,{residencyId:b,expiresAt:A.expiresAt},"relocate",!1,null)}static evict(p,A,w){let R=this.Source,b;if(!((U||m)&&(!A||(b=i.getEntry(p),!b||!A)||b.version!==w))){if(U){if(i.hasLock(p,b.version))return;let D;for(let O in r)D||(D={}),D[O]=A[O];if(D)return y(p,D,b,w,ba,null,null,null,!0)}return i.ifVersion(p,w,()=>{$a(p,A,null)}),m?y(p,null,b,w,ba,null,null,null,!0):i.remove(p,w)}}lock(){throw new Error("Not yet implemented")}static operation(p,A){return p.table||=s,p.schema||=c,LW.operation(p,A)}put(p){this.update(p,!0)}patch(p){this.update(p,!1)}_writeUpdate(p,A,w){let R=this[Fe],b=Ir(R),D=this[ze];ji(D);let O=this[Fr];this[xE]=A?bW:ZSe;let B={key:D,store:i,entry:O,nodeName:R?.nodeName,validate:a(k=>{p||(p=this[_r]),A||p&&MT(this[_r]===p?this:p)?R?.source||(b.checkOverloaded(),this.validate(p,!A),V&&(p[V.name]=V.type==="Date"?new Date(k):V.type==="String"?new Date(k).toISOString():k),A&&(t&&p[t]!==D&&(p[t]=D),Y&&(O?.value?p[Y.name]=O?.value[Y.name]:p[Y.name]=Y.type==="Date"?new Date(k):Y.type==="String"?new Date(k).toISOString():k),p=Al(p))):b.removeWrite(B)},"validate"),before:A?Ne.put?()=>Ne.put(R,D,p):null:Ne.patch?()=>Ne.patch(R,D,p):Ne.put?()=>Ne.put(R,D,Al(this)):null,beforeIntermediate:A?Me.put?()=>Me.put(R,D,p):null:Me.patch?()=>Me.patch(R,D,p):Me.put?()=>Me.put(R,D,Al(this)):null,commit:a((k,C,F)=>{if(F){if(R&&C?.version>(R.lastModified||0)&&(R.lastModified=C.version),this[Fr]=C,C?.value?.[ve])throw new Error("Can not assign a record to a record, check for circular references");A||(this[ve]=C?.value??null)}this[_r]=void 0,this[kE]=k;let x=C?.value,q=p;this[xE]=0;let ee=_i(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=_i(k,{version:ge,localTime:K},w?.nodeId),ee===0)return;if(ee>0)continue}if(ce.type==="patch")Be.push(ce),G=p;else if(ce.type==="put"||ce.type==="delete")return}K=ce.previousLocalTime}Be.sort((we,ce)=>we.version-ce.version);for(let we of Be){let ce=we.getValue(i);if(q=PT(q,ce,A),qe.default.debug?.("Rebuilding update with future patch:",q),!q)return}}else{if(A)return;q=PT(q,x,A),qe.default.debug?.("Rebuilding update without audit:",q)}let Re;if(A?Re=q:(this[ve]=x,Re=Al(this,q)),this[ve]=Re,Re?.[ve])throw new Error("Can not assign a record to a record, check for circular references");let Ee;if(w?.residencyId!=null)Ee=w.residencyId;else{O?.residencyId&&(R.previousResidency=Ve.getResidencyRecord(O.residencyId));let K=Ve.getResidency(Re,R);if(K){if(!Array.isArray(K))throw new Error("Residency must be an array, got: "+K);K.includes(server.hostname)||K.push(server.hostname)}Ee=tt(K)}A||(G=p);let Ae=R?.expiresAt??(h?h+Date.now():-1);qe.default.trace?.(`Saving record with id: ${D}, timestamp: ${new Date(k).toISOString()}${Ae?", expires at: "+new Date(Ae).toISOString():""}${C?", replaces entry from: "+new Date(C.version).toISOString():", new entry"}`,Re),$a(D,x,Re);let re=A?"put":"patch";y(D,Re,C,k,0,m,{user:R?.user,residencyId:Ee,expiresAt:Ae,nodeId:w?.nodeId,originatingOperation:R?.originatingOperation},re,!1,G),R.expiresAt&&xo()},"commit")};b.addWrite(B)}async delete(p){if(typeof p=="string")return this.deleteProperty(p);if(this[li]){for await(let A of this.search(p))(await Ve.getResource(A[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(p);return}return this[ve]?this._writeDelete(p):!1}_writeDelete(p){let A=Ir(this[Fe]),w=this[ze];ji(w);let R=this[Fe];return A.addWrite({key:w,store:i,resource:this,nodeName:R?.nodeName,before:Ne.delete?.bind(this,R,w),beforeIntermediate:Me.delete?.bind(this,R,w),commit:a((b,D,O)=>{let B=D?.value;O&&(R&&D?.version>(R.lastModified||0)&&(R.lastModified=D.version),qT(this,D)),!(_i(b,D,p?.nodeId)<=0)&&($a(this[ze],B),qe.default.trace?.(`Deleting record with id: ${w}, txn timestamp: ${new Date(b).toISOString()}`),m||g?(y(w,null,this[Fr],b,0,m,{user:R?.user,nodeId:p?.nodeId},"delete"),m||xo()):i.remove(this[ze]))},"commit")}),!0}search(p){let A=this[Fe],w=Ir(A);if(!p)throw new Error("No query provided");let R=p.conditions;R?R.length===void 0&&(R=R[Symbol.iterator]?Array.from(R):[R]):R=Array.isArray(p)?p:p[Symbol.iterator]?Array.from(p):[],this[ze]&&(R=[{attribute:null,comparator:Array.isArray(this[ze])?"prefix":"starts_with",value:this[ze]}].concat(R));let b,D={};function O(K,ge){let Be;switch(ge){case"and":case void 0:if(K.length<1)throw new Error('An "and" operator requires at least one condition');Be=!0;break;case"or":if(K.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+ge)}for(let we of K){if(we.conditions){we.conditions=O(we.conditions,we.operator);continue}let ce=we[0]??we.attribute,Ye=ce==null?H:Hi(S,ce);if(Ye)(Ye.type||CN[we.comparator])&&(we[1]===void 0?we.value=k(we.value,Ye):we[1]=k(we[1],Ye));else if(ce!=null)throw(0,Nr.handleHDBError)(new Error,`${ce} is not a defined attribute`,404);if(we.chainedConditions)if(we.chainedConditions.length===1&&(!we.operator||we.operator=="and")){let rt=we.chainedConditions[0],Ze,st;if(rt.comparator==="gt"||rt.comparator==="greater_than"||rt.comparator==="ge"||rt.comparator==="greater_than_equal"?(Ze=we,st=rt):(Ze=rt,st=we),Ze.comparator!=="lt"&&Ze.comparator!=="less_than"&&Ze.comparator!=="le"&&Ze.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let Bt=st.comparator==="ge"||st.comparator==="greater_than_equal",ko=Ze.comparator==="le"||Ze.comparator==="less_than_equal";we.comparator=(Bt?"ge":"gt")+(ko?"le":"lt"),we.value=[st.value,Ze.value]}else throw new Error("Multiple chained conditions are not currently supported")}return K}a(O,"prepareConditions");function B(K,ge){if(p.enforceExecutionOrder)return K;for(let Be of K)Be.conditions&&(Be.conditions=B(Be.conditions,Be.operator));return K.length>1&&ge!=="or"?(0,DW.sortBy)(K,NS(Ve)):K}a(B,"orderConditions");function k(K,ge){return Array.isArray(K)?K.map(Be=>GT(Be,ge)):GT(K,ge)}a(k,"coerceTypedValues");let C=p.operator;(R.length>0||C)&&(R=O(R,C));let F=typeof p.sort=="object"&&p.sort,x;if(F&&C!=="or"){let K=F.attribute;if(K==null)throw new Nr.ClientError("Sort requires an attribute");if(b=R.find(ge=>rd(ge.attribute)===rd(K)),!b){let ge=Hi(S,K);if(!ge)throw(0,Nr.handleHDBError)(new Error,`${Array.isArray(K)?K.join("."):K} is not a defined attribute`,404);if(ge.indexed)b={attribute:K,comparator:"sort"},R.push(b);else if(R.length===0&&!p.allowFullScan)throw(0,Nr.handleHDBError)(new Error,`${Array.isArray(K)?K.join("."):K} is not indexed and not combined with any other conditions`,404)}b&&(b.descending=!!F.descending)}R=B(R,C),F&&(b&&R[0]===b?F.next&&(x={dbOrderedAttribute:F.attribute,attribute:F.next.attribute,descending:F.next.descending,next:F.next.next}):(b&&R.splice(R.indexOf(b),1),x=F));let q=p.select;if(R.length===0&&(R=[{attribute:t,comparator:"greater_than",value:!0}]),p.explain)return{conditions:R,operator:C,postOrdering:x,selectApplied:!!q};let ee=w.useReadTxn(),G=DN(R,C,Ve,ee,p,A,(K,ge)=>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,b,D){let O=new vs;if(w){p=Ld(p,A,R,b,null);let B;O.iterate=function(){let C,F=p[Symbol.asyncIterator]?p[Symbol.asyncIterator]():p[Symbol.iterator](),x,q=w.dbOrderedAttribute,ee,G,Re=!0;function Ee(re){let K=re.next&&Ee(re.next),ge=re.descending;return(Be,we)=>{let ce=Il(Be,re.attribute,R),Ye=Il(we,re.attribute,R),rt=ge?(0,bl.compareKeys)(Ye,ce):(0,bl.compareKeys)(ce,Ye);return rt===0?K?.(Be,we)||0:rt}}a(Ee,"createComparator");let Ae=Ee(w);return{async next(){let re;if(C)if(re=C.next(),re.done){if(x)return O.onDone&&O.onDone(),re}else return{value:await D.call(this,re.value)};B=[],ee&&B.push(ee);do if(re=await F.next(),re.done){if(x=!0,B.length)break;return O.onDone&&O.onDone(),re}else{let K=re.value;if(K?.then&&(K=await K),q){let ge=Il(K,q,R);if(Re)Re=!1,G=ge;else if(ge!==G){G=ge,ee=K;break}}B.push(K)}while(!0);return w.isGrouped,B.sort(Ae),C=B[Symbol.iterator](),re=C.next(),re.done?(O.onDone&&O.onDone(),re):{value:await D.call(this,re.value)}},return(){O.onDone&&O.onDone(),F.return()},throw(){O.onDone&&O.onDone(),F.throw()}}};let k=a(C=>{if(typeof A=="object"&&Array.isArray(C.attribute))for(let F=0;F<A.length;F++){let x=A[F],q;if(x.name===C.attribute[0]){for(q=x.sort||(x.sort={});q.next;)q=q.next;q.attribute=C.attribute.slice(1),q.descending=C.descending}else x===C.attribute[0]&&(A[F]=q={name:x,sort:{attribute:C.attribute.slice(1),descending:C.descending}})}C.next&&k(C.next)},"applySortingOnSelect");k(w)}else O.iterate=(p[Symbol.asyncIterator]||p[Symbol.iterator]).bind(p),O=O.map(function(B){try{let k=D.call(this,B);return typeof k?.catch=="function"?k.catch(C=>{throw C.partialObject={[t]:B.key},C}):k}catch(k){throw k.partialObject={[t]:B.key},k}});return O}static transformEntryForSelect(p,A,w,R,b,D){if(p&&(p===t||p?.length===1&&p[0]===t&&Array.isArray(p))){let C=a(F=>(A?.transaction?.stale&&(A.transaction.stale=!1),F?.key??F),"transform");return p===t?C:p.asArray?F=>[C(F)]:F=>({[t]:C(F)})}let O;b&&U&&!(typeof p=="string"?[p]:p)?.every(C=>{let F;return typeof C=="object"?F=C.name:F=C,r[F]||F===t})&&(O=!0);let B,k=a(function(C){let F;if(A?.transaction?.stale&&(A.transaction.stale=!1),C!=null){if(F=C.value||C.deref?.()?.value,!F&&(C.key===void 0||C.deref)||C.metadataFlags&Ns){if(C.metadataFlags&Ns&&A.replicateFrom===!1&&D&&C.residencyId)return Ha.SKIP;if(C=Va(C.key??C,A,{transaction:w,lazy:p?.length<4,ensureLoaded:b},this?.isSync,x=>x),C?.then)return C.then(k.bind(this));F=C?.value}if(O&&C?.metadataFlags&(Ns|ba)||C?.expiresAt!=null&&C?.expiresAt<Date.now()){if(A.onlyIfCached&&A.noCacheStore)return{[t]:C.key,message:"This entry has expired"};let x=Pd(C.key??C,C,A);if(x?.then)return x.then(k)}}if(F==null)return D?Ha.SKIP:F;if(p&&!(p[0]==="*"&&p.length===1)){let x,q=a((G,Re)=>{let Ee;typeof G=="object"?Ee=G.name:Ee=G;let Ae=wn?.[Ee],re;if(Ae){let K=R?.[Ee];if(K)if(K.hasMappings){let Be=Ae.from?F[Ae.from]:rd(C.key);re=K.get(Be),re||(re=[])}else re=K.fromRecord?.(F);else re=Ae(F,A,C);let ge=a(Be=>{if(Be&&typeof Be=="object"){let we=Ae.definition?.tableClass||Ve;B||(B={});let ce=B[Ee]||(B[Ee]=we.transformEntryForSelect(Ee===G?null:G.select||(Array.isArray(G)?G:null),A,w,K,b));if(Array.isArray(Be)){let Ye=[],rt=we.transformToOrderedSelect(Be,G.select,typeof G.sort=="object"&&G.sort,A,w,ce)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),Ze=a(Bt=>{for(;!Bt.done;){if(Bt?.then)return Bt.then(Ze);Ye.push(Bt.value),Bt=rt.next()}Re(Ye,Ee)},"nextValue"),st=Ze(rt.next());st&&(x||(x=[]),x.push(st));return}else if(Be=ce.call(this,Be),Be?.then){x||(x=[]),x.push(Be.then(Ye=>Re(Ye,Ee)));return}}Re(Be,Ee)},"handleResolvedValue");re?.then?(x||(x=[]),x.push(re.then(ge))):ge(re);return}else re=F[Ee],re&&typeof re=="object"&&Ee!==G&&(re=Ve.transformEntryForSelect(G.select||G,A,w,null)({value:re}));Re(re,Ee)},"selectAttribute"),ee;if(typeof p=="string")q(p,G=>{ee=G});else if(Array.isArray(p))if(p.asArray)ee=[],p.forEach((G,Re)=>{G==="*"?p[Re]=F:q(G,Ee=>ee[Re]=Ee)});else{ee={};let G=p.forceNulls;for(let Re of p)if(Re==="*")for(let Ee in F)ee[Ee]=F[Ee];else q(Re,(Ee,Ae)=>{Ee===void 0&&G&&(Ee=null),ee[Ae]=Ee})}else throw new Nr.ClientError("Invalid select"+p);return x?Promise.all(x).then(()=>ee):ee}return F},"transform");return k}async subscribe(p){if(!l)throw new Error("Can not subscribe to a table without an audit log");m||Et({table:s,database:c,schemaDefined:u,attributes:S,audit:!0}),p||(p={});let A=!p.rawEvents,w=[],R=this,b=py(Ve,this[ze]??null,function(O,B,k,C){try{let F=B.getValue?.(i,A),x=B.type;if(!F&&x==="patch"&&A){let ee=i.getEntry(O);ee?.version===B.version?F=ee.value:F=B.getValue?.(i,!0,k),x="put"}let q={id:O,localTime:k,value:F,version:B.version,type:x,beginTxn:C};w?w.push(q):this.send(q)}catch(F){qe.default.error?.(F)}},p.startTime||0,p),D=(async()=>{this[li]&&(b.includeDescendants=!0,p.onlyChildren&&(b.onlyChildren=!0)),p.supportsTransactions&&(b.supportsTransactions=!0);let O=this[ze],B=p.previousCount;B>1e3&&(B=1e3);let k=p.startTime;if(this[li]){if(k){if(B)throw new Nr.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:C,value:F}of l.getRange({start:k,exclusiveStart:!0,snapshot:!1})){let x=xt(F);if(x.tableId!==n)continue;let q=x.recordId;if(O==null||wW(O,q)){let ee=x.getValue(i,A,C);if(b.send({id:q,localTime:C,value:ee,version:x.version,type:x.type}),b.queue?.length>NW&&await b.waitForDrain()===!1)return}b.startTime=C}}else if(B){let C=[];for(let{key:F,value:x}of l.getRange({start:"z",end:!1,reverse:!0}))try{let q=xt(x);if(q.tableId!==n)continue;let ee=q.recordId;if(O==null||wW(O,ee)){let G=q.getValue(i,A,F);if(C.push({id:ee,localTime:F,value:G,version:q.version,type:q.type}),--B<=0)break}}catch(q){qe.default.error("Error getting history entry",F,q)}for(let F=C.length;F>0;)b.send(C[--F]);C[0]&&(b.startTime=C[0].localTime)}else if(!p.omitCurrent){for(let{key:C,value:F,version:x,localTime:q}of i.getRange({start:O??!1,end:O==null?void 0:[O,bl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(F&&(b.send({id:C,localTime:q,value:F,version:x,type:"put"}),b.queue?.length>NW&&await b.waitForDrain()===!1))return}}else{B&&!k&&(k=0);let C=this[Fr]?.localTime;if(C===Qg&&(i.cache?.delete(O),this[Fr]=i.getEntry(O),qe.default.trace?.("re-retrieved record",C,this[Fr]?.localTime),C=this[Fr]?.localTime),qe.default.trace?.("Subscription from",k,"from",O,C),k<C){let F=[],x=C;do{let q=l.get(x);if(q){p.omitCurrent=!0;let ee=xt(q),G=ee.getValue(i,A,x);A&&(ee.type="put"),F.push({id:O,value:G,localTime:x,...ee}),x=ee.previousLocalTime}else break;B&&B--}while(x>k&&B!==0);for(let q=F.length;q>0;)b.send(F[--q]);b.startTime=C}!p.omitCurrent&&this.doesExist()&&b.send({id:O,localTime:C,value:this[ve],version:this[kE],type:"put"})}for(let C of w)b.send(C);w=null})();return p.listener&&b.on("data",p.listener),b}static subscribeOnThisThread(p,A){return p===0||A?.crossThreads===!1}doesExist(){return!!(this[ve]||this[xE])}publish(p,A){this._writePublish(p,A)}_writePublish(p,A){let w=Ir(this[Fe]),R=this[ze]||null;R!=null&&ji(R);let b=this[Fe];w.addWrite({key:R,store:i,entry:this[Fr],nodeName:b?.nodeName,validate:a(()=>{b?.source||(w.checkOverloaded(),this.validate(p))},"validate"),before:Ne.publish?.bind(this,b,R,p),beforeIntermediate:Me.publish?.bind(this,b,R,p),commit:a((D,O,B)=>{O===void 0&&g&&!m&&xo(),qe.default.trace?.(`Publishing message to id: ${R}, timestamp: ${new Date(D).toISOString()}`),y(R,O?.value??null,O,O?.version||D,0,!0,{user:b?.user,residencyId:A?.residencyId,expiresAt:b?.expiresAt,nodeId:A?.nodeId},"message",!1,p)},"commit")})}validate(p,A){let w,R=a((b,D,O)=>{if(D.type&&b!=null)if(A&&b.__op__&&(b=b.value),D.properties){typeof b!="object"&&(w||(w=[])).push(`Value ${ui(b)} in property ${O} must be an object${D.type?" ("+D.type+")":""}`);let B=D.properties;for(let k=0,C=B.length;k<C;k++){let F=B[k],x=R(b[F.name],F,O+"."+F.name);x&&(b[F.name]=x)}if(D.sealed&&b!=null&&typeof b=="object")for(let k in b)B.find(C=>C.name===k)||(w||(w=[])).push(`Property ${k} is not allowed within object in property ${O}`)}else switch(D.type){case"Int":(typeof b!="number"||b>>0!==b)&&(w||(w=[])).push(`Value ${ui(b)} in property ${O} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof b!="number"||!(Math.floor(b)===b&&Math.abs(b)<=9007199254740992))&&(w||(w=[])).push(`Value ${ui(b)} in property ${O} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof b!="number"&&(w||(w=[])).push(`Value ${ui(b)} in property ${O} must be a number`);break;case"ID":typeof b=="string"||b?.length>0&&b.every?.(B=>typeof B=="string")||(w||(w=[])).push(`Value ${ui(b)} in property ${O} must be a string, or an array of strings`);break;case"String":typeof b!="string"&&(w||(w=[])).push(`Value ${ui(b)} in property ${O} must be a string`);break;case"Boolean":typeof b!="boolean"&&(w||(w=[])).push(`Value ${ui(b)} in property ${O} must be a boolean`);break;case"Date":if(!(b instanceof Date)){if(typeof b=="string"||typeof b=="number")return new Date(b);(w||(w=[])).push(`Value ${ui(b)} in property ${O} must be a Date`)}break;case"BigInt":if(typeof b!="bigint"){if(typeof b=="string"||typeof b=="number")return BigInt(b);(w||(w=[])).push(`Value ${ui(b)} in property ${O} must be a bigint`)}break;case"Bytes":b instanceof Uint8Array||(w||(w=[])).push(`Value ${ui(b)} in property ${O} must be a Buffer or Uint8Array`);break;case"array":if(Array.isArray(b)){if(D.elements)for(let B=0,k=b.length;B<k;B++){let C=b[B],F=R(C,D.elements,O+"[*]");F&&(b[B]=F)}}else(w||(w=[])).push(`Value ${ui(b)} in property ${O} must be a Buffer or Uint8Array`);break}D.nullable===!1&&b==null&&(w||(w=[])).push(`Property ${O} is required (and not does not allow null values)`)},"validateValue");for(let b=0,D=S.length;b<D;b++){let O=S[b];if(!(O.relationship||O.computed)&&(!A||O.name in p)){let B=R(p[O.name],O,O.name);B&&(p[O.name]=B)}}if(_)for(let b in p)S.find(D=>D.name===b)||(w||(w=[])).push(`Property ${b} is not allowed`);if(w)throw new Nr.ClientError(w.join(". "))}getUpdatedTime(){return this[kE]}wasLoadedFromSource(){return U?!!this[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(),b=Math.floor(A/2),D=p?.exactCount,O=0,B=0,k;for(let{value:C}of i.getRange({start:!0,lazy:!0}))if(C!=null&&O++,B++,!D&&B<b&&performance.now()-R>w){k=B;break}if(k){let C=O;O=0;for(let{value:re}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:k}))re!=null&&O++;let F=k*2,x=(O+C)/F,q=Math.pow((O-C+1)/k/2,2)+x*(1-x)/F,ee=Math.max(Math.sqrt(q)*A,1),G=Math.round(x*A),Re=Math.max(G-1.96*ee,O+C),Ee=Math.min(G+1.96*ee,A),Ae=Math.pow(10,Math.round(Math.log10(ee)));return Ae>G&&(Ae=Ae/10),O=Math.round(G/Ae)*Ae,{recordCount:O,estimatedRange:[Math.round(Re),Math.round(Ee)]}}return{recordCount:O}}static updatedAttributes(){wn=this.propertyResolvers={$id:a((p,A,w)=>({value:w.key}),"$id"),$updatedtime:a((p,A,w)=>w.version,"$updatedtime"),$record:a((p,A,w)=>w?{value:p}:p,"$record")};for(let p of this.attributes){p.resolve=null;let A=p.relationship,w=p.computed;if(A)if(p.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),w&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),Dd=!0,A.to)p.elements?.definition?(wn[p.name]=p.resolve=(R,b,D)=>{let O=R[A.from?A.from:t],B=p.elements.definition.tableClass;return D?td({attribute:A.to,value:O},Ir(b).getReadTxn(),!1,B,!1).asArray:B.search([{attribute:A.to,value:O}],b).asArray},p.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},p.resolve.definition=p.elements.definition,A.from&&(p.resolve.from=A.from)):console.error(`The one-to-many/many-to-many relationship property "${p.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(A.from){let R=p.definition||p.elements?.definition;R?(wn[p.name]=p.resolve=(b,D,O)=>{let B=b[A.from];if(B!==void 0){if(p.elements){let k,C=B?.map(F=>{let x=O?R.tableClass.primaryStore.getEntry(F,{transaction:Ir(D).getReadTxn()}):R.tableClass.get(F,D);return x?.then&&(k=!0),x});return A.filterMissing?k?Promise.all(C).then(F=>F.filter(CW)):C.filter(CW):k?Promise.all(C):C}return O?R.tableClass.primaryStore.getEntry(B,{transaction:Ir(D).getReadTxn()}):R.tableClass.get(B,D)}},p.set=(b,D)=>{if(Array.isArray(D)){let O=D.map(B=>B[ze]||B[R.tableClass.primaryKey]);b[A.from]=O}else{let O=D[ze]||D[R.tableClass.primaryKey];b[A.from]=O}},p.resolve.definition=p.definition||p.elements?.definition,p.resolve.from=A.from):console.error(`The relationship property "${p.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${p.name}" in table "${s}" must use either "from" or "to" arguments`);else w&&(typeof w.from=="function"&&this.setComputedAttribute(p.name,w.from),wn[p.name]=p.resolve=(R,b,D)=>{let O=typeof w.from=="string"?R[w.from]:R,B=this.userResolvers[p.name];if(B)return B(O,b,D);qe.default.warn(`Computed attribute "${p.name}" does not have a function assigned to it. Please use setComputedAttribute('${p.name}', resolver) to assign a resolver function.`),this.userResolvers[p.name]=()=>{}})}BT(this,this)}static setComputedAttribute(p,A){let w=Hi(S,p);if(!w){console.error(`The attribute "${p}" does not exist in the table "${s}"`);return}if(!w.computed){console.error(`The attribute "${p}" is not defined as computed in the table "${s}"`);return}this.userResolvers[p]=A}static async deleteHistory(p=0,A=!1){let w;for(let{key:R,value:b}of l.getRange({start:0,end:p}))await yd(),xt(b).tableId===n&&(w=wT(l,R,b));if(A)for(let{key:R,value:b,localTime:D}of i.getRange({start:0,versions:!0}))await yd(),b===null&&D<p&&(w=i.remove(R));await w}static async*getHistory(p=0,A=1/0){for(let{key:w,value:R}of l.getRange({start:p||1,end:A})){await yd();let b=xt(R);b.tableId===n&&(yield{id:b.recordId,localTime:w,version:b.version,type:b.type,value:b.getValue(i,!0,w),user:b.user,operation:b.originatingOperation})}}static async getHistoryOfRecord(p){let A=[];if(p==null)throw new Error("An id is required");let w=i.getEntry(p);if(!w)return A;let R=w.localTime;if(!R)throw new Error("The entry does not have a local audit time");let b=0;do{await 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(b<1e3&&R);return A.reverse()}static cleanup(){Q?.remove()}}Ve.updatedAttributes();let is=Ve.prototype;return is[XSe]=!0,h&&Ve.setTTLExpiration(h/1e3),ne&&Se(),Ve;function $a(v,p,A){let w;for(let R in r){let b=r[R],D=b.isIndexing,O=wn[R],B=A&&(O?O(A):A[R]),k=p&&(O?O(p):p[R]);if(B===k&&!D)continue;w=!0;let C=b.indexNulls,F=(0,FE.getIndexedValues)(B,C),x=(0,FE.getIndexedValues)(k,C);if(x?.length>0){let q=new Set(x);if(F=F?F.filter(ee=>{if(q.has(ee))q.delete(ee);else return!0}):[],x=Array.from(q),(x.length>0||F.length>0)&&yW){let ee=x.concat(F).map(G=>({key:G,value:v}));b.prefetch(ee,IW)}for(let ee=0,G=x.length;ee<G;ee++)b.remove(x[ee],v)}else F?.length>0&&yW&&b.prefetch(F.map(q=>({key:q,value:v})),IW);if(F)for(let q=0,ee=F.length;q<ee;q++)b.put(F[q],v)}return w}a($a,"updateIndices");function ji(v){switch(typeof v){case"number":return!0;case"string":if(v.length<659)return!0;if(v.length>OW)throw new Error("Primary key size is too large: "+v.length);break;case"object":if(v===null)throw new Error("Invalid primary key of null");break;case"bigint":if(v<2n**64n&&v>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof v)}if((0,bl.writeKey)(v,eTe,0)>OW)throw new Error("Primary key size is too large: "+v.length);return!0}a(ji,"checkValidId");function Va(v,p,A,w,R){if(Ve.getResidencyById&&A.ensureLoaded&&p?.replicateFrom!==!1){let D=Ve.getResidencyById(v);if(D&&!D.includes(server.hostname)&&I)return I({key:v,residency:D}).then(R)}let b=a(()=>{if(p?.transaction?.stale&&(p.transaction.stale=!1),A.transaction?.isDone)return R(null,v);let D=i.getEntry(v,A);return D?.residencyId&&D.metadataFlags&Ns&&I&&A.ensureLoaded&&p?.replicateFrom!==!1?I(D).then(O=>R(O,v)):(D&&p&&(D?.version>(p.lastModified||0)&&(p.lastModified=D.version),D?.localTime&&!p.lastRefreshed&&(p.lastRefreshed=D.localTime)),R(D,v))},"whenPrefetched");return w?b():ae>0?(ae--,b()):new Promise((D,O)=>{ae===0?(ae--,i.prefetch([v],()=>{B(),k()})):(de.push(v),j.push(k),de.length>zE&&(ae--,B()));function B(){if(de.length>0){let C=j;i.prefetch(de,()=>{ae===-1?B():ae++;for(let F of C)F()}),de=[],j=[],Oe>2&&Oe--}else ae=Oe,Oe<Bs&&Oe++}a(B,"prefetch");function k(){try{D(b())}catch(C){O(C)}}a(k,"load")})}a(Va,"loadLocalRecord");function Ka(v){if(!v?.role)return;let p=v.role.permission;if(p.super_user)return tTe;let A=p[c],w,R=A?.tables;if(R)return R[s];if(c==="data"&&(w=p[s])&&!w.tables)return w}a(Ka,"getTablePermissions");function Pd(v,p,A,w){if(U){let R=!1;if(A.noCache?R=!0:(p?(!p.value||p.metadataFlags&(Ns|ba)||p.expiresAt!=null&&p.expiresAt<Date.now())&&(R=!0):R=!0,qn(!R,"cache-hit",s)),R){let b=Md(v,p,A).then(D=>(D?.value?.[ve]&&qe.default.error?.("Can not assign a record with a record property"),A&&(D?.version>(A.lastModified||0)&&(A.lastModified=D.version),A.lastRefreshed=Date.now()),D));if(A?.onlyIfCached||p?.value&&w?.allowStaleWhileRevalidate?.(p,v)){if(b.catch(D=>qe.default.warn?.(D)),A?.onlyIfCached&&!w.doesExist())throw new Nr.ServerError("Entry is not cached",504);return}else return b}}else if(p?.value&&p.expiresAt!=null&&p.expiresAt<Date.now())return Ve.evict(p.key,p.value,p.version),p.value=null,{then(R){return R(p)}}}a(Pd,"ensureLoadedFromSource");function Ir(v){let p=v?.transaction;if(p){if(!p.lmdbDb)return p.lmdbDb=i,p;do{if(p.lmdbDb?.path===i.path)return p;let A=p.next;if(!A)return p=p.next=new mc,p.lmdbDb=i,p;p=A}while(!0)}else return new cp}a(Ir,"txnForContext");function Il(v,p,A){if(!v)return;let w=v.value||i.getEntry(v.key)?.value;if(typeof p=="object"){let b=wn,D=w;for(let O=0,B=p.length;O<B;O++){let k=p[O],C=b?.[k];D=C&&D?C(D,A,!0)?.value:D?.[k],b=C?.definition?.tableClass?.propertyResolvers}return D}let R=wn[p];return R?R(w,A):w[p]}a(Il,"getAttributeValue");function Ld(v,p,A,w,R){let b=R?.length,D={transaction:w,lazy:b>0||typeof p=="string"||p?.length<4,alwaysPrefetch:!0},O;function B(k,C){let F=k?.value;if(!F)return Ha.SKIP;for(let x=0;x<b;x++)if(!O?.includes(x)&&!R[x](F,k))return Ha.SKIP;return C!==void 0&&(k.key=C),k}if(a(B,"processEntry"),b>0||!v.hasEntries){let k=v.map(C=>{if(O=null,typeof C=="object"&&C?.key!==void 0)return b>0?B(C):C;if(C==null)return Ha.SKIP;for(let F=0;F<b;F++){let q=R[F].idFilter;if(q){if(!q(C))return Ha.SKIP;O||(O=[]),O.push(F)}}return Va(C,A,D,!1,B)});return Array.isArray(v)&&(k=k.filter(C=>C!==Ha.SKIP)),k.hasEntries=!0,k}return v}a(Ld,"transformToEntries");function _i(v,p,A=server.replication?.getThisNodeId(l)){if(v<=p?.version){if(p?.version===v&&A!==void 0){let w=server.replication?.exportIdMapping(l),R=p.localTime,b=R&&l.get(R);if(b){let D,O,B=xt(b);for(let k in w)w[k]===A&&(D=k),w[k]===B.nodeId&&(O=k);if(D>O)return 1;if(D===O)return 0}}return-1}return 1}a(_i,"precedesExistingVersion");async function Md(v,p,A){let w=p?.metadataFlags,R=p?.version,b,D;if(!i.attemptLock(v,R,()=>{clearTimeout(D);let C=i.getEntry(v);!C||!C.value||C.metadataFlags&(Ns|ba)?b(Md(v,i.getEntry(v),A)):b(C)}))return new Promise(C=>{b=C,D=setTimeout(()=>{i.unlock(v,R)},JSe)});let O=p?.value,B={requestContext:A,replacingRecord:O,replacingEntry:p,replacingVersion:R,noCacheStore:!1,source:null,resourceCache:A?.resourceCache},k=A?.responseHeaders;return new Promise((C,F)=>{let x;Iw(Dt(B,async q=>{let ee=performance.now(),G,Re,Ee;try{for(let ge of Ve.sources)if(ge.get&&(!ge.get.reliesOnPrototype||ge.prototype.get)){if(ge.available?.(p)===!1)continue;if(B.source=ge,G=await ge.get(v,B),G)break}Ee=w&Ns;let re=B.lastModified||Ee&&R;Re=Ee||re>R||!O,re||(re=(0,FE.getNextMonotonicTime)());let K=performance.now()-ee;if(pr(K,"cache-resolution",s,null,"success"),k&&Bm(k,"Server-Timing",`cache-resolve;dur=${K.toFixed(2)}`,!0),q.timestamp=re,h&&B.expiresAt==null&&(B.expiresAt=Date.now()+h),G){if(typeof G!="object")throw new Error("Only objects can be cached and stored in tables");if(G.status>0&&G.headers)if(G.status>=300)if(G.status===304)G=O,re=R;else throw new Nr.ServerError(G.body||"Error from source",G.status);else G=G.body;typeof G.toJSON=="function"&&(G=G.toJSON()),t&&G[t]!==v&&(G[t]=v)}x=!0,C({key:v,version:re,value:G})}catch(re){re.message+=` while resolving record ${v} for ${s}`,O&&((re.code==="ECONNRESET"||re.code==="ECONNREFUSED"||re.code==="EAI_AGAIN")&&!A?.mustRevalidate||A?.staleIfError&&(re.statusCode===500||re.statusCode===502||re.statusCode===503||re.statusCode===504))?(C({key:v,version:R,value:O}),qe.default.trace?.(re.message,"(returned stale record)")):F(re);let K=performance.now()-ee;pr(K,"cache-resolution",s,null,"fail"),k&&Bm(k,"Server-Timing",`cache-resolve;dur=${K.toFixed(2)}`,!0),B.transaction.abort();return}if(A?.noCacheStore||B.noCacheStore){B.transaction.abort();return}Ir(B).addWrite({key:v,store:i,entry:p,nodeName:"source",commit:a((re,K)=>{if(K?.version!==R)return;let ge=$a(v,O,G);G?(Me.put?.(B,v,G),qe.default.trace?.(`Writing resolved record from source with id: ${v}, timestamp: ${new Date(re).toISOString()}`),y(v,G,K,re,0,m&&Re||null,{user:B?.user,expiresAt:B.expiresAt},"put",!!Ee)):K&&(Me.delete?.(B,v),qe.default.trace?.(`Deleting resolved record from source with id: ${v}, timestamp: ${new Date(re).toISOString()}`),m||g?y(v,null,K,re,0,m&&Re||null,{user:B?.user},"delete",!!Ee):i.remove(v,R))},"commit")})}),()=>{i.unlock(v,R)},q=>{i.unlock(v,R),x&&qe.default.error?.("Error committing cache update",q)})})}a(Md,"getFromSource");function Ya(v){if(!v||v.user?.role?.permission?.super_user)return!0;if(v.replicateTo)throw new Nr.ClientError("Can not specify replication parameters without super user permissions",403);if(v.replicatedConfirmation)throw new Nr.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}a(Ya,"checkContextPermissions");function xo(){if(Gr!==Cd&&(Cd=Gr,(0,yl.getWorkerIndex)()===(0,yl.getWorkerCount)()-1)){if(Fa&&clearTimeout(Fa),!Gr)return;let v=new Date;v.setMonth(0),v.setDate(1),v.setHours(0),v.setMinutes(0),v.setSeconds(0);let p=Math.ceil((Date.now()-v.getTime())/Gr)*Gr+v.getTime(),A=a(w=>{qe.default.trace?.(`Scheduled next cleanup scan at ${new Date(w)}ms`),Fa=setTimeout(()=>X=X.then(async()=>{if(A(Math.max(w+Gr,Date.now())),i.rootStore.status!=="open"){clearTimeout(Fa);return}let R=50,b=new Array(R),D=0;qe.default.info?.(`Starting cleanup scan for ${s}`);try{let O=0;for(let{key:B,value:k,version:C,expiresAt:F}of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let x;k===null&&!m&&C+QSe<Date.now()?x=i.remove(B,C):F!=null&&F+T<Date.now()&&(x=Ve.evict(B,k,C),O++),x&&(await b[D],b[D]=x.catch(q=>{qe.default.error?.("Cleanup error",q)}),++D>=R&&(D=0)),await 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,v=>{let p=i.getEntry(v);p?.value===null&&i.remove(v,p.version)})}a(ie,"addDeleteRemoval");function Se(){(0,yl.getWorkerIndex)()===0&&setInterval(async()=>{if(!Nl){Nl=!0;try{let v=ne.name,p=r[v];if(!p)throw new Error(`expiresAt attribute ${ne} must be indexed`);for(let A of p.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let w of p.getValues(A)){let R=i.getEntry(w);R?.value?R.value[v]<Date.now()&&Ve.evict(w,R.value,R.version):i.ifVersion(w,R?.version,()=>p.remove(A,w))}await yd()}}catch(v){qe.default.error?.("Error in evicting old records",v)}finally{Nl=!1}}},zSe).unref()}a(Se,"runRecordExpirationEviction");function tt(v){if(v){let p=v.join(","),A=d.get([Symbol.for("residency_by_set"),p]);return A||(d.put([Symbol.for("residency_by_set"),p],A=Math.floor(Math.random()*2147483647)),d.put([Symbol.for("residency_by_id"),A],v),A)}}a(tt,"getResidencyId")}function 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 rTe(e){LW=e}function GT(e,t){let r=t?.type;if(e===null)return e;if(e===""&&r&&r!=="String"&&r!=="Any")return null;try{switch(r){case"Int":case"Long":if(e[0]==="$")return FT(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return FT(+e);case"Float":return e==="null"?null:FT(+e);case"BigInt":return e==="null"?null:BigInt(e);case"Boolean":return e==="true"?!0:e==="false"?!1:e;case"Date":if(isNaN(e)){if(e==="null")return null;nTe.test(e)||(e+="Z");let n=new Date(e);return FT(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,$T.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function FT(e){if(isNaN(e))throw new SyntaxError;return e}function wW(e,t){if(e==null)return!0;if(!Array.isArray(t))return e===t||t.startsWith?.(e);if(Array.isArray(e)){let r=e.length;if(e[r-1]===null&&r--,t.length>=r){for(let n=0;n<r;n++)if(t[n]!==e[n])return!1;return!0}return!1}else if(t[0]===e)return!0}function 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 ui(e){try{return JSON.stringify(e)}catch{return e}}function sTe(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var Us,Ha,FE,DW,PW,bd,Nr,GE,qE,qe,bl,yl,$T,jSe,LW,zSe,QSe,yW,JSe,kE,XSe,Fr,xE,bW,ZSe,Ow,Ns,ba,eTe,OW,NW,tTe,zMe,nTe,yd,Vf=Ie(()=>{Us=L(M()),Ha=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();fE();qe=L(Oc());_p();Sc();bl=require("ordered-binary"),yl=L(dt());Ji();$T=L(te());vl();Ii();CT();vf();jSe=new Uint8Array(9);jSe[8]=192;zSe=6e4,QSe=864e5;bd.initSync();yW=bd.get(Us.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),JSe=1e4,kE=Symbol.for("version"),XSe=Symbol.for("incremental-update"),Fr=Symbol("entry"),xE=Symbol("is-saving"),bW=1,ZSe=2,Ow=Symbol("loaded-from-source"),Ns=1,ba=8,eTe=Buffer.allocUnsafeSlow(8192),OW=1978,NW=100,tTe={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},zMe=(0,$T.convertToMS)(bd.get(Us.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(VT,"makeTable");a(Nw,"attributesAsObject");a(IW,"noop");a(rTe,"setServerUtilities");nTe=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(GT,"coerceType");a(FT,"rejectNaN");a(wW,"isDescendantId");yd=a(()=>new Promise(setImmediate),"rest");a(Iw,"when");a(qT,"updateResource");a(CW,"exists");a(ui,"stringify");a(sTe,"hasOtherProcesses")});var lt={};je(lt,{database:()=>Ql,databases:()=>We,dropDatabase:()=>xR,dropTableMeta:()=>lTe,getDatabases:()=>ut,getDefaultCompression:()=>Lm,getTables:()=>iTe,onRemovedDB:()=>sf,onUpdatedTable:()=>Lc,readMetaDb:()=>$E,resetDatabases:()=>ku,table:()=>Et,tables:()=>zn});function iTe(){return jT||ut(),zn||{}}function ut(){if(jT)return We;jT=!0,Id=new Map;let e=(0,er.getHdbBasePath)()&&(0,Ut.join)((0,er.getHdbBasePath)(),br.DATABASES_DIR_NAME),t=(0,er.get)(br.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)(br.CONFIG_PARAMS.STORAGE_PATH)||e&&((0,ns.existsSync)(e)?e:(0,Ut.join)((0,er.getHdbBasePath)(),br.LEGACY_DATABASES_DIR_NAME)),!e)return;if((0,ns.existsSync)(e))for(let n of(0,ns.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,ns.existsSync)((0,Nd.getBaseSchemaPath)())){for(let n of(0,ns.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,ns.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,ns.existsSync)(i))for(let c of(0,ns.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,ns.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 zn)delete zn[i];delete zn[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 ku(){jT=!1;for(let[,e]of xa)e.needsDeletion=!0;ut();for(let[e,t]of xa)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),xa.delete(e),delete We[t.databaseName],KE.forEach(r=>r(t.databaseName)));return We}function $E(e,t,r=Dw,n,s){let i=new ww.default(e,!1);try{let o=xa.get(e);o?o.needsDeletion=!1:(o=(0,wd.open)(i),xa.set(e,o));let c=new Ol.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(KT.INTERNAL_DBIS_NAME,c)),u=o.auditStore;u||(n?(0,ns.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={},y=[],I,U,H=typeof m.audit=="boolean"?m.audit:(0,er.get)(br.CONFIG_PARAMS.LOGGING_AUDITLOG),X=m.trackDeletes,Y=m.expiration,V=m.eviction,ne=m.sealed,Q=m.splitSegments,de=m.replicate;if(g)S=g.indices,y=g.attributes,g.schemaVersion++;else{I=m.tableId,I?I>=(l.get(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 Ol.default(!m.is_hash_attribute,m.is_hash_attribute);if(j.compression=m.compression,j.compression){let ae=(0,er.get)(br.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||vW;j.compression.threshold=ae}U=Nh(o.openDB(m.key,j)),o.databaseName=r,U.rootStore=o,U.tableId=I}for(let j of T){j.attribute=j.name;try{if(!j.is_hash_attribute&&(j.indexed||j.attribute&&!j.name)){if(!S[j.name]){let Oe=new Ol.default(!j.is_hash_attribute,j.is_hash_attribute);S[j.name]=o.openDB(j.key,Oe),S[j.name].indexNulls=j.indexNulls}let ae=y.find(Oe=>Oe.name===j.name);ae?y.splice(y.indexOf(ae),1,j):y.push(j)}}catch(ae){Vt.error("Error trying to update attribute",j,y,S,ae)}}if(!g){g=HW(d,f,VT({primaryStore:U,auditStore:u,audit:H,sealed:ne,splitSegments:Q,replicate:de,expirationMS:Y&&Y*1e3,evictionMS:V&&V*1e3,trackDeletes:X,tableName:f,tableId:I,primaryKey:m.name,databasePath:s?r+"/"+f:r,databaseName:r,indices:S,attributes:T,schemaDefined:m.schemaDefined,dbisDB:l})),g.schemaVersion=1;for(let j of VE)j(g)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function BW(e){let t=We[e];if(t||(e==="data"?t=We[e]=zn: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 Ql({database:e,table:t}){e||(e=Dw),ut();let r=BW(e),n=(0,Ut.join)((0,er.getHdbBasePath)(),br.DATABASES_DIR_NAME),s=(0,er.get)(br.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)(br.CONFIG_PARAMS.STORAGE_PATH)||((0,ns.existsSync)(n)?n:(0,Ut.join)((0,er.getHdbBasePath)(),br.LEGACY_DATABASES_DIR_NAME));let o=(0,Ut.join)(n,(i?t:e)+".mdb"),c=xa.get(o);if(!c||c.status==="closed"){let l=new ww.default(o,!1);c=(0,wd.open)(l),xa.set(o,c)}return c.auditStore||(c.auditStore=IT(c)),c}async function xR(e){if(!We[e])throw new Error("Schema does not exist");let t=We[e],r;for(let n in t)r=t[n].primaryStore.rootStore,xa.delete(r.path),r.status==="open"&&(await r.close(),await YE.remove(r.path));if(r||(r=Ql({database:e,table:null}),r.status==="open"&&(await r.close(),await YE.remove(r.path))),e==="data"){for(let n in zn)delete zn[n];delete zn[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=Ql({database:r,table:t}),T=We[r];Vt.trace(`Defining ${t} in ${r}`);let m=T?.[t];if(h.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let g,S,y;E==null&&(E=!0);let I=new Ol.default(!1);for(let Q of o)Q.attribute&&!Q.name?(Q.name=Q.attribute,Q.indexed=!0):Q.attribute=Q.name,Q.expiresAt&&(Q.indexed=!0);let U,H;if(m){if(g=m.primaryKey,m.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);u==null&&(u=m.splitSegments),m.attributes.splice(0,m.attributes.length,...o)}else{let Q=h.auditStore;S=o.find(Oe=>Oe.isPrimaryKey)||{},g=S.name,S.is_hash_attribute=S.isPrimaryKey=!0,S.schemaDefined=E,S.compression=Lm(),_&&(S.trackDeletes=!0),c=S.audit=typeof c=="boolean"?c:(0,er.get)(br.CONFIG_PARAMS.LOGGING_AUDITLOG),n&&(S.expiration=n),s&&(S.eviction=s),u??=!1,S.splitSegments=u,typeof l=="boolean"&&(S.sealed=l),typeof d=="boolean"&&(S.replicate=d),f&&(S.origins?S.origins.includes(f)||S.origins.push(f):S.origins=[f]),Vt.trace(`${t} table loading, opening primary store`);let de=new Ol.default(!1,!0);de.compression=S.compression;let j=t+"/";if(y=h.dbisDb=h.openDB(KT.INTERNAL_DBIS_NAME,I),ne(),y.get(j))return H&&H(),ku(),Et(e);let ae=Nh(h.openDB(j,de));h.databaseName=r,ae.rootStore=h,ae.tableId=y.get(Od),Vt.trace(`Assigning new table id ${ae.tableId} for ${t}`),ae.tableId||(ae.tableId=1),y.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:y})),m.schemaVersion=1,U=!0,y.put(j,S)}let X=m.indices;y=y||(h.dbisDb=h.openDB(KT.INTERNAL_DBIS_NAME,I)),m.dbisDB=y;let Y=[];for(let{key:Q,value:de}of y.getRange({start:!0})){let[j,ae]=Q.toString().split("/");if(ae===""&&(ae=de.name),ae){if(j!==t)continue}else continue;let Oe=o.find(Me=>Me.name===ae),Ne=!Oe?.indexed&&de.indexed&&!de.isPrimaryKey;if((!Oe||Ne)&&(ne(),U=!0,Oe||y.remove(Q),Ne)){let Me=m.indices[j];Me&&Y.push(Me)}}let V=[];try{for(let Q of o||[]){if((Q.relationship||Q.computed)&&(U=!0,Q.relationship))continue;let de=t+"/"+(Q.name||"");Object.defineProperty(Q,"key",{value:de,configurable:!0});let j=y.get(de);if(Q.isPrimaryKey){if(j=j||y.get(de=t+"/")||{},c!==void 0&&c!==m.audit||l!==void 0&&l!==m.sealed||d!==void 0&&d!==m.replicate||(+n||void 0)!==(+j.expiration||void 0)||(+s||void 0)!==(+j.eviction||void 0)){let Oe={...j};typeof c=="boolean"&&(c&&m.enableAuditing(c),Oe.audit=c),n&&(Oe.expiration=+n),s&&(Oe.eviction=+s),l!==void 0&&(Oe.sealed=l),d!==void 0&&(Oe.replicate=d),U=!0,ne(),y.put(de,Oe)}continue}j?.attribute&&!j.name&&(j.indexed=!0);let ae=!j||j.type!==Q.type||j.indexed!==Q.indexed||j.nullable!==Q.nullable||j.version!==Q.version||JSON.stringify(j.properties)!==JSON.stringify(Q.properties)||JSON.stringify(j.elements)!==JSON.stringify(Q.elements);if(Q.indexed){let Oe=new Ol.default(!0,!1),Ne=h.openDB(de,Oe);(ae||j.indexingPID&&j.indexingPID!==process.pid||j.restartNumber<WE.workerData?.restartNumber)&&(U=!0,ne(),j=y.get(de),(ae||j.indexingPID&&j.indexingPID!==process.pid||j.restartNumber<WE.workerData?.restartNumber)&&(U=!0,Q.indexNulls===void 0&&(Q.indexNulls=!0),m.primaryStore.getStats().entryCount>0&&(Q.lastIndexedKey=j?.lastIndexedKey??void 0,Q.indexingPID=process.pid,Ne.isIndexing=!0,Object.defineProperty(Q,"dbi",{value:Ne}),V.push(Q))),y.put(de,Q)),j?.indexNulls&&Q.indexNulls===void 0&&(Q.indexNulls=!0),Ne.indexNulls=Q.indexNulls,X[Q.name]=Ne}else ae&&(U=!0,ne(),y.put(de,Q))}}finally{H&&H()}if(U&&(m.schemaVersion++,m.updatedAttributes()),Vt.trace(`${t} table loading, running index`),V.length>0||Y.length>0?m.indexingOperation=cTe(m,V,Y):U&&YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"schema-change",m.databaseName,m.tableName)),m.origin=f,U)for(let Q of VE)Q(m,f!=="cluster");return(n||s||i)&&m.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),Vt.trace(`${t} table loaded`),m;function ne(){H||h.transactionSync(()=>({then(Q){H=Q}}))}a(ne,"startTxn")}async function cTe(e,t,r){try{Vt.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o={},c=0,l=t.length;if(await new Promise(u=>setImmediate(u)),l>0){let u;for(let _ of t)(0,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]),y=(0,MW.getIndexedValues)(S);if(y)for(let I=0,U=y.length;I<U;I++)T.dbi.put(y[I],_)}catch(g){o[m]||(o[m]=!0,Vt.error(`Error indexing attribute ${m}`,g))}}}),s.then(()=>d--,h=>{d--,Vt.error(h)}),WE.workerData&&WE.workerData.restartNumber!==UW.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=_,e.dbisDB.put(h.key,h);if(i)return}d>oTe?await s:d>aTe&&await new Promise(h=>setImmediate(h))}for(let _ of t)delete _.lastIndexedKey,delete _.indexingPID,_.dbi.isIndexing=!1,s=e.dbisDB.put(_.key,_)}await s,await YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),Vt.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){Vt.error("Error in indexing",n)}}function lTe({table:e,database:t}){let r=Ql({database:t,table:e}),n=[],s=r.dbisDb;for(let i of s.getKeys({start:e+"/",end:e+"0"}))n.push(s.remove(i));return Promise.all(n)}function Lc(e){return VE.push(e),{remove(){let t=VE.indexOf(e);t>-1&&VE.splice(t,1)}}}function 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)(br.CONFIG_PARAMS.STORAGE_COMPRESSION),t=(0,er.get)(br.CONFIG_PARAMS.STORAGE_COMPRESSION_DICTIONARY),r=(0,er.get)(br.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,ns,Nd,Ol,ww,br,YE,Cw,MW,YT,WT,WE,Vt,UW,Dw,zT,vW,zn,We,Od,VE,KE,jT,xa,Id,oTe,aTe,Pe=Ie(()=>{er=L(se()),KT=L(Ht()),wd=require("lmdb"),Ut=require("path"),ns=require("fs"),Nd=L(gt());Vf();Ol=L(a_()),ww=L(c_()),br=L(M()),YE=L(require("fs-extra")),Cw=L(Ei()),MW=L(cn()),YT=L(no()),WT=L(qs()),WE=require("worker_threads"),Vt=L(W()),UW=L(dt());Ji();vl();Dw="data",zT=Symbol("defined-tables"),vW=((0,er.get)(br.CONFIG_PARAMS.STORAGE_PAGESIZE)||4096)-60;(0,er.initSync)();zn=Object.create(null),We=Object.create(null);(0,Cw._assignPackageExport)("databases",We);(0,Cw._assignPackageExport)("tables",zn);Od=Symbol.for("next-table-id"),VE=[],KE=[],xa=new Map;a(iTe,"getTables");a(ut,"getDatabases");a(ku,"resetDatabases");a($E,"readMetaDb");a(BW,"ensureDB");a(HW,"setTable");a(Ql,"database");a(xR,"dropDatabase");a(Et,"table");oTe=1e3,aTe=10;a(cTe,"runIndexing");a(lTe,"dropTableMeta");a(Lc,"onUpdatedTable");a(sf,"onRemovedDB");a(Lm,"getDefaultCompression")});var te=N((sUe,JW)=>{"use strict";var ka=require("path"),qW=require("fs-extra"),In=W(),xW=require("fs-extra"),QT=require("os"),uTe=require("net"),dTe=require("recursive-iterator"),Kt=M(),_Te=hg(),kW=require("papaparse"),JT=require("moment"),{inspect:fTe}=require("util"),FW=require("is-number"),nUe=require("lodash"),ETe=require("minimist"),hTe=require("https"),pTe=require("http"),{hdb_errors:XT}=_e(),mTe=/^((\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d\.\d+([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z)))$/,$W=require("util").promisify(setTimeout),STe=100,TTe=5,gTe="",ATe=4,GW={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};JW.exports={isEmpty:ss,isEmptyOrZeroLength:Wi,arrayHasEmptyValues:bTe,arrayHasEmptyOrZeroLengthValues:OTe,buildFolderPath:NTe,isBoolean:VW,errorizeMessage:RTe,stripFileExtension:wTe,autoCast:CTe,autoCastJSON:KW,autoCastJSONDeep:Lw,removeDir:DTe,compareVersions:PTe,isCompatibleDataVersion:LTe,escapeRawValue:MTe,unescapeValue:UTe,stringifyProps:vTe,timeoutPromise:HTe,isClusterOperation:kTe,getClusterUser:GTe,checkGlobalSchemaTable:FTe,getHomeDir:WW,getPropsFilePath:BTe,promisifyPapaParse:qTe,removeBOM:jW,createEventPromise:$Te,checkProcessRunning:VTe,checkSchemaTableExist:KTe,checkSchemaExists:zW,checkTableExists:QW,getStartOfTomorrowInSeconds:YTe,getLimitKey:WTe,isObject:ITe,isNotEmptyAndHasValue:yTe,autoCasterIsNumberCheck:YW,backtickASTSchemaItems:jTe,isPortTaken:xTe,createForkArgs:zTe,autoCastBoolean:QTe,async_set_timeout:$W,getTableHashAttribute:JTe,doesSchemaExist:XTe,doesTableExist:ZTe,stringifyObj:ege,ms_to_time:tge,changeExtension:rge,getEnvCliRootPath:Mw,noBootFile:nge,httpRequest:sge,transformReq:ige,convertToMS:oge,PACKAGE_ROOT:Kt.PACKAGE_ROOT};function RTe(e){return e instanceof Error?e:new Error(e)}a(RTe,"errorizeMessage");function ss(e){return e==null}a(ss,"isEmpty");function yTe(e){return!ss(e)&&(e||e===0||e===""||VW(e))}a(yTe,"isNotEmptyAndHasValue");function Wi(e){return ss(e)||e.length===0||e.size===0}a(Wi,"isEmptyOrZeroLength");function bTe(e){if(ss(e))return!0;for(let t=0;t<e.length;t++)if(ss(e[t]))return!0;return!1}a(bTe,"arrayHasEmptyValues");function OTe(e){if(Wi(e))return!0;for(let t=0;t<e.length;t++)if(Wi(e[t]))return!0;return!1}a(OTe,"arrayHasEmptyOrZeroLengthValues");function NTe(...e){try{return e.join(ka.sep)}catch{console.error(e)}}a(NTe,"buildFolderPath");function VW(e){return ss(e)?!1:e===!0||e===!1}a(VW,"isBoolean");function ITe(e){return ss(e)?!1:typeof e=="object"}a(ITe,"isObject");function wTe(e){return Wi(e)?gTe:e.slice(0,-ATe)}a(wTe,"stripFileExtension");function CTe(e){return ss(e)||e===""||typeof e!="string"?e:GW[e]!==void 0?GW[e]:YW(e)===!0?Number(e):mTe.test(e)?new Date(e):e}a(CTe,"autoCast");function KW(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(KW,"autoCastJSON");function 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 DTe(e){if(Wi(e))throw new Error(`Directory path: ${e} does not exist`);try{await xW.emptyDir(e),await xW.remove(e)}catch(t){throw In.error(`Error removing files in ${e} -- ${t}`),t}}a(DTe,"removeDir");function PTe(e,t){if(Wi(e)){In.info("Invalid current version sent as parameter.");return}if(Wi(t)){In.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,o=s.replace(n,"").split("."),c=i.replace(n,"").split("."),l=Math.min(o.length,c.length);for(let u=0;u<l;u++)if(r=parseInt(o[u],10)-parseInt(c[u],10),r)return r;return o.length-c.length}a(PTe,"compareVersions");function LTe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(LTe,"isCompatibleDataVersion");function MTe(e){if(ss(e))return e;let t=String(e);return t==="."?Kt.UNICODE_PERIOD:t===".."?Kt.UNICODE_PERIOD+Kt.UNICODE_PERIOD:t.replace(Kt.FORWARD_SLASH_REGEX,Kt.UNICODE_FORWARD_SLASH)}a(MTe,"escapeRawValue");function UTe(e){if(ss(e))return e;let t=String(e);return t===Kt.UNICODE_PERIOD?".":t===Kt.UNICODE_PERIOD+Kt.UNICODE_PERIOD?"..":String(e).replace(Kt.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(UTe,"unescapeValue");function vTe(e,t){if(ss(e))return In.info("Properties object is null"),"";let r="";return e.each(function(n,s){try{if(t&&t[n]){let i=t[n];for(let o of i)r+=";"+o+QT.EOL}!Wi(n)&&n[0]===";"?r+=" "+n+s+QT.EOL:Wi(n)||(r+=n+"="+s+QT.EOL)}catch{In.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(vTe,"stringifyProps");function WW(){let e;try{e=QT.homedir()}catch{e=process.env.HOME}return e}a(WW,"getHomeDir");function BTe(){let e=ka.join(WW(),Kt.HDB_HOME_DIR_NAME,Kt.BOOT_PROPS_FILE_NAME);return qW.existsSync(e)||(e=ka.join(__dirname,"../","hdb_boot_properties.file")),e}a(BTe,"getPropsFilePath");function HTe(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:a(function(){clearTimeout(r)},"cancel")}}a(HTe,"timeoutPromise");async function xTe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=uTe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(xTe,"isPortTaken");function kTe(e){try{return Kt.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){In.error(`Error checking operation against cluster ops ${t}`)}return!1}a(kTe,"isClusterOperation");function FTe(e,t){let r=(Pe(),oe(lt)).getDatabases();if(!r[e])return XT.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return XT.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(FTe,"checkGlobalSchemaTable");function GTe(e,t){if(ss(t)){In.warn("No CLUSTERING_USER defined, clustering disabled");return}if(ss(e)||Wi(e)){In.warn("No users to search.");return}let r;try{let n=e.get(t);n&&n.role.permission.cluster_user===!0&&n.active===!0&&(r=n)}catch(n){In.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){In.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(GTe,"getClusterUser");function qTe(){kW.parsePromise=function(e,t,r){return new Promise(function(n,s){kW.parse(e,{header:!0,transformHeader:jW,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(qTe,"promisifyPapaParse");function jW(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(jW,"removeBOM");function $Te(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;In.info(`Got cluster status event response: ${fTe(s)}`);try{i.cancel()}catch{In.error("Error trying to cancel timeout.")}n(s)})})}a($Te,"createEventPromise");async function VTe(e){let t=!0,r=0;do await $W(STe*r++),(await _Te.findPs(e)).length>0&&(t=!1);while(t&&r<TTe);if(t)throw new Error(`process ${e} was not started`)}a(VTe,"checkProcessRunning");function KTe(e,t){let r=zW(e);if(r)return r;let n=QW(e,t);if(n)return n}a(KTe,"checkSchemaTableExist");function zW(e){let{getDatabases:t}=(Pe(),oe(lt));if(!t()[e])return XT.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(zW,"checkSchemaExists");function QW(e,t){let{getDatabases:r}=(Pe(),oe(lt));if(!r()[e][t])return XT.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(QW,"checkTableExists");function YTe(){let e=JT().utc().add(1,Kt.MOMENT_DAYS_TAG).startOf(Kt.MOMENT_DAYS_TAG).unix(),t=JT().utc().unix();return e-t}a(YTe,"getStartOfTomorrowInSeconds");function WTe(){return JT().utc().format("DD-MM-YYYY")}a(WTe,"getLimitKey");function jTe(e){try{let t=new dTe(e);for(let{node:r}of t)r&&(r.columnid&&typeof r.columnid!="string"&&(r.columnid=r.columnid.toString()),r.columnid&&!r.columnid.startsWith("`")&&(r.columnid_orig=r.columnid,r.columnid=`\`${r.columnid}\``),r.tableid&&!r.tableid.startsWith("`")&&(r.tableid_orig=r.tableid,r.tableid=`\`${r.tableid}\``),r.databaseid&&!r.databaseid.startsWith("`")&&(r.databaseid_orig=r.databaseid,r.databaseid=`\`${r.databaseid}\``),r.as&&typeof r.as=="string"&&!r.as.startsWith("[")&&(r.as_orig=r.as,r.as=`\`${r.as}\``))}catch(t){In.error("Got an error back ticking items."),In.error(t)}}a(jTe,"backtickASTSchemaItems");function zTe(e){return[e]}a(zTe,"createForkArgs");function QTe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(QTe,"autoCastBoolean");function JTe(e,t){let{getDatabases:r}=(Pe(),oe(lt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(JTe,"getTableHashAttribute");function XTe(e){let{getDatabases:t}=(Pe(),oe(lt));return t()[e]!==void 0}a(XTe,"doesSchemaExist");function ZTe(e,t){let{getDatabases:r}=(Pe(),oe(lt));return r()[e]?.[t]!==void 0}a(ZTe,"doesTableExist");function ege(e){try{return JSON.stringify(e)}catch{return e}}a(ege,"stringifyObj");function tge(e){let t=JT.duration(e),r=t.seconds()>0?t.seconds()+"s":"",n=t.minutes()>0?t.minutes()+"m ":"",s=t.hours()>0?t.hours()+"h ":"",i=t.days()>0?t.days()+"d ":"";return(t.years()>0?t.years()+"y ":"")+i+s+n+r}a(tge,"ms_to_time");function rge(e,t){let r=ka.basename(e,ka.extname(e));return ka.join(ka.dirname(e),r+t)}a(rge,"changeExtension");function Mw(){if(process.env[Kt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[Kt.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=ETe(process.argv);if(e[Kt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[Kt.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(Mw,"getEnvCliRootPath");var Pw;function nge(){if(Pw)return Pw;let e=Mw();if(Mw()&&qW.pathExistsSync(ka.join(e,Kt.HDB_CONFIG_FILE)))return Pw=!0,!0}a(nge,"noBootFile");function sge(e,t){let r;return e.protocol==="http:"?r=pTe:r=hTe,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8"),o.body="",o.on("data",c=>{o.body+=c}),o.on("end",()=>{n(o)})});i.on("error",o=>{s(o)}),i.write(t instanceof Buffer?t:JSON.stringify(t)),i.end()})}a(sge,"httpRequest");function ige(e){if(!e.schema&&!e.database){e.schema=Kt.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(ige,"transformReq");function oge(e){let t=0;if(typeof e=="number"&&(t=e),typeof e=="string")switch(t=parseFloat(e),e.slice(-1)){case"M":t*=86400*30;break;case"D":case"d":t*=86400;break;case"H":case"h":t*=3600;break;case"m":t*=60;break}return t*1e3}a(oge,"convertToMS")});var ZW=N((aUe,XW)=>{"use strict";var Uw=M(),age=te(),cge=Pi(),di=W(),lge=Sm(),uge=pf(),oUe=xu(),dge=us(),_ge=Af(),fge=require("semver/functions/gte"),Ege=3e4,hge=7;XW.exports=pge;async function pge(){try{di.notify("Starting update nodes. This process will attempt to update any node connections the need to be reestablished after a 4.0.0 upgrade"),await dge.setSchemaDataToGlobalAsync();let e=await cge.getAllNodeRecords(),t=[];for(let r=0,n=e.length;r<n;r++){let s=e[r];s.system_info.hdb_version===Uw.PRE_4_0_0_VERSION&&t.push(mge(s))}await Promise.allSettled(t),di.notify("Shutting down 4.0.0 clustering upgrade process")}catch(e){throw di.error(e),e}}a(pge,"updateAllNodes");async function mge(e){try{let{name:t,subscriptions:r}=e;di.notify("Running 4.0.0 update on node:",t);let n=!1,s=0;for(;s<hge;){let i=[];if(await lge.buildNodeStatus(e,i),di.trace("Received status:",i[0].status,"from node:",t),i[0].status==="open"&&fge(i[0].system_info.hdb_version,"4.0.0")){di.notify("Received open status from node:",t,"calling add node");let o={operation:Uw.OPERATIONS_ENUM.ADD_NODE,node_name:t,subscriptions:r};await uge(o,!0),di.notify("Successfully added node",t),n=!0;break}s=(Date.now()-e.__updatedtime__)/(1e3*60*60*24),di.trace("Update node has been running for",s,"days. Calling node status again for node:",t),await age.async_set_timeout(Ege)}n||(di.error("4.0.0 node update was unable to update connection to node:",t),di.error("Removing following node record from hdb_nodes",e),await _ge({operation:Uw.OPERATIONS_ENUM.REMOVE_NODE,node_name:t}))}catch(t){throw di.error(t),t}}a(mge,"updateNode")});var Sge=ZW();(async()=>{try{await Sge()}catch(e){console.error("Error launching 4.0.0 node update"),console.error(e),process.exit(1)}})();