harperdb 4.4.16 → 4.4.17
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/bin/harperdb.js +40 -40
- package/bin/lite.js +38 -38
- package/launchServiceScripts/launchInstallNATSServer.js +1 -1
- package/launchServiceScripts/launchNatsIngestService.js +38 -38
- package/launchServiceScripts/launchNatsReplyService.js +38 -38
- package/launchServiceScripts/launchUpdateNodes4-0-0.js +38 -38
- package/npm-shrinkwrap.json +33 -39
- package/package.json +1 -1
- package/resources/Table.d.ts +2 -1
- package/resources/databases.d.ts +2 -1
- package/server/jobs/jobProcess.js +37 -37
- package/server/threads/threadServer.js +38 -38
- package/studio/build-local/asset-manifest.json +2 -2
- package/studio/build-local/index.html +1 -1
- package/studio/build-local/static/js/{main.be3fea91.js → main.510a0ad0.js} +2 -2
- package/utility/scripts/restartHdb.js +38 -38
- /package/studio/build-local/static/js/{main.be3fea91.js.LICENSE.txt → main.510a0ad0.js.LICENSE.txt} +0 -0
|
@@ -1,43 +1,43 @@
|
|
|
1
|
-
"use strict";var JW=Object.create;var Ud=Object.defineProperty;var XW=Object.getOwnPropertyDescriptor;var ZW=Object.getOwnPropertyNames;var ej=Object.getPrototypeOf,tj=Object.prototype.hasOwnProperty;var a=(e,t)=>Ud(e,"name",{value:t,configurable:!0});var Oe=(e,t)=>()=>(e&&(t=e(e=0)),t);var N=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),je=(e,t)=>{for(var r in t)Ud(e,r,{get:t[r],enumerable:!0})},Hw=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of ZW(t))!tj.call(e,s)&&s!==r&&Ud(e,s,{get:()=>t[s],enumerable:!(n=XW(t,s))||n.enumerable});return e};var L=(e,t,r)=>(r=e!=null?JW(ej(e)):{},Hw(t||!e||!e.__esModule?Ud(r,"default",{value:e,enumerable:!0}):r,e)),oe=e=>Hw(Ud({},"__esModule",{value:!0}),e);var Fw=N((Tge,kw)=>{var rj=require("fast-glob"),{statSync:ig,existsSync:og,readFileSync:nj,writeFileSync:sj}=require("fs"),{spawnSync:ij,spawn:oj,execFileSync:Sge}=require("child_process"),{isMainThread:aj}=require("worker_threads"),{join:Go,relative:xw}=require("path"),{PACKAGE_ROOT:Hs}=M(),{tmpdir:cj,platform:lj}=require("os");require("source-map-support").install();var uj=["resources","server","dataLayer","components"],vd="ts-build",ag,dj=__filename.endsWith("tsBuild.js");if(dj){if(aj){let r;try{ig(Go(Hs,vd)),r=!0}catch{}if(r)for(let n of rj.sync(uj.map(s=>s+"/**/*.ts"),{cwd:Hs})){let s=0,i=0;try{s=ig(Go(Hs,n)).mtimeMs-5e3,i=ig(Go(Hs,vd,n.replace(/.ts$/,".js"))).mtimeMs}catch{}if(s>i){console.warn(`TypeScript ${n} is not compiled`+(i?` (TS source file was modified at ${new Date(s)} and compiled file at ${new Date(i)})`:"")+", consider enabling auto-compilation of TypeScript in your IDE), compiling now."),ag=!0;break}}else console.log("TypeScript modules are not compiled, compiling now"),ag=!0;if(ag){let n=Go(Hs,"node_modules/.bin/tsc");lj()==="win32"&&(n+=".cmd");let s=ij(n,{cwd:Hs});if(s.stdout?.length&&console.log(s.stdout.toString()),s.stderr?.length&&console.log(s.stderr.toString()),r){let i=Go(cj(),"harperdb-tsc.pid"),o;if(og(i))try{process.kill(+nj(i,{encoding:"utf8"}),0),o=!0}catch{}if(!o){console.log("starting tsc background process");let c=oj(n,["--watch"],{cwd:Hs,detached:!0,stdio:"ignore"});sj(i,c.pid.toString()),c.unref()}}}}let e=kw.constructor,t=e._findPath;e._findPath=function(r,n,s){if(r.startsWith(".")&&!s&&n.length===1&&n[0].startsWith(Hs)&&!n[0].includes("node_modules")){let i=xw(Hs,n[0]),o;i.startsWith(vd)?o=Go(Hs,xw(vd,i)):o=Go(Hs,vd,i);let c=Go(o,r),l=c+".js";if(og(l))return l;if(c.includes(".")&&og(c))return c}return t(r,n,s)}}});var M=N((Age,eC)=>{"use strict";var is=require("path"),_j=require("fs"),{relative:gge,join:Rge}=is,{existsSync:fj}=_j;function Ej(){let e=__dirname;for(;!fj(is.join(e,"package.json"));){let t=is.dirname(e);if(t===e)throw new Error("Could not find package root");e=t}return e}a(Ej,"getHDBPackageRoot");var qo=Ej(),Gw="js",eh=Gw,hj="harperdb-config.yaml",pj="defaultConfig.yaml",mj="hdb",qw=`harperdb.${eh}`,$w=`customFunctionsServer.${eh}`,Sj=`restartHdb.${eh}`,lg="HarperDB",ZE="Custom Functions",th="Clustering Hub",rh="Clustering Leaf",Tj="Clustering Ingest Service",gj="Clustering Reply Service",Rj="foreground.pid",Aj="hdb.pid",yj="data",bj={HDB:lg,CLUSTERING_HUB:th,CLUSTERING_LEAF:rh,CLUSTERING_INGEST_SERVICE:Tj,CLUSTERING_REPLY_SERVICE:gj,CUSTOM_FUNCTIONS:ZE,RESTART_HDB:"Restart HDB",INSTALL:"Install",RUN:"Run",STOP:"Stop",UPGRADE:"Upgrade",REGISTER:"Register",JOB:"Job",CLUSTERING_UPGRADE_4_0_0:"Upgrade-4-0-0"},Oj={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},Nj={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},Ij={harperdb:lg,"clustering hub":th,"clustering leaf":rh,"custom functions":ZE,custom_functions:ZE,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers",http:"http"},wj={CLUSTERING_HUB_PROC_DESCRIPTOR:th,CLUSTERING_LEAF_PROC_DESCRIPTOR:rh},cg={HDB:is.join(qo,"server/harperdb"),CUSTOM_FUNCTIONS:is.join(qo,"server/customFunctions"),CLUSTERING_HUB:is.join(qo,"server/nats"),CLUSTERING_LEAF:is.join(qo,"server/nats")},Cj={HDB:is.join(cg.HDB,qw),CUSTOM_FUNCTIONS:is.join(cg.CUSTOM_FUNCTIONS,$w)},Dj={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:is.join(qo,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:is.join(qo,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:is.join(qo,"launchServiceScripts/launchUpdateNodes4-0-0.js")},Pj={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},Vw="support@harperdb.io",Lj="customer-success@harperdb.io",Kw=1,Mj=4141,Yw="https://harperdbhelp.zendesk.com/hc/en-us/requests/new",Uj="https://www.harperdb.io/product",vj=`For support, please submit a request at ${Yw} or contact ${Vw}`,Ww=`For license support, please contact ${Lj}`,Bj="None of the specified records were found.",Hj="hash attribute not found",xj=`Your current license only supports ${Kw} role. ${Ww}`,kj="Your current license only supports 3 connections to a node.",Fj="127.0.0.1",Gj=1,qj=/^\.$/,$j=/^\.\.$/,Vj="U+002E",Kj=/\//g,Yj="U+002F",Wj=/U\+002F/g,jj=/^U\+002E$/,zj=/^U\+002EU\+002E$/,Qj="d",Jj=999999,Xj="*",Zj="--max-old-space-size=",ez="system",tz="__hdb_hash",rz=".harperdb",nz=".hdb",sz="keys",iz="hdb_boot_properties.file",oz=".updateConfig.json",az="SIGTSTP",cz=24,lz=6e4,uz=448,dz="blob",_z="database",fz="schema",Ez="transactions",hz=".count",pz="id",mz="PROCESS_NAME",jw={SETTINGS_PATH_KEY:"settings_path"},zw=require("lodash"),Sz={TC_AGREEMENT:"TC_AGREEMENT",CLUSTERING_USER:"CLUSTERING_USER",CLUSTERING_PASSWORD:"CLUSTERING_PASSWORD",HDB_ADMIN_USERNAME:"HDB_ADMIN_USERNAME",HDB_ADMIN_PASSWORD:"HDB_ADMIN_PASSWORD",OPERATIONSAPI_ROOT:"OPERATIONSAPI_ROOT",ROOTPATH:"ROOTPATH",CLUSTERING_NODENAME:"CLUSTERING_NODENAME",CLUSTERING_ENABLED:"CLUSTERING_ENABLED",HDB_CONFIG:"HDB_CONFIG",DEFAULTS_MODE:"DEFAULTS_MODE",REPLICATION_HOSTNAME:"REPLICATION_HOSTNAME",CLUSTERING_PORT:"CLUSTERING_PORT",HDB_ROOT:"HDB_ROOT",SERVER_PORT:"SERVER_PORT",NODE_NAME:"NODE_NAME",CLUSTERING:"CLUSTERING"},Tz={HDB_PATH_KEY:"HDB_INTERNAL_PATH",HDB_AUTH_HEADER:"hdb_auth_header",HDB_USER_DATA_KEY:"hdb_user",CHUNK_SIZE:1e3,MAX_CHARACTER_SIZE:250},gz={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},Rz={JOB_TABLE_NAME:"hdb_job",NODE_TABLE_NAME:"hdb_nodes",ATTRIBUTE_TABLE_NAME:"hdb_attribute",LICENSE_TABLE_NAME:"hdb_license",ROLE_TABLE_NAME:"hdb_role",SCHEMA_TABLE_NAME:"hdb_schema",TABLE_TABLE_NAME:"hdb_table",USER_TABLE_NAME:"hdb_user",INFO_TABLE_NAME:"hdb_info"},Az={JOB_TABLE_HASH_ATTRIBUTE:"id",NODE_TABLE_HASH_ATTRIBUTE:"name",ATTRIBUTE_TABLE_HASH_ATTRIBUTE:"id",LICENSE_TABLE_HASH_ATTRIBUTE:"license_key",ROLE_TABLE_HASH_ATTRIBUTE:"id",SCHEMA_TABLE_HASH_ATTRIBUTE:"name",TABLE_TABLE_HASH_ATTRIBUTE:"id",USER_TABLE_HASH_ATTRIBUTE:"username",INFO_TABLE_ATTRIBUTE:"info_id"},Cn="hdb_internal:",yz={CREATE_SCHEMA:Cn+"create_schema",CREATE_TABLE:Cn+"create_table",CREATE_ATTRIBUTE:Cn+"create_attribute",ADD_USER:Cn+"add_user",ALTER_USER:Cn+"alter_user",DROP_USER:Cn+"drop_user",HDB_NODES:Cn+"hdb_nodes",HDB_USERS:Cn+"hdb_users",HDB_WORKERS:Cn+"hdb_workers",CATCHUP:Cn+"catchup",SCHEMA_CATCHUP:Cn+"schema_catchup",WORKER_ROOM:Cn+"cluster_workers"},bz={ATTR_ATTRIBUTE_KEY:"attribute",ATTR_CREATEDDATE_KEY:"createddate",ATTR_HASH_ATTRIBUTE_KEY:"hash_attribute",ATTR_ID_KEY:"id",ATTR_NAME_KEY:"name",ATTR_PASSWORD_KEY:"password",ATTR_RESIDENCE_KEY:"residence",ATTR_ROLE_KEY:"role",ATTR_SCHEMA_KEY:"schema",ATTR_SCHEMA_TABLE_KEY:"schema_table",ATTR_TABLE_KEY:"table",ATTR_USERNAME_KEY:"username"},Oz="060493.ks",Nz=".license",Iz={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},le={INSERT:"insert",UPDATE:"update",UPSERT:"upsert",SEARCH_BY_CONDITIONS:"search_by_conditions",SEARCH_BY_HASH:"search_by_hash",SEARCH_BY_ID:"search_by_id",SEARCH_BY_VALUE:"search_by_value",SEARCH:"search",SQL:"sql",CSV_DATA_LOAD:"csv_data_load",CSV_FILE_LOAD:"csv_file_load",CSV_URL_LOAD:"csv_url_load",CREATE_SCHEMA:"create_schema",CREATE_DATABASE:"create_database",CREATE_TABLE:"create_table",CREATE_ATTRIBUTE:"create_attribute",DROP_SCHEMA:"drop_schema",DROP_DATABASE:"drop_database",DROP_TABLE:"drop_table",DESCRIBE_SCHEMA:"describe_schema",DESCRIBE_DATABASE:"describe_database",DESCRIBE_TABLE:"describe_table",DESCRIBE_ALL:"describe_all",DELETE:"delete",ADD_USER:"add_user",ALTER_USER:"alter_user",DROP_USER:"drop_user",LIST_USERS:"list_users",LIST_ROLES:"list_roles",ADD_ROLE:"add_role",ALTER_ROLE:"alter_role",DROP_ROLE:"drop_role",USER_INFO:"user_info",READ_LOG:"read_log",ADD_NODE:"add_node",UPDATE_NODE:"update_node",SET_NODE_REPLICATION:"set_node_replication",EXPORT_TO_S3:"export_to_s3",IMPORT_FROM_S3:"import_from_s3",DELETE_FILES_BEFORE:"delete_files_before",DELETE_RECORDS_BEFORE:"delete_records_before",EXPORT_LOCAL:"export_local",SEARCH_JOBS_BY_START_DATE:"search_jobs_by_start_date",GET_JOB:"get_job",DELETE_JOB:"delete_job",UPDATE_JOB:"update_job",GET_FINGERPRINT:"get_fingerprint",SET_LICENSE:"set_license",GET_REGISTRATION_INFO:"registration_info",CONFIGURE_CLUSTER:"configure_cluster",SET_CONFIGURATION:"set_configuration",CLUSTER_STATUS:"cluster_status",CLUSTER_NETWORK:"cluster_network",DROP_ATTRIBUTE:"drop_attribute",REMOVE_NODE:"remove_node",RESTART:"restart",RESTART_SERVICE:"restart_service",CATCHUP:"catchup",SYSTEM_INFORMATION:"system_information",DELETE_AUDIT_LOGS_BEFORE:"delete_audit_logs_before",READ_AUDIT_LOG:"read_audit_log",CREATE_AUTHENTICATION_TOKENS:"create_authentication_tokens",LOGIN:"login",LOGOUT:"logout",REFRESH_OPERATION_TOKEN:"refresh_operation_token",GET_CONFIGURATION:"get_configuration",CUSTOM_FUNCTIONS_STATUS:"custom_functions_status",GET_CUSTOM_FUNCTIONS:"get_custom_functions",GET_CUSTOM_FUNCTION:"get_custom_function",SET_CUSTOM_FUNCTION:"set_custom_function",GET_COMPONENTS:"get_components",GET_COMPONENT_FILE:"get_component_file",SET_COMPONENT_FILE:"set_component_file",DROP_COMPONENT:"drop_component",DROP_CUSTOM_FUNCTION:"drop_custom_function",ADD_CUSTOM_FUNCTION_PROJECT:"add_custom_function_project",ADD_COMPONENT:"add_component",DROP_CUSTOM_FUNCTION_PROJECT:"drop_custom_function_project",PACKAGE_CUSTOM_FUNCTION_PROJECT:"package_custom_function_project",DEPLOY_CUSTOM_FUNCTION_PROJECT:"deploy_custom_function_project",PACKAGE_COMPONENT:"package_component",DEPLOY_COMPONENT:"deploy_component",CLUSTER_SET_ROUTES:"cluster_set_routes",CLUSTER_DELETE_ROUTES:"cluster_delete_routes",CLUSTER_GET_ROUTES:"cluster_get_routes",READ_TRANSACTION_LOG:"read_transaction_log",DELETE_TRANSACTION_LOGS_BEFORE:"delete_transaction_logs_before",INSTALL_NODE_MODULES:"install_node_modules",AUDIT_NODE_MODULES:"audit_node_modules",PURGE_STREAM:"purge_stream",GET_BACKUP:"get_backup",SIGN_CERTIFICATE:"sign_certificate",CREATE_CSR:"create_csr",LIST_CERTIFICATES:"list_certificates",ADD_CERTIFICATES:"add_certificate",REMOVE_CERTIFICATE:"remove_certificate",ADD_NODE_BACK:"add_node_back",REMOVE_NODE_BACK:"remove_node_back",ADD_SSH_KEY:"add_ssh_key",UPDATE_SSH_KEY:"update_ssh_key",DELETE_SSH_KEY:"delete_ssh_key",LIST_SSH_KEYS:"list_ssh_keys",SET_SSH_KNOWN_HOSTS:"set_ssh_known_hosts",GET_SSH_KNOWN_HOSTS:"get_ssh_known_hosts",GET_KEY:"get_key"},wz={CSV:".csv",JSON:".json"},Cz={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},Dz={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},Bd={};Bd[le.INSERT]=le.INSERT;Bd[le.UPDATE]=le.UPDATE;Bd[le.UPSERT]=le.UPSERT;Bd[le.DELETE]=le.DELETE;var nt=Object.create(null);nt[le.DESCRIBE_ALL]=le.DESCRIBE_ALL;nt[le.DESCRIBE_TABLE]=le.DESCRIBE_TABLE;nt[le.DESCRIBE_SCHEMA]=le.DESCRIBE_SCHEMA;nt[le.READ_LOG]=le.READ_LOG;nt[le.ADD_NODE]=le.ADD_NODE;nt[le.LIST_USERS]=le.LIST_USERS;nt[le.LIST_ROLES]=le.LIST_ROLES;nt[le.USER_INFO]=le.USER_INFO;nt[le.SQL]=le.SQL;nt[le.GET_JOB]=le.GET_JOB;nt[le.SEARCH_JOBS_BY_START_DATE]=le.SEARCH_JOBS_BY_START_DATE;nt[le.DELETE_FILES_BEFORE]=le.DELETE_FILES_BEFORE;nt[le.EXPORT_LOCAL]=le.EXPORT_LOCAL;nt[le.EXPORT_TO_S3]=le.EXPORT_TO_S3;nt[le.CLUSTER_STATUS]=le.CLUSTER_STATUS;nt[le.REMOVE_NODE]=le.REMOVE_NODE;nt[le.RESTART]=le.RESTART;nt[le.CUSTOM_FUNCTIONS_STATUS]=le.CUSTOM_FUNCTIONS_STATUS;nt[le.GET_CUSTOM_FUNCTIONS]=le.GET_CUSTOM_FUNCTIONS;nt[le.GET_CUSTOM_FUNCTION]=le.GET_CUSTOM_FUNCTION;nt[le.SET_CUSTOM_FUNCTION]=le.SET_CUSTOM_FUNCTION;nt[le.DROP_CUSTOM_FUNCTION]=le.DROP_CUSTOM_FUNCTION;nt[le.ADD_CUSTOM_FUNCTION_PROJECT]=le.ADD_CUSTOM_FUNCTION_PROJECT;nt[le.DROP_CUSTOM_FUNCTION_PROJECT]=le.DROP_CUSTOM_FUNCTION_PROJECT;nt[le.PACKAGE_CUSTOM_FUNCTION_PROJECT]=le.PACKAGE_CUSTOM_FUNCTION_PROJECT;nt[le.DEPLOY_CUSTOM_FUNCTION_PROJECT]=le.DEPLOY_CUSTOM_FUNCTION_PROJECT;nt[le.ADD_SSH_KEY]=le.ADD_SSH_KEY;nt[le.UPDATE_SSH_KEY]=le.UPDATE_SSH_KEY;nt[le.DELETE_SSH_KEY]=le.DELETE_SSH_KEY;var Pz={DEV:"dev",RUN:"run",START:"start",INSTALL:"install",REGISTER:"register",STOP:"stop",RESTART:"restart",VERSION:"version",UPGRADE:"upgrade",HELP:"help",STATUS:"status",OPERATION:"operation",RENEWCERTS:"renew-certs",COPYDB:"copy-db"},Lz={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},Qw={HDB_ROOT_KEY:"HDB_ROOT",SERVER_PORT_KEY:"SERVER_PORT",CERT_KEY:"CERTIFICATE",PRIVATE_KEY_KEY:"PRIVATE_KEY",HTTP_SECURE_ENABLED_KEY:"HTTPS_ON",CORS_ENABLED_KEY:"CORS_ON",CORS_WHITELIST_KEY:"CORS_WHITELIST",LOG_LEVEL_KEY:"LOG_LEVEL",LOGGER_KEY:"LOGGER",LOG_PATH_KEY:"LOG_PATH",LOG_ROTATE:"LOG_ROTATE",LOG_ROTATE_MAX_SIZE:"LOG_ROTATE_MAX_SIZE",LOG_ROTATE_RETAIN:"LOG_ROTATE_RETAIN",LOG_ROTATE_COMPRESS:"LOG_ROTATE_COMPRESS",LOG_ROTATE_DATE_FORMAT:"LOG_ROTATE_DATE_FORMAT",LOG_ROTATE_ROTATE_MODULE:"LOG_ROTATE_ROTATE_MODULE",LOG_ROTATE_WORKER_INTERVAL:"LOG_ROTATE_WORKER_INTERVAL",LOG_ROTATE_ROTATE_INTERVAL:"LOG_ROTATE_ROTATE_INTERVAL",LOG_ROTATE_TIMEZONE:"LOG_ROTATE_TIMEZONE",LOG_DAILY_ROTATE_KEY:"LOG_DAILY_ROTATE",LOG_MAX_DAILY_FILES_KEY:"LOG_MAX_DAILY_FILES",PROPS_ENV_KEY:"NODE_ENV",SETTINGS_PATH_KEY:"settings_path",CLUSTERING_PORT_KEY:"CLUSTERING_PORT",CLUSTERING_NODE_NAME_KEY:"NODE_NAME",CLUSTERING_ENABLED_KEY:"CLUSTERING",ALLOW_SELF_SIGNED_SSL_CERTS:"ALLOW_SELF_SIGNED_SSL_CERTS",MAX_HDB_PROCESSES:"MAX_HDB_PROCESSES",INSTALL_USER:"install_user",CLUSTERING_USER_KEY:"CLUSTERING_USER",MAX_CLUSTERING_PROCESSES:"MAX_CLUSTERING_PROCESSES",SERVER_TIMEOUT_KEY:"SERVER_TIMEOUT_MS",SERVER_KEEP_ALIVE_TIMEOUT_KEY:"SERVER_KEEP_ALIVE_TIMEOUT",SERVER_HEADERS_TIMEOUT_KEY:"SERVER_HEADERS_TIMEOUT",DISABLE_TRANSACTION_LOG_KEY:"DISABLE_TRANSACTION_LOG",OPERATION_TOKEN_TIMEOUT_KEY:"OPERATION_TOKEN_TIMEOUT",REFRESH_TOKEN_TIMEOUT_KEY:"REFRESH_TOKEN_TIMEOUT",CUSTOM_FUNCTIONS_ENABLED_KEY:"CUSTOM_FUNCTIONS",CUSTOM_FUNCTIONS_PORT_KEY:"CUSTOM_FUNCTIONS_PORT",CUSTOM_FUNCTIONS_DIRECTORY_KEY:"CUSTOM_FUNCTIONS_DIRECTORY",MAX_CUSTOM_FUNCTION_PROCESSES:"MAX_CUSTOM_FUNCTION_PROCESSES",LOG_TO_FILE:"LOG_TO_FILE",LOG_TO_STDSTREAMS:"LOG_TO_STDSTREAMS",RUN_IN_FOREGROUND:"RUN_IN_FOREGROUND",LOCAL_STUDIO_ON:"LOCAL_STUDIO_ON",STORAGE_WRITE_ASYNC:"STORAGE_WRITE_ASYNC"},Mz=zw.invert(Qw),Uz={CUSTOMFUNCTIONS_ENABLED:"customFunctions_enabled",CUSTOMFUNCTIONS_NETWORK_PORT:"customFunctions_network_port",CUSTOMFUNCTIONS_TLS_CERTIFICATE:"customFunctions_tls_certificate",CUSTOMFUNCTIONS_NETWORK_CORS:"customFunctions_network_cors",CUSTOMFUNCTIONS_NETWORK_CORSACCESSLIST:"customFunctions_network_corsAccessList",CUSTOMFUNCTIONS_NETWORK_HEADERSTIMEOUT:"customFunctions_network_headersTimeout",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",CUSTOMFUNCTIONS_NETWORK_KEEPALIVETIMEOUT:"customFunctions_network_keepAliveTimeout",CUSTOMFUNCTIONS_TLS_PRIVATEKEY:"customFunctions_tls_privateKey",CUSTOMFUNCTIONS_TLS_CERT_AUTH:"customFunctions_tls_certificateAuthority",CUSTOMFUNCTIONS_NETWORK_TIMEOUT:"customFunctions_network_timeout",CUSTOMFUNCTIONS_NODEENV:"customFunctions_nodeEnv",CUSTOMFUNCTIONS_ROOT:"customFunctions_root"},P={ANALYTICS_AGGREGATEPERIOD:"analytics_aggregatePeriod",AUTHENTICATION_AUTHORIZELOCAL:"authentication_authorizeLocal",AUTHENTICATION_CACHETTL:"authentication_cacheTTL",AUTHENTICATION_ENABLESESSIONS:"authentication_enableSessions",AUTHENTICATION_OPERATIONTOKENTIMEOUT:"authentication_operationTokenTimeout",AUTHENTICATION_REFRESHTOKENTIMEOUT:"authentication_refreshTokenTimeout",CLUSTERING_USER:"clustering_user",CLUSTERING_ENABLED:"clustering_enabled",CLUSTERING_HUBSERVER_CLUSTER_NAME:"clustering_hubServer_cluster_name",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT:"clustering_hubServer_cluster_network_port",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES:"clustering_hubServer_cluster_network_routes",CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT:"clustering_hubServer_leafNodes_network_port",CLUSTERING_HUBSERVER_NETWORK_PORT:"clustering_hubServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_PORT:"clustering_leafServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_ROUTES:"clustering_leafServer_network_routes",CLUSTERING_LEAFSERVER_STREAMS_MAXAGE:"clustering_leafServer_streams_maxAge",CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES:"clustering_leafServer_streams_maxBytes",CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS:"clustering_leafServer_streams_maxMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS:"clustering_leafServer_streams_maxConsumeMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS:"clustering_leafServer_streams_maxIngestThreads",CLUSTERING_LEAFSERVER_STREAMS_PATH:"clustering_leafServer_streams_path",CLUSTERING_NODENAME:"clustering_nodeName",CLUSTERING_TLS_CERTIFICATE:"clustering_tls_certificate",CLUSTERING_TLS_PRIVATEKEY:"clustering_tls_privateKey",CLUSTERING_TLS_CERT_AUTH:"clustering_tls_certificateAuthority",CLUSTERING_TLS_INSECURE:"clustering_tls_insecure",CLUSTERING_TLS_VERIFY:"clustering_tls_verify",CLUSTERING_LOGLEVEL:"clustering_logLevel",CLUSTERING_REPUBLISHMESSAGES:"clustering_republishMessages",CLUSTERING_DATABASELEVEL:"clustering_databaseLevel",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",THREADS:"threads",THREADS_COUNT:"threads_count",THREADS_DEBUG:"threads_debug",THREADS_DEBUG_STARTINGPORT:"threads_debug_startingPort",THREADS_DEBUG_PORT:"threads_debug_port",THREADS_DEBUG_HOST:"threads_debug_host",THREADS_DEBUG_WAITFORDEBUGGER:"threads_debug_waitForDebugger",THREADS_MAXHEAPMEMORY:"threads_maxHeapMemory",HTTP_SESSIONAFFINITY:"http_sessionAffinity",HTTP_COMPRESSIONTHRESHOLD:"http_compressionThreshold",HTTP_CORS:"http_cors",HTTP_CORSACCESSLIST:"http_corsAccessList",HTTP_HEADERSTIMEOUT:"http_headersTimeout",HTTP_KEEPALIVETIMEOUT:"http_keepAliveTimeout",HTTP_MAXPARAMLENGTH:"http_maxParamLength",HTTP_TIMEOUT:"http_timeout",HTTP_PORT:"http_port",HTTP_SECUREPORT:"http_securePort",HTTP_MTLS:"http_mtls",HTTP_MTLS_REQUIRED:"http_mtls_required",HTTP_MTLS_USER:"http_mtls_user",HTTP_MAXHEADERSIZE:"http_maxHeaderSize",HTTP_THREADRANGE:"http_threadRange",LOCALSTUDIO_ENABLED:"localStudio_enabled",LOGGING_CONSOLE:"logging_console",LOGGING_FILE:"logging_file",LOGGING_LEVEL:"logging_level",LOGGING_ROOT:"logging_root",LOGGING_ROTATION_ENABLED:"logging_rotation_enabled",LOGGING_ROTATION_COMPRESS:"logging_rotation_compress",LOGGING_ROTATION_INTERVAL:"logging_rotation_interval",LOGGING_ROTATION_MAXSIZE:"logging_rotation_maxSize",LOGGING_ROTATION_PATH:"logging_rotation_path",LOGGING_STDSTREAMS:"logging_stdStreams",LOGGING_AUDITLOG:"logging_auditLog",LOGGING_AUDITRETENTION:"logging_auditRetention",LOGGING_AUDITAUTHEVENTS_LOGFAILED:"logging_auditAuthEvents_logFailed",LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL:"logging_auditAuthEvents_logSuccessful",OPERATIONSAPI_NETWORK_CORS:"operationsApi_network_cors",OPERATIONSAPI_NETWORK_CORSACCESSLIST:"operationsApi_network_corsAccessList",OPERATIONSAPI_NETWORK_HEADERSTIMEOUT:"operationsApi_network_headersTimeout",OPERATIONSAPI_NETWORK_HTTPS:"operationsApi_network_https",OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT:"operationsApi_network_keepAliveTimeout",OPERATIONSAPI_NETWORK_PORT:"operationsApi_network_port",OPERATIONSAPI_NETWORK_DOMAINSOCKET:"operationsApi_network_domainSocket",OPERATIONSAPI_NETWORK_SECUREPORT:"operationsApi_network_securePort",OPERATIONSAPI_TLS:"operationsApi_tls",OPERATIONSAPI_TLS_CERTIFICATE:"operationsApi_tls_certificate",OPERATIONSAPI_TLS_PRIVATEKEY:"operationsApi_tls_privateKey",OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY:"operationsApi_tls_certificateAuthority",OPERATIONSAPI_NETWORK_TIMEOUT:"operationsApi_network_timeout",OPERATIONSAPI_SYSINFO_NETWORK:"operationsApi_sysInfo_network",OPERATIONSAPI_SYSINFO_DISK:"operationsApi_sysInfo_disk",REPLICATION:"replication",REPLICATION_HOSTNAME:"replication_hostname",REPLICATION_URL:"replication_url",REPLICATION_PORT:"replication_port",REPLICATION_SECUREPORT:"replication_securePort",REPLICATION_ROUTES:"replication_routes",REPLICATION_DATABASES:"replication_databases",REPLICATION_ENABLEROOTCAS:"replication_enableRootCAs",ROOTPATH:"rootPath",SERIALIZATION_BIGINT:"serialization_bigInt",STORAGE_WRITEASYNC:"storage_writeAsync",STORAGE_OVERLAPPINGSYNC:"storage_overlappingSync",STORAGE_CACHING:"storage_caching",STORAGE_COMPRESSION:"storage_compression",STORAGE_NOREADAHEAD:"storage_noReadAhead",STORAGE_PREFETCHWRITES:"storage_prefetchWrites",STORAGE_ENCRYPTION:"storage_encryption",STORAGE_MAXTRANSACTIONQUEUETIME:"storage_maxTransactionQueueTime",STORAGE_PATH:"storage_path",STORAGE_AUDIT_PATH:"storage_audit_path",STORAGE_MAXFREESPACETOLOAD:"storage_maxFreeSpaceToLoad",STORAGE_MAXFREESPACETORETAIN:"storage_maxFreeSpaceToRetain",STORAGE_PAGESIZE:"storage_pageSize",STORAGE_COMPRESSION_DICTIONARY:"storage_compression_dictionary",STORAGE_COMPRESSION_THRESHOLD:"storage_compression_threshold",STORAGE_COMPACTONSTART:"storage_compactOnStart",STORAGE_COMPACTONSTARTKEEPBACKUP:"storage_compactOnStartKeepBackup",DATABASES:"databases",IGNORE_SCRIPTS:"ignoreScripts",MQTT_NETWORK_PORT:"mqtt_network_port",MQTT_WEBSOCKET:"mqtt_webSocket",MQTT_NETWORK_SECUREPORT:"mqtt_network_securePort",MQTT_NETWORK_MTLS:"mqtt_network_mtls",MQTT_NETWORK_MTLS_REQUIRED:"mqtt_network_mtls_required",MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY:"mqtt_network_mtls_certificateAuthority",MQTT_NETWORK_MTLS_USER:"mqtt_network_mtls_user",MQTT_REQUIREAUTHENTICATION:"mqtt_requireAuthentication",COMPONENTSROOT:"componentsRoot",TLS_CERTIFICATE:"tls_certificate",TLS_PRIVATEKEY:"tls_privateKey",TLS_CERTIFICATEAUTHORITY:"tls_certificateAuthority",TLS_CIPHERS:"tls_ciphers",TLS:"tls",CLONED:"cloned"},Jw={settings_path:jw.SETTINGS_PATH_KEY,hdb_root_key:P.ROOTPATH,hdb_root:P.ROOTPATH,rootpath:P.ROOTPATH,server_port_key:P.OPERATIONSAPI_NETWORK_PORT,server_port:P.OPERATIONSAPI_NETWORK_PORT,cert_key:P.TLS_CERTIFICATE,certificate:P.TLS_CERTIFICATE,private_key_key:P.TLS_PRIVATEKEY,private_key:P.TLS_PRIVATEKEY,http_secure_enabled_key:P.OPERATIONSAPI_NETWORK_HTTPS,https_on:P.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:P.OPERATIONSAPI_NETWORK_CORS,cors_on:P.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:P.LOGGING_LEVEL,log_level:P.LOGGING_LEVEL,log_path_key:P.LOGGING_ROOT,log_path:P.LOGGING_ROOT,clustering_node_name_key:P.CLUSTERING_NODENAME,node_name:P.CLUSTERING_NODENAME,clustering_enabled_key:P.CLUSTERING_ENABLED,clustering:P.CLUSTERING_ENABLED,max_http_threads:P.THREADS_COUNT,max_hdb_processes:P.THREADS_COUNT,server_timeout_key:P.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:P.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:P.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:P.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:P.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:P.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:P.LOGGING_AUDITLOG,disable_transaction_log:P.LOGGING_AUDITLOG,operation_token_timeout_key:P.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:P.AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:P.AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:P.AUTHENTICATION_REFRESHTOKENTIMEOUT,custom_functions_port_key:P.HTTP_PORT,custom_functions_port:P.HTTP_PORT,custom_functions_directory_key:P.COMPONENTSROOT,custom_functions_directory:P.COMPONENTSROOT,max_custom_function_processes:P.THREADS_COUNT,logging_console:P.LOGGING_CONSOLE,log_to_file:P.LOGGING_FILE,log_to_stdstreams:P.LOGGING_STDSTREAMS,local_studio_on:P.LOCALSTUDIO_ENABLED,clustering_port:P.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:P.CLUSTERING_USER,clustering_enabled:P.CLUSTERING_ENABLED,clustering_hubserver_cluster_name:P.CLUSTERING_HUBSERVER_CLUSTER_NAME,clustering_hubserver_cluster_network_port:P.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_hubserver_cluster_network_routes:P.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,clustering_hubserver_leafnodes_network_port:P.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT,clustering_hubserver_network_port:P.CLUSTERING_HUBSERVER_NETWORK_PORT,clustering_leafserver_network_port:P.CLUSTERING_LEAFSERVER_NETWORK_PORT,clustering_leafserver_network_routes:P.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,clustering_leafserver_streams_maxage:P.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE,clustering_leafserver_streams_maxbytes:P.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES,clustering_leafserver_streams_maxconsumemsgs:P.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS,clustering_leafserver_streams_maxingestthreads:P.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS,clustering_leafserver_streams_maxmsgs:P.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS,clustering_leafserver_streams_path:P.CLUSTERING_LEAFSERVER_STREAMS_PATH,clustering_nodename:P.CLUSTERING_NODENAME,clustering_tls_certificate:P.CLUSTERING_TLS_CERTIFICATE,clustering_tls_privatekey:P.CLUSTERING_TLS_PRIVATEKEY,clustering_tls_certificateauthority:P.CLUSTERING_TLS_CERT_AUTH,clustering_tls_insecure:P.CLUSTERING_TLS_INSECURE,clustering_tls_verify:P.CLUSTERING_TLS_VERIFY,clustering_loglevel:P.CLUSTERING_LOGLEVEL,clustering_republishmessages:P.CLUSTERING_REPUBLISHMESSAGES,clustering_databaselevel:P.CLUSTERING_DATABASELEVEL,customfunctions_network_port:P.HTTP_PORT,customfunctions_tls_certificate:P.TLS_CERTIFICATE,customfunctions_network_cors:P.HTTP_CORS,customfunctions_network_corsaccesslist:P.HTTP_CORSACCESSLIST,customfunctions_network_headerstimeout:P.HTTP_HEADERSTIMEOUT,customfunctions_network_https:P.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:P.HTTP_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:P.TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:P.TLS_CERTIFICATEAUTHORITY,customfunctions_network_timeout:P.HTTP_TIMEOUT,customfunctions_tls:P.TLS,http_threads:P.THREADS_COUNT,threads:P.THREADS_COUNT,threads_count:P.THREADS_COUNT,threads_debug:P.THREADS_DEBUG,threads_debug_startingport:P.THREADS_DEBUG_STARTINGPORT,threads_debug_port:P.THREADS_DEBUG_PORT,threads_debug_host:P.THREADS_DEBUG_HOST,threads_debug_waitfordebugger:P.THREADS_DEBUG_WAITFORDEBUGGER,threads_maxheapmemory:P.THREADS_MAXHEAPMEMORY,http_session_affinity:P.HTTP_SESSIONAFFINITY,http_compressionthreshold:P.HTTP_COMPRESSIONTHRESHOLD,http_cors:P.HTTP_CORS,http_corsaccesslist:P.HTTP_CORSACCESSLIST,http_headerstimeout:P.HTTP_HEADERSTIMEOUT,http_keepalivetimeout:P.HTTP_KEEPALIVETIMEOUT,http_maxparamlength:P.HTTP_MAXPARAMLENGTH,http_timeout:P.HTTP_TIMEOUT,http_port:P.HTTP_PORT,http_secureport:P.HTTP_SECUREPORT,http_mtls:P.HTTP_MTLS,http_mtls_user:P.HTTP_MTLS_USER,http_mtls_required:P.HTTP_MTLS_REQUIRED,http_maxheadersize:P.HTTP_MAXHEADERSIZE,http_threadrange:P.HTTP_THREADRANGE,customfunctions_processes:P.THREADS_COUNT,customfunctions_root:P.COMPONENTSROOT,localstudio_enabled:P.LOCALSTUDIO_ENABLED,logging_file:P.LOGGING_FILE,logging_level:P.LOGGING_LEVEL,logging_root:P.LOGGING_ROOT,logging_rotation_enabled:P.LOGGING_ROTATION_ENABLED,logging_rotation_compress:P.LOGGING_ROTATION_COMPRESS,logging_rotation_interval:P.LOGGING_ROTATION_INTERVAL,logging_rotation_maxsize:P.LOGGING_ROTATION_MAXSIZE,logging_rotation_path:P.LOGGING_ROTATION_PATH,logging_stdstreams:P.LOGGING_STDSTREAMS,logging_auditlog:P.LOGGING_AUDITLOG,logging_auditretention:P.LOGGING_AUDITRETENTION,logging_auditauthevents_logfailed:P.LOGGING_AUDITAUTHEVENTS_LOGFAILED,logging_auditauthevents_logsuccessful:P.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL,operationsapi_authentication_operationtokentimeout:P.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operationsapi_authentication_refreshtokentimeout:P.AUTHENTICATION_REFRESHTOKENTIMEOUT,operationsapi_network_cors:P.OPERATIONSAPI_NETWORK_CORS,operationsapi_network_corsaccesslist:P.OPERATIONSAPI_NETWORK_CORSACCESSLIST,operationsapi_network_headerstimeout:P.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,operationsapi_network_https:P.OPERATIONSAPI_NETWORK_HTTPS,operationsapi_network_keepalivetimeout:P.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,operationsapi_network_port:P.OPERATIONSAPI_NETWORK_PORT,operationsapi_network_domainsocket:P.OPERATIONSAPI_NETWORK_DOMAINSOCKET,operationsapi_network_secureport:P.OPERATIONSAPI_NETWORK_SECUREPORT,operationsapi_tls:P.OPERATIONSAPI_TLS,operationsapi_tls_certificate:P.OPERATIONSAPI_TLS_CERTIFICATE,operationsapi_tls_privatekey:P.OPERATIONSAPI_TLS_PRIVATEKEY,operationsapi_tls_certificateauthority:P.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY,operationsapi_network_timeout:P.OPERATIONSAPI_NETWORK_TIMEOUT,operationsapi_root:P.ROOTPATH,operationsapi_sysinfo_network:P.OPERATIONSAPI_SYSINFO_NETWORK,operationsapi_sysinfo_disk:P.OPERATIONSAPI_SYSINFO_DISK,databases:P.DATABASES,storage_path:P.STORAGE_PATH,storage_maxtransactionqueuetime:P.STORAGE_MAXTRANSACTIONQUEUETIME,ignorescripts:P.IGNORE_SCRIPTS,mqtt_network_port:P.MQTT_NETWORK_PORT,mqtt_websocket:P.MQTT_WEBSOCKET,mqtt_network_secureport:P.MQTT_NETWORK_SECUREPORT,mqtt_network_mtls:P.MQTT_NETWORK_MTLS,mqtt_network_mtls_certificateAuthority:P.MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY,mqtt_network_mtls_user:P.MQTT_NETWORK_MTLS_USER,mqtt_network_mtls_required:P.MQTT_NETWORK_MTLS_REQUIRED,mqtt_requireauthentication:P.MQTT_REQUIREAUTHENTICATION,analytics_aggregatePeriod:P.ANALYTICS_AGGREGATEPERIOD,authentication_authorizelocal:P.AUTHENTICATION_AUTHORIZELOCAL,authentication_cachettl:P.AUTHENTICATION_CACHETTL,authentication_enablesessions:P.AUTHENTICATION_ENABLESESSIONS,authentication_operationtokentimeout:P.AUTHENTICATION_OPERATIONTOKENTIMEOUT,authentication_refreshtokentimeout:P.AUTHENTICATION_REFRESHTOKENTIMEOUT,componentsroot:P.COMPONENTSROOT,replication:P.REPLICATION,replication_port:P.REPLICATION_PORT,replication_secureport:P.REPLICATION_SECUREPORT,replication_hostname:P.REPLICATION_HOSTNAME,replication_url:P.REPLICATION_URL,replication_routes:P.REPLICATION_ROUTES,tls:P.TLS,tls_certificate:P.TLS_CERTIFICATE,tls_privatekey:P.TLS_PRIVATEKEY,tls_certificateauthority:P.TLS_CERTIFICATEAUTHORITY,tls_ciphers:P.TLS_CIPHERS};for(let e in P){let t=P[e];Jw[t.toLowerCase()]=t}var vz={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},Bz={csv_file_load:"csv_file_load",csv_data_load:le.CSV_DATA_LOAD,csv_url_load:le.CSV_URL_LOAD,delete_files_before:"delete_files_before",delete_records_before:"delete_records_before",delete_audit_logs_before:"delete_audit_logs_before",delete_transaction_logs_before:"delete_transaction_logs_before",empty_trash:"empty_trash",export_local:"export_local",export_to_s3:"export_to_s3",import_from_s3:"import_from_s3",restart_service:"restart_service"},Hz={CLUSTERING_PAYLOAD:"clustering_payload",DELEGATE_THREAD_RESPONSE:"delegate_thread_response",CLUSTERING:"clustering",SCHEMA:"schema",CLUSTER_STATUS:"cluster_status",JOB:"job",CHILD_STARTED:"child_started",CHILD_STOPPED:"child_stopped",USER:"user",RESTART:"restart"},xz={BIDIRECTIONAL:"BIDIRECTIONAL",OUTBOUND:"OUTBOUND",INBOUND:"INBOUND"},kz={VERSION_DEFAULT:"2.2.0"},Fz={DEVELOPMENT:8192,DEFAULT:512},Gz={IDENTIFY:"identify",AUTHENTICATE:"authenticate",AUTHENTICATE_OK:"authenticated",AUTHENTICATE_FAIL:"authenticate_fail",CONNECTION:"connection",CONNECT:"connect",CATCHUP_REQUEST:"catchup_request",CATCHUP_RESPONSE:"catchup",CONFIRM_MSG:"confirm_msg",ERROR:"error",DISCONNECT:"disconnect",SCHEMA_UPDATE_REQ:"schema_update_request",SCHEMA_UPDATE_RES:"schema_update_response",RECONNECT_ATTEMPT:"reconnect_attempt",CONNECT_ERROR:"connect_error",MESSAGE:"msg",VERSION_MISMATCH:"version_mismatch",DIRECTION_CHANGE:"direction_change"},qz={1e3:"SUCCESSFUL_SHUTDOWN",1001:"CLOSE_GOING_AWAY",1002:"CLOSE_PROTOCOL_ERROR",1003:"CLOSE_UNSUPPORTED",1005:"CLOSE_NO_STATUS",1006:"CLOSE_ABNORMAL",1007:"UNSUPPORTED_PAYLOAD",1008:"POLICY_VIOLATION",1009:"CLOSE_TOO_LARGE",1010:"MANDATORY_EXTENSION",1011:"SERVER_ERROR",1012:"SERVICE_RESTART",1013:"SERVER_BUSY",1014:"BAD_GATEWAY",1015:"HANDSHAKE_FAIL",4141:"LICENSE_LIMIT_REACHED"},$z={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},Xw={CREATED_TIME:"__createdtime__",UPDATED_TIME:"__updatedtime__"},Vz=Symbol("metadata"),Kz="__clustering__",Yz=Object.values(Xw),Wz=15984864e5,Zw={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},jz=zw.invert(Zw),zz={GET_CLUSTER_STATUS:"GET_CLUSTER_STATUS",CLUSTER_STATUS_RESPONSE:"CLUSTER_STATUS_RESPONSE",ERROR_RESPONSE:"ERROR",ADD_USER:"ADD_USER",ALTER_USER:"ALTER_USER",DROP_USER:"DROP_USER",HDB_OPERATION:"HDB_OPERATION",ADD_NODE:"ADD_NODE",UPDATE_NODE:"UPDATE_NODE",REMOVE_NODE:"REMOVE_NODE",HDB_USERS_MSG:"HDB_USERS_MSG",HDB_WORKERS:"HDB_WORKERS",HDB_TRANSACTION:"HDB_TRANSACTION"},Qz=111,Jz=`\r
|
|
2
|
-
`,
|
|
3
|
-
`&&(e=e.slice(0,-1)),zi.appendFileSync(
|
|
4
|
-
`&&(e=e.slice(0,-1)),zi.appendFileSync(
|
|
1
|
+
"use strict";var XW=Object.create;var vd=Object.defineProperty;var ZW=Object.getOwnPropertyDescriptor;var ej=Object.getOwnPropertyNames;var tj=Object.getPrototypeOf,rj=Object.prototype.hasOwnProperty;var a=(e,t)=>vd(e,"name",{value:t,configurable:!0});var Ne=(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 ej(t))!rj.call(e,s)&&s!==r&&vd(e,s,{get:()=>t[s],enumerable:!(n=ZW(t,s))||n.enumerable});return e};var L=(e,t,r)=>(r=e!=null?XW(tj(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((gge,Fw)=>{var nj=require("fast-glob"),{statSync:ig,existsSync:og,readFileSync:sj,writeFileSync:ij}=require("fs"),{spawnSync:oj,spawn:aj,execFileSync:Tge}=require("child_process"),{isMainThread:cj}=require("worker_threads"),{join:Fo,relative:kw}=require("path"),{PACKAGE_ROOT:Hs}=M(),{tmpdir:lj,platform:uj}=require("os");require("source-map-support").install();var dj=["resources","server","dataLayer","components"],Bd="ts-build",ag,_j=__filename.endsWith("tsBuild.js");if(_j){if(cj){let r;try{ig(Fo(Hs,Bd)),r=!0}catch{}if(r)for(let n of nj.sync(dj.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");uj()==="win32"&&(n+=".cmd");let s=oj(n,{cwd:Hs});if(s.stdout?.length&&console.log(s.stdout.toString()),s.stderr?.length&&console.log(s.stderr.toString()),r){let i=Fo(lj(),"harperdb-tsc.pid"),o;if(og(i))try{process.kill(+sj(i,{encoding:"utf8"}),0),o=!0}catch{}if(!o){console.log("starting tsc background process");let c=aj(n,["--watch"],{cwd:Hs,detached:!0,stdio:"ignore"});ij(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((yge,tC)=>{"use strict";var is=require("path"),fj=require("fs"),{relative:Rge,join:Age}=is,{existsSync:Ej}=fj;function hj(){let e=__dirname;for(;!Ej(is.join(e,"package.json"));){let t=is.dirname(e);if(t===e)throw new Error("Could not find package root");e=t}return e}a(hj,"getHDBPackageRoot");var Go=hj(),qw="js",eh=qw,pj="harperdb-config.yaml",mj="defaultConfig.yaml",Sj="hdb",$w=`harperdb.${eh}`,Vw=`customFunctionsServer.${eh}`,Tj=`restartHdb.${eh}`,lg="HarperDB",ZE="Custom Functions",th="Clustering Hub",rh="Clustering Leaf",gj="Clustering Ingest Service",Rj="Clustering Reply Service",Aj="foreground.pid",yj="hdb.pid",bj="data",Oj={HDB:lg,CLUSTERING_HUB:th,CLUSTERING_LEAF:rh,CLUSTERING_INGEST_SERVICE:gj,CLUSTERING_REPLY_SERVICE:Rj,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"},Nj={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},Ij={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},wj={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"},Cj={CLUSTERING_HUB_PROC_DESCRIPTOR:th,CLUSTERING_LEAF_PROC_DESCRIPTOR:rh},cg={HDB:is.join(Go,"server/harperdb"),CUSTOM_FUNCTIONS:is.join(Go,"server/customFunctions"),CLUSTERING_HUB:is.join(Go,"server/nats"),CLUSTERING_LEAF:is.join(Go,"server/nats")},Dj={HDB:is.join(cg.HDB,$w),CUSTOM_FUNCTIONS:is.join(cg.CUSTOM_FUNCTIONS,Vw)},Pj={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:is.join(Go,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:is.join(Go,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:is.join(Go,"launchServiceScripts/launchUpdateNodes4-0-0.js")},Lj={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},Kw="support@harperdb.io",Mj="customer-success@harperdb.io",Yw=1,Uj=4141,Ww="https://harperdbhelp.zendesk.com/hc/en-us/requests/new",vj="https://www.harperdb.io/product",Bj=`For support, please submit a request at ${Ww} or contact ${Kw}`,jw=`For license support, please contact ${Mj}`,Hj="None of the specified records were found.",xj="hash attribute not found",kj=`Your current license only supports ${Yw} role. ${jw}`,Fj="Your current license only supports 3 connections to a node.",Gj="127.0.0.1",qj=1,$j=/^\.$/,Vj=/^\.\.$/,Kj="U+002E",Yj=/\//g,Wj="U+002F",jj=/U\+002F/g,zj=/^U\+002E$/,Qj=/^U\+002EU\+002E$/,Jj="d",Xj=999999,Zj="*",ez="--max-old-space-size=",tz="system",rz="__hdb_hash",nz=".harperdb",sz=".hdb",iz="keys",oz="hdb_boot_properties.file",az=".updateConfig.json",cz="SIGTSTP",lz=24,uz=6e4,dz=448,_z="blob",fz="database",Ez="schema",hz="transactions",pz=".count",mz="id",Sz="PROCESS_NAME",zw={SETTINGS_PATH_KEY:"settings_path"},Qw=require("lodash"),Tz={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"},gz={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},Rz={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},Az={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"},yz={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:",bz={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"},Oz={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"},Nz="060493.ks",Iz=".license",wz={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"},Cz={CSV:".csv",JSON:".json"},Dz={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},Pz={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 Lz={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"},Mz={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"},Uz=Qw.invert(Jw),vz={CUSTOMFUNCTIONS_ENABLED:"customFunctions_enabled",CUSTOMFUNCTIONS_NETWORK_PORT:"customFunctions_network_port",CUSTOMFUNCTIONS_TLS_CERTIFICATE:"customFunctions_tls_certificate",CUSTOMFUNCTIONS_NETWORK_CORS:"customFunctions_network_cors",CUSTOMFUNCTIONS_NETWORK_CORSACCESSLIST:"customFunctions_network_corsAccessList",CUSTOMFUNCTIONS_NETWORK_HEADERSTIMEOUT:"customFunctions_network_headersTimeout",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",CUSTOMFUNCTIONS_NETWORK_KEEPALIVETIMEOUT:"customFunctions_network_keepAliveTimeout",CUSTOMFUNCTIONS_TLS_PRIVATEKEY:"customFunctions_tls_privateKey",CUSTOMFUNCTIONS_TLS_CERT_AUTH:"customFunctions_tls_certificateAuthority",CUSTOMFUNCTIONS_NETWORK_TIMEOUT:"customFunctions_network_timeout",CUSTOMFUNCTIONS_NODEENV:"customFunctions_nodeEnv",CUSTOMFUNCTIONS_ROOT:"customFunctions_root"},P={ANALYTICS_AGGREGATEPERIOD:"analytics_aggregatePeriod",AUTHENTICATION_AUTHORIZELOCAL:"authentication_authorizeLocal",AUTHENTICATION_CACHETTL:"authentication_cacheTTL",AUTHENTICATION_ENABLESESSIONS:"authentication_enableSessions",AUTHENTICATION_OPERATIONTOKENTIMEOUT:"authentication_operationTokenTimeout",AUTHENTICATION_REFRESHTOKENTIMEOUT:"authentication_refreshTokenTimeout",CLUSTERING_USER:"clustering_user",CLUSTERING_ENABLED:"clustering_enabled",CLUSTERING_HUBSERVER_CLUSTER_NAME:"clustering_hubServer_cluster_name",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT:"clustering_hubServer_cluster_network_port",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES:"clustering_hubServer_cluster_network_routes",CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT:"clustering_hubServer_leafNodes_network_port",CLUSTERING_HUBSERVER_NETWORK_PORT:"clustering_hubServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_PORT:"clustering_leafServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_ROUTES:"clustering_leafServer_network_routes",CLUSTERING_LEAFSERVER_STREAMS_MAXAGE:"clustering_leafServer_streams_maxAge",CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES:"clustering_leafServer_streams_maxBytes",CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS:"clustering_leafServer_streams_maxMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS:"clustering_leafServer_streams_maxConsumeMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS:"clustering_leafServer_streams_maxIngestThreads",CLUSTERING_LEAFSERVER_STREAMS_PATH:"clustering_leafServer_streams_path",CLUSTERING_NODENAME:"clustering_nodeName",CLUSTERING_TLS_CERTIFICATE:"clustering_tls_certificate",CLUSTERING_TLS_PRIVATEKEY:"clustering_tls_privateKey",CLUSTERING_TLS_CERT_AUTH:"clustering_tls_certificateAuthority",CLUSTERING_TLS_INSECURE:"clustering_tls_insecure",CLUSTERING_TLS_VERIFY:"clustering_tls_verify",CLUSTERING_LOGLEVEL:"clustering_logLevel",CLUSTERING_REPUBLISHMESSAGES:"clustering_republishMessages",CLUSTERING_DATABASELEVEL:"clustering_databaseLevel",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",THREADS:"threads",THREADS_COUNT:"threads_count",THREADS_DEBUG:"threads_debug",THREADS_DEBUG_STARTINGPORT:"threads_debug_startingPort",THREADS_DEBUG_PORT:"threads_debug_port",THREADS_DEBUG_HOST:"threads_debug_host",THREADS_DEBUG_WAITFORDEBUGGER:"threads_debug_waitForDebugger",THREADS_MAXHEAPMEMORY:"threads_maxHeapMemory",HTTP_SESSIONAFFINITY:"http_sessionAffinity",HTTP_COMPRESSIONTHRESHOLD:"http_compressionThreshold",HTTP_CORS:"http_cors",HTTP_CORSACCESSLIST:"http_corsAccessList",HTTP_HEADERSTIMEOUT:"http_headersTimeout",HTTP_KEEPALIVETIMEOUT:"http_keepAliveTimeout",HTTP_MAXPARAMLENGTH:"http_maxParamLength",HTTP_TIMEOUT:"http_timeout",HTTP_PORT:"http_port",HTTP_SECUREPORT:"http_securePort",HTTP_MTLS:"http_mtls",HTTP_MTLS_REQUIRED:"http_mtls_required",HTTP_MTLS_USER:"http_mtls_user",HTTP_MAXHEADERSIZE:"http_maxHeaderSize",HTTP_THREADRANGE:"http_threadRange",LOCALSTUDIO_ENABLED:"localStudio_enabled",LOGGING_CONSOLE:"logging_console",LOGGING_FILE:"logging_file",LOGGING_LEVEL:"logging_level",LOGGING_ROOT:"logging_root",LOGGING_ROTATION_ENABLED:"logging_rotation_enabled",LOGGING_ROTATION_COMPRESS:"logging_rotation_compress",LOGGING_ROTATION_INTERVAL:"logging_rotation_interval",LOGGING_ROTATION_MAXSIZE:"logging_rotation_maxSize",LOGGING_ROTATION_PATH:"logging_rotation_path",LOGGING_STDSTREAMS:"logging_stdStreams",LOGGING_AUDITLOG:"logging_auditLog",LOGGING_AUDITRETENTION:"logging_auditRetention",LOGGING_AUDITAUTHEVENTS_LOGFAILED:"logging_auditAuthEvents_logFailed",LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL:"logging_auditAuthEvents_logSuccessful",OPERATIONSAPI_NETWORK_CORS:"operationsApi_network_cors",OPERATIONSAPI_NETWORK_CORSACCESSLIST:"operationsApi_network_corsAccessList",OPERATIONSAPI_NETWORK_HEADERSTIMEOUT:"operationsApi_network_headersTimeout",OPERATIONSAPI_NETWORK_HTTPS:"operationsApi_network_https",OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT:"operationsApi_network_keepAliveTimeout",OPERATIONSAPI_NETWORK_PORT:"operationsApi_network_port",OPERATIONSAPI_NETWORK_DOMAINSOCKET:"operationsApi_network_domainSocket",OPERATIONSAPI_NETWORK_SECUREPORT:"operationsApi_network_securePort",OPERATIONSAPI_TLS:"operationsApi_tls",OPERATIONSAPI_TLS_CERTIFICATE:"operationsApi_tls_certificate",OPERATIONSAPI_TLS_PRIVATEKEY:"operationsApi_tls_privateKey",OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY:"operationsApi_tls_certificateAuthority",OPERATIONSAPI_NETWORK_TIMEOUT:"operationsApi_network_timeout",OPERATIONSAPI_SYSINFO_NETWORK:"operationsApi_sysInfo_network",OPERATIONSAPI_SYSINFO_DISK:"operationsApi_sysInfo_disk",REPLICATION:"replication",REPLICATION_HOSTNAME:"replication_hostname",REPLICATION_URL:"replication_url",REPLICATION_PORT:"replication_port",REPLICATION_SECUREPORT:"replication_securePort",REPLICATION_ROUTES:"replication_routes",REPLICATION_DATABASES:"replication_databases",REPLICATION_ENABLEROOTCAS:"replication_enableRootCAs",ROOTPATH:"rootPath",SERIALIZATION_BIGINT:"serialization_bigInt",STORAGE_WRITEASYNC:"storage_writeAsync",STORAGE_OVERLAPPINGSYNC:"storage_overlappingSync",STORAGE_CACHING:"storage_caching",STORAGE_COMPRESSION:"storage_compression",STORAGE_NOREADAHEAD:"storage_noReadAhead",STORAGE_PREFETCHWRITES:"storage_prefetchWrites",STORAGE_ENCRYPTION:"storage_encryption",STORAGE_MAXTRANSACTIONQUEUETIME:"storage_maxTransactionQueueTime",STORAGE_PATH:"storage_path",STORAGE_AUDIT_PATH:"storage_audit_path",STORAGE_MAXFREESPACETOLOAD:"storage_maxFreeSpaceToLoad",STORAGE_MAXFREESPACETORETAIN:"storage_maxFreeSpaceToRetain",STORAGE_PAGESIZE:"storage_pageSize",STORAGE_COMPRESSION_DICTIONARY:"storage_compression_dictionary",STORAGE_COMPRESSION_THRESHOLD:"storage_compression_threshold",STORAGE_COMPACTONSTART:"storage_compactOnStart",STORAGE_COMPACTONSTARTKEEPBACKUP:"storage_compactOnStartKeepBackup",DATABASES:"databases",IGNORE_SCRIPTS:"ignoreScripts",MQTT_NETWORK_PORT:"mqtt_network_port",MQTT_WEBSOCKET:"mqtt_webSocket",MQTT_NETWORK_SECUREPORT:"mqtt_network_securePort",MQTT_NETWORK_MTLS:"mqtt_network_mtls",MQTT_NETWORK_MTLS_REQUIRED:"mqtt_network_mtls_required",MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY:"mqtt_network_mtls_certificateAuthority",MQTT_NETWORK_MTLS_USER:"mqtt_network_mtls_user",MQTT_REQUIREAUTHENTICATION:"mqtt_requireAuthentication",COMPONENTSROOT:"componentsRoot",TLS_CERTIFICATE:"tls_certificate",TLS_PRIVATEKEY:"tls_privateKey",TLS_CERTIFICATEAUTHORITY:"tls_certificateAuthority",TLS_CIPHERS:"tls_ciphers",TLS:"tls",CLONED:"cloned"},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,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 Bz={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},Hz={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"},xz={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"},kz={BIDIRECTIONAL:"BIDIRECTIONAL",OUTBOUND:"OUTBOUND",INBOUND:"INBOUND"},Fz={VERSION_DEFAULT:"2.2.0"},Gz={DEVELOPMENT:8192,DEFAULT:512},qz={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"},$z={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"},Vz={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},Zw={CREATED_TIME:"__createdtime__",UPDATED_TIME:"__updatedtime__"},Kz=Symbol("metadata"),Yz="__clustering__",Wz=Object.values(Zw),jz=15984864e5,eC={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},zz=Qw.invert(eC),Qz={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"},Jz=111,Xz=`\r
|
|
2
|
+
`,Zz={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},eQ=["*","%"],tQ="unauthorized_access",rQ="func_val",nQ={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},sQ={JWT_PRIVATE_KEY_NAME:".jwtPrivate.key",JWT_PUBLIC_KEY_NAME:".jwtPublic.key",JWT_PASSPHRASE_NAME:".jwtPass"},iQ={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"},oQ={HDB_CORE:"hdb_core",CUSTOM_FUNCTIONS:"custom_functions"},aQ={HTTP:"http"},cQ={STOPPED:"stopped",ONLINE:"online"},lQ="3.x.x",uQ={SUCCESS:"success",FAILURE:"failure"},dQ={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"};tC.exports={LOCAL_HARPERDB_OPERATIONS:nt,HDB_SUPPORT_ADDRESS:Kw,HDB_SUPPORT_URL:Ww,HDB_PRICING_URL:vj,SUPPORT_HELP_MSG:Bj,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:tz,HASH_FOLDER_NAME:rz,HDB_HOME_DIR_NAME:nz,UPDATE_FILE_NAME:az,LICENSE_KEY_DIR_NAME:iz,BOOT_PROPS_FILE_NAME:oz,JOB_TYPE_ENUM:Hz,JOB_STATUS_ENUM:wz,SYSTEM_TABLE_NAMES:Az,SYSTEM_TABLE_HASH_ATTRIBUTES:yz,OPERATIONS_ENUM:le,VALID_S3_FILE_TYPES:Cz,S3_BUCKET_AUTH_KEYS:Dz,VALID_SQL_OPS_ENUM:Pz,GEO_CONVERSION_ENUM:Mz,HDB_SETTINGS_NAMES:Jw,HDB_SETTINGS_NAMES_REVERSE_LOOKUP:Uz,SERVICE_ACTIONS_ENUM:Lz,CLUSTER_MESSAGE_TYPE_ENUM:xz,CLUSTER_CONNECTION_DIRECTION_ENUM:kz,CLUSTER_EVENTS_DEFS_ENUM:qz,PERIOD_REGEX:$j,DOUBLE_PERIOD_REGEX:Vj,UNICODE_PERIOD:Kj,FORWARD_SLASH_REGEX:Yj,UNICODE_FORWARD_SLASH:Wj,ESCAPED_FORWARD_SLASH_REGEX:jj,ESCAPED_PERIOD_REGEX:zj,ESCAPED_DOUBLE_PERIOD_REGEX:Qj,REG_KEY_FILE_NAME:Nz,RESTART_TIMEOUT_MS:uz,HDB_FILE_PERMISSIONS:dz,DATABASES_DIR_NAME:fz,LEGACY_DATABASES_DIR_NAME:Ez,TRANSACTIONS_DIR_NAME:hz,LIMIT_COUNT_NAME:pz,ID_ATTRIBUTE_STRING:mz,INSERT_MODULE_ENUM:gz,UPGRADE_JSON_FIELD_NAMES_ENUM:Rz,RESTART_CODE:cz,RESTART_CODE_NUM:lz,CLUSTER_OPERATIONS:Hd,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:Oz,HDB_INTERNAL_SC_CHANNEL_PREFIX:Cn,INTERNAL_SC_CHANNELS:bz,CLUSTERING_MESSAGE_TYPES:Qz,HDB_FILE_SUFFIX:sz,BLOB_FOLDER_NAME:_z,ORIGINATOR_SET_VALUE:Jz,LICENSE_VALUES:Fz,RAM_ALLOCATION_ENUM:Gz,TIME_STAMP_NAMES_ENUM:Zw,TIME_STAMP_NAMES:Wz,PERMS_UPDATE_RELEASE_TIMESTAMP:jz,SEARCH_NOT_FOUND_MESSAGE:Hj,SEARCH_ATTRIBUTE_NOT_FOUND:xj,LICENSE_ROLE_DENIED_RESPONSE:kj,LICENSE_MAX_CONNS_REACHED:Fj,BASIC_LICENSE_MAX_NON_CU_ROLES:Yw,BASIC_LICENSE_CLUSTER_CONNECTION_LIMIT_WS_ERROR_CODE:Uj,VALUE_SEARCH_COMPARATORS:eC,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:zz,LICENSE_FILE_NAME:Iz,WEBSOCKET_CLOSE_CODE_DESCRIPTION_LOOKUP:$z,NEW_LINE:Xz,BASIC_LICENSE_MAX_CLUSTER_USER_ROLES:qj,MOMENT_DAYS_TAG:Jj,API_TURNOVER_SEC:Xj,LOOPBACK:Gj,CODE_EXTENSION:eh,WILDCARD_SEARCH_VALUE:Zj,NODE_ERROR_CODES:Vz,JAVASCRIPT_EXTENSION:qw,PERMS_CRUD_ENUM:Zz,UNAUTHORIZED_PERMISSION_NAME:tQ,SEARCH_WILDCARDS:eQ,FUNC_VAL:rQ,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:nQ,JWT_ENUM:sQ,CLUSTERING_FLAG:Yz,ITC_EVENT_TYPES:iQ,CUSTOM_FUNCTION_PROC_NAME:Vw,CUSTOM_FUNCTION_PROC_DESCRIPTOR:ZE,SERVICES:oQ,THREAD_TYPES:aQ,MEM_SETTING_KEY:ez,HDB_RESTART_SCRIPT:Tj,PROCESS_DESCRIPTORS:Oj,SERVICE_SERVERS:Dj,SERVICE_SERVERS_CWD:cg,PROCESS_DESCRIPTORS_VALIDATE:wj,LAUNCH_SERVICE_SCRIPTS:Pj,LOG_LEVELS:Ij,PROCESS_NAME_ENV_PROP:Sz,LOG_NAMES:Nj,PM2_PROCESS_STATUSES:cQ,CONFIG_PARAM_MAP:Xw,CONFIG_PARAMS:P,HDB_CONFIG_FILE:pj,HDB_DEFAULT_CONFIG_FILE:mj,ROLE_TYPES_ENUM:Lj,BOOT_PROP_PARAMS:zw,INSTALL_PROMPTS:Tz,HDB_ROOT_DIR_NAME:Sj,CLUSTERING_PROCESSES:Cj,FOREGROUND_PID_FILE:Aj,PACKAGE_ROOT:Go,PRE_4_0_0_VERSION:lQ,DATABASES_PARAM_CONFIG:Bz,METADATA_PROPERTY:Kz,AUTH_AUDIT_STATUS:uQ,AUTH_AUDIT_TYPES:dQ,HDB_PID_FILE:yj,DEFAULT_DATABASE_NAME:bj,LEGACY_CONFIG_PARAMS:vz};Gw()});var Wa=N((Oge,sC)=>{"use strict";var rC=require("minimist");sC.exports=_Q;function _Q(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(_Q,"assignCMDENVVariables");function nC(e){let t,r=Object.keys(e),n=r.length,s={};for(;n--;)t=r[n],s[t.toLowerCase()]=e[t];return s}a(nC,"objKeysToLowerCase")});var fi=N(_i=>{"use strict";global.Resource=_i.Resource=void 0;global.tables=_i.tables={};global.databases=_i.databases={};global.getUser=_i.getUser=void 0;global.server=_i.server={};global.contentTypes=_i.contentTypes=null;global.threads=_i.threads=[];global.logger={};_i._assignPackageExport=(e,t)=>{global[e]=_i[e]=t}});var W=N((TC,gC)=>{"use strict";var zi=require("fs-extra"),{workerData:fQ,threadId:EQ,isMainThread:hQ}=require("worker_threads"),hi=require("path"),cC=require("yaml"),lC=require("properties-reader"),Wt=M(),iC=Wa(),pQ=require("os"),{PACKAGE_ROOT:fg}=M(),{_assignPackageExport:mQ}=fi(),oC=process.stdout.nativeWrite||(process.stdout.nativeWrite=process.stdout.write),fr={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},uC={STDOUT:"stdOut",STDERR:"stdErr"},SQ=hi.join(fg,"logs"),TQ=hi.join(fg,"config/yaml/",Wt.HDB_DEFAULT_CONFIG_FILE),gQ=1e4,ug,Ei,os,wr,nh,xd,sh,qo,kd;kd===void 0&&dC();Object.assign(TC,{notify:pC,fatal:mC,error:ih,warn:SC,info:fC,debug:hC,trace:EC,setLogLevel:wQ,log_level:wr,loggerWithTag:yQ,suppressLogging:bQ,initLogSettings:dC,logCustomLevel:NQ,closeLogFile:Eg,logsAtLevel:RQ,getLogFilePath:a(()=>sh,"getLogFilePath"),OUTPUTS:uC,AuthAuditLog:PQ});mQ("logger",gC.exports);var dg;function RQ(e){return fr[wr]<=fr[e]}a(RQ,"logsAtLevel");function dC(e=!1){try{if(kd===void 0||e){Eg();let t=IQ(),r=iC(["ROOTPATH"]);try{kd=lC(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!zi.pathExistsSync(hi.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE)))throw n}if({level:wr,config_log_path:xd,to_file:Ei,to_stream:os}=CQ(r.ROOTPATH?hi.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE):kd.get("settings_path")),nh=Wt.LOG_NAMES.HDB,sh=hi.join(xd,nh),hQ)try{require("segfault-handler").registerHandler(hi.join(xd,"crash.log"))}catch{}}}catch(t){if(kd=void 0,t.code===Wt.NODE_ERROR_CODES.ENOENT||t.code===Wt.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=iC(Object.keys(Wt.CONFIG_PARAM_MAP),!0);for(let o in r){let c=Wt.CONFIG_PARAM_MAP[o];c&&c.toLowerCase();let l=r[o];if(c===Wt.CONFIG_PARAMS.LOGGING_LEVEL){wr=l;continue}if(c===Wt.CONFIG_PARAMS.LOGGING_STDSTREAMS){os=l;continue}c===Wt.CONFIG_PARAMS.LOGGING_FILE&&(Ei=c),c===Wt.CONFIG_PARAMS.LOGGING_CONSOLE&&(ug=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=DQ();Ei=Ei===void 0?s:Ei,Ei=aC(Ei),os=os===void 0?i:os,os=aC(os),wr=wr===void 0?n:wr,xd=SQ,nh=Wt.LOG_NAMES.INSTALL,sh=hi.join(xd,nh);return}throw ih("Error initializing log settings"),ih(t),t}process.env.DEV_MODE&&(os=!0),AQ()}a(dC,"initLogSettings");var $o=!0;function AQ(){Ei&&(process.stdout.write=function(e){return typeof e=="string"&&$o&&ug!==!1&&(_g(),e=e.toString(),e[e.length-1]===`
|
|
3
|
+
`&&(e=e.slice(0,-1)),zi.appendFileSync(qo,xs("stdout",[e]))),oC.apply(process.stdout,arguments)},process.stderr.write=function(e){return typeof e=="string"&&$o&&ug!==!1&&(_g(),e[e.length-1]===`
|
|
4
|
+
`&&(e=e.slice(0,-1)),zi.appendFileSync(qo,xs("stderr",[e]))),oC.apply(process.stderr,arguments)})}a(AQ,"stdioLogging");function yQ(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(yQ,"loggerWithTag");function bQ(e){try{$o=!1,e()}finally{$o=!0}}a(bQ,"suppressLogging");var OQ=fQ?.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||OQ+"/"+EQ);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
|
|
8
|
-
`).slice(1)){s=s.trim();let[i]=s.split(" ",1),o=s.slice(i.length+1).trim();t[i]===void 0&&(t[i]={}),t[i][r]=o}}))}catch(r){throw r}return Object.entries(t).filter(([,r])=>r.comm&&r.args&&r.ppid&&r.uid&&r["%cpu"]&&r["%mem"]&&r.args.includes(e)).map(([r,n])=>({pid:Number.parseInt(r,10),name:LQ.basename(n.comm),cmd:n.args,ppid:Number.parseInt(n.ppid,10),uid:Number.parseInt(n.uid,10),cpu:Number.parseFloat(n["%cpu"]),memory:Number.parseFloat(n["%mem"])}))}a(BQ,"findPs")});var Bt=N((Dge,AC)=>{"use strict";var HQ="__dbis__",xQ="__txns__",kQ="__environment_name__",FQ="__dbi_defintion__",GQ={EQUALS:"equals",STARTS_WITH:"startsWith",_STARTS_WITH:"starts_with",ENDS_WITH:"endsWith",_ENDS_WITH:"ends_with",CONTAINS:"contains",SEARCH_ALL:"searchAll",SEARCH_ALL_TO_MAP:"searchAllToMap",BATCH_SEARCH_BY_HASH:"batchSearchByHash",BATCH_SEARCH_BY_HASH_TO_MAP:"batchSearchByHashToMap",GREATER_THAN:"greaterThan",_GREATER_THAN:"greater_than",GREATER_THAN_EQUAL:"greaterThanEqual",_GREATER_THAN_EQUAL:"greater_than_equal",LESS_THAN:"lessThan",_LESS_THAN:"less_than",LESS_THAN_EQUAL:"lessThanEqual",_LESS_THAN_EQUAL:"less_than_equal",BETWEEN:"between"},qQ=["__createdtime__","__updatedtime__"],$Q="\uFFFF",RC={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},VQ=Object.values(RC);AC.exports={AUDIT_STORE_NAME:xQ,INTERNAL_DBIS_NAME:HQ,DBI_DEFINITION_NAME:FQ,SEARCH_TYPES:GQ,TIMESTAMP_NAMES:qQ,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:kQ,TRANSACTIONS_DBI_NAMES_ENUM:RC,TRANSACTIONS_DBIS:VQ,OVERFLOW_MARKER:$Q}});var Dn=N((Pge,PC)=>{"use strict";var yC=M(),bC=Bt(),OC={CONTINUE:100,OK:200,CREATED:201,BAD_REQUEST:400,UNAUTHORIZED:401,FORBIDDEN:403,NOT_FOUND:404,METHOD_NOT_ALLOWED:405,REQUEST_TIMEOUT:408,CONFLICT:409,TOO_MANY_REQUESTS:429,INTERNAL_SERVER_ERROR:500,NOT_IMPLEMENTED:501,BAD_GATEWAY:502,SERVICE_UNAVAILABLE:503,GATEWAY_TIMEOUT:504,HTTP_VERSION_NOT_SUPPORTED:505,INSUFFICIENT_STORAGE:507,NETWORK_AUTHENTICATION_REQUIRED:511},NC=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),IC={500:NC("There was an error processing your request."),400:"Invalid request"},KQ=IC[OC.INTERNAL_SERVER_ERROR],YQ={OP_NOT_SUPPORTED_FOR_FS:a(e=>`${e} is not available for this instance because it uses the File System data store.`,"OP_NOT_SUPPORTED_FOR_FS"),MISSING_VALUE:a(e=>`${e} is missing.`,"MISSING_VALUE"),INVALID_VALUE:a(e=>`${e} is invalid.`,"INVALID_VALUE"),NOT_FOUND:a(e=>`${e} not found.`,"NOT_FOUND")},WQ={CONFIG_VALIDATION:a(e=>`HarperDB config file validation error: ${e}`,"CONFIG_VALIDATION")},jQ={DEFAULT_BULK_LOAD_ERR:"There was an error during your bulk load into HarperDB.",DOWNLOAD_FILE_ERR:a(e=>`There was an error downloading '${e}'.`,"DOWNLOAD_FILE_ERR"),INSERT_JSON_ERR:"There was an error inserting the downloaded JSON data.",INSERT_CSV_ERR:"There was an error inserting the downloaded CSV data.",INVALID_ACTION_PARAM_ERR:a(e=>`Bulk load operation failed - ${e} is not a valid 'action' parameter`,"INVALID_ACTION_PARAM_ERR"),INVALID_FILE_EXT_ERR:a(e=>`Error selecting correct parser - valid file type not found in json - ${e}`,"INVALID_FILE_EXT_ERR"),MAX_FILE_SIZE_ERR:a((e,t)=>`File size is ${e} bytes, which exceeded the maximum size allowed of: ${t} bytes`,"MAX_FILE_SIZE_ERR"),PAPA_PARSE_ERR:"There was an error parsing the downloaded CSV data.",S3_DOWNLOAD_ERR:a(e=>`There was an error downloading '${e}' from AWS.`,"S3_DOWNLOAD_ERR"),WRITE_TEMP_FILE_ERR:"Error writing temporary file to storage"},zQ={BASE_PATH_REQUIRED:"base_path is required",DESTINATION_PATH_REQUIRED:"destination_path is required",ENV_NAME_REQUIRED:"env_name is required",INVALID_BASE_PATH:"invalid base_path",INVALID_DESTINATION_PATH:"invalid destination_path",INVALID_ENVIRONMENT:"invalid environment",ENV_REQUIRED:"env is required",DBI_NAME_REQUIRED:"dbi_name is required",DBI_DOES_NOT_EXIST:"dbi does not exist",HASH_ATTRIBUTE_REQUIRED:"hash_attribute is required",ID_REQUIRED:"id is required",IDS_REQUIRED:"ids is required",IDS_MUST_BE_ITERABLE:"ids must be iterable",FETCH_ATTRIBUTES_REQUIRED:"fetch_attributes is required",FETCH_ATTRIBUTES_MUST_BE_ARRAY:"fetch_attributes must be an array",ATTRIBUTE_REQUIRED:"attribute is required",SEARCH_VALUE_REQUIRED:"search_value is required",SEARCH_VALUE_TOO_LARGE:"search_value is too long",WRITE_ATTRIBUTES_REQUIRED:"write_attributes is required",WRITE_ATTRIBUTES_MUST_BE_ARRAY:"write_attributes must be an array",RECORDS_REQUIRED:"records is required",RECORDS_MUST_BE_ARRAY:"records must be an array",CANNOT_CREATE_INTERNAL_DBIS_NAME:`cannot create a dbi named ${bC.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${bC.INTERNAL_DBIS_NAME}`,START_VALUE_REQUIRED:"start_value is required",END_VALUE_REQUIRED:"end_value is required",CANNOT_COMPARE_STRING_TO_NUMERIC_KEYS:"cannot compare a string to numeric keys",END_VALUE_MUST_BE_GREATER_THAN_START_VALUE:"end_value must be greater than or equal to start_value",UNKNOWN_SEARCH_TYPE:"unknown search type",CANNOT_DROP_TABLE_HASH_ATTRIBUTE:"cannot drop a table's hash attribute"},QQ={ATTR_NAME_LENGTH_ERR:a(e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${yC.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes.`,"ATTR_NAME_LENGTH_ERR"),ATTR_NAME_NULLISH_ERR:"transaction aborted due to record(s) with an attribute name that is null, undefined or empty string",HASH_VAL_LENGTH_ERR:`transaction aborted due to record(s) with a hash value that exceeds ${yC.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes, check log for more info`,INVALID_FORWARD_SLASH_IN_HASH_ERR:"transaction aborted due to record(s) with a hash value that contains a forward slash, check log for more info",RECORD_MISSING_HASH_ERR:"transaction aborted due to record(s) with no hash value, check log for more info"},wC={GENERIC_AUTH_FAIL:"Login failed",USER_INACTIVE:"Cannot complete request: User is inactive",INVALID_TOKEN:"invalid token",NO_ENCRYPTION_KEYS:"unable to generate JWT as there are no encryption keys. please contact your administrator",INVALID_CREDENTIALS:"invalid credentials",PASSWORD_REQUIRED:"password is required",USERNAME_REQUIRED:"username is required",REFRESH_TOKEN_REQUIRED:"refresh_token is required",INVALID_AUTH_OBJECT:"invalid auth_object",INVALID_BODY:"invalid body",TOKEN_EXPIRED:"token expired",REFRESH_TOKEN_SAVE_FAILED:"unable to store refresh_token"},JQ={DEFAULT_INVALID_REQUEST:"Invalid request",OP_AUTH_PERMS_ERROR:"This operation is not authorized due to role restrictions and/or invalid database items",OP_IS_SU_ONLY:a(e=>`Operation '${e}' is restricted to 'super_user' roles`,"OP_IS_SU_ONLY"),OP_NOT_FOUND:a(e=>`Operation '${e}' not found`,"OP_NOT_FOUND"),SYSTEM_TIMESTAMP_PERMS_ERR:"Internal timestamp attributes - '__createdtime_' and '__updatedtime__' - cannot be inserted to or updated by HDB users.",UNKNOWN_OP_AUTH_ERROR:a((e,t,r)=>`There was an error authorizing ${e} op on table '${t}.${r}'`,"UNKNOWN_OP_AUTH_ERROR"),USER_HAS_NO_PERMS:a(e=>`User ${e} has no role or permissions. Please assign the user a valid role.`,"USER_HAS_NO_PERMS"),DROP_SYSTEM:"The 'system' database, tables and records are used internally by HarperDB and cannot be updated or removed."},XQ={ATTR_PERM_MISSING:a((e,t)=>`${e.toUpperCase()} attribute permission missing for '${t}'`,"ATTR_PERM_MISSING"),ATTR_PERM_MISSING_NAME:"Permission object in 'attribute_permission' missing an 'attribute_name'",ATTR_PERM_NOT_BOOLEAN:a((e,t)=>`${e.toUpperCase()} attribute permission for '${t}' must be a boolean`,"ATTR_PERM_NOT_BOOLEAN"),ATTR_PERMS_ARRAY_MISSING:"Missing 'attribute_permissions' array",ATTR_PERMS_NOT_ARRAY:"Value for 'attribute_permissions' must be an array",INVALID_ATTRIBUTE_IN_PERMS:a(e=>`Invalid attribute '${e}' in 'attribute_permissions'`,"INVALID_ATTRIBUTE_IN_PERMS"),INVALID_PERM_KEY:a(e=>`Invalid table permission key value '${e}'`,"INVALID_PERM_KEY"),INVALID_ATTR_PERM_KEY:a(e=>`Invalid attribute permission key value '${e}'`,"INVALID_ATTR_PERM_KEY"),INVALID_ROLE_JSON_KEYS:a(e=>`Invalid ${e.length>1?"keys":"key"} in JSON body - '${e.join("', '")}'`,"INVALID_ROLE_JSON_KEYS"),MISMATCHED_TABLE_ATTR_PERMS:a(e=>`You have a conflict with TABLE permissions for '${e}' being false and ATTRIBUTE permissions being true`,"MISMATCHED_TABLE_ATTR_PERMS"),OUTDATED_PERMS_TRANSLATION_ERROR:"This instance was recently upgraded and uses our new role permissions structure. Please login to this instance in HarperDB Studio, go to 'Roles', and click 'Update Role Permission' for all standard roles to migrate them to the new structure.",ROLE_ALREADY_EXISTS:a(e=>`A role with name '${e}' already exists`,"ROLE_ALREADY_EXISTS"),ROLE_NOT_FOUND:"Role not found",ROLE_PERMS_ERROR:"Errors in the role permissions JSON provided",SCHEMA_PERM_ERROR:a(e=>`Your role does not have permission to view database metadata for '${e}'`,"SCHEMA_PERM_ERROR"),SCHEMA_TABLE_PERM_ERROR:a((e,t)=>`Your role does not have permission to view database.table metadata for '${e}.${t}'`,"SCHEMA_TABLE_PERM_ERROR"),SU_ROLE_MISSING_ERROR:"Missing 'super_user' key/value in permission set",SU_CU_ROLE_BOOLEAN_ERROR:a(e=>`Value for '${e}' permission must be a boolean`,"SU_CU_ROLE_BOOLEAN_ERROR"),STRUCTURE_USER_ROLE_TYPE_ERROR:a(e=>`Value for '${e}' permission must be a boolean or Array`,"STRUCTURE_USER_ROLE_TYPE_ERROR"),SU_CU_ROLE_NO_PERMS_ALLOWED:a(e=>`Roles with '${e}' set to true cannot have other permissions set.`,"SU_CU_ROLE_NO_PERMS_ALLOWED"),SU_CU_ROLE_COMBINED_ERROR:"Roles cannot have both 'super_user' and 'cluster_user' values included in their permissions set.",TABLE_PERM_MISSING:a(e=>`Missing table ${e.toUpperCase()} permission`,"TABLE_PERM_MISSING"),TABLE_PERM_NOT_BOOLEAN:a(e=>`Table ${e.toUpperCase()} permission must be a boolean`,"TABLE_PERM_NOT_BOOLEAN")},ZQ={ATTR_NOT_FOUND:a((e,t,r)=>`Attribute '${r}' does not exist on '${e}.${t}'`,"ATTR_NOT_FOUND"),ATTR_EXISTS_ERR:a((e,t,r)=>`Attribute '${r}' already exists in ${e}.${t}'`,"ATTR_EXISTS_ERR"),DESCRIBE_ALL_ERR:"There was an error during describeAll. Please check the logs and try again.",INVALID_TABLE_ERR:a(e=>`Invalid table ${JSON.stringify(e)}`,"INVALID_TABLE_ERR"),SCHEMA_NOT_FOUND:a(e=>`database '${e}' does not exist`,"SCHEMA_NOT_FOUND"),SCHEMA_EXISTS_ERR:a(e=>`database '${e}' already exists`,"SCHEMA_EXISTS_ERR"),TABLE_EXISTS_ERR:a((e,t)=>`Table '${t}' already exists in '${e}'`,"TABLE_EXISTS_ERR"),SCHEMA_REQUIRED_ERR:"database is required",TABLE_NOT_FOUND:a((e,t)=>`Table '${e}.${t}' does not exist`,"TABLE_NOT_FOUND"),TABLE_REQUIRED_ERR:"table is required"},e2={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},t2={ALTER_USER_DUP_ROLES:a(e=>`Update failed. There are duplicates for the '${e}' role which is not allowed. Update your roles and try again.`,"ALTER_USER_DUP_ROLES"),ALTER_USER_ROLE_NOT_FOUND:a(e=>`Update failed. Requested '${e}' role not found.`,"ALTER_USER_ROLE_NOT_FOUND"),DUP_ROLES_FOUND:a(e=>`Multiple ${e} roles found. Roles must have unique 'role' value. Please update and try again.`,"DUP_ROLES_FOUND"),ROLE_NAME_NOT_FOUND:a(e=>`${e} role not found`,"ROLE_NAME_NOT_FOUND"),USER_ALREADY_EXISTS:a(e=>`User ${e} already exists`,"USER_ALREADY_EXISTS"),USER_NOT_EXIST:a(e=>`User ${e} does not exist`,"USER_NOT_EXIST")},CC={INVALID_DATE:"Invalid date, must be in ISO-8601 format (YYYY-MM-DD).",SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE:a(e=>`invalid sort attribute '${e}', the attribute must either be the table's hash attribute or an attribute used in conditions.`,"SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE")},DC={INVALID_ITC_DATA_TYPE:"Invalid ITC event data type, must be an object",MISSING_TYPE:"ITC event missing 'type'",MISSING_MSG:"ITC event missing 'message'",MISSING_ORIGIN:"ITC event message missing 'originator' property",INVALID_EVENT:a(e=>`ITC server received invalid event type: ${e}`,"INVALID_EVENT")},r2={FUNCTION_STATUS:"Error getting custom function status, check the log for more details",GET_FUNCTIONS:"Error getting custom functions, check the log for more details",GET_FUNCTION:"Error getting custom function, check the log for more details",SET_FUNCTION:"Error setting custom function, check the log for more details",NO_PROJECT:"Project does not exist. Create one using 'add_custom_function_project'",PROJECT_EXISTS:"Project already exists",VALIDATION_ERR:"Error validating request, check the log for more details",NO_FILE:"File does not exist",BAD_FILE_NAME:"File name can only contain alphanumeric, dash and underscore characters",BAD_PROJECT_NAME:"Project name can only contain alphanumeric, dash and underscores characters",BAD_PACKAGE:"Packaged project must be base64-encoded tar file of project directory",DROP_FUNCTION:"Error dropping custom function, check the log for more details",ADD_FUNCTION:"Error adding custom function project, check the log for more details",DROP_FUNCTION_PROJECT:"Error dropping custom function project, check the log for more details",BAD_FILE_PATH:"Filepath must be valid, and contain the name of the tarball you wish to write",NOT_ENABLED:"Custom functions is not enabled, to enable set fastifyRoutes enabled to true in hdb/harperdb-config.yaml file.",BAD_SSH_KEY_NAME:"SSH key name can only contain alphanumeric, dash and underscore characters"},n2={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},s2={...wC,...jQ,...YQ,...JQ,...XQ,...ZQ,...e2,...t2,...QQ,...CC,...DC,...r2,...n2,...WQ};PC.exports={CHECK_LOGS_WRAPPER:NC,HDB_ERROR_MSGS:s2,DEFAULT_ERROR_MSGS:IC,DEFAULT_ERROR_RESP:KQ,HTTP_STATUS_CODES:OC,LMDB_ERRORS_ENUM:zQ,AUTHENTICATION_ERROR_MSGS:wC,VALIDATION_ERROR_MSGS:CC,ITC_ERRORS:DC}});var _e=N((Mge,UC)=>{"use strict";var Ol=Dn(),i2=W(),o2=M(),ah=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,LC),this.statusCode=n||Ol.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(Ol.DEFAULT_ERROR_MSGS[n]?Ol.DEFAULT_ERROR_MSGS[n]:Ol.DEFAULT_ERROR_MSGS[Ol.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR]),this.message=t.message?t.message:this.http_resp_msg,this.type=t.name,s&&(this.logLevel=s),typeof this.message!="string"&&(this.stack=t.stack),i&&i2[s](i)}},pg=class extends Error{static{a(this,"ClientError")}constructor(t,r){if(t instanceof Error)return t.statusCode=r||400,t;super(t),this.statusCode=r||400}},mg=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function LC(e,t,r,n=o2.LOG_LEVELS.ERROR,s=null,i=!1){if(MC(e))return e;let o=new ah(e,t,r,n,s);return i&&delete o.stack,o}a(LC,"handleHDBError");function MC(e){return e.__proto__.constructor.name===ah.name}a(MC,"isHDBError");UC.exports={isHDBError:MC,handleHDBError:LC,ClientError:pg,ServerError:mg,hdb_errors:Ol}});var Sg=N(vC=>{"use strict";var a2={cert:"-----BEGIN CERTIFICATE-----\rMIIDXDCCAkSgAwIBAgIFNTE4MzQwDQYJKoZIhvcNAQELBQAwXTEXMBUGA1UEAxMO\rSGFycGVyREIsIEluYy4xCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDTzEPMA0GA1UE\rBxMGRGVudmVyMRcwFQYDVQQKEw5IYXJwZXJEQiwgSW5jLjAeFw0yMjAzMTEyMzAz\rNDlaFw0yNzAzMTAyMzAzNDlaMF0xFzAVBgNVBAMTDkhhcnBlckRCLCBJbmMuMQsw\rCQYDVQQGEwJVUzELMAkGA1UECBMCQ08xDzANBgNVBAcTBkRlbnZlcjEXMBUGA1UE\rChMOSGFycGVyREIsIEluYy4wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB\rAQCsEUlBF8WImS78rCFXVKyntxfrW++4qZ3hGnoD2MHZAuDHyeP/5eGnaE9GQhKc\r4DwG4DGvh0wP2zIYnBfiQ3L2ZtnlDR9ZkKIQYGlVxTUn6T43krhK5nZKqDF43Yg3\rZEvO3cbJBjiKZx0eA2/toehdSsTAHHQx5gTDcggNe2tgoJHYPwi9YF/AxSBZrbgb\ryWlYgtYDmF32ytHP03GUCIdKOFuBPsHTGu4SkdEIdLIqO9oglW1YFH5qZ6NiwApW\rsP+GCuqOwDXXbdjr75iq9Tq/CDrjGFLaTPmvd2Q0qG/BtaCll0ghpG+yIHvt/iQs\rajS+LxEWAnVlGMaDdFErbDUtAgMBAAGjIzAhMA8GA1UdEwEB/wQFMAMBAf8wDgYD\rVR0PAQH/BAQDAgIEMA0GCSqGSIb3DQEBCwUAA4IBAQASR4YW/rPK7PNArHVe9zzM\rb0rKNX/2T9/0nybRhmE/+hdlSgliTAeebmwkUS2APckmekYt/q2ZY2NS65Fo/jjp\rG8TJrtcF4h+ylVqUp0ZXQLFtIsr7r2JZA7hJ6njW6G4DHSZ0gxtECLi4CBlTjzm5\rNmnmIDObvGRTuqmcdAZmXeObbta/He2XIzietukPAYX062pNM+G5XT5UM1eG/Vlp\rN86vjhpyI+ffKy+C60SJqxmKM3ydgN7oLscE7+2wLPN25XqN4W99OwGsp5dTdu/f\r5lPtFayXdJ55e/sNQKmGN+UGLrL05c2MWgjb8U/LFilnupUianceoeSERZmVjzKX\r-----END CERTIFICATE-----\r".replace(/\r/g,`\r
|
|
7
|
+
`}a(xs,"createLogRecord");function Fd(e){if(Ei){if(_C(e),os){$o=!1;try{process.stdout.write(e)}finally{$o=!0}}}else os&&process.stdout.write(e)}a(Fd,"logStdOut");function oh(e){if(Ei){if(_C(e),os){$o=!1;try{process.stderr.write(e)}finally{$o=!0}}}else os&&process.stderr.write(e)}a(oh,"logStdErr");function _C(e){_g(),qo?zi.appendFileSync(qo,e):dg||console.log(e)}a(_C,"logToFile");function Eg(){try{zi.closeSync(qo)}catch{}qo=null}a(Eg,"closeLogFile");function _g(){if(!qo){try{qo=zi.openSync(sh,"a")}catch(e){dg||(dg=!0,console.error(e))}setTimeout(()=>{Eg()},gQ).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 NQ(e,t,...r){t===uC.STDERR?oh(xs(e,r)):Fd(xs(e,r))}a(NQ,"logCustomLevel");function IQ(){let e;try{e=pQ.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=hi.join(e,Wt.HDB_HOME_DIR_NAME,Wt.BOOT_PROPS_FILE_NAME);return zi.existsSync(t)||(t=hi.join(fg,"utility/hdb_boot_properties.file")),t}a(IQ,"getPropsFilePath");function wQ(e){wr=e}a(wQ,"setLogLevel");function aC(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(aC,"autoCastBoolean");function CQ(e){try{if(e.includes("config/settings.js")){let o=lC(e);return{level:o.get(Wt.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY),config_log_path:hi.dirname(o.get(Wt.HDB_SETTINGS_NAMES.LOG_PATH_KEY)),to_file:o.get(Wt.HDB_SETTINGS_NAMES.LOG_TO_FILE),to_stream:o.get(Wt.HDB_SETTINGS_NAMES.LOG_TO_STDSTREAMS)}}let t=cC.parseDocument(zi.readFileSync(e,"utf8")),r=t.getIn(["logging","level"]),n=t.getIn(["logging","root"]),s=t.getIn(["logging","file"]),i=t.getIn(["logging","stdStreams"]);return{level:r,config_log_path:n,to_file:s,to_stream:i}}catch(t){if(t.code===Wt.NODE_ERROR_CODES.ENOENT)throw t;console.error("Error accessing config file for logging"),console.error(t)}}a(CQ,"getLogConfig");function DQ(){try{let e=cC.parseDocument(zi.readFileSync(TQ,"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(DQ,"getDefaultConfig");function PQ(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(PQ,"AuthAuditLog")});var hg=N((Cge,RC)=>{"use strict";var LQ=require("util"),MQ=require("path"),UQ=require("child_process"),vQ=LQ.promisify(UQ.execFile),BQ=1e3*1e3*10;RC.exports={findPs:HQ};async function HQ(e){let t={};try{await Promise.all(["comm","args","ppid","uid","%cpu","%mem"].map(async r=>{let{stdout:n}=await vQ("ps",["wwxo",`pid,${r}`],{maxBuffer:BQ});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:MQ.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(HQ,"findPs")});var Bt=N((Pge,yC)=>{"use strict";var xQ="__dbis__",kQ="__txns__",FQ="__environment_name__",GQ="__dbi_defintion__",qQ={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"},$Q=["__createdtime__","__updatedtime__"],VQ="\uFFFF",AC={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},KQ=Object.values(AC);yC.exports={AUDIT_STORE_NAME:kQ,INTERNAL_DBIS_NAME:xQ,DBI_DEFINITION_NAME:GQ,SEARCH_TYPES:qQ,TIMESTAMP_NAMES:$Q,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:FQ,TRANSACTIONS_DBI_NAMES_ENUM:AC,TRANSACTIONS_DBIS:KQ,OVERFLOW_MARKER:VQ}});var Dn=N((Lge,LC)=>{"use strict";var bC=M(),OC=Bt(),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"},YQ=wC[NC.INTERNAL_SERVER_ERROR],WQ={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")},jQ={CONFIG_VALIDATION:a(e=>`HarperDB config file validation error: ${e}`,"CONFIG_VALIDATION")},zQ={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"},QQ={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"},JQ={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"},XQ={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."},ZQ={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")},e2={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"},t2={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},r2={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")},n2={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"},s2={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},i2={...CC,...zQ,...WQ,...XQ,...ZQ,...e2,...t2,...r2,...JQ,...DC,...PC,...n2,...s2,...jQ};LC.exports={CHECK_LOGS_WRAPPER:IC,HDB_ERROR_MSGS:i2,DEFAULT_ERROR_MSGS:wC,DEFAULT_ERROR_RESP:YQ,HTTP_STATUS_CODES:NC,LMDB_ERRORS_ENUM:QQ,AUTHENTICATION_ERROR_MSGS:CC,VALIDATION_ERROR_MSGS:DC,ITC_ERRORS:PC}});var _e=N((Uge,vC)=>{"use strict";var wl=Dn(),o2=W(),a2=M(),ah=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,MC),this.statusCode=n||wl.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(wl.DEFAULT_ERROR_MSGS[n]?wl.DEFAULT_ERROR_MSGS[n]:wl.DEFAULT_ERROR_MSGS[wl.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR]),this.message=t.message?t.message:this.http_resp_msg,this.type=t.name,s&&(this.logLevel=s),typeof this.message!="string"&&(this.stack=t.stack),i&&o2[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=a2.LOG_LEVELS.ERROR,s=null,i=!1){if(UC(e))return e;let o=new ah(e,t,r,n,s);return i&&delete o.stack,o}a(MC,"handleHDBError");function UC(e){return e.__proto__.constructor.name===ah.name}a(UC,"isHDBError");vC.exports={isHDBError:UC,handleHDBError:MC,ClientError:pg,ServerError:mg,hdb_errors:wl}});var Sg=N(BC=>{"use strict";var c2={cert:"-----BEGIN CERTIFICATE-----\rMIIDXDCCAkSgAwIBAgIFNTE4MzQwDQYJKoZIhvcNAQELBQAwXTEXMBUGA1UEAxMO\rSGFycGVyREIsIEluYy4xCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDTzEPMA0GA1UE\rBxMGRGVudmVyMRcwFQYDVQQKEw5IYXJwZXJEQiwgSW5jLjAeFw0yMjAzMTEyMzAz\rNDlaFw0yNzAzMTAyMzAzNDlaMF0xFzAVBgNVBAMTDkhhcnBlckRCLCBJbmMuMQsw\rCQYDVQQGEwJVUzELMAkGA1UECBMCQ08xDzANBgNVBAcTBkRlbnZlcjEXMBUGA1UE\rChMOSGFycGVyREIsIEluYy4wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB\rAQCsEUlBF8WImS78rCFXVKyntxfrW++4qZ3hGnoD2MHZAuDHyeP/5eGnaE9GQhKc\r4DwG4DGvh0wP2zIYnBfiQ3L2ZtnlDR9ZkKIQYGlVxTUn6T43krhK5nZKqDF43Yg3\rZEvO3cbJBjiKZx0eA2/toehdSsTAHHQx5gTDcggNe2tgoJHYPwi9YF/AxSBZrbgb\ryWlYgtYDmF32ytHP03GUCIdKOFuBPsHTGu4SkdEIdLIqO9oglW1YFH5qZ6NiwApW\rsP+GCuqOwDXXbdjr75iq9Tq/CDrjGFLaTPmvd2Q0qG/BtaCll0ghpG+yIHvt/iQs\rajS+LxEWAnVlGMaDdFErbDUtAgMBAAGjIzAhMA8GA1UdEwEB/wQFMAMBAf8wDgYD\rVR0PAQH/BAQDAgIEMA0GCSqGSIb3DQEBCwUAA4IBAQASR4YW/rPK7PNArHVe9zzM\rb0rKNX/2T9/0nybRhmE/+hdlSgliTAeebmwkUS2APckmekYt/q2ZY2NS65Fo/jjp\rG8TJrtcF4h+ylVqUp0ZXQLFtIsr7r2JZA7hJ6njW6G4DHSZ0gxtECLi4CBlTjzm5\rNmnmIDObvGRTuqmcdAZmXeObbta/He2XIzietukPAYX062pNM+G5XT5UM1eG/Vlp\rN86vjhpyI+ffKy+C60SJqxmKM3ydgN7oLscE7+2wLPN25XqN4W99OwGsp5dTdu/f\r5lPtFayXdJ55e/sNQKmGN+UGLrL05c2MWgjb8U/LFilnupUianceoeSERZmVjzKX\r-----END CERTIFICATE-----\r".replace(/\r/g,`\r
|
|
9
9
|
`),key:"-----BEGIN RSA PRIVATE KEY-----\rMIIEowIBAAKCAQEArBFJQRfFiJku/KwhV1Ssp7cX61vvuKmd4Rp6A9jB2QLgx8nj\r/+Xhp2hPRkISnOA8BuAxr4dMD9syGJwX4kNy9mbZ5Q0fWZCiEGBpVcU1J+k+N5K4\rSuZ2SqgxeN2IN2RLzt3GyQY4imcdHgNv7aHoXUrEwBx0MeYEw3IIDXtrYKCR2D8I\rvWBfwMUgWa24G8lpWILWA5hd9srRz9NxlAiHSjhbgT7B0xruEpHRCHSyKjvaIJVt\rWBR+amejYsAKVrD/hgrqjsA1123Y6++YqvU6vwg64xhS2kz5r3dkNKhvwbWgpZdI\rIaRvsiB77f4kLGo0vi8RFgJ1ZRjGg3RRK2w1LQIDAQABAoIBAQCEOmh78EOpnGZC\rYBjjHrvrysVD5gvLcfVUtl8Ls7gMB60re1eOIF+PoZZCHKZnDd6zPfiQtj1adg0C\rYnnsM/8VoaZS4gm0b3RLd3ubIQifWhuo40RissY2yxfxlPSH9LhZCY8ojnJG0cTL\resK579E8WCfopjUY33XLqEbN7Ylv39J+DSqInjqV3efJZUa+HqUJ98VxxzodcKMD\rP3bwUU4gHoSSp4pAsOFH5sQhaIWH1IcNjrAwpee2cJQuh4G157RRIuuUpagtaEG/\rXJIiAyBguJyu3JQFnIBQF01N5+omJgXYJ1L0m54543/iIRThmF3zDCDgCyUzmOk+\rH6As9fv1AoGBANOpOtOZLSAScjGsgJamT3ceJ2wCa86g2j8Oxu8lJUmUp5s3tA0v\rBFW5O3S4KR1EXwkLMBUMrfFM8YvzHWxsXBI6XV8azGLvyqPHxr65OhmpGYkGZMXu\rn9okgjkqlewnY2I073gvyK7ppX51UL5y9fF1vlsk+UlW+Rgx/vMHbdcjAoGBANAc\rxRUsxs4QJpbS4zD3JOkHjr24a97TrS3kCybAHUMpR2NrEHPZw9zex0/aphOJUHfL\rIMkOZdpfDqMfxWy4FAEmqBEMkO2SB+h0Wp4P+qp81ax4vGFiB0cD3wtixr11U1tt\rlZ/ZTdv4VDpDFNK1KaplhTDeyuCjeYfS3/GJia9vAoGAcOsAgjBevZR5rXx84WH6\rVO8WUu37u7FenXNxt9VWTinrPMh72uixZFY8nOk+rely1e1NCn3IMko9Ns9NbDFm\r8SaH95vhXArXTYbfxZIlp9jp0YtCqcHDL+p4Oq04bFMbFyJseu7rHj1x18QYfnHw\rOY/6LL/N6k1m+Hx7qgXVmIcCgYB/w0nTCBw84XlvWqSTqQaF8VfWbWP79mP5KmkW\rLxdH5g2noVEGbohqDnK6OXd/wusdwByukiJBf94Skyy25AOT+VFwthA7aU1ljhkb\rtJ+lDuJ28eBkwLPLCzthWBC+u0qjdJFJAzVjd/7tjcU43nNn4s90AzL12iaAFhvZ\rwyA+DQKBgGc/4cdyGJ3YkcA8150gQBawgJZ7q8V1JND87ggWA8wnK3cHn7rMZQl2\r3emDp9HEFXFex5dbGDDqZFAoesZCDxjknIn9oNfW4PvaWS8q7b6ZKLZG1p03Pu7/\rtYaD0kPbo0kysfFT/co+NgHbdykvIyboomfGdNLTUjYuy6lpwpvs\r-----END RSA PRIVATE KEY-----\r".replace(/\r/g,`\r
|
|
10
|
-
`)},c2="certificate.pem",l2="privateKey.pem",u2="caCertificate.pem",d2="natsCertificate.pem",_2="natsCaCertificate.pem",At={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},f2={tls_certificate:At.SERVER,tls_certificateAuthority:At.CA,customFunctions_tls_certificate:At.SERVER,customFunctions_tls_certificateAuthority:At.CA,operationsApi_tls_certificate:At["OPERATIONS-API"],operationsApi_tls_certificateAuthority:At["OPERATIONS-CA"]},E2={[At.SERVER]:2,[At.DEFAULT]:1},h2={[At["OPERATIONS-API"]]:3,[At.SERVER]:2,[At.DEFAULT]:1},p2={[At["OPERATIONS-API"]]:3,[At.SERVER]:2,[At.DEFAULT]:1},m2={[At["OPERATIONS-CA"]]:3,[At.CA]:2,[At["DEFAULT-CA"]]:1},S2={[At["OPERATIONS-CA"]]:3,[At.CA]:2,[At["DEFAULT-CA"]]:1},T2={[At.CA]:2,[At["DEFAULT-CA"]]:1};Object.assign(vC,{CERTIFICATE_PEM_NAME:c2,PRIVATEKEY_PEM_NAME:l2,CA_PEM_NAME:u2,CERT_NAME:At,CERT_CONFIG_NAME_MAP:f2,CERT_PREFERENCE_APP:E2,CERT_PREFERENCE_OPS:h2,CERT_PREFERENCE_REP:p2,CA_CERT_PREFERENCE_REP:m2,CA_CERT_PREFERENCE_OPS:S2,CA_CERT_PREFERENCE_APP:T2,CERTIFICATE_VALUES:a2,NATS_CERTIFICATE_PEM_NAME:d2,NATS_CA_PEM_NAME:_2})});var Tt=N((Bge,BC)=>{"use strict";var nn=require("validate.js");nn.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||nn.validators.type.checks[t](e)?null:` must be a '${t}' value`};nn.validators.type.checks={Object:a(function(e){return nn.isObject(e)&&!nn.isArray(e)},"Object"),Array:nn.isArray,Integer:nn.isInteger,Number:nn.isNumber,String:nn.isString,Date:nn.isDate,Boolean:a(function(e){return typeof e=="boolean"},"Boolean")};nn.validators.hasValidFileExt=function(e,t){return nn.isString(e)?e===""?"can't be blank":t.filter(r=>e.endsWith(r)).length>0?null:`must include one of the following valid file extensions - '${t.join("', '")}'`:null};BC.exports={validateObject:g2,validateObjectAsync:R2,validateBySchema:A2};function g2(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=nn(e,t,{format:"flat"});return r?new Error(r):null}a(g2,"validateObject");async function R2(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await nn.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(R2,"validateObjectAsync");function A2(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(A2,"validateBySchema")});var gg=N((kge,qC)=>{"use strict";var FC=require("fs-extra"),me=require("joi"),y2=require("os"),{boolean:qe,string:It,number:tr,array:za}=me.types(),{totalmem:HC}=require("os"),ja=require("path"),b2=W(),Tg=te(),xge=Sg(),xC=M(),O2=Tt(),kC="log",N2="components",I2="Invalid logging.rotation.maxSize unit. Available units are G, M or K",w2="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",C2="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",D2="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",P2="rootPath config parameter is undefined",sn=me.alternatives([tr.min(0),It]).optional().empty(null),ch=me.alternatives([za.items(It,{host:It.required(),port:sn},{hostname:It.required(),port:sn}).empty(null),za.items(It)]),pi,GC=!1;qC.exports={configValidator:L2,routesValidator:x2,route_constraints:ch};function L2(e,t=!1){if(GC=t,pi=e.rootPath,Tg.isEmpty(pi))throw P2;let r=qe.optional(),n=tr.min(0).max(1e3).empty(null).default(H2),s=It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(Fd),i=It.optional().empty(null),o=It.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=me.string().empty(null).default(Fd),l=me.custom(U2).empty(null).default(Fd),u=e.clustering?.enabled,d=me.object({certificate:i,certificateAuthority:i,privateKey:i}),_;return u===!0?_=me.object({enabled:r,hubServer:me.object({cluster:me.object({name:me.required().empty(null),network:me.object({port:sn,routes:ch}).required()}).required(),leafNodes:me.object({network:me.object({port:sn}).required()}).required(),network:me.object({port:sn}).required()}).required(),leafServer:me.object({network:me.object({port:sn,routes:ch}).required(),streams:me.object({maxAge:tr.min(120).allow(null).optional(),maxBytes:tr.min(1).allow(null).optional(),maxMsgs:tr.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:me.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:qe.optional(),databaseLevel:qe.optional(),tls:me.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:qe.required(),verify:qe.optional()}),user:It.optional().empty(null)}).optional():_=me.object({enabled:r,tls:me.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:qe.optional()})}).optional(),me.object({authentication:me.alternatives(me.object({authorizeLocal:qe,cacheTTL:tr.required(),enableSessions:qe}),qe).optional(),analytics:me.object({aggregatePeriod:tr}),replication:me.object({hostname:me.alternatives(It,tr).optional().empty(null),url:It.optional().empty(null),port:sn,securePort:sn,routes:za.optional().empty(null),databases:me.alternatives(It,za),enableRootCAs:qe.optional()}).optional(),componentsRoot:s.optional(),clustering:_,localStudio:me.object({enabled:r}).required(),logging:me.object({auditAuthEvents:me.object({logFailed:qe,logSuccessful:qe}),file:qe.required(),level:me.valid("notify","fatal","error","warn","info","debug","trace"),rotation:me.object({enabled:qe.optional(),compress:qe.optional(),interval:It.custom(B2).optional().empty(null),maxSize:It.custom(v2).optional().empty(null),path:It.optional().empty(null).default(Fd)}).required(),root:s,stdStreams:qe.required(),auditLog:qe.required()}).required(),operationsApi:me.object({network:me.object({cors:qe.optional(),corsAccessList:za.optional(),headersTimeout:tr.min(1).optional(),keepAliveTimeout:tr.min(1).optional(),port:sn,domainSocket:me.optional().empty("hdb/operations-server").default(Fd),securePort:sn,timeout:tr.min(1).optional()}).optional(),tls:me.alternatives([me.array().items(d),d])}).required(),rootPath:It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:me.object({network:me.object({port:sn,securePort:sn,mtls:me.alternatives([qe.optional(),me.object({user:It.optional(),certificateAuthority:i,required:qe.optional()})])}).required(),webSocket:qe.optional(),requireAuthentication:qe.optional()}),http:me.object({compressionThreshold:tr.optional(),cors:qe.optional(),corsAccessList:za.optional(),headersTimeout:tr.min(1).optional(),port:sn,securePort:sn,maxHeaderSize:tr.optional(),mtls:me.alternatives([qe.optional(),me.object({user:It.optional(),certificateAuthority:i,required:qe.optional()})]),threadRange:me.alternatives([za.optional(),It.optional()])}).required(),threads:me.alternatives(n.optional(),me.object({count:n.optional(),debug:me.alternatives(qe.optional(),me.object({startingPort:tr.min(1).optional(),host:It.optional(),waitForDebugger:qe.optional()})),maxHeapMemory:tr.min(0).optional()})),storage:me.object({writeAsync:qe.required(),overlappingSync:qe.optional(),caching:qe.optional(),compression:me.alternatives([qe.optional(),me.object({dictionary:It.optional(),threshold:tr.optional()})]),compactOnStart:qe.optional(),compactOnStartKeepBackup:qe.optional(),noReadAhead:qe.optional(),path:l,prefetchWrites:qe.optional(),maxFreeSpaceToLoad:tr.optional(),maxFreeSpaceToRetain:tr.optional()}).required(),ignoreScripts:qe.optional(),tls:me.alternatives([me.array().items(d),d])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(L2,"configValidator");function M2(e){return GC||FC.existsSync(e)?null:`Specified path ${e} does not exist.`}a(M2,"doesPathExist");function U2(e,t){me.assert(e,It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=M2(e);if(r)return t.message(r)}a(U2,"validatePath");function v2(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(I2);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(C2):e}a(v2,"validateRotationMaxSize");function B2(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(w2);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(D2):e}a(B2,"validateRotationInterval");function H2(e,t){let r=t.state.path.join("."),n=y2.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||HC();return i=Math.round(Math.min(i,HC())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),b2.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(H2,"setDefaultThreads");function Fd(e,t){let r=t.state.path.join(".");if(!Tg.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(Tg.isEmpty(pi))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return ja.join(pi,N2);case"logging.root":return ja.join(pi,kC);case"clustering.leafServer.streams.path":return ja.join(pi,"clustering","leaf");case"storage.path":let n=ja.join(pi,xC.LEGACY_DATABASES_DIR_NAME);return FC.existsSync(n)?n:ja.join(pi,xC.DATABASES_DIR_NAME);case"logging.rotation.path":return ja.join(pi,kC);case"operationsApi.network.domainSocket":return r==null?null:ja.join(pi,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(Fd,"setDefaultRoot");function x2(e){let t=me.object({routes:ch});return O2.validateBySchema({routes:e},t)}a(x2,"routesValidator")});var Qa={};je(Qa,{server:()=>it});var $C,it,qr=Oe(()=>{$C=L(fi()),it={};(0,$C._assignPackageExport)("server",it)});var wt=N(ZC=>{"use strict";var on=M(),Er=te(),hr=W(),{configValidator:k2,routesValidator:VC}=gg(),$r=require("fs-extra"),YC=require("yaml"),Ln=require("path"),F2=require("is-number"),WC=require("properties-reader"),G2=require("lodash"),{handleHDBError:q2}=_e(),{HTTP_STATUS_CODES:$2,HDB_ERROR_MSGS:Nl}=Dn(),{server:V2}=(qr(),oe(Qa)),{DATABASES_PARAM_CONFIG:Gd,CONFIG_PARAMS:Pn,CONFIG_PARAM_MAP:ks}=on,K2="Unable to get config value because config is uninitialized",Y2="Config successfully initialized",W2="Error backing up config file",j2="Empty parameter sent to getConfigValue",jC=Ln.join(on.PACKAGE_ROOT,"config","yaml",on.HDB_DEFAULT_CONFIG_FILE),z2=Ln.join(on.PACKAGE_ROOT,"config","yaml","defaultNatsConfig.yaml"),Q2="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",KC={logging_rotation_retain:"logging.rotation.retain",logging_rotation_rotate:"logging.rotation.rotate",logging_rotation_rotateinterval:"logging.rotation.rotateInterval",logging_rotation_rotatemodule:"logging.rotation.rotateModule",logging_rotation_timezone:"logging.rotation.timezone",logging_rotation_workerinterval:"logging.rotation.workerInterval"},lh,jt,uh;Object.assign(ZC,{createConfigFile:J2,getDefaultConfig:X2,getConfigValue:QC,initConfig:dh,flattenConfig:Il,updateConfigValue:JC,updateConfigObject:e4,getConfiguration:n4,setConfiguration:s4,readConfigFile:bg,getClusteringRoutes:i4,initOldConfig:XC,getConfigFromFile:o4,getConfigFilePath:Ja,addConfig:a4,deleteConfigFromFile:c4,getConfigObj:l4,resolvePath:Rg,getFlatConfigObj:u4});function Rg(e){if(e?.startsWith("~/"))return Ln.join(Er.getHomeDir(),e.slice(1));let t=se();return Ln.resolve(t.getHdbBasePath(),e)}a(Rg,"resolvePath");function J2(e,t=!1){let r=Ko(jC);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=YC.parseDocument($r.readFileSync(z2,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}lh=Il(r.toJSON());let n;for(let c in e){let l=ks[c.toLowerCase()];if(l===Pn.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(u=>({[u]:e[c][u]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let u=l.split("_"),d=Ag(l,e[c]);l==="rootPath"&&d?.endsWith("/")&&(d=d.slice(0,-1));try{r.setIn([...u],d)}catch(_){hr.error(_)}}}n&&zC(r,n),yg(r,t);let s=r.toJSON();jt=Il(s);let i=r.getIn(["rootPath"]),o=Ln.join(i,on.HDB_CONFIG_FILE);$r.createFileSync(o),$r.writeFileSync(o,String(r)),hr.trace(`Config file written to ${o}`)}a(J2,"createConfigFile");function zC(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!Er.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(Gd.TABLES))for(let i in n[s][Gd.TABLES])for(let o in n[s][Gd.TABLES][i]){let c=n[s][Gd.TABLES][i][o],l=[Pn.DATABASES,s,Gd.TABLES,i,o];e.hasIn(l)?e.setIn(l,c):e.addIn(l,c)}else for(let i in n[s]){let o=n[s][i],c=[Pn.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){hr.error("Error parsing schemas CLI/env config arguments",n)}}a(zC,"setSchemasConfig");function X2(e){if(lh===void 0){let r=Ko(jC);lh=Il(r.toJSON())}let t=ks[e.toLowerCase()];if(t!==void 0)return lh[t.toLowerCase()]}a(X2,"getDefaultConfig");function QC(e){if(e==null){hr.info(j2);return}if(jt===void 0){hr.trace(K2);return}let t=ks[e.toLowerCase()];if(t!==void 0)return jt[t.toLowerCase()]}a(QC,"getConfigValue");function Ja(e=Er.getPropsFilePath()){let t=Er.getEnvCliRootPath();if(t)return Rg(Ln.join(t,on.HDB_CONFIG_FILE));let r=WC(e);return Rg(r.get(on.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(Ja,"getConfigFilePath");function dh(e=!1){if(jt===void 0||e){let t;if(!Er.noBootFile()){t=Er.getPropsFilePath();try{$r.accessSync(t,$r.constants.F_OK|$r.constants.R_OK)}catch(i){throw hr.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Ja(t),n;if(r.includes("config/settings.js"))try{XC(r);return}catch(i){if(i.code!==on.NODE_ERROR_CODES.ENOENT)throw i}try{n=Ko(r)}catch(i){if(i.code===on.NODE_ERROR_CODES.ENOENT){hr.trace(`HarperDB config file not found at ${r}.
|
|
11
|
-
This can occur during early stages of install where the config file has not yet been created`);return}else throw hr.error(i),new Error(`Error reading HarperDB config file at ${r}`)}Z2(n,r),yg(n);let s=n.toJSON();if(V2.config=s,jt=Il(s),jt.logging_rotation_rotate)for(let i in KC)jt[i]&&hr.error(`Config ${KC[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);hr.trace(Y2)}}a(dh,"initConfig");function Z2(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Ln.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Ln.join(r,"log")),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n&&(hr.trace("Updating config file with missing config params"),$r.writeFileSync(t,String(e)))}a(Z2,"checkForUpdatedConfig");function yg(e,t=!1){let r=e.toJSON();if(r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads),r.http?.port&&r.http?.port===r.http?.securePort)throw Nl.CONFIG_VALIDATION("http.port and http.securePort cannot be the same value");if(r.operationsApi?.network?.port&&r.operationsApi?.network?.port===r.operationsApi?.network?.securePort)throw Nl.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=k2(r,t);if(n.error)throw Nl.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket),r?.clustering?.enabled&&e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path)}a(yg,"validateConfig");function e4(e,t){jt===void 0&&(jt={});let r=ks[e.toLowerCase()];if(r===void 0){hr.trace(`Unable to update config object because config param '${e}' does not exist`);return}jt[r.toLowerCase()]=t}a(e4,"updateConfigObject");function JC(e,t,r=void 0,n=!1,s=!1,i=!1){jt===void 0&&dh();let o=QC(ks.hdb_root),c=Ln.join(o,on.HDB_CONFIG_FILE),l=Ko(c),u;if(r===void 0&&e.toLowerCase()===Pn.DATABASES)u=t;else if(r===void 0){let E;if(i)E=e;else if(E=ks[e.toLowerCase()],E===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let f=E.split("_"),h=Ag(E,t);l.setIn([...f],h)}else for(let E in r){let f=ks[E.toLowerCase()];if(f===Pn.HTTP_SECUREPORT&&r[E]===jt[Pn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),f===Pn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===jt[Pn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),f===Pn.DATABASES){u=r[E];continue}if(f?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!f&&(E.endsWith("_package")||E.endsWith("_port"))&&(f=E),f!==void 0){let h=f.split("_"),T=on.LEGACY_CONFIG_PARAMS[E.toUpperCase()];T&&T.startsWith("customFunctions")&&l.hasIn(T.split("_"))&&(f=T,h=T.split("_"));let m=Ag(f,r[E]);f==="rootPath"&&m?.endsWith("/")&&(m=m.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],m)}catch(g){hr.error(g)}}}u&&zC(l,u),yg(l);let d=l.getIn(["rootPath"]),_=Ln.join(d,on.HDB_CONFIG_FILE);n===!0&&t4(c,d),$r.writeFileSync(_,String(l)),s&&(jt=Il(l.toJSON())),hr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(JC,"updateConfigValue");function t4(e,t){try{let r=Ln.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${on.HDB_CONFIG_FILE}.bak`);$r.copySync(e,r),hr.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){hr.error(W2),hr.error(r)}}a(t4,"backupConfigFile");var r4=["databases"];function Il(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network={...e.http,...e.operationsApi.network}),e?.operationsApi&&(e.operationsApi.tls={...e.tls,...e.operationsApi.tls}),uh=e,r(e);function r(n){let s={};for(let i in n)if(n.hasOwnProperty(i)){if(typeof n[i]=="object"&&n[i]!==null&&!Array.isArray(n[i])&&!r4.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!Pn[l.toUpperCase()]&&ks[l]&&(s[ks[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Il,"flattenConfig");function Ag(e,t){if(e===Pn.CLUSTERING_NODENAME||e===Pn.CLUSTERING_USER){if(t==null)return t;if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if(F2(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Er.isObject(t)||t===null)return t;if(typeof t=="string"&&t.toLowerCase()==="true")return!0;if(typeof t=="string"&&t.toLowerCase()==="false")return!1}if(t===void 0||t.toLowerCase()==="undefined")return null;if(typeof t=="string"&&(t.startsWith("{")&&t.endsWith("}")||t.startsWith("[")&&t.endsWith("]")))try{return JSON.parse(t)}catch{}return Er.autoCast(t)}a(Ag,"castConfigValue");function n4(){let e=Er.getPropsFilePath(),t=Ja(e);return Ko(t).toJSON()}a(n4,"getConfiguration");async function s4(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return JC(void 0,void 0,s,!0),Q2}catch(i){throw typeof i=="string"||i instanceof String?q2(i,i,$2.BAD_REQUEST,void 0,void 0,!0):i}}a(s4,"setConfiguration");function bg(){let e=Er.getPropsFilePath();try{$r.accessSync(e,$r.constants.F_OK|$r.constants.R_OK)}catch(n){if(!Er.noBootFile())throw hr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Ja(e);return Ko(t).toJSON()}a(bg,"readConfigFile");function Ko(e){return YC.parseDocument($r.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Ko,"parseYamlDoc");function i4(){let e=bg(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Er.isEmptyOrZeroLength(t)?[]:t;let r=VC(t);if(r)throw Nl.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Er.isEmptyOrZeroLength(n)?[]:n;let s=VC(n);if(s)throw Nl.CONFIG_VALIDATION(s.message);if(!Er.isEmptyOrZeroLength(n)&&!Er.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Er.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw Nl.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(i4,"getClusteringRoutes");function XC(e){let t=WC(e);jt={};for(let r in ks){let n=t.get(r.toUpperCase());if(Er.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=ks[r].toLowerCase();s===Pn.LOGGING_ROOT?jt[s]=Ln.dirname(n):jt[s]=n}return jt}a(XC,"initOldConfig");function o4(e){let t=bg();return G2.get(t,e.replaceAll("_","."))}a(o4,"getConfigFromFile");async function a4(e,t){let r=Ko(Ja());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await $r.writeFile(Ja(),String(r))}a(a4,"addConfig");function c4(e){let t=Ja(Er.getPropsFilePath()),r=Ko(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Ln.join(n,on.HDB_CONFIG_FILE);$r.writeFileSync(s,String(r))}a(c4,"deleteConfigFromFile");function l4(){return uh||(dh(),uh)}a(l4,"getConfigObj");function u4(){return jt||dh(),jt}a(u4,"getFlatConfigObj")});var se=N((sD,iD)=>{"use strict";var Og=require("fs-extra"),Xa=require("path"),eD=require("os"),d4=require("properties-reader"),$d=W(),qd=te(),De=M(),_h=wt(),_4="Error initializing environment manager",fh="BOOT_PROPS_FILE_PATH",tD=!1,f4={[De.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},Qi={};Object.assign(sD,iD.exports={BOOT_PROPS_FILE_PATH:fh,getHdbBasePath:E4,setHdbBasePath:h4,get:rD,initSync:m4,setProperty:Qe,initTestEnvironment:T4,setCloneVar:S4});function E4(){return Qi[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(E4,"getHdbBasePath");function h4(e){Qi[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(h4,"setHdbBasePath");function rD(e){let t=_h.getConfigValue(e);return t===void 0?Qi[e]:t}a(rD,"get");function Qe(e,t){f4[e]&&(Qi[e]=t),_h.updateConfigObject(e,t)}a(Qe,"setProperty");function p4(){let e;try{e=qd.getPropsFilePath(),Og.accessSync(e,Og.constants.F_OK|Og.constants.R_OK),tD=!0;let t=d4(e);return Qi[De.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(De.HDB_SETTINGS_NAMES.INSTALL_USER),Qi[De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),Qi[fh]=e,!0}catch{return $d.trace(`Environment manager found no properties file at ${e}`),!1}}a(p4,"doesPropFileExist");function m4(e=!1){try{((tD||p4()||qd.noBootFile())&&!nD||e)&&(_h.initConfig(e),Qi[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=_h.getConfigValue(De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){$d.error(_4),$d.error(t),console.error(t),process.exit(1)}}a(m4,"initSync");var nD=!1;function S4(e){nD=e}a(S4,"setCloneVar");function T4(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:n,https_enabled:s,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,l=Xa.join(__dirname,"../../","unitTests");Qi[fh]=Xa.join(l,"hdb_boot_properties.file"),Qe(De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Xa.join(l,"settings.test")),Qe(De.HDB_SETTINGS_NAMES.INSTALL_USER,eD.userInfo()?eD.userInfo().username:void 0),Qe(De.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Qe(De.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Xa.join(l,"envDir","log")),Qe(De.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Qe(De.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Qe(De.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Qe(De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Xa.join(l,"envDir")),Qe(De.CONFIG_PARAMS.STORAGE_PATH,Xa.join(l,"envDir")),s&&(Qe(De.CONFIG_PARAMS.HTTP_SECUREPORT,rD(De.CONFIG_PARAMS.HTTP_PORT)),Qe(De.CONFIG_PARAMS.HTTP_PORT,null)),Qe(De.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Qe(De.CONFIG_PARAMS.HTTP_PORT,9926),Qe(De.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Qe(De.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),Qe(De.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,qd.isEmpty(i)?!1:i),Qe(De.CONFIG_PARAMS.HTTP_CORS,qd.isEmpty(i)?!1:i),Qe(De.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Qe(De.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Qe(De.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Qe(De.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Qe(De.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Xa.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Qe(De.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,qd.isEmpty(c)?!1:c),o&&(Qe("CORS_ACCESSLIST",o),Qe(De.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Qe(De.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Qe(De.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Qe(De.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Qe(De.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Qe(De.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Qe(De.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${fh}. Please check your boot props and settings files`;$d.fatal(r),$d.error(t)}}a(T4,"initTestEnvironment")});var gt=N((Vge,_D)=>{"use strict";var jd=M(),g4=te(),an=se(),zd=require("path"),R4=require("minimist"),oD=require("fs-extra"),aD=require("lodash");an.initSync();var{CONFIG_PARAMS:Yo,DATABASES_PARAM_CONFIG:Vd,SYSTEM_SCHEMA_NAME:Eh}=jd,Kd,Yd,Wd;function cD(){if(Kd!==void 0)return Kd;if(an.getHdbBasePath()!==void 0)return Kd=an.get(Yo.STORAGE_PATH)||zd.join(an.getHdbBasePath(),jd.DATABASES_DIR_NAME),Kd}a(cD,"getBaseSchemaPath");function lD(){if(Yd!==void 0)return Yd;if(an.getHdbBasePath()!==void 0)return Yd=dD(Eh),Yd}a(lD,"getSystemSchemaPath");function uD(){if(Wd!==void 0)return Wd;if(an.getHdbBasePath()!==void 0)return Wd=an.get(jd.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||zd.join(an.getHdbBasePath(),jd.TRANSACTIONS_DIR_NAME),Wd}a(uD,"getTransactionAuditStoreBasePath");function A4(e,t){let r=an.get(Yo.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||zd.join(uD(),e.toString())}a(A4,"getTransactionAuditStorePath");function dD(e,t){e=e.toString(),t=t&&t.toString();let r=an.get(jd.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||zd.join(cD(),e)}a(dD,"getSchemaPath");function y4(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,R4(process.argv));let n=r[Yo.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!g4.isObject(n))throw o;i=n}for(let o of i){let c=o[Eh];if(!c)continue;let l=an.get(Yo.DATABASES);l=l??{};let u=c?.tables?.[t]?.[Vd.PATH];if(u)return aD.set(l,[Eh,Vd.TABLES,t,Vd.PATH],u),an.setProperty(Yo.DATABASES,l),u;let d=c?.[Vd.PATH];if(d)return aD.set(l,[Eh,Vd.PATH],d),an.setProperty(Yo.DATABASES,l),d}}let s=r[Yo.STORAGE_PATH.toUpperCase()];if(s){if(!oD.pathExistsSync(s))throw new Error(s+" does not exist");let i=zd.join(s,e);return oD.mkdirsSync(i),an.setProperty(Yo.STORAGE_PATH,s),i}return lD()}a(y4,"initSystemSchemaPaths");function b4(){Kd=void 0,Yd=void 0,Wd=void 0}a(b4,"resetPaths");_D.exports={getBaseSchemaPath:cD,getSystemSchemaPath:lD,getTransactionAuditStorePath:A4,getTransactionAuditStoreBasePath:uD,getSchemaPath:dD,initSystemSchemaPaths:y4,resetPaths:b4}});var cn=N((jge,mD)=>{"use strict";var O4=Dn().LMDB_ERRORS_ENUM,Yge=require("lmdb"),N4=Bt(),Wge=require("buffer").Buffer,{OVERFLOW_MARKER:fD,MAX_SEARCH_KEY_LENGTH:hh}=N4,ED=["number","string","symbol","boolean","bigint"];function I4(e){if(e=e?.primaryStore||e,!e)throw new Error(O4.ENV_REQUIRED)}a(I4,"validateEnv");function w4(e){if(e==null)return null;let t;try{t=typeof e=="object"?JSON.stringify(e):e.toString()}catch{t=e.toString()}return t}a(w4,"stringifyData");function C4(e){return e instanceof Date?e.valueOf():e}a(C4,"convertKeyValueToWrite");function D4(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(ED.includes(typeof e))return e.length>hh?[e.slice(0,hh)+fD]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(ED.includes(typeof i))i.length>hh?r.push(i.slice(0,hh)+fD):r.push(i);else{if(i===null&&t)return r.push(null);if(i instanceof Date)return r.push(i.getTime())}}}else if(e instanceof Date)return[e.getTime()];return r}a(D4,"getIndexedValues");var ph=0,hD=0;function pD(){hD=Date.now()-performance.now()}a(pD,"adjustStartTime");pD();var P4=6e4;setInterval(pD,P4).unref();function L4(){let e=performance.now()+hD;return e>ph?(ph=e,e):(ph+=488e-6,ph)}a(L4,"getNextMonotonicTime");mD.exports={validateEnv:I4,stringifyData:w4,convertKeyValueToWrite:C4,getNextMonotonicTime:L4,getIndexedValues:D4}});var Qd=N((Qge,SD)=>{"use strict";var M4=M().OPERATIONS_ENUM,Ng=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=M4.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};SD.exports=Ng});var Jd=N((Zge,AD)=>{"use strict";var Xge=Qd(),mh=M(),Ig=te(),TD=W(),U4=require("uuid"),{handleHDBError:Sh,hdb_errors:v4}=_e(),{HDB_ERROR_MSGS:Th,HTTP_STATUS_CODES:gh}=v4;AD.exports=gD;function gD(e,t,r){for(let s=0;s<t.length;s++)RD(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];B4(i,r,e.operation)}}a(gD,"processRows");gD.validateAttribute=RD;function RD(e){if(Buffer.byteLength(String(e))>mh.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw Sh(new Error,Th.ATTR_NAME_LENGTH_ERR(e),gh.BAD_REQUEST,void 0,void 0,!0);if(Ig.isEmptyOrZeroLength(e)||Ig.isEmpty(e.trim()))throw Sh(new Error,Th.ATTR_NAME_NULLISH_ERR,gh.BAD_REQUEST,void 0,void 0,!0)}a(RD,"validateAttribute");function B4(e,t,r){if(!e.hasOwnProperty(t)||Ig.isEmptyOrZeroLength(e[t])){if(r===mh.OPERATIONS_ENUM.INSERT||r===mh.OPERATIONS_ENUM.UPSERT){e[t]=U4.v4();return}throw TD.error("Update transaction aborted due to record with no hash value:",e),Sh(new Error,Th.RECORD_MISSING_HASH_ERR,gh.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>mh.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw TD.error(e),Sh(new Error,Th.HASH_VAL_LENGTH_ERR,gh.BAD_REQUEST,void 0,void 0,!0)}a(B4,"validateHash")});var yD,Mn,wg,wl=Oe(()=>{yD=require("events"),Mn=class extends yD.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new wg;return t.queue=this,t}push(t){this.send(t)}send(t){this.resolveNext?(this.resolveNext({value:t}),this.resolveNext=null):this.hasDataListeners?this.emit("data",t):(this.queue||(this.queue=[]),this.queue.push(t))}getNextMessage(){let t=this.queue?.shift();return t||this.emit("drained"),t}waitForDrain(){return new Promise(t=>{!this.queue||this.queue.length===0?t(!0):(this.once("drained",()=>t(!0)),this.currentDrainResolver=t,this.drainCloseListener||(this.drainCloseListener=!0,this.on("close",()=>{this.currentDrainResolver?.(!1)})))})}on(t,r){if(t==="data"&&!this.hasDataListeners)for(this.hasDataListeners=!0;this.queue?.length>0;)r(this.queue.shift());return super.on(t,r)}},wg=class{static{a(this,"EventQueueIterator")}queue;push(t){this.queue.send(t)}next(){let t=this.queue.getNextMessage();return t?{value:t}:new Promise(r=>this.queue.resolveNext=r)}return(t){return this.queue.emit("close"),{value:t,done:!0}}throw(t){return this.queue.emit("close",t),{done:!0}}}});var Pg={};je(Pg,{loadGQLSchema:()=>k4,start:()=>Dg,startOnMainThread:()=>x4});function Dg({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:u,StringValueNode:d}=await import("graphql"),_=o(new c(r.toString(),s)),E=new Map,f=[],h;for(let g of _.definitions)switch(g.kind){case l.OBJECT_TYPE_DEFINITION:let H=function(Y){if(Y.kind==="NonNullType"){let Q=H(Y.type);return Q.nullable=!1,Q}if(Y.kind==="ListType")return{type:"array",elements:H(Y.type)};let ne={type:Y.name?.value};return Object.defineProperty(ne,"location",{value:Y.loc.startToken}),ne};a(H,"getProperty");let S=g.name.value,b=[],I={table:null,database:null,properties:b};E.set(S,I);for(let Y of g.directives){if(Y.name.value==="table"){for(let ne of Y.arguments)I[ne.name.value]=ne.value.value;I.schema&&(I.database=I.schema),I.table||(I.table=S),I.audit&&(I.audit=I.audit!=="false"),I.attributes=I.properties,f.push(I)}if(Y.name.value==="sealed"&&(I.sealed=!0),Y.name.value==="splitSegments"&&(I.splitSegments=!0),Y.name.value==="replicate"&&(I.replicate=!0),Y.name.value==="export"){I.export=!0;for(let ne of Y.arguments)typeof I.export!="object"&&(I.export={}),I.export[ne.name.value]=ne.value.value}}let B=!1,X={};for(let Y of g.fields){let V=H(Y.type);V.name=Y.name.value,b.push(V),X[V.name]=void 0;for(let ne of Y.directives){let Q=ne.name.value;if(Q==="primaryKey")B?console.warn("Can not define two attributes as a primary key at",ne.loc):(V.isPrimaryKey=!0,B=!0);else if(Q==="indexed")V.indexed=!0;else if(Q==="computed"){for(let de of ne.arguments||[])if(de.name.value==="from"){let j=de.value.value;V.computed={from:m(j,de,X)},V.version==null&&(V.version=j)}else de.name.value==="version"&&(V.version=de.value.value);V.computed=V.computed||!0}else if(Q==="relationship"){let de={};for(let j of ne.arguments)de[j.name.value]=j.value.value;V.relationship=de}else if(Q==="createdTime")V.assignCreatedTime=!0;else if(Q==="updatedTime")V.assignUpdatedTime=!0;else if(Q==="expiresAt")V.expiresAt=!0;else if(Q==="allow"){let de=V.authorizedRoles=[];for(let j of ne.arguments)j.name.value==="role"&&de.push(j.value.value)}else server.knownGraphQLDirectives.includes(Q)&&console.warn(`@${Q} is an unknown directive, at`,ne.loc)}}I.type=S,S==="Query"&&(h=I)}function T(g){let S=E.get(g.type);S?(Object.defineProperty(g,"properties",{value:S.properties}),Object.defineProperty(g,"definition",{value:S})):g.type==="array"?T(g.elements):H4.includes(g.type)||(0,OD.getWorkerIndex)()===0&&console.error(`The type ${g.type} is unknown at line ${g.location.line}, column ${g.location.column}, in ${s}`)}a(T,"connectPropertyType");for(let g of E.values())for(let S of g.properties)T(S);for(let g of f)g.tableClass=e(g),g.export&&(g.export.name===""?i.set((0,Cg.dirname)(n),g.tableClass):i.set((0,Cg.dirname)(n)+"/"+(g.export.name||g.type),g.tableClass,g.export));function m(g,S,b){return new bD.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${g}; } } } } computed;`,{filename:s,lineOffset:S.loc.startToken.line-1,columnOffset:S.loc.startToken.column}).runInThisContext()(b)}a(m,"createComputedFrom")}}var Cg,bD,OD,H4,x4,k4,ND=Oe(()=>{Cg=require("path"),bD=require("node:vm");Pe();OD=L(dt()),H4=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];server.knownGraphQLDirectives&&(server.knownGraphQLDirectives=["table","sealed","export","primaryKey","indexed","computed","relationship","createdTime","updatedTime","expiresAt","allow"]);a(Dg,"start");x4=Dg,k4=Dg({ensureTable:Et}).handleFile});var MD={};je(MD,{parse:()=>Mg,streamAsJSON:()=>Xd,stringify:()=>Za});function Xd(e){return new Lg({value:e})}function ID(e){return console.error(e),JSON.stringify(e.toString())}function wD(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Za(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===PD)return LD(e);if(t.resolution)return t.resolution.then(()=>Za(e));throw t}}function LD(e){let t=typeof e;if(t==="object"){if(e===null)return"null";e.toJSON&&(e=e.toJSON());let r;if(Array.isArray(e)){r="[";for(let n=0;n<e.length;n++)n>0&&(r+=","),r+=LD(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Za(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function Mg(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),q4.test(e)?F4.parse(e):JSON.parse(e)):null}var CD,DD,F4,G4,PD,Lg,q4,Ug=Oe(()=>{CD=require("stream"),DD=L(require("json-bigint-fixes")),F4=(0,DD.default)({useNativeBigInt:!0}),G4=1e4,PD={message:"Cannot serialize BigInt to JSON"};BigInt.prototype.toJSON=function(){throw PD};a(Xd,"streamAsJSON");Lg=class extends CD.Readable{static{a(this,"JSONStream")}constructor(t){super(t),this.buffer=[],this.bufferSize=0,this.iterator=this.serialize(t.value,!0),this.activeIterators=[]}*serialize(t){if(t&&typeof t=="object"){let r=t[Symbol.asyncIterator],n=t[Symbol.iterator];if((n||r)&&!t.then){yield"[";let s=!0;if((r||n)&&!(t instanceof Array)){let i=r?t[Symbol.asyncIterator]():t[Symbol.iterator]();this.activeIterators.push(i);let o;for(;;){try{o=i.next(),o.then&&(yield o.then(c=>(o=c,""),c=>(o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")},"")))}catch(c){o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")}}if(o.done){this.activeIterators.splice(this.activeIterators.indexOf(i),1),yield"]";return}else s?s=!1:yield",",yield*this.serialize(o.value)}}for(let i of t)s?s=!1:yield",",yield*this.serialize(i);yield"]";return}if(t.then)try{yield t.then(s=>this.serialize(s),ID)}catch(s){yield ID(s)}else yield Za(t)}else yield Za(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);wD(this.readIterator(this.iterator),t=>{t?(this.done=!0,this.push(null)):this._amReading=!1},t=>{console.error(t),this.done=!0,this.push(t.toString()),this.push(null)})}}push(t){return t===null||t instanceof Buffer?(this.bufferSize>0&&this.flush(),super.push(t)):(this.bufferSize+=t.length||t.toString().length,this.buffer.push(t),this.bufferSize>G4?this.flush():!0)}flush(){let t=super.push(this.buffer.join(""));return this.buffer=[],this.bufferSize=0,t}readIterator(t){try{let r;if(t.childIterator)return wD(this.readIterator(t.childIterator),n=>{if(n)return t.childIterator=null,this.readIterator(t)});do{let n=t.next();if(n.done)return!0;if(r=n.value,r==null)r="null";else{if(r.then)return this.flush(),Promise.resolve(r).then(s=>{if(s&&typeof s.return=="function")return t.childIterator=s,this.readIterator(t);if(this.push(s+""))return this.readIterator(t)});if(typeof r.return=="function")return t.childIterator=r,this.readIterator(t)}}while(this.push(r))}catch(r){return console.error(r),this.push(r.toString()),this.push(null),!0}}_destroy(t,r){for(let n of this.activeIterators)t?n.throw(t):n.return();r()}};a(ID,"handleError");a(wD,"when");a(Za,"stringify");a(LD,"jsStringify");q4=/[[,:]\s*-?\d{16,}/;a(Mg,"parse")});var YD=N((aRe,KD)=>{"use strict";var vg=require("recursive-iterator"),$4=require("alasql"),Bg=require("clone"),UD=te(),{handleHDBError:vD,hdb_errors:V4}=_e(),{HDB_ERROR_MSGS:BD,HTTP_STATUS_CODES:HD}=V4,{getDatabases:K4}=(Pe(),oe(lt)),Y4=["DISTINCT_ARRAY"],xD=Symbol("validateTables"),Hg=Symbol("validateTable"),oRe=Symbol("getAllColumns"),kD=Symbol("validateAllColumns"),Rh=Symbol("findColumn"),FD=Symbol("validateOrderBy"),Zd=Symbol("validateSegment"),xg=Symbol("validateColumn"),GD=Symbol("setColumnsForTable"),qD=Symbol("checkColumnsForAsterisk"),$D=Symbol("validateGroupBy"),VD=Symbol("hasColumns"),kg=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[xD](),this[qD](),this[kD]()}[xD](){if(this[VD]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[Hg](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[Hg](t.table)})}}[VD](){let t=!1,r=new vg(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[Hg](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=K4();if(!r[t.databaseid])throw vD(new Error,BD.SCHEMA_NOT_FOUND(t.databaseid),HD.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw vD(new Error,BD.TABLE_NOT_FOUND(t.databaseid,t.tableid),HD.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=Bg(s);i.table=Bg(t),this.attributes.push(i)})}[Rh](t){return this.attributes.filter(r=>t.tableid?(r.table.as===t.tableid||r.table.tableid===t.tableid)&&r.attribute===t.columnid:r.attribute===t.columnid)}[qD](){let t=new vg(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[GD](r.tableid)}[GD](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new $4.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[kD](){this[Zd](this.statement.columns,!1),this[Zd](this.statement.joins,!1),this[Zd](this.statement.where,!1),this[$D](this.statement.group,!1),this[Zd](this.statement.order,!0)}[Zd](t,r){if(!t)return;let n=new vg(t),s=[];for(let{node:i,path:o}of n)!UD.isEmpty(i)&&!UD.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[FD](i):s.push(this[xg](i)));return s}[$D](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&Y4.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=Bg(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[Rh](n)[0];s&&r.push(s)}}}),this.statement.group.forEach(n=>{let s=null;if(!n.columnid)r.forEach((i,o)=>{if(i.toString()===n.toString()){s=i,r.splice(o,1);return}});else{let i=this[Rh](n);if(!i||i.length===0)throw`unknown column '${n.toString()}' in group by`;if(i.length>1)throw`ambiguously defined column '${n.toString()}' in group by`;r.forEach((o,c)=>{if(o.attribute===i[0].attribute&&o.table.tableid===i[0].table.tableid){s=o,r.splice(c,1);return}})}if(!s)throw`group by column '${n.toString()}' must be in select`}),r.length>0)throw`select column '${r[0].attribute?r[0].attribute:r[0].toString()}' must be in group by`}[FD](t){let r=this.statement.columns.filter(n=>n.as===t.columnid);if(r.length>1)throw`ambiguous column reference ${(t.tableid?t.tableid+".":"")+t.columnid} in order by`;r.length===0&&this[xg](t)}[xg](t){let r=this[Rh](t),n=(t.tableid?t.tableid+".":"")+t.columnid;if(r.length===0)throw`unknown column ${n}`;if(r.length>1)throw`ambiguous column reference ${n}`;return r[0]}};KD.exports=kg});var jD=N((lRe,WD)=>{"use strict";var Fg=class{static{a(this,"BridgeMethods")}createSchema(){throw new Error("createSchema bridge method is not defined")}dropSchema(){throw new Error("dropSchema bridge method is not defined")}createTable(){throw new Error("createTable bridge method is not defined")}dropTable(){throw new Error("dropTable bridge method is not defined")}createRecords(){throw new Error("createRecords bridge method is not defined")}updateRecords(){throw new Error("updateRecords bridge method is not defined")}async upsertRecords(){throw new Error("upsertRecords bridge method is not defined")}deleteRecords(){throw new Error("deleteRecords bridge method is not defined")}createAttribute(){throw new Error("createAttribute bridge method is not defined")}dropAttribute(){throw new Error("dropAttribute bridge method is not defined")}searchByConditions(){throw new Error("searchByConditions bridge method is not defined")}searchByHash(){throw new Error("searchByHash bridge method is not defined")}searchByValue(){throw new Error("searchByValue bridge method is not defined")}getDataByHash(){throw new Error("getDataByHash bridge method is not defined")}getDataByValue(){throw new Error("getDataByValue bridge method is not defined")}deleteRecordsBefore(){throw new Error("deleteRecordsBefore bridge method is not defined")}deleteAuditLogsBefore(){throw new Error("deleteAuditLogsBefore bridge method is not defined")}async readAuditLog(){throw new Error("readAuditLog bridge method is not defined")}};WD.exports=Fg});var QD=N((dRe,zD)=>{"use strict";var Gg=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};zD.exports=Gg});var eP={};je(eP,{HAS_EXPIRATION:()=>bh,HAS_RESIDENCY_ID:()=>zg,HAS_STRUCTURE_UPDATE:()=>Oh,LAST_TIMESTAMP_PLACEHOLDER:()=>n_,LOCAL_TIMESTAMP:()=>W4,METADATA:()=>e_,NO_TIMESTAMP:()=>$g,PENDING_LOCAL_TIME:()=>Qg,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>jg,RecordEncoder:()=>Wg,TIMESTAMP_ASSIGN_LAST:()=>z4,TIMESTAMP_ASSIGN_NEW:()=>XD,TIMESTAMP_ASSIGN_PREVIOUS:()=>ZD,TIMESTAMP_PLACEHOLDER:()=>Ah,TIMESTAMP_RECORD_PREVIOUS:()=>Vg,getUpdateRecord:()=>Jg,handleLocalTimeForGets:()=>Nh});function J4(){return r_[0]=r_[0]^64,j4.getFloat64(0)}function Nh(e){let t=e.getEntry;e.readCount=0,e.cachePuts=!1,e.getEntry=function(i,o){e.readCount++;let c=t.call(this,i,o),l=c?.value,u=l?.[e_];return u>=0&&(c.metadataFlags=u,c.localTime=l.localTime,c.value=l.value,c.residencyId=l.residencyId,l.expiresAt>=0&&(c.expiresAt=l.expiresAt)),c&&(c.key=i),c};let r=e.get;e.get=function(i,o){let c=r.call(this,i,o);return c?.[e_]>=0?c.value:c};let n=e.getRange;e.getRange=function(i){let o=n.call(this,i);return i.valuesForKey?o.map(c=>c?.value):i.values===!1||i.onlyCount?o:o.map(c=>{let l=c.value,u=l[e_];return u>=0&&(c.metadataFlags=u,c.localTime=l.localTime,c.value=l.value,c.residencyId=l.residencyId,l.expiresAt>=0&&(c.expiresAt=l.expiresAt)),c})};let s=e.useReadTransaction();if(s.done(),!s.done.isTracked){let i=s.constructor,o=s.use,c=s.done;i.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,ec.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let l=0;l<ec.length;l++){let u=ec[l].deref();(!u||u.isDone||u.isCommitted)&&ec.splice(l--,1)}},i.prototype.done.isTracked=!0}return e}function Jg(e,t,r){return function(n,s,i,o,c=-1,l,u,d="put",_,E){_||l==null?Cl=i?.localTime?Vg|ZD:$g:Cl=l?i?.localTime?Vg|16384:XD|16384:$g;let f=u?.expiresAt;if(f>=0&&(c|=bh),t_=c,Kg=f,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:Cl>0},T,m=0;try{let g=i?.residencyId,S=u?.residencyId;S&&(Yg=S,t_|=zg,m|=tc),g!==S&&(m|=rc,g||(g=0)),c&bh&&(m|=i_),u?.originatingOperation&&(m|=s_),_&&(h.ifVersion=T=i?.version??null);let b=e.put(n,s,h);if(l){let I=u?.user?.username;if(E&&(yh=e.encoder.encode(E)),e.encoder.hasStructureUpdate&&(m|=Oh,e.encoder.hasStructureUpdate=!1),_&&i?.localTime){let B=i?.localTime,H=r.get(B);if(H){let X=Ht(H).previousLocalTime;return r.put(B,Dl(o,t,n,X,u?.nodeId??server.replication.getThisNodeId(r)??0,I,d,yh,m,S,g,f),{ifVersion:T}),b}}r.put(n_,Dl(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,I,d,yh,m,S,g,f,u?.originatingOperation),{append:d!=="invalidate",instructedWrite:!0,ifVersion:T})}return b}catch(g){throw g.message+=" id: "+n+" options: "+h,g}}}var JD,qg,Ah,n_,jg,W4,e_,r_,j4,$g,XD,z4,ZD,Vg,bh,zg,Qg,Oh,Q4,yh,Cl,t_,Kg,Yg,Wg,ec,Pl=Oe(()=>{JD=require("msgpackr");Ji();qg=L(W()),Ah=new Uint8Array([1,1,1,1,4,64,0,0]),n_=new Uint8Array([1,1,1,1,1,0,0,0]),jg=new Uint8Array([1,1,1,1,3,64,0,0]),W4=Symbol("local-timestamp"),e_=Symbol("metadata"),r_=new Uint8Array(8),j4=new DataView(r_.buffer,0,8),$g=0,XD=0,z4=1,ZD=3,Vg=4,bh=16,zg=32,Qg=1,Oh=256,Cl=0,t_=-1,Kg=-1,Yg=0,Wg=class extends JD.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(Cl||t_>=0){let o=0,c=Cl;c&&(o+=8,Cl=0);let l=t_,u=Kg,d=Yg;l>=0&&(o+=2,t_=-1,u>=0&&(o+=8,Kg=-1),d&&(o+=4,Yg=0));let _=Q4=r.call(this,s,i|2048|o);yh=_.subarray((_.start||0)+o,_.end);let E=_.start||0;return c&&(Ah[4]=c,Ah[5]=c>>8,_.set(Ah,E),E+=8),l>=0&&(_[E++]=l&31,_[E++]=l>>5,u>=0&&((_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(E,u),E+=8),d&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setUint32(E,d)),_}else return r.call(this,s,i)};let n=this.saveStructures;this.saveStructures=function(s,i){let o=n.call(this,s,i);return this.hasStructureUpdate=!0,o}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(r_,0,c),c+=8;else for(let E=0;E<8;E++)r_[E]=t[c++];l=J4(),i=t[c]}let u,d;i<32&&(o=i|t[c+1]<<5,c+=2,o&bh&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&zg&&(d=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let _=r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c);return{localTime:l,value:_,[e_]:o,expiresAt:u,residencyId:d}}return r?.valueAsBuffer?t:super.decode(t,r)}catch(c){throw c.message+=", data: "+t.slice(0,40).toString("hex"),c}}};a(J4,"getTimestamp");a(Nh,"handleLocalTimeForGets");ec=[];setInterval(()=>{for(let e=0;e<ec.length;e++){let t=ec[e].deref();!t||t.isDone||t.isCommitted?ec.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(qg.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):qg.error("Read transaction detected that has been open too long (over one minute), make sure read transactions are quickly closed",t)),t.openTimer++):t.openTimer=1)}},15e3).unref();a(Jg,"getUpdateRecord")});var o_=N((pRe,rP)=>{"use strict";var tP=se(),X4=M(),{RecordEncoder:Z4}=(Pl(),oe(eP)),hRe=require("fs");tP.initSync();var eJ=tP.get(X4.CONFIG_PARAMS.STORAGE_CACHING)!==!1,Xg=class{static{a(this,"OpenDBIObject")}constructor(t,r=!1){this.dupSort=t===!0,this.encoding=t?"ordered-binary":"msgpack",this.useVersions=r,this.sharedStructuresKey=Symbol.for("structures"),r&&(this.cache=eJ&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:Z4})}};rP.exports=Xg});var a_=N((SRe,nP)=>{"use strict";var Un=se(),as=M();Un.initSync();var Ih=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Un.get(as.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Un.get(as.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Un.get(as.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Un.get(as.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Un.get(as.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Un.get(as.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Un.get(as.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Un.get(as.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};nP.exports=Ih;Ih.MAX_DBS=1e4});var ht=N((gRe,fP)=>{"use strict";var eR=require("lmdb"),Fs=require("fs-extra"),vn=require("path"),wh=cn(),oP=W(),ln=Dn().LMDB_ERRORS_ENUM,Ch=QD(),tR=o_(),aP=a_(),Wo=Bt(),sP=M(),{table:tJ,resetDatabases:rJ}=(Pe(),oe(lt)),iP=se(),Gs=Wo.INTERNAL_DBIS_NAME,cP=Wo.DBI_DEFINITION_NAME,nJ="data.mdb",sJ="lock.mdb",c_=".mdb",iJ="-lock",Zg=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=cs(t,r),this.key_type=this.dbi[Wo.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[Wo.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new eR.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function Dh(e,t){if(e===void 0)throw new Error(ln.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(ln.ENV_NAME_REQUIRED)}a(Dh,"pathEnvNameValidation");async function rR(e,t,r=!0){try{await Fs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(ln.INVALID_BASE_PATH):n}try{let n=vn.join(e,t+c_);return await Fs.access(n,Fs.constants.R_OK|Fs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Fs.access(vn.join(e,t,nJ),Fs.constants.R_OK|Fs.constants.F_OK),vn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(ln.INVALID_ENVIRONMENT)}else throw new Error(ln.INVALID_ENVIRONMENT);throw n}}a(rR,"validateEnvironmentPath");function Ph(e,t){if(wh.validateEnv(e),t===void 0)throw new Error(ln.DBI_NAME_REQUIRED)}a(Ph,"validateEnvDBIName");async function oJ(e,t,r=!1,n=!1){Dh(e,t);let s=vn.basename(e);t=t.toString();let i=iP.get(sP.CONFIG_PARAMS.DATABASES);i||iP.setProperty(sP.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await rR(e,t,n),lP(e,t,r)}catch(o){if(o.message===ln.INVALID_ENVIRONMENT){let c=vn.join(e,t);await Fs.mkdirp(n?c:e);let l=new aP(n?c:c+c_,!1),u=eR.open(l);u.dbis=Object.create(null);let d=new tR(!1);u.openDB(Gs,d),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let _=nR(e,t,r);return u[Wo.ENVIRONMENT_NAME_KEY]=_,global.lmdb_map[_]=u,u}throw o}}a(oJ,"createEnvironment");async function aJ(e,t,r,n=!0){Dh(e,t),t=t.toString();let s=vn.join(e,t);return tJ({table:t,database:vn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(aJ,"copyEnvironment");async function lP(e,t,r=!1){Dh(e,t),t=t.toString();let n=nR(e,t,r);if(global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null)),global.lmdb_map[n]!==void 0)return global.lmdb_map[n];let s=await rR(e,t),i=vn.join(e,t+c_),o=s!=i,c=new aP(s,o),l=eR.open(c);l.dbis=Object.create(null);let u=dP(l);for(let d=0;d<u.length;d++)cs(l,u[d]);return l[Wo.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(lP,"openEnvironment");async function cJ(e,t,r=!1){Dh(e,t),t=t.toString();let n=vn.join(e,t+c_),s=await rR(e,t);if(global.lmdb_map!==void 0){let i=nR(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await uP(o),delete global.lmdb_map[i]}}await Fs.remove(s),await Fs.remove(s===n?s+iJ:vn.join(vn.dirname(s),sJ))}a(cJ,"deleteEnvironment");async function uP(e){wh.validateEnv(e);let t=e[Wo.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(uP,"closeEnvironment");function nR(e,t,r=!1){let s=`${vn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(nR,"getCachedEnvironmentName");function lJ(e){wh.validateEnv(e);let t=Object.create(null),r=cs(e,Gs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Gs)try{t[n]=Object.assign(new Ch,s)}catch{oP.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(lJ,"listDBIDefinitions");function dP(e){wh.validateEnv(e);let t=[],r=cs(e,Gs);for(let{key:n}of r.getRange({start:!1}))n!==Gs&&t.push(n);return t}a(dP,"listDBIs");function uJ(e,t){let n=cs(e,Gs).getEntry(t),s=new Ch;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{oP.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(uJ,"getDBIDefinition");function _P(e,t,r,n=!r){if(Ph(e,t),t=t.toString(),t===Gs)throw new Error(ln.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return cs(e,t)}catch(s){if(s.message===ln.DBI_DOES_NOT_EXIST){let i=new tR(r,n===!0),o=e.openDB(t,i),c=new Ch(r===!0,n);return o[cP]=c,cs(e,Gs).putSync(t,c),e.dbis[t]=o,o}throw s}}a(_P,"createDBI");function cs(e,t){if(Ph(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Gs?r=uJ(e,t):r=new Ch,r===void 0)throw new Error(ln.DBI_DOES_NOT_EXIST);let n;try{let s=new tR(r.dup_sort,r.useVersions);if(n=e.openDB(t,s),n.db===void 0)throw new Error("MDB_NOTFOUND")}catch(s){throw s.message.includes("MDB_NOTFOUND")===!0?new Error(ln.DBI_DOES_NOT_EXIST):s}return n[cP]=r,e.dbis[t]=n,n}a(cs,"openDBI");function dJ(e,t){Ph(e,t),t=t.toString();let r=cs(e,t),n=r.getStats();return r[Wo.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(dJ,"statDBI");async function _J(e,t){try{let r=vn.join(e,t+c_);return(await Fs.stat(r)).size}catch{throw new Error(ln.INVALID_ENVIRONMENT)}}a(_J,"environmentDataSize");function fJ(e,t){if(Ph(e,t),t=t.toString(),t===Gs)throw new Error(ln.CANNOT_DROP_INTERNAL_DBIS_NAME);cs(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],cs(e,Gs).removeSync(t)}a(fJ,"dropDBI");function EJ(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{cs(e,i)}catch(o){if(o.message===ln.DBI_DOES_NOT_EXIST)_P(e,i,i!==t,i===t),n=!0;else throw o}}n&&rJ()}a(EJ,"initializeDBIs");fP.exports={openDBI:cs,openEnvironment:lP,createEnvironment:oJ,listDBIs:dP,listDBIDefinitions:lJ,createDBI:_P,dropDBI:fJ,statDBI:dJ,deleteEnvironment:cJ,initializeDBIs:EJ,TransactionCursor:Zg,environmentDataSize:_J,copyEnvironment:aJ,closeEnvironment:uP}});var hP=N((ARe,EP)=>{"use strict";var sR=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};EP.exports=sR});var mP=N((bRe,pP)=>{"use strict";var iR=class{static{a(this,"UpdateRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n,this.original_records=s}};pP.exports=iR});var TP=N((NRe,SP)=>{"use strict";var oR=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};SP.exports=oR});var sc=N((PRe,AP)=>{"use strict";var hJ=ht(),pJ=hP(),mJ=mP(),SJ=TP(),mi=cn(),l_=Dn().LMDB_ERRORS_ENUM,TJ=Bt(),Xi=M(),gJ=te(),RJ=require("uuid"),wRe=require("lmdb"),{handleHDBError:AJ,hdb_errors:yJ}=_e(),{OVERFLOW_MARKER:CRe,MAX_SEARCH_KEY_LENGTH:DRe}=TJ,gP=se();gP.initSync();var Lh=gP.get(Xi.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),aR=Xi.TIME_STAMP_NAMES_ENUM.CREATED_TIME,nc=Xi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function bJ(e,t,r,n,s=mi.getNextMonotonicTime()){dR(e,t,r,n),cR(e,t,r);let i=new pJ,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];RP(u,!0,s);let d=OJ(e,t,r,u),_=u[t];o.push(d),c.push(_)}return lR(o,c,n,i,s)}a(bJ,"insertRecords");function OJ(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let d=c([[{}]]);Array.isArray(d)&&(c=d[0][Xi.FUNC_VAL],n[o]=c)}let l=mi.getIndexedValues(c),u=e.dbis[o];if(l){Lh&&u.prefetch(l.map(d=>({key:d,value:s})),Mh);for(let d=0,_=l.length;d<_;d++)u.put(l[d],s)}}Lh&&e.dbis[t].prefetch([s],Mh),e.dbis[t].put(s,n,n[nc])})}a(OJ,"insertRecord");function NJ(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(NJ,"removeSkippedRecords");function RP(e,t,r){let n=r>0;(n||!Number.isInteger(e[nc]))&&(e[nc]=r||(r=mi.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[aR]))&&(e[aR]=r||mi.getNextMonotonicTime()):delete e[aR]}a(RP,"setTimestamps");function cR(e,t,r){r.indexOf(Xi.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Xi.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Xi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Xi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),hJ.initializeDBIs(e,t,r)}a(cR,"initializeTransaction");async function IJ(e,t,r,n,s=mi.getNextMonotonicTime()){dR(e,t,r,n),cR(e,t,r);let i=new mJ,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let d=n[u],_=d[t],E;try{E=uR(e,t,d,_,i,!0,s)}catch{i.skipped_hashes.push(_),o.push(u);continue}c.push(E),l.push(_)}return lR(c,l,n,i,s,o)}a(IJ,"updateRecords");async function wJ(e,t,r,n,s=mi.getNextMonotonicTime()){try{dR(e,t,r,n)}catch(l){throw AJ(l,l.message,yJ.HTTP_STATUS_CODES.BAD_REQUEST)}cR(e,t,r);let i=new SJ,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],d;gJ.isEmpty(u[t])?(d=RJ.v4(),u[t]=d):d=u[t];let _=uR(e,t,u,d,i,!1,s);o.push(_),c.push(d)}return lR(o,c,n,i,s)}a(wJ,"upsertRecords");async function lR(e,t,r,n,s,i=[]){let o=await Promise.all(e);for(let c=0,l=o.length;c<l;c++)o[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||mi.getNextMonotonicTime(),NJ(r,i),n}a(lR,"finalizeWrite");function uR(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),u=l?.value,d=u;if(!u){if(i)return!1;u={}}if(RP(r,!d,o),Number.isInteger(r[nc])&&u[nc]>r[nc])return!1;d&&s.original_records.push(u);let _,E=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let T=r[h],m=e.dbis[h];if(m===void 0)continue;let g=u[h];if(typeof T=="function"){let b=T([[u]]);Array.isArray(b)&&(T=b[0][Xi.FUNC_VAL],r[h]=T)}if(T===g)continue;let S=mi.getIndexedValues(g);if(S){Lh&&m.prefetch(S.map(b=>({key:b,value:n})),Mh);for(let b=0,I=S.length;b<I;b++)m.remove(S[b],n)}if(S=mi.getIndexedValues(T),S){Lh&&m.prefetch(S.map(b=>({key:b,value:n})),Mh);for(let b=0,I=S.length;b<I;b++)m.put(S[b],n)}}let f={...u,...r};c.put(n,f,f[nc])},"do_put");return l?_=c.ifVersion(n,l.version,E):_=c.ifNoExists(n,E),_.then(f=>f?!0:uR(e,t,r,n,s,i,o))}a(uR,"updateUpsertRecord");function CJ(e,t,r){if(mi.validateEnv(e),t===void 0)throw new Error(l_.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(l_.WRITE_ATTRIBUTES_REQUIRED):new Error(l_.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(CJ,"validateBasic");function dR(e,t,r,n){if(CJ(e,t,r),!Array.isArray(n))throw n===void 0?new Error(l_.RECORDS_REQUIRED):new Error(l_.RECORDS_MUST_BE_ARRAY)}a(dR,"validateWrite");function Mh(){}a(Mh,"noop");AP.exports={insertRecords:bJ,updateRecords:IJ,upsertRecords:wJ}});var Zi=N((MRe,DJ)=>{DJ.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"}]},hdb_certificate:{hash_attribute:"name",name:"hdb_certificate",schema:"system",attributes:[{attribute:"name"},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var Ti=N((URe,OP)=>{"use strict";var bP=te(),yP=M(),Ll=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Si=require("joi"),jo={schema_format:{pattern:Ll,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},PJ=Si.alternatives(Si.string().min(1).max(jo.schema_length.maximum).pattern(Ll).messages({"string.pattern.base":"{:#label} "+jo.schema_format.message}),Si.number(),Si.array()).required(),LJ=Si.alternatives(Si.string().min(1).max(jo.schema_length.maximum).pattern(Ll).messages({"string.pattern.base":"{:#label} "+jo.schema_format.message}),Si.number()),MJ=Si.alternatives(Si.string().min(1).max(jo.schema_length.maximum).pattern(Ll).messages({"string.pattern.base":"{:#label} "+jo.schema_format.message}),Si.number()).required();function UJ(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>jo.schema_length.maximum?`'${e}' maximum of 250 characters`:Ll.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(UJ,"checkValidTable");function vJ(e,t){return bP.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(vJ,"validateSchemaExists");function BJ(e,t){let r=t.state.ancestors[0].schema;return bP.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(BJ,"validateTableExists");function HJ(e,t){return e.toLowerCase()===yP.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${yP.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(HJ,"validateSchemaName");OP.exports={common_validators:jo,schema_regex:Ll,hdb_schema_table:PJ,validateSchemaExists:vJ,validateTableExists:BJ,validateSchemaName:HJ,checkValidTable:UJ,hdb_database:LJ,hdb_table:MJ}});var Uh=N((BRe,NP)=>{var{common_validators:gi}=Ti(),d_=Tt(),u_="is required",rr={database:{presence:!1,format:gi.schema_format,length:gi.schema_length},schema:{presence:!1,format:gi.schema_format,length:gi.schema_length},table:{presence:!0,format:gi.schema_format,length:gi.schema_length},attribute:{presence:!0,format:gi.schema_format,length:gi.schema_length},hash_attribute:{presence:!0,format:gi.schema_format,length:gi.schema_length}};function __(e){for(let t in e)e[t]=e[t]===null||e[t]===void 0||typeof e[t]=="object"?e[t]:e[t].toString();return e}a(__,"makeAttributesStrings");function xJ(e){return e=__(e),rr.table.presence=!1,rr.attribute.presence=!1,rr.hash_attribute.presence=!1,d_.validateObject(e,rr)}a(xJ,"schema_object");function kJ(e){return e=__(e),rr.table.presence={message:u_},rr.attribute.presence=!1,rr.hash_attribute.presence=!1,d_.validateObject(e,rr)}a(kJ,"table_object");function FJ(e){return e=__(e),rr.table.presence={message:u_},rr.attribute.presence=!1,d_.validateObject(e,rr)}a(FJ,"create_table_object");function GJ(e){return e=__(e),rr.table.presence={message:u_},rr.attribute.presence={message:u_},rr.hash_attribute.presence=!1,d_.validateObject(e,rr)}a(GJ,"attribute_object");function qJ(e){return e=__(e),rr.table.presence={message:u_},rr.attribute.presence=!1,rr.hash_attribute.presence=!1,d_.validateObject(e,rr)}a(qJ,"describe_table");function $J(e){if(e){if(!Array.isArray(e))throw new Error("residence must be a string array");if(e.length===0)throw new Error("residence cannot be an empty array");for(let t=0;t<e.length;t++)if(typeof e[t]!="string")throw new Error(`residence must be a string array, item '${e[t]}' is not a string`)}}a($J,"validateTableResidence");NP.exports={schema_object:xJ,create_table_object:FJ,table_object:kJ,attribute_object:GJ,describe_table:qJ,validateTableResidence:$J}});var wP=N((xRe,IP)=>{"use strict";var VJ=require("uuid"),_R=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||VJ.v4(),this.schema_table=`${this.schema}.${this.table}`}};IP.exports=_R});var vh=N((FRe,CP)=>{"use strict";var KJ=wP(),fR=class extends KJ{static{a(this,"LMDBCreateAttributeObject")}constructor(t,r,n,s,i=!0,o=!1){super(t,r,n,s),this.dup_sort=i,this.is_hash_attribute=o}};CP.exports=fR});var PP=N((qRe,DP)=>{"use strict";DP.exports=WJ;var YJ="inserted";function WJ(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===YJ?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(WJ,"returnObject")});var Bh=N((KRe,vP)=>{"use strict";var jJ=M(),ER=ht(),zJ=sc(),{getSystemSchemaPath:QJ,getSchemaPath:JJ}=gt(),VRe=Zi(),XJ=Uh(),ZJ=vh(),e3=PP(),{handleHDBError:LP,hdb_errors:UP}=_e(),MP=te(),{HTTP_STATUS_CODES:t3}=UP,r3="inserted";vP.exports=n3;async function n3(e){let t=XJ.attribute_object(e);if(t)throw LP(new Error,t.message,UP.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&MP.checkGlobalSchemaTable(e.schema,e.table);if(r)throw LP(new Error,r,t3.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=MP.isEmpty(e.dup_sort)||e.dup_sort=="true";let n=[];if(global.hdb_schema[e.schema]&&global.hdb_schema[e.schema][e.table]&&(n=global.hdb_schema[e.schema][e.table].attributes),Array.isArray(n)&&n.length>0){for(let i of n)if(i.attribute===e.attribute)throw new Error(`attribute '${i.attribute}' already exists in ${e.schema}.${e.table}`)}let s=new ZJ(e.schema,e.table,e.attribute,e.id);try{let i=await ER.openEnvironment(JJ(e.schema,e.table),e.table);if(i.dbis[e.attribute]!==void 0)throw new Error(`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`);ER.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await ER.openEnvironment(QJ(),jJ.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await zJ.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return e3(r3,c,{records:[s]},l)}catch(i){throw i}}a(n3,"lmdbCreateAttribute")});var pR=N((WRe,HP)=>{var{hdb_table:s3,hdb_database:BP}=Ti(),i3=Tt(),hR=require("joi"),o3={undefined:"undefined",null:"null"},a3=a((e,t)=>{let r=Object.keys(e),n=r.length,s;for(let i=0;i<n;i++){let o=r[i];(!o||o.length===0||o3[o]!==void 0)&&(s===void 0?s=`Invalid attribute name: '${o}'`:s+=`. Invalid attribute name: '${o}'`)}return s?t.message(s):e},"custom_records_val"),c3=hR.object({database:BP,schema:BP,table:s3,records:hR.array().items(hR.object().custom(a3)).required()});HP.exports=function(e){return i3.validateBySchema(e,c3)}});var f_=N((QRe,kP)=>{"use strict";var eo=te(),xP=W(),zRe=pR(),{getDatabases:l3}=(Pe(),oe(lt)),{ClientError:ic}=_e();kP.exports=u3;function u3(e){if(eo.isEmpty(e))throw new ic("invalid update parameters defined.");if(eo.isEmptyOrZeroLength(e.schema))throw new ic("invalid schema specified.");if(eo.isEmptyOrZeroLength(e.table))throw new ic("invalid table specified.");if(!Array.isArray(e.records))throw new ic("records must be an array");let t=l3()[e.schema]?.[e.table];if(eo.isEmpty(t))throw new ic(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&eo.isEmptyOrZeroLength(o[r]))throw xP.error("a valid hash attribute must be provided with update record:",o),new ic("a valid hash attribute must be provided with update record, check log for more info");if(!eo.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw xP.error(`a valid hash value must be provided with ${e.operation} record:`,o),new ic(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!eo.isEmpty(o[r])&&o[r]!==""&&n.has(eo.autoCast(o[r]))&&(o.skip=!0),n.add(eo.autoCast(o[r]));for(let c in o)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}a(u3,"insertUpdateValidate")});var GP=N((XRe,FP)=>{"use strict";var mR=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};FP.exports=mR});var VP=N((eAe,$P)=>{"use strict";var SR=ht(),d3=W(),qP=Dn().LMDB_ERRORS_ENUM;$P.exports=_3;async function _3(e){try{if(global.lmdb_map!==void 0&&e.operation!==void 0){let t=Object.keys(global.lmdb_map),r;switch(e.operation){case"drop_schema":for(let i=0;i<t.length;i++){let o=t[i];if(o.startsWith(`${e.schema}.`)||o.startsWith(`txn.${e.schema}.`))try{await SR.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==qP.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await SR.closeEnvironment(global.lmdb_map[n]),await SR.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==qP.ENV_REQUIRED)throw i}break;case"drop_attribute":r=global.lmdb_map[`${e.schema}.${e.table}`],r!==void 0&&typeof r.dbis=="object"&&r.dbis[`${e.attribute}`]!==void 0&&delete r.dbis[`${e.attribute}`];break;default:break}}}catch(t){d3.error(t)}}a(_3,"cleanLMDBMap")});var to=N((rAe,jP)=>{"use strict";var E_=require("crypto"),f3=se(),{CONFIG_PARAMS:E3}=M(),YP="aes-256-cbc",h3=32,p3=16,TR=64,WP=32,m3=TR+WP,KP=new Map;jP.exports={encrypt:S3,decrypt:T3,createNatsTableStreamName:g3};function S3(e){let t=E_.randomBytes(h3),r=E_.randomBytes(p3),n=E_.createCipheriv(YP,Buffer.from(t),r),s=n.update(e);s=Buffer.concat([s,n.final()]);let i=t.toString("hex"),o=r.toString("hex"),c=s.toString("hex");return i+o+c}a(S3,"encrypt");function T3(e){let t=e.substr(0,TR),r=e.substr(TR,WP),n=e.substr(m3,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=E_.createDecipheriv(YP,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(T3,"decrypt");function g3(e,t){let r=f3.get(E3.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=KP.get(r);return n||(n=E_.createHash("md5").update(r).digest("hex"),KP.set(r,n)),n}a(g3,"createNatsTableStreamName")});var ro=N((iAe,JP)=>{"use strict";var sAe=Vr(),h_=W(),zP=Uh(),R3=to(),Hh=te(),{handleHDBError:xh,hdb_errors:A3}=_e(),{HDB_ERROR_MSGS:kh,HTTP_STATUS_CODES:gR}=A3,QP=se();QP.initSync();var{getDatabases:RR}=(Pe(),oe(lt)),y3=require("fs-extra"),b3=M();JP.exports={describeAll:O3,describeTable:Fh,describeSchema:N3};async function O3(e={}){try{let t=Hh.isEmptyOrZeroLength(e),r=!!e.bypass_auth,n,s;!t&&!r&&(n=e.hdb_user?.role?.permission,s=n?.super_user||n?.cluster_user);let i=RR(),o={},c={},l=[],u=e?.exact_count;for(let _ in i){o[_]=!0,!t&&!s&&!r&&(c[_]=e.hdb_user?.role?.permission[_]?.describe);let E=i[_];for(let f in E)try{let h;if(t||s||r)h=await Fh({schema:_,table:f,exact_count:u});else if(n&&n[_].describe&&n[_].tables[f].describe){let T=n[_].tables[f].attribute_permissions;h=await Fh({schema:_,table:f,exact_count:u},T)}h&&l.push(h)}catch(h){h_.error(h)}}let d={};for(let _ in l)t||s||r?(d[l[_].schema]==null&&(d[l[_].schema]={}),d[l[_].schema][l[_].name]=l[_],o[l[_].schema]&&delete o[l[_].schema]):c[l[_].schema]&&(d[l[_].schema]==null&&(d[l[_].schema]={}),d[l[_].schema][l[_].name]=l[_],o[l[_].schema]&&delete o[l[_].schema]);for(let _ in o)t||s||r?d[_]={}:c[_]&&(d[_]={});return d}catch(t){return h_.error("Got an error in describeAll"),h_.error(t),xh(new Error,kh.DESCRIBE_ALL_ERR)}}a(O3,"describeAll");async function Fh(e,t){Hh.transformReq(e);let{schema:r,table:n}=e;r=r?.toString(),n=n?.toString();let s=t;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(s=e.hdb_user?.role?.permission[r]?.tables[n]?.attribute_permissions);let i=zP.describe_table(e);if(i)throw i;let c=RR()[r];if(!c)throw xh(new Error,kh.SCHEMA_NOT_FOUND(e.schema),gR.NOT_FOUND);let l=c[n];if(!l)throw xh(new Error,kh.TABLE_NOT_FOUND(e.schema,e.table),gR.NOT_FOUND);function u(f){d.push({attribute:f.attribute,type:f.type,elements:f.elements?.type,indexed:f.indexed,is_primary_key:f.isPrimaryKey,assigned_created_time:f.assignCreatedTime,assigned_updated_time:f.assignUpdatedTime,nullable:f.nullable,properties:f.properties?f.properties.map(h=>({type:h.type,name:h.name})):void 0})}a(u,"pushAtt");let d=[];if(s){let f={};s.forEach(h=>{h.describe&&(f[h.attribute_name]=!0)}),l.attributes.forEach(h=>{f[h.name]&&u(h)})}else l.attributes?.forEach(f=>u(f));let _;try{_=(await y3.stat(l.primaryStore.env.path)).size}catch(f){h_.warn("unable to get database size",f)}let E={schema:r,name:l.tableName,hash_attribute:l.attributes.find(f=>f.isPrimaryKey||f.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:d,db_size:_};l.replicate!==void 0&&(E.replicate=l.replicate),l.expirationMS!==void 0&&(E.expiration=l.expirationMS/1e3+"s"),l.sealed!==void 0&&(E.sealed=l.sealed),l.sources?.length>0&&(E.sources=l.sources.map(f=>f.name).filter(f=>f&&f!=="NATSReplicator"&&f!=="Replicator")),QP.get(b3.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(E.clustering_stream_name=R3.createNatsTableStreamName(E.schema,E.name));try{let f=l.getRecordCount({exactCount:e.exact_count==="true"});E.record_count=f.recordCount,E.table_size=l.getSize(),E.estimated_record_range=f.estimatedRange;let h=l.auditStore;if(h)for(let T of h.getKeys({reverse:!0,limit:1}))E.last_updated_record=T[0];if(!E.last_updated_record&&l.indices.__updatedtime__)for(let T of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))E.last_updated_record=T}catch(f){h_.warn(`unable to stat table dbi due to ${f}`)}return E}a(Fh,"descTable");async function N3(e){Hh.transformReq(e);let t=zP.schema_object(e);if(t)throw t;let r;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(r=e.hdb_user?.role?.permission[e.schema]);let n=e.schema.toString(),i=RR()[n];if(!i)throw xh(new Error,kh.SCHEMA_NOT_FOUND(e.schema),gR.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),Hh.isEmpty(l)||l.describe){let u=await Fh({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(N3,"describeSchema")});var ls=N((lAe,rL)=>{var I3=Zi(),{callbackify:ZP,promisify:w3}=require("util"),{getDatabases:eL}=(Pe(),oe(lt));rL.exports={setSchemaDataToGlobal:XP,getTableSchema:C3,getSystemSchema:D3,setSchemaDataToGlobalAsync:w3(XP)};var tL=ro(),aAe=ZP(tL.describeAll),cAe=ZP(tL.describeTable);function XP(e){global.hdb_schema=eL(),e&&e()}a(XP,"setSchemaDataToGlobal");function C3(e,t,r){let n=eL()[e];if(!n)return r(`schema ${e} does not exist`);let s=n[t];return s?r(null,{schema:e,name:t,hash_attribute:s.primaryKey}):r(`table ${e}.${t} does not exist`)}a(C3,"getTableSchema");function D3(){return I3}a(D3,"getSystemSchema")});var un=N((dAe,oL)=>{"use strict";var qh=pR(),Cr=te(),P3=require("util"),$h=Bn(),L3=ls(),nL=W(),{handleHDBError:oc,hdb_errors:M3}=_e(),{HTTP_STATUS_CODES:ac}=M3,U3=P3.promisify(L3.getTableSchema),v3="updated",sL="inserted",iL="upserted";oL.exports={insert:H3,update:x3,upsert:k3,validation:B3,flush:F3};async function B3(e){if(Cr.isEmpty(e))throw new Error("invalid update parameters defined.");if(Cr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Cr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await U3(e.schema,e.table),r=qh(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let n=t.hash_attribute,s=new Set,i={},o=!1;return e.operation==="update"&&(o=!0),e.records.forEach(c=>{if(o&&Cr.isEmptyOrZeroLength(c[n]))throw nL.error("a valid hash attribute must be provided with update record:",c),new Error("a valid hash attribute must be provided with update record");if(!Cr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw nL.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Cr.isEmpty(c[n])&&c[n]!==""&&s.has(Cr.autoCast(c[n]))&&(c.skip=!0),s.add(Cr.autoCast(c[n]));for(let l in c)i[l]=1}),i[n]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(i)}}a(B3,"validation");async function H3(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=qh(e);if(t)throw oc(new Error,t.message,ac.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw oc(new Error,r,ac.BAD_REQUEST);let n=await $h.createRecords(e);return Gh(sL,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(H3,"insertData");async function x3(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=qh(e);if(t)throw oc(new Error,t.message,ac.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw oc(new Error,r,ac.BAD_REQUEST);let n=await $h.updateRecords(e);return Cr.isEmpty(n.existing_rows)?Gh(v3,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):Gh(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(x3,"updateData");async function k3(e){if(e.operation!=="upsert")throw oc(new Error,"invalid operation, must be upsert",ac.INTERNAL_SERVER_ERROR);let t=qh(e);if(t)throw oc(new Error,t.message,ac.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw oc(new Error,r,ac.BAD_REQUEST);let n=await $h.upsertRecords(e);return Gh(iL,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(k3,"upsertData");function Gh(e,t,r,n,s,i){let o={message:`${e} ${t.length} of ${t.length+n.length} records`,new_attributes:s,txn_time:i};return e===sL?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===iL?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(Gh,"returnObject");function F3(e){return Cr.transformReq(e),$h.flush(e.schema,e.table)}a(F3,"flush")});var yR=N((fAe,lL)=>{var G3=Tt(),AR=require("joi"),{hdb_table:q3,hdb_database:aL}=Ti(),cL={schema:aL,database:aL,table:q3},$3={date:AR.date().iso().required()},V3={timestamp:AR.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};lL.exports=function(e,t){let r=t==="timestamp"?{...cL,...V3}:{...cL,...$3},n=AR.object(r);return G3.validateBySchema(e,n)}});var _L=N((EAe,dL)=>{var K3=Tt(),bR=require("joi"),{hdb_table:Y3,hdb_database:uL}=Ti(),W3=bR.object({schema:uL,database:uL,table:Y3,hash_values:bR.array().required(),ids:bR.array()});dL.exports=function(e){return K3.validateBySchema(e,W3)}});var wR=N((hAe,fL)=>{"use strict";var OR=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i){this.operation=t,this.schema=r,this.table=n,this.hash_attribute=s,this.records=i}},NR=class{static{a(this,"NoSQLSeachObject")}constructor(t,r,n,s,i,o){this.schema=t,this.table=r,this.search_attribute=n,this.hash_attribute=s,this.get_attributes=i,this.search_value=o}},IR=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};fL.exports={InsertObject:OR,NoSQLSeachObject:NR,DeleteResponseObject:IR}});var uc=N((mAe,SL)=>{"use strict";var hL=yR(),j3=_L(),cc=te(),EL=require("moment"),pL=W(),{promisify:z3,callbackify:Q3}=require("util"),lc=M(),J3=ls(),CR=z3(J3.getTableSchema),DR=Bn(),{DeleteResponseObject:X3}=wR(),{handleHDBError:zo,hdb_errors:Z3}=_e(),{HDB_ERROR_MSGS:Vh,HTTP_STATUS_CODES:Qo}=Z3,eX="records successfully deleted",tX=Q3(mL);SL.exports={delete:tX,deleteRecord:mL,deleteFilesBefore:rX,deleteAuditLogsBefore:nX};async function rX(e){let t=hL(e,"date");if(t)throw zo(t,t.message,Qo.BAD_REQUEST,void 0,void 0,!0);if(cc.transformReq(e),!EL(e.date,EL.ISO_8601).isValid())throw zo(new Error,Vh.INVALID_DATE,Qo.BAD_REQUEST,lc.LOG_LEVELS.ERROR,Vh.INVALID_DATE,!0);let n=cc.checkSchemaTableExist(e.schema,e.table);if(n)throw zo(new Error,n,Qo.NOT_FOUND,lc.LOG_LEVELS.ERROR,n,!0);let s=await DR.deleteRecordsBefore(e);if(await CR(e.schema,e.table),pL.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(rX,"deleteFilesBefore");async function nX(e){let t=hL(e,"timestamp");if(t)throw zo(t,t.message,Qo.BAD_REQUEST,void 0,void 0,!0);if(cc.transformReq(e),isNaN(e.timestamp))throw zo(new Error,Vh.INVALID_VALUE("Timestamp"),Qo.BAD_REQUEST,lc.LOG_LEVELS.ERROR,Vh.INVALID_VALUE("Timestamp"),!0);let r=cc.checkSchemaTableExist(e.schema,e.table);if(r)throw zo(new Error,r,Qo.NOT_FOUND,lc.LOG_LEVELS.ERROR,r,!0);let n=await DR.deleteAuditLogsBefore(e);return await CR(e.schema,e.table),pL.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(nX,"deleteAuditLogsBefore");async function mL(e){e.ids&&(e.hash_values=e.ids);let t=j3(e);if(t)throw zo(t,t.message,Qo.BAD_REQUEST,void 0,void 0,!0);cc.transformReq(e);let r=cc.checkSchemaTableExist(e.schema,e.table);if(r)throw zo(new Error,r,Qo.NOT_FOUND,lc.LOG_LEVELS.ERROR,r,!0);try{await CR(e.schema,e.table);let n=await DR.deleteRecords(e);return cc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${eX}`),n}catch(n){if(n.message===lc.SEARCH_NOT_FOUND_MESSAGE){let s=new X3;return s.message=lc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(mL,"deleteRecord")});var Kh=N((TAe,RL)=>{var sX=require("crypto"),TL=9;function iX(e){let t=aX(TL),r=gL(e+t);return t+r}a(iX,"createHash");function oX(e,t){let r=e?.substr(0,TL),n=r+gL(t+r);return e===n}a(oX,"validateHash");function aX(e){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ",r=t.length,n="";for(let s=0;s<e;s++){let i=Math.floor(Math.random()*r);n+=t[i]}return n}a(aX,"generateSalt");function gL(e){return sX.createHash("md5").update(e).digest("hex")}a(gL,"md5");RL.exports={hash:iX,validate:oX}});var yL=N((RAe,AL)=>{var PR=Tt(),Kr={username:{presence:!0,exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function cX(e){return Kr.password.presence=!0,Kr.username.presence=!0,Kr.role.presence=!0,Kr.active.presence=!0,PR.validateObject(e,Kr)}a(cX,"addUserValidation");function lX(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,PR.validateObject(e,Kr)}a(lX,"alterUserValidation");function uX(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,PR.validateObject(e,Kr)}a(uX,"dropUserValidation");AL.exports={addUserValidation:cX,alterUserValidation:lX,dropUserValidation:uX}});var Ct=N((bAe,OL)=>{"use strict";var{platform:yAe}=require("os"),dX="nats-server.zip",LR="nats-server",_X=process.platform==="win32"?`${LR}.exe`:LR,fX=/^[^\s.,*>]+$/,bL="__request__",EX=a(e=>`${e}.${bL}`,"REQUEST_SUBJECT"),hX={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},pX={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},mX={HUB:"hub.pid",LEAF:"leaf.pid"},SX={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},TX={SUCCESS:"success",ERROR:"error"},gX={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},RX={TXN:"txn",MSGID:"msgid"},Ml={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},AX={[Ml.ERR]:1,[Ml.WRN]:2,[Ml.INF]:3,[Ml.DBG]:4,[Ml.TRC]:5},yX={debug:"-D",trace:"-DVV"};OL.exports={NATS_SERVER_ZIP:dX,NATS_SERVER_NAME:LR,NATS_BINARY_NAME:_X,PID_FILES:mX,NATS_CONFIG_FILES:pX,SERVER_SUFFIX:SX,NATS_TERM_CONSTRAINTS_RX:fX,REQUEST_SUFFIX:bL,UPDATE_REMOTE_RESPONSE_STATUSES:TX,CLUSTER_STATUS_STATUSES:gX,REQUEST_SUBJECT:EX,SUBJECT_PREFIXES:RX,MSG_HEADERS:hX,LOG_LEVELS:Ml,LOG_LEVEL_FLAGS:yX,LOG_LEVEL_HIERARCHY:AX}});var IL=N((NAe,NL)=>{"use strict";var Yh=M(),Wh=class{static{a(this,"BaseLicense")}constructor(t=0,r=Yh.RAM_ALLOCATION_ENUM.DEFAULT,n=Yh.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},MR=class extends Wh{static{a(this,"ExtendedLicense")}constructor(t=0,r=Yh.RAM_ALLOCATION_ENUM.DEFAULT,n=Yh.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};NL.exports={BaseLicense:Wh,ExtendedLicense:MR}});var dc=N((wAe,UL)=>{"use strict";var vl=require("fs-extra"),CL=Kh(),DL=require("crypto"),bX=require("moment"),OX=require("uuid").v4,Yr=W(),vR=require("path"),NX=te(),Jo=M(),{totalmem:wL}=require("os"),IX=IL().ExtendedLicense,Ul="invalid license key format",wX="061183",CX="mofi25",DX="aes-256-cbc",PX=16,LX=32,PL=se(),{resolvePath:LL}=wt();PL.initSync();var UR;UL.exports={validateLicense:ML,generateFingerPrint:UX,licenseSearch:xR,getLicense:HX,checkMemoryLimit:xX};function BR(){return vR.join(PL.getHdbBasePath(),Jo.LICENSE_KEY_DIR_NAME,Jo.LICENSE_FILE_NAME)}a(BR,"getLicenseDirPath");function MX(){let e=BR();return LL(vR.join(e,Jo.LICENSE_FILE_NAME))}a(MX,"getLicenseFilePath");function HR(){let e=BR();return LL(vR.join(e,Jo.REG_KEY_FILE_NAME))}a(HR,"getFingerPrintFilePath");async function UX(){let e=HR();try{return await vl.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await vX();throw Yr.error(`Error writing fingerprint file to ${e}`),Yr.error(t),new Error("There was an error generating the fingerprint")}}a(UX,"generateFingerPrint");async function vX(){let e=OX(),t=CL.hash(e),r=HR();try{await vl.mkdirp(BR()),await vl.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw Yr.error(`Error writing fingerprint file to ${r}`),Yr.error(n),new Error("There was an error generating the fingerprint")}return t}a(vX,"writeFingerprint");function ML(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:Jo.RAM_ALLOCATION_ENUM.DEFAULT,version:Jo.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Yr.error("empty license key passed to validate."),r;let n=HR(),s=!1;try{s=vl.statSync(n)}catch(i){Yr.error(i)}if(s){let i;try{i=vl.readFileSync(n,"utf8")}catch{Yr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(CX),c=o[1];c=Buffer.concat([Buffer.from(c)],PX);let l=Buffer.concat([Buffer.from(i)],LX),u=DL.createDecipheriv(DX,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let d=null;try{d=u.update(o[0],"hex","utf8"),d.trim(),d+=u.final("utf8")}catch{let f=BX(o[0],i);if(f)d=f;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Ul),Yr.error(Ul),new Error(Ul)}let _;if(isNaN(d))try{_=JSON.parse(d),r.version=_.version,r.exp_date=_.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),_.ram_allocation&&(r.ram_allocation=_.ram_allocation)}catch{throw console.error(Ul),Yr.error(Ul),new Error(Ul)}else r.exp_date=d;r.exp_date<bX().valueOf()&&(r.valid_date=!1),CL.validate(o[1],`${wX}${i}${t}`)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||Yr.error("Invalid licence"),r}a(ML,"validateLicense");function BX(e,t){try{let r=DL.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{Yr.warn("Check old license failed")}}a(BX,"checkOldLicense");function xR(){let e=new IX,t=[];try{t=vl.readFileSync(MX(),"utf-8").split(Jo.NEW_LINE)}catch(r){r.code==="ENOENT"?Yr.debug("no license file found"):Yr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(NX.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=ML(s.license_key,s.company);i.valid_machine===!0&&i.valid_date===!0&&i.valid_machine===!0&&(e.exp_date=i.exp_date>e.exp_date?i.exp_date:e.exp_date,e.ram_allocation=i.ram_allocation,e.enterprise=!0)}catch(s){Yr.error("There was an error parsing the license string."),Yr.error(s),e.ram_allocation=Jo.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return UR=e,e}a(xR,"licenseSearch");async function HX(){return UR||await xR(),UR}a(HX,"getLicense");function xX(){let e=xR().ram_allocation,t=process.constrainedMemory?.()||wL();if(t=Math.round(Math.min(t,wL())/2**20),t>e)return`This server has more memory (${t}MB) than HarperDB is licensed for (${e}MB), this should only be used for educational and development purposes.`}a(xX,"checkMemoryLimit")});var xn=N((MAe,QL)=>{"use strict";var xL="username is required",kL="nothing to update, must supply active, role or password to update",FL="password cannot be an empty string",GL="If role is specified, it cannot be empty.",qL="active must be true or false";QL.exports={addUser:WX,alterUser:jX,dropUser:QX,getSuperUser:eZ,userInfo:JX,listUsers:zh,listUsersExternal:XX,setUsersToGlobal:Hl,findAndValidateUser:jL,getClusterUser:tZ,USERNAME_REQUIRED:xL,ALTERUSER_NOTHING_TO_UPDATE:kL,EMPTY_PASSWORD:FL,EMPTY_ROLE:GL,ACTIVE_BOOLEAN:qL};var $L=un(),kX=uc(),GR=Kh(),VL=yL(),KL=Vr(),qR=no(),Hn=te(),YL=require("validate.js"),Ke=W(),{promisify:FX}=require("util"),$R=to(),vL=M(),BL=Ct(),GX=wt(),DAe=se(),PAe=dc(),qX=Zi(),{table:LAe}=(Pe(),oe(lt)),{handleHDBError:Ri,hdb_errors:$X}=_e(),{HTTP_STATUS_CODES:Ai,AUTHENTICATION_ERROR_MSGS:kR,HDB_ERROR_MSGS:Bl}=$X,{UserEventMsg:VR}=qs(),FR=require("lodash"),{server:KR}=(qr(),oe(Qa)),VX=W();KR.getUser=(e,t)=>jL(e,t,t!=null);var WL={username:!0,active:!0,role:!0,password:!0},HL=new Map,jh=KL.searchByValue,KX=KL.searchByHash,YX=FX(kX.delete);async function WX(e){let t=YL.cleanAttributes(e,WL),r=VL.addUserValidation(t);if(r)throw Ri(new Error,r.message,Ai.BAD_REQUEST,void 0,void 0,!0);let n={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]},s;try{s=await jh(n),s=s&&Array.from(s)}catch(l){throw Ke.error("There was an error searching for a role in add user"),Ke.error(l),l}if(!s||s.length<1)throw Ri(new Error,Bl.ROLE_NAME_NOT_FOUND(t.role),Ai.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw Ri(new Error,Bl.DUP_ROLES_FOUND(t.role),Ai.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=$R.encrypt(t.password)),t.password=GR.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await $L.insert(i)}catch(l){throw Ke.error("There was an error searching for a user."),Ke.error(l),l}Ke.debug(o);try{await Hl()}catch(l){throw Ke.error("Got an error setting users to global"),Ke.error(l),l}if(o.skipped_hashes.length===1)throw Ri(new Error,Bl.USER_ALREADY_EXISTS(t.username),Ai.CONFLICT,void 0,void 0,!0);let c={...t};return c.role=s[0],qR.signalUserChange(new VR(process.pid)),`${c.username} successfully added`}a(WX,"addUser");async function jX(e){let t=YL.cleanAttributes(e,WL);if(Hn.isEmptyOrZeroLength(t.username))throw new Error(xL);if(Hn.isEmptyOrZeroLength(t.password)&&Hn.isEmptyOrZeroLength(t.role)&&Hn.isEmptyOrZeroLength(t.active))throw new Error(kL);if(!Hn.isEmpty(t.password)&&Hn.isEmptyOrZeroLength(t.password.trim()))throw new Error(FL);if(!Hn.isEmpty(t.active)&&!Hn.isBoolean(t.active))throw new Error(qL);let r=zX(t.username);if(!Hn.isEmpty(t.password)&&!Hn.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=$R.encrypt(t.password)),t.password=GR.hash(t.password)),t.role==="")throw new Error(GL);if(t.role){let i={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]},o;try{o=Array.from(await jh(i)||[])}catch(c){throw Ke.error("Got an error searching for a role."),Ke.error(c),c}if(!o||o.length===0){let c=Bl.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Ke.error(c),Ri(new Error,c,Ai.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=Bl.ALTER_USER_DUP_ROLES(t.role);throw Ke.error(c),Ri(new Error,c,Ai.CONFLICT,void 0,void 0,!0)}t.role=o[0].id}let n={operation:"update",schema:"system",table:"hdb_user",records:[t]},s;try{s=await $L.update(n)}catch(i){throw Ke.error("Error during update."),Ke.error(i),i}try{await Hl()}catch(i){throw Ke.error("Got an error setting users to global"),Ke.error(i),i}return qR.signalUserChange(new VR(process.pid)),s}a(jX,"alterUser");function zX(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(zX,"isClusterUser");async function QX(e){try{let t=VL.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(Hn.isEmpty(global.hdb_users.get(e.username)))throw Ri(new Error,Bl.USER_NOT_EXIST(e.username),Ai.NOT_FOUND,void 0,void 0,!0);let n;try{n=await YX(r)}catch(s){throw Ke.error("Got an error deleting a user."),Ke.error(s),s}Ke.debug(n);try{await Hl()}catch(s){throw Ke.error("Got an error setting users to global."),Ke.error(s),s}return qR.signalUserChange(new VR(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(QX,"dropUser");async function JX(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=FR.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await KX(r)}catch(s){throw Ke.error("Got an error searching for a role."),Ke.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw Ke.error(r),r}return t}a(JX,"userInfo");async function XX(){let e;try{e=await zh()}catch(t){throw Ke.error("Got an error listing users."),Ke.error(t),t}try{e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token})}catch{throw new Error("there was an error massaging the user data")}return[...e.values()]}a(XX,"listUsersExternal");async function zh(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await jh(e)}catch(o){throw Ke.error("Got an error searching for roles."),Ke.error(o),o}let r={};for(let o of t)r[o.id]=FR.cloneDeep(o);if(Object.keys(r).length===0)return null;let n={schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]},s;try{s=await jh(n)}catch(o){throw Ke.error("Got an error searching for users."),Ke.error(o),o}let i=new Map;for(let o of s)o=FR.cloneDeep(o),o.role=r[o.role],ZX(o.role),i.set(o.username,o);return i}catch(e){throw Ke.error("got an error listing users"),Ke.error(e),Hn.errorizeMessage(e)}return null}a(zh,"listUsers");function ZX(e){try{if(!e){Ke.error("invalid user role found.");return}e.permission.system||(e.permission.system={}),e.permission.system.tables||(e.permission.system.tables={});for(let t of Object.keys(qX)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){Ke.error("Got an error trying to set system permissions."),Ke.error(t)}}a(ZX,"appendSystemTablesToRole");async function Hl(){try{let e=await zh();global.hdb_users=e}catch(e){throw Ke.error(e),e}}a(Hl,"setUsersToGlobal");async function jL(e,t,r=!0){global.hdb_users||await Hl();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw Ri(new Error,kR.GENERIC_AUTH_FAIL,Ai.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw Ri(new Error,kR.USER_INACTIVE,Ai.UNAUTHORIZED,void 0,void 0,!0);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(HL.get(t)===n.password)return s;if(GR.validate(n.password,t))HL.set(t,n.password);else throw Ri(new Error,kR.GENERIC_AUTH_FAIL,Ai.UNAUTHORIZED,void 0,void 0,!0)}return s}a(jL,"findAndValidateUser");async function eZ(){global.hdb_users||await Hl();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(eZ,"getSuperUser");async function tZ(){let e=await zh(),t=GX.getConfigFromFile(vL.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!Hn.isEmpty(r)&&r?.role?.role===vL.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=$R.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+BL.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+BL.SERVER_SUFFIX.ADMIN,r}a(tZ,"getClusterUser");var zL=[];KR.invalidateUser=function(e){for(let t of zL)try{t(e)}catch(r){VX.error("Error invalidating user",r)}};KR.onInvalidatedUser=function(e){zL.push(e)}});var m_=N((HAe,eM)=>{"use strict";var _c=W(),kn=M(),rZ=VP(),vAe=ls(),BAe=ro(),nZ=xn(),{validateEvent:JL}=qs(),p_=Bn(),sZ=require("process"),{resetDatabases:iZ}=(Pe(),oe(lt)),oZ={[kn.ITC_EVENT_TYPES.SCHEMA]:aZ,[kn.ITC_EVENT_TYPES.USER]:ZL};async function aZ(e){let t=JL(e);if(t){_c.error(t);return}_c.trace("ITC schemaHandler received schema event:",e),await rZ(e.message),await cZ(e.message)}a(aZ,"schemaHandler");async function cZ(e){try{p_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),p_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),p_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=iZ();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){_c.error(t)}}a(cZ,"syncSchemaMetadata");var XL=[];async function ZL(e){try{try{p_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),p_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){_c.warn(r)}let t=JL(e);if(t){_c.error(t);return}_c.trace(`ITC userHandler ${kn.HDB_ITC_CLIENT_PREFIX}${sZ.pid} received user event:`,e),await nZ.setUsersToGlobal();for(let r of XL)r()}catch(t){_c.error(t)}}a(ZL,"userHandler");ZL.addListener=function(e){XL.push(e)};eM.exports=oZ});var qs=N(($Ae,rM)=>{"use strict";var kAe=W(),YR=te(),lZ=M(),{ITC_ERRORS:S_}=Dn(),{parentPort:FAe,threadId:uZ,isMainThread:dZ,workerData:GAe}=require("worker_threads"),{onMessageFromWorkers:_Z,broadcast:qAe,broadcastWithAcknowledgement:fZ}=dt();rM.exports={sendItcEvent:EZ,validateEvent:tM,SchemaEventMsg:hZ,UserEventMsg:pZ};var Qh;_Z(async(e,t)=>{Qh=Qh||m_(),tM(e),Qh[e.type]&&await Qh[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function EZ(e){return!dZ&&e.message&&(e.message.originator=uZ),fZ(e)}a(EZ,"sendItcEvent");function tM(e){if(typeof e!="object")return S_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||YR.isEmpty(e.type))return S_.MISSING_TYPE;if(!e.hasOwnProperty("message")||YR.isEmpty(e.message))return S_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||YR.isEmpty(e.message.originator))return S_.MISSING_ORIGIN;if(lZ.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return S_.INVALID_EVENT(e.type)}a(tM,"validateEvent");function hZ(e,t,r,n=void 0,s=void 0){this.originator=e,this.operation=t,this.schema=r,this.table=n,this.attribute=s}a(hZ,"SchemaEventMsg");function pZ(e){this.originator=e}a(pZ,"UserEventMsg")});var no=N((YAe,oM)=>{"use strict";var nM=M(),KAe=te(),Jh=W(),sM=GP(),xl,{sendItcEvent:iM}=qs();function mZ(e){try{Jh.info("signalSchemaChange called with message:",e),xl=xl||m_();let t=new sM(nM.ITC_EVENT_TYPES.SCHEMA,e);return xl.schema(t),iM(t)}catch(t){Jh.error(t)}}a(mZ,"signalSchemaChange");function SZ(e){try{Jh.trace("signalUserChange called with message:",e),xl=xl||m_();let t=new sM(nM.ITC_EVENT_TYPES.USER,e);return xl.user(t),iM(t)}catch(t){Jh.error(t)}}a(SZ,"signalUserChange");oM.exports={signalSchemaChange:mZ,signalUserChange:SZ}});var Xh=N((jAe,cM)=>{"use strict";var aM=te(),TZ=M(),gZ=W(),RZ=Bh(),AZ=vh(),yZ=no(),{SchemaEventMsg:bZ}=qs(),OZ="already exists in";cM.exports=NZ;async function NZ(e,t,r){if(aM.isEmptyOrZeroLength(r))return r;let n=[];aM.isEmptyOrZeroLength(t.attributes)||t.attributes.forEach(i=>{n.push(i.attribute)});let s=r.filter(i=>n.indexOf(i)<0);return s.length===0||await Promise.all(s.map(async i=>{await IZ(e,t.schema,t.name,i)})),s}a(NZ,"lmdbCheckForNewAttributes");async function IZ(e,t,r,n){let s=new AZ(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await wZ(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(OZ))gZ.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(IZ,"createNewAttribute");async function wZ(e){let t;return t=await RZ(e),yZ.signalSchemaChange(new bZ(process.pid,TZ.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(wZ,"createAttribute")});var kl=N((QAe,lM)=>{"use strict";var WR=class{static{a(this,"LMDBTransactionObject")}constructor(t,r,n,s,i=void 0){this.operation=t,this.user_name=r,this.timestamp=n,this.hash_values=s,this.origin=i}};lM.exports=WR});var dM=N((XAe,uM)=>{"use strict";var CZ=kl(),DZ=M().OPERATIONS_ENUM,jR=class extends CZ{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(DZ.INSERT,r,n,s,i),this.records=t}};uM.exports=jR});var fM=N((eye,_M)=>{"use strict";var PZ=kl(),LZ=M().OPERATIONS_ENUM,zR=class extends PZ{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(LZ.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};_M.exports=zR});var hM=N((rye,EM)=>{"use strict";var MZ=kl(),UZ=M().OPERATIONS_ENUM,QR=class extends MZ{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(UZ.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};EM.exports=QR});var mM=N((sye,pM)=>{"use strict";var vZ=kl(),BZ=M().OPERATIONS_ENUM,JR=class extends vZ{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(BZ.DELETE,n,s,t,i),this.original_records=r}};pM.exports=JR});var T_=N((aye,RM)=>{"use strict";var oye=require("path"),SM=ht(),HZ=dM(),xZ=fM(),kZ=hM(),FZ=mM(),Fl=Bt(),TM=te(),{CONFIG_PARAMS:GZ}=M(),gM=se();gM.initSync();var Zh=M().OPERATIONS_ENUM,{getTransactionAuditStorePath:qZ}=gt();RM.exports=$Z;async function $Z(e,t){if(gM.get(GZ.LOGGING_AUDITLOG)===!1)return;let r=qZ(e.schema,e.table),n=await SM.openEnvironment(r,e.table,!0),s=VZ(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){SM.initializeDBIs(n,Fl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Fl.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Fl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Fl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),TM.isEmpty(s.user_name)||n.dbis[Fl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Fl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a($Z,"writeTransaction");function VZ(e,t){let r=TM.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===Zh.INSERT)return new HZ(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zh.UPDATE)return new xZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zh.UPSERT)return new kZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zh.DELETE)return new FZ(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(VZ,"createTransactionObject")});var XR=N((uye,AM)=>{"use strict";var KZ=f_(),lye=Qd(),g_=M(),YZ=Jd(),WZ=sc().insertRecords,jZ=ht(),zZ=W(),QZ=Xh(),{getSchemaPath:JZ}=gt(),XZ=T_();AM.exports=ZZ;async function ZZ(e){try{let{schema_table:t,attributes:r}=KZ(e);YZ(e,r,t.hash_attribute),e.schema!==g_.SYSTEM_SCHEMA_NAME&&(r.includes(g_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(g_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(g_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(g_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await QZ(e.hdb_auth_header,t,r),s=JZ(e.schema,e.table),i=await jZ.openEnvironment(s,e.table),o=await WZ(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await XZ(e,o)}catch(c){zZ.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(ZZ,"lmdbCreateRecords")});var OM=N((_ye,bM)=>{"use strict";var yM=M(),e5=XR(),t5=Qd(),r5=require("fs-extra"),{getSchemaPath:n5}=gt();bM.exports=s5;async function s5(e){let t=[{name:e.schema,createddate:Date.now()}],r=new t5(yM.SYSTEM_SCHEMA_NAME,yM.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await e5(r),await r5.mkdirp(n5(e.schema))}a(s5,"lmdbCreateSchema")});var IM=N((Eye,NM)=>{"use strict";var ZR=class{static{a(this,"DeleteRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.deleted=t,this.skipped=r,this.txn_time=n,this.original_records=s}};NM.exports=ZR});var PM=N((Tye,DM)=>{"use strict";var wM=ht(),eA=cn(),tA=Dn().LMDB_ERRORS_ENUM,i5=Bt(),CM=W(),pye=te(),o5=require("lmdb"),a5=IM(),c5=M(),{OVERFLOW_MARKER:mye,MAX_SEARCH_KEY_LENGTH:Sye}=i5,l5=c5.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function u5(e,t,r,n){if(eA.validateEnv(e),t===void 0)throw new Error(tA.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(tA.IDS_REQUIRED):new Error(tA.IDS_MUST_BE_ITERABLE);try{let s=wM.listDBIs(e);wM.initializeDBIs(e,t,s);let i=new a5,o,c=[],l=[];for(let E=0,f=r.length;E<f;E++)try{o=r[E];let h=e.dbis[t].get(o);if(!h||n&&h[l5]>n){i.skipped.push(o);continue}let T=e.dbis[t].ifVersion(o,o5.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let m=0;m<s.length;m++){let g=s[m];if(!h.hasOwnProperty(g)||g===t)continue;let S=e.dbis[g],b=h[g];if(b!=null)try{let I=eA.getIndexedValues(b);if(I)for(let B=0,H=I.length;B<H;B++)S.remove(I[B],o)}catch{CM.warn(`cannot delete from attribute: ${g}, ${b}:${o}`)}}});c.push(T),l.push(o),i.original_records.push(h)}catch(h){CM.warn(h),i.skipped.push(o)}let u=[],d=await Promise.all(c);for(let E=0,f=d.length;E<f;E++)d[E]===!0?i.deleted.push(l[E]):(i.skipped.push(l[E]),u.push(E));let _=0;for(let E=0;E<u.length;E++){let f=u[E];i.original_records.splice(f-_,1),_++}return i.txn_time=eA.getNextMonotonicTime(),i}catch(s){throw s}}a(u5,"deleteRecords");DM.exports={deleteRecords:u5}});var R_=N((Rye,MM)=>{"use strict";var Gl=te(),d5=PM(),_5=ht(),{getSchemaPath:f5}=gt(),E5=T_(),h5=W();MM.exports=p5;async function p5(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Gl.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Gl.isEmptyOrZeroLength(e.hash_values)&&!Gl.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Gl.isEmpty(l)||e.hash_values.push(l)}}if(Gl.isEmptyOrZeroLength(e.hash_values))return LM([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Gl.isEmptyOrZeroLength(e.records)){e.records=[];for(let c=0;c<e.hash_values.length;c++)e.records[c]={[n]:e.hash_values[c]}}let s=f5(e.schema,e.table),i=await _5.openEnvironment(s,e.table),o=await d5.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await E5(e,o)}catch(c){h5.error(`unable to write transaction due to ${c.message}`)}return LM(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(p5,"lmdbDeleteRecords");function LM(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}a(LM,"createDeleteResponse")});var nA=N((bye,UM)=>{"use strict";var m5=M(),yye=cn();function rA(e,t){let r=Object.create(null);if(t.length===1&&m5.SEARCH_WILDCARDS.indexOf(t[0])>=0)Object.assign(r,e);else for(let n=0;n<t.length;n++){let s=t[n],i=e[s];r[s]=i===void 0?null:i}return r}a(rA,"parseRow");function S5(e,t,r,n){let s=rA(r,e);n.push(s)}a(S5,"searchAll");function T5(e,t,r,n){let s=rA(r,e);n[t]=s}a(T5,"searchAllToMap");function g5(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(g5,"iterateDBI");function fc(e,t,r,n,s){let i=Object.create(null);i[s]=e;let o;n===s?o=e:(o=t,n!==void 0&&(i[n]=o)),r[0].push(o),r[1].push(i)}a(fc,"pushResults");function R5(e,t,r,n,s,i){t.toString().endsWith(e)&&fc(t,r,n,s,i)}a(R5,"endsWith");function A5(e,t,r,n,s,i){t.toString().includes(e)&&fc(t,r,n,s,i)}a(A5,"contains");function y5(e,t,r,n,s,i){t>e&&fc(t,r,n,s,i)}a(y5,"greaterThanCompare");function b5(e,t,r,n,s,i){t>=e&&fc(t,r,n,s,i)}a(b5,"greaterThanEqualCompare");function O5(e,t,r,n,s,i){t<e&&fc(t,r,n,s,i)}a(O5,"lessThanCompare");function N5(e,t,r,n,s,i){t<=e&&fc(t,r,n,s,i)}a(N5,"lessThanEqualCompare");UM.exports={parseRow:rA,searchAll:S5,searchAllToMap:T5,iterateDBI:g5,endsWith:R5,contains:A5,greaterThanCompare:y5,greaterThanEqualCompare:b5,lessThanCompare:O5,lessThanEqualCompare:N5,pushResults:fc}});var ql=N((Cye,GM)=>{"use strict";var Xo=ht(),Nye=W(),Fn=cn(),ep=Bt(),zt=Dn().LMDB_ERRORS_ENUM,Iye=te(),I5=M(),tp=nA(),{parseRow:w5}=tp,wye=require("lmdb"),{OVERFLOW_MARKER:vM,MAX_SEARCH_KEY_LENGTH:C5}=ep;function BM(e,t,r,n=!1,s=void 0,i=void 0){return Ec(e,t,r,(o,c)=>c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}))}a(BM,"iterateFullIndex");function A_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return Ec(e,t,r,(d,_,E,f)=>{let S={transaction:d,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return f===r?(S.values=!1,_.getRange(S).map(b=>({value:b}))):_.getRange(S)})}a(A_,"iterateRangeBetween");function Ec(e,t,r,n){let s=e.database||e,i=Xo.openDBI(s,r);i[ep.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&Xo.openDBI(s,t);let o;e.database?o=e:(o=e.useReadTransaction(),o.database=e);let c=n(o,i,s,t);return c.transaction=o,e.database||(c.onDone=()=>{o.done()}),c}a(Ec,"setupTransaction");function HM(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(vM)){if(!s)if(r)s=Xo.openDBI(e,r);else{let l=Xo.listDBIs(e);for(let u=0,d=l.length;u<d&&(s=Xo.openDBI(e,l[u]),!s[ep.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(HM,"getOverflowCheck");function D5(e,t,r,n=!1,s=void 0,i=void 0){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return Ec(e,t,t,(o,c,l)=>(rp(r),r=y_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>w5(u.value,r))))}a(D5,"searchAll");function P5(e,t,r,n=!1,s=void 0,i=void 0){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);rp(r),r=y_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of BM(e,t,t,n,s,i))o.set(c,tp.parseRow(l,r));return o}a(P5,"searchAllToMap");function L5(e,t,r=!1,n=void 0,s=void 0){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=BM(e,void 0,t,r,n,s),c=o.transaction,l=HM(c.database,c,void 0,t);for(let{key:u,value:d}of o){let _=l(u,d);i[_]===void 0&&(i[_]=[]),i[_].push(d)}return i}a(L5,"iterateDBI");function M5(e,t){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return Xo.statDBI(e,t).entryCount}a(M5,"countAll");function U5(e,t,r,n,s=!1,i=void 0,o=void 0){return Zo(e,r,n),Ec(e,t,r,(c,l,u,d)=>(n=Fn.convertKeyValueToWrite(n),d===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(_=>({key:n,value:_}))))}a(U5,"equals");function v5(e,t,r){return Zo(e,t,r),Xo.openDBI(e,t).getValuesCount(r)}a(v5,"count");function B5(e,t,r,n,s=!1,i=void 0,o=void 0){return Zo(e,r,n),Ec(e,null,r,(c,l)=>{n=Fn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let d;if(s===!0){let _;for(let E of l.getKeys({transaction:c,start:n}))if(!E.startsWith(n)){_=E;break}return _!==void 0&&(Number.isInteger(o)?o++:i++),d=l.getRange({transaction:c,start:_,end:void 0,reverse:s,limit:i,offset:o}).map(E=>{let{key:f}=E;if(f!==_){if(f.toString().startsWith(n))return E;if(u===!0)return d.DONE}}),d.filter(E=>E)}else return d=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(_=>{if(_.key.toString().startsWith(n))return _;if(u===!0)return d.DONE}),u?d:d.filter(_=>_)})}a(B5,"startsWith");function H5(e,t,r,n,s=!1,i=void 0,o=void 0){return xM(e,t,r,n,s,i,o,!0)}a(H5,"endsWith");function xM(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Zo(e,r,n),Ec(e,null,r,(l,u,d,_)=>{let E=HM(d,l,_,r);return o=Number.isInteger(o)?o:0,u.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(f=>{let h=f.toString();return h.endsWith(vM)?u.getValues(f,{transaction:l}).map(T=>{let m=E(f,T);if(c?m.endsWith(n):m.includes(n))return{key:m,value:T}}).filter(T=>T):(c?h.endsWith(n):h.includes(n))?u[ep.DBI_DEFINITION_NAME].is_hash_attribute?{key:f,value:f}:u.getValues(f,{transaction:l}).map(T=>({key:f,value:T})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(xM,"contains");function x5(e,t,r,n,s=!1,i=void 0,o=void 0){Zo(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),A_(e,t,r,n,l,s,i,o,!0,!1)}a(x5,"greaterThan");function k5(e,t,r,n,s=!1,i=void 0,o=void 0){Zo(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),A_(e,t,r,n,l,s,i,o,!1,!1)}a(k5,"greaterThanEqual");function F5(e,t,r,n,s=!1,i=void 0,o=void 0){Zo(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),A_(e,t,r,l,n,s,i,o,!1,!0)}a(F5,"lessThan");function G5(e,t,r,n,s=!1,i=void 0,o=void 0){Zo(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),A_(e,t,r,l,n,s,i,o,!1,!1)}a(G5,"lessThanEqual");function q5(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Fn.validateEnv(e),r===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(zt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(zt.END_VALUE_REQUIRED);if(n=Fn.convertKeyValueToWrite(n),s=Fn.convertKeyValueToWrite(s),n>s)throw new Error(zt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return A_(e,t,r,n,s,i,o,c)}a(q5,"between");function $5(e,t,r,n){Fn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(rp(r),r=y_(s,r),n===void 0)throw new Error(zt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=tp.parseRow(c,r)),o}a($5,"searchByHash");function V5(e,t,r){Fn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(V5,"checkHashExists");function K5(e,t,r,n,s=[]){return FM(e,t,r,n,s),kM(e,t,r,n,s).map(i=>i[1])}a(K5,"batchSearchByHash");function Y5(e,t,r,n,s=[]){FM(e,t,r,n,s);let i=new Map;for(let[o,c]of kM(e,t,r,n,s))i.set(o,c);return i}a(Y5,"batchSearchByHashToMap");function kM(e,t,r,n,s=[]){return Ec(e,t,t,(i,o,c)=>{r=y_(c,r);let l=r.length<3;return n.map(u=>{let d=c.dbis[t].get(u,{transaction:i,lazy:l});if(d)return[u,tp.parseRow(d,r)];s.push(u)}).filter(u=>u)})}a(kM,"batchHashSearch");function FM(e,t,r,n,s){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(rp(r),n==null)throw new Error(zt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(zt.IDS_MUST_BE_ITERABLE)}a(FM,"initializeBatchSearchByHash");function rp(e){if(!Array.isArray(e))throw e===void 0?new Error(zt.FETCH_ATTRIBUTES_REQUIRED):new Error(zt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(rp,"validateFetchAttributes");function Zo(e,t,r){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.SEARCH_VALUE_REQUIRED);if(r?.length>C5)throw new Error(zt.SEARCH_VALUE_TOO_LARGE)}a(Zo,"validateComparisonFunctions");function y_(e,t){return t.length===1&&I5.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=Xo.listDBIs(e)),t}a(y_,"setGetWholeRowAttributes");GM.exports={searchAll:D5,searchAllToMap:P5,count:v5,countAll:M5,equals:U5,startsWith:B5,endsWith:H5,contains:xM,searchByHash:$5,setGetWholeRowAttributes:y_,batchSearchByHash:K5,batchSearchByHashToMap:Y5,checkHashExists:V5,iterateDBI:L5,greaterThan:x5,greaterThanEqual:k5,lessThan:F5,lessThanEqual:G5,between:q5}});var $l=N((Pye,YM)=>{var qM=require("lodash"),$M=Tt(),He=require("joi"),W5=te(),{hdb_schema_table:b_,checkValidTable:VM,hdb_table:KM,hdb_database:np}=Ti(),{handleHDBError:j5,hdb_errors:z5}=_e(),{getDatabases:Q5}=(Pe(),oe(lt)),{HTTP_STATUS_CODES:J5}=z5,X5=He.object({database:np,schema:np,table:KM,search_attribute:b_,search_value:He.any().required(),get_attributes:He.array().min(1).items(He.alternatives(b_,He.object())).optional(),desc:He.bool(),limit:He.number().integer().min(1),offset:He.number().integer().min(0)}),Z5=He.object({database:np,schema:np,table:KM,operator:He.string().valid("and","or").default("and").lowercase(),offset:He.number().integer().min(0),limit:He.number().integer().min(1),get_attributes:He.array().min(1).items(He.alternatives(b_,He.object())).optional(),sort:He.object({attribute:He.alternatives(b_,He.array().min(1)),descending:He.bool().optional()}).optional(),conditions:He.array().min(1).items(He.alternatives(He.object({operator:He.string().valid("and","or").default("and").lowercase(),conditions:He.array()}),He.object({search_attribute:He.alternatives(b_,He.array().min(1)),search_type:He.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:He.when("search_type",{switch:[{is:"equals",then:He.any()},{is:"between",then:He.array().items(He.alternatives([He.string(),He.number()])).length(2)}],otherwise:He.alternatives(He.string(),He.number())}).required()}))).required()});YM.exports=function(e,t){let r=null;switch(t){case"value":r=$M.validateBySchema(e,X5);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(VM("database",e.schema)),i(VM("table",e.table)),e.hash_values?Array.isArray(e.hash_values)?e.hash_values.every(o=>typeof o=="string"||typeof o=="number")||i("'hash_values' must be strings or numbers"):i("'hash_values' must be an array"):i("'hash_values' is required"),e.get_attributes?Array.isArray(e.get_attributes)?e.get_attributes.length===0?i("'get_attributes' must contain at least 1 item"):e.get_attributes.every(o=>typeof o=="string"||typeof o=="number")||i("'get_attributes' must be strings or numbers"):i("'get_attributes' must be an array"):i("'get_attributes' is required"),s&&(r=new Error(s.trim()));break;case"conditions":r=$M.validateBySchema(e,Z5);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=W5.checkGlobalSchemaTable(e.schema,e.table);if(s)return j5(new Error,s,J5.NOT_FOUND);let o=Q5()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(d=>{for(let _=0,E=d.conditions.length;_<E;_++){let f=d.conditions[_];f.conditions?l(f):c.push(f.search_attribute)}},"addConditions");t==="conditions"&&l(e);let u=qM.filter(c,d=>d!=="*"&&!d.startsWith?.("$")&&d.attribute!=="*"&&!Array.isArray(d)&&!d.name&&!qM.some(o,_=>_===d||_.attribute===d||_.attribute===d.attribute));if(u&&u.length>0){let d=u.join(", ");return d=d.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${d}'`)}}return r}});var sA=N((Mye,WM)=>{"use strict";var e6=ht(),t6=$l(),{getSchemaPath:r6}=gt();WM.exports=n6;function n6(e){let t=t6(e,"hashes");if(t)throw t;let r=r6(e.schema,e.table);return e6.openEnvironment(r,e.table)}a(n6,"initialize")});var iA=N((vye,jM)=>{"use strict";var s6=ql(),i6=sA();jM.exports=o6;async function o6(e){let t=await i6(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return s6.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(o6,"lmdbGetDataByHash")});var Vl=N((Hye,zM)=>{"use strict";var oA=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};zM.exports=oA});var JM=N((Fye,QM)=>{"use strict";var kye=Vl(),a6=ql(),c6=sA();QM.exports=l6;async function l6(e){let t=await c6(e),r=global.hdb_schema[e.schema][e.table];return a6.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(l6,"lmdbSearchByHash")});var $s=N((qye,XM)=>{"use strict";var aA=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,u=void 0,d=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=u,this.offset=d}};XM.exports=aA});var sp=N((Vye,sU)=>{"use strict";var Wr=ql(),u6=ht(),d6=te(),xe=Bt(),hc=M(),_6=Zi(),ZM=Dn().LMDB_ERRORS_ENUM,{getSchemaPath:f6}=gt(),so=hc.SEARCH_WILDCARDS;async function E6(e,t,r){let n;e.schema===hc.SYSTEM_SCHEMA_NAME?n=_6[e.table]:n=global.hdb_schema[e.schema][e.table];let s=nU(e,n.hash_attribute,r,t);return tU(e,s,n.hash_attribute,r)}a(E6,"prepSearch");async function tU(e,t,r,n){let s=f6(e.schema,e.table),i=await u6.openEnvironment(s,e.table),o=rU(i,e,t,r),c=o.transaction||i;if([xe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,xe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,xe.SEARCH_TYPES.SEARCH_ALL,xe.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(h6(e,r)===!1){let d=e.search_attribute;if(d===r)return n?eU(o,()=>!0):o.map(E=>({[r]:E.key}));let _=a(E=>({[r]:E.value,[d]:E.key}),"toObject");return n?eU(o,_):o.map(_)}let u=e.search_attribute===r?o.map(d=>d.key):o.map(d=>d.value);return n===!0?Wr.batchSearchByHashToMap(c,r,e.get_attributes,u):Wr.batchSearchByHash(c,r,e.get_attributes,u)}a(tU,"executeSearch");function rU(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case xe.SEARCH_TYPES.EQUALS:s=Wr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case xe.SEARCH_TYPES.CONTAINS:s=Wr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case xe.SEARCH_TYPES.ENDS_WITH:case xe.SEARCH_TYPES._ENDS_WITH:s=Wr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case xe.SEARCH_TYPES.STARTS_WITH:case xe.SEARCH_TYPES._STARTS_WITH:s=Wr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case xe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Wr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case xe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Wr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case xe.SEARCH_TYPES.SEARCH_ALL:return Wr.searchAll(e,n,t.get_attributes,o,c,l);case xe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Wr.searchAllToMap(e,n,t.get_attributes,o,c,l);case xe.SEARCH_TYPES.BETWEEN:s=Wr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case xe.SEARCH_TYPES.GREATER_THAN:case xe.SEARCH_TYPES._GREATER_THAN:s=Wr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case xe.SEARCH_TYPES.GREATER_THAN_EQUAL:case xe.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Wr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case xe.SEARCH_TYPES.LESS_THAN:case xe.SEARCH_TYPES._LESS_THAN:s=Wr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case xe.SEARCH_TYPES.LESS_THAN_EQUAL:case xe.SEARCH_TYPES._LESS_THAN_EQUAL:s=Wr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(rU,"searchByType");function eU(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(eU,"createMapFromIterable");function h6(e,t){if(e.get_attributes.length===1&&e.get_attributes[0]==="*")return!0;let r=[e.search_attribute];e.get_attributes.indexOf(t)>=0&&r.push(t);let n=!1;for(let s=0;s<e.get_attributes.length;s++)if(r.indexOf(e.get_attributes[s])<0){n=!0;break}return n}a(h6,"checkToFetchMore");function nU(e,t,r,n){if(d6.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),o=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),so.indexOf(s)>-1)return r===!0?xe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:xe.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(so[0])<0&&s.indexOf(so[1])<0)return c===!0?r===!0?xe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:xe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:xe.SEARCH_TYPES.EQUALS;if(so.indexOf(i)>=0&&so.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),xe.SEARCH_TYPES.CONTAINS;if(so.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),xe.SEARCH_TYPES.ENDS_WITH;if(so.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),xe.SEARCH_TYPES.STARTS_WITH;if(s.includes(so[0])||s.includes(so[1]))return xe.SEARCH_TYPES.EQUALS;throw new Error(ZM.UNKNOWN_SEARCH_TYPE)}else switch(n){case hc.VALUE_SEARCH_COMPARATORS.BETWEEN:return xe.SEARCH_TYPES.BETWEEN;case hc.VALUE_SEARCH_COMPARATORS.GREATER:return xe.SEARCH_TYPES.GREATER_THAN;case hc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return xe.SEARCH_TYPES.GREATER_THAN_EQUAL;case hc.VALUE_SEARCH_COMPARATORS.LESS:return xe.SEARCH_TYPES.LESS_THAN;case hc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return xe.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(ZM.UNKNOWN_SEARCH_TYPE)}}a(nU,"createSearchTypeFromSearchObject");sU.exports={executeSearch:tU,createSearchTypeFromSearchObject:nU,prepSearch:E6,searchByType:rU}});var oU=N((Wye,iU)=>{"use strict";var Yye=$s(),p6=$l(),m6=te(),S6=M(),T6=sp();iU.exports=g6;function g6(e,t){if(!m6.isEmpty(t)&&S6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=p6(e,"value");if(n)throw n;return T6.prepSearch(e,t,!0)}a(g6,"lmdbGetDataByValue")});var O_=N((Qye,aU)=>{"use strict";var zye=$s(),R6=$l(),A6=te(),y6=M(),b6=sp();aU.exports=O6;async function O6(e,t){if(!A6.isEmpty(t)&&y6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=R6(e,"value");if(n)throw n;return b6.prepSearch(e,t,!1)}a(O6,"lmdbSearchByValue")});var lU=N((Zye,cU)=>{"use strict";var Xye=Bt(),cA=class{static{a(this,"SearchByConditionsObject")}constructor(t,r,n,s,i=void 0,o=void 0,c="and"){this.schema=t,this.table=r,this.get_attributes=n,this.limit=i,this.offset=o,this.conditions=s,this.operator=c}},lA=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},uA=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};cU.exports={SearchByConditionsObject:cA,SearchCondition:lA,SortAttribute:uA}});var EU=N((nbe,fU)=>{"use strict";var tbe=lU().SearchByConditionsObject,N6=$s(),I6=$l(),dA=ql(),ip=Bt(),{Resource:rbe}=(Vs(),oe(_A)),_U=sp(),w6=nA(),C6=require("lodash"),{getSchemaPath:D6}=gt(),uU=ht(),{handleHDBError:P6,hdb_errors:L6}=_e(),{HTTP_STATUS_CODES:M6}=L6,U6=1e8;fU.exports=v6;async function v6(e){let t=I6(e,"conditions");if(t)throw P6(t,t.message,M6.BAD_REQUEST,void 0,void 0,!0);e.operator=e.operator?e.operator.toLowerCase():void 0,e.offset=Number.isInteger(e.offset)?e.offset:0;let r=D6(e.schema,e.table),n=await uU.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)uU.openDBI(n,u.search_attribute);let i=C6.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let d=u.search_type;d===ip.SEARCH_TYPES.EQUALS?u.estimated_count=dA.count(n,u.search_attribute,u.search_value):d===ip.SEARCH_TYPES.CONTAINS||d===ip.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=U6}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await dU(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let u=n.dbis[s.hash_attribute],d=i.slice(1).map(_U.filterByType),_=d.length,E=dA.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(f=>u.get(f,{transaction:o,lazy:!0})),_>0&&(l=l.filter(f=>{for(let h=0;h<_;h++)if(!d[h](f))return!1;return!0})),(e.offset||e.limit!==void 0)&&(l=l.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),l=l.map(f=>w6.parseRow(f,E))}else{for(let _=1;_<i.length;_++){let E=i[_],f=await dU(o,e,E,s.hash_attribute);c=c.concat(f)}let u=new Set,d=e.offset||0;c=c.filter(_=>u.has(_)?!1:(u.add(_),!0)).slice(d,e.limit&&e.limit+d),l=dA.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(v6,"lmdbSearchByConditions");async function dU(e,t,r,n){let s=new N6(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===ip.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,_U.searchByType(e,s,i,n).map(o=>o.value)}a(dU,"executeConditionSearch")});var N_=N((ibe,hU)=>{"use strict";var B6=M().OPERATIONS_ENUM,fA=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=B6.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};hU.exports=fA});var EA=N((abe,yU)=>{"use strict";var TU=$s(),gU=N_(),RU=O_(),AU=R_(),dn=M(),pU=te(),mU=ht(),{getTransactionAuditStorePath:H6,getSchemaPath:x6}=gt(),SU=W();yU.exports=k6;async function k6(e){try{if(pU.isEmpty(global.hdb_schema[e.schema])||pU.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await F6(e),await G6(e);let t=x6(e.schema,e.table);try{await mU.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")SU.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=H6(e.schema,e.table);await mU.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")SU.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(k6,"lmdbDropTable");async function F6(e){let t=new TU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await RU(t)),n=[];for(let i=0;i<r.length;i++){let o=r[i];n.push(o.id)}if(n.length===0)return;let s=new gU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await AU(s)}a(F6,"deleteAttributesFromSystem");async function G6(e){let t=new TU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await RU(t))}catch(i){throw i}for(let i=0;i<r.length;i++){let o=r[i];o.name===e.table&&o.schema===e.schema&&(n=o)}if(!n)throw new Error(`${e.schema}.${e.table} was not found`);let s=new gU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await AU(s)}catch(i){throw i}}a(G6,"dropTableFromSystem")});var OU=N((lbe,bU)=>{"use strict";var q6=require("fs-extra"),$6=$s(),V6=Vl(),K6=N_(),Y6=EA(),W6=R_(),j6=iA(),z6=O_(),io=M(),{getSchemaPath:Q6}=gt(),{handleHDBError:J6,hdb_errors:X6}=_e(),{HDB_ERROR_MSGS:Z6,HTTP_STATUS_CODES:e8}=X6;bU.exports=t8;async function t8(e){let t;try{t=await r8(e.schema);let r=new $6(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await z6(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await Y6(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new K6(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await W6(s);let i=Q6(t);await q6.remove(i)}catch(r){throw r}}a(t8,"lmdbDropSchema");async function r8(e){let t=new V6(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await j6(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw J6(new Error,Z6.SCHEMA_NOT_FOUND(e),e8.NOT_FOUND,void 0,void 0,!0);return n}a(r8,"validateDropSchema")});var I_=N((dbe,NU)=>{"use strict";var hA=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};NU.exports=hA});var mA=N((Ebe,IU)=>{"use strict";var n8=require("fs-extra"),op=ht(),{getTransactionAuditStorePath:s8}=gt(),pA=Bt(),fbe=I_();IU.exports=i8;async function i8(e){let t;try{let r=s8(e.schema,e.table);await n8.mkdirp(r),t=await op.createEnvironment(r,e.table,!0)}catch(r){throw r.message=`unable to create transactions audit environment for ${e.schema}.${e.table} due to: ${r.message}`,r}try{op.createDBI(t,pA.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),op.createDBI(t,pA.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),op.createDBI(t,pA.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME,!0,!1)}catch(r){throw r.message=`unable to create dbi for ${e.schema}.${e.table} due to: ${r.message}`,r}return t}a(i8,"createTransactionsAuditEnvironment")});var DU=N((mbe,CU)=>{"use strict";var SA=M(),wU=ht(),o8=sc(),{getSystemSchemaPath:a8,getSchemaPath:c8}=gt(),pbe=Zi(),l8=Bh(),TA=vh(),u8=W(),d8=mA();CU.exports=_8;async function _8(e,t){let r=c8(t.schema,t.table),n=new TA(t.schema,t.table,SA.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new TA(t.schema,t.table,SA.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new TA(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await wU.createEnvironment(r,t.table),e!==void 0){let o=await wU.openEnvironment(a8(),SA.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await o8.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_table_attributes,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await gA(n),await gA(s),await gA(i)}await d8(t)}catch(o){throw o}}a(_8,"lmdbCreateTable");async function gA(e){try{await l8(e)}catch(t){u8.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(gA,"createAttribute")});var LU=N((Tbe,PU)=>{"use strict";var f8=f_(),E8=Jd(),h8=Xh(),w_=M(),p8=sc().updateRecords,m8=ht(),{getSchemaPath:S8}=gt(),T8=T_(),g8=W();PU.exports=R8;async function R8(e){try{let{schema_table:t,attributes:r}=f8(e);E8(e,r,t.hash_attribute),e.schema!==w_.SYSTEM_SCHEMA_NAME&&(r.includes(w_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(w_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(w_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(w_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await h8(e.hdb_auth_header,t,r),s=S8(e.schema,e.table),i=await m8.openEnvironment(s,e.table),o=await p8(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await T8(e,o)}catch(c){g8.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(R8,"lmdbUpdateRecords")});var UU=N((Rbe,MU)=>{"use strict";var A8=M().OPERATIONS_ENUM,RA=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=A8.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};MU.exports=RA});var BU=N((bbe,vU)=>{"use strict";var ybe=UU(),y8=f_(),b8=Jd(),O8=Xh(),C_=M(),N8=sc().upsertRecords,I8=ht(),{getSchemaPath:w8}=gt(),C8=T_(),D8=W(),{handleHDBError:P8,hdb_errors:L8}=_e();vU.exports=M8;async function M8(e){let t;try{t=y8(e)}catch(l){throw P8(l,l.message,L8.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;b8(e,n,r.hash_attribute),e.schema!==C_.SYSTEM_SCHEMA_NAME&&(n.includes(C_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(C_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(C_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(C_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await O8(e.hdb_auth_header,r,n),i=w8(e.schema,e.table),o=await I8.openEnvironment(i,e.table),c=await N8(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await C8(e,c)}catch(l){D8.error(`unable to write transaction due to ${l.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:s,txn_time:c.txn_time}}a(M8,"lmdbUpsertRecords")});var xU=N((Nbe,HU)=>{"use strict";var AA=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};HU.exports=AA});var FU=N((wbe,kU)=>{"use strict";var yA=class{static{a(this,"DeleteAuditLogsBeforeResults")}constructor(t=void 0,r=void 0,n=0){this.start_timestamp=t,this.end_timestamp=r,this.transactions_deleted=n}};kU.exports=yA});var $U=N((Pbe,qU)=>{"use strict";var bA=ht(),{getTransactionAuditStorePath:U8}=gt(),Dbe=xU(),D_=Bt(),v8=te(),GU=FU(),B8=require("util").promisify,H8=B8(setTimeout),x8=1e4,k8=100;qU.exports=F8;async function F8(e){let t=U8(e.schema,e.table),r=await bA.openEnvironment(t,e.table,!0),n=bA.listDBIs(r);bA.initializeDBIs(r,D_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new GU;do s=await G8(r,e.timestamp),i.start_timestamp===void 0&&(i.start_timestamp=s.start_timestamp),s.end_timestamp!==void 0&&(i.end_timestamp=s.end_timestamp),i.transactions_deleted+=s.transactions_deleted,await H8(k8);while(s.transactions_deleted>0);return i}a(F8,"deleteAuditLogsBefore");async function G8(e,t){let r=new GU;try{let n=e.dbis[D_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],s;for(let{key:i,value:o}of n.getRange({start:!1})){if(i>=t)break;r.start_timestamp===void 0&&(r.start_timestamp=i),s=n.remove(i);let c=o[D_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];v8.isEmpty(c)||(s=e.dbis[D_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[D_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>x8)break}return await s,r}catch(n){throw n}}a(G8,"deleteTransactions")});var KU=N((Mbe,VU)=>{"use strict";var OA=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};VU.exports=OA});var WU=N((Bbe,YU)=>{"use strict";var q8=$s(),$8=N_(),vbe=KU(),yi=M(),V8=te(),NA=ht(),K8=Zi(),Y8=O_(),W8=R_(),{getSchemaPath:j8}=gt();YU.exports=z8;async function z8(e,t=!0){let r;e.schema===yi.SYSTEM_SCHEMA_NAME?r=K8[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await J8(e),s=j8(e.schema,e.table),i=await NA.openEnvironment(s,e.table);return t===!0&&await Q8(e,i,r.hash_attribute),NA.dropDBI(i,e.attribute),n}a(z8,"lmdbDropAttribute");async function Q8(e,t,r){let n=NA.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let u={};for(let d in c)d!==i&&(u[d]=c[d]);s=t.dbis[r].put(o,u,l)}await s}a(Q8,"removeAttributeFromAllObjects");async function J8(e){let t=new q8(yi.SYSTEM_SCHEMA_NAME,yi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await Y8(t)).filter(o=>o[yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(V8.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new $8(yi.SYSTEM_SCHEMA_NAME,yi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return W8(i)}a(J8,"dropAttributeFromSystem")});var ZU=N((kbe,XU)=>{"use strict";var IA=ht(),Kl=Bt(),xbe=cn(),wA=M(),jU=te(),{getTransactionAuditStorePath:X8}=gt(),Z8=ql(),ap=kl(),e9=W();XU.exports=t9;async function t9(e){let t=X8(e.schema,e.table),r=await IA.openEnvironment(t,e.table,!0),n=IA.listDBIs(r);IA.initializeDBIs(r,Kl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case wA.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return zU(r,e.search_values);case wA.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,n9(r,e.search_values,s);case wA.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return r9(r,e.search_values);default:return zU(r)}}a(t9,"readAuditLog");function zU(e,t=[0,Date.now()]){jU.isEmpty(t[0])&&(t[0]=0),jU.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[Kl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let s of r.getKeys({start:t[1]}))if(s!==t[1]){n=s;break}return r.getRange({start:t[0],end:n}).map(({value:s})=>Object.assign(new ap,s))}a(zU,"searchTransactionsByTimestamp");function r9(e,t=[]){let r=new Map;for(let n=0;n<t.length;n++){let s=t[n],i=[];for(let o of e.dbis[Kl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,JU(e,i))}return Object.fromEntries(r)}a(r9,"searchTransactionsByUsername");function n9(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],d=Z8.equals(e,Kl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Kl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:_}of d){let E=Number(_);n.has(E)?n.get(E).push(u.toString()):n.set(E,[u.toString()])}}let s=Array.from(n.keys()),i=JU(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,d=n.get(u);QU(l,"records",r,d,o),QU(l,"original_records",r,d,o)}return Object.fromEntries(o)}a(n9,"searchTransactionsByHashValues");function QU(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let u=s.get(l),d=u[u.length-1];if(d.timestamp===i)d[t]=[c];else{let _=new ap(e.operation,e.user_name,i,void 0);_[t]=[c],u.push(_)}}else{let u=new ap(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}a(QU,"loopRecords");function JU(e,t){let r=[];try{let n=e.dbis[Kl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let s=0;s<t.length;s++)try{let i=n.get(t[s]);if(i){let o=Object.assign(new ap,i);r.push(o)}}catch(i){e9.warn(i)}return r}catch(n){throw n}}a(JU,"batchSearchTransactions")});var tv=N(($be,ev)=>{"use strict";var{getSchemaPath:Gbe}=gt(),qbe=ht(),{database:s9}=(Pe(),oe(lt));ev.exports={writeTransaction:i9};async function i9(e,t,r){return s9({database:e,table:t}).transaction(r)}a(i9,"writeTransaction")});var iv=N((Kbe,sv)=>{"use strict";var{getSchemaPath:rv}=gt(),nv=ht();sv.exports={flush:o9,resetReadTxn:a9};async function o9(e,t){return(await nv.openEnvironment(rv(e,t),t.toString())).flushed}a(o9,"flush");async function a9(e,t){try{(await nv.openEnvironment(rv(e,t),t.toString())).resetReadTxn()}catch{}}a(a9,"resetReadTxn")});var lv=N((Wbe,cv)=>{"use strict";var{Readable:c9}=require("stream"),{getDatabases:l9}=(Pe(),oe(lt)),{readSync:u9,openSync:d9,createReadStream:ov}=require("fs"),{open:_9}=require("lmdb"),av=o_(),f9=a_(),{AUDIT_STORE_OPTIONS:E9}=(Ji(),oe(uv)),{INTERNAL_DBIS_NAME:h9,AUDIT_STORE_NAME:p9}=Bt();cv.exports=S9;var CA=32768,m9=100;async function S9(e){let t=e.database||e.schema||"data",r=l9()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let u=r[s[0]];if(!u)throw new Error(`Can not find table ${s[0]}`);let d=u.dbisDB,_=_9({noSync:!0,maxDbs:f9.MAX_DBS}),E,f=_.openDB(h9,new av(!1)),h=d.useReadTransaction(),T=0,m=a(async function(S,b){b.encoding="binary",b.encoder=void 0;let I=_.openDB(S,b),B=d.openDB(S,b);for(let{key:H,version:X,value:Y}of B.getRange({start:null,transaction:h,versions:B.useVersions}))E=I.put(H,Y,X),T++%m9===0&&(await new Promise(V=>setTimeout(V,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:S,value:b}of d.getRange({transaction:h,start:!1}))if(s.some(I=>S.startsWith?.(I+"/"))){f.put(S,b);let[,I]=S.split("/"),B=!I,H=new av(!B,B);await m(S,H)}e.include_audit&&await m(p9,{...E9}),await E;let g=ov(_.path);return g.headers=l(),g.on("close",()=>{h.done(),_.close()}),g}let o=r[Object.keys(r)[0]].primaryStore,c=d9(o.path);return o.transaction(()=>{let u=Buffer.alloc(CA);u9(c,u,0,CA),o.resetReadTxn();let d=o.useReadTransaction();d.renew();let _=ov(null,{fd:c,start:CA}),E=new c9.from(async function*(){yield u;for await(let f of _)d.openTimer&&(d.openTimer=0),yield f;d.done()}());return E.headers=l(),E});function l(){let u=new Map;return u.set("content-type","application/octet-stream"),u.set("content-disposition",`attachment; filename="${t}"`),u.set("date",n),u}}a(S9,"getBackup")});var fv=N((zbe,_v)=>{"use strict";var T9=W(),{handleHDBError:g9}=_e(),R9=jD(),A9=Bh(),y9=XR(),b9=OM(),O9=R_(),N9=iA(),I9=JM(),w9=oU(),C9=O_(),D9=EU(),P9=OU(),L9=DU(),M9=LU(),U9=BU(),v9=$U(),B9=EA(),H9=WU(),x9=ZU(),k9=tv(),dv=iv(),F9=lv(),DA=class extends R9{static{a(this,"LMDBBridge")}async searchByConditions(t){return D9(t)}async getDataByHash(t){return await N9(t)}async searchByHash(t){return await I9(t)}async getDataByValue(t,r){return await w9(t,r)}async searchByValue(t){return await C9(t)}async createSchema(t){return await b9(t)}async dropSchema(t){return await P9(t)}async createTable(t,r){return await L9(t,r)}async dropTable(t){return await B9(t)}async createAttribute(t){return await A9(t)}async createRecords(t){return await y9(t)}async updateRecords(t){return await M9(t)}async upsertRecords(t){try{return await U9(t)}catch(r){throw g9(r,null,null,T9.ERR,r)}}async deleteRecords(t){return await O9(t)}async dropAttribute(t){return await H9(t)}async deleteAuditLogsBefore(t){return await v9(t)}async readAuditLog(t){return await x9(t)}writeTransaction(t,r,n){return k9.writeTransaction(t,r,n)}flush(t,r){return dv.flush(t,r)}resetReadTxn(t,r){return dv.resetReadTxn(t,r)}getBackup(t){return F9(t)}};_v.exports=DA});function Rv(e){LA=e}function V9(){$9=setInterval(function(){for(let e of PA)if(e.stale){let t=e[ke]?.url;mv.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},q9).unref()}var MA,pv,mv,Sv,Tv,gv,Ev,PA,G9,P_,hv,LA,pc,cp,q9,$9,lp=Oe(()=>{MA=L(cn()),pv=L(_e()),mv=L(W());Vs();Sv=L(se()),Tv=L(M()),gv=L(te()),Ev=100,PA=new Set,G9=(0,gv.convertToMS)(Sv.get(Tv.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(Rv,"replicationConfirmation");pc=class e{static{a(this,"DatabaseTransaction")}writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxnsUsed=1,this.readTxn.openTimer&&(this.readTxn.openTimer=0),PA.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(PA.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(P_&&!this.overloadChecked&&performance.now()-hv>G9)throw new pv.ServerError("Outstanding write transactions have too long of queue, please try again later",503);this.overloadChecked=!0}addWrite(t){if(this.open===0)throw new Error("Can not use a transaction that is no longer open");if(this.open===2){let r=new e;return r.addWrite(t),r.commit({})}else this.writes.push(t)}removeWrite(t){let r=this.writes.indexOf(t);r>-1&&(this.writes[r]=null)}commit(t={}){let r=this.timestamp;r||(r=this.timestamp=t.timestamp||(0,MA.getNextMonotonicTime)()),t.timestamp||(t.timestamp=r);let n=t.retries||0;if(this.validated<this.writes.length)try{let _=this.validated;this.validated=this.writes.length;for(let f=_;f<this.validated;f++)this.writes[f]?.validate?.(this.timestamp);let E;for(let f=_;f<this.validated;f++){let h=this.writes[f];h&&(h.before||h.beforeIntermediate)&&(E=!0)}if(E)return(async()=>{try{for(let f=0;f<2;f++){let h;for(let T=_;T<this.validated;T++){let m=this.writes[T];if(!m)continue;let g=m[f===0?"before":"beforeIntermediate"];if(g){let S=g();h?h.push?h.push(S):h=[h,S]:h=S}}h&&await(h.push?Promise.all(h):h)}}catch(f){throw this.abort(),f}return this.commit(t)})()}catch(_){throw this.abort(),_}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(_=>_);let c=a(_=>{_.commit(r,_.entry,n)},"doWrite"),l=a(()=>{let _=this.writes[o++];if(_)if(_.key){n>0&&(_.entry=_.store.getEntry(_.key));let E=_.store.ifVersion(_.key,_.entry?.version??null,l);s=s||E}else l();else for(let E of this.writes)c(E)},"nextCondition"),u=this.lmdbDb;if(this.writes.length>0&&(u?.retryRisk&&(u.retryRisk*=.99),this.writes.length+(u?.retryRisk||0)<Ev>>n?l():s=this.writes[0].store.transaction(()=>{for(let _ of this.writes)_.entry=_.store.getEntry(_.key),c(_);return!0})),s)return P_||(P_=s,hv=performance.now(),P_.then(()=>{P_=null})),s.then(_=>{if(_){if(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.replicatedConfirmation){let E=this.writes[0].store.rootStore.databaseName,f=this.writes[this.writes.length-1];LA&&f&&i.push(LA(E,f.store.getEntry(f.key).localTime,this.replicatedConfirmation))}return this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))}else return u&&(u.retryRisk=(u.retryRisk||0)+Ev/2),t?t.retries=n+1:t={retries:1},this.commit(t)});let d={txnTime:r};if(this.next){let _=this.next?.commit(t);if(_?.then)return _?.then(E=>({txnTime:r,next:E}));d.next=_}return d}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},cp=class extends pc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,MA.getNextMonotonicTime)())}getReadTxn(){}},q9=3e4;a(V9,"startMonitoringTxns");V9()});function Dt(e,t,r){if(!t)t=e,e={};else if(!e)e={};else if(e?.transaction?.open===1&&typeof t=="function")return t(e.transaction);if(typeof t!="function")throw new Error("Callback function must be provided to transaction");let n=e.transaction=new pc;e.timestamp&&(n.timestamp=e.timestamp),e.replicatedConfirmation&&(n.replicatedConfirmation=e.replicatedConfirmation),n[ke]=e,e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var Av,mc=Oe(()=>{Av=L(fi());Vs();lp();a(Dt,"transaction");(0,Av._assignPackageExport)("transaction",Dt);Dt.commit=function(e){let t=(e[ke]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Dt.abort=function(e){let t=(e[ke]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var Dv={};je(Dv,{ResourceBridge:()=>BA});function HA({get_attributes:e},t){if(e){if(e[0]==="*"){if(t.schemaDefined)return;e=t.attributes.map(r=>r.name)}return e.forceNulls=!0,e}}function bv(e,t){let r=bi(e),n=HA(e,r);if(!r)throw new Ks.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache,replicateFrom:e.replicateFrom},o;Dt(i,()=>new Promise(u=>o=u));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let u=c[l++],d;try{d=await r.get({id:u,lazy:s,select:n},i),d=d&&dp(d)}catch(_){d={message:_.toString()}}return t?{value:{key:u,value:d}}:{value:d}}else return o(),{done:!0}},return(u){return o(),{value:u,done:!0}},throw(u){return o(),{done:!0}}}}}}function bi(e){let t=e.database||e.schema||Y9,r=ut()[t];if(!r)throw(0,Ks.handleHDBError)(new Error,K9.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function Ov(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}async function*Nv(e,t,r,n){let s,i=0;for await(let o of e.getHistory(t,r)){let c=o.operation??o.type;c==="put"&&(c="upsert");let{id:l,version:u,value:d}=o;if(s?.timestamp===u)s.hash_values.push(l),s.records.push(d);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:u,hash_values:[l],records:[d]}}}s&&(yield s)}var Iv,up,Ks,wv,Ys,UA,vA,Cv,K9,Y9,W9,j9,yv,BA,Pv=Oe(()=>{"use strict";Iv=L(fv()),up=L($l()),Ks=L(_e());Pe();wv=L(f_()),Ys=L(M()),UA=L(no()),vA=L(qs()),Cv=L(te());mc();_p();({HDB_ERROR_MSGS:K9}=Ks.hdb_errors),Y9="data",W9=1e4,j9=10,BA=class extends Iv.default{static{a(this,"ResourceBridge")}constructor(t){super(t),yv=this}async searchByConditions(t){t.select!==void 0&&(t.get_attributes=t.select);for(let o of t.conditions||[])o?.attribute!==void 0&&(o.search_attribute=o.attribute),o?.comparator!==void 0&&(o.search_type=o.comparator),o?.value!==void 0&&(o.search_value=o.value);let r=(0,up.default)(t,"conditions");if(r)throw(0,Ks.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=bi(t);if(!n)throw new Ks.ClientError(`Table ${t.table} not found`);let s=t.conditions.map(i);function i(o){return o.conditions?(o.conditions=o.conditions.map(i),o):{attribute:o.search_attribute??o.attribute,comparator:o.search_type??o.comparator,value:o.search_value!==void 0?o.search_value:o.value}}return a(i,"mapCondition"),n.search({conditions:s,operator:t.operator?t.operator.toLowerCase():void 0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:HA(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new Ks.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}Et({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await bi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=bi(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c={...c},delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(u=>{if(!u){let{value:d,version:_}=r.primaryStore.getEntry(o);return i(o,d,_)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(u=>setImmediate(u));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){bi(t).dropTable()}createSchema(t){return Yl({database:t.schema,table:null}),UA.signalSchemaChange(new vA.SchemaEventMsg(process.pid,Ys.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await xA(t.schema),UA.signalSchemaChange(new vA.SchemaEventMsg(process.pid,Ys.OPERATIONS_ENUM.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,yv.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,wv.default)(t),s,i=ut()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(o.replicateTo=t.replicateTo),t.replicatedConfirmation&&(o.replicatedConfirmation=t.replicatedConfirmation),Dt(o,async c=>{if(!i.schemaDefined){s=[];for(let d of n)i.attributes.find(E=>E.name==d)||s.push(d);s.length>0&&await i.addAttributes(s.map(d=>({name:d,indexed:!0})))}let l=[],u=[];for(let d of t.records){let _=d[i.primaryKey],E=_!=null&&await i.get(_,o);if(t.requires_existing&&!E||t.requires_no_existing&&E){u.push(d[i.primaryKey]);continue}E&&(E=dp(E));for(let f in d)if(Object.prototype.hasOwnProperty.call(d,f)){let h=d[f];if(typeof h=="function")try{let T=h([[E]]);Array.isArray(T)&&(h=T[0].func_val,d[f]=h)}catch(T){throw T.message+="Trying to set key "+f+" on object"+JSON.stringify(d),T}}if(E)for(let f in E)Object.prototype.hasOwnProperty.call(d,f)||(d[f]=E[f]);await(_==null?i.create(d,o):i.put(d,o)),l.push(d[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:u}})}async deleteRecords(t){let r=ut()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),Dt(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),o=[],c=[];for(let l of i)await r.delete(l,n)?o.push(l):c.push(l);return Ov(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=ut()[t.schema][t.table];if(!r.createdTimeProperty)throw new Ks.ClientError("Table must have a '__createdtime__' attribute or @createdTime timestamp defined to perform this operation");let n=await r.search({conditions:[{attribute:r.createdTimeProperty.name,value:Date.parse(t.date),comparator:Ys.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,l=[],u=a(async()=>{let d=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...d.deleted_hashes),o.push(...d.skipped_hashes),await(0,Cv.async_set_timeout)(j9),l=[],s=!0},"chunkDelete");for await(let d of n)l.push(d[r.primaryKey]),c++,c%W9===0&&await u();return l.length>0&&await u(),s?Ov(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,up.default)(t,"hashes");if(r)throw r;return bv(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of bv(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Ys.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r]===void 0)throw new Error(`Value search comparator - ${r} - is not valid`);t.select!==void 0&&(t.get_attributes=t.select),t.attribute!==void 0&&(t.search_attribute=condition.attribute),t.value!==void 0&&(t.search_value=condition.value);let n=(0,up.default)(t,"value");if(n)throw n;let s=bi(t);if(!s)throw new Ks.ClientError(`Table ${t.table} not found`);let i=t.search_value;i.includes?.("*")&&(i.startsWith("*")?i.endsWith("*")?i!=="*"&&(r="contains",i=i.slice(1,-1)):(r="ends_with",i=i.slice(1)):i.endsWith("*")&&(r="starts_with",i=i.slice(0,-1))),r===Ys.VALUE_SEARCH_COMPARATORS.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,sort:t.sort,select:HA(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=bi(t);t.get_attributes&&!t.get_attributes.includes(s.primaryKey)&&t.get_attributes[0]!=="*"&&t.get_attributes.push(s.primaryKey);for await(let i of this.searchByValue(t,r))n.set(i[s.primaryKey],i);return n}resetReadTxn(t,r){bi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return bi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=bi(t),n={};switch(t.search_type){case Ys.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.operation??o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case Ys.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of Nv(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return Nv(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(HA,"getSelect");a(bv,"getRecords");a(bi,"getTable");a(Ov,"createDeleteResponse");a(Nv,"groupRecordsInHistory")});var Bn=N((uOe,Lv)=>{"use strict";var{ResourceBridge:z9}=(Pv(),oe(Dv)),Q9=se();Q9.initSync();var fp;function J9(){return fp||(fp=new z9,fp)}a(J9,"getBridge");Lv.exports=J9()});var Bv=N((_Oe,vv)=>{"use strict";var Mv=require("lodash"),L_=require("mathjs"),X9=require("jsonata"),Uv=te();vv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?Mv.uniqWith(e,Mv.isEqual):e,"distinct_array"),searchJSON:Z9,mad:M_.bind(null,L_.mad),mean:M_.bind(null,L_.mean),mode:M_.bind(null,L_.mode),prod:M_.bind(null,L_.prod),median:M_.bind(null,L_.median)};function M_(e,t,r,n){return n===1?t==null?[]:[t]:n===2?(t!=null&&r.push(t),r):r!=null&&r.length>0?e(r):null}a(M_,"aggregateFunction");function Z9(e,t){if(typeof e!="string"||e.length===0)throw new Error("search json expression must be a non-empty string");let r="__"+e+"__";if(Uv.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),Uv.isEmpty(this.__ala__.res[r])){let n=X9(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(Z9,"searchJSON")});var xv=N((EOe,Hv)=>{"use strict";var nr=require("moment"),kA="YYYY-MM-DDTHH:mm:ss.SSSZZ";nr.suppressDeprecationWarnings=!0;Hv.exports={current_date:a(()=>nr().utc().format("YYYY-MM-DD"),"current_date"),current_time:a(()=>nr().utc().format("HH:mm:ss.SSS"),"current_time"),extract:a((e,t)=>{switch(t.toLowerCase()){case"year":return nr(e).utc().format("YYYY");case"month":return nr(e).utc().format("MM");case"day":return nr(e).utc().format("DD");case"hour":return nr(e).utc().format("HH");case"minute":return nr(e).utc().format("mm");case"second":return nr(e).utc().format("ss");case"millisecond":return nr(e).utc().format("SSS");default:break}},"extract"),date:a(e=>nr(e).utc().format(kA),"date"),date_format:a((e,t)=>nr(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>nr(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>nr(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=nr(e).utc(),s=nr(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>nr().utc().valueOf(),"now"),get_server_time:a(()=>nr().format(kA),"get_server_time"),offset_utc:a((e,t)=>nr(e).utc().utcOffset(t).format(kA),"offset_utc")}});var qv=N((pOe,Gv)=>{"use strict";var e7=require("@turf/area"),t7=require("@turf/length"),r7=require("@turf/circle"),n7=require("@turf/difference"),s7=require("@turf/distance"),i7=require("@turf/boolean-contains"),o7=require("@turf/boolean-equal"),a7=require("@turf/boolean-disjoint"),c7=require("@turf/helpers"),kv=M(),$e=te(),oo=W();Gv.exports={geoArea:l7,geoLength:u7,geoCircle:d7,geoDifference:_7,geoDistance:Fv,geoNear:f7,geoContains:E7,geoEqual:h7,geoCrosses:p7,geoConvert:m7};function l7(e){if($e.isEmpty(e))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return e7.default(e)}catch(t){return oo.trace(t,e),NaN}}a(l7,"geoArea");function u7(e,t){if($e.isEmpty(e))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return t7.default(e,{units:t||"kilometers"})}catch(r){return oo.trace(r,e),NaN}}a(u7,"geoLength");function d7(e,t,r){if($e.isEmpty(e))return NaN;if($e.isEmpty(t))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return r7.default(e,t,{units:r||"kilometers"})}catch(n){return oo.trace(n,e,t),NaN}}a(d7,"geoCircle");function _7(e,t){if($e.isEmpty(e))return NaN;if($e.isEmpty(t))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return n7(e,t)}catch(r){return oo.trace(r,e,t),NaN}}a(_7,"geoDifference");function Fv(e,t,r){if($e.isEmpty(e))return NaN;if($e.isEmpty(t))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return s7.default(e,t,{units:r||"kilometers"})}catch(n){return oo.trace(n,e,t),NaN}}a(Fv,"geoDistance");function f7(e,t,r,n){if($e.isEmpty(e)||$e.isEmpty(t))return!1;if($e.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return Fv(e,t,n)<=r}catch(s){return oo.trace(s,e,t),!1}}a(f7,"geoNear");function E7(e,t){if($e.isEmpty(e)||$e.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return i7.default(e,t)}catch(r){return oo.trace(r,e,t),!1}}a(E7,"geoContains");function h7(e,t){if($e.isEmpty(e)||$e.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return o7.default(e,t)}catch(r){return oo.trace(r,e,t),!1}}a(h7,"geoEqual");function p7(e,t){if($e.isEmpty(e)||$e.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return!a7.default(e,t)}catch(r){return oo.trace(r,e,t),!1}}a(p7,"geoCrosses");function m7(e,t,r){if($e.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if($e.isEmpty(t))throw new Error("geo_type is required");if($e.isEmpty(kv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(kv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=$e.autoCastJSON(e)),c7[t](e,r)}a(m7,"geoConvert")});var Ep=N((SOe,$v)=>{var Sc=Bv(),Gn=xv(),Oi=qv();$v.exports=e=>{e.aggr.mad=e.aggr.MAD=Sc.mad,e.aggr.mean=e.aggr.MEAN=Sc.mean,e.aggr.mode=e.aggr.MODE=Sc.mode,e.aggr.prod=e.aggr.PROD=Sc.prod,e.aggr.median=e.aggr.MEDIAN=Sc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Sc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Sc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Gn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Gn.current_time,e.fn.extract=e.fn.EXTRACT=Gn.extract,e.fn.date=e.fn.DATE=Gn.date,e.fn.date_format=e.fn.DATE_FORMAT=Gn.date_format,e.fn.date_add=e.fn.DATE_ADD=Gn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Gn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Gn.date_diff,e.fn.now=e.fn.NOW=Gn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Gn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Gn.get_server_time,e.fn.getdate=e.fn.GETDATE=Gn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Gn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Oi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Oi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Oi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Oi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Oi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Oi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Oi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Oi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Oi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Oi.geoNear}});var Wv=N((TOe,Yv)=>{"use strict";var U_=require("lodash"),_n=require("alasql");_n.options.cache=!1;var S7=Ep(),Vv=require("clone"),hp=require("recursive-iterator"),Ue=W(),et=te(),Wl=Bn(),T7=M(),{hdb_errors:g7}=_e(),{getDatabases:Kv}=(Pe(),oe(lt)),R7="IS NULL",Ws="There was a problem performing this search. Please check the logs and try again.";S7(_n);var FA=class{static{a(this,"SQLSearch")}constructor(t,r){if(et.isEmpty(t))throw Ue.error("AST statement for SQL select process cannot be empty"),"statement cannot be null";this.statement=t,this.columns={},this.all_table_attributes=r,this.fetch_attributes=[],this.exact_search_values={},this.comparator_search_values={},this.tables=[],this.data={},this.has_aggregator=!1,this.has_ordinal=!1,this.has_outer_join=!1,this._getColumns(),this._getTables(),this._conditionsToFetchAttributeValues(),this._setAliasesForColumns(),et.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!et.isEmptyOrZeroLength(n))return Ue.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw Ue.error("Error thrown from checkEmptySQL in SQLSearch class method search."),Ue.error(n),new Error(Ws)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw Ue.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),Ue.error(n),new Error(Ws)}if(Object.keys(this.data).length===0)return Ue.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw Ue.error("Error thrown from processJoins in SQLSearch class method search."),Ue.error(n),new Error(Ws)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw Ue.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),Ue.error(n),new Error(Ws)}try{return t=await this._finalSQL(),t}catch(n){throw Ue.error("Error thrown from finalSQL in SQLSearch class method search."),Ue.error(n),new Error(Ws)}}_getColumns(){let t=new hp(this.statement);for(let{node:r,path:n}of t)r&&r.columnid&&(this.columns[n[0]]||(this.columns[n[0]]=[]),this.columns[n[0]].push(Vv(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=U_.uniqBy(t,r=>[r.databaseid,r.tableid,r.as].join()),this.tables.forEach(r=>{let n=`${r.databaseid}_${r.as?r.as:r.tableid}`;this.data[n]={},this.data[n].__hash_name=Kv()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(et.isEmpty(this.statement.where)){Ue.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new hp(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!et.isEmpty(r)&&r.right)if(et.isNotEmptyAndHasValue(r.right.value)){let n=et.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new _n.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=et.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new _n.yy.LogicValue({value:i}):n instanceof _n.yy.StringValue&&et.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new _n.yy.NumValue({value:i}))});if(t){Ue.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new hp(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let n=new Set,s=r.left.columnid?r.left:r.right,i=this._findColumn(s);if(!i)continue;let o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!et.isEmpty(T7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(et.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(et.isEmptyOrZeroLength(r.left.columnid)||et.isEmptyOrZeroLength(r.right.value)){this.comparator_search_values[o].ignore=!0,this.comparator_search_values[o].comparators=[];continue}this.comparator_search_values[o].comparators.push({attribute:r.left.columnid,operation:r.op,search_value:r.right.value})}continue}if(et.isEmpty(this.exact_search_values[o])&&(this.exact_search_values[o]={ignore:!1,values:new Set}),!this.exact_search_values[o].ignore){let c=!1;switch(r.op){case"=":!et.isEmpty(r.right.value)||!et.isEmpty(r.left.value)?n.add(et.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let l=Array.isArray(r.right)?r.right:r.left;for(let u=0;u<l.length;u++)if(l[u].value)n.add(l[u].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(et.isEmptyOrZeroLength(this.all_table_attributes)&&et.isEmptyOrZeroLength(this.statement.from)&&et.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((n,s)=>{if(n.columnid==="*"){t.push(s);return}if(n.aggregatorid&&(this.has_aggregator=!0),!n.aggregatorid&&!n.funcid)if(n.as_orig=n.as?n.as:n.columnid,this.statement.joins)if(r[n.as_orig]>=0){let i=r[n.as_orig]+1;n.as=`[${n.as_orig+i}]`,r[n.as_orig]=i}else n.as=`[${n.as_orig}]`,r[n.as_orig]=0;else n.as=`[${n.as_orig}]`;!n.aggregatorid&&n.funcid&&n.args&&(n.as_orig=n.as?n.as:n.toString().replace(/'/g,'"'),n.as=`[${n.as_orig}]`),n.aggregatorid&&n.expression.columnid!=="*"&&(n.as_orig=n.as?n.as:n.expression.tableid?`${n.aggregatorid}(${n.expression.tableid}.${n.expression.columnid})`:`${n.aggregatorid}(${n.expression.columnid})`,n.as=`[${n.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&U_.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(et.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);et.isEmptyOrZeroLength(n)||(r=this.all_table_attributes.filter(s=>s.attribute===n[0].columnid&&n[0].tableid&&n[0].tableid===(s.table.as?s.table.as:s.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(et.isEmptyOrZeroLength(this.all_table_attributes)&&!et.isEmptyOrZeroLength(this.columns.columns))return t;if(et.isEmptyOrZeroLength(this.all_table_attributes)&&et.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await _n.promise(r)}catch(r){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),Ue.error(r),new Error("There was a problem with the SQL statement")}return t}_addFetchColumns(t){t&&t.length>0&&t.forEach(r=>{let n=this._findColumn(r);n&&this.fetch_attributes.push(Vv(n))})}_addColumnToMergedAttributes(t,r){this.data[t].__merged_attributes.push(r),this.data[t].__merged_attr_map[r]=this.data[t].__merged_attributes.length-1}_setMergedHashAttribute(t,r){this.data[t].__merged_data[r].splice(0,1,r)}_updateMergedAttribute(t,r,n,s){let i=this.data[t].__merged_attr_map[n];this.data[t].__merged_data[r].splice(i,1,s)}async _getFetchAttributeValues(){if(et.isEmptyOrZeroLength(Object.keys(this.columns)))return[];this._addFetchColumns(this.columns.joins);let t=null;try{t=this.statement.where?this.statement.where.toString():""}catch{throw new Error("Could not generate proper where clause")}this.columns.where&&this._addFetchColumns(this.columns.where);let r=this._isSimpleSelect();if(r?this._addFetchColumns(this.columns.columns):(!this.columns.where&&this.fetch_attributes.length===0)|t.indexOf(R7)>-1&&this.tables.forEach(s=>{let i={columnid:Kv()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=U_.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,u=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!et.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!et.isEmptyOrZeroLength(this.exact_search_values[u].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[u].values);let d=await Wl.getDataByHash(c);for(let _ of c.hash_values)d.get(_)&&!this.data[i].__merged_data[_]&&(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_))}catch(d){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(d),new Error(Ws)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async d=>{let _={...c};_.search_value=d;let E=await Wl.getDataByValue(_);for(let[f,h]of E)this.data[i].__merged_data[f]?this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]):(this.data[i].__merged_data[f]=[...n[i]],this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,f))}))}catch(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(d),new Error(Ws)}else if(!et.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!et.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let d=this.comparator_search_values[u].comparators;for(let _=0,E=d.length;_<E;_++){let f=d[_];c.search_attribute=f.attribute,c.search_value=f.search_value;let h=await Wl.getDataByValue(c,f.operation);if(l)for(let[T]of h)this.data[i].__merged_data[T]||(this.data[i].__merged_data[T]=[...n[i]],this._setMergedHashAttribute(i,T));else for(let[T,m]of h)this.data[i].__merged_data[T]?this._updateMergedAttribute(i,T,s.attribute,m[s.attribute]):(this.data[i].__merged_data[T]=[...n[i]],this._updateMergedAttribute(i,T,s.attribute,m[s.attribute]),this._setMergedHashAttribute(i,T))}}catch(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),Ue.error(d),new Error(Ws)}else try{c.search_attribute=s.attribute,c.search_value="*";let d=await Wl.getDataByValue(c);if(l)for(let[_]of d)this.data[i].__merged_data[_]||(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_));else for(let[_,E]of d)this.data[i].__merged_data[_]?this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]):(this.data[i].__merged_data[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]),this._setMergedHashAttribute(i,_))}catch(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),Ue.error(d),new Error(Ws)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof _n.yy.Column||(t=!1)}),t)}_updateOrderByToAliases(){this.statement.order.forEach(t=>{if(t.expression.aggregatorid){t.is_aggregator=!0;return}if(t.expression.value){t.is_ordinal=!0,this.has_ordinal=!0;return}else t.is_ordinal=!1;let r=this.statement.columns.filter(s=>{let i=s.aggregatorid?s.expression:s,o=s.aggregatorid?s.as_orig:i.as_orig;return t.expression.tableid?i.columnid_orig===t.expression.columnid_orig&&i.tableid_orig===t.expression.tableid_orig:i.columnid_orig===t.expression.columnid_orig||t.expression.columnid_orig===o});r[0]||r.push(this._findColumn(t.expression));let n=r[0];if(t.is_func=!!n.funcid,t.is_aggregator=!!n.aggregatorid,n.as)if(n.as&&!t.expression.tableid)t.expression.columnid=n.as,t.expression.columnid_orig=n.as_orig;else{let s=new _n.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new _n.yy.Column,t.expression),t.initial_select_column.as=`[${t.expression.columnid_orig}]`,t.expression.columnid=t.initial_select_column.as;return}if(!t.is_aggregator){let s=t.is_func?new _n.yy.FuncValue:new _n.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(f=>{f.joinmode&&f.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(f.table);let h=f.joinmode+" JOIN ? AS "+(f.as?f.as:f.table.tableid);f.on&&(h+=" ON "+f.on.toString()),i.push(h),t.push(Object.values(this.data[`${f.table.databaseid_orig}_${f.table.as?f.table.as_orig:f.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(f=>{let h=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__hash_name,T=f.as?f.as_orig:f.tableid_orig;o.push({key:`'${T}.${h}'`,schema:f.databaseid_orig,table:f.as?f.as_orig:f.tableid_orig,keys:new Set}),r.push(`${f.as?f.as:f.tableid}.\`${h}\` AS "${T}.${h}"`),c[f.as?f.as_orig:f.tableid_orig]=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let u="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(u="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(f=>{f.is_func?r.push(f.initial_select_column.toString()):f.initial_select_column.tableid?r.push(`${f.initial_select_column.tableid}.${f.initial_select_column.columnid} AS ${f.expression.columnid}`):r.push(`${f.initial_select_column.columnid} AS ${f.expression.columnid}`)}));let d="",_="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(d=this.statement.limit?"LIMIT "+this.statement.limit:"",_=this.statement.offset?"OFFSET "+this.statement.offset:"");let E=[];try{let f=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${u} ${d} ${_}`,h=this._convertColumnsToIndexes(f,s);E=await _n.promise(h,t),t=null}catch(f){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),Ue.error(f),new Error("There was a problem processing the data.")}if(E&&E.length>0){for(let f=0,h=E.length;f<h;f++){let T=E[f];o.forEach(m=>{T[m.key]!==null&&T[m.key]!==void 0&&m.keys.add(T[m.key])})}o.forEach(f=>{let h=Object.keys(this.data[`${f.schema}_${f.table}`].__merged_data),T=U_.difference(h,[...f.keys].map(m=>m.toString()));for(let m=0,g=T.length;m<g;m++){let S=T[m];delete this.data[`${f.schema}_${f.table}`].__merged_data[S]}})}return{existing_attributes:c,joined_length:E?E.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new hp(this.columns);for(let{node:i}of s)if(i&&i.columnid){let o=this._findColumn(i);if(o){let c=o.table.as?o.table.as:o.table.tableid;(!t[c]||t[c].indexOf(o.attribute)<0)&&n.push(o)}}n=U_.uniqBy(n,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(n)}catch(i){throw Ue.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),Ue.error(i),new Error(Ws)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__merged_data,o=[];for(let d in i)o.push(i[d][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await Wl.getDataByHash(c),u=s.columns.length;for(let d=0,_=o.length;d<_;d++){let E=o[d],f=l.get(E);for(let h=0;h<u;h++){let T=s.columns[h],m=f[T]===void 0?null:f[T];this.data[n].__merged_data[E].push(m)}}}}catch(r){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getData."),Ue.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__merged_data)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,l=o.aggregatorid?o.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===l}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();Ue.trace(`Final SQL: ${s}`),n=await _n.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),Ue.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),Ue.error(s),new Error("There was a problem running the generated sql.")}return n}_translateUndefinedValues(t){try{let r=[];for(let n of t){let s=Object.create(null);Object.keys(n).forEach(i=>{n[i]===void 0?s[i]=null:s[i]=n[i]}),r.push(s)}return r}catch(r){return Ue.error(g7.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),Ue.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],u=new RegExp(`${l}.\`${o}\``,"g"),d=`${l}.[${c}]`;n=n.replace(u,d)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),u=`[${c}]`;n=n.replace(l,u)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await Wl.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]={...r[s]}),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw Ue.error("There was an error when processing this SQL operation. Check your logs"),Ue.error(o),new Error(Ws)}}return Object.values(Object.values(this.data)[0].__merged_data)}};Yv.exports=FA});var Vr=N((ROe,jv)=>{"use strict";var A7=YD();jv.exports={searchByConditions:b7,searchByHash:O7,searchByValue:N7,search:I7};var GA=Bn(),{transformReq:qA}=te(),y7=Wv();async function b7(e){return qA(e),GA.searchByConditions(e)}a(b7,"searchByConditions");async function O7(e){qA(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of GA.searchByHash(e))r&&t.push(r);return t}a(O7,"searchByHash");async function N7(e){qA(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of GA.searchByValue(e))t.push(r);return t}a(N7,"searchByValue");function I7(e,t){try{let r=new A7(e);r.validate(),new y7(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(I7,"search")});var pp=N((yOe,zv)=>{"use strict";var w7=Bn();zv.exports={writeTransaction:C7};function C7(e,t,r){return w7.writeTransaction(e,t,r)}a(C7,"writeTransaction")});var Zv=N((NOe,Xv)=>{"use strict";var D7=Vr(),P7=ls(),Qv=W(),L7=un(),OOe=pp(),M7=require("clone"),VA=require("alasql"),U7=Ep(),Jv=require("util"),v7=Jv.promisify(P7.getTableSchema),B7=Jv.promisify(D7.search),H7=M(),$A=te();U7(VA);Xv.exports={update:k7};var x7="There was a problem performing this update. Please check the logs and try again.";async function k7({statement:e,hdb_user:t}){let r=await v7(e.table.databaseid,e.table.tableid),n=F7(e.columns);$A.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=M7(s),c=$A.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=VA.parse(l).statements[0],d=await B7(u),_=G7(n,d);return q7(o,_,t)}a(k7,"update");function F7(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=VA.compile(`SELECT ${r.expression.toString()} AS [${H7.FUNC_VAL}] FROM ?`)}),t}catch(t){throw Qv.error(t),new Error(x7)}}a(F7,"createUpdateRecord");function G7(e,t){return $A.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(G7,"buildUpdateRecords");async function q7(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await L7.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){Qv.error(`Error delete new_attributes from update response: ${i}`)}return s}a(q7,"updateRecords")});var t0=N((DOe,e0)=>{var $7=require("alasql"),V7=Vr(),K7=W(),Y7=Bn(),YA=require("util"),KA=te(),W7=M(),j7=ls(),wOe=pp(),COe=un(),z7="record",Q7="successfully deleted",J7=YA.callbackify(tee),X7=YA.promisify(V7.search),Z7=YA.promisify(j7.getTableSchema);e0.exports={convertDelete:J7};function eee(e){return`${e.deleted_hashes.length} ${z7}${e.deleted_hashes.length===1?"":"s"} ${Q7}`}a(eee,"generateReturnMessage");async function tee({statement:e,hdb_user:t}){let r=await Z7(e.table.databaseid,e.table.tableid);KA.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=KA.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=$7.parse(o).statements[0],l={operation:W7.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await X7(c);let u=await Y7.deleteRecords(l);return KA.isEmptyOrZeroLength(u.message)&&(u.message=eee(u)),delete u.txn_time,u}catch(u){throw K7.error(u),u.hdb_code?u.message:u}}a(tee,"convertDelete")});var o0=N((LOe,i0)=>{"use strict";var ree=ro(),{hdb_errors:r0}=_e(),{getDatabases:n0}=(Pe(),oe(lt));i0.exports={checkSchemaExists:s0,checkSchemaTableExists:nee,schema_describe:ree};async function s0(e){if(!n0()[e])return r0.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(s0,"checkSchemaExists");async function nee(e,t){let r=await s0(e);if(r)return r;if(!n0()[e][t])return r0.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(nee,"checkSchemaTableExists")});var jl=N((UOe,see)=>{see.exports={name:"harperdb",version:"4.4.16",description:"HarperDB is a distributed database, caching service, streaming broker, and application development platform focused on performance and ease of use.",keywords:["database","nosql","api","distributed","broker","mqtt","real-time","enterprise","Fastify","NATS","HarperDB","Harper","clustering","replication","REST","WebSockets","decentralized","server-sent events","document store"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{"minimum-node":"16.0.0","go-lang":"1.21.7","nats-server":"2.10.11"},exports:{".":"./index.js"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"SEE LICENSE IN LICENSE",scripts:{submodules:"git submodule update --init --recursive","cover:test":"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && nyc --no-clean --reporter=lcovonly npm run test:replication && nyc --no-clean --reporter=lcovonly npm run test:apitests && nyc --no-clean --reporter=lcovonly npm run test:resources && nyc --no-clean --reporter=lcovonly npm run test:logging && nyc --no-clean --reporter=lcovonly npm run test:upgrade && nyc --no-clean --reporter=lcovonly npm run test:nats && nyc --no-clean --reporter=lcovonly npm run test:cfserver && nyc --no-clean --reporter=lcovonly npm run test:hdbserver && nyc --no-clean --reporter=lcovonly npm run test:bin && nyc --no-clean --reporter=lcovonly npm run test:main && nyc --no-clean --reporter=lcovonly npm run test:security && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license",test:"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && npm run test:replication && npm run test:apitests && npm run test:resources && npm run test:logging && npm run test:upgrade && npm run test:nats && npm run test:cfserver && npm run test:hdbserver && npm run test:bin && npm run test:main && npm run test:security && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license","test:resources":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/resources/**/*.js' --config '../unitTests/.mocharc.json'","test:bin":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/bin/**/*.js' --config '../unitTests/.mocharc.json'","test:main":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","test:lmdbbridge":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --config '../unitTests/.mocharc.json'","test:lmdbutility":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --config '../unitTests/.mocharc.json'","test:hdbserver":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --config '../unitTests/.mocharc.json'","test:cfserver":"npm run submodules && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/fastifyRoutes/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","test:nats":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","test:upgrade":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --config '../unitTests/.mocharc.json'","test:apitests":"pm2 kill && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/apiTests/**/*-test.mjs' --config '../unitTests/.mocharc.json'","test:logging":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/logging/*.js' --config '../unitTests/.mocharc.json'","test:ci":" cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --retries 3 --config '../unitTests/.mocharc-main.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter","test:security":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/security/**/*.js' --config '../unitTests/.mocharc.json'","test:replication":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/replication/**/*.js' --config '../unitTests/.mocharc.json'","hdb-check":"./utility/devops/hdb-check.sh","download-prebuilds":"node ./utility/devops/build/download-prebuilds.js",prebuild:"date",postinstall:"node ./launchServiceScripts/launchInstallNATSServer.js",build_nats_dependency:"node ./utility/devops/nats/builder.js",coverage:"nyc --reporter=lcov npm test",format:"prettier .","format:fix":"npm run format -- --write",lint:"eslint .","lint:fix":"npm run lint -- --fix"},dependencies:{"@aws-sdk/client-s3":"3.717.0","@aws-sdk/lib-storage":"3.717.0","@endo/static-module-record":"^1.0.4","@fastify/autoload":"5.10.0","@fastify/compress":"~6.5.0","@fastify/cors":"~9.0.1","@fastify/static":"~7.0.4","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"4.1.10","cbor-x":"1.6.0",chalk:"4.1.2","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.2",fastify:"~4.29.0","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.10.0","gunzip-maybe":"1.4.2","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.12.2","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.7",jsonwebtoken:"9.0.2",lmdb:"3.2.2",lodash:"4.17.21",mathjs:"11.12.0",minimist:"1.2.8",moment:"2.30.1","mqtt-packet":"~9.0.0",msgpackr:"1.11.2",nats:"2.19.0",needle:"3.3.1","node-forge":"^1.3.1","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.3",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.4.1",prompt:"1.3.0","properties-reader":"2.3.0","recursive-iterator":"3.3.0",semver:"7.5.4",send:"^1.1.0","serve-static":"2.1.0",ses:"1.1.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.24.5","tar-fs":"3.0.6",ulidx:"0.5.0",uuid:"10.0.0","validate.js":"0.13.1",ws:"8.18.0",yaml:"2.7.0"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"20.14.8","@typescript-eslint/eslint-plugin":"^7.18.0","@typescript-eslint/parser":"^7.18.0",axios:"1.7.5",chai:"4.4.1","chai-integer":"0.1.0",esbuild:"^0.24.2",eslint:"^9.17.0","eslint-config-prettier":"^9.1.0","eslint-plugin-sonarjs":"^3.0.1",eventsource:"^2.0.2","graphql-http":"^1.22.3","hook-std":"3.0.0","intercept-stdout":"0.1.2",mkcert:"1.5.1",mocha:"^11.0.1","mocha-teamcity-reporter":"^4.2.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.8",newman:"6.1.3","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"3.3.3",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0","source-map-support":"^0.5.21",typescript:"^5.7.2",undici:"^6.19.8","why-is-node-still-running":"^1.0.0"},overrides:{alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","segfault-handler":"^1.3.0","utf-8-validate":"^5.0.10"}}});var k_={};je(k_,{addAnalyticsListener:()=>x_,recordAction:()=>pr,recordActionBinary:()=>qn,setAnalyticsEnabled:()=>iee});function iee(e){h0=e}function pr(e,t,r,n,s){if(!h0)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=Tp.get(i);if(o)if(typeof e=="number"){let c=o.values,l=c.index++;if(l>=c.length){let u=c;o.values=c=new Float32Array(l*2),c.set(u),c.index=l+1}c[l]=e,o.total+=e}else if(typeof e=="boolean")e&&o.total++,o.count++;else if(typeof e=="function")o.count++;else throw new TypeError("Invalid metric value type "+typeof e);else{if(typeof e=="number")o={total:e,values:new Float32Array(4)},o.values.index=1,o.values[0]=e,o.total=e;else if(typeof e=="boolean")o={},o.total=e?1:0,o.count=1;else if(typeof e=="function")o={},o.count=1,o.callback=e;else throw new TypeError("Invalid metric value type "+typeof e);o.description={metric:t,path:r,method:n,type:s},Tp.set(i,o)}mp||oee()}function qn(e,t,r,n,s){pr(!!e,t,r,n,s)}function x_(e){S0.push(e)}function oee(){mp=performance.now(),setTimeout(async()=>{let e=performance.now()-mp;mp=0;let t=[],r={time:Date.now(),period:e,threadId:Tc.threadId,metrics:t};for(let[s,i]of Tp){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,u=[],d;for(let _ of T0){let E=Math.floor(c*_),f=o[E-1];if(E>l){let h=E-l;if(f===d){let T=u[u.length-1];typeof T=="number"?u[u.length-1]={value:T,count:1+h}:T.count+=h}else u.push(h>1?{value:f,count:h}:f),d=f;l=E}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:u,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await g0()}let n=process.memoryUsage();t.push({metric:"memory",threadId:Tc.threadId,byThread:!0,...n});for(let s of S0)s(t);Tp=new Map,Tc.parentPort?Tc.parentPort.postMessage({type:m0,report:r}):y0({report:r})},p0).unref()}async function aee(e,t=6e4){let r=zA(),n=R0(),s=new Promise(T=>{let m=performance.now();setImmediate(()=>{let g=performance.now();g-m>5e3&&(0,v_.warn)("Unusually high event queue latency on the main thread of "+Math.round(g-m)+"ms"),m=performance.now()}),n.primaryStore.prefetch([1],()=>{let g=performance.now();g-m>5e3&&(0,v_.warn)("Unusually high task queue latency on the main thread of "+Math.round(g-m)+"ms"),T(g-m)})}),i;for(let T of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(T.value?.time){i=T.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,u=[],d;for(let{key:T,value:m}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!m)continue;if(o){if(T>o+t)break}else o=T;d=T;let{metrics:g,threadId:S}=m;for(let b of g||[]){let{path:I,method:B,type:H,metric:X,count:Y,total:V,distribution:ne,threads:Q,...de}=b;Y||(Y=1);let j=X+(I?"-"+I:"");B!==void 0&&(j+="-"+B),H!==void 0&&(j+="-"+H);let ae=c.get(j);if(ae){if(ae.threads){let ye=ae.threads[S];if(ye)ae=ye;else{ae.threads[S]={...de};continue}}ae.count||(ae.count=1);let Ae=ae.count;for(let ye in de){let Me=de[ye];typeof Me=="number"&&(ae[ye]=(ae[ye]*Ae+Me*Y)/(Ae+Y))}ae.count+=Y,V>=0&&(ae.total+=V,ae.ratio=ae.total/ae.count)}else ae={period:t,...b},delete ae.distribution,c.set(j,ae),ae.byThread&&(ae.threads=[],ae.threads[S]={...de},u.push(ae));if(ne){ne=ne.map(ye=>typeof ye=="number"?{value:ye,count:1}:ye);let Ae=l.get(j);Ae?Ae.push(...ne):l.set(j,ne)}}await g0()}for(let T of u){let{path:m,method:g,type:S,metric:b,count:I,total:B,distribution:H,threads:X,...Y}=T;X=X.filter(V=>V);for(let V in Y){if(typeof T[V]!="number")continue;let ne=0;for(let Q of X){let de=Q[V];typeof de=="number"&&(ne+=de)}T[V]=ne}T.count=X.length,delete T.threads,delete T.byThread}for(let[T,m]of l){let g=c.get(T);m.sort((ye,Me)=>ye.value>Me.value?1:-1);let S=g.count-1,b=[],I=0,B=0,H;for(let ye of T0){let Me=S*ye;for(;I<Me;)H=m[B++],I+=H.count,B===1&&I--;let Gr=m[B>1?B-2:0];H||(H=m[0]),b.push(H.value-(H.value-Gr.value)*(I-Me)/H.count)}let[X,Y,V,ne,Q,de,j,ae,Ae]=b;Object.assign(g,{p1:X,p10:Y,p25:V,median:ne,p75:Q,p90:de,p95:j,p99:ae,p999:Ae})}let _;for(let[T,m]of c)m.id=(0,Sp.getNextMonotonicTime)(),m.time=d,n.primaryStore.put(m.id,m,{append:!0}).then(g=>{g||n.primaryStore.put(m.id,m)}),_=!0;let E=Date.now(),{idle:f,active:h}=performance.eventLoopUtilization();if(_||h*10>f){let T=(0,Sp.getNextMonotonicTime)(),m={id:T,metric:"main-thread-utilization",idle:f-a0,active:h-c0,taskQueueLatency:await s,time:E,...process.memoryUsage()};n.primaryStore.put(T,m,{append:!0}).then(g=>{g||n.primaryStore.put(T,m)})}a0=f,c0=h}async function l0(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function zA(){return u0||(u0=Et({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function R0(){return d0||(d0=Et({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function uee(){A0=!0;let e=(0,H_.get)(jA.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await aee(p0,e),await l0(zA(),cee),await l0(R0(),lee)},Math.min(e/2,2147483647)).unref()}function y0(e,t){let r=e.report;r.threadId=t?.threadId||Tc.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(_0+=n.mean*n.count);r.totalBytesProcessed=_0,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(f0.get(t))}),f0.set(t,t.performance.eventLoopUtilization())),r.id=(0,Sp.getNextMonotonicTime)(),zA().primaryStore.put(r.id,r),A0||uee(),dee&&(b0=fee(r))}async function fee(e){if(await b0,!ea){let r=(0,B_.dirname)((0,v_.getLogFilePath)());try{ea=await(0,WA.open)((0,B_.join)(r,"analytics.log"),"r+")}catch{ea=await(0,WA.open)((0,B_.join)(r,"analytics.log"),"w+")}}let t=(await ea.stat()).size;if(t>_ee){let r=Buffer.alloc(t);await ea.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await ea.write(r,{position:0}),await ea.truncate(r.length),t=r.length}await ea.write(JSON.stringify(e)+`
|
|
12
|
-
`,t)}var Tc,
|
|
10
|
+
`)},l2="certificate.pem",u2="privateKey.pem",d2="caCertificate.pem",_2="natsCertificate.pem",f2="natsCaCertificate.pem",At={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},E2={tls_certificate:At.SERVER,tls_certificateAuthority:At.CA,customFunctions_tls_certificate:At.SERVER,customFunctions_tls_certificateAuthority:At.CA,operationsApi_tls_certificate:At["OPERATIONS-API"],operationsApi_tls_certificateAuthority:At["OPERATIONS-CA"]},h2={[At.SERVER]:2,[At.DEFAULT]:1},p2={[At["OPERATIONS-API"]]:3,[At.SERVER]:2,[At.DEFAULT]:1},m2={[At["OPERATIONS-API"]]:3,[At.SERVER]:2,[At.DEFAULT]:1},S2={[At["OPERATIONS-CA"]]:3,[At.CA]:2,[At["DEFAULT-CA"]]:1},T2={[At["OPERATIONS-CA"]]:3,[At.CA]:2,[At["DEFAULT-CA"]]:1},g2={[At.CA]:2,[At["DEFAULT-CA"]]:1};Object.assign(BC,{CERTIFICATE_PEM_NAME:l2,PRIVATEKEY_PEM_NAME:u2,CA_PEM_NAME:d2,CERT_NAME:At,CERT_CONFIG_NAME_MAP:E2,CERT_PREFERENCE_APP:h2,CERT_PREFERENCE_OPS:p2,CERT_PREFERENCE_REP:m2,CA_CERT_PREFERENCE_REP:S2,CA_CERT_PREFERENCE_OPS:T2,CA_CERT_PREFERENCE_APP:g2,CERTIFICATE_VALUES:c2,NATS_CERTIFICATE_PEM_NAME:_2,NATS_CA_PEM_NAME:f2})});var Tt=N((Hge,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:R2,validateObjectAsync:A2,validateBySchema:y2};function R2(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(R2,"validateObject");async function A2(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(A2,"validateObjectAsync");function y2(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(y2,"validateBySchema")});var gg=N((Fge,$C)=>{"use strict";var GC=require("fs-extra"),me=require("joi"),b2=require("os"),{boolean:qe,string:It,number:tr,array:za}=me.types(),{totalmem:xC}=require("os"),ja=require("path"),O2=W(),Tg=te(),kge=Sg(),kC=M(),N2=Tt(),FC="log",I2="components",w2="Invalid logging.rotation.maxSize unit. Available units are G, M or K",C2="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",D2="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",P2="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",L2="rootPath config parameter is undefined",sn=me.alternatives([tr.min(0),It]).optional().empty(null),ch=me.alternatives([za.items(It,{host:It.required(),port:sn},{hostname:It.required(),port:sn}).empty(null),za.items(It)]),pi,qC=!1;$C.exports={configValidator:M2,routesValidator:k2,route_constraints:ch};function M2(e,t=!1){if(qC=t,pi=e.rootPath,Tg.isEmpty(pi))throw L2;let r=qe.optional(),n=tr.min(0).max(1e3).empty(null).default(x2),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(v2).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:qe.optional(),databaseLevel:qe.optional(),tls:me.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:qe.required(),verify:qe.optional()}),user:It.optional().empty(null)}).optional():_=me.object({enabled:r,tls:me.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:qe.optional()})}).optional(),me.object({authentication:me.alternatives(me.object({authorizeLocal:qe,cacheTTL:tr.required(),enableSessions:qe}),qe).optional(),analytics:me.object({aggregatePeriod:tr}),replication:me.object({hostname:me.alternatives(It,tr).optional().empty(null),url:It.optional().empty(null),port:sn,securePort:sn,routes:za.optional().empty(null),databases:me.alternatives(It,za),enableRootCAs:qe.optional()}).optional(),componentsRoot:s.optional(),clustering:_,localStudio:me.object({enabled:r}).required(),logging:me.object({auditAuthEvents:me.object({logFailed:qe,logSuccessful:qe}),file:qe.required(),level:me.valid("notify","fatal","error","warn","info","debug","trace"),rotation:me.object({enabled:qe.optional(),compress:qe.optional(),interval:It.custom(H2).optional().empty(null),maxSize:It.custom(B2).optional().empty(null),path:It.optional().empty(null).default(Gd)}).required(),root:s,stdStreams:qe.required(),auditLog:qe.required()}).required(),operationsApi:me.object({network:me.object({cors:qe.optional(),corsAccessList:za.optional(),headersTimeout:tr.min(1).optional(),keepAliveTimeout:tr.min(1).optional(),port:sn,domainSocket:me.optional().empty("hdb/operations-server").default(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([qe.optional(),me.object({user:It.optional(),certificateAuthority:i,required:qe.optional()})])}).required(),webSocket:qe.optional(),requireAuthentication:qe.optional()}),http:me.object({compressionThreshold:tr.optional(),cors:qe.optional(),corsAccessList:za.optional(),headersTimeout:tr.min(1).optional(),port:sn,securePort:sn,maxHeaderSize:tr.optional(),mtls:me.alternatives([qe.optional(),me.object({user:It.optional(),certificateAuthority:i,required:qe.optional()})]),threadRange:me.alternatives([za.optional(),It.optional()])}).required(),threads:me.alternatives(n.optional(),me.object({count:n.optional(),debug:me.alternatives(qe.optional(),me.object({startingPort:tr.min(1).optional(),host:It.optional(),waitForDebugger:qe.optional()})),maxHeapMemory:tr.min(0).optional()})),storage:me.object({writeAsync:qe.required(),overlappingSync:qe.optional(),caching:qe.optional(),compression:me.alternatives([qe.optional(),me.object({dictionary:It.optional(),threshold:tr.optional()})]),compactOnStart:qe.optional(),compactOnStartKeepBackup:qe.optional(),noReadAhead:qe.optional(),path:l,prefetchWrites:qe.optional(),maxFreeSpaceToLoad:tr.optional(),maxFreeSpaceToRetain:tr.optional()}).required(),ignoreScripts:qe.optional(),tls:me.alternatives([me.array().items(d),d])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(M2,"configValidator");function U2(e){return qC||GC.existsSync(e)?null:`Specified path ${e} does not exist.`}a(U2,"doesPathExist");function v2(e,t){me.assert(e,It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=U2(e);if(r)return t.message(r)}a(v2,"validatePath");function B2(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(w2);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(D2):e}a(B2,"validateRotationMaxSize");function H2(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(C2);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(P2):e}a(H2,"validateRotationInterval");function x2(e,t){let r=t.state.path.join("."),n=b2.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),O2.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(x2,"setDefaultThreads");function Gd(e,t){let r=t.state.path.join(".");if(!Tg.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(Tg.isEmpty(pi))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return ja.join(pi,I2);case"logging.root":return ja.join(pi,FC);case"clustering.leafServer.streams.path":return ja.join(pi,"clustering","leaf");case"storage.path":let n=ja.join(pi,kC.LEGACY_DATABASES_DIR_NAME);return GC.existsSync(n)?n:ja.join(pi,kC.DATABASES_DIR_NAME);case"logging.rotation.path":return ja.join(pi,FC);case"operationsApi.network.domainSocket":return r==null?null:ja.join(pi,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(Gd,"setDefaultRoot");function k2(e){let t=me.object({routes:ch});return N2.validateBySchema({routes:e},t)}a(k2,"routesValidator")});var Qa={};je(Qa,{server:()=>it});var VC,it,qr=Ne(()=>{VC=L(fi()),it={};(0,VC._assignPackageExport)("server",it)});var wt=N(eD=>{"use strict";var on=M(),Er=te(),hr=W(),{configValidator:F2,routesValidator:KC}=gg(),$r=require("fs-extra"),WC=require("yaml"),Ln=require("path"),G2=require("is-number"),jC=require("properties-reader"),q2=require("lodash"),{handleHDBError:$2}=_e(),{HTTP_STATUS_CODES:V2,HDB_ERROR_MSGS:Cl}=Dn(),{server:K2}=(qr(),oe(Qa)),{DATABASES_PARAM_CONFIG:qd,CONFIG_PARAMS:Pn,CONFIG_PARAM_MAP:ks}=on,Y2="Unable to get config value because config is uninitialized",W2="Config successfully initialized",j2="Error backing up config file",z2="Empty parameter sent to getConfigValue",zC=Ln.join(on.PACKAGE_ROOT,"config","yaml",on.HDB_DEFAULT_CONFIG_FILE),Q2=Ln.join(on.PACKAGE_ROOT,"config","yaml","defaultNatsConfig.yaml"),J2="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:X2,getDefaultConfig:Z2,getConfigValue:JC,initConfig:dh,flattenConfig:Dl,updateConfigValue:XC,updateConfigObject:t4,getConfiguration:s4,setConfiguration:i4,readConfigFile:bg,getClusteringRoutes:o4,initOldConfig:ZC,getConfigFromFile:a4,getConfigFilePath:Ja,addConfig:c4,deleteConfigFromFile:l4,getConfigObj:u4,resolvePath:Rg,getFlatConfigObj:d4});function Rg(e){if(e?.startsWith("~/"))return Ln.join(Er.getHomeDir(),e.slice(1));let t=se();return Ln.resolve(t.getHdbBasePath(),e)}a(Rg,"resolvePath");function X2(e,t=!1){let r=Vo(zC);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=WC.parseDocument($r.readFileSync(Q2,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}lh=Dl(r.toJSON());let n;for(let c in e){let l=ks[c.toLowerCase()];if(l===Pn.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(u=>({[u]:e[c][u]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let u=l.split("_"),d=Ag(l,e[c]);l==="rootPath"&&d?.endsWith("/")&&(d=d.slice(0,-1));try{r.setIn([...u],d)}catch(_){hr.error(_)}}}n&&QC(r,n),yg(r,t);let s=r.toJSON();jt=Dl(s);let i=r.getIn(["rootPath"]),o=Ln.join(i,on.HDB_CONFIG_FILE);$r.createFileSync(o),$r.writeFileSync(o,String(r)),hr.trace(`Config file written to ${o}`)}a(X2,"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 Z2(e){if(lh===void 0){let r=Vo(zC);lh=Dl(r.toJSON())}let t=ks[e.toLowerCase()];if(t!==void 0)return lh[t.toLowerCase()]}a(Z2,"getDefaultConfig");function JC(e){if(e==null){hr.info(z2);return}if(jt===void 0){hr.trace(Y2);return}let t=ks[e.toLowerCase()];if(t!==void 0)return jt[t.toLowerCase()]}a(JC,"getConfigValue");function Ja(e=Er.getPropsFilePath()){let t=Er.getEnvCliRootPath();if(t)return Rg(Ln.join(t,on.HDB_CONFIG_FILE));let r=jC(e);return Rg(r.get(on.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(Ja,"getConfigFilePath");function dh(e=!1){if(jt===void 0||e){let t;if(!Er.noBootFile()){t=Er.getPropsFilePath();try{$r.accessSync(t,$r.constants.F_OK|$r.constants.R_OK)}catch(i){throw hr.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Ja(t),n;if(r.includes("config/settings.js"))try{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}`)}e4(n,r),yg(n);let s=n.toJSON();if(K2.config=s,jt=Dl(s),jt.logging_rotation_rotate)for(let i in YC)jt[i]&&hr.error(`Config ${YC[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);hr.trace(W2)}}a(dh,"initConfig");function e4(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(e4,"checkForUpdatedConfig");function yg(e,t=!1){let r=e.toJSON();if(r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads),r.http?.port&&r.http?.port===r.http?.securePort)throw Cl.CONFIG_VALIDATION("http.port and http.securePort cannot be the same value");if(r.operationsApi?.network?.port&&r.operationsApi?.network?.port===r.operationsApi?.network?.securePort)throw Cl.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=F2(r,t);if(n.error)throw Cl.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket),r?.clustering?.enabled&&e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path)}a(yg,"validateConfig");function t4(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(t4,"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=Ag(E,t);l.setIn([...f],h)}else for(let E in r){let f=ks[E.toLowerCase()];if(f===Pn.HTTP_SECUREPORT&&r[E]===jt[Pn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),f===Pn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===jt[Pn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),f===Pn.DATABASES){u=r[E];continue}if(f?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!f&&(E.endsWith("_package")||E.endsWith("_port"))&&(f=E),f!==void 0){let h=f.split("_"),T=on.LEGACY_CONFIG_PARAMS[E.toUpperCase()];T&&T.startsWith("customFunctions")&&l.hasIn(T.split("_"))&&(f=T,h=T.split("_"));let m=Ag(f,r[E]);f==="rootPath"&&m?.endsWith("/")&&(m=m.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],m)}catch(g){hr.error(g)}}}u&&QC(l,u),yg(l);let d=l.getIn(["rootPath"]),_=Ln.join(d,on.HDB_CONFIG_FILE);n===!0&&r4(c,d),$r.writeFileSync(_,String(l)),s&&(jt=Dl(l.toJSON())),hr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(XC,"updateConfigValue");function r4(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(j2),hr.error(r)}}a(r4,"backupConfigFile");var n4=["databases"];function Dl(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network={...e.http,...e.operationsApi.network}),e?.operationsApi&&(e.operationsApi.tls={...e.tls,...e.operationsApi.tls}),uh=e,r(e);function r(n){let s={};for(let i in n)if(n.hasOwnProperty(i)){if(typeof n[i]=="object"&&n[i]!==null&&!Array.isArray(n[i])&&!n4.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!Pn[l.toUpperCase()]&&ks[l]&&(s[ks[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Dl,"flattenConfig");function Ag(e,t){if(e===Pn.CLUSTERING_NODENAME||e===Pn.CLUSTERING_USER){if(t==null)return t;if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if(G2(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Er.isObject(t)||t===null)return t;if(typeof t=="string"&&t.toLowerCase()==="true")return!0;if(typeof t=="string"&&t.toLowerCase()==="false")return!1}if(t===void 0||t.toLowerCase()==="undefined")return null;if(typeof t=="string"&&(t.startsWith("{")&&t.endsWith("}")||t.startsWith("[")&&t.endsWith("]")))try{return JSON.parse(t)}catch{}return Er.autoCast(t)}a(Ag,"castConfigValue");function s4(){let e=Er.getPropsFilePath(),t=Ja(e);return Vo(t).toJSON()}a(s4,"getConfiguration");async function i4(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return XC(void 0,void 0,s,!0),J2}catch(i){throw typeof i=="string"||i instanceof String?$2(i,i,V2.BAD_REQUEST,void 0,void 0,!0):i}}a(i4,"setConfiguration");function bg(){let e=Er.getPropsFilePath();try{$r.accessSync(e,$r.constants.F_OK|$r.constants.R_OK)}catch(n){if(!Er.noBootFile())throw hr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Ja(e);return Vo(t).toJSON()}a(bg,"readConfigFile");function Vo(e){return WC.parseDocument($r.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Vo,"parseYamlDoc");function o4(){let e=bg(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Er.isEmptyOrZeroLength(t)?[]:t;let r=KC(t);if(r)throw Cl.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Er.isEmptyOrZeroLength(n)?[]:n;let s=KC(n);if(s)throw Cl.CONFIG_VALIDATION(s.message);if(!Er.isEmptyOrZeroLength(n)&&!Er.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Er.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw Cl.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(o4,"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 a4(e){let t=bg();return q2.get(t,e.replaceAll("_","."))}a(a4,"getConfigFromFile");async function c4(e,t){let r=Vo(Ja());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await $r.writeFile(Ja(),String(r))}a(c4,"addConfig");function l4(e){let t=Ja(Er.getPropsFilePath()),r=Vo(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Ln.join(n,on.HDB_CONFIG_FILE);$r.writeFileSync(s,String(r))}a(l4,"deleteConfigFromFile");function u4(){return uh||(dh(),uh)}a(u4,"getConfigObj");function d4(){return jt||dh(),jt}a(d4,"getFlatConfigObj")});var se=N((iD,oD)=>{"use strict";var Og=require("fs-extra"),Xa=require("path"),tD=require("os"),_4=require("properties-reader"),Vd=W(),$d=te(),De=M(),_h=wt(),f4="Error initializing environment manager",fh="BOOT_PROPS_FILE_PATH",rD=!1,E4={[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:h4,setHdbBasePath:p4,get:nD,initSync:S4,setProperty:Qe,initTestEnvironment:g4,setCloneVar:T4});function h4(){return Qi[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(h4,"getHdbBasePath");function p4(e){Qi[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(p4,"setHdbBasePath");function nD(e){let t=_h.getConfigValue(e);return t===void 0?Qi[e]:t}a(nD,"get");function Qe(e,t){E4[e]&&(Qi[e]=t),_h.updateConfigObject(e,t)}a(Qe,"setProperty");function m4(){let e;try{e=$d.getPropsFilePath(),Og.accessSync(e,Og.constants.F_OK|Og.constants.R_OK),rD=!0;let t=_4(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(m4,"doesPropFileExist");function S4(e=!1){try{((rD||m4()||$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(f4),Vd.error(t),console.error(t),process.exit(1)}}a(S4,"initSync");var sD=!1;function T4(e){sD=e}a(T4,"setCloneVar");function g4(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:n,https_enabled:s,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,l=Xa.join(__dirname,"../../","unitTests");Qi[fh]=Xa.join(l,"hdb_boot_properties.file"),Qe(De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Xa.join(l,"settings.test")),Qe(De.HDB_SETTINGS_NAMES.INSTALL_USER,tD.userInfo()?tD.userInfo().username:void 0),Qe(De.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Qe(De.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Xa.join(l,"envDir","log")),Qe(De.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Qe(De.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Qe(De.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Qe(De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Xa.join(l,"envDir")),Qe(De.CONFIG_PARAMS.STORAGE_PATH,Xa.join(l,"envDir")),s&&(Qe(De.CONFIG_PARAMS.HTTP_SECUREPORT,nD(De.CONFIG_PARAMS.HTTP_PORT)),Qe(De.CONFIG_PARAMS.HTTP_PORT,null)),Qe(De.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Qe(De.CONFIG_PARAMS.HTTP_PORT,9926),Qe(De.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Qe(De.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),Qe(De.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,$d.isEmpty(i)?!1:i),Qe(De.CONFIG_PARAMS.HTTP_CORS,$d.isEmpty(i)?!1:i),Qe(De.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Qe(De.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Qe(De.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Qe(De.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Qe(De.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Xa.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Qe(De.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,$d.isEmpty(c)?!1:c),o&&(Qe("CORS_ACCESSLIST",o),Qe(De.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Qe(De.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Qe(De.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Qe(De.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Qe(De.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Qe(De.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Qe(De.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${fh}. Please check your boot props and settings files`;Vd.fatal(r),Vd.error(t)}}a(g4,"initTestEnvironment")});var gt=N((Kge,fD)=>{"use strict";var zd=M(),R4=te(),an=se(),Qd=require("path"),A4=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 y4(e,t){let r=an.get(Ko.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||Qd.join(dD(),e.toString())}a(y4,"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 b4(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,A4(process.argv));let n=r[Ko.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!R4.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(b4,"initSystemSchemaPaths");function O4(){Yd=void 0,Wd=void 0,jd=void 0}a(O4,"resetPaths");fD.exports={getBaseSchemaPath:lD,getSystemSchemaPath:uD,getTransactionAuditStorePath:y4,getTransactionAuditStoreBasePath:dD,getSchemaPath:_D,initSystemSchemaPaths:b4,resetPaths:O4}});var cn=N((zge,SD)=>{"use strict";var N4=Dn().LMDB_ERRORS_ENUM,Wge=require("lmdb"),I4=Bt(),jge=require("buffer").Buffer,{OVERFLOW_MARKER:ED,MAX_SEARCH_KEY_LENGTH:hh}=I4,hD=["number","string","symbol","boolean","bigint"];function w4(e){if(e=e?.primaryStore||e,!e)throw new Error(N4.ENV_REQUIRED)}a(w4,"validateEnv");function C4(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(C4,"stringifyData");function D4(e){return e instanceof Date?e.valueOf():e}a(D4,"convertKeyValueToWrite");function P4(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(P4,"getIndexedValues");var ph=0,pD=0;function mD(){pD=Date.now()-performance.now()}a(mD,"adjustStartTime");mD();var L4=6e4;setInterval(mD,L4).unref();function M4(){let e=performance.now()+pD;return e>ph?(ph=e,e):(ph+=488e-6,ph)}a(M4,"getNextMonotonicTime");SD.exports={validateEnv:w4,stringifyData:C4,convertKeyValueToWrite:D4,getNextMonotonicTime:M4,getIndexedValues:P4}});var Jd=N((Jge,TD)=>{"use strict";var U4=M().OPERATIONS_ENUM,Ng=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=U4.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};TD.exports=Ng});var Xd=N((eRe,yD)=>{"use strict";var Zge=Jd(),mh=M(),Ig=te(),gD=W(),v4=require("uuid"),{handleHDBError:Sh,hdb_errors:B4}=_e(),{HDB_ERROR_MSGS:Th,HTTP_STATUS_CODES:gh}=B4;yD.exports=RD;function RD(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];H4(i,r,e.operation)}}a(RD,"processRows");RD.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 H4(e,t,r){if(!e.hasOwnProperty(t)||Ig.isEmptyOrZeroLength(e[t])){if(r===mh.OPERATIONS_ENUM.INSERT||r===mh.OPERATIONS_ENUM.UPSERT){e[t]=v4.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(H4,"validateHash")});var bD,Mn,wg,Pl=Ne(()=>{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:()=>F4,start:()=>Dg,startOnMainThread:()=>k4});function Dg({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:u,StringValueNode:d}=await import("graphql"),_=o(new c(r.toString(),s)),E=new Map,f=[],h;for(let g of _.definitions)switch(g.kind){case l.OBJECT_TYPE_DEFINITION:let H=function(Y){if(Y.kind==="NonNullType"){let Q=H(Y.type);return Q.nullable=!1,Q}if(Y.kind==="ListType")return{type:"array",elements:H(Y.type)};let ne={type:Y.name?.value};return Object.defineProperty(ne,"location",{value:Y.loc.startToken}),ne};a(H,"getProperty");let S=g.name.value,b=[],I={table:null,database:null,properties:b};E.set(S,I);for(let Y of g.directives){if(Y.name.value==="table"){for(let ne of Y.arguments)I[ne.name.value]=ne.value.value;I.schema&&(I.database=I.schema),I.table||(I.table=S),I.audit&&(I.audit=I.audit!=="false"),I.attributes=I.properties,f.push(I)}if(Y.name.value==="sealed"&&(I.sealed=!0),Y.name.value==="splitSegments"&&(I.splitSegments=!0),Y.name.value==="replicate"&&(I.replicate=!0),Y.name.value==="export"){I.export=!0;for(let ne of Y.arguments)typeof I.export!="object"&&(I.export={}),I.export[ne.name.value]=ne.value.value}}let B=!1,X={};for(let Y of g.fields){let V=H(Y.type);V.name=Y.name.value,b.push(V),X[V.name]=void 0;for(let ne of Y.directives){let Q=ne.name.value;if(Q==="primaryKey")B?console.warn("Can not define two attributes as a primary key at",ne.loc):(V.isPrimaryKey=!0,B=!0);else if(Q==="indexed")V.indexed=!0;else if(Q==="computed"){for(let de of ne.arguments||[])if(de.name.value==="from"){let j=de.value.value;V.computed={from:m(j,de,X)},V.version==null&&(V.version=j)}else de.name.value==="version"&&(V.version=de.value.value);V.computed=V.computed||!0}else if(Q==="relationship"){let de={};for(let j of ne.arguments)de[j.name.value]=j.value.value;V.relationship=de}else if(Q==="createdTime")V.assignCreatedTime=!0;else if(Q==="updatedTime")V.assignUpdatedTime=!0;else if(Q==="expiresAt")V.expiresAt=!0;else if(Q==="allow"){let de=V.authorizedRoles=[];for(let j of ne.arguments)j.name.value==="role"&&de.push(j.value.value)}else server.knownGraphQLDirectives.includes(Q)&&console.warn(`@${Q} is an unknown directive, at`,ne.loc)}}I.type=S,S==="Query"&&(h=I)}function T(g){let S=E.get(g.type);S?(Object.defineProperty(g,"properties",{value:S.properties}),Object.defineProperty(g,"definition",{value:S})):g.type==="array"?T(g.elements):x4.includes(g.type)||(0,ND.getWorkerIndex)()===0&&console.error(`The type ${g.type} is unknown at line ${g.location.line}, column ${g.location.column}, in ${s}`)}a(T,"connectPropertyType");for(let g of E.values())for(let S of g.properties)T(S);for(let g of f)g.tableClass=e(g),g.export&&(g.export.name===""?i.set((0,Cg.dirname)(n),g.tableClass):i.set((0,Cg.dirname)(n)+"/"+(g.export.name||g.type),g.tableClass,g.export));function m(g,S,b){return new OD.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${g}; } } } } computed;`,{filename:s,lineOffset:S.loc.startToken.line-1,columnOffset:S.loc.startToken.column}).runInThisContext()(b)}a(m,"createComputedFrom")}}var Cg,OD,ND,x4,k4,F4,ID=Ne(()=>{Cg=require("path"),OD=require("node:vm");Pe();ND=L(dt()),x4=["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");k4=Dg,F4=Dg({ensureTable:Et}).handleFile});var UD={};je(UD,{parse:()=>Mg,streamAsJSON:()=>Zd,stringify:()=>Za});function Zd(e){return new Lg({value:e})}function wD(e){return console.error(e),JSON.stringify(e.toString())}function CD(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Za(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===LD)return MD(e);if(t.resolution)return t.resolution.then(()=>Za(e));throw t}}function MD(e){let t=typeof e;if(t==="object"){if(e===null)return"null";e.toJSON&&(e=e.toJSON());let r;if(Array.isArray(e)){r="[";for(let n=0;n<e.length;n++)n>0&&(r+=","),r+=MD(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Za(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function Mg(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),$4.test(e)?G4.parse(e):JSON.parse(e)):null}var DD,PD,G4,q4,LD,Lg,$4,Ug=Ne(()=>{DD=require("stream"),PD=L(require("json-bigint-fixes")),G4=(0,PD.default)({useNativeBigInt:!0}),q4=1e4,LD={message:"Cannot serialize BigInt to JSON"};BigInt.prototype.toJSON=function(){throw LD};a(Zd,"streamAsJSON");Lg=class extends DD.Readable{static{a(this,"JSONStream")}constructor(t){super(t),this.buffer=[],this.bufferSize=0,this.iterator=this.serialize(t.value,!0),this.activeIterators=[]}*serialize(t){if(t&&typeof t=="object"){let r=t[Symbol.asyncIterator],n=t[Symbol.iterator];if((n||r)&&!t.then){yield"[";let s=!0;if((r||n)&&!(t instanceof Array)){let i=r?t[Symbol.asyncIterator]():t[Symbol.iterator]();this.activeIterators.push(i);let o;for(;;){try{o=i.next(),o.then&&(yield o.then(c=>(o=c,""),c=>(o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")},"")))}catch(c){o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")}}if(o.done){this.activeIterators.splice(this.activeIterators.indexOf(i),1),yield"]";return}else s?s=!1:yield",",yield*this.serialize(o.value)}}for(let i of t)s?s=!1:yield",",yield*this.serialize(i);yield"]";return}if(t.then)try{yield t.then(s=>this.serialize(s),wD)}catch(s){yield wD(s)}else yield Za(t)}else yield Za(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);CD(this.readIterator(this.iterator),t=>{t?(this.done=!0,this.push(null)):this._amReading=!1},t=>{console.error(t),this.done=!0,this.push(t.toString()),this.push(null)})}}push(t){return t===null||t instanceof Buffer?(this.bufferSize>0&&this.flush(),super.push(t)):(this.bufferSize+=t.length||t.toString().length,this.buffer.push(t),this.bufferSize>q4?this.flush():!0)}flush(){let t=super.push(this.buffer.join(""));return this.buffer=[],this.bufferSize=0,t}readIterator(t){try{let r;if(t.childIterator)return CD(this.readIterator(t.childIterator),n=>{if(n)return t.childIterator=null,this.readIterator(t)});do{let n=t.next();if(n.done)return!0;if(r=n.value,r==null)r="null";else{if(r.then)return this.flush(),Promise.resolve(r).then(s=>{if(s&&typeof s.return=="function")return t.childIterator=s,this.readIterator(t);if(this.push(s+""))return this.readIterator(t)});if(typeof r.return=="function")return t.childIterator=r,this.readIterator(t)}}while(this.push(r))}catch(r){return console.error(r),this.push(r.toString()),this.push(null),!0}}_destroy(t,r){for(let n of this.activeIterators)t?n.throw(t):n.return();r()}};a(wD,"handleError");a(CD,"when");a(Za,"stringify");a(MD,"jsStringify");$4=/[[,:]\s*-?\d{16,}/;a(Mg,"parse")});var WD=N((cRe,YD)=>{"use strict";var vg=require("recursive-iterator"),V4=require("alasql"),Bg=require("clone"),vD=te(),{handleHDBError:BD,hdb_errors:K4}=_e(),{HDB_ERROR_MSGS:HD,HTTP_STATUS_CODES:xD}=K4,{getDatabases:Y4}=(Pe(),oe(lt)),W4=["DISTINCT_ARRAY"],kD=Symbol("validateTables"),Hg=Symbol("validateTable"),aRe=Symbol("getAllColumns"),FD=Symbol("validateAllColumns"),Rh=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=Y4();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)})}[Rh](t){return this.attributes.filter(r=>t.tableid?(r.table.as===t.tableid||r.table.tableid===t.tableid)&&r.attribute===t.columnid:r.attribute===t.columnid)}[$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 V4.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&&W4.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=Bg(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[Rh](n)[0];s&&r.push(s)}}}),this.statement.group.forEach(n=>{let s=null;if(!n.columnid)r.forEach((i,o)=>{if(i.toString()===n.toString()){s=i,r.splice(o,1);return}});else{let i=this[Rh](n);if(!i||i.length===0)throw`unknown column '${n.toString()}' in group by`;if(i.length>1)throw`ambiguously defined column '${n.toString()}' in group by`;r.forEach((o,c)=>{if(o.attribute===i[0].attribute&&o.table.tableid===i[0].table.tableid){s=o,r.splice(c,1);return}})}if(!s)throw`group by column '${n.toString()}' must be in select`}),r.length>0)throw`select column '${r[0].attribute?r[0].attribute:r[0].toString()}' must be in group by`}[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[Rh](t),n=(t.tableid?t.tableid+".":"")+t.columnid;if(r.length===0)throw`unknown column ${n}`;if(r.length>1)throw`ambiguous column reference ${n}`;return r[0]}};YD.exports=kg});var zD=N((uRe,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((_Re,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:()=>j4,METADATA:()=>t_,NO_TIMESTAMP:()=>$g,PENDING_LOCAL_TIME:()=>Qg,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>jg,RecordEncoder:()=>Wg,TIMESTAMP_ASSIGN_LAST:()=>Q4,TIMESTAMP_ASSIGN_NEW:()=>ZD,TIMESTAMP_ASSIGN_PREVIOUS:()=>eP,TIMESTAMP_PLACEHOLDER:()=>Ah,TIMESTAMP_RECORD_PREVIOUS:()=>Vg,getUpdateRecord:()=>Jg,handleLocalTimeForGets:()=>Nh});function X4(){return n_[0]=n_[0]^64,z4.getFloat64(0)}function Nh(e){let t=e.getEntry;e.readCount=0,e.cachePuts=!1,e.getEntry=function(i,o){e.readCount++;let c=t.call(this,i,o),l=c?.value,u=l?.[t_];return u>=0&&(c.metadataFlags=u,c.localTime=l.localTime,c.value=l.value,c.residencyId=l.residencyId,l.expiresAt>=0&&(c.expiresAt=l.expiresAt)),c&&(c.key=i),c};let r=e.get;e.get=function(i,o){let c=r.call(this,i,o);return c?.[t_]>=0?c.value:c};let n=e.getRange;e.getRange=function(i){let o=n.call(this,i);return i.valuesForKey?o.map(c=>c?.value):i.values===!1||i.onlyCount?o:o.map(c=>{let l=c.value,u=l[t_];return u>=0&&(c.metadataFlags=u,c.localTime=l.localTime,c.value=l.value,c.residencyId=l.residencyId,l.expiresAt>=0&&(c.expiresAt=l.expiresAt)),c})};let s=e.useReadTransaction();if(s.done(),!s.done.isTracked){let i=s.constructor,o=s.use,c=s.done;i.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,ec.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let l=0;l<ec.length;l++){let u=ec[l].deref();(!u||u.isDone||u.isCommitted)&&ec.splice(l--,1)}},i.prototype.done.isTracked=!0}return e}function Jg(e,t,r){return function(n,s,i,o,c=-1,l,u,d="put",_,E){_||l==null?Ll=i?.localTime?Vg|eP:$g:Ll=l?i?.localTime?Vg|16384:ZD|16384:$g;let f=u?.expiresAt;if(f>=0&&(c|=bh),r_=c,Kg=f,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:Ll>0},T,m=0;try{let g=i?.residencyId,S=u?.residencyId;S&&(Yg=S,r_|=zg,m|=tc),g!==S&&(m|=rc,g||(g=0)),c&bh&&(m|=o_),u?.originatingOperation&&(m|=i_),_&&(h.ifVersion=T=i?.version??null);let b=e.put(n,s,h);if(l){let I=u?.user?.username;if(E&&(yh=e.encoder.encode(E)),e.encoder.hasStructureUpdate&&(m|=Oh,e.encoder.hasStructureUpdate=!1),_&&i?.localTime){let B=i?.localTime,H=r.get(B);if(H){let X=Ht(H).previousLocalTime;return r.put(B,Ml(o,t,n,X,u?.nodeId??server.replication.getThisNodeId(r)??0,I,d,yh,m,S,g,f),{ifVersion:T}),b}}r.put(s_,Ml(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,I,d,yh,m,S,g,f,u?.originatingOperation),{append:d!=="invalidate",instructedWrite:!0,ifVersion:T})}return b}catch(g){throw g.message+=" id: "+n+" options: "+h,g}}}var XD,qg,Ah,s_,jg,j4,t_,n_,z4,$g,ZD,Q4,eP,Vg,bh,zg,Qg,Oh,J4,yh,Ll,r_,Kg,Yg,Wg,ec,Ul=Ne(()=>{XD=require("msgpackr");Ji();qg=L(W()),Ah=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]),j4=Symbol("local-timestamp"),t_=Symbol("metadata"),n_=new Uint8Array(8),z4=new DataView(n_.buffer,0,8),$g=0,ZD=0,Q4=1,eP=3,Vg=4,bh=16,zg=32,Qg=1,Oh=256,Ll=0,r_=-1,Kg=-1,Yg=0,Wg=class extends XD.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(Ll||r_>=0){let o=0,c=Ll;c&&(o+=8,Ll=0);let l=r_,u=Kg,d=Yg;l>=0&&(o+=2,r_=-1,u>=0&&(o+=8,Kg=-1),d&&(o+=4,Yg=0));let _=J4=r.call(this,s,i|2048|o);yh=_.subarray((_.start||0)+o,_.end);let E=_.start||0;return c&&(Ah[4]=c,Ah[5]=c>>8,_.set(Ah,E),E+=8),l>=0&&(_[E++]=l&31,_[E++]=l>>5,u>=0&&((_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(E,u),E+=8),d&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setUint32(E,d)),_}else return r.call(this,s,i)};let n=this.saveStructures;this.saveStructures=function(s,i){let o=n.call(this,s,i);return this.hasStructureUpdate=!0,o}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(n_,0,c),c+=8;else for(let E=0;E<8;E++)n_[E]=t[c++];l=X4(),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(X4,"getTimestamp");a(Nh,"handleLocalTimeForGets");ec=[];setInterval(()=>{for(let e=0;e<ec.length;e++){let t=ec[e].deref();!t||t.isDone||t.isCommitted?ec.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(qg.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):qg.error("Read transaction detected that has been open too long (over one minute), make sure read transactions are quickly closed",t)),t.openTimer++):t.openTimer=1)}},15e3).unref();a(Jg,"getUpdateRecord")});var a_=N((mRe,nP)=>{"use strict";var rP=se(),Z4=M(),{RecordEncoder:eJ}=(Ul(),oe(tP)),pRe=require("fs");rP.initSync();var tJ=rP.get(Z4.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=tJ&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:eJ})}};nP.exports=Xg});var c_=N((TRe,sP)=>{"use strict";var Un=se(),as=M();Un.initSync();var Ih=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Un.get(as.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Un.get(as.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Un.get(as.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Un.get(as.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Un.get(as.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Un.get(as.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Un.get(as.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Un.get(as.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};sP.exports=Ih;Ih.MAX_DBS=1e4});var ht=N((RRe,EP)=>{"use strict";var eR=require("lmdb"),Fs=require("fs-extra"),vn=require("path"),wh=cn(),aP=W(),ln=Dn().LMDB_ERRORS_ENUM,Ch=JD(),tR=a_(),cP=c_(),Yo=Bt(),iP=M(),{table:rJ,resetDatabases:nJ}=(Pe(),oe(lt)),oP=se(),Gs=Yo.INTERNAL_DBIS_NAME,lP=Yo.DBI_DEFINITION_NAME,sJ="data.mdb",iJ="lock.mdb",l_=".mdb",oJ="-lock",Zg=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=cs(t,r),this.key_type=this.dbi[Yo.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[Yo.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new eR.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function Dh(e,t){if(e===void 0)throw new Error(ln.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(ln.ENV_NAME_REQUIRED)}a(Dh,"pathEnvNameValidation");async function rR(e,t,r=!0){try{await Fs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(ln.INVALID_BASE_PATH):n}try{let n=vn.join(e,t+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,sJ),Fs.constants.R_OK|Fs.constants.F_OK),vn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(ln.INVALID_ENVIRONMENT)}else throw new Error(ln.INVALID_ENVIRONMENT);throw n}}a(rR,"validateEnvironmentPath");function Ph(e,t){if(wh.validateEnv(e),t===void 0)throw new Error(ln.DBI_NAME_REQUIRED)}a(Ph,"validateEnvDBIName");async function aJ(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 rR(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=eR.open(l);u.dbis=Object.create(null);let d=new tR(!1);u.openDB(Gs,d),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let _=nR(e,t,r);return u[Yo.ENVIRONMENT_NAME_KEY]=_,global.lmdb_map[_]=u,u}throw o}}a(aJ,"createEnvironment");async function cJ(e,t,r,n=!0){Dh(e,t),t=t.toString();let s=vn.join(e,t);return rJ({table:t,database:vn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(cJ,"copyEnvironment");async function uP(e,t,r=!1){Dh(e,t),t=t.toString();let n=nR(e,t,r);if(global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null)),global.lmdb_map[n]!==void 0)return global.lmdb_map[n];let s=await rR(e,t),i=vn.join(e,t+l_),o=s!=i,c=new cP(s,o),l=eR.open(c);l.dbis=Object.create(null);let u=_P(l);for(let d=0;d<u.length;d++)cs(l,u[d]);return l[Yo.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(uP,"openEnvironment");async function lJ(e,t,r=!1){Dh(e,t),t=t.toString();let n=vn.join(e,t+l_),s=await rR(e,t);if(global.lmdb_map!==void 0){let i=nR(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await dP(o),delete global.lmdb_map[i]}}await Fs.remove(s),await Fs.remove(s===n?s+oJ:vn.join(vn.dirname(s),iJ))}a(lJ,"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 nR(e,t,r=!1){let s=`${vn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(nR,"getCachedEnvironmentName");function uJ(e){wh.validateEnv(e);let t=Object.create(null),r=cs(e,Gs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Gs)try{t[n]=Object.assign(new Ch,s)}catch{aP.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(uJ,"listDBIDefinitions");function _P(e){wh.validateEnv(e);let t=[],r=cs(e,Gs);for(let{key:n}of r.getRange({start:!1}))n!==Gs&&t.push(n);return t}a(_P,"listDBIs");function dJ(e,t){let n=cs(e,Gs).getEntry(t),s=new Ch;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{aP.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(dJ,"getDBIDefinition");function fP(e,t,r,n=!r){if(Ph(e,t),t=t.toString(),t===Gs)throw new Error(ln.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return cs(e,t)}catch(s){if(s.message===ln.DBI_DOES_NOT_EXIST){let i=new tR(r,n===!0),o=e.openDB(t,i),c=new Ch(r===!0,n);return o[lP]=c,cs(e,Gs).putSync(t,c),e.dbis[t]=o,o}throw s}}a(fP,"createDBI");function cs(e,t){if(Ph(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Gs?r=dJ(e,t):r=new Ch,r===void 0)throw new Error(ln.DBI_DOES_NOT_EXIST);let n;try{let s=new tR(r.dup_sort,r.useVersions);if(n=e.openDB(t,s),n.db===void 0)throw new Error("MDB_NOTFOUND")}catch(s){throw s.message.includes("MDB_NOTFOUND")===!0?new Error(ln.DBI_DOES_NOT_EXIST):s}return n[lP]=r,e.dbis[t]=n,n}a(cs,"openDBI");function _J(e,t){Ph(e,t),t=t.toString();let r=cs(e,t),n=r.getStats();return r[Yo.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(_J,"statDBI");async function fJ(e,t){try{let r=vn.join(e,t+l_);return(await Fs.stat(r)).size}catch{throw new Error(ln.INVALID_ENVIRONMENT)}}a(fJ,"environmentDataSize");function EJ(e,t){if(Ph(e,t),t=t.toString(),t===Gs)throw new Error(ln.CANNOT_DROP_INTERNAL_DBIS_NAME);cs(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],cs(e,Gs).removeSync(t)}a(EJ,"dropDBI");function hJ(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{cs(e,i)}catch(o){if(o.message===ln.DBI_DOES_NOT_EXIST)fP(e,i,i!==t,i===t),n=!0;else throw o}}n&&nJ()}a(hJ,"initializeDBIs");EP.exports={openDBI:cs,openEnvironment:uP,createEnvironment:aJ,listDBIs:_P,listDBIDefinitions:uJ,createDBI:fP,dropDBI:EJ,statDBI:_J,deleteEnvironment:lJ,initializeDBIs:hJ,TransactionCursor:Zg,environmentDataSize:fJ,copyEnvironment:cJ,closeEnvironment:dP}});var pP=N((yRe,hP)=>{"use strict";var sR=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};hP.exports=sR});var SP=N((ORe,mP)=>{"use strict";var iR=class{static{a(this,"UpdateRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n,this.original_records=s}};mP.exports=iR});var gP=N((IRe,TP)=>{"use strict";var oR=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};TP.exports=oR});var sc=N((LRe,yP)=>{"use strict";var pJ=ht(),mJ=pP(),SJ=SP(),TJ=gP(),mi=cn(),u_=Dn().LMDB_ERRORS_ENUM,gJ=Bt(),Xi=M(),RJ=te(),AJ=require("uuid"),CRe=require("lmdb"),{handleHDBError:yJ,hdb_errors:bJ}=_e(),{OVERFLOW_MARKER:DRe,MAX_SEARCH_KEY_LENGTH:PRe}=gJ,RP=se();RP.initSync();var Lh=RP.get(Xi.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),aR=Xi.TIME_STAMP_NAMES_ENUM.CREATED_TIME,nc=Xi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function OJ(e,t,r,n,s=mi.getNextMonotonicTime()){dR(e,t,r,n),cR(e,t,r);let i=new mJ,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];AP(u,!0,s);let d=NJ(e,t,r,u),_=u[t];o.push(d),c.push(_)}return lR(o,c,n,i,s)}a(OJ,"insertRecords");function NJ(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let d=c([[{}]]);Array.isArray(d)&&(c=d[0][Xi.FUNC_VAL],n[o]=c)}let l=mi.getIndexedValues(c),u=e.dbis[o];if(l){Lh&&u.prefetch(l.map(d=>({key:d,value:s})),Mh);for(let d=0,_=l.length;d<_;d++)u.put(l[d],s)}}Lh&&e.dbis[t].prefetch([s],Mh),e.dbis[t].put(s,n,n[nc])})}a(NJ,"insertRecord");function IJ(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(IJ,"removeSkippedRecords");function AP(e,t,r){let n=r>0;(n||!Number.isInteger(e[nc]))&&(e[nc]=r||(r=mi.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[aR]))&&(e[aR]=r||mi.getNextMonotonicTime()):delete e[aR]}a(AP,"setTimestamps");function cR(e,t,r){r.indexOf(Xi.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Xi.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Xi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Xi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),pJ.initializeDBIs(e,t,r)}a(cR,"initializeTransaction");async function wJ(e,t,r,n,s=mi.getNextMonotonicTime()){dR(e,t,r,n),cR(e,t,r);let i=new SJ,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let d=n[u],_=d[t],E;try{E=uR(e,t,d,_,i,!0,s)}catch{i.skipped_hashes.push(_),o.push(u);continue}c.push(E),l.push(_)}return lR(c,l,n,i,s,o)}a(wJ,"updateRecords");async function CJ(e,t,r,n,s=mi.getNextMonotonicTime()){try{dR(e,t,r,n)}catch(l){throw yJ(l,l.message,bJ.HTTP_STATUS_CODES.BAD_REQUEST)}cR(e,t,r);let i=new TJ,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],d;RJ.isEmpty(u[t])?(d=AJ.v4(),u[t]=d):d=u[t];let _=uR(e,t,u,d,i,!1,s);o.push(_),c.push(d)}return lR(o,c,n,i,s)}a(CJ,"upsertRecords");async function lR(e,t,r,n,s,i=[]){let o=await Promise.all(e);for(let c=0,l=o.length;c<l;c++)o[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||mi.getNextMonotonicTime(),IJ(r,i),n}a(lR,"finalizeWrite");function uR(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),u=l?.value,d=u;if(!u){if(i)return!1;u={}}if(AP(r,!d,o),Number.isInteger(r[nc])&&u[nc]>r[nc])return!1;d&&s.original_records.push(u);let _,E=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let T=r[h],m=e.dbis[h];if(m===void 0)continue;let g=u[h];if(typeof T=="function"){let b=T([[u]]);Array.isArray(b)&&(T=b[0][Xi.FUNC_VAL],r[h]=T)}if(T===g)continue;let S=mi.getIndexedValues(g);if(S){Lh&&m.prefetch(S.map(b=>({key:b,value:n})),Mh);for(let b=0,I=S.length;b<I;b++)m.remove(S[b],n)}if(S=mi.getIndexedValues(T),S){Lh&&m.prefetch(S.map(b=>({key:b,value:n})),Mh);for(let b=0,I=S.length;b<I;b++)m.put(S[b],n)}}let f={...u,...r};c.put(n,f,f[nc])},"do_put");return l?_=c.ifVersion(n,l.version,E):_=c.ifNoExists(n,E),_.then(f=>f?!0:uR(e,t,r,n,s,i,o))}a(uR,"updateUpsertRecord");function DJ(e,t,r){if(mi.validateEnv(e),t===void 0)throw new Error(u_.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(u_.WRITE_ATTRIBUTES_REQUIRED):new Error(u_.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(DJ,"validateBasic");function dR(e,t,r,n){if(DJ(e,t,r),!Array.isArray(n))throw n===void 0?new Error(u_.RECORDS_REQUIRED):new Error(u_.RECORDS_MUST_BE_ARRAY)}a(dR,"validateWrite");function Mh(){}a(Mh,"noop");yP.exports={insertRecords:OJ,updateRecords:wJ,upsertRecords:CJ}});var Zi=N((URe,PJ)=>{PJ.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"}]},hdb_certificate:{hash_attribute:"name",name:"hdb_certificate",schema:"system",attributes:[{attribute:"name"},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var Ti=N((vRe,NP)=>{"use strict";var OP=te(),bP=M(),vl=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Si=require("joi"),Wo={schema_format:{pattern:vl,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},LJ=Si.alternatives(Si.string().min(1).max(Wo.schema_length.maximum).pattern(vl).messages({"string.pattern.base":"{:#label} "+Wo.schema_format.message}),Si.number(),Si.array()).required(),MJ=Si.alternatives(Si.string().min(1).max(Wo.schema_length.maximum).pattern(vl).messages({"string.pattern.base":"{:#label} "+Wo.schema_format.message}),Si.number()),UJ=Si.alternatives(Si.string().min(1).max(Wo.schema_length.maximum).pattern(vl).messages({"string.pattern.base":"{:#label} "+Wo.schema_format.message}),Si.number()).required();function vJ(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>Wo.schema_length.maximum?`'${e}' maximum of 250 characters`:vl.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(vJ,"checkValidTable");function BJ(e,t){return OP.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(BJ,"validateSchemaExists");function HJ(e,t){let r=t.state.ancestors[0].schema;return OP.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(HJ,"validateTableExists");function xJ(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(xJ,"validateSchemaName");NP.exports={common_validators:Wo,schema_regex:vl,hdb_schema_table:LJ,validateSchemaExists:BJ,validateTableExists:HJ,validateSchemaName:xJ,checkValidTable:vJ,hdb_database:MJ,hdb_table:UJ}});var Uh=N((HRe,IP)=>{var{common_validators:gi}=Ti(),__=Tt(),d_="is required",rr={database:{presence:!1,format:gi.schema_format,length:gi.schema_length},schema:{presence:!1,format:gi.schema_format,length:gi.schema_length},table:{presence:!0,format:gi.schema_format,length:gi.schema_length},attribute:{presence:!0,format:gi.schema_format,length:gi.schema_length},hash_attribute:{presence:!0,format:gi.schema_format,length:gi.schema_length}};function f_(e){for(let t in e)e[t]=e[t]===null||e[t]===void 0||typeof e[t]=="object"?e[t]:e[t].toString();return e}a(f_,"makeAttributesStrings");function kJ(e){return e=f_(e),rr.table.presence=!1,rr.attribute.presence=!1,rr.hash_attribute.presence=!1,__.validateObject(e,rr)}a(kJ,"schema_object");function FJ(e){return e=f_(e),rr.table.presence={message:d_},rr.attribute.presence=!1,rr.hash_attribute.presence=!1,__.validateObject(e,rr)}a(FJ,"table_object");function GJ(e){return e=f_(e),rr.table.presence={message:d_},rr.attribute.presence=!1,__.validateObject(e,rr)}a(GJ,"create_table_object");function qJ(e){return e=f_(e),rr.table.presence={message:d_},rr.attribute.presence={message:d_},rr.hash_attribute.presence=!1,__.validateObject(e,rr)}a(qJ,"attribute_object");function $J(e){return e=f_(e),rr.table.presence={message:d_},rr.attribute.presence=!1,rr.hash_attribute.presence=!1,__.validateObject(e,rr)}a($J,"describe_table");function VJ(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(VJ,"validateTableResidence");IP.exports={schema_object:kJ,create_table_object:GJ,table_object:FJ,attribute_object:qJ,describe_table:$J,validateTableResidence:VJ}});var CP=N((kRe,wP)=>{"use strict";var KJ=require("uuid"),_R=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||KJ.v4(),this.schema_table=`${this.schema}.${this.table}`}};wP.exports=_R});var vh=N((GRe,DP)=>{"use strict";var YJ=CP(),fR=class extends YJ{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=fR});var LP=N(($Re,PP)=>{"use strict";PP.exports=jJ;var WJ="inserted";function jJ(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===WJ?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(jJ,"returnObject")});var Bh=N((YRe,BP)=>{"use strict";var zJ=M(),ER=ht(),QJ=sc(),{getSystemSchemaPath:JJ,getSchemaPath:XJ}=gt(),KRe=Zi(),ZJ=Uh(),e3=vh(),t3=LP(),{handleHDBError:MP,hdb_errors:vP}=_e(),UP=te(),{HTTP_STATUS_CODES:r3}=vP,n3="inserted";BP.exports=s3;async function s3(e){let t=ZJ.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,r3.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 e3(e.schema,e.table,e.attribute,e.id);try{let i=await ER.openEnvironment(XJ(e.schema,e.table),e.table);if(i.dbis[e.attribute]!==void 0)throw new Error(`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`);ER.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await ER.openEnvironment(JJ(),zJ.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await QJ.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return t3(n3,c,{records:[s]},l)}catch(i){throw i}}a(s3,"lmdbCreateAttribute")});var pR=N((jRe,xP)=>{var{hdb_table:i3,hdb_database:HP}=Ti(),o3=Tt(),hR=require("joi"),a3={undefined:"undefined",null:"null"},c3=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||a3[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"),l3=hR.object({database:HP,schema:HP,table:i3,records:hR.array().items(hR.object().custom(c3)).required()});xP.exports=function(e){return o3.validateBySchema(e,l3)}});var E_=N((JRe,FP)=>{"use strict";var eo=te(),kP=W(),QRe=pR(),{getDatabases:u3}=(Pe(),oe(lt)),{ClientError:ic}=_e();FP.exports=d3;function d3(e){if(eo.isEmpty(e))throw new ic("invalid update parameters defined.");if(eo.isEmptyOrZeroLength(e.schema))throw new ic("invalid schema specified.");if(eo.isEmptyOrZeroLength(e.table))throw new ic("invalid table specified.");if(!Array.isArray(e.records))throw new ic("records must be an array");let t=u3()[e.schema]?.[e.table];if(eo.isEmpty(t))throw new ic(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&eo.isEmptyOrZeroLength(o[r]))throw kP.error("a valid hash attribute must be provided with update record:",o),new ic("a valid hash attribute must be provided with update record, check log for more info");if(!eo.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw kP.error(`a valid hash value must be provided with ${e.operation} record:`,o),new ic(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!eo.isEmpty(o[r])&&o[r]!==""&&n.has(eo.autoCast(o[r]))&&(o.skip=!0),n.add(eo.autoCast(o[r]));for(let c in o)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}a(d3,"insertUpdateValidate")});var qP=N((ZRe,GP)=>{"use strict";var mR=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};GP.exports=mR});var KP=N((tAe,VP)=>{"use strict";var SR=ht(),_3=W(),$P=Dn().LMDB_ERRORS_ENUM;VP.exports=f3;async function f3(e){try{if(global.lmdb_map!==void 0&&e.operation!==void 0){let t=Object.keys(global.lmdb_map),r;switch(e.operation){case"drop_schema":for(let i=0;i<t.length;i++){let o=t[i];if(o.startsWith(`${e.schema}.`)||o.startsWith(`txn.${e.schema}.`))try{await SR.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==$P.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await SR.closeEnvironment(global.lmdb_map[n]),await SR.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==$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){_3.error(t)}}a(f3,"cleanLMDBMap")});var to=N((nAe,zP)=>{"use strict";var h_=require("crypto"),E3=se(),{CONFIG_PARAMS:h3}=M(),WP="aes-256-cbc",p3=32,m3=16,TR=64,jP=32,S3=TR+jP,YP=new Map;zP.exports={encrypt:T3,decrypt:g3,createNatsTableStreamName:R3};function T3(e){let t=h_.randomBytes(p3),r=h_.randomBytes(m3),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(T3,"encrypt");function g3(e){let t=e.substr(0,TR),r=e.substr(TR,jP),n=e.substr(S3,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(g3,"decrypt");function R3(e,t){let r=E3.get(h3.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(R3,"createNatsTableStreamName")});var ro=N((oAe,XP)=>{"use strict";var iAe=Vr(),p_=W(),QP=Uh(),A3=to(),Hh=te(),{handleHDBError:xh,hdb_errors:y3}=_e(),{HDB_ERROR_MSGS:kh,HTTP_STATUS_CODES:gR}=y3,JP=se();JP.initSync();var{getDatabases:RR}=(Pe(),oe(lt)),b3=require("fs-extra"),O3=M();XP.exports={describeAll:N3,describeTable:Fh,describeSchema:I3};async function N3(e={}){try{let t=Hh.isEmptyOrZeroLength(e),r=!!e.bypass_auth,n,s;!t&&!r&&(n=e.hdb_user?.role?.permission,s=n?.super_user||n?.cluster_user);let i=RR(),o={},c={},l=[],u=e?.exact_count;for(let _ in i){o[_]=!0,!t&&!s&&!r&&(c[_]=e.hdb_user?.role?.permission[_]?.describe);let E=i[_];for(let f in E)try{let h;if(t||s||r)h=await Fh({schema:_,table:f,exact_count:u});else if(n&&n[_].describe&&n[_].tables[f].describe){let T=n[_].tables[f].attribute_permissions;h=await Fh({schema:_,table:f,exact_count:u},T)}h&&l.push(h)}catch(h){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(N3,"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=RR()[r];if(!c)throw xh(new Error,kh.SCHEMA_NOT_FOUND(e.schema),gR.NOT_FOUND);let l=c[n];if(!l)throw xh(new Error,kh.TABLE_NOT_FOUND(e.schema,e.table),gR.NOT_FOUND);function u(f){d.push({attribute:f.attribute,type:f.type,elements:f.elements?.type,indexed:f.indexed,is_primary_key:f.isPrimaryKey,assigned_created_time:f.assignCreatedTime,assigned_updated_time:f.assignUpdatedTime,nullable:f.nullable,properties:f.properties?f.properties.map(h=>({type:h.type,name:h.name})):void 0})}a(u,"pushAtt");let d=[];if(s){let f={};s.forEach(h=>{h.describe&&(f[h.attribute_name]=!0)}),l.attributes.forEach(h=>{f[h.name]&&u(h)})}else l.attributes?.forEach(f=>u(f));let _;try{_=(await b3.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(O3.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(E.clustering_stream_name=A3.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 I3(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=RR()[n];if(!i)throw xh(new Error,kh.SCHEMA_NOT_FOUND(e.schema),gR.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),Hh.isEmpty(l)||l.describe){let u=await Fh({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(I3,"describeSchema")});var ls=N((uAe,nL)=>{var w3=Zi(),{callbackify:eL,promisify:C3}=require("util"),{getDatabases:tL}=(Pe(),oe(lt));nL.exports={setSchemaDataToGlobal:ZP,getTableSchema:D3,getSystemSchema:P3,setSchemaDataToGlobalAsync:C3(ZP)};var rL=ro(),cAe=eL(rL.describeAll),lAe=eL(rL.describeTable);function ZP(e){global.hdb_schema=tL(),e&&e()}a(ZP,"setSchemaDataToGlobal");function D3(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(D3,"getTableSchema");function P3(){return w3}a(P3,"getSystemSchema")});var un=N((_Ae,aL)=>{"use strict";var qh=pR(),Cr=te(),L3=require("util"),$h=Bn(),M3=ls(),sL=W(),{handleHDBError:oc,hdb_errors:U3}=_e(),{HTTP_STATUS_CODES:ac}=U3,v3=L3.promisify(M3.getTableSchema),B3="updated",iL="inserted",oL="upserted";aL.exports={insert:x3,update:k3,upsert:F3,validation:H3,flush:G3};async function H3(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 v3(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(H3,"validation");async function x3(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=qh(e);if(t)throw oc(new Error,t.message,ac.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw oc(new Error,r,ac.BAD_REQUEST);let n=await $h.createRecords(e);return Gh(iL,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(x3,"insertData");async function k3(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=qh(e);if(t)throw oc(new Error,t.message,ac.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw oc(new Error,r,ac.BAD_REQUEST);let n=await $h.updateRecords(e);return Cr.isEmpty(n.existing_rows)?Gh(B3,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(k3,"updateData");async function F3(e){if(e.operation!=="upsert")throw oc(new Error,"invalid operation, must be upsert",ac.INTERNAL_SERVER_ERROR);let t=qh(e);if(t)throw oc(new Error,t.message,ac.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw oc(new Error,r,ac.BAD_REQUEST);let n=await $h.upsertRecords(e);return Gh(oL,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(F3,"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 G3(e){return Cr.transformReq(e),$h.flush(e.schema,e.table)}a(G3,"flush")});var yR=N((EAe,uL)=>{var q3=Tt(),AR=require("joi"),{hdb_table:$3,hdb_database:cL}=Ti(),lL={schema:cL,database:cL,table:$3},V3={date:AR.date().iso().required()},K3={timestamp:AR.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};uL.exports=function(e,t){let r=t==="timestamp"?{...lL,...K3}:{...lL,...V3},n=AR.object(r);return q3.validateBySchema(e,n)}});var fL=N((hAe,_L)=>{var Y3=Tt(),bR=require("joi"),{hdb_table:W3,hdb_database:dL}=Ti(),j3=bR.object({schema:dL,database:dL,table:W3,hash_values:bR.array().required(),ids:bR.array()});_L.exports=function(e){return Y3.validateBySchema(e,j3)}});var wR=N((pAe,EL)=>{"use strict";var OR=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i){this.operation=t,this.schema=r,this.table=n,this.hash_attribute=s,this.records=i}},NR=class{static{a(this,"NoSQLSeachObject")}constructor(t,r,n,s,i,o){this.schema=t,this.table=r,this.search_attribute=n,this.hash_attribute=s,this.get_attributes=i,this.search_value=o}},IR=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};EL.exports={InsertObject:OR,NoSQLSeachObject:NR,DeleteResponseObject:IR}});var uc=N((SAe,TL)=>{"use strict";var pL=yR(),z3=fL(),cc=te(),hL=require("moment"),mL=W(),{promisify:Q3,callbackify:J3}=require("util"),lc=M(),X3=ls(),CR=Q3(X3.getTableSchema),DR=Bn(),{DeleteResponseObject:Z3}=wR(),{handleHDBError:jo,hdb_errors:eX}=_e(),{HDB_ERROR_MSGS:Vh,HTTP_STATUS_CODES:zo}=eX,tX="records successfully deleted",rX=J3(SL);TL.exports={delete:rX,deleteRecord:SL,deleteFilesBefore:nX,deleteAuditLogsBefore:sX};async function nX(e){let t=pL(e,"date");if(t)throw jo(t,t.message,zo.BAD_REQUEST,void 0,void 0,!0);if(cc.transformReq(e),!hL(e.date,hL.ISO_8601).isValid())throw jo(new Error,Vh.INVALID_DATE,zo.BAD_REQUEST,lc.LOG_LEVELS.ERROR,Vh.INVALID_DATE,!0);let n=cc.checkSchemaTableExist(e.schema,e.table);if(n)throw jo(new Error,n,zo.NOT_FOUND,lc.LOG_LEVELS.ERROR,n,!0);let s=await DR.deleteRecordsBefore(e);if(await CR(e.schema,e.table),mL.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(nX,"deleteFilesBefore");async function sX(e){let t=pL(e,"timestamp");if(t)throw jo(t,t.message,zo.BAD_REQUEST,void 0,void 0,!0);if(cc.transformReq(e),isNaN(e.timestamp))throw jo(new Error,Vh.INVALID_VALUE("Timestamp"),zo.BAD_REQUEST,lc.LOG_LEVELS.ERROR,Vh.INVALID_VALUE("Timestamp"),!0);let r=cc.checkSchemaTableExist(e.schema,e.table);if(r)throw jo(new Error,r,zo.NOT_FOUND,lc.LOG_LEVELS.ERROR,r,!0);let n=await DR.deleteAuditLogsBefore(e);return await CR(e.schema,e.table),mL.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(sX,"deleteAuditLogsBefore");async function SL(e){e.ids&&(e.hash_values=e.ids);let t=z3(e);if(t)throw jo(t,t.message,zo.BAD_REQUEST,void 0,void 0,!0);cc.transformReq(e);let r=cc.checkSchemaTableExist(e.schema,e.table);if(r)throw jo(new Error,r,zo.NOT_FOUND,lc.LOG_LEVELS.ERROR,r,!0);try{await CR(e.schema,e.table);let n=await DR.deleteRecords(e);return cc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${tX}`),n}catch(n){if(n.message===lc.SEARCH_NOT_FOUND_MESSAGE){let s=new Z3;return s.message=lc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(SL,"deleteRecord")});var Kh=N((gAe,AL)=>{var iX=require("crypto"),gL=9;function oX(e){let t=cX(gL),r=RL(e+t);return t+r}a(oX,"createHash");function aX(e,t){let r=e?.substr(0,gL),n=r+RL(t+r);return e===n}a(aX,"validateHash");function cX(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(cX,"generateSalt");function RL(e){return iX.createHash("md5").update(e).digest("hex")}a(RL,"md5");AL.exports={hash:oX,validate:aX}});var bL=N((AAe,yL)=>{var PR=Tt(),Kr={username:{presence:!0,exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function lX(e){return Kr.password.presence=!0,Kr.username.presence=!0,Kr.role.presence=!0,Kr.active.presence=!0,PR.validateObject(e,Kr)}a(lX,"addUserValidation");function uX(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,PR.validateObject(e,Kr)}a(uX,"alterUserValidation");function dX(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,PR.validateObject(e,Kr)}a(dX,"dropUserValidation");yL.exports={addUserValidation:lX,alterUserValidation:uX,dropUserValidation:dX}});var Ct=N((OAe,NL)=>{"use strict";var{platform:bAe}=require("os"),_X="nats-server.zip",LR="nats-server",fX=process.platform==="win32"?`${LR}.exe`:LR,EX=/^[^\s.,*>]+$/,OL="__request__",hX=a(e=>`${e}.${OL}`,"REQUEST_SUBJECT"),pX={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},mX={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},SX={HUB:"hub.pid",LEAF:"leaf.pid"},TX={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},gX={SUCCESS:"success",ERROR:"error"},RX={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},AX={TXN:"txn",MSGID:"msgid"},Bl={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},yX={[Bl.ERR]:1,[Bl.WRN]:2,[Bl.INF]:3,[Bl.DBG]:4,[Bl.TRC]:5},bX={debug:"-D",trace:"-DVV"};NL.exports={NATS_SERVER_ZIP:_X,NATS_SERVER_NAME:LR,NATS_BINARY_NAME:fX,PID_FILES:SX,NATS_CONFIG_FILES:mX,SERVER_SUFFIX:TX,NATS_TERM_CONSTRAINTS_RX:EX,REQUEST_SUFFIX:OL,UPDATE_REMOTE_RESPONSE_STATUSES:gX,CLUSTER_STATUS_STATUSES:RX,REQUEST_SUBJECT:hX,SUBJECT_PREFIXES:AX,MSG_HEADERS:pX,LOG_LEVELS:Bl,LOG_LEVEL_FLAGS:bX,LOG_LEVEL_HIERARCHY:yX}});var wL=N((IAe,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}},MR=class extends Wh{static{a(this,"ExtendedLicense")}constructor(t=0,r=Yh.RAM_ALLOCATION_ENUM.DEFAULT,n=Yh.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};IL.exports={BaseLicense:Wh,ExtendedLicense:MR}});var dc=N((CAe,vL)=>{"use strict";var xl=require("fs-extra"),DL=Kh(),PL=require("crypto"),OX=require("moment"),NX=require("uuid").v4,Yr=W(),vR=require("path"),IX=te(),Qo=M(),{totalmem:CL}=require("os"),wX=wL().ExtendedLicense,Hl="invalid license key format",CX="061183",DX="mofi25",PX="aes-256-cbc",LX=16,MX=32,LL=se(),{resolvePath:ML}=wt();LL.initSync();var UR;vL.exports={validateLicense:UL,generateFingerPrint:vX,licenseSearch:xR,getLicense:xX,checkMemoryLimit:kX};function BR(){return vR.join(LL.getHdbBasePath(),Qo.LICENSE_KEY_DIR_NAME,Qo.LICENSE_FILE_NAME)}a(BR,"getLicenseDirPath");function UX(){let e=BR();return ML(vR.join(e,Qo.LICENSE_FILE_NAME))}a(UX,"getLicenseFilePath");function HR(){let e=BR();return ML(vR.join(e,Qo.REG_KEY_FILE_NAME))}a(HR,"getFingerPrintFilePath");async function vX(){let e=HR();try{return await xl.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await BX();throw Yr.error(`Error writing fingerprint file to ${e}`),Yr.error(t),new Error("There was an error generating the fingerprint")}}a(vX,"generateFingerPrint");async function BX(){let e=NX(),t=DL.hash(e),r=HR();try{await xl.mkdirp(BR()),await xl.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw Yr.error(`Error writing fingerprint file to ${r}`),Yr.error(n),new Error("There was an error generating the fingerprint")}return t}a(BX,"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=HR(),s=!1;try{s=xl.statSync(n)}catch(i){Yr.error(i)}if(s){let i;try{i=xl.readFileSync(n,"utf8")}catch{Yr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(DX),c=o[1];c=Buffer.concat([Buffer.from(c)],LX);let l=Buffer.concat([Buffer.from(i)],MX),u=PL.createDecipheriv(PX,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=HX(o[0],i);if(f)d=f;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Hl),Yr.error(Hl),new Error(Hl)}let _;if(isNaN(d))try{_=JSON.parse(d),r.version=_.version,r.exp_date=_.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),_.ram_allocation&&(r.ram_allocation=_.ram_allocation)}catch{throw console.error(Hl),Yr.error(Hl),new Error(Hl)}else r.exp_date=d;r.exp_date<OX().valueOf()&&(r.valid_date=!1),DL.validate(o[1],`${CX}${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 HX(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(HX,"checkOldLicense");function xR(){let e=new wX,t=[];try{t=xl.readFileSync(UX(),"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(IX.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 UR=e,e}a(xR,"licenseSearch");async function xX(){return UR||await xR(),UR}a(xX,"getLicense");function kX(){let e=xR().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(kX,"checkMemoryLimit")});var xn=N((UAe,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:jX,alterUser:zX,dropUser:JX,getSuperUser:tZ,userInfo:XX,listUsers:zh,listUsersExternal:ZX,setUsersToGlobal:Fl,findAndValidateUser:zL,getClusterUser:rZ,USERNAME_REQUIRED:kL,ALTERUSER_NOTHING_TO_UPDATE:FL,EMPTY_PASSWORD:GL,EMPTY_ROLE:qL,ACTIVE_BOOLEAN:$L};var VL=un(),FX=uc(),GR=Kh(),KL=bL(),YL=Vr(),qR=no(),Hn=te(),WL=require("validate.js"),Ke=W(),{promisify:GX}=require("util"),$R=to(),BL=M(),HL=Ct(),qX=wt(),PAe=se(),LAe=dc(),$X=Zi(),{table:MAe}=(Pe(),oe(lt)),{handleHDBError:Ri,hdb_errors:VX}=_e(),{HTTP_STATUS_CODES:Ai,AUTHENTICATION_ERROR_MSGS:kR,HDB_ERROR_MSGS:kl}=VX,{UserEventMsg:VR}=qs(),FR=require("lodash"),{server:KR}=(qr(),oe(Qa)),KX=W();KR.getUser=(e,t)=>zL(e,t,t!=null);var jL={username:!0,active:!0,role:!0,password:!0},xL=new Map,jh=YL.searchByValue,YX=YL.searchByHash,WX=GX(FX.delete);async function jX(e){let t=WL.cleanAttributes(e,jL),r=KL.addUserValidation(t);if(r)throw Ri(new Error,r.message,Ai.BAD_REQUEST,void 0,void 0,!0);let n={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]},s;try{s=await jh(n),s=s&&Array.from(s)}catch(l){throw Ke.error("There was an error searching for a role in add user"),Ke.error(l),l}if(!s||s.length<1)throw Ri(new Error,kl.ROLE_NAME_NOT_FOUND(t.role),Ai.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw Ri(new Error,kl.DUP_ROLES_FOUND(t.role),Ai.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=$R.encrypt(t.password)),t.password=GR.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await VL.insert(i)}catch(l){throw Ke.error("There was an error searching for a user."),Ke.error(l),l}Ke.debug(o);try{await Fl()}catch(l){throw Ke.error("Got an error setting users to global"),Ke.error(l),l}if(o.skipped_hashes.length===1)throw Ri(new Error,kl.USER_ALREADY_EXISTS(t.username),Ai.CONFLICT,void 0,void 0,!0);let c={...t};return c.role=s[0],qR.signalUserChange(new VR(process.pid)),`${c.username} successfully added`}a(jX,"addUser");async function zX(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=QX(t.username);if(!Hn.isEmpty(t.password)&&!Hn.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=$R.encrypt(t.password)),t.password=GR.hash(t.password)),t.role==="")throw new Error(qL);if(t.role){let i={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]},o;try{o=Array.from(await jh(i)||[])}catch(c){throw Ke.error("Got an error searching for a role."),Ke.error(c),c}if(!o||o.length===0){let c=kl.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Ke.error(c),Ri(new Error,c,Ai.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=kl.ALTER_USER_DUP_ROLES(t.role);throw Ke.error(c),Ri(new Error,c,Ai.CONFLICT,void 0,void 0,!0)}t.role=o[0].id}let n={operation:"update",schema:"system",table:"hdb_user",records:[t]},s;try{s=await VL.update(n)}catch(i){throw Ke.error("Error during update."),Ke.error(i),i}try{await Fl()}catch(i){throw Ke.error("Got an error setting users to global"),Ke.error(i),i}return qR.signalUserChange(new VR(process.pid)),s}a(zX,"alterUser");function QX(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(QX,"isClusterUser");async function JX(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,kl.USER_NOT_EXIST(e.username),Ai.NOT_FOUND,void 0,void 0,!0);let n;try{n=await WX(r)}catch(s){throw Ke.error("Got an error deleting a user."),Ke.error(s),s}Ke.debug(n);try{await Fl()}catch(s){throw Ke.error("Got an error setting users to global."),Ke.error(s),s}return qR.signalUserChange(new VR(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(JX,"dropUser");async function XX(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=FR.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await YX(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(XX,"userInfo");async function ZX(){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(ZX,"listUsersExternal");async function zh(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await jh(e)}catch(o){throw Ke.error("Got an error searching for roles."),Ke.error(o),o}let r={};for(let o of t)r[o.id]=FR.cloneDeep(o);if(Object.keys(r).length===0)return null;let n={schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]},s;try{s=await jh(n)}catch(o){throw Ke.error("Got an error searching for users."),Ke.error(o),o}let i=new Map;for(let o of s)o=FR.cloneDeep(o),o.role=r[o.role],eZ(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 eZ(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($X)){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(eZ,"appendSystemTablesToRole");async function Fl(){try{let e=await zh();global.hdb_users=e}catch(e){throw Ke.error(e),e}}a(Fl,"setUsersToGlobal");async function zL(e,t,r=!0){global.hdb_users||await Fl();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw Ri(new Error,kR.GENERIC_AUTH_FAIL,Ai.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw Ri(new Error,kR.USER_INACTIVE,Ai.UNAUTHORIZED,void 0,void 0,!0);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(xL.get(t)===n.password)return s;if(GR.validate(n.password,t))xL.set(t,n.password);else throw Ri(new Error,kR.GENERIC_AUTH_FAIL,Ai.UNAUTHORIZED,void 0,void 0,!0)}return s}a(zL,"findAndValidateUser");async function tZ(){global.hdb_users||await Fl();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(tZ,"getSuperUser");async function rZ(){let e=await zh(),t=qX.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=$R.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+HL.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+HL.SERVER_SUFFIX.ADMIN,r}a(rZ,"getClusterUser");var QL=[];KR.invalidateUser=function(e){for(let t of QL)try{t(e)}catch(r){KX.error("Error invalidating user",r)}};KR.onInvalidatedUser=function(e){QL.push(e)}});var S_=N((xAe,tM)=>{"use strict";var _c=W(),kn=M(),nZ=KP(),BAe=ls(),HAe=ro(),sZ=xn(),{validateEvent:XL}=qs(),m_=Bn(),iZ=require("process"),{resetDatabases:oZ}=(Pe(),oe(lt)),aZ={[kn.ITC_EVENT_TYPES.SCHEMA]:cZ,[kn.ITC_EVENT_TYPES.USER]:eM};async function cZ(e){let t=XL(e);if(t){_c.error(t);return}_c.trace("ITC schemaHandler received schema event:",e),await nZ(e.message),await lZ(e.message)}a(cZ,"schemaHandler");async function lZ(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=oZ();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){_c.error(t)}}a(lZ,"syncSchemaMetadata");var ZL=[];async function eM(e){try{try{m_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),m_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){_c.warn(r)}let t=XL(e);if(t){_c.error(t);return}_c.trace(`ITC userHandler ${kn.HDB_ITC_CLIENT_PREFIX}${iZ.pid} received user event:`,e),await sZ.setUsersToGlobal();for(let r of ZL)r()}catch(t){_c.error(t)}}a(eM,"userHandler");eM.addListener=function(e){ZL.push(e)};tM.exports=aZ});var qs=N((VAe,nM)=>{"use strict";var FAe=W(),YR=te(),uZ=M(),{ITC_ERRORS:T_}=Dn(),{parentPort:GAe,threadId:dZ,isMainThread:_Z,workerData:qAe}=require("worker_threads"),{onMessageFromWorkers:fZ,broadcast:$Ae,broadcastWithAcknowledgement:EZ}=dt();nM.exports={sendItcEvent:hZ,validateEvent:rM,SchemaEventMsg:pZ,UserEventMsg:mZ};var Qh;fZ(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 hZ(e){return!_Z&&e.message&&(e.message.originator=dZ),EZ(e)}a(hZ,"sendItcEvent");function rM(e){if(typeof e!="object")return T_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||YR.isEmpty(e.type))return T_.MISSING_TYPE;if(!e.hasOwnProperty("message")||YR.isEmpty(e.message))return T_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||YR.isEmpty(e.message.originator))return T_.MISSING_ORIGIN;if(uZ.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return T_.INVALID_EVENT(e.type)}a(rM,"validateEvent");function pZ(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(pZ,"SchemaEventMsg");function mZ(e){this.originator=e}a(mZ,"UserEventMsg")});var no=N((WAe,aM)=>{"use strict";var sM=M(),YAe=te(),Jh=W(),iM=qP(),Gl,{sendItcEvent:oM}=qs();function SZ(e){try{Jh.info("signalSchemaChange called with message:",e),Gl=Gl||S_();let t=new iM(sM.ITC_EVENT_TYPES.SCHEMA,e);return Gl.schema(t),oM(t)}catch(t){Jh.error(t)}}a(SZ,"signalSchemaChange");function TZ(e){try{Jh.trace("signalUserChange called with message:",e),Gl=Gl||S_();let t=new iM(sM.ITC_EVENT_TYPES.USER,e);return Gl.user(t),oM(t)}catch(t){Jh.error(t)}}a(TZ,"signalUserChange");aM.exports={signalSchemaChange:SZ,signalUserChange:TZ}});var Xh=N((zAe,lM)=>{"use strict";var cM=te(),gZ=M(),RZ=W(),AZ=Bh(),yZ=vh(),bZ=no(),{SchemaEventMsg:OZ}=qs(),NZ="already exists in";lM.exports=IZ;async function IZ(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 wZ(e,t.schema,t.name,i)})),s}a(IZ,"lmdbCheckForNewAttributes");async function wZ(e,t,r,n){let s=new yZ(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await CZ(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(NZ))RZ.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(wZ,"createNewAttribute");async function CZ(e){let t;return t=await AZ(e),bZ.signalSchemaChange(new OZ(process.pid,gZ.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(CZ,"createAttribute")});var ql=N((JAe,uM)=>{"use strict";var WR=class{static{a(this,"LMDBTransactionObject")}constructor(t,r,n,s,i=void 0){this.operation=t,this.user_name=r,this.timestamp=n,this.hash_values=s,this.origin=i}};uM.exports=WR});var _M=N((ZAe,dM)=>{"use strict";var DZ=ql(),PZ=M().OPERATIONS_ENUM,jR=class extends DZ{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(PZ.INSERT,r,n,s,i),this.records=t}};dM.exports=jR});var EM=N((tye,fM)=>{"use strict";var LZ=ql(),MZ=M().OPERATIONS_ENUM,zR=class extends LZ{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(MZ.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};fM.exports=zR});var pM=N((nye,hM)=>{"use strict";var UZ=ql(),vZ=M().OPERATIONS_ENUM,QR=class extends UZ{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(vZ.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};hM.exports=QR});var SM=N((iye,mM)=>{"use strict";var BZ=ql(),HZ=M().OPERATIONS_ENUM,JR=class extends BZ{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(HZ.DELETE,n,s,t,i),this.original_records=r}};mM.exports=JR});var g_=N((cye,AM)=>{"use strict";var aye=require("path"),TM=ht(),xZ=_M(),kZ=EM(),FZ=pM(),GZ=SM(),$l=Bt(),gM=te(),{CONFIG_PARAMS:qZ}=M(),RM=se();RM.initSync();var Zh=M().OPERATIONS_ENUM,{getTransactionAuditStorePath:$Z}=gt();AM.exports=VZ;async function VZ(e,t){if(RM.get(qZ.LOGGING_AUDITLOG)===!1)return;let r=$Z(e.schema,e.table),n=await TM.openEnvironment(r,e.table,!0),s=KZ(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){TM.initializeDBIs(n,$l.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,$l.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[$l.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[$l.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),gM.isEmpty(s.user_name)||n.dbis[$l.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[$l.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(VZ,"writeTransaction");function KZ(e,t){let r=gM.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===Zh.INSERT)return new xZ(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zh.UPDATE)return new kZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zh.UPSERT)return new FZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zh.DELETE)return new GZ(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(KZ,"createTransactionObject")});var XR=N((dye,yM)=>{"use strict";var YZ=E_(),uye=Jd(),R_=M(),WZ=Xd(),jZ=sc().insertRecords,zZ=ht(),QZ=W(),JZ=Xh(),{getSchemaPath:XZ}=gt(),ZZ=g_();yM.exports=e5;async function e5(e){try{let{schema_table:t,attributes:r}=YZ(e);WZ(e,r,t.hash_attribute),e.schema!==R_.SYSTEM_SCHEMA_NAME&&(r.includes(R_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(R_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(R_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(R_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await JZ(e.hdb_auth_header,t,r),s=XZ(e.schema,e.table),i=await zZ.openEnvironment(s,e.table),o=await jZ(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await ZZ(e,o)}catch(c){QZ.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(e5,"lmdbCreateRecords")});var NM=N((fye,OM)=>{"use strict";var bM=M(),t5=XR(),r5=Jd(),n5=require("fs-extra"),{getSchemaPath:s5}=gt();OM.exports=i5;async function i5(e){let t=[{name:e.schema,createddate:Date.now()}],r=new r5(bM.SYSTEM_SCHEMA_NAME,bM.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await t5(r),await n5.mkdirp(s5(e.schema))}a(i5,"lmdbCreateSchema")});var wM=N((hye,IM)=>{"use strict";var ZR=class{static{a(this,"DeleteRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.deleted=t,this.skipped=r,this.txn_time=n,this.original_records=s}};IM.exports=ZR});var LM=N((gye,PM)=>{"use strict";var CM=ht(),eA=cn(),tA=Dn().LMDB_ERRORS_ENUM,o5=Bt(),DM=W(),mye=te(),a5=require("lmdb"),c5=wM(),l5=M(),{OVERFLOW_MARKER:Sye,MAX_SEARCH_KEY_LENGTH:Tye}=o5,u5=l5.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function d5(e,t,r,n){if(eA.validateEnv(e),t===void 0)throw new Error(tA.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(tA.IDS_REQUIRED):new Error(tA.IDS_MUST_BE_ITERABLE);try{let s=CM.listDBIs(e);CM.initializeDBIs(e,t,s);let i=new c5,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[u5]>n){i.skipped.push(o);continue}let T=e.dbis[t].ifVersion(o,a5.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let m=0;m<s.length;m++){let g=s[m];if(!h.hasOwnProperty(g)||g===t)continue;let S=e.dbis[g],b=h[g];if(b!=null)try{let I=eA.getIndexedValues(b);if(I)for(let B=0,H=I.length;B<H;B++)S.remove(I[B],o)}catch{DM.warn(`cannot delete from attribute: ${g}, ${b}:${o}`)}}});c.push(T),l.push(o),i.original_records.push(h)}catch(h){DM.warn(h),i.skipped.push(o)}let u=[],d=await Promise.all(c);for(let E=0,f=d.length;E<f;E++)d[E]===!0?i.deleted.push(l[E]):(i.skipped.push(l[E]),u.push(E));let _=0;for(let E=0;E<u.length;E++){let f=u[E];i.original_records.splice(f-_,1),_++}return i.txn_time=eA.getNextMonotonicTime(),i}catch(s){throw s}}a(d5,"deleteRecords");PM.exports={deleteRecords:d5}});var A_=N((Aye,UM)=>{"use strict";var Vl=te(),_5=LM(),f5=ht(),{getSchemaPath:E5}=gt(),h5=g_(),p5=W();UM.exports=m5;async function m5(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Vl.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Vl.isEmptyOrZeroLength(e.hash_values)&&!Vl.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Vl.isEmpty(l)||e.hash_values.push(l)}}if(Vl.isEmptyOrZeroLength(e.hash_values))return MM([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Vl.isEmptyOrZeroLength(e.records)){e.records=[];for(let c=0;c<e.hash_values.length;c++)e.records[c]={[n]:e.hash_values[c]}}let s=E5(e.schema,e.table),i=await f5.openEnvironment(s,e.table),o=await _5.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await h5(e,o)}catch(c){p5.error(`unable to write transaction due to ${c.message}`)}return MM(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(m5,"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 nA=N((Oye,vM)=>{"use strict";var S5=M(),bye=cn();function rA(e,t){let r=Object.create(null);if(t.length===1&&S5.SEARCH_WILDCARDS.indexOf(t[0])>=0)Object.assign(r,e);else for(let n=0;n<t.length;n++){let s=t[n],i=e[s];r[s]=i===void 0?null:i}return r}a(rA,"parseRow");function T5(e,t,r,n){let s=rA(r,e);n.push(s)}a(T5,"searchAll");function g5(e,t,r,n){let s=rA(r,e);n[t]=s}a(g5,"searchAllToMap");function R5(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(R5,"iterateDBI");function fc(e,t,r,n,s){let i=Object.create(null);i[s]=e;let o;n===s?o=e:(o=t,n!==void 0&&(i[n]=o)),r[0].push(o),r[1].push(i)}a(fc,"pushResults");function A5(e,t,r,n,s,i){t.toString().endsWith(e)&&fc(t,r,n,s,i)}a(A5,"endsWith");function y5(e,t,r,n,s,i){t.toString().includes(e)&&fc(t,r,n,s,i)}a(y5,"contains");function b5(e,t,r,n,s,i){t>e&&fc(t,r,n,s,i)}a(b5,"greaterThanCompare");function O5(e,t,r,n,s,i){t>=e&&fc(t,r,n,s,i)}a(O5,"greaterThanEqualCompare");function N5(e,t,r,n,s,i){t<e&&fc(t,r,n,s,i)}a(N5,"lessThanCompare");function I5(e,t,r,n,s,i){t<=e&&fc(t,r,n,s,i)}a(I5,"lessThanEqualCompare");vM.exports={parseRow:rA,searchAll:T5,searchAllToMap:g5,iterateDBI:R5,endsWith:A5,contains:y5,greaterThanCompare:b5,greaterThanEqualCompare:O5,lessThanCompare:N5,lessThanEqualCompare:I5,pushResults:fc}});var Kl=N((Dye,qM)=>{"use strict";var Jo=ht(),Iye=W(),Fn=cn(),ep=Bt(),zt=Dn().LMDB_ERRORS_ENUM,wye=te(),w5=M(),tp=nA(),{parseRow:C5}=tp,Cye=require("lmdb"),{OVERFLOW_MARKER:BM,MAX_SEARCH_KEY_LENGTH:D5}=ep;function HM(e,t,r,n=!1,s=void 0,i=void 0){return Ec(e,t,r,(o,c)=>c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}))}a(HM,"iterateFullIndex");function y_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return Ec(e,t,r,(d,_,E,f)=>{let S={transaction:d,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return f===r?(S.values=!1,_.getRange(S).map(b=>({value:b}))):_.getRange(S)})}a(y_,"iterateRangeBetween");function Ec(e,t,r,n){let s=e.database||e,i=Jo.openDBI(s,r);i[ep.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&Jo.openDBI(s,t);let o;e.database?o=e:(o=e.useReadTransaction(),o.database=e);let c=n(o,i,s,t);return c.transaction=o,e.database||(c.onDone=()=>{o.done()}),c}a(Ec,"setupTransaction");function xM(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(BM)){if(!s)if(r)s=Jo.openDBI(e,r);else{let l=Jo.listDBIs(e);for(let u=0,d=l.length;u<d&&(s=Jo.openDBI(e,l[u]),!s[ep.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(xM,"getOverflowCheck");function P5(e,t,r,n=!1,s=void 0,i=void 0){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return Ec(e,t,t,(o,c,l)=>(rp(r),r=b_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>C5(u.value,r))))}a(P5,"searchAll");function L5(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(L5,"searchAllToMap");function M5(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(M5,"iterateDBI");function U5(e,t){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return Jo.statDBI(e,t).entryCount}a(U5,"countAll");function v5(e,t,r,n,s=!1,i=void 0,o=void 0){return Xo(e,r,n),Ec(e,t,r,(c,l,u,d)=>(n=Fn.convertKeyValueToWrite(n),d===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(_=>({key:n,value:_}))))}a(v5,"equals");function B5(e,t,r){return Xo(e,t,r),Jo.openDBI(e,t).getValuesCount(r)}a(B5,"count");function H5(e,t,r,n,s=!1,i=void 0,o=void 0){return Xo(e,r,n),Ec(e,null,r,(c,l)=>{n=Fn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let d;if(s===!0){let _;for(let E of l.getKeys({transaction:c,start:n}))if(!E.startsWith(n)){_=E;break}return _!==void 0&&(Number.isInteger(o)?o++:i++),d=l.getRange({transaction:c,start:_,end:void 0,reverse:s,limit:i,offset:o}).map(E=>{let{key:f}=E;if(f!==_){if(f.toString().startsWith(n))return E;if(u===!0)return d.DONE}}),d.filter(E=>E)}else return d=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(_=>{if(_.key.toString().startsWith(n))return _;if(u===!0)return d.DONE}),u?d:d.filter(_=>_)})}a(H5,"startsWith");function x5(e,t,r,n,s=!1,i=void 0,o=void 0){return kM(e,t,r,n,s,i,o,!0)}a(x5,"endsWith");function kM(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Xo(e,r,n),Ec(e,null,r,(l,u,d,_)=>{let E=xM(d,l,_,r);return o=Number.isInteger(o)?o:0,u.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(f=>{let h=f.toString();return h.endsWith(BM)?u.getValues(f,{transaction:l}).map(T=>{let m=E(f,T);if(c?m.endsWith(n):m.includes(n))return{key:m,value:T}}).filter(T=>T):(c?h.endsWith(n):h.includes(n))?u[ep.DBI_DEFINITION_NAME].is_hash_attribute?{key:f,value:f}:u.getValues(f,{transaction:l}).map(T=>({key:f,value:T})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(kM,"contains");function k5(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(k5,"greaterThan");function F5(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(F5,"greaterThanEqual");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="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),y_(e,t,r,l,n,s,i,o,!1,!0)}a(G5,"lessThan");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="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),y_(e,t,r,l,n,s,i,o,!1,!1)}a(q5,"lessThanEqual");function $5(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($5,"between");function V5(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(V5,"searchByHash");function K5(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(K5,"checkHashExists");function Y5(e,t,r,n,s=[]){return GM(e,t,r,n,s),FM(e,t,r,n,s).map(i=>i[1])}a(Y5,"batchSearchByHash");function W5(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(W5,"batchSearchByHashToMap");function FM(e,t,r,n,s=[]){return Ec(e,t,t,(i,o,c)=>{r=b_(c,r);let l=r.length<3;return n.map(u=>{let d=c.dbis[t].get(u,{transaction:i,lazy:l});if(d)return[u,tp.parseRow(d,r)];s.push(u)}).filter(u=>u)})}a(FM,"batchHashSearch");function GM(e,t,r,n,s){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(rp(r),n==null)throw new Error(zt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(zt.IDS_MUST_BE_ITERABLE)}a(GM,"initializeBatchSearchByHash");function rp(e){if(!Array.isArray(e))throw e===void 0?new Error(zt.FETCH_ATTRIBUTES_REQUIRED):new Error(zt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(rp,"validateFetchAttributes");function Xo(e,t,r){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.SEARCH_VALUE_REQUIRED);if(r?.length>D5)throw new Error(zt.SEARCH_VALUE_TOO_LARGE)}a(Xo,"validateComparisonFunctions");function b_(e,t){return t.length===1&&w5.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=Jo.listDBIs(e)),t}a(b_,"setGetWholeRowAttributes");qM.exports={searchAll:P5,searchAllToMap:L5,count:B5,countAll:U5,equals:v5,startsWith:H5,endsWith:x5,contains:kM,searchByHash:V5,setGetWholeRowAttributes:b_,batchSearchByHash:Y5,batchSearchByHashToMap:W5,checkHashExists:K5,iterateDBI:M5,greaterThan:k5,greaterThanEqual:F5,lessThan:G5,lessThanEqual:q5,between:$5}});var Yl=N((Lye,WM)=>{var $M=require("lodash"),VM=Tt(),He=require("joi"),j5=te(),{hdb_schema_table:O_,checkValidTable:KM,hdb_table:YM,hdb_database:np}=Ti(),{handleHDBError:z5,hdb_errors:Q5}=_e(),{getDatabases:J5}=(Pe(),oe(lt)),{HTTP_STATUS_CODES:X5}=Q5,Z5=He.object({database:np,schema:np,table:YM,search_attribute:O_,search_value:He.any().required(),get_attributes:He.array().min(1).items(He.alternatives(O_,He.object())).optional(),desc:He.bool(),limit:He.number().integer().min(1),offset:He.number().integer().min(0)}),e6=He.object({database:np,schema:np,table:YM,operator:He.string().valid("and","or").default("and").lowercase(),offset:He.number().integer().min(0),limit:He.number().integer().min(1),get_attributes:He.array().min(1).items(He.alternatives(O_,He.object())).optional(),sort:He.object({attribute:He.alternatives(O_,He.array().min(1)),descending:He.bool().optional()}).optional(),conditions:He.array().min(1).items(He.alternatives(He.object({operator:He.string().valid("and","or").default("and").lowercase(),conditions:He.array()}),He.object({search_attribute:He.alternatives(O_,He.array().min(1)),search_type:He.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:He.when("search_type",{switch:[{is:"equals",then:He.any()},{is:"between",then:He.array().items(He.alternatives([He.string(),He.number()])).length(2)}],otherwise:He.alternatives(He.string(),He.number())}).required()}))).required()});WM.exports=function(e,t){let r=null;switch(t){case"value":r=VM.validateBySchema(e,Z5);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,e6);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=j5.checkGlobalSchemaTable(e.schema,e.table);if(s)return z5(new Error,s,X5.NOT_FOUND);let o=J5()[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 sA=N((Uye,jM)=>{"use strict";var t6=ht(),r6=Yl(),{getSchemaPath:n6}=gt();jM.exports=s6;function s6(e){let t=r6(e,"hashes");if(t)throw t;let r=n6(e.schema,e.table);return t6.openEnvironment(r,e.table)}a(s6,"initialize")});var iA=N((Bye,zM)=>{"use strict";var i6=Kl(),o6=sA();zM.exports=a6;async function a6(e){let t=await o6(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return i6.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(a6,"lmdbGetDataByHash")});var Wl=N((xye,QM)=>{"use strict";var oA=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};QM.exports=oA});var XM=N((Gye,JM)=>{"use strict";var Fye=Wl(),c6=Kl(),l6=sA();JM.exports=u6;async function u6(e){let t=await l6(e),r=global.hdb_schema[e.schema][e.table];return c6.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(u6,"lmdbSearchByHash")});var $s=N(($ye,ZM)=>{"use strict";var aA=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,u=void 0,d=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=u,this.offset=d}};ZM.exports=aA});var sp=N((Kye,iU)=>{"use strict";var Wr=Kl(),d6=ht(),_6=te(),xe=Bt(),hc=M(),f6=Zi(),eU=Dn().LMDB_ERRORS_ENUM,{getSchemaPath:E6}=gt(),so=hc.SEARCH_WILDCARDS;async function h6(e,t,r){let n;e.schema===hc.SYSTEM_SCHEMA_NAME?n=f6[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(h6,"prepSearch");async function rU(e,t,r,n){let s=E6(e.schema,e.table),i=await d6.openEnvironment(s,e.table),o=nU(i,e,t,r),c=o.transaction||i;if([xe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,xe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,xe.SEARCH_TYPES.SEARCH_ALL,xe.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(p6(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 xe.SEARCH_TYPES.EQUALS:s=Wr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case xe.SEARCH_TYPES.CONTAINS:s=Wr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case xe.SEARCH_TYPES.ENDS_WITH:case xe.SEARCH_TYPES._ENDS_WITH:s=Wr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case xe.SEARCH_TYPES.STARTS_WITH:case xe.SEARCH_TYPES._STARTS_WITH:s=Wr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case xe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Wr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case xe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Wr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case xe.SEARCH_TYPES.SEARCH_ALL:return Wr.searchAll(e,n,t.get_attributes,o,c,l);case xe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Wr.searchAllToMap(e,n,t.get_attributes,o,c,l);case xe.SEARCH_TYPES.BETWEEN:s=Wr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case xe.SEARCH_TYPES.GREATER_THAN:case xe.SEARCH_TYPES._GREATER_THAN:s=Wr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case xe.SEARCH_TYPES.GREATER_THAN_EQUAL:case xe.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Wr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case xe.SEARCH_TYPES.LESS_THAN:case xe.SEARCH_TYPES._LESS_THAN:s=Wr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case xe.SEARCH_TYPES.LESS_THAN_EQUAL:case xe.SEARCH_TYPES._LESS_THAN_EQUAL:s=Wr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(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 p6(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(p6,"checkToFetchMore");function sU(e,t,r,n){if(_6.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),o=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),so.indexOf(s)>-1)return r===!0?xe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:xe.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(so[0])<0&&s.indexOf(so[1])<0)return c===!0?r===!0?xe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:xe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:xe.SEARCH_TYPES.EQUALS;if(so.indexOf(i)>=0&&so.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),xe.SEARCH_TYPES.CONTAINS;if(so.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),xe.SEARCH_TYPES.ENDS_WITH;if(so.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),xe.SEARCH_TYPES.STARTS_WITH;if(s.includes(so[0])||s.includes(so[1]))return xe.SEARCH_TYPES.EQUALS;throw new Error(eU.UNKNOWN_SEARCH_TYPE)}else switch(n){case hc.VALUE_SEARCH_COMPARATORS.BETWEEN:return xe.SEARCH_TYPES.BETWEEN;case hc.VALUE_SEARCH_COMPARATORS.GREATER:return xe.SEARCH_TYPES.GREATER_THAN;case hc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return xe.SEARCH_TYPES.GREATER_THAN_EQUAL;case hc.VALUE_SEARCH_COMPARATORS.LESS:return xe.SEARCH_TYPES.LESS_THAN;case hc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return xe.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(eU.UNKNOWN_SEARCH_TYPE)}}a(sU,"createSearchTypeFromSearchObject");iU.exports={executeSearch:rU,createSearchTypeFromSearchObject:sU,prepSearch:h6,searchByType:nU}});var aU=N((jye,oU)=>{"use strict";var Wye=$s(),m6=Yl(),S6=te(),T6=M(),g6=sp();oU.exports=R6;function R6(e,t){if(!S6.isEmpty(t)&&T6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=m6(e,"value");if(n)throw n;return g6.prepSearch(e,t,!0)}a(R6,"lmdbGetDataByValue")});var N_=N((Jye,cU)=>{"use strict";var Qye=$s(),A6=Yl(),y6=te(),b6=M(),O6=sp();cU.exports=N6;async function N6(e,t){if(!y6.isEmpty(t)&&b6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=A6(e,"value");if(n)throw n;return O6.prepSearch(e,t,!1)}a(N6,"lmdbSearchByValue")});var uU=N((ebe,lU)=>{"use strict";var Zye=Bt(),cA=class{static{a(this,"SearchByConditionsObject")}constructor(t,r,n,s,i=void 0,o=void 0,c="and"){this.schema=t,this.table=r,this.get_attributes=n,this.limit=i,this.offset=o,this.conditions=s,this.operator=c}},lA=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},uA=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};lU.exports={SearchByConditionsObject:cA,SearchCondition:lA,SortAttribute:uA}});var hU=N((sbe,EU)=>{"use strict";var rbe=uU().SearchByConditionsObject,I6=$s(),w6=Yl(),dA=Kl(),ip=Bt(),{Resource:nbe}=(Vs(),oe(_A)),fU=sp(),C6=nA(),D6=require("lodash"),{getSchemaPath:P6}=gt(),dU=ht(),{handleHDBError:L6,hdb_errors:M6}=_e(),{HTTP_STATUS_CODES:U6}=M6,v6=1e8;EU.exports=B6;async function B6(e){let t=w6(e,"conditions");if(t)throw L6(t,t.message,U6.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=P6(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=D6.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let d=u.search_type;d===ip.SEARCH_TYPES.EQUALS?u.estimated_count=dA.count(n,u.search_attribute,u.search_value):d===ip.SEARCH_TYPES.CONTAINS||d===ip.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=v6}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=dA.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(f=>u.get(f,{transaction:o,lazy:!0})),_>0&&(l=l.filter(f=>{for(let h=0;h<_;h++)if(!d[h](f))return!1;return!0})),(e.offset||e.limit!==void 0)&&(l=l.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),l=l.map(f=>C6.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=dA.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(B6,"lmdbSearchByConditions");async function _U(e,t,r,n){let s=new I6(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((obe,pU)=>{"use strict";var H6=M().OPERATIONS_ENUM,fA=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=H6.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};pU.exports=fA});var EA=N((cbe,bU)=>{"use strict";var gU=$s(),RU=I_(),AU=N_(),yU=A_(),dn=M(),mU=te(),SU=ht(),{getTransactionAuditStorePath:x6,getSchemaPath:k6}=gt(),TU=W();bU.exports=F6;async function F6(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 G6(e),await q6(e);let t=k6(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=x6(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(F6,"lmdbDropTable");async function G6(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 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 RU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await yU(s)}a(G6,"deleteAttributesFromSystem");async function q6(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 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 RU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await yU(s)}catch(i){throw i}}a(q6,"dropTableFromSystem")});var NU=N((ube,OU)=>{"use strict";var $6=require("fs-extra"),V6=$s(),K6=Wl(),Y6=I_(),W6=EA(),j6=A_(),z6=iA(),Q6=N_(),io=M(),{getSchemaPath:J6}=gt(),{handleHDBError:X6,hdb_errors:Z6}=_e(),{HDB_ERROR_MSGS:e8,HTTP_STATUS_CODES:t8}=Z6;OU.exports=r8;async function r8(e){let t;try{t=await n8(e.schema);let r=new V6(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 Q6(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await W6(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new Y6(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await j6(s);let i=J6(t);await $6.remove(i)}catch(r){throw r}}a(r8,"lmdbDropSchema");async function n8(e){let t=new K6(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 z6(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw X6(new Error,e8.SCHEMA_NOT_FOUND(e),t8.NOT_FOUND,void 0,void 0,!0);return n}a(n8,"validateDropSchema")});var w_=N((_be,IU)=>{"use strict";var hA=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};IU.exports=hA});var mA=N((hbe,wU)=>{"use strict";var s8=require("fs-extra"),op=ht(),{getTransactionAuditStorePath:i8}=gt(),pA=Bt(),Ebe=w_();wU.exports=o8;async function o8(e){let t;try{let r=i8(e.schema,e.table);await s8.mkdirp(r),t=await op.createEnvironment(r,e.table,!0)}catch(r){throw r.message=`unable to create transactions audit environment for ${e.schema}.${e.table} due to: ${r.message}`,r}try{op.createDBI(t,pA.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),op.createDBI(t,pA.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),op.createDBI(t,pA.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME,!0,!1)}catch(r){throw r.message=`unable to create dbi for ${e.schema}.${e.table} due to: ${r.message}`,r}return t}a(o8,"createTransactionsAuditEnvironment")});var PU=N((Sbe,DU)=>{"use strict";var SA=M(),CU=ht(),a8=sc(),{getSystemSchemaPath:c8,getSchemaPath:l8}=gt(),mbe=Zi(),u8=Bh(),TA=vh(),d8=W(),_8=mA();DU.exports=f8;async function f8(e,t){let r=l8(t.schema,t.table),n=new TA(t.schema,t.table,SA.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new TA(t.schema,t.table,SA.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new TA(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await CU.createEnvironment(r,t.table),e!==void 0){let o=await CU.openEnvironment(c8(),SA.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await a8.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_table_attributes,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await gA(n),await gA(s),await gA(i)}await _8(t)}catch(o){throw o}}a(f8,"lmdbCreateTable");async function gA(e){try{await u8(e)}catch(t){d8.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(gA,"createAttribute")});var MU=N((gbe,LU)=>{"use strict";var E8=E_(),h8=Xd(),p8=Xh(),C_=M(),m8=sc().updateRecords,S8=ht(),{getSchemaPath:T8}=gt(),g8=g_(),R8=W();LU.exports=A8;async function A8(e){try{let{schema_table:t,attributes:r}=E8(e);h8(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 p8(e.hdb_auth_header,t,r),s=T8(e.schema,e.table),i=await S8.openEnvironment(s,e.table),o=await m8(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await g8(e,o)}catch(c){R8.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(A8,"lmdbUpdateRecords")});var vU=N((Abe,UU)=>{"use strict";var y8=M().OPERATIONS_ENUM,RA=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=y8.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};UU.exports=RA});var HU=N((Obe,BU)=>{"use strict";var bbe=vU(),b8=E_(),O8=Xd(),N8=Xh(),D_=M(),I8=sc().upsertRecords,w8=ht(),{getSchemaPath:C8}=gt(),D8=g_(),P8=W(),{handleHDBError:L8,hdb_errors:M8}=_e();BU.exports=U8;async function U8(e){let t;try{t=b8(e)}catch(l){throw L8(l,l.message,M8.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;O8(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 N8(e.hdb_auth_header,r,n),i=C8(e.schema,e.table),o=await w8.openEnvironment(i,e.table),c=await I8(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await D8(e,c)}catch(l){P8.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(U8,"lmdbUpsertRecords")});var kU=N((Ibe,xU)=>{"use strict";var AA=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};xU.exports=AA});var GU=N((Cbe,FU)=>{"use strict";var yA=class{static{a(this,"DeleteAuditLogsBeforeResults")}constructor(t=void 0,r=void 0,n=0){this.start_timestamp=t,this.end_timestamp=r,this.transactions_deleted=n}};FU.exports=yA});var VU=N((Lbe,$U)=>{"use strict";var bA=ht(),{getTransactionAuditStorePath:v8}=gt(),Pbe=kU(),P_=Bt(),B8=te(),qU=GU(),H8=require("util").promisify,x8=H8(setTimeout),k8=1e4,F8=100;$U.exports=G8;async function G8(e){let t=v8(e.schema,e.table),r=await bA.openEnvironment(t,e.table,!0),n=bA.listDBIs(r);bA.initializeDBIs(r,P_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new qU;do s=await q8(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 x8(F8);while(s.transactions_deleted>0);return i}a(G8,"deleteAuditLogsBefore");async function q8(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];B8.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>k8)break}return await s,r}catch(n){throw n}}a(q8,"deleteTransactions")});var YU=N((Ube,KU)=>{"use strict";var OA=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};KU.exports=OA});var jU=N((Hbe,WU)=>{"use strict";var $8=$s(),V8=I_(),Bbe=YU(),yi=M(),K8=te(),NA=ht(),Y8=Zi(),W8=N_(),j8=A_(),{getSchemaPath:z8}=gt();WU.exports=Q8;async function Q8(e,t=!0){let r;e.schema===yi.SYSTEM_SCHEMA_NAME?r=Y8[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await X8(e),s=z8(e.schema,e.table),i=await NA.openEnvironment(s,e.table);return t===!0&&await J8(e,i,r.hash_attribute),NA.dropDBI(i,e.attribute),n}a(Q8,"lmdbDropAttribute");async function J8(e,t,r){let n=NA.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let u={};for(let d in c)d!==i&&(u[d]=c[d]);s=t.dbis[r].put(o,u,l)}await s}a(J8,"removeAttributeFromAllObjects");async function X8(e){let t=new $8(yi.SYSTEM_SCHEMA_NAME,yi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await W8(t)).filter(o=>o[yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(K8.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new V8(yi.SYSTEM_SCHEMA_NAME,yi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return j8(i)}a(X8,"dropAttributeFromSystem")});var ev=N((Fbe,ZU)=>{"use strict";var IA=ht(),jl=Bt(),kbe=cn(),wA=M(),zU=te(),{getTransactionAuditStorePath:Z8}=gt(),e9=Kl(),ap=ql(),t9=W();ZU.exports=r9;async function r9(e){let t=Z8(e.schema,e.table),r=await IA.openEnvironment(t,e.table,!0),n=IA.listDBIs(r);IA.initializeDBIs(r,jl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case wA.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return QU(r,e.search_values);case wA.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,s9(r,e.search_values,s);case wA.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return n9(r,e.search_values);default:return QU(r)}}a(r9,"readAuditLog");function QU(e,t=[0,Date.now()]){zU.isEmpty(t[0])&&(t[0]=0),zU.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[jl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let s of r.getKeys({start:t[1]}))if(s!==t[1]){n=s;break}return r.getRange({start:t[0],end:n}).map(({value:s})=>Object.assign(new ap,s))}a(QU,"searchTransactionsByTimestamp");function n9(e,t=[]){let r=new Map;for(let n=0;n<t.length;n++){let s=t[n],i=[];for(let o of e.dbis[jl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,XU(e,i))}return Object.fromEntries(r)}a(n9,"searchTransactionsByUsername");function s9(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],d=e9.equals(e,jl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,jl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:_}of d){let E=Number(_);n.has(E)?n.get(E).push(u.toString()):n.set(E,[u.toString()])}}let s=Array.from(n.keys()),i=XU(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,d=n.get(u);JU(l,"records",r,d,o),JU(l,"original_records",r,d,o)}return Object.fromEntries(o)}a(s9,"searchTransactionsByHashValues");function JU(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let u=s.get(l),d=u[u.length-1];if(d.timestamp===i)d[t]=[c];else{let _=new ap(e.operation,e.user_name,i,void 0);_[t]=[c],u.push(_)}}else{let u=new ap(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}a(JU,"loopRecords");function XU(e,t){let r=[];try{let n=e.dbis[jl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let s=0;s<t.length;s++)try{let i=n.get(t[s]);if(i){let o=Object.assign(new ap,i);r.push(o)}}catch(i){t9.warn(i)}return r}catch(n){throw n}}a(XU,"batchSearchTransactions")});var rv=N((Vbe,tv)=>{"use strict";var{getSchemaPath:qbe}=gt(),$be=ht(),{database:i9}=(Pe(),oe(lt));tv.exports={writeTransaction:o9};async function o9(e,t,r){return i9({database:e,table:t}).transaction(r)}a(o9,"writeTransaction")});var ov=N((Ybe,iv)=>{"use strict";var{getSchemaPath:nv}=gt(),sv=ht();iv.exports={flush:a9,resetReadTxn:c9};async function a9(e,t){return(await sv.openEnvironment(nv(e,t),t.toString())).flushed}a(a9,"flush");async function c9(e,t){try{(await sv.openEnvironment(nv(e,t),t.toString())).resetReadTxn()}catch{}}a(c9,"resetReadTxn")});var uv=N((jbe,lv)=>{"use strict";var{Readable:l9}=require("stream"),{getDatabases:u9}=(Pe(),oe(lt)),{readSync:d9,openSync:_9,createReadStream:av}=require("fs"),{open:f9}=require("lmdb"),cv=a_(),E9=c_(),{AUDIT_STORE_OPTIONS:h9}=(Ji(),oe(dv)),{INTERNAL_DBIS_NAME:p9,AUDIT_STORE_NAME:m9}=Bt();lv.exports=T9;var CA=32768,S9=100;async function T9(e){let t=e.database||e.schema||"data",r=u9()[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,_=f9({noSync:!0,maxDbs:E9.MAX_DBS}),E,f=_.openDB(p9,new cv(!1)),h=d.useReadTransaction(),T=0,m=a(async function(S,b){b.encoding="binary",b.encoder=void 0;let I=_.openDB(S,b),B=d.openDB(S,b);for(let{key:H,version:X,value:Y}of B.getRange({start:null,transaction:h,versions:B.useVersions}))E=I.put(H,Y,X),T++%S9===0&&(await new Promise(V=>setTimeout(V,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:S,value:b}of d.getRange({transaction:h,start:!1}))if(s.some(I=>S.startsWith?.(I+"/"))){f.put(S,b);let[,I]=S.split("/"),B=!I,H=new cv(!B,B);await m(S,H)}e.include_audit&&await m(m9,{...h9}),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=_9(o.path);return o.transaction(()=>{let u=Buffer.alloc(CA);d9(c,u,0,CA),o.resetReadTxn();let d=o.useReadTransaction();d.renew();let _=av(null,{fd:c,start:CA}),E=new l9.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(T9,"getBackup")});var Ev=N((Qbe,fv)=>{"use strict";var g9=W(),{handleHDBError:R9}=_e(),A9=zD(),y9=Bh(),b9=XR(),O9=NM(),N9=A_(),I9=iA(),w9=XM(),C9=aU(),D9=N_(),P9=hU(),L9=NU(),M9=PU(),U9=MU(),v9=HU(),B9=VU(),H9=EA(),x9=jU(),k9=ev(),F9=rv(),_v=ov(),G9=uv(),DA=class extends A9{static{a(this,"LMDBBridge")}async searchByConditions(t){return P9(t)}async getDataByHash(t){return await I9(t)}async searchByHash(t){return await w9(t)}async getDataByValue(t,r){return await C9(t,r)}async searchByValue(t){return await D9(t)}async createSchema(t){return await O9(t)}async dropSchema(t){return await L9(t)}async createTable(t,r){return await M9(t,r)}async dropTable(t){return await H9(t)}async createAttribute(t){return await y9(t)}async createRecords(t){return await b9(t)}async updateRecords(t){return await U9(t)}async upsertRecords(t){try{return await v9(t)}catch(r){throw R9(r,null,null,g9.ERR,r)}}async deleteRecords(t){return await N9(t)}async dropAttribute(t){return await x9(t)}async deleteAuditLogsBefore(t){return await B9(t)}async readAuditLog(t){return await k9(t)}writeTransaction(t,r,n){return F9.writeTransaction(t,r,n)}flush(t,r){return _v.flush(t,r)}resetReadTxn(t,r){return _v.resetReadTxn(t,r)}getBackup(t){return G9(t)}};fv.exports=DA});function Av(e){LA=e}function K9(){V9=setInterval(function(){for(let e of PA)if(e.stale){let t=e[ke]?.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},$9).unref()}var MA,mv,Sv,Tv,gv,Rv,hv,PA,q9,L_,pv,LA,pc,cp,$9,V9,lp=Ne(()=>{MA=L(cn()),mv=L(_e()),Sv=L(W());Vs();Tv=L(se()),gv=L(M()),Rv=L(te()),hv=100,PA=new Set,q9=(0,Rv.convertToMS)(Tv.get(gv.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(Av,"replicationConfirmation");pc=class e{static{a(this,"DatabaseTransaction")}writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxnsUsed=1,this.readTxn.openTimer&&(this.readTxn.openTimer=0),PA.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(PA.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(L_&&!this.overloadChecked&&performance.now()-pv>q9)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,MA.getNextMonotonicTime)()),t.timestamp||(t.timestamp=r);let n=t.retries||0;if(this.validated<this.writes.length)try{let _=this.validated;this.validated=this.writes.length;for(let f=_;f<this.validated;f++)this.writes[f]?.validate?.(this.timestamp);let E;for(let f=_;f<this.validated;f++){let h=this.writes[f];h&&(h.before||h.beforeIntermediate)&&(E=!0)}if(E)return(async()=>{try{for(let f=0;f<2;f++){let h;for(let T=_;T<this.validated;T++){let m=this.writes[T];if(!m)continue;let g=m[f===0?"before":"beforeIntermediate"];if(g){let S=g();h?h.push?h.push(S):h=[h,S]:h=S}}h&&await(h.push?Promise.all(h):h)}}catch(f){throw this.abort(),f}return this.commit(t)})()}catch(_){throw this.abort(),_}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(_=>_);let c=a(_=>{_.commit(r,_.entry,n)},"doWrite"),l=a(()=>{let _=this.writes[o++];if(_)if(_.key){n>0&&(_.entry=_.store.getEntry(_.key));let E=_.store.ifVersion(_.key,_.entry?.version??null,l);s=s||E}else l();else for(let E of this.writes)c(E)},"nextCondition"),u=this.lmdbDb;if(this.writes.length>0&&(u?.retryRisk&&(u.retryRisk*=.99),this.writes.length+(u?.retryRisk||0)<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];LA&&f&&i.push(LA(E,f.store.getEntry(f.key).localTime,this.replicatedConfirmation))}return this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))}else return u&&(u.retryRisk=(u.retryRisk||0)+hv/2),t?t.retries=n+1:t={retries:1},this.commit(t)});let d={txnTime:r};if(this.next){let _=this.next?.commit(t);if(_?.then)return _?.then(E=>({txnTime:r,next:E}));d.next=_}return d}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},cp=class extends pc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,MA.getNextMonotonicTime)())}getReadTxn(){}},$9=3e4;a(K9,"startMonitoringTxns");K9()});function Dt(e,t,r){if(!t)t=e,e={};else if(!e)e={};else if(e?.transaction?.open===1&&typeof t=="function")return t(e.transaction);if(typeof t!="function")throw new Error("Callback function must be provided to transaction");let n=e.transaction=new pc;e.timestamp&&(n.timestamp=e.timestamp),e.replicatedConfirmation&&(n.replicatedConfirmation=e.replicatedConfirmation),n[ke]=e,e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var yv,mc=Ne(()=>{yv=L(fi());Vs();lp();a(Dt,"transaction");(0,yv._assignPackageExport)("transaction",Dt);Dt.commit=function(e){let t=(e[ke]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Dt.abort=function(e){let t=(e[ke]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var Pv={};je(Pv,{ResourceBridge:()=>BA});function HA({get_attributes:e},t){if(e){if(e[0]==="*"){if(t.schemaDefined)return;e=t.attributes.map(r=>r.name)}return e.forceNulls=!0,e}}function Ov(e,t){let r=bi(e),n=HA(e,r);if(!r)throw new Ks.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache,replicateFrom:e.replicateFrom},o;Dt(i,()=>new Promise(u=>o=u));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let u=c[l++],d;try{d=await r.get({id:u,lazy:s,select:n},i),d=d&&dp(d)}catch(_){d={message:_.toString()}}return t?{value:{key:u,value:d}}:{value:d}}else return o(),{done:!0}},return(u){return o(),{value:u,done:!0}},throw(u){return o(),{done:!0}}}}}}function bi(e){let t=e.database||e.schema||W9,r=ut()[t];if(!r)throw(0,Ks.handleHDBError)(new Error,Y9.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,UA,vA,Dv,Y9,W9,j9,z9,bv,BA,Lv=Ne(()=>{"use strict";wv=L(Ev()),up=L(Yl()),Ks=L(_e());Pe();Cv=L(E_()),Ys=L(M()),UA=L(no()),vA=L(qs()),Dv=L(te());mc();_p();({HDB_ERROR_MSGS:Y9}=Ks.hdb_errors),W9="data",j9=1e4,z9=10,BA=class extends wv.default{static{a(this,"ResourceBridge")}constructor(t){super(t),bv=this}async searchByConditions(t){t.select!==void 0&&(t.get_attributes=t.select);for(let o of t.conditions||[])o?.attribute!==void 0&&(o.search_attribute=o.attribute),o?.comparator!==void 0&&(o.search_type=o.comparator),o?.value!==void 0&&(o.search_value=o.value);let r=(0,up.default)(t,"conditions");if(r)throw(0,Ks.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=bi(t);if(!n)throw new Ks.ClientError(`Table ${t.table} not found`);let s=t.conditions.map(i);function i(o){return o.conditions?(o.conditions=o.conditions.map(i),o):{attribute:o.search_attribute??o.attribute,comparator:o.search_type??o.comparator,value:o.search_value!==void 0?o.search_value:o.value}}return a(i,"mapCondition"),n.search({conditions:s,operator:t.operator?t.operator.toLowerCase():void 0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:HA(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new Ks.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}Et({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await bi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=bi(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c={...c},delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(u=>{if(!u){let{value:d,version:_}=r.primaryStore.getEntry(o);return i(o,d,_)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(u=>setImmediate(u));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){bi(t).dropTable()}createSchema(t){return zl({database:t.schema,table:null}),UA.signalSchemaChange(new vA.SchemaEventMsg(process.pid,Ys.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await xA(t.schema),UA.signalSchemaChange(new vA.SchemaEventMsg(process.pid,Ys.OPERATIONS_ENUM.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,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)(z9),l=[],s=!0},"chunkDelete");for await(let d of n)l.push(d[r.primaryKey]),c++,c%j9===0&&await u();return l.length>0&&await u(),s?Nv(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,up.default)(t,"hashes");if(r)throw r;return Ov(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of Ov(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Ys.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r]===void 0)throw new Error(`Value search comparator - ${r} - is not valid`);t.select!==void 0&&(t.get_attributes=t.select),t.attribute!==void 0&&(t.search_attribute=condition.attribute),t.value!==void 0&&(t.search_value=condition.value);let n=(0,up.default)(t,"value");if(n)throw n;let s=bi(t);if(!s)throw new Ks.ClientError(`Table ${t.table} not found`);let i=t.search_value;i.includes?.("*")&&(i.startsWith("*")?i.endsWith("*")?i!=="*"&&(r="contains",i=i.slice(1,-1)):(r="ends_with",i=i.slice(1)):i.endsWith("*")&&(r="starts_with",i=i.slice(0,-1))),r===Ys.VALUE_SEARCH_COMPARATORS.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,sort:t.sort,select:HA(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=bi(t);t.get_attributes&&!t.get_attributes.includes(s.primaryKey)&&t.get_attributes[0]!=="*"&&t.get_attributes.push(s.primaryKey);for await(let i of this.searchByValue(t,r))n.set(i[s.primaryKey],i);return n}resetReadTxn(t,r){bi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return bi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=bi(t),n={};switch(t.search_type){case Ys.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.operation??o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case Ys.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of 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(HA,"getSelect");a(Ov,"getRecords");a(bi,"getTable");a(Nv,"createDeleteResponse");a(Iv,"groupRecordsInHistory")});var Bn=N((dOe,Mv)=>{"use strict";var{ResourceBridge:Q9}=(Lv(),oe(Pv)),J9=se();J9.initSync();var fp;function X9(){return fp||(fp=new Q9,fp)}a(X9,"getBridge");Mv.exports=X9()});var Hv=N((fOe,Bv)=>{"use strict";var Uv=require("lodash"),M_=require("mathjs"),Z9=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:e7,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 e7(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=Z9(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(e7,"searchJSON")});var kv=N((hOe,xv)=>{"use strict";var nr=require("moment"),kA="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(kA),"date"),date_format:a((e,t)=>nr(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>nr(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>nr(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=nr(e).utc(),s=nr(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>nr().utc().valueOf(),"now"),get_server_time:a(()=>nr().format(kA),"get_server_time"),offset_utc:a((e,t)=>nr(e).utc().utcOffset(t).format(kA),"offset_utc")}});var $v=N((mOe,qv)=>{"use strict";var t7=require("@turf/area"),r7=require("@turf/length"),n7=require("@turf/circle"),s7=require("@turf/difference"),i7=require("@turf/distance"),o7=require("@turf/boolean-contains"),a7=require("@turf/boolean-equal"),c7=require("@turf/boolean-disjoint"),l7=require("@turf/helpers"),Fv=M(),$e=te(),oo=W();qv.exports={geoArea:u7,geoLength:d7,geoCircle:_7,geoDifference:f7,geoDistance:Gv,geoNear:E7,geoContains:h7,geoEqual:p7,geoCrosses:m7,geoConvert:S7};function u7(e){if($e.isEmpty(e))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return t7.default(e)}catch(t){return oo.trace(t,e),NaN}}a(u7,"geoArea");function d7(e,t){if($e.isEmpty(e))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return r7.default(e,{units:t||"kilometers"})}catch(r){return oo.trace(r,e),NaN}}a(d7,"geoLength");function _7(e,t,r){if($e.isEmpty(e))return NaN;if($e.isEmpty(t))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return n7.default(e,t,{units:r||"kilometers"})}catch(n){return oo.trace(n,e,t),NaN}}a(_7,"geoCircle");function f7(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 s7(e,t)}catch(r){return oo.trace(r,e,t),NaN}}a(f7,"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 i7.default(e,t,{units:r||"kilometers"})}catch(n){return oo.trace(n,e,t),NaN}}a(Gv,"geoDistance");function E7(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(E7,"geoNear");function h7(e,t){if($e.isEmpty(e)||$e.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return o7.default(e,t)}catch(r){return oo.trace(r,e,t),!1}}a(h7,"geoContains");function p7(e,t){if($e.isEmpty(e)||$e.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return a7.default(e,t)}catch(r){return oo.trace(r,e,t),!1}}a(p7,"geoEqual");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,"geoCrosses");function S7(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)),l7[t](e,r)}a(S7,"geoConvert")});var Ep=N((TOe,Vv)=>{var Sc=Hv(),Gn=kv(),Oi=$v();Vv.exports=e=>{e.aggr.mad=e.aggr.MAD=Sc.mad,e.aggr.mean=e.aggr.MEAN=Sc.mean,e.aggr.mode=e.aggr.MODE=Sc.mode,e.aggr.prod=e.aggr.PROD=Sc.prod,e.aggr.median=e.aggr.MEDIAN=Sc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Sc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Sc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Gn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Gn.current_time,e.fn.extract=e.fn.EXTRACT=Gn.extract,e.fn.date=e.fn.DATE=Gn.date,e.fn.date_format=e.fn.DATE_FORMAT=Gn.date_format,e.fn.date_add=e.fn.DATE_ADD=Gn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Gn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Gn.date_diff,e.fn.now=e.fn.NOW=Gn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Gn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Gn.get_server_time,e.fn.getdate=e.fn.GETDATE=Gn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Gn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Oi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Oi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Oi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Oi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Oi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Oi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Oi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Oi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Oi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Oi.geoNear}});var jv=N((gOe,Wv)=>{"use strict";var v_=require("lodash"),_n=require("alasql");_n.options.cache=!1;var T7=Ep(),Kv=require("clone"),hp=require("recursive-iterator"),Ue=W(),et=te(),Ql=Bn(),g7=M(),{hdb_errors:R7}=_e(),{getDatabases:Yv}=(Pe(),oe(lt)),A7="IS NULL",Ws="There was a problem performing this search. Please check the logs and try again.";T7(_n);var FA=class{static{a(this,"SQLSearch")}constructor(t,r){if(et.isEmpty(t))throw Ue.error("AST statement for SQL select process cannot be empty"),"statement cannot be null";this.statement=t,this.columns={},this.all_table_attributes=r,this.fetch_attributes=[],this.exact_search_values={},this.comparator_search_values={},this.tables=[],this.data={},this.has_aggregator=!1,this.has_ordinal=!1,this.has_outer_join=!1,this._getColumns(),this._getTables(),this._conditionsToFetchAttributeValues(),this._setAliasesForColumns(),et.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!et.isEmptyOrZeroLength(n))return Ue.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw Ue.error("Error thrown from checkEmptySQL in SQLSearch class method search."),Ue.error(n),new Error(Ws)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw Ue.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),Ue.error(n),new Error(Ws)}if(Object.keys(this.data).length===0)return Ue.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw Ue.error("Error thrown from processJoins in SQLSearch class method search."),Ue.error(n),new Error(Ws)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw Ue.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),Ue.error(n),new Error(Ws)}try{return t=await this._finalSQL(),t}catch(n){throw Ue.error("Error thrown from finalSQL in SQLSearch class method search."),Ue.error(n),new Error(Ws)}}_getColumns(){let t=new hp(this.statement);for(let{node:r,path:n}of t)r&&r.columnid&&(this.columns[n[0]]||(this.columns[n[0]]=[]),this.columns[n[0]].push(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(g7.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(A7)>-1&&this.tables.forEach(s=>{let i={columnid:Yv()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=v_.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,u=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!et.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!et.isEmptyOrZeroLength(this.exact_search_values[u].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[u].values);let d=await Ql.getDataByHash(c);for(let _ of c.hash_values)d.get(_)&&!this.data[i].__merged_data[_]&&(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_))}catch(d){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(d),new Error(Ws)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async d=>{let _={...c};_.search_value=d;let E=await Ql.getDataByValue(_);for(let[f,h]of E)this.data[i].__merged_data[f]?this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]):(this.data[i].__merged_data[f]=[...n[i]],this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,f))}))}catch(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(d),new Error(Ws)}else if(!et.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!et.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let d=this.comparator_search_values[u].comparators;for(let _=0,E=d.length;_<E;_++){let f=d[_];c.search_attribute=f.attribute,c.search_value=f.search_value;let h=await Ql.getDataByValue(c,f.operation);if(l)for(let[T]of h)this.data[i].__merged_data[T]||(this.data[i].__merged_data[T]=[...n[i]],this._setMergedHashAttribute(i,T));else for(let[T,m]of h)this.data[i].__merged_data[T]?this._updateMergedAttribute(i,T,s.attribute,m[s.attribute]):(this.data[i].__merged_data[T]=[...n[i]],this._updateMergedAttribute(i,T,s.attribute,m[s.attribute]),this._setMergedHashAttribute(i,T))}}catch(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),Ue.error(d),new Error(Ws)}else try{c.search_attribute=s.attribute,c.search_value="*";let d=await Ql.getDataByValue(c);if(l)for(let[_]of d)this.data[i].__merged_data[_]||(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_));else for(let[_,E]of d)this.data[i].__merged_data[_]?this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]):(this.data[i].__merged_data[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]),this._setMergedHashAttribute(i,_))}catch(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),Ue.error(d),new Error(Ws)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof _n.yy.Column||(t=!1)}),t)}_updateOrderByToAliases(){this.statement.order.forEach(t=>{if(t.expression.aggregatorid){t.is_aggregator=!0;return}if(t.expression.value){t.is_ordinal=!0,this.has_ordinal=!0;return}else t.is_ordinal=!1;let r=this.statement.columns.filter(s=>{let i=s.aggregatorid?s.expression:s,o=s.aggregatorid?s.as_orig:i.as_orig;return t.expression.tableid?i.columnid_orig===t.expression.columnid_orig&&i.tableid_orig===t.expression.tableid_orig:i.columnid_orig===t.expression.columnid_orig||t.expression.columnid_orig===o});r[0]||r.push(this._findColumn(t.expression));let n=r[0];if(t.is_func=!!n.funcid,t.is_aggregator=!!n.aggregatorid,n.as)if(n.as&&!t.expression.tableid)t.expression.columnid=n.as,t.expression.columnid_orig=n.as_orig;else{let s=new _n.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new _n.yy.Column,t.expression),t.initial_select_column.as=`[${t.expression.columnid_orig}]`,t.expression.columnid=t.initial_select_column.as;return}if(!t.is_aggregator){let s=t.is_func?new _n.yy.FuncValue:new _n.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(f=>{f.joinmode&&f.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(f.table);let h=f.joinmode+" JOIN ? AS "+(f.as?f.as:f.table.tableid);f.on&&(h+=" ON "+f.on.toString()),i.push(h),t.push(Object.values(this.data[`${f.table.databaseid_orig}_${f.table.as?f.table.as_orig:f.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(f=>{let h=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__hash_name,T=f.as?f.as_orig:f.tableid_orig;o.push({key:`'${T}.${h}'`,schema:f.databaseid_orig,table:f.as?f.as_orig:f.tableid_orig,keys:new Set}),r.push(`${f.as?f.as:f.tableid}.\`${h}\` AS "${T}.${h}"`),c[f.as?f.as_orig:f.tableid_orig]=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let u="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(u="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(f=>{f.is_func?r.push(f.initial_select_column.toString()):f.initial_select_column.tableid?r.push(`${f.initial_select_column.tableid}.${f.initial_select_column.columnid} AS ${f.expression.columnid}`):r.push(`${f.initial_select_column.columnid} AS ${f.expression.columnid}`)}));let d="",_="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(d=this.statement.limit?"LIMIT "+this.statement.limit:"",_=this.statement.offset?"OFFSET "+this.statement.offset:"");let E=[];try{let f=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${u} ${d} ${_}`,h=this._convertColumnsToIndexes(f,s);E=await _n.promise(h,t),t=null}catch(f){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),Ue.error(f),new Error("There was a problem processing the data.")}if(E&&E.length>0){for(let f=0,h=E.length;f<h;f++){let T=E[f];o.forEach(m=>{T[m.key]!==null&&T[m.key]!==void 0&&m.keys.add(T[m.key])})}o.forEach(f=>{let h=Object.keys(this.data[`${f.schema}_${f.table}`].__merged_data),T=v_.difference(h,[...f.keys].map(m=>m.toString()));for(let m=0,g=T.length;m<g;m++){let S=T[m];delete this.data[`${f.schema}_${f.table}`].__merged_data[S]}})}return{existing_attributes:c,joined_length:E?E.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new hp(this.columns);for(let{node:i}of s)if(i&&i.columnid){let o=this._findColumn(i);if(o){let c=o.table.as?o.table.as:o.table.tableid;(!t[c]||t[c].indexOf(o.attribute)<0)&&n.push(o)}}n=v_.uniqBy(n,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(n)}catch(i){throw Ue.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),Ue.error(i),new Error(Ws)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__merged_data,o=[];for(let d in i)o.push(i[d][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await Ql.getDataByHash(c),u=s.columns.length;for(let d=0,_=o.length;d<_;d++){let E=o[d],f=l.get(E);for(let h=0;h<u;h++){let T=s.columns[h],m=f[T]===void 0?null:f[T];this.data[n].__merged_data[E].push(m)}}}}catch(r){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getData."),Ue.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__merged_data)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,l=o.aggregatorid?o.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===l}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();Ue.trace(`Final SQL: ${s}`),n=await _n.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),Ue.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),Ue.error(s),new Error("There was a problem running the generated sql.")}return n}_translateUndefinedValues(t){try{let r=[];for(let n of t){let s=Object.create(null);Object.keys(n).forEach(i=>{n[i]===void 0?s[i]=null:s[i]=n[i]}),r.push(s)}return r}catch(r){return Ue.error(R7.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),Ue.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],u=new RegExp(`${l}.\`${o}\``,"g"),d=`${l}.[${c}]`;n=n.replace(u,d)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),u=`[${c}]`;n=n.replace(l,u)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await Ql.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]={...r[s]}),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw Ue.error("There was an error when processing this SQL operation. Check your logs"),Ue.error(o),new Error(Ws)}}return Object.values(Object.values(this.data)[0].__merged_data)}};Wv.exports=FA});var Vr=N((AOe,zv)=>{"use strict";var y7=WD();zv.exports={searchByConditions:O7,searchByHash:N7,searchByValue:I7,search:w7};var GA=Bn(),{transformReq:qA}=te(),b7=jv();async function O7(e){return qA(e),GA.searchByConditions(e)}a(O7,"searchByConditions");async function N7(e){qA(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of GA.searchByHash(e))r&&t.push(r);return t}a(N7,"searchByHash");async function I7(e){qA(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of GA.searchByValue(e))t.push(r);return t}a(I7,"searchByValue");function w7(e,t){try{let r=new y7(e);r.validate(),new b7(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(w7,"search")});var pp=N((bOe,Qv)=>{"use strict";var C7=Bn();Qv.exports={writeTransaction:D7};function D7(e,t,r){return C7.writeTransaction(e,t,r)}a(D7,"writeTransaction")});var e0=N((IOe,Zv)=>{"use strict";var P7=Vr(),L7=ls(),Jv=W(),M7=un(),NOe=pp(),U7=require("clone"),VA=require("alasql"),v7=Ep(),Xv=require("util"),B7=Xv.promisify(L7.getTableSchema),H7=Xv.promisify(P7.search),x7=M(),$A=te();v7(VA);Zv.exports={update:F7};var k7="There was a problem performing this update. Please check the logs and try again.";async function F7({statement:e,hdb_user:t}){let r=await B7(e.table.databaseid,e.table.tableid),n=G7(e.columns);$A.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=U7(s),c=$A.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=VA.parse(l).statements[0],d=await H7(u),_=q7(n,d);return $7(o,_,t)}a(F7,"update");function G7(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=VA.compile(`SELECT ${r.expression.toString()} AS [${x7.FUNC_VAL}] FROM ?`)}),t}catch(t){throw Jv.error(t),new Error(k7)}}a(G7,"createUpdateRecord");function q7(e,t){return $A.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(q7,"buildUpdateRecords");async function $7(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await M7.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($7,"updateRecords")});var r0=N((POe,t0)=>{var V7=require("alasql"),K7=Vr(),Y7=W(),W7=Bn(),YA=require("util"),KA=te(),j7=M(),z7=ls(),COe=pp(),DOe=un(),Q7="record",J7="successfully deleted",X7=YA.callbackify(ree),Z7=YA.promisify(K7.search),eee=YA.promisify(z7.getTableSchema);t0.exports={convertDelete:X7};function tee(e){return`${e.deleted_hashes.length} ${Q7}${e.deleted_hashes.length===1?"":"s"} ${J7}`}a(tee,"generateReturnMessage");async function ree({statement:e,hdb_user:t}){let r=await eee(e.table.databaseid,e.table.tableid);KA.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=KA.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=V7.parse(o).statements[0],l={operation:j7.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await Z7(c);let u=await W7.deleteRecords(l);return KA.isEmptyOrZeroLength(u.message)&&(u.message=tee(u)),delete u.txn_time,u}catch(u){throw Y7.error(u),u.hdb_code?u.message:u}}a(ree,"convertDelete")});var a0=N((MOe,o0)=>{"use strict";var nee=ro(),{hdb_errors:n0}=_e(),{getDatabases:s0}=(Pe(),oe(lt));o0.exports={checkSchemaExists:i0,checkSchemaTableExists:see,schema_describe:nee};async function i0(e){if(!s0()[e])return n0.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(i0,"checkSchemaExists");async function see(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(see,"checkSchemaTableExists")});var Jl=N((vOe,iee)=>{iee.exports={name:"harperdb",version:"4.4.17",description:"HarperDB is a distributed database, caching service, streaming broker, and application development platform focused on performance and ease of use.",keywords:["database","nosql","api","distributed","broker","mqtt","real-time","enterprise","Fastify","NATS","HarperDB","Harper","clustering","replication","REST","WebSockets","decentralized","server-sent events","document store"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{"minimum-node":"16.0.0","go-lang":"1.21.7","nats-server":"2.10.11"},exports:{".":"./index.js"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"SEE LICENSE IN LICENSE",scripts:{submodules:"git submodule update --init --recursive","cover:test":"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && nyc --no-clean --reporter=lcovonly npm run test:replication && nyc --no-clean --reporter=lcovonly npm run test:apitests && nyc --no-clean --reporter=lcovonly npm run test:resources && nyc --no-clean --reporter=lcovonly npm run test:logging && nyc --no-clean --reporter=lcovonly npm run test:upgrade && nyc --no-clean --reporter=lcovonly npm run test:nats && nyc --no-clean --reporter=lcovonly npm run test:cfserver && nyc --no-clean --reporter=lcovonly npm run test:hdbserver && nyc --no-clean --reporter=lcovonly npm run test:bin && nyc --no-clean --reporter=lcovonly npm run test:main && nyc --no-clean --reporter=lcovonly npm run test:security && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license",test:"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && npm run test:replication && npm run test:apitests && npm run test:resources && npm run test:logging && npm run test:upgrade && npm run test:nats && npm run test:cfserver && npm run test:hdbserver && npm run test:bin && npm run test:main && npm run test:security && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license","test:resources":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/resources/**/*.js' --config '../unitTests/.mocharc.json'","test:bin":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/bin/**/*.js' --config '../unitTests/.mocharc.json'","test:main":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","test:lmdbbridge":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --config '../unitTests/.mocharc.json'","test:lmdbutility":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --config '../unitTests/.mocharc.json'","test:hdbserver":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --config '../unitTests/.mocharc.json'","test:cfserver":"npm run submodules && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/fastifyRoutes/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","test:nats":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","test:upgrade":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --config '../unitTests/.mocharc.json'","test:apitests":"pm2 kill && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/apiTests/**/*-test.mjs' --config '../unitTests/.mocharc.json'","test:logging":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/logging/*.js' --config '../unitTests/.mocharc.json'","test:ci":" cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --retries 3 --config '../unitTests/.mocharc-main.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter","test:security":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/security/**/*.js' --config '../unitTests/.mocharc.json'","test:replication":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/replication/**/*.js' --config '../unitTests/.mocharc.json'","hdb-check":"./utility/devops/hdb-check.sh","download-prebuilds":"node ./utility/devops/build/download-prebuilds.js",prebuild:"date",postinstall:"node ./launchServiceScripts/launchInstallNATSServer.js",build_nats_dependency:"node ./utility/devops/nats/builder.js",coverage:"nyc --reporter=lcov npm test",format:"prettier .","format:fix":"npm run format -- --write",lint:"eslint .","lint:fix":"npm run lint -- --fix"},dependencies:{"@aws-sdk/client-s3":"3.717.0","@aws-sdk/lib-storage":"3.717.0","@endo/static-module-record":"^1.0.4","@fastify/autoload":"5.10.0","@fastify/compress":"~6.5.0","@fastify/cors":"~9.0.1","@fastify/static":"~7.0.4","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"4.1.10","cbor-x":"1.6.0",chalk:"4.1.2","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.2",fastify:"~4.29.0","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.10.0","gunzip-maybe":"1.4.2","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.12.2","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.7",jsonwebtoken:"9.0.2",lmdb:"3.2.2",lodash:"4.17.21",mathjs:"11.12.0",minimist:"1.2.8",moment:"2.30.1","mqtt-packet":"~9.0.0",msgpackr:"1.11.2",nats:"2.19.0",needle:"3.3.1","node-forge":"^1.3.1","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.3",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.4.1",prompt:"1.3.0","properties-reader":"2.3.0","recursive-iterator":"3.3.0",semver:"7.5.4",send:"^1.1.0","serve-static":"2.1.0",ses:"1.1.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.24.5","tar-fs":"3.0.6",ulidx:"0.5.0",uuid:"10.0.0","validate.js":"0.13.1",ws:"8.18.0",yaml:"2.7.0"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"20.14.8","@typescript-eslint/eslint-plugin":"^7.18.0","@typescript-eslint/parser":"^7.18.0",axios:"1.7.5",chai:"4.4.1","chai-integer":"0.1.0",esbuild:"^0.24.2",eslint:"^9.17.0","eslint-config-prettier":"^9.1.0","eslint-plugin-sonarjs":"^3.0.1",eventsource:"^2.0.2","graphql-http":"^1.22.3","hook-std":"3.0.0","intercept-stdout":"0.1.2",mkcert:"1.5.1",mocha:"^11.0.1","mocha-teamcity-reporter":"^4.2.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.8",newman:"6.1.3","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"3.3.3",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0","source-map-support":"^0.5.21",typescript:"^5.7.2",undici:"^6.19.8","why-is-node-still-running":"^1.0.0"},overrides:{alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","segfault-handler":"^1.3.0","utf-8-validate":"^5.0.10"}}});var F_={};je(F_,{addAnalyticsListener:()=>k_,recordAction:()=>pr,recordActionBinary:()=>qn,setAnalyticsEnabled:()=>oee});function oee(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||aee()}function qn(e,t,r,n,s){pr(!!e,t,r,n,s)}function k_(e){T0.push(e)}function aee(){mp=performance.now(),setTimeout(async()=>{let e=performance.now()-mp;mp=0;let t=[],r={time:Date.now(),period:e,threadId:Tc.threadId,metrics:t};for(let[s,i]of Tp){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,u=[],d;for(let _ of g0){let E=Math.floor(c*_),f=o[E-1];if(E>l){let h=E-l;if(f===d){let T=u[u.length-1];typeof T=="number"?u[u.length-1]={value:T,count:1+h}:T.count+=h}else u.push(h>1?{value:f,count:h}:f),d=f;l=E}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:u,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await R0()}let n=process.memoryUsage();t.push({metric:"memory",threadId:Tc.threadId,byThread:!0,...n});for(let s of T0)s(t);Tp=new Map,Tc.parentPort?Tc.parentPort.postMessage({type:S0,report:r}):b0({report:r})},m0).unref()}async function cee(e,t=6e4){let r=zA(),n=A0(),s=new Promise(T=>{let m=performance.now();setImmediate(()=>{let g=performance.now();g-m>5e3&&(0,B_.warn)("Unusually high event queue latency on the main thread of "+Math.round(g-m)+"ms"),m=performance.now()}),n.primaryStore.prefetch([1],()=>{let g=performance.now();g-m>5e3&&(0,B_.warn)("Unusually high task queue latency on the main thread of "+Math.round(g-m)+"ms"),T(g-m)})}),i;for(let T of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(T.value?.time){i=T.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,u=[],d;for(let{key:T,value:m}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!m)continue;if(o){if(T>o+t)break}else o=T;d=T;let{metrics:g,threadId:S}=m;for(let b of g||[]){let{path:I,method:B,type:H,metric:X,count:Y,total:V,distribution:ne,threads:Q,...de}=b;Y||(Y=1);let j=X+(I?"-"+I:"");B!==void 0&&(j+="-"+B),H!==void 0&&(j+="-"+H);let ae=c.get(j);if(ae){if(ae.threads){let ye=ae.threads[S];if(ye)ae=ye;else{ae.threads[S]={...de};continue}}ae.count||(ae.count=1);let Ae=ae.count;for(let ye in de){let Me=de[ye];typeof Me=="number"&&(ae[ye]=(ae[ye]*Ae+Me*Y)/(Ae+Y))}ae.count+=Y,V>=0&&(ae.total+=V,ae.ratio=ae.total/ae.count)}else ae={period:t,...b},delete ae.distribution,c.set(j,ae),ae.byThread&&(ae.threads=[],ae.threads[S]={...de},u.push(ae));if(ne){ne=ne.map(ye=>typeof ye=="number"?{value:ye,count:1}:ye);let Ae=l.get(j);Ae?Ae.push(...ne):l.set(j,ne)}}await R0()}for(let T of u){let{path:m,method:g,type:S,metric:b,count:I,total:B,distribution:H,threads:X,...Y}=T;X=X.filter(V=>V);for(let V in Y){if(typeof T[V]!="number")continue;let ne=0;for(let Q of X){let de=Q[V];typeof de=="number"&&(ne+=de)}T[V]=ne}T.count=X.length,delete T.threads,delete T.byThread}for(let[T,m]of l){let g=c.get(T);m.sort((ye,Me)=>ye.value>Me.value?1:-1);let S=g.count-1,b=[],I=0,B=0,H;for(let ye of g0){let Me=S*ye;for(;I<Me;)H=m[B++],I+=H.count,B===1&&I--;let Gr=m[B>1?B-2:0];H||(H=m[0]),b.push(H.value-(H.value-Gr.value)*(I-Me)/H.count)}let[X,Y,V,ne,Q,de,j,ae,Ae]=b;Object.assign(g,{p1:X,p10:Y,p25:V,median:ne,p75:Q,p90:de,p95:j,p99:ae,p999:Ae})}let _;for(let[T,m]of c)m.id=(0,Sp.getNextMonotonicTime)(),m.time=d,n.primaryStore.put(m.id,m,{append:!0}).then(g=>{g||n.primaryStore.put(m.id,m)}),_=!0;let E=Date.now(),{idle:f,active:h}=performance.eventLoopUtilization();if(_||h*10>f){let T=(0,Sp.getNextMonotonicTime)(),m={id:T,metric:"main-thread-utilization",idle:f-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 zA(){return d0||(d0=Et({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function A0(){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 dee(){y0=!0;let e=(0,x_.get)(jA.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await cee(m0,e),await u0(zA(),lee),await u0(A0(),uee)},Math.min(e/2,2147483647)).unref()}function b0(e,t){let r=e.report;r.threadId=t?.threadId||Tc.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(f0+=n.mean*n.count);r.totalBytesProcessed=f0,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(E0.get(t))}),E0.set(t,t.performance.eventLoopUtilization())),r.id=(0,Sp.getNextMonotonicTime)(),zA().primaryStore.put(r.id,r),y0||dee(),_ee&&(O0=Eee(r))}async function Eee(e){if(await O0,!Zo){let r=(0,H_.dirname)((0,B_.getLogFilePath)());try{Zo=await(0,WA.open)((0,H_.join)(r,"analytics.log"),"r+")}catch{Zo=await(0,WA.open)((0,H_.join)(r,"analytics.log"),"w+")}}let t=(await Zo.stat()).size;if(t>fee){let r=Buffer.alloc(t);await Zo.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Zo.write(r,{position:0}),await Zo.truncate(r.length),t=r.length}await Zo.write(JSON.stringify(e)+`
|
|
12
|
+
`,t)}var Tc,h0,B_,H_,WA,Sp,x_,jA,Tp,p0,mp,m0,S0,T0,g0,c0,l0,R0,lee,uee,d0,_0,y0,f0,E0,_ee,O0,Zo,fee,Ni=Ne(()=>{Tc=require("worker_threads"),h0=L(dt());Pe();B_=L(W()),H_=require("path"),WA=require("fs/promises"),Sp=L(cn()),x_=L(se()),jA=L(M());qr();(0,x_.initSync)();Tp=new Map,p0=(0,x_.get)(jA.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)>-1;a(oee,"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(aee,"sendAnalytics");a(cee,"aggregation");c0=0,l0=0,R0=a(()=>new Promise(setImmediate),"rest");a(u0,"cleanup");lee=36e5,uee=31536e6;a(zA,"getRawAnalyticsTable");a(A0,"getAnalyticsTable");(0,h0.setChildListenerByType)(S0,b0);a(dee,"startScheduledTasks");f0=0,E0=new Map,_ee=!1;a(b0,"recordAnalytics");fee=1e6;a(Eee,"logAnalytics")});var ey=N((jOe,H0)=>{"use strict";var{decode:hee}=require("msgpackr"),{isMainThread:KOe,parentPort:YOe,threadId:WOe}=require("worker_threads"),Ap=mr(),Xl=Ct(),XA=M(),jr=W(),JA=se(),pee=M(),{onMessageByType:mee}=dt(),C0=to(),{recordAction:N0,recordActionBinary:See}=(Ni(),oe(F_)),{publishToStream:Tee}=Ap,{ConsumerEvents:I0}=require("nats"),gee=Vr(),{promisify:Ree}=require("util"),D0=Ree(setTimeout),yp=1e4,bp,Rp,Aee,yee,P0,G_=new Map,Zl=new Map;H0.exports={initialize:L0,ingestConsumer:ZA,setSubscription:bee,setIgnoreOrigin:Iee,getDatabaseSubscriptions:Nee,updateConsumer:M0};async function L0(){mee(XA.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 Ap.getNATSReferences();bp=e,Rp=e.info.server_name,Aee=t,yee=r}a(L0,"initialize");async function M0(e){if(e.status==="start"){let{js:t,jsm:r}=await U0(e.node_domain_name);ZA(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=G_.get(e.stream_name+e.node_domain_name);t&&(jr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),G_.set(e.stream_name+e.node_domain_name,"close")),Zl.get(e.node_domain_name)==="failed"&&Zl.set(e.node_domain_name,"close")}}a(M0,"updateConsumer");var Op=new Map;function bee(e,t,r){let n=Op.get(e);n||Op.set(e,n=new Map),n.set(t,r),P0||L0().then(Oee)}a(bee,"setSubscription");async function Oee(){let e=await gee.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+Xl.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions||[])if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await U0(r),!n))break;let{schema:o,table:c}=i,l=C0.createNatsTableStreamName(o,c);ZA(l,n,s,r)}}}a(Oee,"accessConsumers");async function U0(e){let t,r,n=1;for(;!r;)try{t=await bp.jetstream({domain:e}),r=await bp.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(Zl.get(e)==="close")break;Zl.set(e,"failed"),n%10===1&&jr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<yp?n++*100:yp;await D0(i)}return{js:t,jsm:r}}a(U0,"connectToRemoteJS");function Nee(){return Op}a(Nee,"getDatabaseSubscriptions");var v0;function Iee(e){v0=e}a(Iee,"setIgnoreOrigin");var B0=100,w0=new Array(B0),gp=0;async function ZA(e,t,r,n){let{connection:s}=await Ap.getNATSReferences();bp=s,Rp=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,Rp),jr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(Zl.get(n)==="close")break;o%10===1&&jr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",u.message),u.code==="404"&&(jr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await Ap.createConsumer(r,e,Rp,new Date(Date.now()).toISOString()));let d=o++*100<yp?o++*100:yp;await D0(d)}let c=!1,l;for(;!c;){if(G_.get(e+n)==="close"||Zl.get(n)==="close"){G_.delete(e+n),c=!0;continue}l=await i.consume({max_messages:JA.get(XA.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]=wee(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(ZA,"ingestConsumer");async function wee(e){let t=hee(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=JA.get(XA.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(Xl.MSG_HEADERS.TRANSACTED_NODES)&&r.values(Xl.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(Xl.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!v0),See(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(Xl.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:u,records:d,hash_values:_,__origin:E,expiresAt:f}=t;jr.trace("processing message:",o,c,u,(d?"records: "+d.map(B=>B?.id):"")+(_?"ids: "+_:""),"with sequence:",e.seq),jr.trace(`messageProcessor nats msg id: ${e.headers.get(Xl.MSG_HEADERS.NATS_MSG_ID)}`);let h;d||(d=_);let T=new Promise(B=>h=B),{timestamp:m,user:g,node_name:S}=E||{},b=Op.get(c)?.get(u);if(!b)throw new Error(`Missing table for replication message: ${u}`);if(o==="define_schema")t.type=o,t.onCommit=h,b.send(t);else if(d.length===1&&!l)b.send({type:QA(o),value:d[0],id:_?.[0],expiresAt:f,timestamp:m,table:u,onCommit:h,user:g,nodeName:S});else{let B=d.map((H,X)=>({type:QA(o),value:H,expiresAt:f,id:_?.[X],table:u}));for(;l;)B.push({type:QA(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;b.send({type:"transaction",writes:B,table:u,timestamp:m,onCommit:h,user:g,nodeName:S})}JA.get(pee.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&Tee(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(wee,"messageProcessor");function QA(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(QA,"convertOperation")});var mr=N((tNe,eB)=>{"use strict";var br=se();br.initSync();var Cee=require("fs-extra"),Dee=require("semver"),V_=require("path"),{monotonicFactory:Pee}=require("ulidx"),k0=Pee(),Lee=require("util"),F0=require("child_process"),Mee=Lee.promisify(F0.exec),Uee=F0.spawn,Dr=Ct(),Je=M(),Np=te(),js=W(),Ip=to(),vee=pp(),q_=wt(),{broadcast:Bee,onMessageByType:Hee,getWorkerIndex:xee}=dt(),{isMainThread:G0}=require("worker_threads"),{Encoder:kee,decode:sy}=require("msgpackr"),q0=new kee,{isEmpty:yc}=Np,$0=xn(),QOe=48*36e11;G0&&Hee(Je.ITC_EVENT_TYPES.RESTART,()=>{zr=void 0,Ac=void 0});var{connect:Fee,StorageType:Gee,RetentionPolicy:qee,AckPolicy:iy,DeliverPolicy:oy,DiscardPolicy:$ee,NatsConnection:JOe,JetStreamManager:XOe,JetStreamClient:ZOe,StringCodec:eNe,JSONCodec:Vee,createInbox:ay,headers:Kee,ErrorCode:x0}=require("nats"),{PACKAGE_ROOT:Yee}=M(),Wee=Jl(),{recordAction:jee}=(Ni(),oe(F_)),V0=Vee(),zee="clustering",Qee=Wee.engines[Dr.NATS_SERVER_NAME],Jee=V_.join(Yee,"dependencies"),ny=V_.join(Jee,`${process.platform}-${process.arch}`,Dr.NATS_BINARY_NAME),ty,ry,$_,gc,Rc;eB.exports={runCommand:K0,checkNATSServerInstalled:Xee,createConnection:cy,getConnection:K_,getJetStreamManager:Y_,getJetStream:W0,getNATSReferences:Ii,getServerList:ete,createLocalStream:ly,listStreams:j0,deleteLocalStream:tte,getServerConfig:eu,listRemoteStreams:rte,viewStream:nte,viewStreamIterator:ste,publishToStream:ite,request:cte,reloadNATS:uy,reloadNATSHub:lte,reloadNATSLeaf:ute,extractServerName:ate,requestErrorHandler:dte,createLocalTableStream:X0,createTableStreams:Ete,purgeTableStream:Z0,purgeSchemaTableStreams:hte,getStreamInfo:pte,updateLocalStreams:Ste,closeConnection:Zee,getJsmServerName:wp,addNatsMsgHeader:z0,clearClientCache:Y0,updateRemoteConsumer:_te,createConsumer:Q0,updateConsumerIterator:fte};async function K0(e,t=void 0){let{stdout:r,stderr:n}=await Mee(e,{cwd:t});if(n)throw new Error(n.replace(`
|
|
13
13
|
`,""));return r.replace(`
|
|
14
|
-
`,"")}a(V0,"runCommand");async function Jee(){try{await wee.access(ny)}catch{return!1}let e=await V0(`${ny} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return Cee.eq(t,zee)}a(Jee,"checkNATSServerInstalled");async function cy(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await q0.getClusterUser();if(yc(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}js.trace("create nats connection called");let i=await kee({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:br.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:br.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:br.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),js.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&js.error("Error with Nats client connection, connection closed",o),i===zr&&K0()}),i}a(cy,"createConnection");function K0(){zr=void 0,gc=void 0,Rc=void 0,Ac=void 0}a(K0,"clearClientCache");async function Xee(){zr&&(await zr.drain(),zr=void 0,gc=void 0,Rc=void 0,Ac=void 0)}a(Xee,"closeConnection");var zr,Ac;async function V_(){return Ac||(Ac=cy(br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),zr=await Ac),zr||Ac}a(V_,"getConnection");async function K_(){if(gc)return gc;yc(zr)&&await V_();let{domain:e}=Jl(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(yc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return gc=await zr.jetstreamManager({domain:e,timeout:6e4}),gc}a(K_,"getJetStreamManager");async function Y0(){if(Rc)return Rc;yc(zr)&&await V_();let{domain:e}=Jl(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(yc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Rc=zr.jetstream({domain:e,timeout:6e4}),Rc}a(Y0,"getJetStream");async function Ii(){let e=zr||await V_(),t=gc||await K_(),r=Rc||await Y0();return{connection:e,jsm:t,js:r}}a(Ii,"getNATSReferences");async function Zee(e){let t=br.get(Je.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await q0.getClusterUser(),s=await cy(t,r,n),i=ay(),o=s.subscribe(i),c=[],l,u=(async()=>{for await(let d of o){let _=$0.decode(d.data);_.response_time=Date.now()-l,c.push(_)}})();return l=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await Np.async_set_timeout(e),await o.drain(),await s.close(),await u,c}a(Zee,"getServerList");async function ly(e,t){let{jsm:r}=await Ii(),n=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:Fee.File,retention:Gee.Limits,subjects:t,discard:qee.Old,max_msgs:s,max_bytes:i,max_age:n})}a(ly,"createLocalStream");async function W0(){let{jsm:e}=await Ii(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(W0,"listStreams");async function ete(e){let{jsm:t}=await Ii();await t.streams.delete(e)}a(ete,"deleteLocalStream");async function tte(e){let{connection:t}=await Ii(),r=[],n=ay(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push($0.decode(o.data))})();return await t.publish(`$JS.${e}.API.STREAM.LIST`,void 0,{reply:n}),await t.flush(),await s.drain(),await i,r}a(tte,"listRemoteStreams");async function rte(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ii(),i=x0(),o={durable_name:i,ack_policy:iy.Explicit};t&&(o.deliver_policy=oy.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let u=[];for await(let d of l){let _=sy(d.data),E={nats_timestamp:d.info.timestampNanos,nats_sequence:d.info.streamSequence,entry:_};if(d.headers&&(E.origin=d.headers.get(Dr.MSG_HEADERS.ORIGIN)),u.push(E),d.ack(),d.info.pending===0)break}return await c.delete(),u}a(rte,"viewStream");async function*nte(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ii(),i=x0(),o={durable_name:i,ack_policy:iy.Explicit};t&&(o.deliver_policy=oy.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let u of l){let d=sy(u.data);d[0]||(d=[d]);for(let _ of d){let E={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:_};u.headers&&(E.origin=u.headers.get(Dr.MSG_HEADERS.ORIGIN)),yield E}if(u.ack(),u.info.pending===0)break}await c.delete()}a(nte,"viewStreamIterator");async function ste(e,t,r,n){js.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=j0(n,r);let{js:s}=await Ii(),i=await wp(),o=`${e}.${i}`,c=n instanceof Uint8Array?n:G0.encode(n);try{js.trace(`publishToStream publishing to subject: ${o}`),Wee(c.length,"bytes-sent",e,n.operation,"replication"),await s.publish(o,c,{headers:r})}catch(l){if(l.code&&l.code.toString()==="503")return Q0(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){js.trace(`publishToStream creating stream: ${t}`);let d=o.split(".");d[2]="*",await ly(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(ste,"publishToStream");function j0(e,t){t===void 0&&(t=Vee());let r=br.get(Je.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Dr.MSG_HEADERS.ORIGIN)&&r&&t.append(Dr.MSG_HEADERS.ORIGIN,r),t}a(j0,"addNatsMsgHeader");function Jl(e){e=e.toLowerCase();let t=$_.join(br.get(Je.CONFIG_PARAMS.ROOTPATH),jee);if(e===Je.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return yc(ry)&&(ry={port:G_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:G_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Dr.SERVER_SUFFIX.HUB,config_file:Dr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:$_.join(t,Dr.PID_FILES.HUB),hdb_nats_path:t}),ry;if(e===Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return yc(ty)&&(ty={port:G_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:G_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Dr.SERVER_SUFFIX.LEAF,config_file:Dr.NATS_CONFIG_FILES.LEAF_SERVER,domain:G_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Dr.SERVER_SUFFIX.LEAF,pid_file_path:$_.join(t,Dr.PID_FILES.LEAF),hdb_nats_path:t}),ty;js.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(Jl,"getServerConfig");async function z0(e,t,r,n){try{await e.consumers.add(t,{ack_policy:iy.Explicit,durable_name:r,deliver_policy:oy.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(z0,"createConsumer");async function ite(e,t,r){await e.consumers.delete(t,r)}a(ite,"removeConsumer");function ote(e){return e.split(".")[1]}a(ote,"extractServerName");async function ate(e,t,r=6e4,n=ay()){if(!Np.isObject(t))throw new Error("data param must be an object");let s=G0.encode(t),{connection:i}=await Ii(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return sy(c.data)}a(ate,"request");function uy(e){return new Promise(async(t,r)=>{let n=Mee(ny,["--signal",`reload=${e}`],{cwd:__dirname}),s,i;n.on("error",o=>{r(o)}),n.stdout.on("data",o=>{i+=o.toString()}),n.stderr.on("data",o=>{s+=o.toString()}),n.stderr.on("close",o=>{s&&r(s),t(i)})})}a(uy,"reloadNATS");async function cte(){let{pid_file_path:e}=Jl(Je.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await uy(e)}a(cte,"reloadNATSHub");async function lte(){let{pid_file_path:e}=Jl(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await uy(e)}a(lte,"reloadNATSLeaf");function ute(e,t,r){let n;switch(e.code){case H0.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case H0.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(ute,"requestErrorHandler");async function dte(e,t){let r=t+Dr.SERVER_SUFFIX.LEAF,{connection:n}=await Ii(),{jsm:s}=await Tte(r),{schema:i,table:o}=e,c=Ip.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await Q0(async()=>{if(e.subscribe===!0)await z0(s,c,n.info.server_name,l);else try{await ite(s,c,n.info.server_name)}catch(u){js.trace(u)}})}a(dte,"updateRemoteConsumer");async function _te(e,t,r,n){let s=Ip.createNatsTableStreamName(e,t),i=r+Dr.SERVER_SUFFIX.LEAF,o={type:Je.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!F0&&Hee()<br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=ey();await c(o)}await vee(o),n==="stop"&&await Np.async_set_timeout(1e3)}a(_te,"updateConsumerIterator");function Q0(e){return Uee.writeTransaction(Je.SYSTEM_SCHEMA_NAME,Je.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(Q0,"exclusiveLock");async function J0(e,t){let r=Ip.createNatsTableStreamName(e,t),n=await wp(),s=pte(e,t,n);await ly(r,[s])}a(J0,"createLocalTableStream");async function fte(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await J0(n,s)}}a(fte,"createTableStreams");async function X0(e,t,r=void 0){if(br.get(Je.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=Ip.createNatsTableStreamName(e,t),{domain:s}=Jl(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await V_()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")js.warn(n);else throw n}}a(X0,"purgeTableStream");async function Ete(e,t){if(br.get(Je.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await X0(e,t[r])}a(Ete,"purgeSchemaTableStreams");async function hte(e){return(await K_()).streams.info(e)}a(hte,"getStreamInfo");function pte(e,t,r){return`${Dr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(pte,"createSubjectName");async function wp(){if(q_)return q_;if(q_=(await K_())?.nc?.info?.server_name,q_===void 0)throw new Error("Unable to get jetstream manager server name");return q_}a(wp,"getJsmServerName");async function mte(){let e=await K_(),t=await wp(),r=await W0();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=Ste(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let u=i.split(".");u[u.length-1]=t;let d=u.join(".");js.trace(`Updating stream subject name from: ${i} to: ${d}`),s.subjects[0]=d,await e.streams.update(s.name,s)}}a(mte,"updateLocalStreams");function Ste(e){let{config:t}=e,r=!1,n=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}a(Ste,"updateStreamLimits");async function Tte(e){let t,r;try{t=await zr.jetstream({domain:e}),r=await zr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw js.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(Tte,"connectToRemoteJS")});var bc=N(Dp=>{var Cp=W();for(let e of["trace","debug","info","warn","error","fatal","notify"])Cp.logsAtLevel(e)&&(Dp[e]=Cp[e]);Dp.loggerWithTag=e=>Cp.loggerWithTag(e,!0);Dp.setLogLevel=Cp.setLogLevel});function dy(e){let t=e.get(Pp),r=t?(0,Xl.unpack)(t):null;r||(r={remoteNameToId:{}});let n=ot(),s=!1;r.nodeName=ot();let i=r.remoteNameToId;if(i[n]!==0){let o=0,c;for(let l in i){let u=i[l];u===0?c=l:u>o&&(o=u)}if(c){o++,i[c]=o;let l=[Symbol.for("seq"),o];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:W_(e)??1,nodes:[]})})}i[n]=0,e.putSync(Pp,(0,Xl.pack)(r))}return r}function Y_(e){return dy(e).remoteNameToId}function tB(e,t,r){let n=dy(r),s=n.remoteNameToId,i=new Map,o=!1;for(let c in t){let l=t[c],u=s[c];if(u==null){let d=0;for(let _ in s){let E=s[_];E>d&&(d=E)}u=d+1,s[c]=u,o=!0}i.set(l,u)}return o&&r.putSync(Pp,(0,Xl.pack)(n)),i}function Lp(e,t){let r=dy(t),n=r.remoteNameToId,s=n[e];if(s==null){let i=0;for(let o in n){let c=n[o];c>i&&(i=c)}s=i+1,n[e]=s,t.putSync(Pp,(0,Xl.pack)(r))}return eB.info?.("The remote node name map",e,n,s),s}var eB,Xl,Pp,_y=Oe(()=>{eB=L(bc());us();Xl=require("msgpackr"),Pp=Symbol.for("remote-ids");a(dy,"getIdMappingRecord");a(Y_,"exportIdMapping");a(tB,"remoteToLocalNodeId");a(Lp,"getIdOfRemoteNode")});var ta,fy=Oe(()=>{ta=class{constructor(t){this.error=t}static{a(this,"ErrorResource")}isError=!0;allowRead(){throw this.error}allowUpdate(){throw this.error}allowCreate(){throw this.error}allowDelete(){throw this.error}getId(){throw this.error}getContext(){throw this.error}get(){throw this.error}post(){throw this.error}put(){throw this.error}delete(){throw this.error}connect(){throw this.error}getResource(){return this}publish(){throw this.error}subscribe(){throw this.error}}});var sB={};je(sB,{Resources:()=>Mp,keyArrayToString:()=>Zl,resetResources:()=>gte,resources:()=>wi});function gte(){return wi=new Mp}function Zl(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var rB,nB,Mp,wi,eu=Oe(()=>{mc();fy();rB=L(W()),nB=L(_e()),Mp=class extends Map{static{a(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,exportTypes:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s){let c=new nB.ServerError(`Conflicting paths for ${t}`);rB.default.error(c),i.Resource=new ta(c)}super.set(t,i);for(let[c,l]of this){let u=2;for(;(u=c.indexOf("/",u))>-1;){let d=this.get(c.slice(0,u));d&&(d.hasSubPaths=!0),u+=2}}}getMatch(t,r){let n=2,s;for(;(n=t.indexOf("/",n))>-1;){let c=t.slice(0,n),l=this.get(c);if(!l&&c.indexOf(".")>-1){let u=c.split(".");l=this.get(u[0])}if(l&&(!r||l.exportTypes?.[r]!==!1)){if(l.relativeURL=t.slice(n),!l.hasSubPaths)return l;s=l}n+=2}if(s)return s;let i=t.indexOf("?"),o=i>-1?t.slice(0,i):t;return s=this.get(o),!s&&o.indexOf(".")>-1&&(s=this.get(o.split(".")[0])),s&&(!r||s.exportTypes?.[r]!==!1)?s.relativeURL=i>-1?t.slice(i):"":s||(s=this.get(""),s&&(!r||s.exportTypes?.[r]!==!1)&&(t[0]!=="/"&&(t="/"+t),s.relativeURL=t)),s}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return Dt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(gte,"resetResources");a(Zl,"keyArrayToString")});function py(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=oB,Rte(e.primaryStore,e.auditStore)):(c=iB,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{aB(iB[i])})));let l=c[i]||(c[i]=[]);if(l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now()),s?.scope==="full-database")return;let u=l[o];u||(u=l[o]=new Map,u.envs=l,u.tableId=o,u.store=e.primaryStore),t=Zl(t);let d=new hy(r);d.startTime=n;let _=u.get(t);return _?_.push(d):(u.set(t,_=[d]),_.tables=u,_.key=t),d.subscriptions=_,d}function aB(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),cB(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=Ht(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,l=Zl(c),u=0;do{let d=o.get(l);if(d){for(let E of d)if(!(u>0&&!(E.includeDescendants&&!(E.onlyChildren&&u>1)))){if(E.startTime>=n){(0,Ey.info)("omitting",c,E.startTime,n);continue}try{let f;E.supportsTransactions&&E.txnInProgress!==i.version&&(f=!0,E.txnInProgress||(r?r.push(E):r=[E]),E.txnInProgress=i.version),E.listener(c,i,n,f)}catch(f){console.error(f),(0,Ey.info)(f)}}}if(l==null)break;let _=l.lastIndexOf?.("/",l.length-2);_>-1?l=l.slice(0,_):l=null,u++}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function Rte(e,t){let r=t||e,n=r.env;if(!n.hasAfterCommitListener){n.hasAfterCommitListener=!0;let s=n.path;r.on("aftercommit",({next:i,last:o,txnId:c})=>{let l=oB[s];if(!l)return;let u=a(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),l.txnTime=r.threadLocalWrites[0]||Date.now();try{aB(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function cB(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function lB(e){return e.nextTransaction||(py({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),cB(e)),e.nextTransaction}var Ey,iB,oB,hy,my=Oe(()=>{Ey=L(W());wl();eu();Ji();iB=Object.create(null),oB=Object.create(null);a(py,"addSubscription");hy=class extends Mn{static{a(this,"Subscription")}listener;subscriptions;startTime;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;if(t){let r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};a(aB,"notifyFromTransactionData");a(Rte,"listenToCommits");a(cB,"nextTransaction");a(lB,"whenNextTransaction")});var hB={};je(hB,{commits_awaiting_replication:()=>nu,getHDBNodeTable:()=>Sr,iterateRoutes:()=>z_,shouldReplicateToNode:()=>j_,subscribeToNodeUpdates:()=>su});function Sr(){return uB||(uB=Et({table:"hdb_nodes",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"ca"},{attribute:"ca_info"},{attribute:"replicates"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function su(e){Sr().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;EB.debug?.("adding node",n,"on node",ot()," on process",process.pid),server.nodes=server.nodes.filter(s=>s.name!==n),r.type==="put"&&n!==ot()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r)),(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function j_(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&Sr().primaryStore.get(ot())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function Ate(){su(e=>{ra({},(t,r)=>{let n=e.name,s=dB.get(n);if(s||dB.set(n,s=new Map),s.has(r))return;let i;for(let o in t)if(i=t[o].auditStore,i)break;if(i){let o=new Float64Array(i.getUserSharedBuffer(["replicated",r,n],new ArrayBuffer(8),{callback:a(()=>{let c=o[0],l=o.lastTime;for(let{txnTime:u,onConfirm:d}of nu.get(r)||[])u>l&&u<=c&&d();o.lastTime=c},"callback")}));o.lastTime=0,s.set(r,o)}})})}function*z_(e){for(let t of e.routes||[]){let r=t.url,n;if(typeof t=="string"?t.includes("://")?r=t:n=t:n=t.hostname??t.host,n&&!r){let s=tu.default.get(ru.CONFIG_PARAMS.REPLICATION_SECUREPORT)??(!tu.default.get(ru.CONFIG_PARAMS.REPLICATION_PORT)&&tu.default.get(ru.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||tu.default.get(ru.CONFIG_PARAMS.REPLICATION_PORT)||tu.default.get(ru.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT);let o=i?.lastIndexOf?.(":");o>0&&(i=+i.slice(o+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){_B.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{replicates:!t.subscriptions,url:r,subscription:t.subscriptions,routes:t.routes}}}var _B,fB,tu,ru,EB,uB,dB,nu,iu=Oe(()=>{Pe();us();lp();_B=require("worker_threads"),fB=L(_e()),tu=L(se()),ru=L(M()),EB=L(bc());server.nodes=[];a(Sr,"getHDBNodeTable");a(su,"subscribeToNodeUpdates");a(j_,"shouldReplicateToNode");dB=new Map;Rv((e,t,r)=>{if(r>server.nodes.length)throw new fB.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);nu||(nu=new Map,Ate());let n=nu.get(e);return n||(n=[],nu.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(Ate,"startSubscriptionToReplications");a(z_,"iterateRoutes")});var gB={};je(gB,{connectedToNode:()=>Oc,disconnectedFromNode:()=>cu,ensureNode:()=>co,requestClusterStatus:()=>TB,startOnMainThread:()=>Ty});async function Ty(e){let t=0,r=ut();for(let i of Object.getOwnPropertyNames(r)){let o=r[i];for(let c in o){let l=o[c];if(l.auditStore){Up.set(i,W_(l.auditStore));break}}}Ci.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes.search([]))i.push(o);for(let o of z_(e))try{let c=!o.subscriptions;if(c){let u=ot();Sr().primaryStore.get(u)===void 0&&await co(u,{name:u,url:e.url??na(),replicates:!0})}let l=o.trusted!==!1;if(c&&o.replicates==null&&(o.replicates=!0),i.find(u=>u.url===o.url))continue;s(o)}catch(c){console.error(c)}su(s)});let n;function s(i,o=i?.name){let c=ot()&&o===ot()||na()&&i?.url===na();if(c){let _=!!i?.replicates;if(n!==void 0&&n!==_)for(let E of Sr().search([]))E.replicates&&E.name!==o&&s(E,E.name);n=_}if(_t.trace("Setting up node replication for",i),!i){for(let[_,E]of ao){let f;for(let[h,{worker:T,nodes:m}]of E){let g=m[0];if(g&&g.name==o){f=!0;for(let[S,{worker:b}]of E)E.delete(S),_t.warn("Node was deleted, unsubscribing from node",o,S,_),b?.postMessage({type:"unsubscribe-from-node",node:o,database:S,url:_});break}}if(f){ao.get(_).iterator.remove(),ao.delete(_);return}}return}if(c)return;if(!i.url){_t.info(`Node ${i.name} is missing url`);return}let l=ao.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(_t.info(`Added node ${i.name} at ${i.url} for process ${ot()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[_,E]of ou)if(i.url===E.url){ou.delete(_);break}ou.set(i.name,i)}let u=ut();if(l||(l=new Map,ao.set(i.url,l)),l.iterator=ra(e,(_,E,f)=>{f?d(E,!0):d(E,!1)}),i.subscriptions)for(let _ of i.subscriptions){let E=_.database||_.schema;u[E]||(_t.warn(`Database ${E} not found for node ${i.name}, making a subscription anyway`),d(E,!1))}function d(_,E){_t.trace("Setting up replication for database",_,"on node",i.name);let f=l.get(_),h,T=[{replicateByDefault:E,...i}];Up.has(_)&&(T.push({replicateByDefault:E,name:ot(),start_time:Up.get(_),end_time:Date.now(),replicates:!0}),Up.delete(_));let m=j_(i,_),g=Ci.workers.filter(S=>S.name==="http");if(f?(h=f.worker,f.nodes=T):m&&(t=t%g.length,h=g[t++],l.set(_,{worker:h,nodes:T,url:i.url}),h?.on("exit",()=>{l.get(_)?.worker===h&&(l.delete(_),d(_,E))})),m)setTimeout(()=>{let S={type:"subscribe-to-node",database:_,nodes:T};h?h.postMessage(S):au(S)},yte);else{_t.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[_],Sr().primaryStore.get(ot())?.replicates),Sr().primaryStore.get(ot())?.replicates||(n=!1);let S={type:"unsubscribe-from-node",database:_,url:i.url,name:i.name};h?h.postMessage(S):Bp(S)}}a(d,"onDatabase")}a(s,"onNodeUpdate"),cu=a(function(i){try{_t.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(ou.keys()),c=o.sort(),l=c.indexOf(i.name||zs(i.url));if(l===-1){_t.warn("Disconnected node not found in node map",i.name,o);return}let u=ao.get(i.url),d=u?.get(i.database);if(!d){_t.warn("Disconnected node not found in replication map",i.database,u);return}if(d.connected=!1,i.finished)return;let _=d.nodes[0];if(!(_.replicates===!0||_.replicates?.sends||_.subscriptions?.length))return;let E=(l+1)%c.length;for(;l!==E;){let f=c[E],h=ou.get(f);u=ao.get(h.url);let T=u?.get(i.database);if(!T){E=(E+1)%c.length;continue}let{worker:m,nodes:g}=T,S=!1;for(let b of d.nodes){if(g.some(I=>I.name===b.name)){_t.info(`Disconnected node is already failing over to ${f} for ${i.database}`);continue}g.push(b),S=!0}if(!S){_t.info(`Disconnected node ${i.name} has no nodes to fail over to ${f}`);return}d.redirectingTo=T,_t.info(`Failing over ${i.database} from ${i.name} to ${f}`),m?m.postMessage({type:"subscribe-to-node",database:i.database,nodes:g}):au({database:i.database,nodes:g});return}_t.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){_t.error("Error failing over node",o)}},"disconnectedFromNode"),Oc=a(function(i){let o=ao.get(i.url),c=o?.get(i.database);if(!c){_t.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,o);return}if(c.connected=!0,c.latency=i.latency,c.catchingUpFrom=i.lastSendTime,c.redirectingTo){let{worker:l,nodes:u}=c.redirectingTo,d=u.find(_=>_.name===i.name);c.redirectingTo=null,d&&(u.splice(u.indexOf(d),1),l?l.postMessage({type:"subscribe-to-node",database:i.database,nodes:u}):au({database:i.database,nodes:u}))}},"connectedToNode"),(0,Ci.onMessageByType)("disconnected-from-node",cu),(0,Ci.onMessageByType)("connected-to-node",Oc),(0,Ci.onMessageByType)("request-cluster-status",TB)}function TB(e,t){let r=[];for(let[n,s]of ou)try{let i=ao.get(s.url);_t.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let o=[];if(i){for(let[l,{worker:u,connected:d,nodes:_,latency:E,catchingUpFrom:f}]of i)o.push({database:l,connected:d,latency:E,catching_up_from:f?new Date(f).toISOString():"up-to-date",thread_id:u?.threadId,nodes:_.map(h=>h.name)});let c=(0,Sy.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){_t.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function co(e,t){let r=Sr();e=e??zs(t.url),t.name=e;try{if(t.ca){let s=new SB.X509Certificate(t.ca);t.ca_info={issuer:s.issuer.replace(/\n/g," "),subject:s.subject.replace(/\n/g," "),subject_alt_name:s.subjectAltName,serial_number:s.serialNumber,valid_from:s.validFrom,valid_to:s.validTo}}}catch(s){_t.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(_t.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.put(t);else{t.replicates&&!pB.default.get(mB.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],o=(0,Sy.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let u of o)if((c.database??c.schema)===(u.database??u.schema)&&c.table===u.table){u.publish=c.publish,u.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...o,...i];break}_t.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Ci,vp,_t,Sy,pB,mB,SB,yte,ao,cu,Oc,ou,Up,Q_=Oe(()=>{Pe();Ci=L(dt());us();vp=require("worker_threads");iu();_t=L(W()),Sy=require("lodash"),pB=L(se()),mB=L(M()),SB=require("crypto"),yte=200,ao=new Map,ou=new Map,Up=new Map;a(Ty,"startOnMainThread");a(TB,"requestClusterStatus");vp.parentPort&&(cu=a(e=>{vp.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),Oc=a(e=>{vp.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Ci.onMessageByType)("subscribe-to-node",e=>{au(e)}),(0,Ci.onMessageByType)("unsubscribe-from-node",e=>{Bp(e)}));a(co,"ensureNode")});var Hp=N((wNe,RB)=>{"use strict";var bte=M().OPERATIONS_ENUM,gy=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=bte.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};RB.exports=gy});var yB=N((DNe,AB)=>{"use strict";var Ote={OPERATION:"operation",REFRESH:"refresh"},Ry=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},Ay=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};AB.exports={JWTTokens:Ry,TOKEN_TYPE_ENUM:Ote,JWTRSAKeys:Ay}});var lu=N((LNe,IB)=>{"use strict";var X_=require("jsonwebtoken"),yy=require("fs-extra"),by=te(),ds=M(),{handleHDBError:fn,hdb_errors:Nte}=_e(),{HTTP_STATUS_CODES:En,AUTHENTICATION_ERROR_MSGS:hn}=Nte,J_=W(),bB=Kh(),Iy=xn(),Ite=un().update,wte=Hp(),Cte=no(),{UserEventMsg:Dte}=qs(),sa=se();sa.initSync();var Oy=require("path"),{JWTTokens:Pte,JWTRSAKeys:Lte,TOKEN_TYPE_ENUM:xp}=yB(),Mte=sa.get(ds.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?sa.get(ds.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",Ute=sa.get(ds.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?sa.get(ds.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",kp="RS256",Ny;IB.exports={createTokens:vte,validateOperationToken:Hte,refreshOperationToken:Bte,validateRefreshToken:NB,getJWTRSAKeys:Z_};async function vte(e){if(by.isEmpty(e)||typeof e!="object")throw fn(new Error,hn.INVALID_AUTH_OBJECT,En.BAD_REQUEST,void 0,void 0,!0);if(by.isEmpty(e.username))throw fn(new Error,hn.USERNAME_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);if(by.isEmpty(e.password))throw fn(new Error,hn.PASSWORD_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await Iy.findAndValidateUser(e.username,e.password),!t)throw fn(new Error,hn.INVALID_CREDENTIALS,En.UNAUTHORIZED,void 0,void 0,!0)}catch(E){throw J_.error(E),fn(new Error,hn.INVALID_CREDENTIALS,En.UNAUTHORIZED,void 0,void 0,!0)}let r=await Z_(),n=!1,s=!1;t.role&&t.role.permission&&(n=t.role.permission.super_user===!0,s=t.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s},o=await OB(i,r.private_key,r.passphrase),c=await X_.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:Ute,algorithm:kp,subject:xp.REFRESH}),l=bB.hash(c),u=new wte(ds.SYSTEM_SCHEMA_NAME,ds.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:l}]),d,_;try{d=await Ite(u)}catch(E){J_.error(E),_=E}if(_!==void 0||d.skipped_hashes.length>0)throw fn(new Error,hn.REFRESH_TOKEN_SAVE_FAILED,En.INTERNAL_SERVER_ERROR);return Cte.signalUserChange(new Dte(process.pid)),new Pte(o,c)}a(vte,"createTokens");async function OB(e,t,r){return await X_.sign(e,{key:t,passphrase:r},{expiresIn:Mte,algorithm:kp,subject:xp.OPERATION})}a(OB,"signOperationToken");async function Z_(){if(Ny===void 0)try{let e=Oy.join(sa.getHdbBasePath(),ds.LICENSE_KEY_DIR_NAME,ds.JWT_ENUM.JWT_PASSPHRASE_NAME),t=Oy.join(sa.getHdbBasePath(),ds.LICENSE_KEY_DIR_NAME,ds.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=Oy.join(sa.getHdbBasePath(),ds.LICENSE_KEY_DIR_NAME,ds.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await yy.readFile(e)).toString(),s=(await yy.readFile(t)).toString(),i=(await yy.readFile(r)).toString();Ny=new Lte(i,s,n)}catch(e){throw J_.error(e),fn(new Error,hn.NO_ENCRYPTION_KEYS,En.INTERNAL_SERVER_ERROR)}return Ny}a(Z_,"getJWTRSAKeys");async function Bte(e){if(!e)throw fn(new Error,hn.INVALID_BODY,En.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw fn(new Error,hn.REFRESH_TOKEN_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);await NB(e.refresh_token);let t=await Z_(),r=await X_.decode(e.refresh_token);return{operation_token:await OB({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(Bte,"refreshOperationToken");async function Hte(e){try{let t=await Z_(),r=await X_.verify(e,t.public_key,{algorithms:kp,subject:xp.OPERATION});return await Iy.findAndValidateUser(r.username,void 0,!1)}catch(t){throw J_.warn(t),t.name&&t.name==="TokenExpiredError"?fn(new Error,hn.TOKEN_EXPIRED,En.FORBIDDEN):fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED)}}a(Hte,"validateOperationToken");async function NB(e){let t;try{let r=await Z_(),n=await X_.verify(e,r.public_key,{algorithms:kp,subject:xp.REFRESH});t=await Iy.findAndValidateUser(n.username,void 0,!1)}catch(r){throw J_.warn(r),r.name&&r.name==="TokenExpiredError"?fn(new Error,hn.TOKEN_EXPIRED,En.FORBIDDEN):fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED)}if(!bB.validate(t.refresh_token,e))throw fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED);return t}a(NB,"validateRefreshToken")});var Xs=N(XB=>{"use strict";var sr=require("path"),pn=require("fs-extra"),uu=require("node-forge"),UB=require("net"),{generateKeyPair:Cy,X509Certificate:uo,createPrivateKey:vB}=require("crypto"),xte=require("util");Cy=xte.promisify(Cy);var yt=uu.pki,Qs=require("joi"),{v4:BB}=require("uuid"),{validateBySchema:My}=Tt(),pt=W(),_s=se(),Es=M(),{CONFIG_PARAMS:du}=Es,Js=Sg(),{ClientError:ia}=_e(),Ic=require("node:tls"),{relative:HB,join:kte}=require("node:path"),{CERT_PREFERENCE_APP:UNe,CERTIFICATE_VALUES:wB}=Js,Fte=Wa(),Dy=wt(),CB=parseInt(process.version.slice(1))<20,{table:Gte,getDatabases:qte,databases:wy}=(Pe(),oe(lt)),{getJWTRSAKeys:DB}=lu();Object.assign(XB,{generateKeys:By,updateConfigCert:KB,createCsr:Qte,signCertificate:Jte,setCertTable:_u,loadCertificates:qB,reviewSelfSignedCert:xy,createTLSSelector:jB,listCertificates:QB,addCertificate:nre,removeCertificate:ire,createNatsCerts:ere,generateCertsKeys:Zte,getReplicationCert:tf,getReplicationCertAuth:zte,renewSelfSigned:tre,hostnamesFromCert:JB,getKey:ore});var{urlToNodeName:xB,getThisNodeUrl:$te,getThisNodeName:Gp,clearThisNodeName:Vte}=(us(),oe(ca)),{readFileSync:Kte,watchFile:Yte,statSync:kB}=require("node:fs"),vNe=se(),{getTicketKeys:Wte,onMessageFromWorkers:jte}=dt(),lo=W(),{isMainThread:FB}=require("worker_threads"),{TLSSocket:GB,createSecureContext:BNe}=require("node:tls"),Uy=3650,ef=["127.0.0.1","localhost","::1"],vy=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];jte(async e=>{e.type===Es.ITC_EVENT_TYPES.RESTART&&(_s.initSync(!0),await xy())});var Pr;function aa(){return Pr||(Pr=qte().system.hdb_certificate,Pr||(Pr=Gte({table:"hdb_certificate",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]}))),Pr}a(aa,"getCertTable");async function tf(){let e=jB("operations-api"),t={secureContexts:null,setSecureContext:a(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(Gp());if(!r)return;let n=new uo(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(tf,"getReplicationCert");async function zte(){aa();let e=(await tf()).options.cert,r=new uo(e).issuer.match(/CN=(.*)/)?.[1];return Pr.get(r)}a(zte,"getReplicationCertAuth");var PB,oa=new Map;function qB(){if(PB)return;PB=!0;let e=[{configKey:du.TLS},{configKey:du.OPERATIONSAPI_TLS}];aa();let t=sr.dirname(Dy.getConfigFilePath()),r;for(let{configKey:n}of e){let s=Dy.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&HB(kte(t,"keys"),o);c&&LB(o,l=>{oa.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&FB){let d;LB(u,_=>{if(wB.cert===_)return;let E=i.hostname??i.hostnames??i.host??i.hosts;E&&!Array.isArray(E)&&(E=[E]);let f=YB(u),h=new uo(f),T;try{T=ky(h)}catch(b){pt.error("error extracting common name from certificate",b);return}if(T==null){pt.error("error extracting common name from certificate");return}if(h.checkIssued(new uo(wB.cert)))return;let m=Pr.primaryStore.get(T),g=kB(u).mtimeMs,S=!m||m.is_self_signed?1:m.file_timestamp??m.__updatedtime__;if(m&&g<=S){g<S&&pt.info(`Certificate ${T} at ${u} is older (${new Date(g)}) than the certificate in the database (${S>1?new Date(S):"only self signed certificate available"})`);return}r=Pr.put({name:T,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:f,private_key_name:c,is_authority:l,hostnames:E,file_timestamp:g,details:{issuer:h.issuer.replace(/\n/g," "),subject:h.subject.replace(/\n/g," "),subject_alt_name:h.subjectAltName,serial_number:h.serialNumber,valid_from:h.validFrom,valid_to:h.validTo}})},l?"certificate authority":"certificate")}}}}}return r}a(qB,"loadCertificates");function LB(e,t,r){let n,s=a((i,o)=>{try{let c=i.mtimeMs;c&&c!==n&&(o&&FB&&pt.warn(`Reloading ${r}:`,e),n=c,t(YB(e)))}catch(c){pt.error(`Error loading ${r}:`,e,c)}},"loadFile");pn.existsSync(e)?s(kB(e)):pt.error(`${r} file not found:`,e),Yte(e,{persistent:!1},s)}a(LB,"loadAndWatch");function Py(){let e=$te();if(e==null){let t=ef[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return xB(e)}a(Py,"getHost");function Fp(){let e=Gp();if(e==null){let t=ef[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(Fp,"getCommonName");async function Qte(){let e=await tf(),t=yt.certificateFromPem(e.options.cert),r=yt.privateKeyFromPem(e.options.key);pt.info("Creating CSR with cert named:",e.name);let n=yt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:Fp()},...vy];pt.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:$B()}];return pt.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),uu.pki.certificationRequestToPem(n)}a(Qte,"createCsr");function $B(){let e=ef.includes(Fp())?ef:[...ef,Fp()];return e.includes(Py())||e.push(Py()),[{name:"basicConstraints",cA:!1,critical:!0},{name:"keyUsage",digitalSignature:!0,keyEncipherment:!0,critical:!0},{name:"extKeyUsage",serverAuth:!0,clientAuth:!0},{name:"nsCertType",client:!0,server:!0},{name:"subjectAltName",altNames:e.map(t=>UB.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a($B,"certExtensions");async function Jte(e){let t={},r=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;aa();for await(let d of Pr.search([]))if(d.is_authority&&!d.details.issuer.includes("HarperDB-Certificate-Authority")){if(oa.has(d.private_key_name)){n=oa.get(d.private_key_name),s=d;break}else if(d.private_key_name&&await pn.exists(sr.join(r,d.private_key_name))){n=pn.readFile(sr.join(r,d.private_key_name)),s=d;break}}if(!n){let d=await Ly();s=d.ca,n=d.private_key}n=yt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=yt.certificateFromPem(s.certificate);pt.info("Signing CSR with cert named",s.name);let o=yt.certificationRequestFromPem(e.csr);try{o.verify()}catch(d){return pt.error(d),new Error("Error verifying CSR: "+d.message)}let c=uu.pki.createCertificate();c.serialNumber=Math.random().toString().slice(2,10),c.validity.notBefore=new Date;let l=new Date;c.validity.notAfter=l,c.validity.notAfter.setDate(l.getDate()+Uy),pt.info("sign cert setting validity:",c.validity),pt.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),pt.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=o.getAttribute({name:"extensionRequest"}).extensions;pt.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=o.publicKey,c.sign(n,uu.md.sha256.create()),t.certificate=yt.certificateToPem(c)}else pt.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(Jte,"signCertificate");async function Xte(e,t){await _u({name:Gp(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await _u({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:yt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(Xte,"createCertificateTable");async function _u(e){let t=new uo(e.certificate);e.details={issuer:t.issuer.replace(/\n/g," "),subject:t.subject.replace(/\n/g," "),subject_alt_name:t.subjectAltName,serial_number:t.serialNumber,valid_from:t.validFrom,valid_to:t.validTo},aa(),await Pr.patch(e)}a(_u,"setCertTable");async function By(){let e=await Cy("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:yt.publicKeyFromPem(e.publicKey),private_key:yt.privateKeyFromPem(e.privateKey)}}a(By,"generateKeys");async function Hy(e,t,r){let n=yt.createCertificate();if(!t){let o=await tf();t=yt.certificateFromPem(o.options.cert).publicKey}n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+Uy);let i=[{name:"commonName",value:Fp()},...vy];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions($B()),n.sign(e,uu.md.sha256.create()),yt.certificateToPem(n)}a(Hy,"generateCertificates");async function Ly(){let e=await QB(),t;for(let r of e){if(!r.is_authority)continue;let n=await zB(r.private_key_name);if(r.private_key_name&&n&&new uo(r.certificate).checkPrivateKey(vB(n))){pt.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;pt.trace("No CA found with matching private key")}a(Ly,"getCertAuthority");async function VB(e,t,r=!0){let n=yt.createCertificate();n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+Uy);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${_s.get(du.REPLICATION_HOSTNAME)??xB(_s.get(du.REPLICATION_URL))??BB().split("-")[0]}`},...vy];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,uu.md.sha256.create());let o=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME),c=sr.join(o,Js.PRIVATEKEY_PEM_NAME);return r&&await pn.writeFile(c,yt.privateKeyToPem(e)),n}a(VB,"generateCertAuthority");async function Zte(){let{private_key:e,public_key:t}=await By(),r=await VB(e,t),n=await Hy(e,t,r);await Xte(n,r),KB()}a(Zte,"generateCertsKeys");async function ere(){let e=await Hy(yt.privateKeyFromPem(Js.CERTIFICATE_VALUES.key),void 0,yt.certificateFromPem(Js.CERTIFICATE_VALUES.cert)),t=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME),r=sr.join(t,Js.NATS_CERTIFICATE_PEM_NAME);await pn.exists(r)||await pn.writeFile(r,e);let n=sr.join(t,Js.NATS_CA_PEM_NAME);await pn.exists(n)||await pn.writeFile(n,Js.CERTIFICATE_VALUES.cert)}a(ere,"createNatsCerts");async function tre(){aa();for await(let e of Pr.search([{attribute:"is_self_signed",value:!0}]))await Pr.delete(e.name);await xy()}a(tre,"renewSelfSigned");async function xy(){Vte(),await qB(),aa();let e=await Ly();if(!e){pt.notify("A matching Certificate Authority and key was not found. A new CA will be created in advance, so it's available if needed.");let r=_s.get(du.TLS_PRIVATEKEY),n=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME),s,i=HB(n,r);try{s=yt.privateKeyFromPem(await pn.readFile(r))}catch(c){pt.warn("Unable to parse the TLS key",r,"A new key will be generated and used to create Certificate Authority",c),{private_key:s}=await By(),await pn.exists(sr.join(n,Js.PRIVATEKEY_PEM_NAME))&&(i=`privateKey${BB().split("-")[0]}.pem`),await pn.writeFile(sr.join(n,i),yt.privateKeyToPem(s))}let o=await VB(s,yt.setRsaPublicKey(s.n,s.e),!1);await _u({name:o.subject.getField("CN").value,uses:["https","wss"],certificate:yt.certificateToPem(o),private_key_name:i,is_authority:!0,is_self_signed:!0})}if(!await tf()){let r=Gp();pt.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await Ly();let n=yt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await Hy(yt.privateKeyFromPem(e.private_key),s,n);await _u({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(xy,"reviewSelfSignedCert");function KB(){let e=Fte(Object.keys(Es.CONFIG_PARAM_MAP),!0),t=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME),r=sr.join(t,Js.PRIVATEKEY_PEM_NAME),n=sr.join(t,Js.NATS_CERTIFICATE_PEM_NAME),s=sr.join(t,Js.NATS_CA_PEM_NAME),i=Es.CONFIG_PARAMS,o={[i.TLS_PRIVATEKEY]:e[i.TLS_PRIVATEKEY.toLowerCase()]?e[i.TLS_PRIVATEKEY.toLowerCase()]:r};e[i.TLS_CERTIFICATE.toLowerCase()]&&(o[i.TLS_CERTIFICATE]=e[i.TLS_CERTIFICATE.toLowerCase()]),e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.TLS_CERTIFICATEAUTHORITY]=e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATE]=e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]),e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_PRIVATEKEY]=e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY]=e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]),(e[i.CLUSTERING_ENABLED.toLowerCase()]||e.clustering)&&(o[i.CLUSTERING_TLS_CERTIFICATE]=e[i.CLUSTERING_TLS_CERTIFICATE.toLowerCase()]??n,o[i.CLUSTERING_TLS_CERT_AUTH]=e[i.CLUSTERING_TLS_CERT_AUTH.toLowerCase()]??s,o[i.CLUSTERING_TLS_PRIVATEKEY]=e[i.CLUSTERING_TLS_PRIVATEKEY.toLowerCase()]??r),Dy.updateConfigValue(void 0,void 0,o,!1,!0)}a(KB,"updateConfigCert");function YB(e){return e.startsWith("-----BEGIN")?e:Kte(e,"utf8")}a(YB,"readPEM");var MB=Ic.createSecureContext;Ic.createSecureContext=function(e){if(!e.cert||!e.key)return MB(e);let t={...e};delete t.key,delete t.cert;let r=MB(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var WB=Ic.Server;Ic.Server=function(e,t){return e.ALPNCallback&&(e.ALPNProtocols=null),WB.call(this,e,t)};Ic.Server.prototype=WB.prototype;var rre=GB.prototype._init;GB.prototype._init=function(e,t){rre.call(this,e,t);let r=this;this._handle.oncertcb=function(n){let s=n.servername;r._SNICallback(s,(i,o)=>{this.sni_context=o?.context||o,this.certCbDone()})}};var Nc=new Map;function jB(e,t){let r=new Map,n,s=!1;return i.initialize=o=>i.ready?i.ready:(o&&(o.secureContexts=r,o.secureContextsListeners=[]),i.ready=new Promise((c,l)=>{async function u(){try{r.clear(),Nc.clear();let d=0;for await(let _ of wy.system.hdb_certificate.search([])){if(e!=="operations-api"&&_.uses?.includes?.("operations"))continue;let E=_.certificate,f=new uo(E);_.is_authority&&(f.asString=E,Nc.set(f.subject,E))}for await(let _ of wy.system.hdb_certificate.search([]))try{if(_.is_authority)continue;if(!(e==="operations-api")&&_.uses?.includes?.("operations")){lo.trace("Skipping cert",_.name,"for",e,o.ports||"client","because it is for operations");continue}let f=_.is_self_signed?1:2,h=await zB(_.private_key_name),T=_.certificate,m=new uo(T);if(Nc.has(m.issuer)&&(T+=`
|
|
15
|
-
`+Nc.get(m.issuer)),!h||!T)throw new Error("Missing private key or certificate for secure server");let g={ciphers:_.ciphers,ticketKeys:Wte(),availableCAs:Nc,ca:t&&Array.from(Nc.values()),cert:T,key:h,key_file:_.private_key_name,is_self_signed:_.is_self_signed};o&&(g.sessionIdContext=o.sessionIdContext);let S=Ic.createSecureContext(g);S.name=_.name,S.options=g,S.quality=f,S.certificateAuthorities=Array.from(Nc),S.certStart=T.toString().slice(0,100);let b=_.hostnames??JB(m);Array.isArray(b)||(b=[b]);let I;for(let B of b)if(B){B[0]==="*"&&(s=!0,B=B.slice(1)),B===Py()&&(f+=2),UB.isIP(B)&&(I=!0);let H=r.get(B)?.quality??0;f>H&&r.set(B,S)}else lo.error("No hostname found for certificate at",Ic.certificate);lo.trace("Adding TLS",S.name,"for",o.ports||"client","cert named",_.name,"hostnames",b,"quality",f,"best quality",d),f>d&&(i.defaultContext=n=S,d=f,o&&(o.defaultContext=S))}catch(E){lo.error("Error applying TLS for",_.name,E)}o?.secureContextsListeners.forEach(_=>_()),c(n)}catch(d){l(d)}}a(u,"updateTLS"),wy.system.hdb_certificate.subscribe({listener:u,omitCurrent:!0}),u()})),i;function i(o,c){lo.info("TLS requested for",o||"(no SNI)",this.isReplicationConnection);let l=o;for(;;){let d=r.get(l);if(d)return lo.debug("Found certificate for",o,d.certStart),d.replicationContext&&(this.isReplicationConnection||CB)&&(d=d.replicationContext),c(null,d);if(s&&l){let _=l.indexOf(".",1);_<0?l="":l=l.slice(_)}else break}o?lo.debug("No certificate found to match",o,"using the default certificate"):lo.debug("No SNI, using the default certificate",n?.name);let u=n;u?u.replicationContext&&(this.isReplicationConnection||CB)&&(u=u.replicationContext):lo.info("No default certificate found"),c(null,u)}a(i,"SNICallback")}a(jB,"createTLSSelector");async function zB(e){let t=oa.get(e);return!t&&e?await pn.readFile(sr.join(_s.get(du.ROOTPATH),Es.LICENSE_KEY_DIR_NAME,e),"utf8"):t}a(zB,"getPrivateKeyByName");async function QB(){aa();let e=[];for await(let t of Pr.search([]))e.push(t);return e}a(QB,"listCertificates");async function nre(e){let t=My(e,Qs.object({name:Qs.string().required(),certificate:Qs.string().required(),is_authority:Qs.boolean().required(),private_key:Qs.string(),hosts:Qs.array(),uses:Qs.array()}));if(t)throw new ia(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,o=new uo(n),c=!1,l=!1,u;for(let[f,h]of oa)!s&&!c&&o.checkPrivateKey(vB(h))&&(c=!0,u=f),s&&s===h&&(l=!0,u=f);if(!i&&!s&&!c)throw new ia("A suitable private key was not found for this certificate");let d;if(!r){try{d=ky(o)}catch(f){pt.error(f)}if(d==null)throw new ia("Error extracting certificate common name, please provide a name parameter")}let _=sre(r??d);s&&!c&&!l&&(await pn.writeFile(sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME,_+".pem"),s),oa.set(_,s));let E={name:r??d,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&u||i&&s)&&(E.private_key_name=u??_+".pem"),await _u(E),"Successfully added certificate: "+_}a(nre,"addCertificate");function sre(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(sre,"sanitizeName");async function ire(e){let t=My(e,Qs.object({name:Qs.string().required()}));if(t)throw new ia(t.message);let{name:r}=e;aa();let n=await Pr.get(r);if(!n)throw new ia(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await Pr.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(pt.info("Removing private key named",s),await pn.remove(sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME,s)))}return await Pr.delete(r),"Successfully removed "+r}a(ire,"removeCertificate");function ky(e){return e.subject.match(/CN=(.*)/)?.[1]}a(ky,"extractCommonName");function JB(e){return e.subjectAltName?e.subjectAltName.split(",").map(t=>{let r=t.indexOf(":");if(t=t.slice(r+1),t=t.trim(),t[0]==='"')try{t=JSON.parse(t)}catch{}return t.indexOf("=")>-1?t.match(/CN=([^,]*)/)?.[1]:t}).filter(t=>t):[ky(e)]}a(JB,"hostnamesFromCert");async function ore(e){if(e.bypass_auth!==!0)throw new ia("Unauthorized","401");let t=My(e,Qs.object({name:Qs.string().required()}));if(t)throw new ia(t.message);let{name:r}=e;if(r===".jwtPrivate")return(await DB()).private_key;if(r===".jwtPublic")return(await DB()).public_key;if(oa.get(r))return oa.get(e.name);throw new ia("Key not found")}a(ore,"getKey")});async function Ky(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=ot(),i;if(e.includes("wss://")){if(!Gy){let l=(0,fH.createTLSSelector)("operations-api"),u={secureContexts:null};await l.initialize(u),Gy=u.secureContexts}if(i=Gy.get(s),i&&fe.debug?.("Creating web socket for URL",e,"with certificate named:",i.name),!i&&n!==!1)throw new Error("Unable to find a valid certificate to use for replication to connect to "+e)}let o={};r&&(o.Authorization=r);let c={headers:o,localAddress:s?.startsWith("127.0")?s:void 0,servername:(0,hH.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,ALPNProtocols:["http/1.1","harperdb-replication"],rejectUnauthorized:n!==!1,secureContext:void 0};return i&&(c.secureContext=EH.createSecureContext({...i.options,ca:Array.from(ua)})),new dH.WebSocket(e,"harperdb-replication-v1",c)}function Yp(e,t,r){let n=t.port||t.securePort,s=Vy.pid%1e3+"-"+_H.threadId+(n?"s:"+n:"c:"+t.url?.slice(-4))+" "+Math.random().toString().slice(2,3),i=0,o=Buffer.allocUnsafeSlow(1024),c=0,l=new DataView(o.buffer,0,1024),u=t.database,d=t.databaseSubscriptions||wc,_,E,f=!1,h=t.subscription;h?.then&&h.then(ie=>h=ie);let T=t.tables||u&&ut()[u];if(!r){fe.error?.("No authorization provided"),ss(1008,"Unauthorized");return}let m=new Map,g=[],S=r.name;S&&t.connection&&(t.connection.nodeName=S);let b,I,B,H,X,Y,V=1e3,ne,Q=0,de=0,j=0,ae=0;if(t.url){let ie=a(()=>{X&&j===e._socket?.bytesRead&&ae===e._socket?.bytesWritten?e.terminate():(X=performance.now(),e.ping(),j=e._socket?.bytesRead,ae=e._socket?.bytesWritten)},"send_ping");B=setInterval(ie,lH).unref(),ie()}else Ae();function Ae(){clearTimeout(H),j=e._socket?.bytesRead,ae=e._socket?.bytesWritten,H=setTimeout(()=>{j===e._socket?.bytesRead&&ae===e._socket?.bytesWritten&&(fe.warn?.(`Timeout waiting for ping from ${S}, terminating connection and reconnecting`),e.terminate())},lH*2).unref()}a(Ae,"resetPingTimer"),u&&Va(u);let ye,Me,Gr=[],wd=[],ka,wn=[],Cd=[],Al=[],Uw=150,jE=0,vt=0,Fa,Ga,vs,Bs,zE;e.on("message",ie=>{Q=performance.now();try{let Se=ie.dataView=new Cc(ie.buffer,ie.byteOffset,ie.byteLength);if(ie[0]>127){let R=(0,ct.decode)(ie),[w,A,y]=R;switch(w){case eH:{if(A){if(S){if(S!==A){fe.error?.(s,`Node name mismatch, expecting to connect to ${S}, but peer reported name as ${A}, disconnecting`),e.send((0,ct.encode)([fu])),ss(1008,"Node name mismatch");return}}else if(S=A,t.connection?.tentativeNode){let x=t.connection.tentativeNode;x.name=S,t.connection.tentativeNode=null,co(S,x)}if(t.connection&&(t.connection.nodeName=S),fe.debug?.(s,"received node name:",S,"db:",u),!u)try{Va(u=R[2]),u==="system"&&(ye=ra(t,(x,q)=>{$a(q)&&Ir(q)}),e.on("close",()=>{ye?.remove()}))}catch(x){fe.warn?.(s,"Error setting database",x),e.send((0,ct.encode)([fu])),ss(1008,x.message);return}qa()}break}case aH:{fe.debug?.(s,"Received table definitions for",A.map(x=>x.table));for(let x of A){let q=R[2];x.database=q;let ee;$a(q)&&(q==="system"?We[q]?.[x.table]||(ee=qy(x,We[q]?.[x.table])):ee=qy(x,We[q]?.[x.table]),_||(_=ee?.auditStore),T||(T=ut()?.[q]))}break}case fu:ss();break;case sH:try{let x=r?.replicates||r?.subscribers||r?.name;server.operation(A,{user:r},!x).then(q=>{Array.isArray(q)&&(q={results:q}),q.requestId=A.requestId,e.send((0,ct.encode)([$p,q]))},q=>{e.send((0,ct.encode)([$p,{requestId:A.requestId,error:q instanceof Error?q.toString():q}]))})}catch(x){e.send((0,ct.encode)([$p,{requestId:A.requestId,error:x instanceof Error?x.toString():x}]))}break;case $p:let{resolve:D,reject:O}=m.get(A.requestId);A.error?O(new Error(A.error)):D(A),m.delete(A.requestId);break;case Fy:let v=R[3];T||(u?fe.error?.(s,"No tables found for",u):fe.error?.(s,"Database name never received"));let k=T[v];k=qy({table:v,database:u,attributes:A.attributes,schemaDefined:A.schemaDefined},k),Gr[y]={name:v,decoder:new ct.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:A.typedStructs,structures:A.structures}),getEntry(x){return k.primaryStore.getEntry(x)},rootStore:k.primaryStore.rootStore};break;case tH:zE=_?tB(S,A,_):new Map,ka=R[2],fe.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${ka}`);break;case rH:let C=y;Al[C]=A;break;case oH:let F=["replicated",u,S];E||(E=new Float64Array(_.getUserSharedBuffer(F,new ArrayBuffer(8)))),E[0]=A,fe.trace?.(s,"received and broadcasting committed update",A),E.buffer.notify();break;case iH:b=A,h.send({type:"end_txn",localTime:b,remoteNodeIds:g});break;case nH:{let x=A,q;try{let ee=R[3],G=wd[y]||(wd[y]=T[R[4]]);if(!G)return fe.warn?.("Unknown table id trying to handle record request",y);let be=G.primaryStore.getBinaryFast(Symbol.for("structures")),Ee=be.length;if(Ee!==vt){vt=Ee;let re=(0,ct.decode)(be);e.send((0,ct.encode)([Fy,{typedStructs:re.typed,structures:re.named},y,G.tableName]))}let Re=G.primaryStore.getBinaryFast(ee);if(Re){let re=G.primaryStore.decoder.decode(Re,{valueAsBuffer:!0});q=(0,ct.encode)([qp,x,{value:re.value,expiresAt:re.expiresAt,version:re.version,residencyId:re.residencyId,nodeId:re.nodeId,user:re.user}])}else q=(0,ct.encode)([qp,x])}catch(ee){q=(0,ct.encode)([qp,x,{error:ee.message}])}e.send(q);break}case qp:{let{resolve:x,reject:q,tableId:ee,key:G}=m.get(R[1]),be=R[2];if(be?.error)q(new Error(be.error));else if(be){let Ee=Gr[ee].decoder.decode(be.value);be.value=Ee,be.key=G,x(be)}else x();m.delete(R[1]);break}case ZB:{Bs=A;let x,q,ee=!1;if(h){if(u!==h.databaseName&&!h.then){fe.error?.("Subscription request for wrong database",u,h.databaseName);return}}else h=d.get(u);if(fe.debug?.(s,"received subscription request for",u,"at",Bs),!h){let ce;h=new Promise(Ye=>{fe.debug?.("Waiting for subscription to database "+u),ce=Ye}),h.ready=ce,wc.set(u,h)}if(r.name)q=Sr().subscribe(r.name),q.then(async ce=>{x=ce;for await(let Ye of x){let rt=Ye.value;if(!(rt?.replicates===!0||rt?.replicates?.receives||rt?.subscriptions?.some(Ze=>(Ze.database||Ze.schema)===u&&Ze.publish!==!1))){ee=!0,e.send((0,ct.encode)([fu])),ss(1008,`Unauthorized database subscription to ${u}`);return}}},ce=>{fe.error?.(s,"Error subscribing to HDB nodes",ce)});else if(!(r?.role?.permission?.super_user||r.replicates)){e.send((0,ct.encode)([fu])),ss(1008,`Unauthorized database subscription to ${u}`);return}if(vs&&(fe.debug?.(s,"stopping previous subscription",u),vs.emit("close")),Bs.length===0)return;let G=Bs[0],be=a(ce=>{if(ce&&(G.replicateByDefault?!G.tables.includes(ce.tableName):G.tables.includes(ce.tableName)))return{table:ce}},"tableToTableEntry"),Ee={txnTime:0},Re,re,K=1/0,Te,Be=a((ce,Ye)=>{if(K=Ye,ce.type==="end_txn"){Ee.txnTime&&(o[i]!==66&&fe.error?.("Invalid encoding of message"),di(9),di(Kp),Ka(Te=Ye),Ie()),i=c,Ee.txnTime=0;return}let rt=ce.nodeId,Ze=ce.tableId,st=re[Ze];if(!st&&(st=re[Ze]=be(h.tableById[Ze]),!st))return fe.debug?.("Not subscribed to table",Ze);let Kt=st.table,Fo=Kt.primaryStore,Yt=Fo.encoder;(ce.extendedType&Oh||!Yt.typedStructs)&&(Yt._mergeStructures(Yt.getStructures()),Yt.typedStructs&&(Yt.lastTypedStructuresLength=Yt.typedStructs.length));let QE=Re[rt];if(!(QE&&QE.startTime<Ye&&(!QE.endTime||QE.endTime>Ye)))return rf&&fe.trace?.(s,"skipping replication update",ce.recordId,"to:",S,"from:",rt,"subscribed:",Re),vw();rf&&fe.trace?.(s,"sending replication update",ce.recordId,"to:",S,"from:",rt,"subscribed:",Re);let ZT=ce.version;Ee.txnTime!==ZT&&(Ee.txnTime&&(rf&&fe.trace?.(s,"new txn time, sending queued txn",Ee.txnTime),o[i]!==66&&fe.error?.("Invalid encoding of message"),Ie()),Ee.txnTime=ZT,i=c,Ka(ZT));let Ya=ce.residencyId,eg=ji(Ya,Kt),JE;if(eg&&!eg.includes(S)){let bl=ji(ce.previousResidencyId,Kt);if(bl&&!bl.includes(S)&&(ce.type==="put"||ce.type==="patch")||Kt.getResidencyById)return vw();let Md=ce.recordId;fe.trace?.(s,"sending invalidation",Md,S,"from",rt);let ng=0;Ya&&(ng|=tc),ce.previousResidencyId&&(ng|=rc);let sg,XE=null;for(let Bw in Kt.indices){if(!XE){if(sg=ce.getValue(Fo,!0),!sg)break;XE={}}XE[Bw]=sg[Bw]}JE=Dl(ce.version,Ze,Md,null,rt,ce.user,ce.type==="put"||ce.type==="patch"?"invalidate":ce.type,Yt.encode(XE),ng,Ya,ce.previousResidencyId,ce.expiresAt)}function vw(){fe.trace?.(s,"skipping audit record",ce.recordId),Y||(Y=setTimeout(()=>{Y=null,(Te||0)+cH/2<K&&(rf&&fe.trace?.(s,"sending skipped sequence update",K),e.send((0,ct.encode)([iH,K])))},cH).unref())}a(vw,"skipAuditRecord");let tg=Yt.typedStructs,rg=Yt.structures;if((tg?.length!=st.typed_length||rg?.length!=st.structure_length)&&(st.typed_length=tg?.length,st.structure_length=rg.length,fe.debug?.(s,"send table struct",st.typed_length,st.structure_length),st.sentName||(st.sentName=!0),e.send((0,ct.encode)([Fy,{typedStructs:tg,structures:rg,attributes:Kt.attributes,schemaDefined:Kt.schemaDefined},Ze,st.table.tableName]))),Ya&&!Cd[Ya]&&(e.send((0,ct.encode)([rH,eg,Ya])),Cd[Ya]=!0),JE)di(JE.length),Ld(JE);else{let bl=ce.encoded,Md=bl[0]===66?8:0;di(bl.length-Md),Ld(bl,Md)}},"sendAuditRecord"),Ie=a(()=>{c-i>8?(e.send(o.subarray(i,c)),fe.debug?.(s,"Sent message, size:",c-i)):fe.debug?.(s,"skipping empty transaction")},"sendQueuedData");vs=new $y.EventEmitter,vs.once("close",()=>{ee=!0,x?.end()});for(let{startTime:ce}of Bs)ce<K&&(K=ce);(q||Promise.resolve()).then(async()=>{h=await h,_=h.auditStore,re=h.tableById.map(be),Re=[];for(let{name:Ye,startTime:rt,endTime:Ze}of Bs){let st=Lp(Ye,_);fe.debug?.("subscription to",Ye,"using local id",st,"starting",rt),Re[st]={startTime:rt,endTime:Ze}}Ir(u),ye||(ye=Dc(Ye=>{Ye.databaseName===u&&Ir(u)}),Me=nf(Ye=>{Ye===u&&(e.send((0,ct.encode)([fu])),ss())}),e.on("close",()=>{ye?.remove(),Me?.remove()})),e.send((0,ct.encode)([tH,Y_(h.auditStore),Bs.map(({name:Ye})=>Ye)]));let ce=!0;do{isFinite(K)||(fe.warn?.("Invalid sequence id "+K),ss(1008,"Invalid sequence id"+K));let Ye;if(ce&&!ee&&(ce=!1,!(Yy(_)<=K)&&server.nodes[0]?.name===S)){fe.info?.("Replicating all tables to",S);let Ze=K,st=Wp(_);for(let Kt in T){let Fo=T[Kt];for(let Yt of Fo.primaryStore.getRange({snapshot:!1})){if(ee)return;Yt.localTime>=K&&(fe.trace?.(s,"Copying record from",u,Kt,Yt.key,Yt.localTime),Ze=Math.max(Yt.localTime,Ze),Ye=!0,Be({recordId:Yt.key,tableId:Fo.tableId,type:"put",getValue(){return Yt.value},encoded:Fo.primaryStore.getBinary(Yt.key),version:Yt.version,residencyId:Yt.residencyId,nodeId:st},Yt.localTime))}}K=Ze}for(let{key:rt,value:Ze}of _.getRange({start:K||1,exclusiveStart:!0,snapshot:!1})){if(ee)return;de=rt;let st=Ht(Ze);Be(st,rt),e._socket.writableNeedDrain?await new Promise(Kt=>e._socket.once("drain",Kt)):await new Promise(setImmediate),vs.startTime=rt,Ye=!0}Ye&&Be({type:"end_txn"},K),de=0,await lB(_)}while(!ee)}).catch(ce=>{fe.error?.(s,"Error handling subscription to node",ce),ss(1008,"Error handling subscription to node")});break}}return}Se.position=8;let tt=!0,U,p;do{let R=Se.readInt();if(R===9&&Se.getUint8(Se.position)==Kp){Se.position++,b=p=Se.readFloat64(),fe.trace?.("received remote sequence update",b,u);break}let w=Se.position,A=Ht(ie,w,w+R),y=Gr[A.tableId];y||fe.error?.(`No table found with an id of ${A.tableId}`);let D;A.residencyId&&(D=Al[A.residencyId],fe.trace?.(s,"received residency list",D,A.type,A.recordId));try{U={table:y.name,id:A.recordId,type:A.type,nodeId:zE.get(A.nodeId),residencyList:D,timestamp:A.version,value:A.getValue(y),user:A.user,beginTxn:tt,expiresAt:A.expiresAt}}catch(O){throw O.message+="typed structures for current decoder"+JSON.stringify(y.decoder.typedStructs),O}tt=!1,rf&&fe.trace?.(s,"received replication message",A.type,"id",U.id,"version",A.version,"nodeId",U.nodeId,"value",U.value),h.send(U),Se.position=w+R}while(Se.position<ie.byteLength);jE++,pr(ie.byteLength,"bytes-received",S+"."+u+"."+U.table,"replication","ingest"),jE>Uw&&!Fa&&(Fa=!0,e.pause()),h.send({type:"end_txn",localTime:b,remoteNodeIds:g,onCommit(){if(U){let R=Date.now()-U.timestamp;pr(R,"replication-latency",S+"."+u+"."+U.table,U.type,"ingest")}jE--,Fa&&(Fa=!1,e.resume()),!I&&p&&(fe.trace?.(s,"queuing confirmation of a commit at",p),setTimeout(()=>{e.send((0,ct.encode)([oH,I])),fe.trace?.(s,"sent confirmation of a commit at",I),I=null},are)),I=p}})}catch(Se){fe.error?.(s,"Error handling incoming replication message",Se)}}),e.on("ping",Ae),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-X,Oc({name:S,database:u,url:t.url,lastSendTime:de,latency:t.connection.latency})),X=null}),e.on("close",(ie,Se)=>{clearInterval(B),clearTimeout(H),vs&&vs.emit("close"),Ga&&Ga.end();for(let[tt,{reject:U}]of m)U(new Error(`Connection closed ${Se?.toString()} ${ie}`));fe.debug?.(s,"closed",ie,Se?.toString())});function Ve(){}a(Ve,"recordRemoteNodeSequence");function ss(ie,Se){e.isFinished=!0,e.close(ie,Se)}a(ss,"close");function qa(){if(f||(f=!0,t.connection?.on("subscriptions-updated",qa)),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let ie=new Map;try{for(let U of h?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let p of U.value.nodes||[])p.lastTxnTime>(ie.get(p.id)??0)&&ie.set(p.id,p.lastTxnTime)}catch(U){if(!U.message.includes("Can not re"))throw U}let Se=t.connection?.nodeSubscriptions?.[0];g=[];let tt=t.connection?.nodeSubscriptions.map((U,p)=>{let R=[],{replicateByDefault:w}=U;if(U.subscriptions){for(let O of U.subscriptions)if(O.subscribe&&(O.schema||O.database)===u){let v=O.table;T?.[v]?.replicate!==!1&&R.push(v)}w=!1}else for(let O in T)(w?T[O].replicate===!1:T[O].replicate)&&R.push(O);let A=_&&Lp(U.name,_),y=h?.dbisDB?.get([Symbol.for("seq"),A])??1,D=Math.max(y?.seqId??1,(typeof U.start_time=="string"?new Date(U.start_time).getTime():U.start_time)??1);if(fe.debug?.("Starting time recorded in db",U.name,A,u,y?.seqId,"start time:",D),Se!==U){D>5e3&&(D-=5e3);let O=_&&Lp(Se.name,_),v=h?.dbisDB?.get([Symbol.for("seq"),O])??1;for(let k of v?.nodes||[])k.name===U.name&&(D=k.seqId,fe.debug?.("Using sequence id from proxy node",Se.name,D))}return g.push(A),ie.get(A)>D&&(D=ie.get(A),fe.debug?.("Updating start time from more recent txn recorded",Se.name,D)),{name:U.name,replicateByDefault:w,tables:R,startTime:D,endTime:U.end_time}});if(tt)if(fe.debug?.(s,"sending subscription request",tt,h?.dbisDB?.path),clearTimeout(ne),tt.length>0)e.send((0,ct.encode)([ZB,tt]));else{let U=a(()=>{let p=performance.now();ne=setTimeout(()=>{Q<=p?ss(1008,"No nodes to subscribe to"):U()},V)},"schedule_close");U()}}a(qa,"sendSubscriptionRequestUpdate");function ji(ie,Se){if(!ie)return;let tt=wn[ie];return tt||(tt=Se.getResidencyRecord(ie),wn[ie]=tt),tt}a(ji,"getResidence");function $a(ie){return!(la&&la!="*"&&!la[ie]&&!la.includes?.(ie)&&!la.some?.(Se=>Se.name===ie))}a($a,"checkDatabaseAccess");function Va(ie){if(h=h||d.get(ie),!$a(ie))throw new Error(`Access to database "${ie}" is not permitted`);h||fe.warn?.(`No database named "${ie}" was declared and registered`),_=h?.auditStore,T||(T=ut()?.[ie]);let Se=ot();if(Se===S)throw Se?new Error("Should not connect to self",Se):new Error("Node name not defined");return Dd(Se,ie),!0}a(Va,"setDatabase");function Dd(ie,Se){let tt=ut()?.[Se],U=[];for(let p in tt){let R=tt[p];U.push({table:p,schemaDefined:R.schemaDefined,attributes:R.attributes.map(w=>({name:w.name,type:w.type,isPrimaryKey:w.isPrimaryKey}))})}fe.trace?.("Sending database info for node",ie,"database name",Se),e.send((0,ct.encode)([eH,ie,Se,U]))}a(Dd,"sendNodeDBName");function Ir(ie){let Se=ut()?.[ie],tt=[];for(let U in Se){if(Bs&&!Bs.some(R=>R.replicateByDefault?!R.tables.includes(U):R.tables.includes(U)))continue;let p=Se[U];tt.push({table:U,schemaDefined:p.schemaDefined,attributes:p.attributes.map(R=>({name:R.name,type:R.type,isPrimaryKey:R.isPrimaryKey}))})}e.send((0,ct.encode)([aH,tt,ie]))}a(Ir,"sendDBSchema");let yl=1,Pd=[];return{end(){Ga&&Ga.end(),vs&&vs.emit("close")},getRecord(ie){let Se=yl++;return new Promise((tt,U)=>{let p=[nH,Se,ie.table.tableId,ie.id];Pd[ie.table.tableId]||(p.push(ie.table.tableName),Pd[ie.table.tableId]=!0),e.send((0,ct.encode)(p)),m.set(Se,{tableId:ie.table.tableId,key:ie.id,resolve(R){let{table:w,entry:A}=ie;tt(R),R&&w._recordRelocate(A,R)},reject:U})})},sendOperation(ie){let Se=yl++;return ie.requestId=Se,e.send((0,ct.encode)([sH,ie])),new Promise((tt,U)=>{m.set(Se,{resolve:tt,reject:U})})}};function di(ie){ko(5),ie<128?o[c++]=ie:ie<16384?(l.setUint16(c,ie|32768),c+=2):ie<1056964608?(l.setUint32(c,ie|3221225472),c+=4):(o[c]=255,l.setUint32(c+1,ie),c+=5)}function Ld(ie,Se=0,tt=ie.length){let U=tt-Se;ko(U),ie.copy(o,c,Se,tt),c+=U}function Ka(ie){ko(8),l.setFloat64(c,ie),c+=8}function ko(ie){if(ie+16>o.length-c){let Se=Buffer.allocUnsafeSlow(c+ie-i+65536>>10<<11);o.copy(Se,0,i,c),c=c-i,i=0,o=Se,l=new DataView(o.buffer,0,o.length)}}}function qy(e,t){let r=e.database??"data";if(r!=="data"&&!We[r]){fe.warn?.("Database not found",e.database);return}t||(t={});let n=!1,s=e.schemaDefined,i=t.attributes||[];for(let o=0;o<e.attributes?.length;o++){let c=e.attributes[o],l=i[o];(!l||l.name!==c.name||l.type!==c.type)&&(n=!0,s||(c.indexed=!0),i[o]=c)}return n?(fe.debug?.("(Re)creating",e),Et({table:e.table,database:e.database,schemaDefined:e.schemaDefined,attributes:i,...t})):t}var ct,dH,_H,fe,$y,fH,EH,Vy,hH,ZB,eH,tH,fu,rH,Fy,nH,qp,sH,$p,iH,oH,aH,pH,wc,rf,cH,are,lH,Gy,uH,Vp,mH=Oe(()=>{Pe();Ji();_y();my();us();Pl();ct=require("msgpackr"),dH=require("ws"),_H=require("worker_threads"),fe=L(bc());Q_();$y=require("events"),fH=L(Xs()),EH=L(require("node:tls"));iu();Vy=L(require("node:process")),hH=require("node:net");Ni();ZB=129,eH=140,tH=141,fu=142,rH=130,Fy=132,nH=133,qp=134,sH=136,$p=137,iH=143,oH=144,aH=145,pH=new Map,wc=new Map,rf=!0,cH=300,are=2,lH=3e4;a(Ky,"createWebSocket");uH=1e3,Vp=class extends $y.EventEmitter{constructor(r,n,s,i,o){super();this.url=r;this.subscription=n;this.databaseName=s;this.nodeName=i;this.authorization=o;this.nodeName=this.nodeName??zs(r)}static{a(this,"NodeReplicationConnection")}socket;startTime;retryTime=uH;retries=0;isConnected=!0;isFinished=!1;nodeSubscriptions=[];latency=0;replicateTablesByDefault;session;sessionResolve;sessionReject;async connect(){this.session||this.resetSession();let r=[];this.socket=await Ky(this.url,{serverName:this.nodeName,authorization:this.authorization});let n;fe.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${Vy.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),fe.info?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=uH,Oc({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=Yp(this.socket,{database:this.databaseName,subscription:this.subscription,url:this.url,connection:this},{replicates:!0}),this.sessionResolve(n)}),this.socket.on("error",s=>{s.code==="SELF_SIGNED_CERT_IN_CHAIN"?(fe.warn?.(`Can not connect to ${this.url}, this server does not have a certificate authority for the certificate provided by ${this.url}`),s.isHandled=!0):s.code!=="ECONNREFUSED"&&(s.code==="UNABLE_TO_VERIFY_LEAF_SIGNATURE"?fe.error?.(`Can not connect to ${this.url}, the certificate provided by ${this.url} is not trusted, this node needs to be added to the cluster, or a certificate authority needs to be added`):fe.error?.(`Error in connection to ${this.url} due to ${s.message}`)),this.sessionReject(s)}),this.socket.on("close",(s,i)=>{if(this.isConnected&&(cu({name:this.nodeName,database:this.databaseName,url:this.url,finished:this.socket.isFinished}),this.isConnected=!1),this.socket.isFinished){this.isFinished=!0,n?.end(),this.emit("finished");return}if(++this.retries%20===1){let o=i?.toString();fe.warn?.(`${n?"Disconnected from":"Failed to connect to"} ${this.url} (db: "${this.databaseName}"), due to ${o?'"'+o+'" ':""}(code: ${s})`)}n=null,this.resetSession(),setTimeout(()=>{this.connect()},this.retryTime).unref(),this.retryTime+=this.retryTime>>3})}resetSession(){this.session=new Promise((r,n)=>{this.sessionResolve=r,this.sessionReject=n})}subscribe(r,n){this.nodeSubscriptions=r,this.replicateTablesByDefault=n,this.emit("subscriptions-updated",r)}unsubscribe(){this.socket.isFinished=!0,this.socket.close(1008,"No longer subscribed")}getRecord(r){return this.session.then(n=>n.getRecord(r))}};a(Yp,"replicateOverWS");a(qy,"ensureTableIfChanged")});var ca={};je(ca,{clearThisNodeName:()=>hre,disableReplication:()=>dre,enabled_databases:()=>la,forEachReplicatedDatabase:()=>ra,getThisNodeId:()=>Wp,getThisNodeName:()=>ot,getThisNodeUrl:()=>na,hostnameToUrl:()=>Qp,lastTimeInAuditStore:()=>W_,monitorNodeCAs:()=>OH,replicateOperation:()=>mre,replication_certificate_authorities:()=>ua,sendOperationToNode:()=>af,servers:()=>lre,setReplicator:()=>IH,start:()=>ure,startOnMainThread:()=>Ty,subscribeToNode:()=>au,unsubscribeFromNode:()=>Bp,urlToNodeName:()=>zs});function ure(e){if(e.port||(e.port=hs.default.get(Pc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=hs.default.get(Pc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),!ot())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let n of z_(e))t.set(zs(n.url),n);_re(e),e={mtls:!0,isOperationsServer:!0,maxPayload:10*1024*1024*1024,...e};let r=it.ws(async(n,s,i,o)=>{if(s.headers.get("sec-websocket-protocol")!=="harperdb-replication-v1")return o(n,s,i);await i,n._socket.unref(),Yp(n,e,s?.user),n.on("error",c=>{c.code!=="ECONNREFUSED"&&Tr.error("Error in connection to "+this.url,c.message)})},e);e.runFirst=!0,it.http((n,s)=>{if(n.isWebSocket&&n.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){!n.authorized&&n._nodeRequest.socket.authorizationError&&Tr.error(`Incoming client connection from ${n.ip} did not have valid certificate, you may need turn on enableRootCAs in the config if you are using a publicly signed certificate, or add the CA to the server's trusted CAs`,n._nodeRequest.socket.authorizationError);let i=Sr().primaryStore;if(n.authorized&&n.peerCertificate.subject){let o=n.peerCertificate.subject,c=o&&(i.get(o.CN)||t.get(o.CN));c?n.user=c:Tr.warn(`No node found for certificate common name ${o.CN}, available nodes are ${Array.from(i.getRange({}).filter(({value:l})=>l).map(({key:l})=>l)).join(", ")} and routes ${Array.from(t.keys()).join(", ")}, connection will require credentials.`)}else{let o=i.get(n.ip)||t.get(n.ip);o?n.user=o:Tr.warn(`No node found for IP address ${n.ip}, available nodes are ${Array.from(new Set([...i.getKeys(),...t.keys()])).join(", ")}, connection will require credentials.`)}}return s(n)},e);for(let n of r)if(n.secureContexts){let s=a(()=>{let i=new Set(n.secureContexts.values());n.defaultContext&&i.add(n.defaultContext);for(let o of i)try{let c=Array.from(ua);o.options.availableCAs&&c.push(...o.options.availableCAs.values());let l={...o.options,ca:c};o.replicationContext=of.createSecureContext(l)}catch(c){Tr.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),OH(s)}}function OH(e){let t=0;su(r=>{if(r?.ca){if(ua.add(r.ca),ua.size!==t)t=ua.size,e?.();else if(hs.default.get(Pc.CONFIG_PARAMS.REPLICATION_ENABLEROOTCAS)!==!1)for(let n of of.rootCertificates)ua.add(n)}})}function dre(e=!0){bH=e}function _re(e){bH||(ut(),la=e.databases,ra(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||wc;for(let[s,i]of sf){let o=i.get(r);o&&(o.subscribe([],!1),i.delete(r))}n.delete(r);return}for(let n in t){let s=t[n];IH(r,s,e),pH.get(s)?.forEach(i=>i(s))}}))}function IH(e,t,r){if(!t)return console.error(`Attempt to replicate non-existent table ${t.name} from database ${e}`);if(t.replicate===!1||t.sources?.some(s=>s.isReplicator))return;let n;t.sourcedFrom(class NH extends Lr{static{a(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||wc,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(Tr.trace("Setting up replicator subscription to database",e),!o?.auditStore)return this.subscription=o=new Mn,i.set(e,o),o.tableById=c,o.auditStore=t.auditStore,o.dbisDB=t.dbisDB,o.databaseName=e,l&&l(o),o;this.subscription=o}static subscribeOnThisThread(i,o){return!0}static async load(i){if(i){let o=i.residencyId,c=i.residency||t.dbisDB.get([Symbol.for("residency_by_id"),o]);if(c){let l,u=new Set;do{let d;for(let E of c){let f=fre(E,NH.subscription,e);f?.isConnected&&!u.has(f)&&(!d||f.latency<d.latency)&&(d=f)}if(!d)throw l||new AH.ServerError("No connection to any other nodes are available",502);let _={requestId:cre++,table:t,entry:i,id:i.key};u.add(d);try{return await d.getRecord(_)}catch(E){if(d.isConnected)throw E;Tr.warn("Error in load from node",zp,E),l||(l=E)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function wH(e,t,r,n,s){let i=sf.get(e);i||sf.set(e,i=new Map);let o=i.get(r);if(o)return o;if(t)return i.set(r,o=new Vp(e,t,r,n,s)),o.connect(),o.once("finished",()=>i.delete(r)),o}function fre(e,t,r){let n=SH.get(e)?.get(r);if(n)return n;let s=Sr().primaryStore.get(e);return s?.url&&(n=wH(s.url,t,r,e,s.authorization),SH.set(e,sf.get(s.url))),n}async function af(e,t,r){r||(r={}),r.serverName=e.name;let n=await Ky(e.url,r),s=Yp(n,{},{});return new Promise((i,o)=>{n.on("open",()=>{i(s.sendOperation(t))}),n.on("error",c=>{o(c)}),n.on("close",c=>{Tr.info("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function au(e){try{yH.isMainThread&&Tr.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=wc.get(e.database);if(!t){let n;t=new Promise(s=>{Tr.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,wc.set(e.database,t)}let r=wH(e.nodes[0].url,t,e.database,e.nodes[0].name,e.nodes[0].authorization);e.nodes[0].name===void 0?r.tentativeNode=e.nodes[0]:r.nodeName=e.nodes[0].name,r.subscribe(e.nodes.filter(n=>j_(n,e.database)),e.replicateByDefault)}catch(t){Tr.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function Bp({name:e,url:t,database:r}){Tr.trace("Unsubscribing from node",e,t,r,"nodes",Array.from(Sr().primaryStore.getRange({})));let n=sf.get(t);if(n){let s=n.get(r);s&&(s.unsubscribe(),n.delete(r))}}function Ere(){if(Wy!==void 0)return Wy;let e=hs.default.get(Pc.CONFIG_PARAMS.OPERATIONSAPI_TLS_CERTIFICATE)||hs.default.get(Pc.CONFIG_PARAMS.TLS_CERTIFICATE);if(e)return Wy=new gH.X509Certificate((0,RH.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function ot(){return zp||(zp=hs.default.get("replication_hostname")??zs(hs.default.get("replication_url"))??Ere()??TH("operationsapi_network_secureport")??TH("operationsapi_network_port")??"127.0.0.1")}function hre(){zp=void 0}function TH(e){let t=hs.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function jp(e){let t=hs.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function Wp(e){return Y_(e)?.[ot()]}function na(){let e=hs.default.get("replication_url");return e||Qp(ot())}function Qp(e){let t=jp("replication_port");if(t)return`ws://${e}:${t}`;if(t=jp("replication_secureport"),t)return`wss://${e}:${t}`;if(t=jp("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=jp("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function zs(e){if(e)return new URL(e).hostname}function ra(e,t){for(let n of Object.getOwnPropertyNames(We))r(n);return nf(n=>{r(n)}),Dc((n,s)=>{r(n.databaseName)});function r(n){let s=We[n];Tr.trace("Checking replication status of ",n,e?.databases),e?.databases===void 0||e.databases==="*"||e.databases.includes(n)||e.databases.some?.(i=>i.name===n)||!s?t(s,n,!0):pre(n)&&t(s,n,!1)}a(r,"forDatabase")}function pre(e){let t=We[e];for(let r in t)if(t[r].replicate)return!0}function W_(e){for(let t of e.getKeys({limit:1,reverse:!0}))return t}async function mre(e){let t={message:""};if(e.replicated){e.replicated=!1,Tr.trace?.("Replicating operation",e.operation,"to nodes",it.nodes.map(n=>n.name));let r=await Promise.allSettled(it.nodes.map(n=>af(n,e)));t.replicated=r.map((n,s)=>{let i=n.status==="rejected"?{status:"failed",reason:n.reason.toString()}:n.value;return i.node=it.nodes[s]?.name,i})}return t}var hs,Tr,gH,RH,Pc,of,AH,yH,bH,cre,lre,ua,la,sf,SH,Wy,zp,us=Oe(()=>{Pe();Vs();wl();mH();qr();hs=L(se()),Tr=L(W()),gH=require("crypto"),RH=require("fs");Q_();iu();Pc=L(M());_y();of=L(require("node:tls")),AH=L(_e()),yH=require("worker_threads"),cre=1,lre=[],ua=hs.default.get(Pc.CONFIG_PARAMS.REPLICATION_ENABLEROOTCAS)!==!1?new Set(of.rootCertificates):new Set;a(ure,"start");a(OH,"monitorNodeCAs");a(dre,"disableReplication");a(_re,"assignReplicationSource");a(IH,"setReplicator");sf=new Map;a(wH,"getConnection");SH=new Map;a(fre,"getConnectionByName");a(af,"sendOperationToNode");a(au,"subscribeToNode");a(Bp,"unsubscribeFromNode");a(Ere,"getCommonNameFromCert");a(ot,"getThisNodeName");a(hre,"clearThisNodeName");Object.defineProperty(it,"hostname",{get(){return ot()}});a(TH,"getHostFromListeningPort");a(jp,"getPortFromListeningPort");a(Wp,"getThisNodeId");it.replication={getThisNodeId:Wp,exportIdMapping:Y_};a(na,"getThisNodeUrl");a(Qp,"hostnameToUrl");a(zs,"urlToNodeName");a(ra,"forEachReplicatedDatabase");a(pre,"hasExplicitlyReplicatedTable");a(W_,"lastTimeInAuditStore");a(mre,"replicateOperation")});var em=N((dIe,MH)=>{"use strict";var Eu=Uh(),hu=o0(),Sre=W(),Tre=require("uuid").v4,uIe=require("clone"),Xp=no(),pu=M(),gre=require("util"),da=Bn(),{handleHDBError:mn,hdb_errors:Rre}=_e(),{HDB_ERROR_MSGS:Jp,HTTP_STATUS_CODES:Sn}=Rre,{SchemaEventMsg:Zp}=qs(),CH=mr(),{getDatabases:Are}=(Pe(),oe(lt)),{transformReq:mu}=te(),{replicateOperation:DH}=(us(),oe(ca));MH.exports={createSchema:yre,createSchemaStructure:PH,createTable:bre,createTableStructure:LH,createAttribute:Cre,dropSchema:Ore,dropTable:Nre,dropAttribute:Ire,getBackup:Dre};async function yre(e){let t=await PH(e);return Xp.signalSchemaChange(new Zp(process.pid,e.operation,e.schema)),t}a(yre,"createSchema");async function PH(e){let t=Eu.schema_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);if(mu(e),!await hu.checkSchemaExists(e.schema))throw mn(new Error,Jp.SCHEMA_EXISTS_ERR(e.schema),Sn.BAD_REQUEST,pu.LOG_LEVELS.ERROR,Jp.SCHEMA_EXISTS_ERR(e.schema),!0);return await da.createSchema(e),`database '${e.schema}' successfully created`}a(PH,"createSchemaStructure");async function bre(e){return mu(e),e.hash_attribute=e.primary_key??e.hash_attribute,await LH(e)}a(bre,"createTable");async function LH(e){let t=Eu.create_table_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);if(Eu.validateTableResidence(e.residence),!await hu.checkSchemaTableExists(e.schema,e.table))throw mn(new Error,Jp.TABLE_EXISTS_ERR(e.schema,e.table),Sn.BAD_REQUEST,pu.LOG_LEVELS.ERROR,Jp.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:Tre(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await da.createTable(n,e);else throw mn(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Sn.BAD_REQUEST);else await da.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(LH,"createTableStructure");async function Ore(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=Eu.schema_object(e),n=t??r;if(n)throw mn(n,n.message,Sn.BAD_REQUEST,void 0,void 0,!0);mu(e);let s=await hu.checkSchemaExists(e.schema);if(s)throw mn(new Error,s,Sn.NOT_FOUND,pu.LOG_LEVELS.ERROR,s,!0);let i=await hu.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);await da.dropSchema(e),Xp.signalSchemaChange(new Zp(process.pid,e.operation,e.schema)),await CH.purgeSchemaTableStreams(e.schema,o);let c=await DH(e);return c.message=`successfully deleted '${e.schema}'`,c}a(Ore,"dropSchema");async function Nre(e){let t=Eu.table_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);mu(e);let r=await hu.checkSchemaTableExists(e.schema,e.table);if(r)throw mn(new Error,r,Sn.NOT_FOUND,pu.LOG_LEVELS.ERROR,r,!0);await da.dropTable(e),await CH.purgeTableStream(e.schema,e.table);let n=await DH(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}a(Nre,"dropTable");async function Ire(e){let t=Eu.attribute_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);mu(e);let r=await hu.checkSchemaTableExists(e.schema,e.table);if(r)throw mn(new Error,r,Sn.NOT_FOUND,pu.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw mn(new Error,"You cannot drop a hash attribute",Sn.BAD_REQUEST,void 0,void 0,!0);if(pu.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw mn(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Sn.BAD_REQUEST,void 0,void 0,!0);try{return await da.dropAttribute(e),wre(e),Xp.signalSchemaChange(new Zp(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw Sre.error(`Got an error deleting attribute ${gre.inspect(e)}.`),n}}a(Ire,"dropAttribute");function wre(e){let t=Object.values(global.hdb_schema[e.schema][e.table].attributes);for(let r=0;r<t.length;r++)t[r].attribute===e.attribute&&global.hdb_schema[e.schema][e.table].attributes.splice(r,1)}a(wre,"dropAttributeFromGlobal");async function Cre(e){mu(e);let t=Are()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw mn(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Sn.BAD_REQUEST,void 0,void 0,!0);return await da.createAttribute(e),Xp.signalSchemaChange(new Zp(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(Cre,"createAttribute");function Dre(e){return da.getBackup(e)}a(Dre,"getBackup")});var vH=N((fIe,UH)=>{"use strict";var{OPERATIONS_ENUM:Pre}=M(),jy=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Pre.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};UH.exports=jy});var zy=N((pIe,FH)=>{"use strict";var Lre=Bn(),hIe=vH(),tm=te(),rm=M(),Mre=se(),{handleHDBError:BH,hdb_errors:Ure}=_e(),{HDB_ERROR_MSGS:HH,HTTP_STATUS_CODES:xH}=Ure,vre=Object.values(rm.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),kH="To use this operation audit log must be enabled in harperdb-config.yaml";FH.exports=Bre;async function Bre(e){if(tm.isEmpty(e.schema))throw new Error(HH.SCHEMA_REQUIRED_ERR);if(tm.isEmpty(e.table))throw new Error(HH.TABLE_REQUIRED_ERR);if(!Mre.get(rm.CONFIG_PARAMS.LOGGING_AUDITLOG))throw BH(new Error,kH,xH.BAD_REQUEST,rm.LOG_LEVELS.ERROR,kH,!0);let t=tm.checkSchemaTableExist(e.schema,e.table);if(t)throw BH(new Error,t,xH.NOT_FOUND,rm.LOG_LEVELS.ERROR,t,!0);if(!tm.isEmpty(e.search_type)&&vre.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await Lre.readAuditLog(e)}a(Bre,"readAuditLog")});var qH=N((SIe,GH)=>{"use strict";var{OPERATIONS_ENUM:Hre}=M(),Qy=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Hre.GET_BACKUP,this.schema=t,this.table=r}};GH.exports=Qy});var KH=N((AIe,VH)=>{"use strict";var xre=Bn(),gIe=qH(),Jy=te(),kre=M(),RIe=se(),{handleHDBError:Fre,hdb_errors:Gre}=_e(),{HDB_ERROR_MSGS:$H,HTTP_STATUS_CODES:qre}=Gre;VH.exports=$re;async function $re(e){if(Jy.isEmpty(e.schema))throw new Error($H.SCHEMA_REQUIRED_ERR);if(Jy.isEmpty(e.table))throw new Error($H.TABLE_REQUIRED_ERR);let t=Jy.checkSchemaTableExist(e.schema,e.table);if(t)throw Fre(new Error,t,qre.NOT_FOUND,kre.LOG_LEVELS.ERROR,t,!0);return await xre.getBackup(read_audit_log_object)}a($re,"getBackup")});var JH=N((bIe,QH)=>{var Su=require("validate.js"),WH=Tt(),Tu=M(),{handleHDBError:Vre,hdb_errors:Kre}=_e(),{HDB_ERROR_MSGS:Qt,HTTP_STATUS_CODES:Yre}=Kre,Xy=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Wre={STRUCTURE_USER:"structure_user"},YH=Object.values(Tu.ROLE_TYPES_ENUM),jre="attribute_permissions",zre="attribute_name",{PERMS_CRUD_ENUM:gu}=Tu,Qre=[jre,...Object.values(gu)],jH=[gu.READ,gu.INSERT,gu.UPDATE],Jre=[zre,...jH];function Xre(e){let t=Xy();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,zH(e,t)}a(Xre,"addRoleValidation");function Zre(e){let t=Xy();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,zH(e,t)}a(Zre,"alterRoleValidation");function ene(e){let t=Xy();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,WH.validateObject(e,t)}a(ene,"dropRoleValidation");var tne=["operation","role","id","permission","hdb_user","hdb_auth_header","access"];function zH(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)tne.includes(n[o])||s.push(n[o]);s.length>0&&ir(Qt.INVALID_ROLE_JSON_KEYS(s),r);let i=WH.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{ir(o,r)}),e.permission){let o=rne(e);o&&ir(o,r),YH.forEach(c=>{e.permission[c]&&!Su.isBoolean(e.permission[c])&&ir(Qt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(YH.indexOf(o)<0){if(o===Wre.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let u=0,d=l.length;u<d;u++){let _=l[u];global.hdb_schema[_]||ir(Qt.SCHEMA_NOT_FOUND(_),r)}continue}ir(Qt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){ir(Qt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let u=c.tables[l];if(!l||!global.hdb_schema[o][l]){ir(Qt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(d=>{Qre.includes(d)||ir(Qt.INVALID_PERM_KEY(d),r,o,l)}),Object.values(gu).forEach(d=>{Su.isDefined(u[d])?Su.isBoolean(u[d])||ir(Qt.TABLE_PERM_NOT_BOOLEAN(d),r,o,l):ir(Qt.TABLE_PERM_MISSING(d),r,o,l)}),u.attribute_permissions===void 0){ir(Qt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){ir(Qt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}if(u.attribute_permissions){let d=global.hdb_schema[o][l].attributes.map(({attribute:E})=>E),_={read:!1,insert:!1,update:!1};for(let E in u.attribute_permissions){let f=u.attribute_permissions[E];if(Object.keys(f).forEach(T=>{!Jre.includes(T)&&T!==gu.DELETE&&ir(Qt.INVALID_ATTR_PERM_KEY(T),r,o,l)}),!Su.isDefined(f.attribute_name)){ir(Qt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=f.attribute_name;if(!d.includes(h)){ir(Qt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}jH.forEach(T=>{Su.isDefined(f[T])?Su.isBoolean(f[T])||ir(Qt.ATTR_PERM_NOT_BOOLEAN(T,h),r,o,l):ir(Qt.ATTR_PERM_MISSING(T,h),r,o,l)}),!_.read&&f.read===!0&&(_.read=!0),!_.insert&&f.insert===!0&&(_.insert=!0),!_.update&&f.update===!0&&(_.update=!0)}if(u.read===!1&&_.read===!0||u.insert===!1&&_.insert===!0||u.update===!1&&_.update===!0){let E=`${o}.${l}`;ir(Qt.MISMATCHED_TABLE_ATTR_PERMS(E),r,o,l)}}}}return nne(r)}a(zH,"customValidate");QH.exports={addRoleValidation:Xre,alterRoleValidation:Zre,dropRoleValidation:ene};function rne(e){let{operation:t,permission:r}=e;if(t===Tu.OPERATIONS_ENUM.ADD_ROLE||t===Tu.OPERATIONS_ENUM.ALTER_ROLE){let n=r.super_user===!0,s=r.cluster_user===!0;if(Object.keys(r).length>1&&(n||s)){if(s&&n)return Qt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?Tu.ROLE_TYPES_ENUM.SUPER_USER:Tu.ROLE_TYPES_ENUM.CLUSTER_USER;return Qt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(rne,"validateNoSUPerms");function nne(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:Qt.ROLE_PERMS_ERROR,...e};return Vre(new Error,n,Yre.BAD_REQUEST)}else return null}a(nne,"generateRolePermResponse");function ir(e,t,r,n){if(!r)t.main_permissions.push(e);else{let s=n?r+"_"+n:r;t.schema_permissions[s]?t.schema_permissions[s].push(e):t.schema_permissions[s]=[e]}}a(ir,"addPermError")});var lf=N((IIe,tx)=>{"use strict";var XH=un(),ZH=Vr(),sne=uc(),eb=JH(),tb=no(),NIe=require("uuid").v4,ine=require("util"),nm=M(),one=te(),rb=ZH.searchByValue,ane=ZH.searchByHash,cne=ine.promisify(sne.delete),lne=$s(),une=Vl(),{hdb_errors:dne,handleHDBError:Lc}=_e(),{HDB_ERROR_MSGS:ex,HTTP_STATUS_CODES:cf}=dne,{UserEventMsg:nb}=qs();tx.exports={addRole:_ne,alterRole:fne,dropRole:Ene,listRoles:hne};function Zy(e){try{e.hdb_auth_header&&delete e.hdb_auth_header,e.HDB_INTERNAL_PATH&&delete e.HDB_INTERNAL_PATH,e.operation&&delete e.operation,e.hdb_user&&delete e.hdb_user}catch{}return e}a(Zy,"scrubRoleDetails");async function _ne(e){let t=eb.addRoleValidation(e);if(t)throw t;e=Zy(e);let r={schema:"system",table:"hdb_role",search_attribute:"role",search_value:e.role,hash_attribute:"id",get_attributes:["*"]},n;try{n=Array.from(await rb(r)||[])}catch(i){throw Lc(i)}if(n&&n.length>0)throw Lc(new Error,ex.ROLE_ALREADY_EXISTS(e.role),cf.CONFLICT,void 0,void 0,!0);e.id||(e.id=e.role);let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await XH.insert(s),tb.signalUserChange(new nb(process.pid)),e=Zy(e),e}a(_ne,"addRole");async function fne(e){let t=eb.alterRoleValidation(e);if(t)throw t;e=Zy(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await XH.update(r)}catch(s){throw Lc(s)}if(n&&n?.message==="updated 0 of 1 records")throw Lc(new Error,"Invalid role id",cf.BAD_REQUEST,void 0,void 0,!0);return await tb.signalUserChange(new nb(process.pid)),e}a(fne,"alterRole");async function Ene(e){let t=eb.dropRoleValidation(e);if(t)throw Lc(new Error,t,cf.BAD_REQUEST,void 0,void 0,!0);let r=new une(nm.SYSTEM_SCHEMA_NAME,nm.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await ane(r));if(n.length===0)throw Lc(new Error,ex.ROLE_NOT_FOUND,cf.NOT_FOUND,void 0,void 0,!0);let s=new lne(nm.SYSTEM_SCHEMA_NAME,nm.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await rb(s)),o=!1;if(one.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw Lc(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,cf.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await cne(c),tb.signalUserChange(new nb(process.pid)),`${n[0].role} successfully deleted`}a(Ene,"dropRole");async function hne(){return rb({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(hne,"listRoles")});var ix=N((CIe,sx)=>{"use strict";var pne=se(),_a=require("joi"),mne=Tt(),rx=require("moment"),Sne=require("fs-extra"),sb=require("path"),Tne=require("lodash"),uf=M(),{LOG_LEVELS:Mc}=M(),gne="YYYY-MM-DD hh:mm:ss",Rne=sb.resolve(__dirname,"../logs");sx.exports=function(e){return mne.validateBySchema(e,Ane)};var Ane=_a.object({from:_a.custom(nx),until:_a.custom(nx),level:_a.valid(Mc.NOTIFY,Mc.FATAL,Mc.ERROR,Mc.WARN,Mc.INFO,Mc.DEBUG,Mc.TRACE),order:_a.valid("asc","desc"),limit:_a.number().min(1),start:_a.number().min(0),log_name:_a.custom(yne)});function nx(e,t){if(rx(e,rx.ISO_8601).format(gne)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(nx,"validateDatetime");function yne(e,t){if(Tne.invert(uf.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=pne.get(uf.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?uf.LOG_NAMES.HDB:e,i=s===uf.LOG_NAMES.INSTALL?sb.join(Rne,uf.LOG_NAMES.INSTALL):sb.join(n,s);return Sne.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(yne,"validateReadLogPath")});var ob=N((PIe,ax)=>{"use strict";var sm=M(),bne=W(),One=se(),Nne=ix(),ib=require("path"),ox=require("fs-extra"),{once:Ine}=require("events"),{handleHDBError:wne,hdb_errors:Cne}=_e(),{PACKAGE_ROOT:Dne}=M(),Pne=ib.join(Dne,"logs"),Lne=1e3,Mne=200;ax.exports=Une;async function Une(e){let t=Nne(e);if(t)throw wne(t,t.message,Cne.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=One.get(sm.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?sm.LOG_NAMES.HDB:e.log_name,s=n===sm.LOG_NAMES.INSTALL?ib.join(Pne,sm.LOG_NAMES.INSTALL):ib.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,l=c?new Date(e.from):void 0,u=e.until!==void 0,d=u?new Date(e.until):void 0,_=e.limit===void 0?Lne:e.limit,E=e.order===void 0?void 0:e.order,f=e.start===void 0?0:e.start,h=f+_,T=0;E==="desc"&&!l&&!d&&(T=Math.max(ox.statSync(s).size-(h+5)*Mne,0));let m=ox.createReadStream(s,{start:T});m.on("error",H=>{bne.error(H)});let g=0,S=[],b="",I;m.on("data",H=>{let X=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;H=b+H;let Y=0,V;for(;(V=X.exec(H))&&!m.destroyed;){I&&(I.message=H.slice(Y,V.index),B(I));let[ne,Q,de]=V,j=de.split("] ["),ae=j[0],Ae=j[1];j.splice(0,2),I={timestamp:Q,thread:ae,level:Ae,tags:j,message:""},Y=V.index+ne.length}b=H.slice(Y)}),m.on("end",H=>{m.destroyed||I&&(I.message=b.trim(),B(I))}),m.resume();function B(H){let X,Y,V;switch(!0){case(i&&c&&u):X=new Date(H.timestamp),Y=new Date(l),V=new Date(d),H.level===o&&X>=Y&&X<=V&&g<f?g++:H.level===o&&X>=Y&&X<=V&&(fa(H,E,S),g++,g===h&&m.destroy());break;case(i&&c):X=new Date(H.timestamp),Y=new Date(l),H.level===o&&X>=Y&&g<f?g++:H.level===o&&X>=Y&&(fa(H,E,S),g++,g===h&&m.destroy());break;case(i&&u):X=new Date(H.timestamp),V=new Date(d),H.level===o&&X<=V&&g<f?g++:H.level===o&&X<=V&&(fa(H,E,S),g++,g===h&&m.destroy());break;case(c&&u):X=new Date(H.timestamp),Y=new Date(l),V=new Date(d),X>=Y&&X<=V&&g<f?g++:X>=Y&&X<=V&&(fa(H,E,S),g++,g===h&&m.destroy());break;case i:H.level===o&&g<f?g++:H.level===o&&(fa(H,E,S),g++,g===h&&m.destroy());break;case c:X=new Date(H.timestamp),Y=new Date(l),X>=Y&&g<f?g++:X>=Y&&g>=f&&(fa(H,E,S),g++,g===h&&m.destroy());break;case u:X=new Date(H.timestamp),V=new Date(d),X<=V&&g<f?g++:X<=V&&g>=f&&(fa(H,E,S),g++,g===h&&m.destroy());break;default:g<f?g++:(fa(H,E,S),g++,g===h&&m.destroy())}}return a(B,"onLogMessage"),await Ine(m,"close"),S}a(Une,"readLog");function fa(e,t,r){t==="desc"?vne(e,r):t==="asc"?Bne(e,r):r.push(e)}a(fa,"pushLineToResult");function vne(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)>r?n=i+1:s=i}t.splice(n,0,e)}a(vne,"insertDescending");function Bne(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)<r?n=i+1:s=i}t.splice(n,0,e)}a(Bne,"insertAscending")});var im=N((HIe,dx)=>{"use strict";var ab=require("joi"),{string:Ru,boolean:cx,date:Hne}=ab.types(),xne=Tt(),{validateSchemaExists:MIe,validateTableExists:UIe,validateSchemaName:vIe}=Ti(),kne=M(),Fne=Ct(),lx=se();lx.initSync();var BIe=Ru.invalid(lx.get(kne.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(Fne.NATS_TERM_CONSTRAINTS_RX).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >","any.invalid":"'node_name' cannot be this nodes name"}).empty(null),ux={operation:Ru.valid("add_node","update_node","set_node_replication"),node_name:Ru.optional(),subscriptions:ab.array().items({table:Ru.optional(),schema:Ru.optional(),database:Ru.optional(),subscribe:cx.required(),publish:cx.required().custom(qne),start_time:Hne.iso()})};function Gne(e){return xne.validateBySchema(e,ab.object(ux))}a(Gne,"addUpdateNodeValidator");function qne(e,t){if(t.state.ancestors[2].operation==="add_node"&&e===!1&&t.state.ancestors[0].subscribe===!1)return t.message(`'subscriptions[${t.state.path[1]}]' subscribe and/or publish must be set to true when adding a node`)}a(qne,"checkForFalsy");dx.exports={addUpdateNodeValidator:Gne,validation_schema:ux}});var fx=N((kIe,_x)=>{var $ne=Tt(),Vne={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};_x.exports=function(e){return $ne.validateObject(e,Vne)}});var cb=N((GIe,px)=>{"use strict";var Kne=fx(),Au=require("passport"),Yne=require("passport-local").Strategy,Wne=require("passport-http").BasicStrategy,jne=require("util"),zne=xn(),hx=jne.callbackify(zne.findAndValidateUser),FIe=Dn(),Qne=M(),Ex=lu();Au.use(new Yne(function(e,t,r){hx(e,t,r)}));Au.use(new Wne(function(e,t,r){hx(e,t,r)}));Au.serializeUser(function(e,t){t(null,e)});Au.deserializeUser(function(e,t){t(null,e)});function Jne(e,t,r){if(e.raw?.user!==void 0)return r(null,e.raw.user);let n,s;if(e.headers?.authorization){let o=e.headers.authorization.split(" ");n=o[0],s=o[1]}function i(o,c){return o?r(o):c?r(null,c):r("Must login")}switch(a(i,"handleResponse"),n){case"Basic":Au.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===Qne.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?Ex.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):Ex.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:Au.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(Jne,"authorize");function Xne(e,t){let r=Kne(e);if(r){t(r);return}let n={authorized:!0,messages:[]},s=e.user.role;if(!s?.permission)return t("Invalid role");let i=JSON.parse(s.permission);if(i.super_user)return t(null,n);if(!i[e.schema])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.schema} schema`),t(null,n);if(!i[e.schema].tables[e.table])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.table} table`),t(null,n);if(!i[e.schema].tables[e.table][e.operation])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.operation} on ${e.table} table`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&!e.attributes)return n.authorized=!1,n.messages.push(`${e.schema}.${e.table} has attribute permissions. Missing attributes to validate`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&e.attributes){let o=i[e.schema].tables[e.table].attribute_permissions;for(let c in o)e.attributes.indexOf(o[c].attribute_name)>-1&&!o[c][e.operation]&&(n.authorized=!1,n.messages.push(`Not authorized to ${e.operation} ${o[c].attribute_name} `))}return t(null,n)}a(Xne,"checkPermissions");px.exports={authorize:Jne,checkPermissions:Xne}});var yu=N(($Ie,mx)=>{"use strict";var lb=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},ub=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};mx.exports={Node:lb,NodeSubscription:ub}});var Tx=N((KIe,Sx)=>{"use strict";var Zne=M().OPERATIONS_ENUM,db=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Zne.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Sx.exports=db});var df=N((WIe,gx)=>{"use strict";var _b=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},fb=class{static{a(this,"RemotePayloadSubscription")}constructor(t,r,n,s,i,o,c){this.schema=t,this.table=r,this.hash_attribute=n,this.publish=s,this.subscribe=i,this.start_time=o,c!==void 0&&(this.attributes=c)}};gx.exports={RemotePayloadObject:_b,RemotePayloadSubscription:fb}});var Ax=N((zIe,Rx)=>{"use strict";var Eb=class{static{a(this,"TableSizeObject")}constructor(t,r,n=0,s=0,i=0,o=0){this.schema=t,this.table=r,this.table_size=n,this.record_count=s,this.transaction_log_size=i,this.transaction_log_record_count=o}};Rx.exports=Eb});var bx=N((twe,yx)=>{"use strict";var ese=Ax(),JIe=Bt(),XIe=ht(),tse=W(),{getSchemaPath:ZIe,getTransactionAuditStorePath:ewe}=gt(),{getDatabases:rse}=(Pe(),oe(lt));yx.exports=nse;async function nse(e){let t=new ese;try{let r=rse()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats();t.schema=e.schema,t.table=e.name,t.record_count=n.entryCount,t.transaction_log_record_count=s.entryCount}catch(r){tse.warn(`unable to stat table dbi due to ${r}`)}return t}a(nse,"lmdbGetTableSize")});var Nx=N((nwe,Ox)=>{"use strict";var hb=class{static{a(this,"SystemInformationObject")}constructor(t,r,n,s,i,o,c){this.system=t,this.time=r,this.cpu=n,this.memory=s,this.disk=i,this.network=o,this.harperdb_processes=c}};Ox.exports=hb});var Ou=N((lwe,Dx)=>{"use strict";var sse=require("fs-extra"),ise=require("path"),Qr=require("systeminformation"),Ea=W(),Ix=mr(),iwe=Ct(),bu=M(),ose=bx(),ase=ro(),{getThreadInfo:wx}=dt(),_f=se();_f.initSync();var cse=Nx(),{openEnvironment:owe}=ht(),{getSchemaPath:awe}=gt(),{database:cwe,databases:pb}=(Pe(),oe(lt)),om;Dx.exports={getHDBProcessInfo:gb,getNetworkInfo:Ab,getDiskInfo:Rb,getMemoryInfo:Tb,getCPUInfo:Sb,getTimeInfo:mb,getSystemInformation:yb,systemInformation:lse,getTableSize:bb,getMetrics:Ob};function mb(){return Qr.time()}a(mb,"getTimeInfo");async function Sb(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:u,...d}=await Qr.cpu();d.cpu_speed=await Qr.cpuCurrentSpeed();let{raw_currentload:_,raw_currentload_idle:E,raw_currentload_irq:f,raw_currentload_nice:h,raw_currentload_system:T,raw_currentload_user:m,cpus:g,...S}=await Qr.currentLoad();return S.cpus=[],g.forEach(b=>{let{raw_load:I,raw_load_idle:B,raw_load_irq:H,raw_load_nice:X,raw_load_system:Y,raw_load_user:V,...ne}=b;S.cpus.push(ne)}),d.current_load=S,d}catch(e){return Ea.error(`error in getCPUInfo: ${e}`),{}}}a(Sb,"getCPUInfo");async function Tb(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Qr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return Ea.error(`error in getMemoryInfo: ${e}`),{}}}a(Tb,"getMemoryInfo");async function gb(){let e={core:[],clustering:[]};try{let t=await Qr.processes(),r;try{r=Number.parseInt(await sse.readFile(ise.join(_f.get(bu.CONFIG_PARAMS.ROOTPATH),bu.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===bu.NODE_ERROR_CODES.ENOENT)Ea.warn("Unable to locate 'hdb.pid' file, try stopping and starting HarperDB. This could be because HarperDB is not running.");else throw n}t.list.forEach(n=>{n.pid===r?e.core.push(n):n.name==="nats-server"&&e.clustering.push(n)});for(let n of e.core)for(let s of t.list)s.pid===n.parentPid&&(s.name==="PM2"||s.command==="PM2")&&(n.parent="PM2");return e}catch(t){return Ea.error(`error in getHDBProcessInfo: ${t}`),e}}a(gb,"getHDBProcessInfo");async function Rb(){let e={};try{if(!_f.get(bu.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Qr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...u}=await Qr.fsStats();return e.read_write=u,e.size=await Qr.fsSize(),e}catch(t){return Ea.error(`error in getDiskInfo: ${t}`),e}}a(Rb,"getDiskInfo");async function Ab(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return _f.get(bu.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await Qr.networkInterfaceDefault(),e.latency=await Qr.inetChecksite("google.com"),(await Qr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:u,ieee8021xState:d,carrier_changes:_,...E}=n;e.interfaces.push(E)}),(await Qr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)})),e}catch(t){return Ea.error(`error in getNetworkInfo: ${t}`),e}}a(Ab,"getNetworkInfo");async function yb(){if(om!==void 0)return om;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Qr.osInfo();e=c;let l=await Qr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,om=e,om}catch(t){return Ea.error(`error in getSystemInformation: ${t}`),e}}a(yb,"getSystemInformation");async function bb(){let e=[],t=await ase.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await ose(n));return e}a(bb,"getTableSize");async function Ob(){let e={};for(let t in pb){let r=e[t]={},n=r.tables={};for(let s in pb[t])try{let i=pb[t][s];r.readers||(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[u,d,_]=l.trim().split(" ");return{pid:u,thread:d,txnid:_}}),i.primaryStore.auditStore&&(r.audit=i.auditStore.getStats()));let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){Ea.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(Ob,"getMetrics");async function Cx(){if(_f.get(bu.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await Ix.getNATSReferences(),t=await Ix.listStreams(),r=[];for(let n of t){let s=[],i=await e.consumers.list(n.config.name);for await(let c of i)s.push({name:c.name,created:c.created,num_ack_pending:c.num_ack_pending,num_redelivered:c.num_redelivered,num_waiting:c.num_waiting,num_pending:c.num_pending});let o={stream_name:n.config.name,database:n.config.subjects[0].split(".")[1],table:n.config.subjects[0].split(".")[2],state:n.state,consumers:s};r.push(o)}return r}}a(Cx,"getNatsStreamInfo");async function lse(e){let t=new cse;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await yb(),t.time=mb(),t.cpu=await Sb(),t.memory=await Tb(),t.disk=await Rb(),t.network=await Ab(),t.harperdb_processes=await gb(),t.table_size=await bb(),t.metrics=await Ob(),t.threads=await wx(),t.replication=await Cx(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await yb();break;case"time":t.time=mb();break;case"cpu":t.cpu=await Sb();break;case"memory":t.memory=await Tb();break;case"disk":t.disk=await Rb();break;case"network":t.network=await Ab();break;case"harperdb_processes":t.harperdb_processes=await gb();break;case"table_size":t.table_size=await bb();break;case"database_metrics":case"metrics":t.metrics=await Ob();break;case"threads":t.threads=await wx();break;case"replication":t.replication=await Cx();break;default:break}return t}a(lse,"systemInformation")});var Uc=N((dwe,Px)=>{"use strict";Px.exports={version:use,printVersion:dse};var am=jl();function use(){if(am)return am.version}a(use,"version");function dse(){am&&console.log(`HarperDB Version ${am.version}`)}a(dse,"printVersion")});var Di=N((hwe,vx)=>{"use strict";var _se=un(),Nb=te(),fse=require("util"),vc=M(),Lx=se();Lx.initSync();var Ese=cb(),Mx=Vr(),{Node:fwe,NodeSubscription:Ewe}=yu(),hse=Vl(),pse=Tx(),{RemotePayloadObject:mse,RemotePayloadSubscription:Sse}=df(),{handleHDBError:Tse,hdb_errors:gse}=_e(),{HTTP_STATUS_CODES:Rse,HDB_ERROR_MSGS:Ase}=gse,yse=$s(),bse=Ou(),Ose=Uc(),{getDatabases:Nse}=(Pe(),oe(lt)),Ise=fse.promisify(Ese.authorize),wse=Mx.searchByHash,Cse=Mx.searchByValue;vx.exports={authHeaderToUser:Dse,isEmpty:Pse,getNodeRecord:Lse,upsertNodeRecord:Mse,buildNodePayloads:Use,checkClusteringEnabled:vse,getAllNodeRecords:Bse,getSystemInfo:Hse,reverseSubscription:Ux};async function Dse(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await Ise(t,null),e}a(Dse,"authHeaderToUser");function Pse(e){return e==null}a(Pse,"isEmpty");async function Lse(e){let t=new hse(vc.SYSTEM_SCHEMA_NAME,vc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return wse(t)}a(Lse,"getNodeRecord");async function Mse(e){let t=new pse(vc.SYSTEM_SCHEMA_NAME,vc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return _se.upsert(t)}a(Mse,"upsertNodeRecord");function Ux(e){if(Nb.isEmpty(e.subscribe)||Nb.isEmpty(e.publish))throw new Error("Received invalid subscription object");let{schema:t,table:r,hash_attribute:n}=e,s={schema:t,table:r,hash_attribute:n};return e.subscribe===!0&&e.publish===!1?(s.subscribe=!1,s.publish=!0):e.subscribe===!1&&e.publish===!0?(s.subscribe=!0,s.publish=!1):(s.subscribe=e.subscribe,s.publish=e.publish),s}a(Ux,"reverseSubscription");function Use(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:u}=c,d=Nb.getTableHashAttribute(l,u),{subscribe:_,publish:E}=Ux(c),f=Nse()[l]?.[u],h=new Sse(l,u,d,E,_,c.start_time,f.schemaDefined?f.attributes:void 0);s.push(h)}return new mse(r,t,s,n)}a(Use,"buildNodePayloads");function vse(){if(!Lx.get(vc.CONFIG_PARAMS.CLUSTERING_ENABLED))throw Tse(new Error,Ase.CLUSTERING_NOT_ENABLED,Rse.BAD_REQUEST,void 0,void 0,!0)}a(vse,"checkClusteringEnabled");async function Bse(){let e=new yse(vc.SYSTEM_SCHEMA_NAME,vc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await Cse(e))}a(Bse,"getAllNodeRecords");async function Hse(){let e=await bse.getSystemInformation();return{hdb_version:Ose.version(),node_version:e.node_version,platform:e.platform}}a(Hse,"getSystemInfo")});var Ib=N((mwe,$x)=>{"use strict";var cm=mr(),Bx=te(),Hx=Ct(),xx=M(),lm=W(),kx=em(),xse=I_(),{RemotePayloadObject:kse}=df(),{handleHDBError:Fx,hdb_errors:Fse}=_e(),{HTTP_STATUS_CODES:Gx}=Fse,{NodeSubscription:qx}=yu();$x.exports=Gse;async function Gse(e,t){let r;try{r=await cm.request(`${t}.${Hx.REQUEST_SUFFIX}`,new kse(xx.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),lm.trace("Response from remote describe all request:",r)}catch(o){lm.error(`addNode received error from describe all request to remote node: ${o}`);let c=cm.requestErrorHandler(o,"add_node",t);throw Fx(new Error,c,Gx.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===Hx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw Fx(new Error,o,Gx.INTERNAL_SERVER_ERROR,"error",o)}let n=r.message,s=[],i=[];for(let o of e){let{table:c}=o,l=o.database??o.schema??"data";if(l===xx.SYSTEM_SCHEMA_NAME){await cm.createLocalTableStream(l,c);let h=new qx(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let u=Bx.doesSchemaExist(l),d=n[l]!==void 0,_=c?Bx.doesTableExist(l,c):!0,E=c?n?.[l]?.[c]!==void 0:!0;if(!u&&!d||!_&&!E){s.push(o);continue}if(!u&&d&&(lm.trace(`addNode creating schema: ${l}`),await kx.createSchema({operation:"create_schema",schema:l})),!_&&E){lm.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new xse(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await kx.createTable(h)}await cm.createLocalTableStream(l,c);let f=new qx(l,c,o.publish,o.subscribe);f.start_time=o.start_time,i.push(f)}return{added:i,skipped:s}}a(Gse,"reviewSubscriptions")});var Bc={};je(Bc,{addNodeBack:()=>Yse,removeNodeBack:()=>Wse,setNode:()=>Kse});async function Kse(e){e.node_name&&!e.hostname&&(e.hostname=e.node_name),e.verify_tls!==void 0&&(e.rejectUnauthorized=e.verify_tls);let{url:t,hostname:r}=e;t?r||(r=e.hostname=zs(t)):t=Qp(r);let n=(0,Kx.validateBySchema)(e,Vse);if(n)throw(0,_o.handleHDBError)(n,n.message,$se.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new _o.ClientError("url or hostname is required for remove_node operation");let f=r,h=Sr(),T=await h.get(f);if(!T)throw new _o.ClientError(f+" does not exist");try{await af({url:T.url},{operation:ff.OPERATIONS_ENUM.REMOVE_NODE_BACK,name:T?.subscriptions?.length>0?ot():f},void 0)}catch(m){$n.warn(`Error removing node from target node ${f}, if it is offline and we be online in the future, you may need to clean up this node manually, or retry:`,m)}return await h.delete(f),`Successfully removed '${f}' from cluster`}if(!t)throw new _o.ClientError("url required for this operation");let s=na();if(s==null)throw new _o.ClientError("replication url is missing from harperdb-config.yaml");let i,o,c;if(t?.startsWith("wss:")){i=await(0,ps.getReplicationCert)();let f=await(0,ps.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,ps.createCsr)(),$n.info("Sending CSR to target node:",t)):f&&(c=f.certificate,$n.info("Sending CA named",f.name,"to target node",t))}let l={operation:ff.OPERATIONS_ENUM.ADD_NODE_BACK,hostname:(0,Yx.get)(ff.CONFIG_PARAMS.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:o,cert_auth:c,authorization:e.retain_authorization?e.authorization:null};if(e.subscriptions?l.subscriptions=e.subscriptions.map(Vx):l.subscriptions=null,e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let f=Vx(e);l.subscribe=f.subscribe,l.publish=f.publish}e?.authorization?.username&&e?.authorization?.password&&(e.authorization="Basic "+Buffer.from(e.authorization.username+":"+e.authorization.password).toString("base64"));let u,d;try{u=await af({url:t},l,e)}catch(f){f.message=`Error returned from ${t}: `+f.message,$n.warn("Error adding node:",t,"to cluster:",f),d=f}if(o&&(!u?.certificate||!u?.certificate?.includes?.("BEGIN CERTIFICATE")))throw d?(d.message+=" and connection was required to sign certificate",d):new Error(`Unexpected certificate signature response from node ${t} response: ${JSON.stringify(u)}`);o&&($n.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,ps.setCertTable)({name:qse.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,ps.setCertTable)({name:ot(),uses:["https","operations","wss"],certificate:u.certificate,private_key_name:i?.options?.key_file,is_authority:!1,is_self_signed:!1}),c=u.signingCA);let _={url:t,ca:u?.usingCA};if(e.hostname&&(_.name=e.hostname),e.subscriptions?_.subscriptions=e.subscriptions:_.replicates=!0,e.start_time&&(_.start_time=typeof e.start_time=="string"?new Date(e.start_time).getTime():e.start_time),e.retain_authorization&&(_.authorization=e.authorization),_.replicates){let f={url:s,ca:c,replicates:!0,subscriptions:null};e.retain_authorization&&(f.authorization=e.authorization),e.start_time&&(f.start_time=e.start_time),await co(ot(),f)}await co(u?u.nodeName:_.name??zs(t),_);let E;return e.operation==="update_node"?E=`Successfully updated '${t}'`:E=`Successfully added '${t}' to cluster`,d&&(E+=" but there was an error updating target node: "+d.message),E}async function Yse(e){$n.trace("addNodeBack received request:",e);let t=await(0,ps.signCertificate)(e),r;e.csr?(r=t.signingCA,$n.info("addNodeBack received CSR from node:",e.url,"this node will use and respond with CA that was used to issue CSR")):(r=e?.cert_auth,$n.info("addNodeBack received CA from node:",e.url));let n={url:e.url,ca:r};e.subscriptions?n.subscriptions=e.subscriptions:(n.replicates=!0,n.subscriptions=null),e.start_time&&(n.start_time=e.start_time),e.authorization&&(n.authorization=e.authorization);let s=await(0,ps.getReplicationCertAuth)();if(n.replicates){let i={url:na(),ca:s?.certificate,replicates:!0,subscriptions:null};e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await co(ot(),i)}return await co(e.hostname,n),t.nodeName=ot(),t.usingCA=s?.certificate,$n.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function Wse(e){$n.trace("removeNodeBack received request:",e),await Sr().delete(e.name)}function Vx(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var ps,Kx,Nu,Yx,ff,$n,_o,qse,$se,Vse,Hc=Oe(()=>{ps=L(Xs()),Kx=L(Tt()),Nu=L(require("joi")),Yx=L(se()),ff=L(M());Q_();iu();us();$n=L(W()),_o=L(_e()),{pki:qse}=require("node-forge"),{HTTP_STATUS_CODES:$se}=_o.hdb_errors,Vse=Nu.default.object({hostname:Nu.default.string(),verify_tls:Nu.default.boolean(),replicates:Nu.default.boolean(),subscriptions:Nu.default.array()});a(Kse,"setNode");a(Yse,"addNodeBack");a(Wse,"removeNodeBack");a(Vx,"reverseSubscription")});var pf=N((Owe,jx)=>{"use strict";var{handleHDBError:um,hdb_errors:jse}=_e(),{HTTP_STATUS_CODES:dm}=jse,{addUpdateNodeValidator:zse}=im(),_m=W(),fm=M(),Wx=Ct(),Qse=te(),Ef=mr(),hf=Di(),wb=se(),Jse=Ib(),{Node:Xse,NodeSubscription:Zse}=yu(),{broadcast:eie}=dt(),{setNode:tie}=(Hc(),oe(Bc)),ywe=se(),bwe=M(),rie="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",nie="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",sie=wb.get(fm.CONFIG_PARAMS.CLUSTERING_NODENAME);jx.exports=iie;async function iie(e,t=!1){if(_m.trace("addNode called with:",e),wb.get(fm.CONFIG_PARAMS.REPLICATION_URL)||wb.get(fm.CONFIG_PARAMS.REPLICATION_HOSTNAME))return tie(e);hf.checkClusteringEnabled();let r=zse(e);if(r)throw um(r,r.message,dm.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let _=await hf.getNodeRecord(n);if(!Qse.isEmptyOrZeroLength(_))throw um(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,dm.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await Jse(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=rie,o;let c=hf.buildNodePayloads(s,sie,fm.OPERATIONS_ENUM.ADD_NODE,await hf.getSystemInfo()),l=[];for(let _=0,E=s.length;_<E;_++){let f=s[_];s[_].start_time===void 0&&delete s[_].start_time,l.push(new Zse(f.schema,f.table,f.publish,f.subscribe))}_m.trace("addNode sending remote payload:",c);let u;try{u=await Ef.request(`${n}.${Wx.REQUEST_SUFFIX}`,c)}catch(_){_m.error(`addNode received error from request: ${_}`);for(let f=0,h=s.length;f<h;f++){let T=s[f];T.publish=!1,T.subscribe=!1,await Ef.updateRemoteConsumer(T,n)}let E=Ef.requestErrorHandler(_,"add_node",n);throw um(new Error,E,dm.INTERNAL_SERVER_ERROR,"error",E)}if(u.status===Wx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let _=`Error returned from remote node ${n}: ${u.message}`;throw um(new Error,_,dm.INTERNAL_SERVER_ERROR,"error",_)}_m.trace(u);for(let _=0,E=s.length;_<E;_++){let f=s[_];await Ef.updateRemoteConsumer(f,n),f.subscribe===!0&&await Ef.updateConsumerIterator(f.schema,f.table,n,"start")}let d=new Xse(n,l,u.system_info);return await hf.upsertNodeRecord(d),eie({type:"nats_update"}),i.length>0?o.message=nie:o.message=`Successfully added '${n}' to manifest`,o}a(iie,"addNode")});var Lb=N((wwe,Qx)=>{"use strict";var{handleHDBError:Cb,hdb_errors:oie}=_e(),{HTTP_STATUS_CODES:Db}=oie,{addUpdateNodeValidator:aie}=im(),mf=W(),Em=M(),zx=Ct(),Iwe=te(),Sf=mr(),Tf=Di(),Pb=se(),{cloneDeep:cie}=require("lodash"),lie=Ib(),{Node:uie,NodeSubscription:die}=yu(),{broadcast:_ie}=dt(),{setNode:fie}=(Hc(),oe(Bc)),Eie="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",hie="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",pie=Pb.get(Em.CONFIG_PARAMS.CLUSTERING_NODENAME);Qx.exports=mie;async function mie(e){if(mf.trace("updateNode called with:",e),Pb.get(Em.CONFIG_PARAMS.REPLICATION_URL)??Pb.get(Em.CONFIG_PARAMS.REPLICATION_HOSTNAME))return fie(e);Tf.checkClusteringEnabled();let t=aie(e);if(t)throw Cb(t,t.message,Db.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Tf.getNodeRecord(r);s.length>0&&(n=cie(s));let{added:i,skipped:o}=await lie(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=Eie,c;let l=Tf.buildNodePayloads(i,pie,Em.OPERATIONS_ENUM.UPDATE_NODE,await Tf.getSystemInfo());for(let d=0,_=i.length;d<_;d++){let E=i[d];mf.trace(`updateNode updating work stream for node: ${r} subscription:`,E),i[d].start_time===void 0&&delete i[d].start_time}mf.trace("updateNode sending remote payload:",l);let u;try{u=await Sf.request(`${r}.${zx.REQUEST_SUFFIX}`,l)}catch(d){mf.error(`updateNode received error from request: ${d}`);let _=Sf.requestErrorHandler(d,"update_node",r);throw Cb(new Error,_,Db.INTERNAL_SERVER_ERROR,"error",_)}if(u.status===zx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${r}: ${u.message}`;throw Cb(new Error,d,Db.INTERNAL_SERVER_ERROR,"error",d)}mf.trace(u);for(let d=0,_=i.length;d<_;d++){let E=i[d];await Sf.updateRemoteConsumer(E,r),E.subscribe===!0?await Sf.updateConsumerIterator(E.schema,E.table,r,"start"):await Sf.updateConsumerIterator(E.schema,E.table,r,"stop")}return n||(n=[new uie(r,[],u.system_info)]),await Sie(n[0],i,u.system_info),o.length>0?c.message=hie:c.message=`Successfully updated '${r}'`,c}a(mie,"updateNode");async function Sie(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let l=0,u=e.subscriptions.length;l<u;l++){let d=n.subscriptions[l];if(d.schema===o.schema&&d.table===o.table){d.publish=o.publish,d.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new die(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await Tf.upsertNodeRecord(n),_ie({type:"nats_update"})}a(Sie,"updateNodeTable")});var tk=N((Dwe,ek)=>{"use strict";var Zx=require("joi"),{string:Jx}=Zx.types(),Tie=Tt(),Xx=M(),gie=se(),Rie=Ct();ek.exports=Aie;function Aie(e){let t=Jx.invalid(gie.get(Xx.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(Rie.NATS_TERM_CONSTRAINTS_RX).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >","any.invalid":"'node_name' cannot be this nodes name"}).empty(null),r=Zx.object({operation:Jx.valid(Xx.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return Tie.validateBySchema(e,r)}a(Aie,"removeNodeValidator")});var Rf=N((Lwe,ok)=>{"use strict";var{handleHDBError:rk,hdb_errors:yie}=_e(),{HTTP_STATUS_CODES:nk}=yie,bie=tk(),gf=W(),sk=Di(),Oie=te(),Iu=M(),ik=Ct(),Mb=mr(),Ub=se(),{RemotePayloadObject:Nie}=df(),{NodeSubscription:Iie}=yu(),wie=N_(),Cie=uc(),{broadcast:Die}=dt(),{setNode:Pie}=(Hc(),oe(Bc)),Lie=Ub.get(Iu.CONFIG_PARAMS.CLUSTERING_NODENAME);ok.exports=Mie;async function Mie(e){if(gf.trace("removeNode called with:",e),Ub.get(Iu.CONFIG_PARAMS.REPLICATION_URL)??Ub.get(Iu.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Pie(e);sk.checkClusteringEnabled();let t=bie(e);if(t)throw rk(t,t.message,nk.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await sk.getNodeRecord(r);if(Oie.isEmptyOrZeroLength(n))throw rk(new Error,`Node '${r}' was not found.`,nk.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new Nie(Iu.OPERATIONS_ENUM.REMOVE_NODE,Lie,[]),i,o=!1;for(let l=0,u=n.subscriptions.length;l<u;l++){let d=n.subscriptions[l];d.subscribe===!0&&await Mb.updateConsumerIterator(d.schema,d.table,r,"stop");try{await Mb.updateRemoteConsumer(new Iie(d.schema,d.table,!1,!1),r)}catch(_){gf.error(_)}}try{i=await Mb.request(`${r}.${ik.REQUEST_SUFFIX}`,s),gf.trace("Remove node reply from remote node:",r,i)}catch(l){gf.error("removeNode received error from request:",l),o=!0}let c=new wie(Iu.SYSTEM_SCHEMA_NAME,Iu.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Cie.deleteRecord(c),Die({type:"nats_update"}),i?.status===ik.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(gf.error("Error returned from remote node:",r,i?.message),`Successfully removed '${r}' from local manifest, however there was an error reaching remote node. Check the logs for more details.`):`Successfully removed '${r}' from manifest`}a(Mie,"removeNode")});var lk=N((Uwe,ck)=>{"use strict";var ak=require("joi"),{string:Uie,array:vie}=ak.types(),Bie=Tt(),Hie=im();ck.exports=xie;function xie(e){let t=ak.object({operation:Uie.valid("configure_cluster").required(),connections:vie.items(Hie.validation_schema).required()});return Bie.validateBySchema(e,t)}a(xie,"configureClusterValidator")});var vb=N((Bwe,Ek)=>{"use strict";var uk=M(),hm=W(),kie=te(),Fie=se(),Gie=Rf(),qie=pf(),$ie=Di(),Vie=lk(),{handleHDBError:dk,hdb_errors:Kie}=_e(),{HTTP_STATUS_CODES:_k}=Kie,Yie="Configure cluster complete.",Wie="Failed to configure the cluster. Check the logs for more details.",jie="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";Ek.exports=zie;async function zie(e){hm.trace("configure cluster called with:",e);let t=Vie(e);if(t)throw dk(t,t.message,_k.BAD_REQUEST,void 0,void 0,!0);let r=await $ie.getAllNodeRecords(),n=[];if(Fie.get(uk.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let d=0,_=r.length;d<_;d++){let E=await fk(Gie,{operation:uk.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[d].name},r[d].name);n.push(E)}hm.trace("All results from configure_cluster remove node:",n)}let s=[],i=e.connections.length;for(let d=0;d<i;d++){let _=e.connections[d],E=await fk(qie,_,_.node_name);s.push(E)}hm.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,u=n.concat(s);for(let d=0,_=u.length;d<_;d++){let E=u[d];E.status==="rejected"&&(hm.error(E.node_name,E?.error?.message,E?.error?.stack),o.includes(E.node_name)||o.push(E.node_name)),(E?.result?.message?.includes?.("Successfully")||E?.result?.includes?.("Successfully"))&&(l=!0),!(typeof E.result=="string"&&E.result.includes("Successfully removed")||E.status==="rejected")&&c.push({node_name:E?.node_name,response:E?.result})}if(kie.isEmptyOrZeroLength(o))return{message:Yie,connections:c};if(l)return{message:jie,failed_nodes:o,connections:c};throw dk(new Error,Wie,_k.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(zie,"configureCluster");async function fk(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(fk,"functionWrapper")});var Sk=N((xwe,mk)=>{"use strict";var Af=require("joi"),Qie=Tt(),{validateSchemaExists:hk,validateTableExists:Jie,validateSchemaName:pk}=Ti(),Xie=Af.object({operation:Af.string().valid("purge_stream"),schema:Af.string().custom(hk).custom(pk).optional(),database:Af.string().custom(hk).custom(pk).optional(),table:Af.string().custom(Jie).required()});function Zie(e){return Qie.validateBySchema(e,Xie)}a(Zie,"purgeStreamValidator");mk.exports=Zie});var Bb=N((Fwe,Tk)=>{"use strict";var{handleHDBError:eoe,hdb_errors:toe}=_e(),{HTTP_STATUS_CODES:roe}=toe,noe=Sk(),soe=mr(),ioe=Di();Tk.exports=ooe;async function ooe(e){e.schema=e.schema??e.database;let t=noe(e);if(t)throw eoe(t,t.message,roe.BAD_REQUEST,void 0,void 0,!0);ioe.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await soe.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(ooe,"purgeStream")});var mm=N((qwe,Nk)=>{"use strict";var xb=Di(),aoe=mr(),pm=se(),wu=M(),xc=Ct(),coe=te(),Hb=W(),{RemotePayloadObject:loe}=df(),{ErrorCode:gk}=require("nats"),{parentPort:Rk}=require("worker_threads"),{onMessageByType:uoe}=dt(),{getThisNodeName:doe}=(us(),oe(ca)),{requestClusterStatus:_oe}=(Q_(),oe(gB)),Ak=pm.get(wu.CONFIG_PARAMS.CLUSTERING_ENABLED),yk=pm.get(wu.CONFIG_PARAMS.CLUSTERING_NODENAME);Nk.exports={clusterStatus:foe,buildNodeStatus:Ok};var bk;uoe("cluster-status",async e=>{bk(e)});async function foe(){if(pm.get(wu.CONFIG_PARAMS.REPLICATION_URL)||pm.get(wu.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;return Rk?(Rk.postMessage({type:"request-cluster-status"}),n=await new Promise(s=>{bk=s})):n=_oe(),n.node_name=doe(),n.is_enabled=!0,n}let e={node_name:yk,is_enabled:Ak,connections:[]};if(!Ak)return e;let t=await xb.getAllNodeRecords();if(coe.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(Ok(t[n],e.connections));return await Promise.allSettled(r),e}a(foe,"clusterStatus");async function Ok(e,t){let r=e.name,n=new loe(wu.OPERATIONS_ENUM.CLUSTER_STATUS,yk,void 0,await xb.getSystemInfo()),s,i,o=xc.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await aoe.request(xc.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===xc.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=xc.CLUSTER_STATUS_STATUSES.CLOSED,Hb.error(`Error getting node status from ${r} `,s))}catch(l){Hb.warn(`Error getting node status from ${r}`,l),l.code===gk.NoResponders?o=xc.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===gk.Timeout?o=xc.CLUSTER_STATUS_STATUSES.TIMEOUT:o=xc.CLUSTER_STATUS_STATUSES.CLOSED}let c=new Eoe(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let l={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==wu.PRE_4_0_0_VERSION&&await xb.upsertNodeRecord(l)}catch(l){Hb.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(Ok,"buildNodeStatus");function Eoe(e,t,r,n,s,i,o,c){this.node_name=e,this.status=t,this.ports={clustering:r,operations_api:n},this.latency_ms=s,this.uptime=i,this.subscriptions=o,this.system_info=c}a(Eoe,"NodeStatusObject")});var Fb=N((Vwe,Ik)=>{"use strict";var{handleHDBError:hoe,hdb_errors:poe}=_e(),{HTTP_STATUS_CODES:moe}=poe,Soe=mr(),Toe=Di(),kb=te(),Sm=require("joi"),goe=Tt(),Roe=2e3,Aoe=Sm.object({timeout:Sm.number().min(1),connected_nodes:Sm.boolean(),routes:Sm.boolean()});Ik.exports=yoe;async function yoe(e){Toe.checkClusteringEnabled();let t=goe.validateBySchema(e,Aoe);if(t)throw hoe(t,t.message,moe.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||kb.autoCastBoolean(n),o=s===void 0||kb.autoCastBoolean(s),c={nodes:[]},l=await Soe.getServerList(r??Roe),u={};if(i)for(let d=0,_=l.length;d<_;d++){let E=l[d].statsz;E&&(u[l[d].server.name]=E.routes)}for(let d=0,_=l.length;d<_;d++){if(l[d].statsz)continue;let E=l[d].server,f=l[d].data;if(E.name.endsWith("-hub")){let h={name:E.name.slice(0,-4),response_time:l[d].response_time};i&&(h.connected_nodes=[],u[E.name]&&u[E.name].forEach(T=>{h.connected_nodes.includes(T.name.slice(0,-4))||h.connected_nodes.push(T.name.slice(0,-4))})),o&&(h.routes=f.cluster?.urls?f.cluster?.urls.map(T=>({host:T.split(":")[0],port:kb.autoCast(T.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(yoe,"clusterNetwork")});var Pk=N((Ywe,Dk)=>{"use strict";var Gb=require("joi"),wk=Tt(),{route_constraints:Ck}=gg();Dk.exports={setRoutesValidator:boe,deleteRoutesValidator:Ooe};function boe(e){let t=Gb.object({server:Gb.valid("hub","leaf"),routes:Ck.required()});return wk.validateBySchema(e,t)}a(boe,"setRoutesValidator");function Ooe(e){let t=Gb.object({routes:Ck.required()});return wk.validateBySchema(e,t)}a(Ooe,"deleteRoutesValidator")});var Tm=N((jwe,xk)=>{"use strict";var fo=wt(),qb=te(),ms=M(),Cu=se(),Lk=Pk(),{handleHDBError:Mk,hdb_errors:Noe}=_e(),{HTTP_STATUS_CODES:Uk}=Noe,vk="cluster routes successfully set",Bk="cluster routes successfully deleted";xk.exports={setRoutes:woe,getRoutes:Coe,deleteRoutes:Doe};function Ioe(e){let t=fo.getClusteringRoutes(),r=e.server==="hub"?t.hub_routes:t.leaf_routes,n=e.server==="hub"?t.leaf_routes:t.hub_routes,s=[],i=[];for(let o=0,c=e.routes.length;o<c;o++){let l=e.routes[o];l.port=qb.autoCast(l.port);let u=r.some(_=>_.host===l.host&&_.port===l.port),d=n.some(_=>_.host===l.host&&_.port===l.port);u||d?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?fo.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):fo.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:vk,set:i,skipped:s}}a(Ioe,"setRoutesNats");function woe(e){let t=Lk.setRoutesValidator(e);if(t)throw Mk(t,t.message,Uk.BAD_REQUEST,void 0,void 0,!0);if(Cu.get(ms.CONFIG_PARAMS.CLUSTERING_ENABLED))return Ioe(e);let r=[],n=[],s=Cu.get(ms.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{Hk(s,i)?n.push(i):(s.push(i),r.push(i))}),fo.updateConfigValue(ms.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:vk,set:r,skipped:n}}a(woe,"setRoutes");function Hk(e,t){return typeof t=="string"?e.includes(t):typeof t=="object"&&t!==null?e.some(r=>(r.host===t.host||r.hostname===t.hostname)&&r.port===t.port):!1}a(Hk,"existsInArray");function Coe(){if(Cu.get(ms.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=fo.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return Cu.get(ms.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(Coe,"getRoutes");function Doe(e){let t=Lk.deleteRoutesValidator(e);if(t)throw Mk(t,t.message,Uk.BAD_REQUEST,void 0,void 0,!0);if(Cu.get(ms.CONFIG_PARAMS.CLUSTERING_ENABLED))return Poe(e);let r=[],n=[],s=Cu.get(ms.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{Hk(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),fo.updateConfigValue(ms.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:Bk,deleted:r,skipped:n}}a(Doe,"deleteRoutes");function Poe(e){let t=fo.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],o=!1,c=!1;for(let l=0,u=e.routes.length;l<u;l++){let d=e.routes[l],_=!1;for(let E=0,f=r.length;E<f;E++){let h=r[E];if(d.host===h.host&&d.port===h.port){r.splice(E,1),_=!0,o=!0,s.push(d);break}}if(!_){let E=!0;for(let f=0,h=n.length;f<h;f++){let T=n[f];if(d.host===T.host&&d.port===T.port){n.splice(f,1),c=!0,E=!1,s.push(d);break}}E&&i.push(d)}}return o&&(r=qb.isEmptyOrZeroLength(r)?null:r,fo.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=qb.isEmptyOrZeroLength(n)?null:n,fo.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:Bk,deleted:s,skipped:i}}a(Poe,"deleteRoutesNats")});var Fk=N((Qwe,kk)=>{"use strict";var yf=require("alasql"),kc=require("recursive-iterator"),Zs=W(),Loe=te(),bf=M(),$b=class{static{a(this,"sql_statement_bucket")}constructor(t){this.ast=t,this.affected_attributes=new Map,this.table_lookup=new Map,this.schema_lookup=new Map,this.table_to_schema_lookup=new Map,Uoe(this.ast,this.affected_attributes,this.table_lookup,this.schema_lookup,this.table_to_schema_lookup)}getAttributesBySchemaTableName(t,r){if(!t||!r||!this.affected_attributes)return[];if(this.affected_attributes.has(t))return!this.affected_attributes.get(t).has(r)&&(r=this.table_lookup.get(r),!r)?[]:this.affected_attributes.get(t).get(r)}getAllTables(){let t=[];if(!this.affected_attributes)return t;for(let r of this.affected_attributes.keys())t.push(Array.from(this.affected_attributes.get(r).keys()));return t}getTablesBySchemaName(t){return!t||!this.affected_attributes?[]:Array.from(this.affected_attributes.get(t).keys())}getSchemas(){return this.affected_attributes?Array.from(this.affected_attributes.keys()):[]}getAst(){return this.ast}updateAttributeWildcardsForRolePerms(t){let r=this.ast.columns.filter(s=>bf.SEARCH_WILDCARDS.includes(s.columnid));if(r.length===0)return this.ast;let n=this.ast.from[0].databaseid;return this.ast.columns=this.ast.columns.filter(s=>!bf.SEARCH_WILDCARDS.includes(s.columnid)),r.forEach(s=>{let i=this.table_to_schema_lookup.has(s.tableid)?this.table_to_schema_lookup.get(s.tableid):n,o=this.table_lookup.has(s.tableid)?this.table_lookup.get(s.tableid):this.ast.from[0].tableid;if(t[i]&&t[i].tables[o]&&t[i].tables[o][bf.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=Moe(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(u=>({attribute_name:u.attribute}));let l=this.affected_attributes.get(i).get(o).filter(u=>!bf.SEARCH_WILDCARDS.includes(u));c.forEach(({attribute_name:u})=>{let d=new yf.yy.Column({columnid:u});s.tableid&&(d.tableid=s.tableid),this.ast.columns.push(d),l.includes(u)||l.push(u)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function Moe(e){return e.filter(t=>t[bf.PERMS_CRUD_ENUM.READ])}a(Moe,"filterReadRestrictedAttrs");function Uoe(e,t,r,n,s){voe(e,t,r,n,s)}a(Uoe,"interpretAST");function Of(e,t,r,n,s){if(!(!e||!e.databaseid)&&(t.has(e.databaseid)||t.set(e.databaseid,new Map),t.get(e.databaseid).has(e.tableid)||t.get(e.databaseid).set(e.tableid,[]),e.as&&(r.has(e.as)||r.set(e.as,e.tableid),n&&!n.has(e.as)&&n.set(e.as,e.databaseid)),s)){let i=e.databaseid,o=e.tableid;e.as&&(o=e.as),s.set(o,i)}}a(Of,"addSchemaTableToMap");function voe(e,t,r,n,s){if(!e){Zs.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof yf.yy.Insert?koe(e,t,r):e instanceof yf.yy.Select?Boe(e,t,r,n,s):e instanceof yf.yy.Update?Hoe(e,t,r):e instanceof yf.yy.Delete?xoe(e,t,r):Zs.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(voe,"getRecordAttributesAST");function Boe(e,t,r,n,s){if(!e){Zs.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(Loe.isEmptyOrZeroLength(i)){Zs.error("No schema specified");return}e.from.forEach(c=>{Of(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),Of(c.table,t,r,n,s)});let o=new kc(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,u=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(u).has(l))if(r.has(l))l=r.get(l);else{Zs.info(`table specified as ${l} not found.`);return}t.get(u).get(l).indexOf(c.columnid)<0&&t.get(u).get(l).push(c.columnid)}if(e.where){let c=new kc(e.where),l=e.from[0].tableid;for(let{node:u}of c)if(u&&u.columnid){let d=u.tableid?u.tableid:l;if(!t.get(i).has(d))if(r.has(d))d=r.get(d);else{Zs.info(`table specified as ${d} not found.`);continue}t.get(i).get(d).indexOf(u.columnid)<0&&t.get(i).get(d).push(u.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new kc(c.on);for(let{node:u}of l)if(u&&u.columnid){let d=u.tableid,_=s.get(d);if(!t.get(_).has(d))if(r.has(d))d=r.get(d);else{Zs.info(`table specified as ${d} not found.`);continue}t.get(_).get(d).indexOf(u.columnid)<0&&t.get(_).get(d).push(u.columnid)}}),e.order){let c=new kc(e.order);for(let{node:l}of c)if(l&&l.columnid){let u=l.tableid,d=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(d).has(u))if(r.has(u))u=r.get(u);else{Zs.info(`table specified as ${u} not found.`);return}t.get(d).get(u).indexOf(l.columnid)<0&&t.get(d).get(u).push(l.columnid)}}}a(Boe,"getSelectAttributes");function Hoe(e,t,r){if(!e){Zs.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new kc(e.columns),s=e.table.databaseid;Of(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&Vb(e.table.tableid,s,i.columnid,t,r)}a(Hoe,"getUpdateAttributes");function xoe(e,t,r){if(!e){Zs.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new kc(e.where),s=e.table.databaseid;Of(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&Vb(e.table.tableid,s,i.columnid,t,r)}a(xoe,"getDeleteAttributes");function koe(e,t,r){if(!e){Zs.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new kc(e.columns),s=e.into.databaseid;Of(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&Vb(e.into.tableid,s,i.columnid,t,r)}a(koe,"getInsertAttributes");function Vb(e,t,r,n,s){if(!n.get(t))return;let i=e;n.get(t).has(i)||(i=s.get(i)),n.get(t).get(i).push(r)}a(Vb,"pushAttribute");kk.exports=$b});var Wb=N((Xwe,Vk)=>{var gm=dc(),Gk=require("chalk"),Vn=W(),qk=require("prompt"),{promisify:Foe}=require("util"),Kb=M(),Goe=require("fs-extra"),qoe=require("path"),$oe=te(),Voe=Uc(),$k=se();$k.initSync();var Koe=require("moment"),Yoe=Foe(qk.get),Woe=qoe.join($k.getHdbBasePath(),Kb.LICENSE_KEY_DIR_NAME,Kb.LICENSE_FILE_NAME,Kb.LICENSE_FILE_NAME);Vk.exports={getFingerprint:zoe,setLicense:joe,parseLicense:Yb,register:Qoe,getRegistrationInfo:Xoe};async function joe(e){if(e&&e.key&&e.company){try{Vn.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await Yb(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw Vn.error(r),Vn.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(joe,"setLicense");async function zoe(){let e={};try{e=await gm.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw Vn.error(r),Vn.error(t),new Error(r)}return e}a(zoe,"getFingerprint");async function Yb(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");Vn.info("Validating license input...");let r=gm.validateLicense(e,t);if(Vn.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(Vn.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(Vn.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{Vn.info("writing license to disk"),await Goe.writeFile(Woe,JSON.stringify({license_key:e,company:t}))}catch(n){throw Vn.error("Failed to write License"),n}return"Registration successful."}a(Yb,"parseLicense");async function Qoe(){let e=await Joe();return Yb(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(Qoe,"register");async function Joe(){let e=await gm.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:Gk.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:Gk.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{qk.start()}catch(n){Vn.error(n)}let r;try{r=await Yoe(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(Joe,"promptForRegistration");async function Xoe(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await gm.getLicense()}catch(r){throw Vn.error(`There was an error when searching licenses due to: ${r.message}`),r}if($oe.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=Voe.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=Koe.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(Xoe,"getRegistrationInfo")});var Yk=N((eCe,Kk)=>{"use strict";var Zoe=Ct(),jb=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,u,d,_,E,f,h){this.port=t,o===null&&(o=void 0),this.server_name=r+Zoe.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.reconnect_error_reports=100,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l},this.leafnodes={port:u,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:d,port:_,routes:E,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:f},HDB:{users:h}},this.system_account="SYS"}};Kk.exports=jb});var zk=N((rCe,jk)=>{"use strict";var Wk=Ct(),zb=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,u,d,_){this.port=t,_===null&&(_=void 0),this.server_name=r+Wk.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+Wk.SERVER_SUFFIX.LEAF},this.tls={cert_file:u,key_file:d,ca_file:_,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:_,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:_,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:l,jetstream:"enabled"}},this.system_account="SYS"}};jk.exports=zb});var Jk=N((sCe,Qk)=>{"use strict";var Qb=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};Qk.exports=Qb});var Zk=N((oCe,Xk)=>{"use strict";var eae=Ct(),Jb=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+eae.SERVER_SUFFIX.ADMIN,this.password=r}};Xk.exports=Jb});var bm=N((cCe,rF)=>{"use strict";var Fc=require("path"),Gc=require("fs-extra"),tae=Yk(),rae=zk(),nae=Jk(),sae=Zk(),Xb=xn(),Pu=te(),Tn=wt(),Am=M(),Nf=Ct(),{CONFIG_PARAMS:Jt}=Am,Lu=W(),If=se(),eF=to(),Zb=mr(),iae=Xs(),Du="clustering",oae=1e4,tF=50;rF.exports={generateNatsConfig:cae,removeNatsConfig:lae,getHubConfigPath:aae};function aae(){let e=If.get(Jt.ROOTPATH);return Fc.join(e,Du,Nf.NATS_CONFIG_FILES.HUB_SERVER)}a(aae,"getHubConfigPath");async function cae(e=!1,t=void 0){let r=If.get(Jt.ROOTPATH);Gc.ensureDirSync(Fc.join(r,"clustering","leaf")),If.initSync();let n=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_CERT_AUTH),s=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_PRIVATEKEY),i=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_CERTIFICATE);!await Gc.exists(i)&&!await Gc.exists(!n)&&await iae.createNatsCerts();let o=Fc.join(r,Du,Nf.PID_FILES.HUB),c=Fc.join(r,Du,Nf.PID_FILES.LEAF),l=Tn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=Fc.join(r,Du,Nf.NATS_CONFIG_FILES.HUB_SERVER),d=Fc.join(r,Du,Nf.NATS_CONFIG_FILES.LEAF_SERVER),_=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_INSECURE),E=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_VERIFY),f=Tn.getConfigFromFile(Jt.CLUSTERING_NODENAME),h=Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await Zb.checkNATSServerInstalled()||ym("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let T=await Xb.listUsers(),m=Tn.getConfigFromFile(Jt.CLUSTERING_USER),g=await Xb.getClusterUser();(Pu.isEmpty(g)||g.active!==!0)&&ym(`Invalid cluster user '${m}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await Rm(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await Rm(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await Rm(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),await Rm(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let S=[],b=[];for(let[ne,Q]of T.entries())Q.role?.role===Am.ROLE_TYPES_ENUM.CLUSTER_USER&&Q.active&&(S.push(new sae(Q.username,eF.decrypt(Q.hash))),b.push(new nae(Q.username,eF.decrypt(Q.hash))));let I=[],{hub_routes:B}=Tn.getClusteringRoutes();if(!Pu.isEmptyOrZeroLength(B))for(let ne of B)I.push(`tls://${g.sys_name_encoded}:${g.uri_encoded_d_hash}@${ne.host}:${ne.port}`);let H=new tae(Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),f,o,i,s,n,_,E,h,Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NAME),Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),I,S,b);n==null&&(delete H.tls.ca_file,delete H.leafnodes.tls.ca_file),t=Pu.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===Am.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Gc.writeJson(u,H),Lu.trace(`Hub server config written to ${u}`));let X=`tls://${g.sys_name_encoded}:${g.uri_encoded_d_hash}@0.0.0.0:${h}`,Y=`tls://${g.uri_encoded_name}:${g.uri_encoded_d_hash}@0.0.0.0:${h}`,V=new rae(Tn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT),f,c,l,[X],[Y],S,b,i,s,n,_);n==null&&delete V.tls.ca_file,(t===void 0||t===Am.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Gc.writeJson(d,V),Lu.trace(`Leaf server config written to ${d}`))}a(cae,"generateNatsConfig");async function Rm(e){let t=If.get(e);return Pu.isEmpty(t)&&ym(`port undefined for '${e}'`),await Pu.isPortTaken(t)&&ym(`'${e}' port '${t}' is is in use by another process, check to see if HarperDB is already running or another process is using this port.`),!0}a(Rm,"isPortAvailable");function ym(e){let t=`Error generating clustering config: ${e}`;Lu.error(t),console.error(t),process.exit(1)}a(ym,"generateNatsConfigError");async function lae(e){let{port:t,config_file:r}=Zb.getServerConfig(e),{username:n,decrypt_hash:s}=await Xb.getClusterUser(),i=0,o=2e3;for(;i<tF;){try{let d=await Zb.createConnection(t,n,s,!1);if(d.protocol.connected===!0){d.close();break}}catch(d){Lu.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${d}`)}if(i++,i>=tF)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);let u=o*(i*2);u>3e4&&Lu.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await Pu.async_set_timeout(u)}let c="0".repeat(oae),l=Fc.join(If.get(Jt.ROOTPATH),Du,r);await Gc.writeFile(l,c),await Gc.remove(l),Lu.notify(e,"started.")}a(lae,"removeNatsConfig")});var cF=N((uCe,aF)=>{"use strict";var Kn=se(),uae=dc(),Fe=M(),wf=Ct(),Eo=require("path"),{PACKAGE_ROOT:Nm}=M(),nF=se(),Om=te(),Mu="/dev/null",dae=Eo.join(Nm,"launchServiceScripts"),sF=Eo.join(Nm,"utility/scripts"),_ae=Eo.join(sF,Fe.HDB_RESTART_SCRIPT),iF=Eo.resolve(Nm,"dependencies",`${process.platform}-${process.arch}`,wf.NATS_BINARY_NAME);function oF(){let t=uae.licenseSearch().ram_allocation||Fe.RAM_ALLOCATION_ENUM.DEFAULT,r=Fe.MEM_SETTING_KEY+t,n={[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return Om.noBootFile()&&(n[Fe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Om.getEnvCliRootPath()),{name:Fe.PROCESS_DESCRIPTORS.HDB,script:Fe.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:Nm}}a(oF,"generateMainServerConfig");var fae=9930;function Eae(){Kn.initSync(!0);let e=Kn.get(Fe.CONFIG_PARAMS.ROOTPATH),t=Eo.join(e,"clustering",wf.NATS_CONFIG_FILES.HUB_SERVER),r=Eo.join(Kn.get(Fe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Fe.LOG_NAMES.HDB),n=nF.get(Fe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=wf.LOG_LEVEL_FLAGS[Kn.get(Fe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==fae?"-"+n:""),script:iF,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return Kn.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Mu,i.error_file=Mu),i}a(Eae,"generateNatsHubServerConfig");var hae=9940;function pae(){Kn.initSync(!0);let e=Kn.get(Fe.CONFIG_PARAMS.ROOTPATH),t=Eo.join(e,"clustering",wf.NATS_CONFIG_FILES.LEAF_SERVER),r=Eo.join(Kn.get(Fe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Fe.LOG_NAMES.HDB),n=nF.get(Fe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=wf.LOG_LEVEL_FLAGS[Kn.get(Fe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==hae?"-"+n:""),script:iF,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return Kn.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Mu,i.error_file=Mu),i}a(pae,"generateNatsLeafServerConfig");function mae(){Kn.initSync();let e=Eo.join(Kn.get(Fe.CONFIG_PARAMS.LOGGING_ROOT),Fe.LOG_NAMES.HDB),t={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:Fe.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:dae,autorestart:!1};return Kn.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=Mu,t.error_file=Mu),t}a(mae,"generateClusteringUpgradeV4ServiceConfig");function Sae(){let e={[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.RESTART_HDB};return Om.noBootFile()&&(e[Fe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Om.getEnvCliRootPath()),{...{name:Fe.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:sF},script:_ae}}a(Sae,"generateRestart");function Tae(){return{apps:[oF()]}}a(Tae,"generateAllServiceConfigs");aF.exports={generateAllServiceConfigs:Tae,generateMainServerConfig:oF,generateRestart:Sae,generateNatsHubServerConfig:Eae,generateNatsLeafServerConfig:pae,generateClusteringUpgradeV4ServiceConfig:mae}});var Uu=N((fCe,AF)=>{"use strict";var at=M(),gae=te(),po=bm(),Im=mr(),ho=Ct(),ha=cF(),wm=se(),qc=W(),Rae=Di(),{startWorker:lF,onMessageFromWorkers:Aae}=dt(),yae=Ou(),_Ce=require("util"),bae=require("child_process"),Oae=require("fs"),{execFile:Nae}=bae,Xe;AF.exports={enterPM2Mode:Iae,start:pa,stop:eO,reload:dF,restart:_F,list:tO,describe:hF,connect:mo,kill:Lae,startAllServices:Mae,startService:rO,getUniqueServicesList:pF,restartAllServices:Uae,isServiceRegistered:mF,reloadStopStart:SF,restartHdb:EF,deleteProcess:Dae,startClusteringProcesses:gF,startClusteringThreads:RF,isHdbRestartRunning:Pae,isClusteringRunning:Bae,stopClustering:vae,reloadClustering:Hae,expectedRestartOfChildren:fF};var Cf=!1;Aae(e=>{e.type==="restart"&&wm.initSync(!0)});function Iae(){Cf=!0}a(Iae,"enterPM2Mode");function mo(){return Xe||(Xe=require("pm2")),new Promise((e,t)=>{Xe.connect((r,n)=>{r&&t(r),e(n)})})}a(mo,"connect");var Jr,wae=10,uF;function pa(e,t=!1){if(Cf)return Cae(e);let r=Nae(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let o=Jr.indexOf(r);o>-1&&Jr.splice(o,1),!uF&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<wae&&(Oae.existsSync(po.getHubConfigPath())?pa(e):(await po.generateNatsConfig(!0),pa(e),await new Promise(c=>setTimeout(c,3e3)),await po.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await po.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=wm.get(at.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,u=0,d;for(;l=c.exec(i);){if(l.index&&ho.LOG_LEVEL_HIERARCHY[o]>=ho.LOG_LEVEL_HIERARCHY[d||"info"]){let f=d===ho.LOG_LEVELS.ERR||d===ho.LOG_LEVELS.WRN?qc.OUTPUTS.STDERR:qc.OUTPUTS.STDOUT;qc.logCustomLevel(d||"info",f,n,i.slice(u,l.index).trim())}let[_,E]=l;u=l.index+_.length,d=ho.LOG_LEVELS[E]}if(ho.LOG_LEVEL_HIERARCHY[o]>=ho.LOG_LEVEL_HIERARCHY[d||"info"]){let _=d===ho.LOG_LEVELS.ERR||d===ho.LOG_LEVELS.WRN?qc.OUTPUTS.STDERR:qc.OUTPUTS.STDOUT;qc.logCustomLevel(d||"info",_,n,i.slice(u).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!Jr&&(Jr=[],!t)){let i=a(()=>{uF=!0,Jr&&(Jr.map(o=>o.kill()),process.exit(0))},"kill_children");process.on("exit",i),process.on("SIGINT",i),process.on("SIGQUIT",i),process.on("SIGTERM",i)}Jr.push(r)}a(pa,"start");function Cae(e){return new Promise(async(t,r)=>{try{await mo()}catch(n){r(n)}Xe.start(e,(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(s)})})}a(Cae,"startWithPM2");function eO(e){if(!Cf){for(let t of Jr||[])t.name===e&&(Jr.splice(Jr.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await mo()}catch(n){r(n)}Xe.stop(e,async(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.delete(e,(i,o)=>{i&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(o)})})})}a(eO,"stop");function dF(e){return new Promise(async(t,r)=>{try{await mo()}catch(n){r(n)}Xe.reload(e,(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(s)})})}a(dF,"reload");function _F(e){if(!Cf){fF();for(let t of Jr||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await mo()}catch(n){r(n)}Xe.restart(e,(n,s)=>{Xe.disconnect(),t(s)})})}a(_F,"restart");function fF(){for(let e of Jr||[])e.config&&(e.config.restarts=0)}a(fF,"expectedRestartOfChildren");function Dae(e){return new Promise(async(t,r)=>{try{await mo()}catch(n){r(n)}Xe.delete(e,(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(s)})})}a(Dae,"deleteProcess");async function EF(){await pa(ha.generateRestart())}a(EF,"restartHdb");async function Pae(){let e=await tO();for(let t in e)if(e[t].name===at.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(Pae,"isHdbRestartRunning");function tO(){return new Promise(async(e,t)=>{try{await mo()}catch(r){t(r)}Xe.list((r,n)=>{r&&(Xe.disconnect(),t(r)),Xe.disconnect(),e(n)})})}a(tO,"list");function hF(e){return new Promise(async(t,r)=>{try{await mo()}catch(n){r(n)}Xe.describe(e,(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(s)})})}a(hF,"describe");function Lae(){if(!Cf){for(let e of Jr||[])e.kill();Jr=[];return}return new Promise(async(e,t)=>{try{await mo()}catch(r){t(r)}Xe.killDaemon((r,n)=>{r&&(Xe.disconnect(),t(r)),Xe.disconnect(),e(n)})})}a(Lae,"kill");async function Mae(){try{await gF(),await RF(),await pa(ha.generateAllServiceConfigs())}catch(e){throw Xe?.disconnect(),e}}a(Mae,"startAllServices");async function rO(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case at.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=ha.generateMainServerConfig();break;case at.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=ha.generateNatsIngestServiceConfig();break;case at.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=ha.generateNatsReplyServiceConfig();break;case at.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=ha.generateNatsHubServerConfig(),await pa(r,t),await po.removeNatsConfig(e);return;case at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=ha.generateNatsLeafServerConfig(),await pa(r,t),await po.removeNatsConfig(e);return;case at.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=ha.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await pa(r)}catch(r){throw Xe?.disconnect(),r}}a(rO,"startService");async function pF(){try{let e=await tO(),t={};for(let r=0,n=e.length;r<n;r++){let s=e[r];t[s.name]===void 0&&(t[s.name]={name:s.name,exec_mode:s.pm2_env.exec_mode})}return t}catch(e){throw Xe?.disconnect(),e}}a(pF,"getUniqueServicesList");async function Uae(e=[]){try{let t=!1,r=await pF();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===at.PROCESS_DESCRIPTORS.HDB?t=!0:await _F(o))}t&&await SF(at.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Xe?.disconnect(),t}}a(Uae,"restartAllServices");async function mF(e){if(Jr?.find(r=>r.name===e))return!0;let t=await yae.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(mF,"isServiceRegistered");async function SF(e){let t=wm.get(at.CONFIG_PARAMS.THREADS_COUNT)??wm.get(at.CONFIG_PARAMS.THREADS),r=await hF(e),n=gae.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await eO(e),await rO(e)):e===at.PROCESS_DESCRIPTORS.HDB?await EF():await dF(e)}a(SF,"reloadStopStart");var TF;async function gF(e=!1){for(let t in at.CLUSTERING_PROCESSES){let r=at.CLUSTERING_PROCESSES[t];await rO(r,e)}}a(gF,"startClusteringProcesses");async function RF(){TF=lF(at.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:at.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await Im.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await Im.updateLocalStreams();let e=await Rae.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===at.PRE_4_0_0_VERSION){qc.info("Starting clustering upgrade 4.0.0 process"),lF(at.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(RF,"startClusteringThreads");async function vae(){for(let e in at.CLUSTERING_PROCESSES)if(e!==at.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===at.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await TF.terminate();else{let t=at.CLUSTERING_PROCESSES[e];await eO(t)}}a(vae,"stopClustering");async function Bae(){for(let e in at.CLUSTERING_PROCESSES){let t=at.CLUSTERING_PROCESSES[e];if(await mF(t)===!1)return!1}return!0}a(Bae,"isClusteringRunning");async function Hae(){await po.generateNatsConfig(!0),await Im.reloadNATSHub(),await Im.reloadNATSLeaf(),await po.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await po.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(Hae,"reloadClustering")});var iO={};je(iO,{compactOnStart:()=>xae,copyDb:()=>wF});async function xae(){Df.notify("Running compact on start"),console.log("Running compact on start");let e=(0,nO.get)(ma.CONFIG_PARAMS.ROOTPATH),t=new Map,r=ut();try{for(let n in r){if(n==="system")continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,Cm.join)(e,"backup",n+".mdb"),o=(0,Cm.join)(e,ma.DATABASES_DIR_NAME,n+"-copy.mdb"),c=await yF(n);console.log("Database",n,"before compact has a total record count of",c),t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await wF(n,o),console.log("Backing up",n,"to",i),await(0,$c.move)(s,i,{overwrite:!0})}vu();for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,$c.move)(i,s,{overwrite:!0}),await(0,$c.remove)((0,Cm.join)(e,ma.DATABASES_DIR_NAME,`${n}-copy.mdb-lock`));vu()}catch(n){Df.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,sO.updateConfigValue)(ma.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1);for(let[s,{db_path:i,backup_dest:o}]of t){console.error("Moving backup database",o,"back to",i);try{await(0,$c.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw vu(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await yF(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){o=!1;let l=`There is a discrepancy between pre and post compact record count for database ${n}.
|
|
14
|
+
`,"")}a(K0,"runCommand");async function Xee(){try{await Cee.access(ny)}catch{return!1}let e=await K0(`${ny} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return Dee.eq(t,Qee)}a(Xee,"checkNATSServerInstalled");async function cy(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await $0.getClusterUser();if(yc(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}js.trace("create nats connection called");let i=await Fee({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:br.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:br.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:br.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),js.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&js.error("Error with Nats client connection, connection closed",o),i===zr&&Y0()}),i}a(cy,"createConnection");function Y0(){zr=void 0,gc=void 0,Rc=void 0,Ac=void 0}a(Y0,"clearClientCache");async function Zee(){zr&&(await zr.drain(),zr=void 0,gc=void 0,Rc=void 0,Ac=void 0)}a(Zee,"closeConnection");var zr,Ac;async function K_(){return Ac||(Ac=cy(br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),zr=await Ac),zr||Ac}a(K_,"getConnection");async function Y_(){if(gc)return gc;yc(zr)&&await K_();let{domain:e}=eu(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(yc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return gc=await zr.jetstreamManager({domain:e,timeout:6e4}),gc}a(Y_,"getJetStreamManager");async function W0(){if(Rc)return Rc;yc(zr)&&await K_();let{domain:e}=eu(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(yc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Rc=zr.jetstream({domain:e,timeout:6e4}),Rc}a(W0,"getJetStream");async function Ii(){let e=zr||await K_(),t=gc||await Y_(),r=Rc||await W0();return{connection:e,jsm:t,js:r}}a(Ii,"getNATSReferences");async function ete(e){let t=br.get(Je.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await $0.getClusterUser(),s=await cy(t,r,n),i=ay(),o=s.subscribe(i),c=[],l,u=(async()=>{for await(let d of o){let _=V0.decode(d.data);_.response_time=Date.now()-l,c.push(_)}})();return l=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await Np.async_set_timeout(e),await o.drain(),await s.close(),await u,c}a(ete,"getServerList");async function ly(e,t){let{jsm:r}=await Ii(),n=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:Gee.File,retention:qee.Limits,subjects:t,discard:$ee.Old,max_msgs:s,max_bytes:i,max_age:n})}a(ly,"createLocalStream");async function j0(){let{jsm:e}=await Ii(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(j0,"listStreams");async function tte(e){let{jsm:t}=await Ii();await t.streams.delete(e)}a(tte,"deleteLocalStream");async function rte(e){let{connection:t}=await Ii(),r=[],n=ay(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(V0.decode(o.data))})();return await t.publish(`$JS.${e}.API.STREAM.LIST`,void 0,{reply:n}),await t.flush(),await s.drain(),await i,r}a(rte,"listRemoteStreams");async function nte(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ii(),i=k0(),o={durable_name:i,ack_policy:iy.Explicit};t&&(o.deliver_policy=oy.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let u=[];for await(let d of l){let _=sy(d.data),E={nats_timestamp:d.info.timestampNanos,nats_sequence:d.info.streamSequence,entry:_};if(d.headers&&(E.origin=d.headers.get(Dr.MSG_HEADERS.ORIGIN)),u.push(E),d.ack(),d.info.pending===0)break}return await c.delete(),u}a(nte,"viewStream");async function*ste(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ii(),i=k0(),o={durable_name:i,ack_policy:iy.Explicit};t&&(o.deliver_policy=oy.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let u of l){let d=sy(u.data);d[0]||(d=[d]);for(let _ of d){let E={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:_};u.headers&&(E.origin=u.headers.get(Dr.MSG_HEADERS.ORIGIN)),yield E}if(u.ack(),u.info.pending===0)break}await c.delete()}a(ste,"viewStreamIterator");async function ite(e,t,r,n){js.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=z0(n,r);let{js:s}=await Ii(),i=await wp(),o=`${e}.${i}`,c=n instanceof Uint8Array?n:q0.encode(n);try{js.trace(`publishToStream publishing to subject: ${o}`),jee(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(ite,"publishToStream");function z0(e,t){t===void 0&&(t=Kee());let r=br.get(Je.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Dr.MSG_HEADERS.ORIGIN)&&r&&t.append(Dr.MSG_HEADERS.ORIGIN,r),t}a(z0,"addNatsMsgHeader");function eu(e){e=e.toLowerCase();let t=V_.join(br.get(Je.CONFIG_PARAMS.ROOTPATH),zee);if(e===Je.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return yc(ry)&&(ry={port:q_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:q_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Dr.SERVER_SUFFIX.HUB,config_file:Dr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:V_.join(t,Dr.PID_FILES.HUB),hdb_nats_path:t}),ry;if(e===Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return yc(ty)&&(ty={port:q_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:q_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Dr.SERVER_SUFFIX.LEAF,config_file:Dr.NATS_CONFIG_FILES.LEAF_SERVER,domain:q_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Dr.SERVER_SUFFIX.LEAF,pid_file_path:V_.join(t,Dr.PID_FILES.LEAF),hdb_nats_path:t}),ty;js.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(eu,"getServerConfig");async function Q0(e,t,r,n){try{await e.consumers.add(t,{ack_policy:iy.Explicit,durable_name:r,deliver_policy:oy.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(Q0,"createConsumer");async function ote(e,t,r){await e.consumers.delete(t,r)}a(ote,"removeConsumer");function ate(e){return e.split(".")[1]}a(ate,"extractServerName");async function cte(e,t,r=6e4,n=ay()){if(!Np.isObject(t))throw new Error("data param must be an object");let s=q0.encode(t),{connection:i}=await Ii(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return sy(c.data)}a(cte,"request");function uy(e){return new Promise(async(t,r)=>{let n=Uee(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 lte(){let{pid_file_path:e}=eu(Je.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await uy(e)}a(lte,"reloadNATSHub");async function ute(){let{pid_file_path:e}=eu(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await uy(e)}a(ute,"reloadNATSLeaf");function dte(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(dte,"requestErrorHandler");async function _te(e,t){let r=t+Dr.SERVER_SUFFIX.LEAF,{connection:n}=await Ii(),{jsm:s}=await gte(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 ote(s,c,n.info.server_name)}catch(u){js.trace(u)}})}a(_te,"updateRemoteConsumer");async function fte(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&&xee()<br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=ey();await c(o)}await Bee(o),n==="stop"&&await Np.async_set_timeout(1e3)}a(fte,"updateConsumerIterator");function J0(e){return vee.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=mte(e,t,n);await ly(r,[s])}a(X0,"createLocalTableStream");async function Ete(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(Ete,"createTableStreams");async function Z0(e,t,r=void 0){if(br.get(Je.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=Ip.createNatsTableStreamName(e,t),{domain:s}=eu(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await K_()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")js.warn(n);else throw n}}a(Z0,"purgeTableStream");async function hte(e,t){if(br.get(Je.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await Z0(e,t[r])}a(hte,"purgeSchemaTableStreams");async function pte(e){return(await Y_()).streams.info(e)}a(pte,"getStreamInfo");function mte(e,t,r){return`${Dr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(mte,"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 Ste(){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=Tte(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(Ste,"updateLocalStreams");function Tte(e){let{config:t}=e,r=!1,n=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}a(Tte,"updateStreamLimits");async function gte(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(gte,"connectToRemoteJS")});var bc=N(Dp=>{var Cp=W();for(let e of["trace","debug","info","warn","error","fatal","notify"])Cp.logsAtLevel(e)&&(Dp[e]=Cp[e]);Dp.loggerWithTag=e=>Cp.loggerWithTag(e,!0);Dp.setLogLevel=Cp.setLogLevel});function dy(e){let t=e.get(Pp),r=t?(0,tu.unpack)(t):null;r||(r={remoteNameToId:{}});let n=ot(),s=!1;r.nodeName=ot();let i=r.remoteNameToId;if(i[n]!==0){let o=0,c;for(let l in i){let u=i[l];u===0?c=l:u>o&&(o=u)}if(c){o++,i[c]=o;let l=[Symbol.for("seq"),o];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:j_(e)??1,nodes:[]})})}i[n]=0,e.putSync(Pp,(0,tu.pack)(r))}return r}function W_(e){return dy(e).remoteNameToId}function rB(e,t,r){let n=dy(r),s=n.remoteNameToId,i=new Map,o=!1;for(let c in t){let l=t[c],u=s[c];if(u==null){let d=0;for(let _ in s){let E=s[_];E>d&&(d=E)}u=d+1,s[c]=u,o=!0}i.set(l,u)}return o&&r.putSync(Pp,(0,tu.pack)(n)),i}function Lp(e,t){let r=dy(t),n=r.remoteNameToId,s=n[e];if(s==null){let i=0;for(let o in n){let c=n[o];c>i&&(i=c)}s=i+1,n[e]=s,t.putSync(Pp,(0,tu.pack)(r))}return tB.info?.("The remote node name map",e,n,s),s}var tB,tu,Pp,_y=Ne(()=>{tB=L(bc());us();tu=require("msgpackr"),Pp=Symbol.for("remote-ids");a(dy,"getIdMappingRecord");a(W_,"exportIdMapping");a(rB,"remoteToLocalNodeId");a(Lp,"getIdOfRemoteNode")});var ea,fy=Ne(()=>{ea=class{constructor(t){this.error=t}static{a(this,"ErrorResource")}isError=!0;allowRead(){throw this.error}allowUpdate(){throw this.error}allowCreate(){throw this.error}allowDelete(){throw this.error}getId(){throw this.error}getContext(){throw this.error}get(){throw this.error}post(){throw this.error}put(){throw this.error}delete(){throw this.error}connect(){throw this.error}getResource(){return this}publish(){throw this.error}subscribe(){throw this.error}}});var iB={};je(iB,{Resources:()=>Mp,keyArrayToString:()=>ru,resetResources:()=>Rte,resources:()=>wi});function Rte(){return wi=new Mp}function ru(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var nB,sB,Mp,wi,nu=Ne(()=>{mc();fy();nB=L(W()),sB=L(_e()),Mp=class extends Map{static{a(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,exportTypes:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s){let c=new sB.ServerError(`Conflicting paths for ${t}`);nB.default.error(c),i.Resource=new ea(c)}super.set(t,i);for(let[c,l]of this){let u=2;for(;(u=c.indexOf("/",u))>-1;){let d=this.get(c.slice(0,u));d&&(d.hasSubPaths=!0),u+=2}}}getMatch(t,r){let n=2,s;for(;(n=t.indexOf("/",n))>-1;){let c=t.slice(0,n),l=this.get(c);if(!l&&c.indexOf(".")>-1){let u=c.split(".");l=this.get(u[0])}if(l&&(!r||l.exportTypes?.[r]!==!1)){if(l.relativeURL=t.slice(n),!l.hasSubPaths)return l;s=l}n+=2}if(s)return s;let i=t.indexOf("?"),o=i>-1?t.slice(0,i):t;return s=this.get(o),!s&&o.indexOf(".")>-1&&(s=this.get(o.split(".")[0])),s&&(!r||s.exportTypes?.[r]!==!1)?s.relativeURL=i>-1?t.slice(i):"":s||(s=this.get(""),s&&(!r||s.exportTypes?.[r]!==!1)&&(t[0]!=="/"&&(t="/"+t),s.relativeURL=t)),s}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return Dt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(Rte,"resetResources");a(ru,"keyArrayToString")});function py(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=aB,Ate(e.primaryStore,e.auditStore)):(c=oB,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{cB(oB[i])})));let l=c[i]||(c[i]=[]);if(l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now()),s?.scope==="full-database")return;let u=l[o];u||(u=l[o]=new Map,u.envs=l,u.tableId=o,u.store=e.primaryStore),t=ru(t);let d=new hy(r);d.startTime=n;let _=u.get(t);return _?_.push(d):(u.set(t,_=[d]),_.tables=u,_.key=t),d.subscriptions=_,d}function cB(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),lB(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=Ht(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,l=ru(c),u=0;do{let d=o.get(l);if(d){for(let E of d)if(!(u>0&&!(E.includeDescendants&&!(E.onlyChildren&&u>1)))){if(E.startTime>=n){(0,Ey.info)("omitting",c,E.startTime,n);continue}try{let f;E.supportsTransactions&&E.txnInProgress!==i.version&&(f=!0,E.txnInProgress||(r?r.push(E):r=[E]),E.txnInProgress=i.version),E.listener(c,i,n,f)}catch(f){console.error(f),(0,Ey.info)(f)}}}if(l==null)break;let _=l.lastIndexOf?.("/",l.length-2);_>-1?l=l.slice(0,_):l=null,u++}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function Ate(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=Ne(()=>{Ey=L(W());Pl();nu();Ji();oB=Object.create(null),aB=Object.create(null);a(py,"addSubscription");hy=class extends Mn{static{a(this,"Subscription")}listener;subscriptions;startTime;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;if(t){let r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};a(cB,"notifyFromTransactionData");a(Ate,"listenToCommits");a(lB,"nextTransaction");a(uB,"whenNextTransaction")});var pB={};je(pB,{commits_awaiting_replication:()=>ou,getHDBNodeTable:()=>Sr,iterateRoutes:()=>Q_,shouldReplicateToNode:()=>z_,subscribeToNodeUpdates:()=>au});function Sr(){return dB||(dB=Et({table:"hdb_nodes",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"ca"},{attribute:"ca_info"},{attribute:"replicates"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function au(e){Sr().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;hB.debug?.("adding node",n,"on node",ot()," on process",process.pid),server.nodes=server.nodes.filter(s=>s.name!==n),r.type==="put"&&n!==ot()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r)),(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function z_(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&Sr().primaryStore.get(ot())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function yte(){au(e=>{ta({},(t,r)=>{let n=e.name,s=_B.get(n);if(s||_B.set(n,s=new Map),s.has(r))return;let i;for(let o in t)if(i=t[o].auditStore,i)break;if(i){let o=new Float64Array(i.getUserSharedBuffer(["replicated",r,n],new ArrayBuffer(8),{callback:a(()=>{let c=o[0],l=o.lastTime;for(let{txnTime:u,onConfirm:d}of ou.get(r)||[])u>l&&u<=c&&d();o.lastTime=c},"callback")}));o.lastTime=0,s.set(r,o)}})})}function*Q_(e){for(let t of e.routes||[]){let r=t.url,n;if(typeof t=="string"?t.includes("://")?r=t:n=t:n=t.hostname??t.host,n&&!r){let s=su.default.get(iu.CONFIG_PARAMS.REPLICATION_SECUREPORT)??(!su.default.get(iu.CONFIG_PARAMS.REPLICATION_PORT)&&su.default.get(iu.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||su.default.get(iu.CONFIG_PARAMS.REPLICATION_PORT)||su.default.get(iu.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT);let o=i?.lastIndexOf?.(":");o>0&&(i=+i.slice(o+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){fB.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{replicates:!t.subscriptions,url:r,subscription:t.subscriptions,routes:t.routes}}}var fB,EB,su,iu,hB,dB,_B,ou,cu=Ne(()=>{Pe();us();lp();fB=require("worker_threads"),EB=L(_e()),su=L(se()),iu=L(M()),hB=L(bc());server.nodes=[];a(Sr,"getHDBNodeTable");a(au,"subscribeToNodeUpdates");a(z_,"shouldReplicateToNode");_B=new Map;Av((e,t,r)=>{if(r>server.nodes.length)throw new EB.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);ou||(ou=new Map,yte());let n=ou.get(e);return n||(n=[],ou.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(yte,"startSubscriptionToReplications");a(Q_,"iterateRoutes")});var RB={};je(RB,{connectedToNode:()=>Oc,disconnectedFromNode:()=>du,ensureNode:()=>co,requestClusterStatus:()=>gB,startOnMainThread:()=>Ty});async function Ty(e){let t=0,r=ut();for(let i of Object.getOwnPropertyNames(r)){let o=r[i];for(let c in o){let l=o[c];if(l.auditStore){Up.set(i,j_(l.auditStore));break}}}Ci.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes.search([]))i.push(o);for(let o of Q_(e))try{let c=!o.subscriptions;if(c){let u=ot();Sr().primaryStore.get(u)===void 0&&await co(u,{name:u,url:e.url??ra(),replicates:!0})}let l=o.trusted!==!1;if(c&&o.replicates==null&&(o.replicates=!0),i.find(u=>u.url===o.url))continue;s(o)}catch(c){console.error(c)}au(s)});let n;function s(i,o=i?.name){let c=ot()&&o===ot()||ra()&&i?.url===ra();if(c){let _=!!i?.replicates;if(n!==void 0&&n!==_)for(let E of Sr().search([]))E.replicates&&E.name!==o&&s(E,E.name);n=_}if(_t.trace("Setting up node replication for",i),!i){for(let[_,E]of ao){let f;for(let[h,{worker:T,nodes:m}]of E){let g=m[0];if(g&&g.name==o){f=!0;for(let[S,{worker:b}]of E)E.delete(S),_t.warn("Node was deleted, unsubscribing from node",o,S,_),b?.postMessage({type:"unsubscribe-from-node",node:o,database:S,url:_});break}}if(f){ao.get(_).iterator.remove(),ao.delete(_);return}}return}if(c)return;if(!i.url){_t.info(`Node ${i.name} is missing url`);return}let l=ao.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(_t.info(`Added node ${i.name} at ${i.url} for process ${ot()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[_,E]of lu)if(i.url===E.url){lu.delete(_);break}lu.set(i.name,i)}let u=ut();if(l||(l=new Map,ao.set(i.url,l)),l.iterator=ta(e,(_,E,f)=>{f?d(E,!0):d(E,!1)}),i.subscriptions)for(let _ of i.subscriptions){let E=_.database||_.schema;u[E]||(_t.warn(`Database ${E} not found for node ${i.name}, making a subscription anyway`),d(E,!1))}function d(_,E){_t.trace("Setting up replication for database",_,"on node",i.name);let f=l.get(_),h,T=[{replicateByDefault:E,...i}];Up.has(_)&&(T.push({replicateByDefault:E,name:ot(),start_time:Up.get(_),end_time:Date.now(),replicates:!0}),Up.delete(_));let m=z_(i,_),g=Ci.workers.filter(S=>S.name==="http");if(f?(h=f.worker,f.nodes=T):m&&(t=t%g.length,h=g[t++],l.set(_,{worker:h,nodes:T,url:i.url}),h?.on("exit",()=>{l.get(_)?.worker===h&&(l.delete(_),d(_,E))})),m)setTimeout(()=>{let S={type:"subscribe-to-node",database:_,nodes:T};h?h.postMessage(S):uu(S)},bte);else{_t.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[_],Sr().primaryStore.get(ot())?.replicates),Sr().primaryStore.get(ot())?.replicates||(n=!1);let S={type:"unsubscribe-from-node",database:_,url:i.url,name:i.name};h?h.postMessage(S):Bp(S)}}a(d,"onDatabase")}a(s,"onNodeUpdate"),du=a(function(i){try{_t.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(lu.keys()),c=o.sort(),l=c.indexOf(i.name||zs(i.url));if(l===-1){_t.warn("Disconnected node not found in node map",i.name,o);return}let u=ao.get(i.url),d=u?.get(i.database);if(!d){_t.warn("Disconnected node not found in replication map",i.database,u);return}if(d.connected=!1,i.finished)return;let _=d.nodes[0];if(!(_.replicates===!0||_.replicates?.sends||_.subscriptions?.length))return;let E=(l+1)%c.length;for(;l!==E;){let f=c[E],h=lu.get(f);u=ao.get(h.url);let T=u?.get(i.database);if(!T){E=(E+1)%c.length;continue}let{worker:m,nodes:g}=T,S=!1;for(let b of d.nodes){if(g.some(I=>I.name===b.name)){_t.info(`Disconnected node is already failing over to ${f} for ${i.database}`);continue}g.push(b),S=!0}if(!S){_t.info(`Disconnected node ${i.name} has no nodes to fail over to ${f}`);return}d.redirectingTo=T,_t.info(`Failing over ${i.database} from ${i.name} to ${f}`),m?m.postMessage({type:"subscribe-to-node",database:i.database,nodes:g}):uu({database:i.database,nodes:g});return}_t.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){_t.error("Error failing over node",o)}},"disconnectedFromNode"),Oc=a(function(i){let o=ao.get(i.url),c=o?.get(i.database);if(!c){_t.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,o);return}if(c.connected=!0,c.latency=i.latency,c.catchingUpFrom=i.lastSendTime,c.redirectingTo){let{worker:l,nodes:u}=c.redirectingTo,d=u.find(_=>_.name===i.name);c.redirectingTo=null,d&&(u.splice(u.indexOf(d),1),l?l.postMessage({type:"subscribe-to-node",database:i.database,nodes:u}):uu({database:i.database,nodes:u}))}},"connectedToNode"),(0,Ci.onMessageByType)("disconnected-from-node",du),(0,Ci.onMessageByType)("connected-to-node",Oc),(0,Ci.onMessageByType)("request-cluster-status",gB)}function gB(e,t){let r=[];for(let[n,s]of lu)try{let i=ao.get(s.url);_t.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let o=[];if(i){for(let[l,{worker:u,connected:d,nodes:_,latency:E,catchingUpFrom:f}]of i)o.push({database:l,connected:d,latency:E,catching_up_from:f?new Date(f).toISOString():"up-to-date",thread_id:u?.threadId,nodes:_.map(h=>h.name)});let c=(0,Sy.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){_t.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function co(e,t){let r=Sr();e=e??zs(t.url),t.name=e;try{if(t.ca){let s=new TB.X509Certificate(t.ca);t.ca_info={issuer:s.issuer.replace(/\n/g," "),subject:s.subject.replace(/\n/g," "),subject_alt_name:s.subjectAltName,serial_number:s.serialNumber,valid_from:s.validFrom,valid_to:s.validTo}}}catch(s){_t.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(_t.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.put(t);else{t.replicates&&!mB.default.get(SB.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],o=(0,Sy.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let u of o)if((c.database??c.schema)===(u.database??u.schema)&&c.table===u.table){u.publish=c.publish,u.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...o,...i];break}_t.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Ci,vp,_t,Sy,mB,SB,TB,bte,ao,du,Oc,lu,Up,J_=Ne(()=>{Pe();Ci=L(dt());us();vp=require("worker_threads");cu();_t=L(W()),Sy=require("lodash"),mB=L(se()),SB=L(M()),TB=require("crypto"),bte=200,ao=new Map,lu=new Map,Up=new Map;a(Ty,"startOnMainThread");a(gB,"requestClusterStatus");vp.parentPort&&(du=a(e=>{vp.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),Oc=a(e=>{vp.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Ci.onMessageByType)("subscribe-to-node",e=>{uu(e)}),(0,Ci.onMessageByType)("unsubscribe-from-node",e=>{Bp(e)}));a(co,"ensureNode")});var Hp=N((CNe,AB)=>{"use strict";var Ote=M().OPERATIONS_ENUM,gy=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=Ote.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};AB.exports=gy});var bB=N((PNe,yB)=>{"use strict";var Nte={OPERATION:"operation",REFRESH:"refresh"},Ry=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},Ay=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};yB.exports={JWTTokens:Ry,TOKEN_TYPE_ENUM:Nte,JWTRSAKeys:Ay}});var _u=N((MNe,wB)=>{"use strict";var Z_=require("jsonwebtoken"),yy=require("fs-extra"),by=te(),ds=M(),{handleHDBError:fn,hdb_errors:Ite}=_e(),{HTTP_STATUS_CODES:En,AUTHENTICATION_ERROR_MSGS:hn}=Ite,X_=W(),OB=Kh(),Iy=xn(),wte=un().update,Cte=Hp(),Dte=no(),{UserEventMsg:Pte}=qs(),na=se();na.initSync();var Oy=require("path"),{JWTTokens:Lte,JWTRSAKeys:Mte,TOKEN_TYPE_ENUM:xp}=bB(),Ute=na.get(ds.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?na.get(ds.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",vte=na.get(ds.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?na.get(ds.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",kp="RS256",Ny;wB.exports={createTokens:Bte,validateOperationToken:xte,refreshOperationToken:Hte,validateRefreshToken:IB,getJWTRSAKeys:ef};async function Bte(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:vte,algorithm:kp,subject:xp.REFRESH}),l=OB.hash(c),u=new Cte(ds.SYSTEM_SCHEMA_NAME,ds.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:l}]),d,_;try{d=await wte(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 Dte.signalUserChange(new Pte(process.pid)),new Lte(o,c)}a(Bte,"createTokens");async function NB(e,t,r){return await Z_.sign(e,{key:t,passphrase:r},{expiresIn:Ute,algorithm:kp,subject:xp.OPERATION})}a(NB,"signOperationToken");async function ef(){if(Ny===void 0)try{let e=Oy.join(na.getHdbBasePath(),ds.LICENSE_KEY_DIR_NAME,ds.JWT_ENUM.JWT_PASSPHRASE_NAME),t=Oy.join(na.getHdbBasePath(),ds.LICENSE_KEY_DIR_NAME,ds.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=Oy.join(na.getHdbBasePath(),ds.LICENSE_KEY_DIR_NAME,ds.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await yy.readFile(e)).toString(),s=(await yy.readFile(t)).toString(),i=(await yy.readFile(r)).toString();Ny=new Mte(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 Hte(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(Hte,"refreshOperationToken");async function xte(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(xte,"validateOperationToken");async function IB(e){let t;try{let r=await ef(),n=await Z_.verify(e,r.public_key,{algorithms:kp,subject:xp.REFRESH});t=await Iy.findAndValidateUser(n.username,void 0,!1)}catch(r){throw X_.warn(r),r.name&&r.name==="TokenExpiredError"?fn(new Error,hn.TOKEN_EXPIRED,En.FORBIDDEN):fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED)}if(!OB.validate(t.refresh_token,e))throw fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED);return t}a(IB,"validateRefreshToken")});var Xs=N(ZB=>{"use strict";var sr=require("path"),pn=require("fs-extra"),fu=require("node-forge"),vB=require("net"),{generateKeyPair:Cy,X509Certificate:lo,createPrivateKey:BB}=require("crypto"),kte=require("util");Cy=kte.promisify(Cy);var yt=fu.pki,Qs=require("joi"),{v4:HB}=require("uuid"),{validateBySchema:My}=Tt(),pt=W(),_s=se(),Es=M(),{CONFIG_PARAMS:Eu}=Es,Js=Sg(),{ClientError:ia}=_e(),Ic=require("node:tls"),{relative:xB,join:Fte}=require("node:path"),{CERT_PREFERENCE_APP:vNe,CERTIFICATE_VALUES:CB}=Js,Gte=Wa(),Dy=wt(),DB=parseInt(process.version.slice(1))<20,{table:qte,getDatabases:$te,databases:wy}=(Pe(),oe(lt)),{getJWTRSAKeys:PB}=_u();Object.assign(ZB,{generateKeys:By,updateConfigCert:YB,createCsr:Jte,signCertificate:Xte,setCertTable:hu,loadCertificates:$B,reviewSelfSignedCert:xy,createTLSSelector:zB,listCertificates:JB,addCertificate:sre,removeCertificate:ore,createNatsCerts:tre,generateCertsKeys:ere,getReplicationCert:rf,getReplicationCertAuth:Qte,renewSelfSigned:rre,hostnamesFromCert:XB,getKey:are});var{urlToNodeName:kB,getThisNodeUrl:Vte,getThisNodeName:Gp,clearThisNodeName:Kte}=(us(),oe(ca)),{readFileSync:Yte,watchFile:Wte,statSync:FB}=require("node:fs"),BNe=se(),{getTicketKeys:jte,onMessageFromWorkers:zte}=dt(),sa=W(),{isMainThread:GB}=require("worker_threads"),{TLSSocket:qB,createSecureContext:HNe}=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."}];zte(async e=>{e.type===Es.ITC_EVENT_TYPES.RESTART&&(_s.initSync(!0),await xy())});var Pr;function aa(){return Pr||(Pr=$te().system.hdb_certificate,Pr||(Pr=qte({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 Qte(){aa();let e=(await rf()).options.cert,r=new lo(e).issuer.match(/CN=(.*)/)?.[1];return Pr.get(r)}a(Qte,"getReplicationCertAuth");var LB,oa=new Map;function $B(){if(LB)return;LB=!0;let e=[{configKey:Eu.TLS},{configKey:Eu.OPERATIONSAPI_TLS}];aa();let t=sr.dirname(Dy.getConfigFilePath()),r;for(let{configKey:n}of e){let s=Dy.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&xB(Fte(t,"keys"),o);c&&MB(o,l=>{oa.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&GB){let d;MB(u,_=>{if(CB.cert===_)return;let E=i.hostname??i.hostnames??i.host??i.hosts;E&&!Array.isArray(E)&&(E=[E]);let f=WB(u),h=new lo(f),T;try{T=ky(h)}catch(b){pt.error("error extracting common name from certificate",b);return}if(T==null){pt.error("error extracting common name from certificate");return}if(h.checkIssued(new lo(CB.cert)))return;let m=Pr.primaryStore.get(T),g=FB(u).mtimeMs,S=!m||m.is_self_signed?1:m.file_timestamp??m.__updatedtime__;if(m&&g<=S){g<S&&pt.info(`Certificate ${T} at ${u} is older (${new Date(g)}) than the certificate in the database (${S>1?new Date(S):"only self signed certificate available"})`);return}r=Pr.put({name:T,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:f,private_key_name:c,is_authority:l,hostnames:E,file_timestamp:g,details:{issuer:h.issuer.replace(/\n/g," "),subject:h.subject.replace(/\n/g," "),subject_alt_name:h.subjectAltName,serial_number:h.serialNumber,valid_from:h.validFrom,valid_to:h.validTo}})},l?"certificate authority":"certificate")}}}}}return r}a($B,"loadCertificates");function MB(e,t,r){let n,s=a((i,o)=>{try{let c=i.mtimeMs;c&&c!==n&&(o&&GB&&pt.warn(`Reloading ${r}:`,e),n=c,t(WB(e)))}catch(c){pt.error(`Error loading ${r}:`,e,c)}},"loadFile");pn.existsSync(e)?s(FB(e)):pt.error(`${r} file not found:`,e),Wte(e,{persistent:!1},s)}a(MB,"loadAndWatch");function Py(){let e=Vte();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 Jte(){let e=await rf(),t=yt.certificateFromPem(e.options.cert),r=yt.privateKeyFromPem(e.options.key);pt.info("Creating CSR with cert named:",e.name);let n=yt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:Fp()},...vy];pt.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:VB()}];return pt.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),fu.pki.certificationRequestToPem(n)}a(Jte,"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 Xte(e){let t={},r=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;aa();for await(let d of Pr.search([]))if(d.is_authority&&!d.details.issuer.includes("HarperDB-Certificate-Authority")){if(oa.has(d.private_key_name)){n=oa.get(d.private_key_name),s=d;break}else if(d.private_key_name&&await pn.exists(sr.join(r,d.private_key_name))){n=pn.readFile(sr.join(r,d.private_key_name)),s=d;break}}if(!n){let d=await Ly();s=d.ca,n=d.private_key}n=yt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=yt.certificateFromPem(s.certificate);pt.info("Signing CSR with cert named",s.name);let o=yt.certificationRequestFromPem(e.csr);try{o.verify()}catch(d){return pt.error(d),new Error("Error verifying CSR: "+d.message)}let c=fu.pki.createCertificate();c.serialNumber=Math.random().toString().slice(2,10),c.validity.notBefore=new Date;let l=new Date;c.validity.notAfter=l,c.validity.notAfter.setDate(l.getDate()+Uy),pt.info("sign cert setting validity:",c.validity),pt.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),pt.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=o.getAttribute({name:"extensionRequest"}).extensions;pt.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=o.publicKey,c.sign(n,fu.md.sha256.create()),t.certificate=yt.certificateToPem(c)}else pt.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(Xte,"signCertificate");async function Zte(e,t){await hu({name:Gp(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await hu({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:yt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(Zte,"createCertificateTable");async function hu(e){let t=new lo(e.certificate);e.details={issuer:t.issuer.replace(/\n/g," "),subject:t.subject.replace(/\n/g," "),subject_alt_name:t.subjectAltName,serial_number:t.serialNumber,valid_from:t.validFrom,valid_to:t.validTo},aa(),await Pr.patch(e)}a(hu,"setCertTable");async function By(){let e=await Cy("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:yt.publicKeyFromPem(e.publicKey),private_key:yt.privateKeyFromPem(e.privateKey)}}a(By,"generateKeys");async function Hy(e,t,r){let n=yt.createCertificate();if(!t){let o=await rf();t=yt.certificateFromPem(o.options.cert).publicKey}n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+Uy);let i=[{name:"commonName",value:Fp()},...vy];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(VB()),n.sign(e,fu.md.sha256.create()),yt.certificateToPem(n)}a(Hy,"generateCertificates");async function Ly(){let e=await JB(),t;for(let r of e){if(!r.is_authority)continue;let n=await QB(r.private_key_name);if(r.private_key_name&&n&&new lo(r.certificate).checkPrivateKey(BB(n))){pt.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;pt.trace("No CA found with matching private key")}a(Ly,"getCertAuthority");async function KB(e,t,r=!0){let n=yt.createCertificate();n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+Uy);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${_s.get(Eu.REPLICATION_HOSTNAME)??kB(_s.get(Eu.REPLICATION_URL))??HB().split("-")[0]}`},...vy];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,fu.md.sha256.create());let o=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME),c=sr.join(o,Js.PRIVATEKEY_PEM_NAME);return r&&await pn.writeFile(c,yt.privateKeyToPem(e)),n}a(KB,"generateCertAuthority");async function ere(){let{private_key:e,public_key:t}=await By(),r=await KB(e,t),n=await Hy(e,t,r);await Zte(n,r),YB()}a(ere,"generateCertsKeys");async function tre(){let e=await Hy(yt.privateKeyFromPem(Js.CERTIFICATE_VALUES.key),void 0,yt.certificateFromPem(Js.CERTIFICATE_VALUES.cert)),t=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME),r=sr.join(t,Js.NATS_CERTIFICATE_PEM_NAME);await pn.exists(r)||await pn.writeFile(r,e);let n=sr.join(t,Js.NATS_CA_PEM_NAME);await pn.exists(n)||await pn.writeFile(n,Js.CERTIFICATE_VALUES.cert)}a(tre,"createNatsCerts");async function rre(){aa();for await(let e of Pr.search([{attribute:"is_self_signed",value:!0}]))await Pr.delete(e.name);await xy()}a(rre,"renewSelfSigned");async function xy(){Kte(),await $B(),aa();let e=await Ly();if(!e){pt.notify("A matching Certificate Authority and key was not found. A new CA will be created in advance, so it's available if needed.");let r=_s.get(Eu.TLS_PRIVATEKEY),n=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME),s,i=xB(n,r);try{s=yt.privateKeyFromPem(await pn.readFile(r))}catch(c){pt.warn("Unable to parse the TLS key",r,"A new key will be generated and used to create Certificate Authority",c),{private_key:s}=await By(),await pn.exists(sr.join(n,Js.PRIVATEKEY_PEM_NAME))&&(i=`privateKey${HB().split("-")[0]}.pem`),await pn.writeFile(sr.join(n,i),yt.privateKeyToPem(s))}let o=await KB(s,yt.setRsaPublicKey(s.n,s.e),!1);await hu({name:o.subject.getField("CN").value,uses:["https"],certificate:yt.certificateToPem(o),private_key_name:i,is_authority:!0,is_self_signed:!0})}if(!await rf()){let r=Gp();pt.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await Ly();let n=yt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await Hy(yt.privateKeyFromPem(e.private_key),s,n);await hu({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(xy,"reviewSelfSignedCert");function YB(){let e=Gte(Object.keys(Es.CONFIG_PARAM_MAP),!0),t=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME),r=sr.join(t,Js.PRIVATEKEY_PEM_NAME),n=sr.join(t,Js.NATS_CERTIFICATE_PEM_NAME),s=sr.join(t,Js.NATS_CA_PEM_NAME),i=Es.CONFIG_PARAMS,o={[i.TLS_PRIVATEKEY]:e[i.TLS_PRIVATEKEY.toLowerCase()]?e[i.TLS_PRIVATEKEY.toLowerCase()]:r};e[i.TLS_CERTIFICATE.toLowerCase()]&&(o[i.TLS_CERTIFICATE]=e[i.TLS_CERTIFICATE.toLowerCase()]),e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.TLS_CERTIFICATEAUTHORITY]=e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATE]=e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]),e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_PRIVATEKEY]=e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY]=e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]),(e[i.CLUSTERING_ENABLED.toLowerCase()]||e.clustering)&&(o[i.CLUSTERING_TLS_CERTIFICATE]=e[i.CLUSTERING_TLS_CERTIFICATE.toLowerCase()]??n,o[i.CLUSTERING_TLS_CERT_AUTH]=e[i.CLUSTERING_TLS_CERT_AUTH.toLowerCase()]??s,o[i.CLUSTERING_TLS_PRIVATEKEY]=e[i.CLUSTERING_TLS_PRIVATEKEY.toLowerCase()]??r),Dy.updateConfigValue(void 0,void 0,o,!1,!0)}a(YB,"updateConfigCert");function WB(e){return e.startsWith("-----BEGIN")?e:Yte(e,"utf8")}a(WB,"readPEM");var UB=Ic.createSecureContext;Ic.createSecureContext=function(e){if(!e.cert||!e.key)return UB(e);let t={...e};delete t.key,delete t.cert;let r=UB(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var jB=Ic.Server;Ic.Server=function(e,t){return e.ALPNCallback&&(e.ALPNProtocols=null),jB.call(this,e,t)};Ic.Server.prototype=jB.prototype;var nre=qB.prototype._init;qB.prototype._init=function(e,t){nre.call(this,e,t);let r=this;this._handle.oncertcb=function(n){let s=n.servername;r._SNICallback(s,(i,o)=>{this.sni_context=o?.context||o,this.certCbDone()})}};var Nc=new Map;function zB(e,t){let r=new Map,n,s=!1;return i.initialize=o=>i.ready?i.ready:(o&&(o.secureContexts=r,o.secureContextsListeners=[]),i.ready=new Promise((c,l)=>{async function u(){try{r.clear(),Nc.clear();let d=0;for await(let _ of wy.system.hdb_certificate.search([])){let E=_.certificate,f=new lo(E);_.is_authority&&(f.asString=E,Nc.set(f.subject,E))}for await(let _ of wy.system.hdb_certificate.search([]))try{if(_.is_authority)continue;let E=e==="operations-api",f=_.is_self_signed?1:2;E&&_.uses?.includes?.("operations")&&(f+=1);let h=await QB(_.private_key_name),T=_.certificate,m=new lo(T);if(Nc.has(m.issuer)&&(T+=`
|
|
15
|
+
`+Nc.get(m.issuer)),!h||!T)throw new Error("Missing private key or certificate for secure server");let g={ciphers:_.ciphers,ticketKeys:jte(),availableCAs:Nc,ca:t&&Array.from(Nc.values()),cert:T,key:h,key_file:_.private_key_name,is_self_signed:_.is_self_signed};o&&(g.sessionIdContext=o.sessionIdContext);let S=Ic.createSecureContext(g);S.name=_.name,S.options=g,S.quality=f,S.certificateAuthorities=Array.from(Nc),S.certStart=T.toString().slice(0,100);let b=_.hostnames??XB(m);Array.isArray(b)||(b=[b]);let I;for(let B of b)if(B){B[0]==="*"&&(s=!0,B=B.slice(1)),B===Py()&&(f+=2),vB.isIP(B)&&(I=!0);let H=r.get(B)?.quality??0;f>H&&r.set(B,S)}else sa.error("No hostname found for certificate at",Ic.certificate);sa.trace("Adding TLS",S.name,"for",o.ports||"client","cert named",_.name,"hostnames",b,"quality",f,"best quality",d),f>d&&(i.defaultContext=n=S,d=f,o&&(o.defaultContext=S))}catch(E){sa.error("Error applying TLS for",_.name,E)}o?.secureContextsListeners.forEach(_=>_()),c(n)}catch(d){l(d)}}a(u,"updateTLS"),wy.system.hdb_certificate.subscribe({listener:u,omitCurrent:!0}),u()})),i;function i(o,c){sa.info("TLS requested for",o||"(no SNI)",this.isReplicationConnection);let l=o;for(;;){let d=r.get(l);if(d)return sa.debug("Found certificate for",o,d.certStart),d.replicationContext&&(this.isReplicationConnection||DB)&&(d=d.replicationContext),c(null,d);if(s&&l){let _=l.indexOf(".",1);_<0?l="":l=l.slice(_)}else break}o?sa.debug("No certificate found to match",o,"using the default certificate"):sa.debug("No SNI, using the default certificate",n?.name);let u=n;u?u.replicationContext&&(this.isReplicationConnection||DB)&&(u=u.replicationContext):sa.info("No default certificate found"),c(null,u)}a(i,"SNICallback")}a(zB,"createTLSSelector");async function QB(e){let t=oa.get(e);return!t&&e?await pn.readFile(sr.join(_s.get(Eu.ROOTPATH),Es.LICENSE_KEY_DIR_NAME,e),"utf8"):t}a(QB,"getPrivateKeyByName");async function JB(){aa();let e=[];for await(let t of Pr.search([]))e.push(t);return e}a(JB,"listCertificates");async function sre(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 _=ire(r??d);s&&!c&&!l&&(await pn.writeFile(sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME,_+".pem"),s),oa.set(_,s));let E={name:r??d,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&u||i&&s)&&(E.private_key_name=u??_+".pem"),await hu(E),"Successfully added certificate: "+_}a(sre,"addCertificate");function ire(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(ire,"sanitizeName");async function ore(e){let t=My(e,Qs.object({name:Qs.string().required()}));if(t)throw new ia(t.message);let{name:r}=e;aa();let n=await Pr.get(r);if(!n)throw new ia(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await Pr.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(pt.info("Removing private key named",s),await pn.remove(sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME,s)))}return await Pr.delete(r),"Successfully removed "+r}a(ore,"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 are(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(are,"getKey")});async function Ky(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=ot(),i;if(e.includes("wss://")){if(!Gy){let l=(0,EH.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,pH.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=hH.createSecureContext({...i.options,ca:Array.from(Cc)})),new _H.WebSocket(e,"harperdb-replication-v1",c)}function Yp(e,t,r){let n=t.port||t.securePort,s=Vy.pid%1e3+"-"+fH.threadId+(n?"s:"+n:"c:"+t.url?.slice(-4))+" "+Math.random().toString().slice(2,3),i=0,o=Buffer.allocUnsafeSlow(1024),c=0,l=new DataView(o.buffer,0,1024),u=t.database,d=t.databaseSubscriptions||wc,_,E,f=!1,h=t.subscription;h?.then&&h.then(ie=>h=ie);let T=t.tables||u&&ut()[u];if(!r){fe.error?.("No authorization provided"),ss(1008,"Unauthorized");return}let m=new Map,g=[],S=r.name;S&&t.connection&&(t.connection.nodeName=S);let b,I,B,H,X,Y,V=1e3,ne,Q=0,de=0,j=0,ae=0;if(t.url){let ie=a(()=>{X&&j===e._socket?.bytesRead&&ae===e._socket?.bytesWritten?e.terminate():(X=performance.now(),e.ping(),j=e._socket?.bytesRead,ae=e._socket?.bytesWritten)},"send_ping");B=setInterval(ie,uH).unref(),ie()}else Ae();function Ae(){clearTimeout(H),j=e._socket?.bytesRead,ae=e._socket?.bytesWritten,H=setTimeout(()=>{j===e._socket?.bytesRead&&ae===e._socket?.bytesWritten&&(fe.warn?.(`Timeout waiting for ping from ${S}, terminating connection and reconnecting`),e.terminate())},uH*2).unref()}a(Ae,"resetPingTimer"),u&&Va(u);let ye,Me,Gr=[],Cd=[],ka,wn=[],Dd=[],Ol=[],vw=150,jE=0,vt=0,Fa,Ga,vs,Bs,zE;e.on("message",ie=>{Q=performance.now();try{let Se=ie.dataView=new Dc(ie.buffer,ie.byteOffset,ie.byteLength);if(ie[0]>127){let R=(0,ct.decode)(ie),[w,A,y]=R;switch(w){case tH:{if(A){if(S){if(S!==A){fe.error?.(s,`Node name mismatch, expecting to connect to ${S}, but peer reported name as ${A}, disconnecting`),e.send((0,ct.encode)([pu])),ss(1008,"Node name mismatch");return}}else if(S=A,t.connection?.tentativeNode){let x=t.connection.tentativeNode;x.name=S,t.connection.tentativeNode=null,co(S,x)}if(t.connection&&(t.connection.nodeName=S),fe.debug?.(s,"received node name:",S,"db:",u),!u)try{Va(u=R[2]),u==="system"&&(ye=ta(t,(x,q)=>{$a(q)&&Ir(q)}),e.on("close",()=>{ye?.remove()}))}catch(x){fe.warn?.(s,"Error setting database",x),e.send((0,ct.encode)([pu])),ss(1008,x.message);return}qa()}break}case cH:{fe.debug?.(s,"Received table definitions for",A.map(x=>x.table));for(let x of A){let q=R[2];x.database=q;let ee;$a(q)&&(q==="system"?We[q]?.[x.table]||(ee=qy(x,We[q]?.[x.table])):ee=qy(x,We[q]?.[x.table]),_||(_=ee?.auditStore),T||(T=ut()?.[q]))}break}case pu:ss();break;case iH:try{let x=r?.replicates||r?.subscribers||r?.name;server.operation(A,{user:r},!x).then(q=>{Array.isArray(q)&&(q={results:q}),q.requestId=A.requestId,e.send((0,ct.encode)([$p,q]))},q=>{e.send((0,ct.encode)([$p,{requestId:A.requestId,error:q instanceof Error?q.toString():q}]))})}catch(x){e.send((0,ct.encode)([$p,{requestId:A.requestId,error:x instanceof Error?x.toString():x}]))}break;case $p:let{resolve:D,reject:O}=m.get(A.requestId);A.error?O(new Error(A.error)):D(A),m.delete(A.requestId);break;case Fy:let v=R[3];T||(u?fe.error?.(s,"No tables found for",u):fe.error?.(s,"Database name never received"));let k=T[v];k=qy({table:v,database:u,attributes:A.attributes,schemaDefined:A.schemaDefined},k),Gr[y]={name:v,decoder:new ct.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:A.typedStructs,structures:A.structures}),getEntry(x){return k.primaryStore.getEntry(x)},rootStore:k.primaryStore.rootStore};break;case rH:zE=_?rB(S,A,_):new Map,ka=R[2],fe.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${ka}`);break;case nH:let C=y;Ol[C]=A;break;case aH:let F=["replicated",u,S];E||(E=new Float64Array(_.getUserSharedBuffer(F,new ArrayBuffer(8)))),E[0]=A,fe.trace?.(s,"received and broadcasting committed update",A),E.buffer.notify();break;case oH:b=A,h.send({type:"end_txn",localTime:b,remoteNodeIds:g});break;case sH:{let x=A,q;try{let ee=R[3],G=Cd[y]||(Cd[y]=T[R[4]]);if(!G)return fe.warn?.("Unknown table id trying to handle record request",y);let be=G.primaryStore.getBinaryFast(Symbol.for("structures")),Ee=be.length;if(Ee!==vt){vt=Ee;let re=(0,ct.decode)(be);e.send((0,ct.encode)([Fy,{typedStructs:re.typed,structures:re.named},y,G.tableName]))}let Re=G.primaryStore.getBinaryFast(ee);if(Re){let re=G.primaryStore.decoder.decode(Re,{valueAsBuffer:!0});q=(0,ct.encode)([qp,x,{value:re.value,expiresAt:re.expiresAt,version:re.version,residencyId:re.residencyId,nodeId:re.nodeId,user:re.user}])}else q=(0,ct.encode)([qp,x])}catch(ee){q=(0,ct.encode)([qp,x,{error:ee.message}])}e.send(q);break}case qp:{let{resolve:x,reject:q,tableId:ee,key:G}=m.get(R[1]),be=R[2];if(be?.error)q(new Error(be.error));else if(be){let Ee=Gr[ee].decoder.decode(be.value);be.value=Ee,be.key=G,x(be)}else x();m.delete(R[1]);break}case eH:{Bs=A;let x,q,ee=!1;if(h){if(u!==h.databaseName&&!h.then){fe.error?.("Subscription request for wrong database",u,h.databaseName);return}}else h=d.get(u);if(fe.debug?.(s,"received subscription request for",u,"at",Bs),!h){let ce;h=new Promise(Ye=>{fe.debug?.("Waiting for subscription to database "+u),ce=Ye}),h.ready=ce,wc.set(u,h)}if(r.name)q=Sr().subscribe(r.name),q.then(async ce=>{x=ce;for await(let Ye of x){let rt=Ye.value;if(!(rt?.replicates===!0||rt?.replicates?.receives||rt?.subscriptions?.some(Ze=>(Ze.database||Ze.schema)===u&&Ze.publish!==!1))){ee=!0,e.send((0,ct.encode)([pu])),ss(1008,`Unauthorized database subscription to ${u}`);return}}},ce=>{fe.error?.(s,"Error subscribing to HDB nodes",ce)});else if(!(r?.role?.permission?.super_user||r.replicates)){e.send((0,ct.encode)([pu])),ss(1008,`Unauthorized database subscription to ${u}`);return}if(vs&&(fe.debug?.(s,"stopping previous subscription",u),vs.emit("close")),Bs.length===0)return;let G=Bs[0],be=a(ce=>{if(ce&&(G.replicateByDefault?!G.tables.includes(ce.tableName):G.tables.includes(ce.tableName)))return{table:ce}},"tableToTableEntry"),Ee={txnTime:0},Re,re,K=1/0,Te,Be=a((ce,Ye)=>{if(K=Ye,ce.type==="end_txn"){Ee.txnTime&&(o[i]!==66&&fe.error?.("Invalid encoding of message"),di(9),di(Kp),Ka(Te=Ye),Ie()),i=c,Ee.txnTime=0;return}let rt=ce.nodeId,Ze=ce.tableId,st=re[Ze];if(!st&&(st=re[Ze]=be(h.tableById[Ze]),!st))return fe.debug?.("Not subscribed to table",Ze);let Kt=st.table,ko=Kt.primaryStore,Yt=ko.encoder;(ce.extendedType&Oh||!Yt.typedStructs)&&(Yt._mergeStructures(Yt.getStructures()),Yt.typedStructs&&(Yt.lastTypedStructuresLength=Yt.typedStructs.length));let QE=Re[rt];if(!(QE&&QE.startTime<Ye&&(!QE.endTime||QE.endTime>Ye)))return nf&&fe.trace?.(s,"skipping replication update",ce.recordId,"to:",S,"from:",rt,"subscribed:",Re),Bw();nf&&fe.trace?.(s,"sending replication update",ce.recordId,"to:",S,"from:",rt,"subscribed:",Re);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"),Ie()),Ee.txnTime=ZT,i=c,Ka(ZT));let Ya=ce.residencyId,eg=ji(Ya,Kt),JE;if(eg&&!eg.includes(S)){let Il=ji(ce.previousResidencyId,Kt);if(Il&&!Il.includes(S)&&(ce.type==="put"||ce.type==="patch")||Kt.getResidencyById)return Bw();let Ud=ce.recordId;fe.trace?.(s,"sending invalidation",Ud,S,"from",rt);let ng=0;Ya&&(ng|=tc),ce.previousResidencyId&&(ng|=rc);let sg,XE=null;for(let Hw in Kt.indices){if(!XE){if(sg=ce.getValue(ko,!0),!sg)break;XE={}}XE[Hw]=sg[Hw]}JE=Ml(ce.version,Ze,Ud,null,rt,ce.user,ce.type==="put"||ce.type==="patch"?"invalidate":ce.type,Yt.encode(XE),ng,Ya,ce.previousResidencyId,ce.expiresAt)}function Bw(){fe.trace?.(s,"skipping audit record",ce.recordId),Y||(Y=setTimeout(()=>{Y=null,(Te||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:Kt.attributes,schemaDefined:Kt.schemaDefined},Ze,st.table.tableName]))),Ya&&!Dd[Ya]&&(e.send((0,ct.encode)([nH,eg,Ya])),Dd[Ya]=!0),JE)di(JE.length),Md(JE);else{let Il=ce.encoded,Ud=Il[0]===66?8:0;di(Il.length-Ud),Md(Il,Ud)}},"sendAuditRecord"),Ie=a(()=>{c-i>8?(e.send(o.subarray(i,c)),fe.debug?.(s,"Sent message, size:",c-i)):fe.debug?.(s,"skipping empty transaction")},"sendQueuedData");vs=new $y.EventEmitter,vs.once("close",()=>{ee=!0,x?.end()});for(let{startTime:ce}of Bs)ce<K&&(K=ce);(q||Promise.resolve()).then(async()=>{h=await h,_=h.auditStore,re=h.tableById.map(be),Re=[];for(let{name:Ye,startTime:rt,endTime:Ze}of Bs){let st=Lp(Ye,_);fe.debug?.("subscription to",Ye,"using local id",st,"starting",rt),Re[st]={startTime:rt,endTime:Ze}}Ir(u),ye||(ye=Pc(Ye=>{Ye.databaseName===u&&Ir(u)}),Me=sf(Ye=>{Ye===u&&(e.send((0,ct.encode)([pu])),ss())}),e.on("close",()=>{ye?.remove(),Me?.remove()})),e.send((0,ct.encode)([rH,W_(h.auditStore),Bs.map(({name:Ye})=>Ye)]));let ce=!0;do{isFinite(K)||(fe.warn?.("Invalid sequence id "+K),ss(1008,"Invalid sequence id"+K));let Ye;if(ce&&!ee&&(ce=!1,!(Yy(_)<=K)&&server.nodes[0]?.name===S)){fe.info?.("Replicating all tables to",S);let Ze=K,st=Wp(_);for(let Kt in T){let ko=T[Kt];for(let Yt of ko.primaryStore.getRange({snapshot:!1})){if(ee)return;Yt.localTime>=K&&(fe.trace?.(s,"Copying record from",u,Kt,Yt.key,Yt.localTime),Ze=Math.max(Yt.localTime,Ze),Ye=!0,Be({recordId:Yt.key,tableId: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=Ht(Ze);Be(st,rt),e._socket.writableNeedDrain?await new Promise(Kt=>e._socket.once("drain",Kt)):await new Promise(setImmediate),vs.startTime=rt,Ye=!0}Ye&&Be({type:"end_txn"},K),de=0,await uB(_)}while(!ee)}).catch(ce=>{fe.error?.(s,"Error handling subscription to node",ce),ss(1008,"Error handling subscription to node")});break}}return}Se.position=8;let tt=!0,U,p;do{let R=Se.readInt();if(R===9&&Se.getUint8(Se.position)==Kp){Se.position++,b=p=Se.readFloat64(),fe.trace?.("received remote sequence update",b,u);break}let w=Se.position,A=Ht(ie,w,w+R),y=Gr[A.tableId];y||fe.error?.(`No table found with an id of ${A.tableId}`);let D;A.residencyId&&(D=Ol[A.residencyId],fe.trace?.(s,"received residency list",D,A.type,A.recordId));try{U={table:y.name,id:A.recordId,type:A.type,nodeId:zE.get(A.nodeId),residencyList:D,timestamp:A.version,value:A.getValue(y),user:A.user,beginTxn:tt,expiresAt:A.expiresAt}}catch(O){throw O.message+="typed structures for current decoder"+JSON.stringify(y.decoder.typedStructs),O}tt=!1,nf&&fe.trace?.(s,"received replication message",A.type,"id",U.id,"version",A.version,"nodeId",U.nodeId,"value",U.value),h.send(U),Se.position=w+R}while(Se.position<ie.byteLength);jE++,pr(ie.byteLength,"bytes-received",S+"."+u+"."+U.table,"replication","ingest"),jE>vw&&!Fa&&(Fa=!0,e.pause()),h.send({type:"end_txn",localTime:b,remoteNodeIds:g,onCommit(){if(U){let R=Date.now()-U.timestamp;pr(R,"replication-latency",S+"."+u+"."+U.table,U.type,"ingest")}jE--,Fa&&(Fa=!1,e.resume()),!I&&p&&(fe.trace?.(s,"queuing confirmation of a commit at",p),setTimeout(()=>{e.send((0,ct.encode)([aH,I])),fe.trace?.(s,"sent confirmation of a commit at",I),I=null},cre)),I=p}})}catch(Se){fe.error?.(s,"Error handling incoming replication message",Se)}}),e.on("ping",Ae),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-X,Oc({name:S,database:u,url:t.url,lastSendTime:de,latency:t.connection.latency})),X=null}),e.on("close",(ie,Se)=>{clearInterval(B),clearTimeout(H),vs&&vs.emit("close"),Ga&&Ga.end();for(let[tt,{reject:U}]of m)U(new Error(`Connection closed ${Se?.toString()} ${ie}`));fe.debug?.(s,"closed",ie,Se?.toString())});function Ve(){}a(Ve,"recordRemoteNodeSequence");function ss(ie,Se){e.isFinished=!0,e.close(ie,Se)}a(ss,"close");function qa(){if(f||(f=!0,t.connection?.on("subscriptions-updated",qa)),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let ie=new Map;try{for(let U of h?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let p of U.value.nodes||[])p.lastTxnTime>(ie.get(p.id)??0)&&ie.set(p.id,p.lastTxnTime)}catch(U){if(!U.message.includes("Can not re"))throw U}let Se=t.connection?.nodeSubscriptions?.[0];g=[];let tt=t.connection?.nodeSubscriptions.map((U,p)=>{let R=[],{replicateByDefault:w}=U;if(U.subscriptions){for(let O of U.subscriptions)if(O.subscribe&&(O.schema||O.database)===u){let v=O.table;T?.[v]?.replicate!==!1&&R.push(v)}w=!1}else for(let O in T)(w?T[O].replicate===!1:T[O].replicate)&&R.push(O);let A=_&&Lp(U.name,_),y=h?.dbisDB?.get([Symbol.for("seq"),A])??1,D=Math.max(y?.seqId??1,(typeof U.start_time=="string"?new Date(U.start_time).getTime():U.start_time)??1);if(fe.debug?.("Starting time recorded in db",U.name,A,u,y?.seqId,"start time:",D),Se!==U){D>5e3&&(D-=5e3);let O=_&&Lp(Se.name,_),v=h?.dbisDB?.get([Symbol.for("seq"),O])??1;for(let k of v?.nodes||[])k.name===U.name&&(D=k.seqId,fe.debug?.("Using sequence id from proxy node",Se.name,D))}return g.push(A),ie.get(A)>D&&(D=ie.get(A),fe.debug?.("Updating start time from more recent txn recorded",Se.name,D)),{name:U.name,replicateByDefault:w,tables:R,startTime:D,endTime:U.end_time}});if(tt)if(fe.debug?.(s,"sending subscription request",tt,h?.dbisDB?.path),clearTimeout(ne),tt.length>0)e.send((0,ct.encode)([eH,tt]));else{let U=a(()=>{let p=performance.now();ne=setTimeout(()=>{Q<=p?ss(1008,"No nodes to subscribe to"):U()},V)},"schedule_close");U()}}a(qa,"sendSubscriptionRequestUpdate");function ji(ie,Se){if(!ie)return;let tt=wn[ie];return tt||(tt=Se.getResidencyRecord(ie),wn[ie]=tt),tt}a(ji,"getResidence");function $a(ie){return!(la&&la!="*"&&!la[ie]&&!la.includes?.(ie)&&!la.some?.(Se=>Se.name===ie))}a($a,"checkDatabaseAccess");function Va(ie){if(h=h||d.get(ie),!$a(ie))throw new Error(`Access to database "${ie}" is not permitted`);h||fe.warn?.(`No database named "${ie}" was declared and registered`),_=h?.auditStore,T||(T=ut()?.[ie]);let Se=ot();if(Se===S)throw Se?new Error("Should not connect to self",Se):new Error("Node name not defined");return Pd(Se,ie),!0}a(Va,"setDatabase");function Pd(ie,Se){let tt=ut()?.[Se],U=[];for(let p in tt){let R=tt[p];U.push({table:p,schemaDefined:R.schemaDefined,attributes:R.attributes.map(w=>({name:w.name,type:w.type,isPrimaryKey:w.isPrimaryKey}))})}fe.trace?.("Sending database info for node",ie,"database name",Se),e.send((0,ct.encode)([tH,ie,Se,U]))}a(Pd,"sendNodeDBName");function Ir(ie){let Se=ut()?.[ie],tt=[];for(let U in Se){if(Bs&&!Bs.some(R=>R.replicateByDefault?!R.tables.includes(U):R.tables.includes(U)))continue;let p=Se[U];tt.push({table:U,schemaDefined:p.schemaDefined,attributes:p.attributes.map(R=>({name:R.name,type:R.type,isPrimaryKey:R.isPrimaryKey}))})}e.send((0,ct.encode)([cH,tt,ie]))}a(Ir,"sendDBSchema");let Nl=1,Ld=[];return{end(){Ga&&Ga.end(),vs&&vs.emit("close")},getRecord(ie){let Se=Nl++;return new Promise((tt,U)=>{let p=[sH,Se,ie.table.tableId,ie.id];Ld[ie.table.tableId]||(p.push(ie.table.tableName),Ld[ie.table.tableId]=!0),e.send((0,ct.encode)(p)),m.set(Se,{tableId:ie.table.tableId,key:ie.id,resolve(R){let{table:w,entry:A}=ie;tt(R),R&&w._recordRelocate(A,R)},reject:U})})},sendOperation(ie){let Se=Nl++;return ie.requestId=Se,e.send((0,ct.encode)([iH,ie])),new Promise((tt,U)=>{m.set(Se,{resolve:tt,reject:U})})}};function di(ie){xo(5),ie<128?o[c++]=ie:ie<16384?(l.setUint16(c,ie|32768),c+=2):ie<1056964608?(l.setUint32(c,ie|3221225472),c+=4):(o[c]=255,l.setUint32(c+1,ie),c+=5)}function Md(ie,Se=0,tt=ie.length){let U=tt-Se;xo(U),ie.copy(o,c,Se,tt),c+=U}function Ka(ie){xo(8),l.setFloat64(c,ie),c+=8}function xo(ie){if(ie+16>o.length-c){let Se=Buffer.allocUnsafeSlow(c+ie-i+65536>>10<<11);o.copy(Se,0,i,c),c=c-i,i=0,o=Se,l=new DataView(o.buffer,0,o.length)}}}function qy(e,t){let r=e.database??"data";if(r!=="data"&&!We[r]){fe.warn?.("Database not found",e.database);return}t||(t={});let n=!1,s=e.schemaDefined,i=t.attributes||[];for(let o=0;o<e.attributes?.length;o++){let c=e.attributes[o],l=i[o];(!l||l.name!==c.name||l.type!==c.type)&&(n=!0,s||(c.indexed=!0),i[o]=c)}return n?(fe.debug?.("(Re)creating",e),Et({table:e.table,database:e.database,schemaDefined:e.schemaDefined,attributes:i,...t})):t}var ct,_H,fH,fe,$y,EH,hH,Vy,pH,eH,tH,rH,pu,nH,Fy,sH,qp,iH,$p,oH,aH,cH,mH,wc,nf,lH,cre,uH,Gy,dH,Vp,SH=Ne(()=>{Pe();Ji();_y();my();us();Ul();ct=require("msgpackr"),_H=require("ws"),fH=require("worker_threads"),fe=L(bc());J_();$y=require("events"),EH=L(Xs()),hH=L(require("node:tls"));cu();Vy=L(require("node:process")),pH=require("node:net");Ni();eH=129,tH=140,rH=141,pu=142,nH=130,Fy=132,sH=133,qp=134,iH=136,$p=137,oH=143,aH=144,cH=145,mH=new Map,wc=new Map,nf=!0,lH=300,cre=2,uH=3e4;a(Ky,"createWebSocket");dH=1e3,Vp=class extends $y.EventEmitter{constructor(r,n,s,i,o){super();this.url=r;this.subscription=n;this.databaseName=s;this.nodeName=i;this.authorization=o;this.nodeName=this.nodeName??zs(r)}static{a(this,"NodeReplicationConnection")}socket;startTime;retryTime=dH;retries=0;isConnected=!0;isFinished=!1;nodeSubscriptions=[];latency=0;replicateTablesByDefault;session;sessionResolve;sessionReject;async connect(){this.session||this.resetSession();let r=[];this.socket=await Ky(this.url,{serverName:this.nodeName,authorization:this.authorization});let n;fe.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${Vy.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),fe.info?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=dH,Oc({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=Yp(this.socket,{database:this.databaseName,subscription:this.subscription,url:this.url,connection:this},{replicates:!0}),this.sessionResolve(n)}),this.socket.on("error",s=>{s.code==="SELF_SIGNED_CERT_IN_CHAIN"?(fe.warn?.(`Can not connect to ${this.url}, this server does not have a certificate authority for the certificate provided by ${this.url}`),s.isHandled=!0):s.code!=="ECONNREFUSED"&&(s.code==="UNABLE_TO_VERIFY_LEAF_SIGNATURE"?fe.error?.(`Can not connect to ${this.url}, the certificate provided by ${this.url} is not trusted, this node needs to be added to the cluster, or a certificate authority needs to be added`):fe.error?.(`Error in connection to ${this.url} due to ${s.message}`)),this.sessionReject(s)}),this.socket.on("close",(s,i)=>{if(this.isConnected&&(du({name:this.nodeName,database:this.databaseName,url:this.url,finished:this.socket.isFinished}),this.isConnected=!1),this.socket.isFinished){this.isFinished=!0,n?.end(),this.emit("finished");return}if(++this.retries%20===1){let o=i?.toString();fe.warn?.(`${n?"Disconnected from":"Failed to connect to"} ${this.url} (db: "${this.databaseName}"), due to ${o?'"'+o+'" ':""}(code: ${s})`)}n=null,this.resetSession(),setTimeout(()=>{this.connect()},this.retryTime).unref(),this.retryTime+=this.retryTime>>3})}resetSession(){this.session=new Promise((r,n)=>{this.sessionResolve=r,this.sessionReject=n})}subscribe(r,n){this.nodeSubscriptions=r,this.replicateTablesByDefault=n,this.emit("subscriptions-updated",r)}unsubscribe(){this.socket.isFinished=!0,this.socket.close(1008,"No longer subscribed")}getRecord(r){return this.session.then(n=>n.getRecord(r))}};a(Yp,"replicateOverWS");a(qy,"ensureTableIfChanged")});var ca={};je(ca,{clearThisNodeName:()=>pre,disableReplication:()=>_re,enabled_databases:()=>la,forEachReplicatedDatabase:()=>ta,getThisNodeId:()=>Wp,getThisNodeName:()=>ot,getThisNodeUrl:()=>ra,hostnameToUrl:()=>Jp,lastTimeInAuditStore:()=>j_,monitorNodeCAs:()=>NH,replicateOperation:()=>Sre,replication_certificate_authorities:()=>Cc,sendOperationToNode:()=>af,servers:()=>ure,setReplicator:()=>wH,start:()=>dre,startOnMainThread:()=>Ty,subscribeToNode:()=>uu,unsubscribeFromNode:()=>Bp,urlToNodeName:()=>zs});function dre(e){if(e.port||(e.port=hs.default.get(Lc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=hs.default.get(Lc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),!ot())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let n of Q_(e))t.set(zs(n.url),n);fre(e),e={mtls:!0,isOperationsServer:!0,maxPayload:10*1024*1024*1024,...e};let r=it.ws(async(n,s,i,o)=>{if(s.headers.get("sec-websocket-protocol")!=="harperdb-replication-v1")return o(n,s,i);await i,n._socket.unref(),Yp(n,e,s?.user),n.on("error",c=>{c.code!=="ECONNREFUSED"&&Tr.error("Error in connection to "+this.url,c.message)})},e);e.runFirst=!0,it.http((n,s)=>{if(n.isWebSocket&&n.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){!n.authorized&&n._nodeRequest.socket.authorizationError&&Tr.error(`Incoming client connection from ${n.ip} did not have valid certificate, you may need turn on enableRootCAs in the config if you are using a publicly signed certificate, or add the CA to the server's trusted CAs`,n._nodeRequest.socket.authorizationError);let i=Sr().primaryStore;if(n.authorized&&n.peerCertificate.subject){let o=n.peerCertificate.subject,c=o&&(i.get(o.CN)||t.get(o.CN));c?n.user=c:Tr.warn(`No node found for certificate common name ${o.CN}, available nodes are ${Array.from(i.getRange({}).filter(({value:l})=>l).map(({key:l})=>l)).join(", ")} and routes ${Array.from(t.keys()).join(", ")}, connection will require credentials.`)}else{let o=i.get(n.ip)||t.get(n.ip);o?n.user=o:Tr.warn(`No node found for IP address ${n.ip}, available nodes are ${Array.from(new Set([...i.getKeys(),...t.keys()])).join(", ")}, connection will require credentials.`)}}return s(n)},e);for(let n of r)if(n.secureContexts){let s=a(()=>{let i=new Set(n.secureContexts.values());n.defaultContext&&i.add(n.defaultContext);for(let o of i)try{let c=Array.from(Cc);o.options.availableCAs&&c.push(...o.options.availableCAs.values());let l={...o.options,ca:c};o.replicationContext=Qp.createSecureContext(l)}catch(c){Tr.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),NH(s),hs.default.get(Lc.CONFIG_PARAMS.REPLICATION_ENABLEROOTCAS)!==!1&&s()}}function NH(e){let t=0;au(r=>{r?.ca&&(Cc.add(r.ca),Cc.size!==t&&(t=Cc.size,e?.()))})}function _re(e=!0){OH=e}function fre(e){OH||(ut(),la=e.databases,ta(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||wc;for(let[s,i]of of){let o=i.get(r);o&&(o.subscribe([],!1),i.delete(r))}n.delete(r);return}for(let n in t){let s=t[n];wH(r,s,e),mH.get(s)?.forEach(i=>i(s))}}))}function wH(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 IH extends Lr{static{a(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||wc,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(Tr.trace("Setting up replicator subscription to database",e),!o?.auditStore)return this.subscription=o=new Mn,i.set(e,o),o.tableById=c,o.auditStore=t.auditStore,o.dbisDB=t.dbisDB,o.databaseName=e,l&&l(o),o;this.subscription=o}static subscribeOnThisThread(i,o){return!0}static async load(i){if(i){let o=i.residencyId,c=i.residency||t.dbisDB.get([Symbol.for("residency_by_id"),o]);if(c){let l,u=new Set;do{let d;for(let E of c){let f=Ere(E,IH.subscription,e);f?.isConnected&&!u.has(f)&&(!d||f.latency<d.latency)&&(d=f)}if(!d)throw l||new yH.ServerError("No connection to any other nodes are available",502);let _={requestId:lre++,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 CH(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 Ere(e,t,r){let n=TH.get(e)?.get(r);if(n)return n;let s=Sr().primaryStore.get(e);return s?.url&&(n=CH(s.url,t,r,e,s.authorization),TH.set(e,of.get(s.url))),n}async function af(e,t,r){r||(r={}),r.serverName=e.name;let n=await Ky(e.url,r),s=Yp(n,{},{});return new Promise((i,o)=>{n.on("open",()=>{i(s.sendOperation(t))}),n.on("error",c=>{o(c)}),n.on("close",c=>{Tr.info("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function uu(e){try{bH.isMainThread&&Tr.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=wc.get(e.database);if(!t){let n;t=new Promise(s=>{Tr.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,wc.set(e.database,t)}let r=CH(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 hre(){if(Wy!==void 0)return Wy;let e=hs.default.get(Lc.CONFIG_PARAMS.OPERATIONSAPI_TLS_CERTIFICATE)||hs.default.get(Lc.CONFIG_PARAMS.TLS_CERTIFICATE);if(e)return Wy=new RH.X509Certificate((0,AH.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function ot(){return zp||(zp=hs.default.get("replication_hostname")??zs(hs.default.get("replication_url"))??hre()??gH("operationsapi_network_secureport")??gH("operationsapi_network_port")??"127.0.0.1")}function pre(){zp=void 0}function gH(e){let t=hs.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function jp(e){let t=hs.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function Wp(e){return W_(e)?.[ot()]}function ra(){let e=hs.default.get("replication_url");return e||Jp(ot())}function Jp(e){let t=jp("replication_port");if(t)return`ws://${e}:${t}`;if(t=jp("replication_secureport"),t)return`wss://${e}:${t}`;if(t=jp("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=jp("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function zs(e){if(e)return new URL(e).hostname}function ta(e,t){for(let n of Object.getOwnPropertyNames(We))r(n);return sf(n=>{r(n)}),Pc((n,s)=>{r(n.databaseName)});function r(n){let s=We[n];Tr.trace("Checking replication status of ",n,e?.databases),e?.databases===void 0||e.databases==="*"||e.databases.includes(n)||e.databases.some?.(i=>i.name===n)||!s?t(s,n,!0):mre(n)&&t(s,n,!1)}a(r,"forDatabase")}function mre(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 Sre(e){let t={message:""};if(e.replicated){e.replicated=!1,Tr.trace?.("Replicating operation",e.operation,"to nodes",it.nodes.map(n=>n.name));let r=await Promise.allSettled(it.nodes.map(n=>af(n,e)));t.replicated=r.map((n,s)=>{let i=n.status==="rejected"?{status:"failed",reason:n.reason.toString()}:n.value;return i.node=it.nodes[s]?.name,i})}return t}var hs,Tr,RH,AH,Lc,Qp,yH,bH,OH,lre,ure,Cc,la,of,TH,Wy,zp,us=Ne(()=>{Pe();Vs();Pl();SH();qr();hs=L(se()),Tr=L(W()),RH=require("crypto"),AH=require("fs");J_();cu();Lc=L(M());_y();Qp=L(require("node:tls")),yH=L(_e()),bH=require("worker_threads"),lre=1,ure=[],Cc=hs.default.get(Lc.CONFIG_PARAMS.REPLICATION_ENABLEROOTCAS)!==!1?new Set(Qp.rootCertificates):new Set;a(dre,"start");a(NH,"monitorNodeCAs");a(_re,"disableReplication");a(fre,"assignReplicationSource");a(wH,"setReplicator");of=new Map;a(CH,"getConnection");TH=new Map;a(Ere,"getConnectionByName");a(af,"sendOperationToNode");a(uu,"subscribeToNode");a(Bp,"unsubscribeFromNode");a(hre,"getCommonNameFromCert");a(ot,"getThisNodeName");a(pre,"clearThisNodeName");Object.defineProperty(it,"hostname",{get(){return ot()}});a(gH,"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(mre,"hasExplicitlyReplicatedTable");a(j_,"lastTimeInAuditStore");a(Sre,"replicateOperation")});var tm=N((_Ie,UH)=>{"use strict";var mu=Uh(),Su=a0(),Tre=W(),gre=require("uuid").v4,dIe=require("clone"),Zp=no(),Tu=M(),Rre=require("util"),ua=Bn(),{handleHDBError:mn,hdb_errors:Are}=_e(),{HDB_ERROR_MSGS:Xp,HTTP_STATUS_CODES:Sn}=Are,{SchemaEventMsg:em}=qs(),DH=mr(),{getDatabases:yre}=(Pe(),oe(lt)),{transformReq:gu}=te(),{replicateOperation:PH}=(us(),oe(ca));UH.exports={createSchema:bre,createSchemaStructure:LH,createTable:Ore,createTableStructure:MH,createAttribute:Dre,dropSchema:Nre,dropTable:Ire,dropAttribute:wre,getBackup:Pre};async function bre(e){let t=await LH(e);return Zp.signalSchemaChange(new em(process.pid,e.operation,e.schema)),t}a(bre,"createSchema");async function LH(e){let t=mu.schema_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);if(gu(e),!await Su.checkSchemaExists(e.schema))throw mn(new Error,Xp.SCHEMA_EXISTS_ERR(e.schema),Sn.BAD_REQUEST,Tu.LOG_LEVELS.ERROR,Xp.SCHEMA_EXISTS_ERR(e.schema),!0);return await ua.createSchema(e),`database '${e.schema}' successfully created`}a(LH,"createSchemaStructure");async function Ore(e){return gu(e),e.hash_attribute=e.primary_key??e.hash_attribute,await MH(e)}a(Ore,"createTable");async function MH(e){let t=mu.create_table_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);if(mu.validateTableResidence(e.residence),!await Su.checkSchemaTableExists(e.schema,e.table))throw mn(new Error,Xp.TABLE_EXISTS_ERR(e.schema,e.table),Sn.BAD_REQUEST,Tu.LOG_LEVELS.ERROR,Xp.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:gre(),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(MH,"createTableStructure");async function Nre(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=mu.schema_object(e),n=t??r;if(n)throw mn(n,n.message,Sn.BAD_REQUEST,void 0,void 0,!0);gu(e);let s=await Su.checkSchemaExists(e.schema);if(s)throw mn(new Error,s,Sn.NOT_FOUND,Tu.LOG_LEVELS.ERROR,s,!0);let i=await Su.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);await ua.dropSchema(e),Zp.signalSchemaChange(new em(process.pid,e.operation,e.schema)),await DH.purgeSchemaTableStreams(e.schema,o);let c=await PH(e);return c.message=`successfully deleted '${e.schema}'`,c}a(Nre,"dropSchema");async function Ire(e){let t=mu.table_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);gu(e);let r=await Su.checkSchemaTableExists(e.schema,e.table);if(r)throw mn(new Error,r,Sn.NOT_FOUND,Tu.LOG_LEVELS.ERROR,r,!0);await ua.dropTable(e),await DH.purgeTableStream(e.schema,e.table);let n=await PH(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}a(Ire,"dropTable");async function wre(e){let t=mu.attribute_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);gu(e);let r=await Su.checkSchemaTableExists(e.schema,e.table);if(r)throw mn(new Error,r,Sn.NOT_FOUND,Tu.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw mn(new Error,"You cannot drop a hash attribute",Sn.BAD_REQUEST,void 0,void 0,!0);if(Tu.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw mn(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Sn.BAD_REQUEST,void 0,void 0,!0);try{return await ua.dropAttribute(e),Cre(e),Zp.signalSchemaChange(new em(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw Tre.error(`Got an error deleting attribute ${Rre.inspect(e)}.`),n}}a(wre,"dropAttribute");function Cre(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(Cre,"dropAttributeFromGlobal");async function Dre(e){gu(e);let t=yre()[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(Dre,"createAttribute");function Pre(e){return ua.getBackup(e)}a(Pre,"getBackup")});var BH=N((EIe,vH)=>{"use strict";var{OPERATIONS_ENUM:Lre}=M(),jy=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Lre.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};vH.exports=jy});var zy=N((mIe,GH)=>{"use strict";var Mre=Bn(),pIe=BH(),rm=te(),nm=M(),Ure=se(),{handleHDBError:HH,hdb_errors:vre}=_e(),{HDB_ERROR_MSGS:xH,HTTP_STATUS_CODES:kH}=vre,Bre=Object.values(nm.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),FH="To use this operation audit log must be enabled in harperdb-config.yaml";GH.exports=Hre;async function Hre(e){if(rm.isEmpty(e.schema))throw new Error(xH.SCHEMA_REQUIRED_ERR);if(rm.isEmpty(e.table))throw new Error(xH.TABLE_REQUIRED_ERR);if(!Ure.get(nm.CONFIG_PARAMS.LOGGING_AUDITLOG))throw HH(new Error,FH,kH.BAD_REQUEST,nm.LOG_LEVELS.ERROR,FH,!0);let t=rm.checkSchemaTableExist(e.schema,e.table);if(t)throw HH(new Error,t,kH.NOT_FOUND,nm.LOG_LEVELS.ERROR,t,!0);if(!rm.isEmpty(e.search_type)&&Bre.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await Mre.readAuditLog(e)}a(Hre,"readAuditLog")});var $H=N((TIe,qH)=>{"use strict";var{OPERATIONS_ENUM:xre}=M(),Qy=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=xre.GET_BACKUP,this.schema=t,this.table=r}};qH.exports=Qy});var YH=N((yIe,KH)=>{"use strict";var kre=Bn(),RIe=$H(),Jy=te(),Fre=M(),AIe=se(),{handleHDBError:Gre,hdb_errors:qre}=_e(),{HDB_ERROR_MSGS:VH,HTTP_STATUS_CODES:$re}=qre;KH.exports=Vre;async function Vre(e){if(Jy.isEmpty(e.schema))throw new Error(VH.SCHEMA_REQUIRED_ERR);if(Jy.isEmpty(e.table))throw new Error(VH.TABLE_REQUIRED_ERR);let t=Jy.checkSchemaTableExist(e.schema,e.table);if(t)throw Gre(new Error,t,$re.NOT_FOUND,Fre.LOG_LEVELS.ERROR,t,!0);return await kre.getBackup(read_audit_log_object)}a(Vre,"getBackup")});var XH=N((OIe,JH)=>{var Ru=require("validate.js"),jH=Tt(),Au=M(),{handleHDBError:Kre,hdb_errors:Yre}=_e(),{HDB_ERROR_MSGS:Qt,HTTP_STATUS_CODES:Wre}=Yre,Xy=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),jre={STRUCTURE_USER:"structure_user"},WH=Object.values(Au.ROLE_TYPES_ENUM),zre="attribute_permissions",Qre="attribute_name",{PERMS_CRUD_ENUM:yu}=Au,Jre=[zre,...Object.values(yu)],zH=[yu.READ,yu.INSERT,yu.UPDATE],Xre=[Qre,...zH];function Zre(e){let t=Xy();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,QH(e,t)}a(Zre,"addRoleValidation");function ene(e){let t=Xy();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,QH(e,t)}a(ene,"alterRoleValidation");function tne(e){let t=Xy();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,jH.validateObject(e,t)}a(tne,"dropRoleValidation");var rne=["operation","role","id","permission","hdb_user","hdb_auth_header","access"];function QH(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)rne.includes(n[o])||s.push(n[o]);s.length>0&&ir(Qt.INVALID_ROLE_JSON_KEYS(s),r);let i=jH.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{ir(o,r)}),e.permission){let o=nne(e);o&&ir(o,r),WH.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(WH.indexOf(o)<0){if(o===jre.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=>{Jre.includes(d)||ir(Qt.INVALID_PERM_KEY(d),r,o,l)}),Object.values(yu).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=>{!Xre.includes(T)&&T!==yu.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}zH.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 sne(r)}a(QH,"customValidate");JH.exports={addRoleValidation:Zre,alterRoleValidation:ene,dropRoleValidation:tne};function nne(e){let{operation:t,permission:r}=e;if(t===Au.OPERATIONS_ENUM.ADD_ROLE||t===Au.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?Au.ROLE_TYPES_ENUM.SUPER_USER:Au.ROLE_TYPES_ENUM.CLUSTER_USER;return Qt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(nne,"validateNoSUPerms");function sne(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 Kre(new Error,n,Wre.BAD_REQUEST)}else return null}a(sne,"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((wIe,rx)=>{"use strict";var ZH=un(),ex=Vr(),ine=uc(),eb=XH(),tb=no(),IIe=require("uuid").v4,one=require("util"),sm=M(),ane=te(),rb=ex.searchByValue,cne=ex.searchByHash,lne=one.promisify(ine.delete),une=$s(),dne=Wl(),{hdb_errors:_ne,handleHDBError:Mc}=_e(),{HDB_ERROR_MSGS:tx,HTTP_STATUS_CODES:cf}=_ne,{UserEventMsg:nb}=qs();rx.exports={addRole:fne,alterRole:Ene,dropRole:hne,listRoles:pne};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 fne(e){let t=eb.addRoleValidation(e);if(t)throw t;e=Zy(e);let r={schema:"system",table:"hdb_role",search_attribute:"role",search_value:e.role,hash_attribute:"id",get_attributes:["*"]},n;try{n=Array.from(await rb(r)||[])}catch(i){throw Mc(i)}if(n&&n.length>0)throw Mc(new Error,tx.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 ZH.insert(s),tb.signalUserChange(new nb(process.pid)),e=Zy(e),e}a(fne,"addRole");async function Ene(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 ZH.update(r)}catch(s){throw Mc(s)}if(n&&n?.message==="updated 0 of 1 records")throw Mc(new Error,"Invalid role id",cf.BAD_REQUEST,void 0,void 0,!0);return await tb.signalUserChange(new nb(process.pid)),e}a(Ene,"alterRole");async function hne(e){let t=eb.dropRoleValidation(e);if(t)throw Mc(new Error,t,cf.BAD_REQUEST,void 0,void 0,!0);let r=new dne(sm.SYSTEM_SCHEMA_NAME,sm.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await cne(r));if(n.length===0)throw Mc(new Error,tx.ROLE_NOT_FOUND,cf.NOT_FOUND,void 0,void 0,!0);let s=new une(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(ane.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw Mc(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,cf.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await lne(c),tb.signalUserChange(new nb(process.pid)),`${n[0].role} successfully deleted`}a(hne,"dropRole");async function pne(){return rb({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(pne,"listRoles")});var ox=N((DIe,ix)=>{"use strict";var mne=se(),da=require("joi"),Sne=Tt(),nx=require("moment"),Tne=require("fs-extra"),sb=require("path"),gne=require("lodash"),uf=M(),{LOG_LEVELS:Uc}=M(),Rne="YYYY-MM-DD hh:mm:ss",Ane=sb.resolve(__dirname,"../logs");ix.exports=function(e){return Sne.validateBySchema(e,yne)};var yne=da.object({from:da.custom(sx),until:da.custom(sx),level:da.valid(Uc.NOTIFY,Uc.FATAL,Uc.ERROR,Uc.WARN,Uc.INFO,Uc.DEBUG,Uc.TRACE),order:da.valid("asc","desc"),limit:da.number().min(1),start:da.number().min(0),log_name:da.custom(bne)});function sx(e,t){if(nx(e,nx.ISO_8601).format(Rne)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(sx,"validateDatetime");function bne(e,t){if(gne.invert(uf.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=mne.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(Ane,uf.LOG_NAMES.INSTALL):sb.join(n,s);return Tne.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(bne,"validateReadLogPath")});var ob=N((LIe,cx)=>{"use strict";var im=M(),One=W(),Nne=se(),Ine=ox(),ib=require("path"),ax=require("fs-extra"),{once:wne}=require("events"),{handleHDBError:Cne,hdb_errors:Dne}=_e(),{PACKAGE_ROOT:Pne}=M(),Lne=ib.join(Pne,"logs"),Mne=1e3,Une=200;cx.exports=vne;async function vne(e){let t=Ine(e);if(t)throw Cne(t,t.message,Dne.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=Nne.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(Lne,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?Mne: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(ax.statSync(s).size-(h+5)*Une,0));let m=ax.createReadStream(s,{start:T});m.on("error",H=>{One.error(H)});let g=0,S=[],b="",I;m.on("data",H=>{let X=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;H=b+H;let Y=0,V;for(;(V=X.exec(H))&&!m.destroyed;){I&&(I.message=H.slice(Y,V.index),B(I));let[ne,Q,de]=V,j=de.split("] ["),ae=j[0],Ae=j[1];j.splice(0,2),I={timestamp:Q,thread:ae,level:Ae,tags:j,message:""},Y=V.index+ne.length}b=H.slice(Y)}),m.on("end",H=>{m.destroyed||I&&(I.message=b.trim(),B(I))}),m.resume();function B(H){let X,Y,V;switch(!0){case(i&&c&&u):X=new Date(H.timestamp),Y=new Date(l),V=new Date(d),H.level===o&&X>=Y&&X<=V&&g<f?g++:H.level===o&&X>=Y&&X<=V&&(_a(H,E,S),g++,g===h&&m.destroy());break;case(i&&c):X=new Date(H.timestamp),Y=new Date(l),H.level===o&&X>=Y&&g<f?g++:H.level===o&&X>=Y&&(_a(H,E,S),g++,g===h&&m.destroy());break;case(i&&u):X=new Date(H.timestamp),V=new Date(d),H.level===o&&X<=V&&g<f?g++:H.level===o&&X<=V&&(_a(H,E,S),g++,g===h&&m.destroy());break;case(c&&u):X=new Date(H.timestamp),Y=new Date(l),V=new Date(d),X>=Y&&X<=V&&g<f?g++:X>=Y&&X<=V&&(_a(H,E,S),g++,g===h&&m.destroy());break;case i:H.level===o&&g<f?g++:H.level===o&&(_a(H,E,S),g++,g===h&&m.destroy());break;case c:X=new Date(H.timestamp),Y=new Date(l),X>=Y&&g<f?g++:X>=Y&&g>=f&&(_a(H,E,S),g++,g===h&&m.destroy());break;case u:X=new Date(H.timestamp),V=new Date(d),X<=V&&g<f?g++:X<=V&&g>=f&&(_a(H,E,S),g++,g===h&&m.destroy());break;default:g<f?g++:(_a(H,E,S),g++,g===h&&m.destroy())}}return a(B,"onLogMessage"),await wne(m,"close"),S}a(vne,"readLog");function _a(e,t,r){t==="desc"?Bne(e,r):t==="asc"?Hne(e,r):r.push(e)}a(_a,"pushLineToResult");function Bne(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)>r?n=i+1:s=i}t.splice(n,0,e)}a(Bne,"insertDescending");function Hne(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(Hne,"insertAscending")});var om=N((xIe,_x)=>{"use strict";var ab=require("joi"),{string:bu,boolean:lx,date:xne}=ab.types(),kne=Tt(),{validateSchemaExists:UIe,validateTableExists:vIe,validateSchemaName:BIe}=Ti(),Fne=M(),Gne=Ct(),ux=se();ux.initSync();var HIe=bu.invalid(ux.get(Fne.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(Gne.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),dx={operation:bu.valid("add_node","update_node","set_node_replication"),node_name:bu.optional(),subscriptions:ab.array().items({table:bu.optional(),schema:bu.optional(),database:bu.optional(),subscribe:lx.required(),publish:lx.required().custom($ne),start_time:xne.iso()})};function qne(e){return kne.validateBySchema(e,ab.object(dx))}a(qne,"addUpdateNodeValidator");function $ne(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($ne,"checkForFalsy");_x.exports={addUpdateNodeValidator:qne,validation_schema:dx}});var Ex=N((FIe,fx)=>{var Vne=Tt(),Kne={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};fx.exports=function(e){return Vne.validateObject(e,Kne)}});var cb=N((qIe,mx)=>{"use strict";var Yne=Ex(),Ou=require("passport"),Wne=require("passport-local").Strategy,jne=require("passport-http").BasicStrategy,zne=require("util"),Qne=xn(),px=zne.callbackify(Qne.findAndValidateUser),GIe=Dn(),Jne=M(),hx=_u();Ou.use(new Wne(function(e,t,r){px(e,t,r)}));Ou.use(new jne(function(e,t,r){px(e,t,r)}));Ou.serializeUser(function(e,t){t(null,e)});Ou.deserializeUser(function(e,t){t(null,e)});function Xne(e,t,r){if(e.raw?.user!==void 0)return r(null,e.raw.user);let n,s;if(e.headers?.authorization){let o=e.headers.authorization.split(" ");n=o[0],s=o[1]}function i(o,c){return o?r(o):c?r(null,c):r("Must login")}switch(a(i,"handleResponse"),n){case"Basic":Ou.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===Jne.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?hx.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):hx.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:Ou.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(Xne,"authorize");function Zne(e,t){let r=Yne(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(Zne,"checkPermissions");mx.exports={authorize:Xne,checkPermissions:Zne}});var Nu=N((VIe,Sx)=>{"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}};Sx.exports={Node:lb,NodeSubscription:ub}});var gx=N((YIe,Tx)=>{"use strict";var ese=M().OPERATIONS_ENUM,db=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=ese.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Tx.exports=db});var df=N((jIe,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 yx=N((QIe,Ax)=>{"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}};Ax.exports=Eb});var Ox=N((rwe,bx)=>{"use strict";var tse=yx(),XIe=Bt(),ZIe=ht(),rse=W(),{getSchemaPath:ewe,getTransactionAuditStorePath:twe}=gt(),{getDatabases:nse}=(Pe(),oe(lt));bx.exports=sse;async function sse(e){let t=new tse;try{let r=nse()[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){rse.warn(`unable to stat table dbi due to ${r}`)}return t}a(sse,"lmdbGetTableSize")});var Ix=N((swe,Nx)=>{"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}};Nx.exports=hb});var wu=N((uwe,Px)=>{"use strict";var ise=require("fs-extra"),ose=require("path"),Qr=require("systeminformation"),fa=W(),wx=mr(),owe=Ct(),Iu=M(),ase=Ox(),cse=ro(),{getThreadInfo:Cx}=dt(),_f=se();_f.initSync();var lse=Ix(),{openEnvironment:awe}=ht(),{getSchemaPath:cwe}=gt(),{database:lwe,databases:pb}=(Pe(),oe(lt)),am;Px.exports={getHDBProcessInfo:gb,getNetworkInfo:Ab,getDiskInfo:Rb,getMemoryInfo:Tb,getCPUInfo:Sb,getTimeInfo:mb,getSystemInformation:yb,systemInformation:use,getTableSize:bb,getMetrics:Ob};function mb(){return Qr.time()}a(mb,"getTimeInfo");async function Sb(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:u,...d}=await Qr.cpu();d.cpu_speed=await Qr.cpuCurrentSpeed();let{raw_currentload:_,raw_currentload_idle:E,raw_currentload_irq:f,raw_currentload_nice:h,raw_currentload_system:T,raw_currentload_user:m,cpus:g,...S}=await Qr.currentLoad();return S.cpus=[],g.forEach(b=>{let{raw_load:I,raw_load_idle:B,raw_load_irq:H,raw_load_nice:X,raw_load_system:Y,raw_load_user:V,...ne}=b;S.cpus.push(ne)}),d.current_load=S,d}catch(e){return fa.error(`error in getCPUInfo: ${e}`),{}}}a(Sb,"getCPUInfo");async function Tb(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Qr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return fa.error(`error in getMemoryInfo: ${e}`),{}}}a(Tb,"getMemoryInfo");async function gb(){let e={core:[],clustering:[]};try{let t=await Qr.processes(),r;try{r=Number.parseInt(await ise.readFile(ose.join(_f.get(Iu.CONFIG_PARAMS.ROOTPATH),Iu.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Iu.NODE_ERROR_CODES.ENOENT)fa.warn("Unable to locate 'hdb.pid' file, try stopping and starting HarperDB. This could be because HarperDB is not running.");else throw n}t.list.forEach(n=>{n.pid===r?e.core.push(n):n.name==="nats-server"&&e.clustering.push(n)});for(let n of e.core)for(let s of t.list)s.pid===n.parentPid&&(s.name==="PM2"||s.command==="PM2")&&(n.parent="PM2");return e}catch(t){return fa.error(`error in getHDBProcessInfo: ${t}`),e}}a(gb,"getHDBProcessInfo");async function Rb(){let e={};try{if(!_f.get(Iu.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Qr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...u}=await Qr.fsStats();return e.read_write=u,e.size=await Qr.fsSize(),e}catch(t){return fa.error(`error in getDiskInfo: ${t}`),e}}a(Rb,"getDiskInfo");async function Ab(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return _f.get(Iu.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await Qr.networkInterfaceDefault(),e.latency=await Qr.inetChecksite("google.com"),(await Qr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:u,ieee8021xState:d,carrier_changes:_,...E}=n;e.interfaces.push(E)}),(await Qr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)})),e}catch(t){return fa.error(`error in getNetworkInfo: ${t}`),e}}a(Ab,"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 cse.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await ase(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 Dx(){if(_f.get(Iu.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await wx.getNATSReferences(),t=await wx.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(Dx,"getNatsStreamInfo");async function use(e){let t=new lse;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await yb(),t.time=mb(),t.cpu=await Sb(),t.memory=await Tb(),t.disk=await Rb(),t.network=await Ab(),t.harperdb_processes=await gb(),t.table_size=await bb(),t.metrics=await Ob(),t.threads=await Cx(),t.replication=await Dx(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await yb();break;case"time":t.time=mb();break;case"cpu":t.cpu=await Sb();break;case"memory":t.memory=await Tb();break;case"disk":t.disk=await Rb();break;case"network":t.network=await Ab();break;case"harperdb_processes":t.harperdb_processes=await gb();break;case"table_size":t.table_size=await bb();break;case"database_metrics":case"metrics":t.metrics=await Ob();break;case"threads":t.threads=await Cx();break;case"replication":t.replication=await Dx();break;default:break}return t}a(use,"systemInformation")});var vc=N((_we,Lx)=>{"use strict";Lx.exports={version:dse,printVersion:_se};var cm=Jl();function dse(){if(cm)return cm.version}a(dse,"version");function _se(){cm&&console.log(`HarperDB Version ${cm.version}`)}a(_se,"printVersion")});var Di=N((pwe,Bx)=>{"use strict";var fse=un(),Nb=te(),Ese=require("util"),Bc=M(),Mx=se();Mx.initSync();var hse=cb(),Ux=Vr(),{Node:Ewe,NodeSubscription:hwe}=Nu(),pse=Wl(),mse=gx(),{RemotePayloadObject:Sse,RemotePayloadSubscription:Tse}=df(),{handleHDBError:gse,hdb_errors:Rse}=_e(),{HTTP_STATUS_CODES:Ase,HDB_ERROR_MSGS:yse}=Rse,bse=$s(),Ose=wu(),Nse=vc(),{getDatabases:Ise}=(Pe(),oe(lt)),wse=Ese.promisify(hse.authorize),Cse=Ux.searchByHash,Dse=Ux.searchByValue;Bx.exports={authHeaderToUser:Pse,isEmpty:Lse,getNodeRecord:Mse,upsertNodeRecord:Use,buildNodePayloads:vse,checkClusteringEnabled:Bse,getAllNodeRecords:Hse,getSystemInfo:xse,reverseSubscription:vx};async function Pse(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await wse(t,null),e}a(Pse,"authHeaderToUser");function Lse(e){return e==null}a(Lse,"isEmpty");async function Mse(e){let t=new pse(Bc.SYSTEM_SCHEMA_NAME,Bc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return Cse(t)}a(Mse,"getNodeRecord");async function Use(e){let t=new mse(Bc.SYSTEM_SCHEMA_NAME,Bc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return fse.upsert(t)}a(Use,"upsertNodeRecord");function vx(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(vx,"reverseSubscription");function vse(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}=vx(c),f=Ise()[l]?.[u],h=new Tse(l,u,d,E,_,c.start_time,f.schemaDefined?f.attributes:void 0);s.push(h)}return new Sse(r,t,s,n)}a(vse,"buildNodePayloads");function Bse(){if(!Mx.get(Bc.CONFIG_PARAMS.CLUSTERING_ENABLED))throw gse(new Error,yse.CLUSTERING_NOT_ENABLED,Ase.BAD_REQUEST,void 0,void 0,!0)}a(Bse,"checkClusteringEnabled");async function Hse(){let e=new bse(Bc.SYSTEM_SCHEMA_NAME,Bc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await Dse(e))}a(Hse,"getAllNodeRecords");async function xse(){let e=await Ose.getSystemInformation();return{hdb_version:Nse.version(),node_version:e.node_version,platform:e.platform}}a(xse,"getSystemInfo")});var Ib=N((Swe,Vx)=>{"use strict";var lm=mr(),Hx=te(),xx=Ct(),kx=M(),um=W(),Fx=tm(),kse=w_(),{RemotePayloadObject:Fse}=df(),{handleHDBError:Gx,hdb_errors:Gse}=_e(),{HTTP_STATUS_CODES:qx}=Gse,{NodeSubscription:$x}=Nu();Vx.exports=qse;async function qse(e,t){let r;try{r=await lm.request(`${t}.${xx.REQUEST_SUFFIX}`,new Fse(kx.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 Gx(new Error,c,qx.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===xx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw Gx(new Error,o,qx.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===kx.SYSTEM_SCHEMA_NAME){await lm.createLocalTableStream(l,c);let h=new $x(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let u=Hx.doesSchemaExist(l),d=n[l]!==void 0,_=c?Hx.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 Fx.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 kse(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await Fx.createTable(h)}await lm.createLocalTableStream(l,c);let f=new $x(l,c,o.publish,o.subscribe);f.start_time=o.start_time,i.push(f)}return{added:i,skipped:s}}a(qse,"reviewSubscriptions")});var Hc={};je(Hc,{addNodeBack:()=>Wse,removeNodeBack:()=>jse,setNode:()=>Yse});async function Yse(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,Yx.validateBySchema)(e,Kse);if(n)throw(0,uo.handleHDBError)(n,n.message,Vse.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new uo.ClientError("url or hostname is required for remove_node operation");let f=r,h=Sr(),T=await h.get(f);if(!T)throw new uo.ClientError(f+" does not exist");try{await af({url:T.url},{operation:ff.OPERATIONS_ENUM.REMOVE_NODE_BACK,name:T?.subscriptions?.length>0?ot():f},void 0)}catch(m){$n.warn(`Error removing node from target node ${f}, if it is offline and we be online in the future, you may need to clean up this node manually, or retry:`,m)}return await h.delete(f),`Successfully removed '${f}' from cluster`}if(!t)throw new uo.ClientError("url required for this operation");let s=ra();if(s==null)throw new uo.ClientError("replication url is missing from harperdb-config.yaml");let i,o,c;if(t?.startsWith("wss:")){i=await(0,ps.getReplicationCert)();let f=await(0,ps.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,ps.createCsr)(),$n.info("Sending CSR to target node:",t)):f&&(c=f.certificate,$n.info("Sending CA named",f.name,"to target node",t))}let l={operation:ff.OPERATIONS_ENUM.ADD_NODE_BACK,hostname:(0,Wx.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(Kx):l.subscriptions=null,e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let f=Kx(e);l.subscribe=f.subscribe,l.publish=f.publish}e?.authorization?.username&&e?.authorization?.password&&(e.authorization="Basic "+Buffer.from(e.authorization.username+":"+e.authorization.password).toString("base64"));let u,d;try{u=await af({url:t},l,e)}catch(f){f.message=`Error returned from ${t}: `+f.message,$n.warn("Error adding node:",t,"to cluster:",f),d=f}if(o&&(!u?.certificate||!u?.certificate?.includes?.("BEGIN CERTIFICATE")))throw d?(d.message+=" and connection was required to sign certificate",d):new Error(`Unexpected certificate signature response from node ${t} response: ${JSON.stringify(u)}`);o&&($n.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,ps.setCertTable)({name:$se.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,ps.setCertTable)({name:ot(),uses:["https","operations","wss"],certificate:u.certificate,private_key_name:i?.options?.key_file,is_authority:!1,is_self_signed:!1}),c=u.signingCA);let _={url:t,ca:u?.usingCA};if(e.hostname&&(_.name=e.hostname),e.subscriptions?_.subscriptions=e.subscriptions:_.replicates=!0,e.start_time&&(_.start_time=typeof e.start_time=="string"?new Date(e.start_time).getTime():e.start_time),e.retain_authorization&&(_.authorization=e.authorization),_.replicates){let f={url:s,ca:c,replicates:!0,subscriptions:null};e.retain_authorization&&(f.authorization=e.authorization),e.start_time&&(f.start_time=e.start_time),await co(ot(),f)}await co(u?u.nodeName:_.name??zs(t),_);let E;return e.operation==="update_node"?E=`Successfully updated '${t}'`:E=`Successfully added '${t}' to cluster`,d&&(E+=" but there was an error updating target node: "+d.message),E}async function Wse(e){$n.trace("addNodeBack received request:",e);let t=await(0,ps.signCertificate)(e),r;e.csr?(r=t.signingCA,$n.info("addNodeBack received CSR from node:",e.url,"this node will use and respond with CA that was used to issue CSR")):(r=e?.cert_auth,$n.info("addNodeBack received CA from node:",e.url));let n={url:e.url,ca:r};e.subscriptions?n.subscriptions=e.subscriptions:(n.replicates=!0,n.subscriptions=null),e.start_time&&(n.start_time=e.start_time),e.authorization&&(n.authorization=e.authorization);let s=await(0,ps.getReplicationCertAuth)();if(n.replicates){let i={url:ra(),ca:s?.certificate,replicates:!0,subscriptions:null};e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await co(ot(),i)}return await co(e.hostname,n),t.nodeName=ot(),t.usingCA=s?.certificate,$n.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function jse(e){$n.trace("removeNodeBack received request:",e),await Sr().delete(e.name)}function Kx(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var ps,Yx,Cu,Wx,ff,$n,uo,$se,Vse,Kse,xc=Ne(()=>{ps=L(Xs()),Yx=L(Tt()),Cu=L(require("joi")),Wx=L(se()),ff=L(M());J_();cu();us();$n=L(W()),uo=L(_e()),{pki:$se}=require("node-forge"),{HTTP_STATUS_CODES:Vse}=uo.hdb_errors,Kse=Cu.default.object({hostname:Cu.default.string(),verify_tls:Cu.default.boolean(),replicates:Cu.default.boolean(),subscriptions:Cu.default.array()});a(Yse,"setNode");a(Wse,"addNodeBack");a(jse,"removeNodeBack");a(Kx,"reverseSubscription")});var pf=N((Nwe,zx)=>{"use strict";var{handleHDBError:dm,hdb_errors:zse}=_e(),{HTTP_STATUS_CODES:_m}=zse,{addUpdateNodeValidator:Qse}=om(),fm=W(),Em=M(),jx=Ct(),Jse=te(),Ef=mr(),hf=Di(),wb=se(),Xse=Ib(),{Node:Zse,NodeSubscription:eie}=Nu(),{broadcast:tie}=dt(),{setNode:rie}=(xc(),oe(Hc)),bwe=se(),Owe=M(),nie="Unable to create 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",iie=wb.get(Em.CONFIG_PARAMS.CLUSTERING_NODENAME);zx.exports=oie;async function oie(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 rie(e);hf.checkClusteringEnabled();let r=Qse(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(!Jse.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 Xse(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=nie,o;let c=hf.buildNodePayloads(s,iie,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 eie(f.schema,f.table,f.publish,f.subscribe))}fm.trace("addNode sending remote payload:",c);let u;try{u=await Ef.request(`${n}.${jx.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===jx.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 Zse(n,l,u.system_info);return await hf.upsertNodeRecord(d),tie({type:"nats_update"}),i.length>0?o.message=sie:o.message=`Successfully added '${n}' to manifest`,o}a(oie,"addNode")});var Lb=N((Cwe,Jx)=>{"use strict";var{handleHDBError:Cb,hdb_errors:aie}=_e(),{HTTP_STATUS_CODES:Db}=aie,{addUpdateNodeValidator:cie}=om(),mf=W(),hm=M(),Qx=Ct(),wwe=te(),Sf=mr(),Tf=Di(),Pb=se(),{cloneDeep:lie}=require("lodash"),uie=Ib(),{Node:die,NodeSubscription:_ie}=Nu(),{broadcast:fie}=dt(),{setNode:Eie}=(xc(),oe(Hc)),hie="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",pie="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",mie=Pb.get(hm.CONFIG_PARAMS.CLUSTERING_NODENAME);Jx.exports=Sie;async function Sie(e){if(mf.trace("updateNode called with:",e),Pb.get(hm.CONFIG_PARAMS.REPLICATION_URL)??Pb.get(hm.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Eie(e);Tf.checkClusteringEnabled();let t=cie(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=lie(s));let{added:i,skipped:o}=await uie(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=hie,c;let l=Tf.buildNodePayloads(i,mie,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}.${Qx.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===Qx.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 die(r,[],u.system_info)]),await Tie(n[0],i,u.system_info),o.length>0?c.message=pie:c.message=`Successfully updated '${r}'`,c}a(Sie,"updateNode");async function Tie(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 _ie(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await Tf.upsertNodeRecord(n),fie({type:"nats_update"})}a(Tie,"updateNodeTable")});var rk=N((Pwe,tk)=>{"use strict";var ek=require("joi"),{string:Xx}=ek.types(),gie=Tt(),Zx=M(),Rie=se(),Aie=Ct();tk.exports=yie;function yie(e){let t=Xx.invalid(Rie.get(Zx.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(Aie.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=ek.object({operation:Xx.valid(Zx.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return gie.validateBySchema(e,r)}a(yie,"removeNodeValidator")});var Rf=N((Mwe,ak)=>{"use strict";var{handleHDBError:nk,hdb_errors:bie}=_e(),{HTTP_STATUS_CODES:sk}=bie,Oie=rk(),gf=W(),ik=Di(),Nie=te(),Du=M(),ok=Ct(),Mb=mr(),Ub=se(),{RemotePayloadObject:Iie}=df(),{NodeSubscription:wie}=Nu(),Cie=I_(),Die=uc(),{broadcast:Pie}=dt(),{setNode:Lie}=(xc(),oe(Hc)),Mie=Ub.get(Du.CONFIG_PARAMS.CLUSTERING_NODENAME);ak.exports=Uie;async function Uie(e){if(gf.trace("removeNode called with:",e),Ub.get(Du.CONFIG_PARAMS.REPLICATION_URL)??Ub.get(Du.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Lie(e);ik.checkClusteringEnabled();let t=Oie(e);if(t)throw nk(t,t.message,sk.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await ik.getNodeRecord(r);if(Nie.isEmptyOrZeroLength(n))throw nk(new Error,`Node '${r}' was not found.`,sk.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new Iie(Du.OPERATIONS_ENUM.REMOVE_NODE,Mie,[]),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 wie(d.schema,d.table,!1,!1),r)}catch(_){gf.error(_)}}try{i=await Mb.request(`${r}.${ok.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 Cie(Du.SYSTEM_SCHEMA_NAME,Du.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Die.deleteRecord(c),Pie({type:"nats_update"}),i?.status===ok.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(Uie,"removeNode")});var uk=N((vwe,lk)=>{"use strict";var ck=require("joi"),{string:vie,array:Bie}=ck.types(),Hie=Tt(),xie=om();lk.exports=kie;function kie(e){let t=ck.object({operation:vie.valid("configure_cluster").required(),connections:Bie.items(xie.validation_schema).required()});return Hie.validateBySchema(e,t)}a(kie,"configureClusterValidator")});var vb=N((Hwe,hk)=>{"use strict";var dk=M(),pm=W(),Fie=te(),Gie=se(),qie=Rf(),$ie=pf(),Vie=Di(),Kie=uk(),{handleHDBError:_k,hdb_errors:Yie}=_e(),{HTTP_STATUS_CODES:fk}=Yie,Wie="Configure cluster complete.",jie="Failed to configure the cluster. Check the logs for more details.",zie="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";hk.exports=Qie;async function Qie(e){pm.trace("configure cluster called with:",e);let t=Kie(e);if(t)throw _k(t,t.message,fk.BAD_REQUEST,void 0,void 0,!0);let r=await Vie.getAllNodeRecords(),n=[];if(Gie.get(dk.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let d=0,_=r.length;d<_;d++){let E=await Ek(qie,{operation:dk.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 Ek($ie,_,_.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(Fie.isEmptyOrZeroLength(o))return{message:Wie,connections:c};if(l)return{message:zie,failed_nodes:o,connections:c};throw _k(new Error,jie,fk.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(Qie,"configureCluster");async function Ek(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(Ek,"functionWrapper")});var Tk=N((kwe,Sk)=>{"use strict";var Af=require("joi"),Jie=Tt(),{validateSchemaExists:pk,validateTableExists:Xie,validateSchemaName:mk}=Ti(),Zie=Af.object({operation:Af.string().valid("purge_stream"),schema:Af.string().custom(pk).custom(mk).optional(),database:Af.string().custom(pk).custom(mk).optional(),table:Af.string().custom(Xie).required()});function eoe(e){return Jie.validateBySchema(e,Zie)}a(eoe,"purgeStreamValidator");Sk.exports=eoe});var Bb=N((Gwe,gk)=>{"use strict";var{handleHDBError:toe,hdb_errors:roe}=_e(),{HTTP_STATUS_CODES:noe}=roe,soe=Tk(),ioe=mr(),ooe=Di();gk.exports=aoe;async function aoe(e){e.schema=e.schema??e.database;let t=soe(e);if(t)throw toe(t,t.message,noe.BAD_REQUEST,void 0,void 0,!0);ooe.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await ioe.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(aoe,"purgeStream")});var Sm=N(($we,Ik)=>{"use strict";var xb=Di(),coe=mr(),mm=se(),Pu=M(),kc=Ct(),loe=te(),Hb=W(),{RemotePayloadObject:uoe}=df(),{ErrorCode:Rk}=require("nats"),{parentPort:Ak}=require("worker_threads"),{onMessageByType:doe}=dt(),{getThisNodeName:_oe}=(us(),oe(ca)),{requestClusterStatus:foe}=(J_(),oe(RB)),yk=mm.get(Pu.CONFIG_PARAMS.CLUSTERING_ENABLED),bk=mm.get(Pu.CONFIG_PARAMS.CLUSTERING_NODENAME);Ik.exports={clusterStatus:Eoe,buildNodeStatus:Nk};var Ok;doe("cluster-status",async e=>{Ok(e)});async function Eoe(){if(mm.get(Pu.CONFIG_PARAMS.REPLICATION_URL)||mm.get(Pu.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;return Ak?(Ak.postMessage({type:"request-cluster-status"}),n=await new Promise(s=>{Ok=s})):n=foe(),n.node_name=_oe(),n.is_enabled=!0,n}let e={node_name:bk,is_enabled:yk,connections:[]};if(!yk)return e;let t=await xb.getAllNodeRecords();if(loe.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(Nk(t[n],e.connections));return await Promise.allSettled(r),e}a(Eoe,"clusterStatus");async function Nk(e,t){let r=e.name,n=new uoe(Pu.OPERATIONS_ENUM.CLUSTER_STATUS,bk,void 0,await xb.getSystemInfo()),s,i,o=kc.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await coe.request(kc.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===kc.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=kc.CLUSTER_STATUS_STATUSES.CLOSED,Hb.error(`Error getting node status from ${r} `,s))}catch(l){Hb.warn(`Error getting node status from ${r}`,l),l.code===Rk.NoResponders?o=kc.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===Rk.Timeout?o=kc.CLUSTER_STATUS_STATUSES.TIMEOUT:o=kc.CLUSTER_STATUS_STATUSES.CLOSED}let c=new hoe(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let l={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==Pu.PRE_4_0_0_VERSION&&await xb.upsertNodeRecord(l)}catch(l){Hb.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(Nk,"buildNodeStatus");function hoe(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(hoe,"NodeStatusObject")});var Fb=N((Kwe,wk)=>{"use strict";var{handleHDBError:poe,hdb_errors:moe}=_e(),{HTTP_STATUS_CODES:Soe}=moe,Toe=mr(),goe=Di(),kb=te(),Tm=require("joi"),Roe=Tt(),Aoe=2e3,yoe=Tm.object({timeout:Tm.number().min(1),connected_nodes:Tm.boolean(),routes:Tm.boolean()});wk.exports=boe;async function boe(e){goe.checkClusteringEnabled();let t=Roe.validateBySchema(e,yoe);if(t)throw poe(t,t.message,Soe.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 Toe.getServerList(r??Aoe),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(boe,"clusterNetwork")});var Lk=N((Wwe,Pk)=>{"use strict";var Gb=require("joi"),Ck=Tt(),{route_constraints:Dk}=gg();Pk.exports={setRoutesValidator:Ooe,deleteRoutesValidator:Noe};function Ooe(e){let t=Gb.object({server:Gb.valid("hub","leaf"),routes:Dk.required()});return Ck.validateBySchema(e,t)}a(Ooe,"setRoutesValidator");function Noe(e){let t=Gb.object({routes:Dk.required()});return Ck.validateBySchema(e,t)}a(Noe,"deleteRoutesValidator")});var gm=N((zwe,kk)=>{"use strict";var _o=wt(),qb=te(),ms=M(),Lu=se(),Mk=Lk(),{handleHDBError:Uk,hdb_errors:Ioe}=_e(),{HTTP_STATUS_CODES:vk}=Ioe,Bk="cluster routes successfully set",Hk="cluster routes successfully deleted";kk.exports={setRoutes:Coe,getRoutes:Doe,deleteRoutes:Poe};function woe(e){let t=_o.getClusteringRoutes(),r=e.server==="hub"?t.hub_routes:t.leaf_routes,n=e.server==="hub"?t.leaf_routes:t.hub_routes,s=[],i=[];for(let o=0,c=e.routes.length;o<c;o++){let l=e.routes[o];l.port=qb.autoCast(l.port);let u=r.some(_=>_.host===l.host&&_.port===l.port),d=n.some(_=>_.host===l.host&&_.port===l.port);u||d?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?_o.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):_o.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:Bk,set:i,skipped:s}}a(woe,"setRoutesNats");function Coe(e){let t=Mk.setRoutesValidator(e);if(t)throw Uk(t,t.message,vk.BAD_REQUEST,void 0,void 0,!0);if(Lu.get(ms.CONFIG_PARAMS.CLUSTERING_ENABLED))return woe(e);let r=[],n=[],s=Lu.get(ms.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{xk(s,i)?n.push(i):(s.push(i),r.push(i))}),_o.updateConfigValue(ms.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:Bk,set:r,skipped:n}}a(Coe,"setRoutes");function xk(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(xk,"existsInArray");function Doe(){if(Lu.get(ms.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=_o.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return Lu.get(ms.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(Doe,"getRoutes");function Poe(e){let t=Mk.deleteRoutesValidator(e);if(t)throw Uk(t,t.message,vk.BAD_REQUEST,void 0,void 0,!0);if(Lu.get(ms.CONFIG_PARAMS.CLUSTERING_ENABLED))return Loe(e);let r=[],n=[],s=Lu.get(ms.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{xk(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),_o.updateConfigValue(ms.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:Hk,deleted:r,skipped:n}}a(Poe,"deleteRoutes");function Loe(e){let t=_o.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],o=!1,c=!1;for(let l=0,u=e.routes.length;l<u;l++){let d=e.routes[l],_=!1;for(let E=0,f=r.length;E<f;E++){let h=r[E];if(d.host===h.host&&d.port===h.port){r.splice(E,1),_=!0,o=!0,s.push(d);break}}if(!_){let E=!0;for(let f=0,h=n.length;f<h;f++){let T=n[f];if(d.host===T.host&&d.port===T.port){n.splice(f,1),c=!0,E=!1,s.push(d);break}}E&&i.push(d)}}return o&&(r=qb.isEmptyOrZeroLength(r)?null:r,_o.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=qb.isEmptyOrZeroLength(n)?null:n,_o.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:Hk,deleted:s,skipped:i}}a(Loe,"deleteRoutesNats")});var Gk=N((Jwe,Fk)=>{"use strict";var yf=require("alasql"),Fc=require("recursive-iterator"),Zs=W(),Moe=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,voe(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=Uoe(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 Uoe(e){return e.filter(t=>t[bf.PERMS_CRUD_ENUM.READ])}a(Uoe,"filterReadRestrictedAttrs");function voe(e,t,r,n,s){Boe(e,t,r,n,s)}a(voe,"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 Boe(e,t,r,n,s){if(!e){Zs.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof yf.yy.Insert?Foe(e,t,r):e instanceof yf.yy.Select?Hoe(e,t,r,n,s):e instanceof yf.yy.Update?xoe(e,t,r):e instanceof yf.yy.Delete?koe(e,t,r):Zs.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(Boe,"getRecordAttributesAST");function Hoe(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(Moe.isEmptyOrZeroLength(i)){Zs.error("No schema specified");return}e.from.forEach(c=>{Of(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),Of(c.table,t,r,n,s)});let o=new Fc(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,u=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(u).has(l))if(r.has(l))l=r.get(l);else{Zs.info(`table specified as ${l} not found.`);return}t.get(u).get(l).indexOf(c.columnid)<0&&t.get(u).get(l).push(c.columnid)}if(e.where){let c=new Fc(e.where),l=e.from[0].tableid;for(let{node:u}of c)if(u&&u.columnid){let d=u.tableid?u.tableid:l;if(!t.get(i).has(d))if(r.has(d))d=r.get(d);else{Zs.info(`table specified as ${d} not found.`);continue}t.get(i).get(d).indexOf(u.columnid)<0&&t.get(i).get(d).push(u.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new Fc(c.on);for(let{node:u}of l)if(u&&u.columnid){let d=u.tableid,_=s.get(d);if(!t.get(_).has(d))if(r.has(d))d=r.get(d);else{Zs.info(`table specified as ${d} not found.`);continue}t.get(_).get(d).indexOf(u.columnid)<0&&t.get(_).get(d).push(u.columnid)}}),e.order){let c=new Fc(e.order);for(let{node:l}of c)if(l&&l.columnid){let u=l.tableid,d=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(d).has(u))if(r.has(u))u=r.get(u);else{Zs.info(`table specified as ${u} not found.`);return}t.get(d).get(u).indexOf(l.columnid)<0&&t.get(d).get(u).push(l.columnid)}}}a(Hoe,"getSelectAttributes");function xoe(e,t,r){if(!e){Zs.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new Fc(e.columns),s=e.table.databaseid;Of(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&Vb(e.table.tableid,s,i.columnid,t,r)}a(xoe,"getUpdateAttributes");function koe(e,t,r){if(!e){Zs.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new Fc(e.where),s=e.table.databaseid;Of(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&Vb(e.table.tableid,s,i.columnid,t,r)}a(koe,"getDeleteAttributes");function Foe(e,t,r){if(!e){Zs.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new Fc(e.columns),s=e.into.databaseid;Of(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&Vb(e.into.tableid,s,i.columnid,t,r)}a(Foe,"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");Fk.exports=$b});var Wb=N((Zwe,Kk)=>{var Rm=dc(),qk=require("chalk"),Vn=W(),$k=require("prompt"),{promisify:Goe}=require("util"),Kb=M(),qoe=require("fs-extra"),$oe=require("path"),Voe=te(),Koe=vc(),Vk=se();Vk.initSync();var Yoe=require("moment"),Woe=Goe($k.get),joe=$oe.join(Vk.getHdbBasePath(),Kb.LICENSE_KEY_DIR_NAME,Kb.LICENSE_FILE_NAME,Kb.LICENSE_FILE_NAME);Kk.exports={getFingerprint:Qoe,setLicense:zoe,parseLicense:Yb,register:Joe,getRegistrationInfo:Zoe};async function zoe(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(zoe,"setLicense");async function Qoe(){let e={};try{e=await Rm.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw Vn.error(r),Vn.error(t),new Error(r)}return e}a(Qoe,"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=Rm.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 qoe.writeFile(joe,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 Joe(){let e=await Xoe();return Yb(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(Joe,"register");async function Xoe(){let e=await Rm.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:qk.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:qk.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{$k.start()}catch(n){Vn.error(n)}let r;try{r=await Woe(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(Xoe,"promptForRegistration");async function Zoe(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await Rm.getLicense()}catch(r){throw Vn.error(`There was an error when searching licenses due to: ${r.message}`),r}if(Voe.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=Koe.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=Yoe.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(Zoe,"getRegistrationInfo")});var Wk=N((tCe,Yk)=>{"use strict";var eae=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+eae.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"}};Yk.exports=jb});var Qk=N((nCe,zk)=>{"use strict";var jk=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+jk.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+jk.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"}};zk.exports=zb});var Xk=N((iCe,Jk)=>{"use strict";var Qb=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};Jk.exports=Qb});var eF=N((aCe,Zk)=>{"use strict";var tae=Ct(),Jb=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+tae.SERVER_SUFFIX.ADMIN,this.password=r}};Zk.exports=Jb});var Om=N((lCe,nF)=>{"use strict";var Gc=require("path"),qc=require("fs-extra"),rae=Wk(),nae=Qk(),sae=Xk(),iae=eF(),Xb=xn(),Uu=te(),Tn=wt(),ym=M(),Nf=Ct(),{CONFIG_PARAMS:Jt}=ym,vu=W(),If=se(),tF=to(),Zb=mr(),oae=Xs(),Mu="clustering",aae=1e4,rF=50;nF.exports={generateNatsConfig:lae,removeNatsConfig:uae,getHubConfigPath:cae};function cae(){let e=If.get(Jt.ROOTPATH);return Gc.join(e,Mu,Nf.NATS_CONFIG_FILES.HUB_SERVER)}a(cae,"getHubConfigPath");async function lae(e=!1,t=void 0){let r=If.get(Jt.ROOTPATH);qc.ensureDirSync(Gc.join(r,"clustering","leaf")),If.initSync();let n=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_CERT_AUTH),s=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_PRIVATEKEY),i=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_CERTIFICATE);!await qc.exists(i)&&!await qc.exists(!n)&&await oae.createNatsCerts();let o=Gc.join(r,Mu,Nf.PID_FILES.HUB),c=Gc.join(r,Mu,Nf.PID_FILES.LEAF),l=Tn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=Gc.join(r,Mu,Nf.NATS_CONFIG_FILES.HUB_SERVER),d=Gc.join(r,Mu,Nf.NATS_CONFIG_FILES.LEAF_SERVER),_=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_INSECURE),E=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_VERIFY),f=Tn.getConfigFromFile(Jt.CLUSTERING_NODENAME),h=Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await Zb.checkNATSServerInstalled()||bm("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let T=await Xb.listUsers(),m=Tn.getConfigFromFile(Jt.CLUSTERING_USER),g=await Xb.getClusterUser();(Uu.isEmpty(g)||g.active!==!0)&&bm(`Invalid cluster user '${m}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await Am(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await Am(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await Am(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),await Am(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let S=[],b=[];for(let[ne,Q]of T.entries())Q.role?.role===ym.ROLE_TYPES_ENUM.CLUSTER_USER&&Q.active&&(S.push(new iae(Q.username,tF.decrypt(Q.hash))),b.push(new sae(Q.username,tF.decrypt(Q.hash))));let I=[],{hub_routes:B}=Tn.getClusteringRoutes();if(!Uu.isEmptyOrZeroLength(B))for(let ne of B)I.push(`tls://${g.sys_name_encoded}:${g.uri_encoded_d_hash}@${ne.host}:${ne.port}`);let H=new rae(Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),f,o,i,s,n,_,E,h,Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NAME),Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),I,S,b);n==null&&(delete H.tls.ca_file,delete H.leafnodes.tls.ca_file),t=Uu.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===ym.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await qc.writeJson(u,H),vu.trace(`Hub server config written to ${u}`));let X=`tls://${g.sys_name_encoded}:${g.uri_encoded_d_hash}@0.0.0.0:${h}`,Y=`tls://${g.uri_encoded_name}:${g.uri_encoded_d_hash}@0.0.0.0:${h}`,V=new nae(Tn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT),f,c,l,[X],[Y],S,b,i,s,n,_);n==null&&delete V.tls.ca_file,(t===void 0||t===ym.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await qc.writeJson(d,V),vu.trace(`Leaf server config written to ${d}`))}a(lae,"generateNatsConfig");async function Am(e){let t=If.get(e);return Uu.isEmpty(t)&&bm(`port undefined for '${e}'`),await Uu.isPortTaken(t)&&bm(`'${e}' port '${t}' is is in use by another process, check to see if HarperDB is already running or another process is using this port.`),!0}a(Am,"isPortAvailable");function bm(e){let t=`Error generating clustering config: ${e}`;vu.error(t),console.error(t),process.exit(1)}a(bm,"generateNatsConfigError");async function uae(e){let{port:t,config_file:r}=Zb.getServerConfig(e),{username:n,decrypt_hash:s}=await Xb.getClusterUser(),i=0,o=2e3;for(;i<rF;){try{let d=await Zb.createConnection(t,n,s,!1);if(d.protocol.connected===!0){d.close();break}}catch(d){vu.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${d}`)}if(i++,i>=rF)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);let u=o*(i*2);u>3e4&&vu.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await Uu.async_set_timeout(u)}let c="0".repeat(aae),l=Gc.join(If.get(Jt.ROOTPATH),Mu,r);await qc.writeFile(l,c),await qc.remove(l),vu.notify(e,"started.")}a(uae,"removeNatsConfig")});var lF=N((dCe,cF)=>{"use strict";var Kn=se(),dae=dc(),Fe=M(),wf=Ct(),fo=require("path"),{PACKAGE_ROOT:Im}=M(),sF=se(),Nm=te(),Bu="/dev/null",_ae=fo.join(Im,"launchServiceScripts"),iF=fo.join(Im,"utility/scripts"),fae=fo.join(iF,Fe.HDB_RESTART_SCRIPT),oF=fo.resolve(Im,"dependencies",`${process.platform}-${process.arch}`,wf.NATS_BINARY_NAME);function aF(){let t=dae.licenseSearch().ram_allocation||Fe.RAM_ALLOCATION_ENUM.DEFAULT,r=Fe.MEM_SETTING_KEY+t,n={[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return Nm.noBootFile()&&(n[Fe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Nm.getEnvCliRootPath()),{name:Fe.PROCESS_DESCRIPTORS.HDB,script:Fe.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:Im}}a(aF,"generateMainServerConfig");var Eae=9930;function hae(){Kn.initSync(!0);let e=Kn.get(Fe.CONFIG_PARAMS.ROOTPATH),t=fo.join(e,"clustering",wf.NATS_CONFIG_FILES.HUB_SERVER),r=fo.join(Kn.get(Fe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Fe.LOG_NAMES.HDB),n=sF.get(Fe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=wf.LOG_LEVEL_FLAGS[Kn.get(Fe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==Eae?"-"+n:""),script:oF,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return Kn.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Bu,i.error_file=Bu),i}a(hae,"generateNatsHubServerConfig");var pae=9940;function mae(){Kn.initSync(!0);let e=Kn.get(Fe.CONFIG_PARAMS.ROOTPATH),t=fo.join(e,"clustering",wf.NATS_CONFIG_FILES.LEAF_SERVER),r=fo.join(Kn.get(Fe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Fe.LOG_NAMES.HDB),n=sF.get(Fe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=wf.LOG_LEVEL_FLAGS[Kn.get(Fe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==pae?"-"+n:""),script:oF,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return Kn.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Bu,i.error_file=Bu),i}a(mae,"generateNatsLeafServerConfig");function Sae(){Kn.initSync();let e=fo.join(Kn.get(Fe.CONFIG_PARAMS.LOGGING_ROOT),Fe.LOG_NAMES.HDB),t={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:Fe.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:_ae,autorestart:!1};return Kn.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=Bu,t.error_file=Bu),t}a(Sae,"generateClusteringUpgradeV4ServiceConfig");function Tae(){let e={[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.RESTART_HDB};return Nm.noBootFile()&&(e[Fe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Nm.getEnvCliRootPath()),{...{name:Fe.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:iF},script:fae}}a(Tae,"generateRestart");function gae(){return{apps:[aF()]}}a(gae,"generateAllServiceConfigs");cF.exports={generateAllServiceConfigs:gae,generateMainServerConfig:aF,generateRestart:Tae,generateNatsHubServerConfig:hae,generateNatsLeafServerConfig:mae,generateClusteringUpgradeV4ServiceConfig:Sae}});var Hu=N((ECe,yF)=>{"use strict";var at=M(),Rae=te(),ho=Om(),wm=mr(),Eo=Ct(),Ea=lF(),Cm=se(),$c=W(),Aae=Di(),{startWorker:uF,onMessageFromWorkers:yae}=dt(),bae=wu(),fCe=require("util"),Oae=require("child_process"),Nae=require("fs"),{execFile:Iae}=Oae,Xe;yF.exports={enterPM2Mode:wae,start:ha,stop:eO,reload:_F,restart:fF,list:tO,describe:pF,connect:po,kill:Mae,startAllServices:Uae,startService:rO,getUniqueServicesList:mF,restartAllServices:vae,isServiceRegistered:SF,reloadStopStart:TF,restartHdb:hF,deleteProcess:Pae,startClusteringProcesses:RF,startClusteringThreads:AF,isHdbRestartRunning:Lae,isClusteringRunning:Hae,stopClustering:Bae,reloadClustering:xae,expectedRestartOfChildren:EF};var Cf=!1;yae(e=>{e.type==="restart"&&Cm.initSync(!0)});function wae(){Cf=!0}a(wae,"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,Cae=10,dF;function ha(e,t=!1){if(Cf)return Dae(e);let r=Iae(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),!dF&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<Cae&&(Nae.existsSync(ho.getHubConfigPath())?ha(e):(await ho.generateNatsConfig(!0),ha(e),await new Promise(c=>setTimeout(c,3e3)),await ho.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await ho.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=Cm.get(at.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,u=0,d;for(;l=c.exec(i);){if(l.index&&Eo.LOG_LEVEL_HIERARCHY[o]>=Eo.LOG_LEVEL_HIERARCHY[d||"info"]){let f=d===Eo.LOG_LEVELS.ERR||d===Eo.LOG_LEVELS.WRN?$c.OUTPUTS.STDERR:$c.OUTPUTS.STDOUT;$c.logCustomLevel(d||"info",f,n,i.slice(u,l.index).trim())}let[_,E]=l;u=l.index+_.length,d=Eo.LOG_LEVELS[E]}if(Eo.LOG_LEVEL_HIERARCHY[o]>=Eo.LOG_LEVEL_HIERARCHY[d||"info"]){let _=d===Eo.LOG_LEVELS.ERR||d===Eo.LOG_LEVELS.WRN?$c.OUTPUTS.STDERR:$c.OUTPUTS.STDOUT;$c.logCustomLevel(d||"info",_,n,i.slice(u).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!Jr&&(Jr=[],!t)){let i=a(()=>{dF=!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 Dae(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(Dae,"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 _F(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(_F,"reload");function fF(e){if(!Cf){EF();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(fF,"restart");function EF(){for(let e of Jr||[])e.config&&(e.config.restarts=0)}a(EF,"expectedRestartOfChildren");function Pae(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(Pae,"deleteProcess");async function hF(){await ha(Ea.generateRestart())}a(hF,"restartHdb");async function Lae(){let e=await tO();for(let t in e)if(e[t].name===at.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(Lae,"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 pF(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(pF,"describe");function Mae(){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(Mae,"kill");async function Uae(){try{await RF(),await AF(),await ha(Ea.generateAllServiceConfigs())}catch(e){throw Xe?.disconnect(),e}}a(Uae,"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 mF(){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(mF,"getUniqueServicesList");async function vae(e=[]){try{let t=!1,r=await mF();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 fF(o))}t&&await TF(at.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Xe?.disconnect(),t}}a(vae,"restartAllServices");async function SF(e){if(Jr?.find(r=>r.name===e))return!0;let t=await bae.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(SF,"isServiceRegistered");async function TF(e){let t=Cm.get(at.CONFIG_PARAMS.THREADS_COUNT)??Cm.get(at.CONFIG_PARAMS.THREADS),r=await pF(e),n=Rae.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await eO(e),await rO(e)):e===at.PROCESS_DESCRIPTORS.HDB?await hF():await _F(e)}a(TF,"reloadStopStart");var gF;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 AF(){gF=uF(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 Aae.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===at.PRE_4_0_0_VERSION){$c.info("Starting clustering upgrade 4.0.0 process"),uF(at.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(AF,"startClusteringThreads");async function Bae(){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 gF.terminate();else{let t=at.CLUSTERING_PROCESSES[e];await eO(t)}}a(Bae,"stopClustering");async function Hae(){for(let e in at.CLUSTERING_PROCESSES){let t=at.CLUSTERING_PROCESSES[e];if(await SF(t)===!1)return!1}return!0}a(Hae,"isClusteringRunning");async function xae(){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(xae,"reloadClustering")});var iO={};je(iO,{compactOnStart:()=>kae,copyDb:()=>CF});async function kae(){Df.notify("Running compact on start"),console.log("Running compact on start");let e=(0,nO.get)(pa.CONFIG_PARAMS.ROOTPATH),t=new Map,r=ut();try{for(let n in r){if(n==="system")continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,Dm.join)(e,"backup",n+".mdb"),o=(0,Dm.join)(e,pa.DATABASES_DIR_NAME,n+"-copy.mdb"),c=await bF(n);console.log("Database",n,"before compact has a total record count of",c),t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await CF(n,o),console.log("Backing up",n,"to",i),await(0,Vc.move)(s,i,{overwrite:!0})}xu();for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,Vc.move)(i,s,{overwrite:!0}),await(0,Vc.remove)((0,Dm.join)(e,pa.DATABASES_DIR_NAME,`${n}-copy.mdb-lock`));xu()}catch(n){Df.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,sO.updateConfigValue)(pa.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1);for(let[s,{db_path:i,backup_dest:o}]of t){console.error("Moving backup database",o,"back to",i);try{await(0,Vc.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw xu(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await bF(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){o=!1;let l=`There is a discrepancy between pre and post compact record count for database ${n}.
|
|
16
16
|
Total record count before compaction: ${i}, total after: ${c}.
|
|
17
|
-
Database backup has not been removed and can be found here: ${s}`;Df.error(l),console.error(l)}(0,nO.get)(
|
|
18
|
-
${r.stack}`;throw dO.error(n),BF(new Error)}}}a(tce,"getRolePermissions");function rce(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[gn.SYSTEM_SCHEMA_NAME]=n[gn.SYSTEM_SCHEMA_NAME],r.structure_user=n.structure_user;let s=Array.isArray(e.permission.structure_user)||e.permission.structure_user===!0?e.permission.structure_user:[];return Object.keys(t).forEach(i=>{if(s===!0||s.indexOf(i)>-1){r[i]=nce(t[i]);return}r[i]=FF(),n[i]?(n[i].describe&&(r[i].describe=!0),Object.keys(t[i]).forEach(o=>{if(n[i].tables[o]){let c=n[i].tables[o],l=t[i][o],u=sce(c,l);r[i].describe||qF.forEach(d=>{u[d]&&(r[i].describe=!0)}),r[i].tables[o]=u}else r[i].tables[o]=_O()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=_O()})}),r}a(rce,"translateRolePermissions");function nce(e){let t=FF(!0);return Object.keys(e).forEach(r=>{t.tables[r]=_O(!0,!0,!0,!0,!0)}),t}a(nce,"createStructureUserPermissions");function sce(e,t){let{attribute_permissions:r}=e;if(r?.length>0){let s={...e};s.attribute_permissions=[];let i=r.reduce((u,d)=>{let{attribute_name:_}=d,E=d;return gn.TIME_STAMP_NAMES.includes(_)&&(E=xF(_,d[vf])),u[_]=E,u},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=HF(o);return t.attributes.forEach(({attribute:u})=>{if(i[u]){let d=i[u];d.describe=VF(d),s.attribute_permissions.push(d),c||ice(d,l)}else if(u!==o){let d;gn.TIME_STAMP_NAMES.includes(u)?d=xF(u):d=HF(u),s.attribute_permissions.push(d)}}),c||s.attribute_permissions.push(l),s.describe=kF(s),s}else return e.describe=kF(e),e}a(sce,"getTableAttrPerms");function kF(e){return qF.filter(t=>e[t]).length>0}a(kF,"getSchemaTableDescribePerm");function VF(e){return $F.filter(t=>e[t]).length>0}a(VF,"getAttributeDescribePerm");function ice(e,t){$F.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(ice,"checkForHashPerms")});var WF={};je(WF,{Headers:()=>So,appendHeader:()=>vm,mergeHeaders:()=>hO});function vm(e,t,r,n){if(e.append)e.append(t,r,n);else if(e.set){let s=e.get(t);if(s)if(n)r=(typeof s=="string"?s:s.join(", "))+", "+r;else if(typeof s=="string")r=[s,r];else{s.push(r);return}return e.set(t,r)}else e[t]=(e[t]?e[t]+", ":"")+r}function hO(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new So(e));for(let[r,n]of t)e.has(r)?r.toLowerCase()==="set-cookie"&&e.append?.(r,n,!0):e.set(r,n);return e}var So,Bf=Oe(()=>{So=class extends Map{static{a(this,"Headers")}constructor(t){if(t)if(t[Symbol.iterator])super(t);else{super();for(let r in t)this.set(r,t[r])}else super()}set(t,r){return typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r),super.set(t.toLowerCase(),[t,r])}get(t){return typeof t!="string"&&(t=""+t),super.get(t.toLowerCase())?.[1]}has(t){return typeof t!="string"&&(t=""+t),super.has(t.toLowerCase())}setIfNone(t,r){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let n=t.toLowerCase();if(!super.has(n))return super.set(n,[t,r])}append(t,r,n){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let s=t.toLowerCase(),i=super.get(s);if(i){let o=i[1];if(n)r=(typeof o=="string"?o:o.join(", "))+", "+r;else if(typeof o=="string")r=[o,r];else{o.push(r);return}}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}};a(vm,"appendHeader");a(hO,"mergeHeaders")});var Hf={};je(Hf,{authentication:()=>eG,bypassAuth:()=>_ce,login:()=>Ece,logout:()=>hce,start:()=>fce});function _ce(){ZF=!0}async function eG(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let f=e.isOperationsServer?lce?cce:[]:ace?oce:[];if(f.includes(i)||f.includes("*")){if(e.method==="OPTIONS"){let h=new So([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers","Accept, Content-Type, Authorization"],["Access-Control-Allow-Origin",i]]);return Bm&&h.set("Access-Control-Allow-Credentials","true"),{status:200,headers:h}}o.push("Access-Control-Allow-Origin",i),Bm&&o.push("Access-Control-Allow-Credentials","true")}}let l,u;if(Bm){i||(i=r.host);let f=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.split(/;\s+/)||[];for(let T of h)if(T.startsWith(f)){let m=T.indexOf(";");l=T.slice(f.length,m===-1?T.length:m),u=await jF.get(l);break}e.session=u||(u={})}let d=a((f,h,T)=>{let m=new ku.AuthAuditLog(f,h,Or.AUTH_AUDIT_TYPES.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);m.auth_strategy=T,l&&(m.session_id=l),r.referer&&(m.referer=r.referer),r.origin&&(m.origin=r.origin),h===Or.AUTH_AUDIT_STATUS.SUCCESS?pO.notify(m):pO.error(m)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&pO.error("Authorization error:",e._nodeRequest.socket.authorizationError),e.mtlsConfig&&e.authorized&&e.peerCertificate.subject){let f=e.mtlsConfig.user;f!==null?((f===void 0||f==="Common Name"||f==="CN")&&(f=e.peerCertificate.subject.CN),e.user=await it.getUser(f,null,e),d(f,Or.AUTH_AUDIT_STATUS.SUCCESS,"mTLS")):(0,ku.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let _;if(!e.user)if(n){if(_=Kc.get(n),!_){let f=n.indexOf(" "),h=n.slice(0,f),T=n.slice(f+1),m,g;try{switch(h){case"Basic":let S=atob(T),b=S.indexOf(":");m=S.slice(0,b),g=S.slice(b+1),_=m||g?await it.getUser(m,g,e):null;break;case"Bearer":try{_=await(0,Hm.validateOperationToken)(T)}catch(I){if(I.message==="invalid token")try{return await(0,Hm.validateRefreshToken)(T),c({status:-1})}catch{throw I}}break}}catch(S){return dce&&(Kc.get(T)||(Kc.set(T,T),d(m,Or.AUTH_AUDIT_STATUS.FAILURE,h))),c({status:401,body:Yc({error:S.message},e)})}Kc.set(n,_),uce&&d(_.username,Or.AUTH_AUDIT_STATUS.SUCCESS,h)}e.user=_}else u?.user?e.user=await it.getUser(u.user,null,e):(ZF&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,QF.getSuperUser)());Bm&&(e.session.update=function(f){if(!l){l=(0,JF.v4)();let T=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${l}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",T):E?.headers?.set&&E.headers.set("Set-Cookie",T)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):E?.headers?.set&&(i&&E.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),E.headers.set("X-Hdb-Session","Secure"))),f.id=l,jF.put(f)},e.login=async function(f,h){e.user=await it.getUser(f,h,e),e.session.update({user:e.user&&(e.user.getId?.()??e.user.username)})});let E=await t(e);return E&&(E.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&wi.loginPath?(E.status=302,E.headers.set("Location",wi.loginPath(e))):E.headers.set("WWW-Authenticate","Basic")),c(E))}catch(l){throw c(l)}function c(l){let u=o.length;if(u>0){let d=l.headers;d||(l.headers=d=new So);for(let _=0;_<u;){let E=o[_++];d.set(E,o[_++])}}return o=null,l}a(c,"applyResponseHeaders")}function fce({server:e,port:t,securePort:r}){e.http(eG,t||r?{port:t,securePort:r}:{port:"all"}),zF||(zF=!0,setInterval(()=>{Kc=new Map},Ts.get(Or.CONFIG_PARAMS.AUTHENTICATION_CACHETTL)).unref(),XF.user.addListener(()=>{Kc=new Map}))}async function Ece(e){if(!e.baseRequest?.login)throw new Error("No session for login");return e.baseResponse.headers.set=(t,r)=>{e.fastifyResponse.header(t,r)},await e.baseRequest.login(e.username,e.password),"Login successful"}async function hce(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var QF,Hm,JF,Ts,Or,ku,XF,pO,oce,ace,cce,lce,jF,Bm,ZF,uce,dce,Kc,zF,xm=Oe(()=>{QF=L(xn());qr();eu();Hm=L(lu());Pe();JF=require("uuid"),Ts=L(se()),Or=L(M()),ku=L(W()),XF=L(m_());Bf();Wc();pO=(0,ku.loggerWithTag)("auth-event");Ts.initSync();oce=Ts.get(Or.CONFIG_PARAMS.HTTP_CORSACCESSLIST),ace=Ts.get(Or.CONFIG_PARAMS.HTTP_CORS),cce=Ts.get(Or.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORSACCESSLIST),lce=Ts.get(Or.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORS),jF=Et({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),Bm=Ts.get(Or.CONFIG_PARAMS.AUTHENTICATION_ENABLESESSIONS)??!0,ZF=process.env.AUTHENTICATION_AUTHORIZELOCAL??Ts.get(Or.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,uce=Ts.get(Or.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,dce=Ts.get(Or.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,Kc=new Map;it.onInvalidatedUser(()=>{Kc=new Map});a(_ce,"bypassAuth");a(eG,"authentication");a(fce,"start");a(Ece,"login");a(hce,"logout")});var aG=N((MCe,oG)=>{"use strict";var Ne=require("joi"),tG=require("fs-extra"),rG=require("path"),Yn=Tt(),nG=se(),sG=M(),iG=W(),{hdb_errors:pce}=_e(),{HDB_ERROR_MSGS:Xr}=pce,To=/^[a-zA-Z0-9-_]+$/,mce=/^[a-zA-Z0-9-_]+$/;oG.exports={getDropCustomFunctionValidator:Tce,setCustomFunctionValidator:gce,addComponentValidator:bce,dropCustomFunctionProjectValidator:Oce,packageComponentValidator:Nce,deployComponentValidator:Ice,setComponentFileValidator:Rce,getComponentFileValidator:yce,dropComponentFileValidator:Ace,addSSHKeyValidator:wce,updateSSHKeyValidator:Cce,deleteSSHKeyValidator:Dce,setSSHKnownHostsValidator:Pce};function km(e,t,r){try{let n=nG.get(sG.CONFIG_PARAMS.COMPONENTSROOT),s=rG.join(n,t);return tG.existsSync(s)?e?t:r.message(Xr.PROJECT_EXISTS):e?r.message(Xr.NO_PROJECT):t}catch(n){return iG.error(n),r.message(Xr.VALIDATION_ERR)}}a(km,"checkProjectExists");function xf(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(xf,"checkFilePath");function Sce(e,t,r,n){try{let s=nG.get(sG.CONFIG_PARAMS.COMPONENTSROOT),i=rG.join(s,e,t,r+".js");return tG.existsSync(i)?r:n.message(Xr.NO_FILE)}catch(s){return iG.error(s),n.message(Xr.VALIDATION_ERR)}}a(Sce,"checkFileExists");function Tce(e){let t=Ne.object({project:Ne.string().pattern(To).custom(km.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().pattern(To).custom(Sce.bind(null,e.project,e.type)).custom(xf).required().messages({"string.pattern.base":Xr.BAD_FILE_NAME})});return Yn.validateBySchema(e,t)}a(Tce,"getDropCustomFunctionValidator");function gce(e){let t=Ne.object({project:Ne.string().pattern(To).custom(km.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().custom(xf).required(),function_content:Ne.string().required()});return Yn.validateBySchema(e,t)}a(gce,"setCustomFunctionValidator");function Rce(e){let t=Ne.object({project:Ne.string().pattern(To).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),file:Ne.string().custom(xf).required(),payload:Ne.string().allow("").optional(),encoding:Ne.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Yn.validateBySchema(e,t)}a(Rce,"setComponentFileValidator");function Ace(e){let t=Ne.object({project:Ne.string().pattern(To).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),file:Ne.string().custom(xf).optional()});return Yn.validateBySchema(e,t)}a(Ace,"dropComponentFileValidator");function yce(e){let t=Ne.object({project:Ne.string().required(),file:Ne.string().custom(xf).required(),encoding:Ne.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Yn.validateBySchema(e,t)}a(yce,"getComponentFileValidator");function bce(e){let t=Ne.object({project:Ne.string().pattern(To).custom(km.bind(null,!1)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME})});return Yn.validateBySchema(e,t)}a(bce,"addComponentValidator");function Oce(e){let t=Ne.object({project:Ne.string().pattern(To).custom(km.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME})});return Yn.validateBySchema(e,t)}a(Oce,"dropCustomFunctionProjectValidator");function Nce(e){let t=Ne.object({project:Ne.string().pattern(To).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),skip_node_modules:Ne.boolean()});return Yn.validateBySchema(e,t)}a(Nce,"packageComponentValidator");function Ice(e){let t=Ne.object({project:Ne.string().pattern(To).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),package:Ne.string().optional(),restart:Ne.boolean().optional()});return Yn.validateBySchema(e,t)}a(Ice,"deployComponentValidator");function wce(e){let t=Ne.object({name:Ne.string().pattern(mce).required().messages({"string.pattern.base":Xr.BAD_SSH_KEY_NAME}),key:Ne.string().required(),host:Ne.string().required(),hostname:Ne.string().required(),known_hosts:Ne.string().optional()});return Yn.validateBySchema(e,t)}a(wce,"addSSHKeyValidator");function Cce(e){let t=Ne.object({name:Ne.string().required(),key:Ne.string().required()});return Yn.validateBySchema(e,t)}a(Cce,"updateSSHKeyValidator");function Dce(e){let t=Ne.object({name:Ne.string().required()});return Yn.validateBySchema(e,t)}a(Dce,"deleteSSHKeyValidator");function Pce(e){let t=Ne.object({known_hosts:Ne.string().required()});return Yn.validateBySchema(e,t)}a(Pce,"setSSHKnownHostsValidator")});var kf=N((vCe,fG)=>{"use strict";var Fm=require("joi"),jc=require("path"),qm=require("fs-extra"),{exec:Lce}=require("child_process"),Mce=require("util"),cG=Mce.promisify(Lce),qu=M(),{handleHDBError:Fu,hdb_errors:Uce}=_e(),{HTTP_STATUS_CODES:Gu}=Uce,Vu=se(),vce=Tt(),$u=W();Vu.initSync();var mO=Vu.get(qu.CONFIG_PARAMS.COMPONENTSROOT),lG="npm install --force --omit=dev --json",Bce=`${lG} --dry-run`,Hce=Vu.get(qu.CONFIG_PARAMS.ROOTPATH),Gm=jc.join(Hce,"ssh");fG.exports={installModules:Gce,auditModules:qce,installAllRootModules:xce,uninstallRootModule:kce,linkHarperdb:Fce,runCommand:Ku};async function xce(e=!1,t=Vu.get(qu.CONFIG_PARAMS.ROOTPATH)){await $m();let r=!1,n=process.env;qm.pathExistsSync(Gm)&&qm.readdirSync(Gm).forEach(s=>{s.includes(".key")&&!r&&(n={GIT_SSH_COMMAND:"ssh -F "+jc.join(Gm,"config")+" -o UserKnownHostsFile="+jc.join(Gm,"known_hosts"),...process.env},r=!0)}),await Ku(e?"npm install --force --ignore-scripts":"npm install --force",t,n)}a(xce,"installAllRootModules");async function kce(e){await Ku(`npm uninstall ${e}`,Vu.get(qu.CONFIG_PARAMS.ROOTPATH))}a(kce,"uninstallRootModule");async function Fce(){await $m(),await Ku(`npm link ${qu.PACKAGE_ROOT}`,Vu.get(qu.CONFIG_PARAMS.ROOTPATH))}a(Fce,"linkHarperdb");async function Ku(e,t=void 0,r=process.env){let n,s;try{({stdout:n,stderr:s}=await cG(e,{cwd:t,env:r}))}catch(i){throw new Error(i.stderr.replace(`
|
|
19
|
-
`,""))}return s&&!s.includes("Debugger listening")&&!s.includes("warn using --force")
|
|
20
|
-
`,"")}a(
|
|
17
|
+
Database backup has not been removed and can be found here: ${s}`;Df.error(l),console.error(l)}(0,nO.get)(pa.CONFIG_PARAMS.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||o===!1||(console.log("Removing backup",s),await(0,Vc.remove)(s))}(0,sO.updateConfigValue)(pa.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1)}async function bF(e){let t=await(0,wF.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}async function CF(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,OF.open)(new NF.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 IF.default(!h,h);g.encoding="binary",g.compression=T;let S=n.openDB(E,g);S.decoder=null,g.compression=m;let b=o.openDB(E,g);b.encoder=null,console.log("copying",E,"from",e,"to",t),await _(S,b,h,d)}if(i){let E=n.openDB(Pm.AUDIT_STORE_NAME,Pf);console.log("copying audit log for",e,"to",t),_(i,E,!1,d)}async function _(E,f,h,T){let m=0,g=0;for(let{key:S,value:b,version:I}of E.getRange({start:null,versions:h,transaction:T}))l=f.put(S,b,I),m++,T.openTimer&&(T.openTimer=0),g+=(S?.length||10)+b.length,u++>5e3&&(await l,console.log("copied",m,"entries",g,"bytes"),u=0);console.log("finish copying, copied",m,"entries",g,"bytes")}a(_,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{d.done(),o.close()}}var OF,Dm,Vc,nO,NF,IF,Pm,pa,wF,sO,Df,oO=Ne(()=>{Pe();OF=require("lmdb"),Dm=require("path"),Vc=require("fs-extra"),nO=L(se()),NF=L(c_()),IF=L(a_()),Pm=L(Bt()),pa=L(M());Ji();wF=L(ro()),sO=L(wt()),Df=L(W());a(kae,"compactOnStart");a(bF,"getTotalDBRecordCount");a(CF,"copyDb")});var Gu=N((ACe,BF)=>{"use strict";var Fae=require("minimist"),{isMainThread:cO,parentPort:Mf,threadId:TCe}=require("worker_threads"),Pt=M(),{PROCESS_DESCRIPTORS_VALIDATE:ku}=Pt,Pi=W(),lO=te(),Um=Om(),Mm=mr(),gCe=Ct(),MF=wt(),ei=Hu(),DF=wu(),{compactOnStart:Gae}=(oO(),oe(iO)),qae=Wa(),{restartWorkers:vm,onMessageByType:$ae}=dt(),{handleHDBError:Vae,hdb_errors:Kae}=_e(),{HTTP_STATUS_CODES:Yae}=Kae,Uf=se(),{sendOperationToNode:PF,getThisNodeName:Wae,monitorNodeCAs:jae}=(us(),oe(ca)),{getHDBNodeTable:RCe}=(cu(),oe(pB));Uf.initSync();var Lf=`Restarting HarperDB. This may take up to ${Pt.RESTART_TIMEOUT_MS/1e3} seconds.`,zae="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",LF="Clustering is not enabled so cannot be restarted",Qae="Invalid service",Fu,Ss;BF.exports={restart:UF,restartService:uO};cO&&$ae(Pt.ITC_EVENT_TYPES.RESTART,async(e,t)=>{e.workerType?await uO({service:e.workerType}):UF({operation:"restart"}),t.postMessage({type:"restart-complete"})});async function UF(e){Ss=Object.keys(e).length===0,Fu=await ei.isServiceRegistered(Pt.HDB_PROC_DESCRIPTOR);let t=Fae(process.argv);if(t.service){await uO(t);return}if(Ss&&!Fu){console.error(zae);return}if(Ss&&console.log(Lf),Fu){ei.enterPM2Mode(),Pi.notify(Lf);let r=qae(Object.keys(Pt.CONFIG_PARAM_MAP),!0);return lO.isEmptyOrZeroLength(Object.keys(r))||MF.updateConfigValue(void 0,void 0,r,!0,!0),Jae(),Lf}return cO?(Pi.notify(Lf),Uf.get(Pt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await Gae(),setTimeout(()=>{vm()},50)):Mf.postMessage({type:Pt.ITC_EVENT_TYPES.RESTART}),Lf}a(UF,"restart");async function uO(e){let{service:t}=e;if(Pt.PROCESS_DESCRIPTORS_VALIDATE[t]===void 0)throw Vae(new Error,Qae,Yae.BAD_REQUEST,void 0,void 0,!0);if(ei.expectedRestartOfChildren(),Fu=await ei.isServiceRegistered(Pt.HDB_PROC_DESCRIPTOR),!cO){e.replicated&&jae(),Mf.postMessage({type:Pt.ITC_EVENT_TYPES.RESTART,workerType:t}),Mf.ref(),await new Promise(s=>{Mf.on("message",i=>{i.type==="restart-complete"&&(s(),Mf.unref())})});let n;if(e.replicated){e.replicated=!1,n=[];for(let s of server.nodes){if(s.name===Wae())continue;let{job_id:i}=await PF(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 PF(s,{operation:"get_job",id:i})).results[0];if(E.status==="COMPLETE"&&(clearInterval(d),o({node:s.name,message:E.message})),E.status==="ERROR"){clearInterval(d);let f=new Error(E.message);f.replicated=n,c(f)}},250)}))}return{replicated:n}}return}let r;switch(t){case ku.clustering:if(!Uf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=LF;break}Ss&&console.log("Restarting clustering"),Pi.notify("Restarting clustering"),await vF();break;case ku.clustering_config:case ku["clustering config"]:if(!Uf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=LF;break}Ss&&console.log("Restarting clustering_config"),Pi.notify("Restarting clustering_config"),await ei.reloadClustering();break;case"custom_functions":case"custom functions":case ku.harperdb:case ku.http_workers:case ku.http:if(Ss&&!Fu){r=`Restart ${t} is not available from the CLI when running in non-pm2 mode. Either call restart ${t} from the API or stop and start HarperDB.`;break}Ss&&console.log("Restarting http_workers"),Pi.notify("Restarting http_workers"),Ss?await ei.restart(Pt.HDB_PROC_DESCRIPTOR):await vm("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(Pi.error(r),Ss&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(uO,"restartService");async function Jae(){await vF(),await ei.restart(Pt.HDB_PROC_DESCRIPTOR),await lO.async_set_timeout(2e3),Uf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await aO(),Ss&&(await Mm.closeConnection(),process.exit(0))}a(Jae,"restartPM2Mode");async function vF(){if(!MF.getConfigFromFile(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await DF.getHDBProcessInfo()).clustering.length===0)Pi.trace("Clustering not running, restart will start clustering services"),await Um.generateNatsConfig(!0),await ei.startClusteringProcesses(),await ei.startClusteringThreads(),await aO(),Ss&&await Mm.closeConnection();else{await Um.generateNatsConfig(!0),Fu?(Pi.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await ei.restart(Pt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await ei.restart(Pt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await DF.getHDBProcessInfo()).clustering.forEach(s=>{Pi.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await lO.async_set_timeout(3e3),await aO(),await Mm.updateLocalStreams(),Ss&&await Mm.closeConnection(),Pi.trace("Restart clustering restarting ingest and reply service threads");let t=vm(Pt.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=vm(Pt.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(vF,"restartClustering");async function aO(){await Um.removeNatsConfig(Pt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Um.removeNatsConfig(Pt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(aO,"removeNatsConfig")});var WF=N((OCe,YF)=>{"use strict";var bCe=require("lodash"),gn=M(),{handleHDBError:HF,hdb_errors:Xae}=_e(),{HDB_ERROR_MSGS:Zae,HTTP_STATUS_CODES:ece}=Xae,dO=W();YF.exports={getRolePermissions:rce};var Kc=Object.create(null),tce=a(e=>({key:e,perms:{}}),"perms_template_obj"),GF=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),qF=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,...qF(t,r,n,s)}),"table_perms_template"),xF=a((e,t=qF())=>({attribute_name:e,describe:KF(t),[vf]:t[vf],[fO]:t[fO],[EO]:t[EO]}),"attr_perms_template"),kF=a((e,t=!1)=>({attribute_name:e,describe:t,[vf]:t}),"timestamp_attr_perms_template"),{READ:vf,INSERT:fO,UPDATE:EO}=gn.PERMS_CRUD_ENUM,$F=Object.values(gn.PERMS_CRUD_ENUM),VF=[vf,fO,EO];function rce(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r={...global.hdb_schema};delete r[gn.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(Kc[t]&&Kc[t].key===n)return Kc[t].perms;let s=nce(e,r);return Kc[t]?Kc[t].key=n:Kc[t]=tce(n),Kc[t].perms=s,s}catch(r){if(!e[gn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[gn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<gn.PERMS_UPDATE_RELEASE_TIMESTAMP){let n=`Role permissions for role '${t}' must be updated to align with new structure from the 2.2.0 release.`;throw dO.error(n),dO.debug(r),HF(new Error,Zae.OUTDATED_PERMS_TRANSLATION_ERROR,ece.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
|
|
18
|
+
${r.stack}`;throw dO.error(n),HF(new Error)}}}a(rce,"getRolePermissions");function nce(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]=sce(t[i]);return}r[i]=GF(),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=ice(c,l);r[i].describe||$F.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(nce,"translateRolePermissions");function sce(e){let t=GF(!0);return Object.keys(e).forEach(r=>{t.tables[r]=_O(!0,!0,!0,!0,!0)}),t}a(sce,"createStructureUserPermissions");function ice(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=kF(_,d[vf])),u[_]=E,u},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=xF(o);return t.attributes.forEach(({attribute:u})=>{if(i[u]){let d=i[u];d.describe=KF(d),s.attribute_permissions.push(d),c||oce(d,l)}else if(u!==o){let d;gn.TIME_STAMP_NAMES.includes(u)?d=kF(u):d=xF(u),s.attribute_permissions.push(d)}}),c||s.attribute_permissions.push(l),s.describe=FF(s),s}else return e.describe=FF(e),e}a(ice,"getTableAttrPerms");function FF(e){return $F.filter(t=>e[t]).length>0}a(FF,"getSchemaTableDescribePerm");function KF(e){return VF.filter(t=>e[t]).length>0}a(KF,"getAttributeDescribePerm");function oce(e,t){VF.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(oce,"checkForHashPerms")});var jF={};je(jF,{Headers:()=>mo,appendHeader:()=>Bm,mergeHeaders:()=>hO});function Bm(e,t,r,n){if(e.append)e.append(t,r,n);else if(e.set){let s=e.get(t);if(s)if(n)r=(typeof s=="string"?s:s.join(", "))+", "+r;else if(typeof s=="string")r=[s,r];else{s.push(r);return}return e.set(t,r)}else e[t]=(e[t]?e[t]+", ":"")+r}function hO(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new mo(e));for(let[r,n]of t)e.has(r)?r.toLowerCase()==="set-cookie"&&e.append?.(r,n,!0):e.set(r,n);return e}var mo,Bf=Ne(()=>{mo=class extends Map{static{a(this,"Headers")}constructor(t){if(t)if(t[Symbol.iterator])super(t);else{super();for(let r in t)this.set(r,t[r])}else super()}set(t,r){return typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r),super.set(t.toLowerCase(),[t,r])}get(t){return typeof t!="string"&&(t=""+t),super.get(t.toLowerCase())?.[1]}has(t){return typeof t!="string"&&(t=""+t),super.has(t.toLowerCase())}setIfNone(t,r){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let n=t.toLowerCase();if(!super.has(n))return super.set(n,[t,r])}append(t,r,n){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let s=t.toLowerCase(),i=super.get(s);if(i){let o=i[1];if(n)r=(typeof o=="string"?o:o.join(", "))+", "+r;else if(typeof o=="string")r=[o,r];else{o.push(r);return}}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}};a(Bm,"appendHeader");a(hO,"mergeHeaders")});var Hf={};je(Hf,{authentication:()=>tG,bypassAuth:()=>fce,login:()=>hce,logout:()=>pce,start:()=>Ece});function fce(){eG=!0}async function tG(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let f=e.isOperationsServer?uce?lce:[]:cce?ace:[];if(f.includes(i)||f.includes("*")){if(e.method==="OPTIONS"){let h=new mo([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers","Accept, Content-Type, Authorization"],["Access-Control-Allow-Origin",i]]);return Hm&&h.set("Access-Control-Allow-Credentials","true"),{status:200,headers:h}}o.push("Access-Control-Allow-Origin",i),Hm&&o.push("Access-Control-Allow-Credentials","true")}}let l,u;if(Hm){i||(i=r.host);let f=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.split(/;\s+/)||[];for(let T of h)if(T.startsWith(f)){let m=T.indexOf(";");l=T.slice(f.length,m===-1?T.length:m),u=await zF.get(l);break}e.session=u||(u={})}let d=a((f,h,T)=>{let m=new qu.AuthAuditLog(f,h,Or.AUTH_AUDIT_TYPES.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);m.auth_strategy=T,l&&(m.session_id=l),r.referer&&(m.referer=r.referer),r.origin&&(m.origin=r.origin),h===Or.AUTH_AUDIT_STATUS.SUCCESS?pO.notify(m):pO.error(m)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&pO.error("Authorization error:",e._nodeRequest.socket.authorizationError),e.mtlsConfig&&e.authorized&&e.peerCertificate.subject){let f=e.mtlsConfig.user;f!==null?((f===void 0||f==="Common Name"||f==="CN")&&(f=e.peerCertificate.subject.CN),e.user=await it.getUser(f,null,e),d(f,Or.AUTH_AUDIT_STATUS.SUCCESS,"mTLS")):(0,qu.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let _;if(!e.user)if(n){if(_=Yc.get(n),!_){let f=n.indexOf(" "),h=n.slice(0,f),T=n.slice(f+1),m,g;try{switch(h){case"Basic":let S=atob(T),b=S.indexOf(":");m=S.slice(0,b),g=S.slice(b+1),_=m||g?await it.getUser(m,g,e):null;break;case"Bearer":try{_=await(0,xm.validateOperationToken)(T)}catch(I){if(I.message==="invalid token")try{return await(0,xm.validateRefreshToken)(T),c({status:-1})}catch{throw I}}break}}catch(S){return _ce&&(Yc.get(T)||(Yc.set(T,T),d(m,Or.AUTH_AUDIT_STATUS.FAILURE,h))),c({status:401,body:Wc({error:S.message},e)})}Yc.set(n,_),dce&&d(_.username,Or.AUTH_AUDIT_STATUS.SUCCESS,h)}e.user=_}else u?.user?e.user=await it.getUser(u.user,null,e):(eG&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,JF.getSuperUser)());Hm&&(e.session.update=function(f){if(!l){l=(0,XF.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,zF.put(f)},e.login=async function(f,h){e.user=await it.getUser(f,h,e),e.session.update({user:e.user&&(e.user.getId?.()??e.user.username)})});let E=await t(e);return E&&(E.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&wi.loginPath?(E.status=302,E.headers.set("Location",wi.loginPath(e))):E.headers.set("WWW-Authenticate","Basic")),c(E))}catch(l){throw c(l)}function c(l){let u=o.length;if(u>0){let d=l.headers;d||(l.headers=d=new mo);for(let _=0;_<u;){let E=o[_++];d.set(E,o[_++])}}return o=null,l}a(c,"applyResponseHeaders")}function Ece({server:e,port:t,securePort:r}){e.http(tG,t||r?{port:t,securePort:r}:{port:"all"}),QF||(QF=!0,setInterval(()=>{Yc=new Map},Ts.get(Or.CONFIG_PARAMS.AUTHENTICATION_CACHETTL)).unref(),ZF.user.addListener(()=>{Yc=new Map}))}async function hce(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 pce(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var JF,xm,XF,Ts,Or,qu,ZF,pO,ace,cce,lce,uce,zF,Hm,eG,dce,_ce,Yc,QF,km=Ne(()=>{JF=L(xn());qr();nu();xm=L(_u());Pe();XF=require("uuid"),Ts=L(se()),Or=L(M()),qu=L(W()),ZF=L(S_());Bf();jc();pO=(0,qu.loggerWithTag)("auth-event");Ts.initSync();ace=Ts.get(Or.CONFIG_PARAMS.HTTP_CORSACCESSLIST),cce=Ts.get(Or.CONFIG_PARAMS.HTTP_CORS),lce=Ts.get(Or.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORSACCESSLIST),uce=Ts.get(Or.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORS),zF=Et({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),Hm=Ts.get(Or.CONFIG_PARAMS.AUTHENTICATION_ENABLESESSIONS)??!0,eG=process.env.AUTHENTICATION_AUTHORIZELOCAL??Ts.get(Or.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,dce=Ts.get(Or.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,_ce=Ts.get(Or.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,Yc=new Map;it.onInvalidatedUser(()=>{Yc=new Map});a(fce,"bypassAuth");a(tG,"authentication");a(Ece,"start");a(hce,"login");a(pce,"logout")});var cG=N((UCe,aG)=>{"use strict";var Oe=require("joi"),rG=require("fs-extra"),nG=require("path"),Yn=Tt(),sG=se(),iG=M(),oG=W(),{hdb_errors:mce}=_e(),{HDB_ERROR_MSGS:Xr}=mce,So=/^[a-zA-Z0-9-_]+$/,Sce=/^[a-zA-Z0-9-_]+$/;aG.exports={getDropCustomFunctionValidator:gce,setCustomFunctionValidator:Rce,addComponentValidator:Oce,dropCustomFunctionProjectValidator:Nce,packageComponentValidator:Ice,deployComponentValidator:wce,setComponentFileValidator:Ace,getComponentFileValidator:bce,dropComponentFileValidator:yce,addSSHKeyValidator:Cce,updateSSHKeyValidator:Dce,deleteSSHKeyValidator:Pce,setSSHKnownHostsValidator:Lce};function Fm(e,t,r){try{let n=sG.get(iG.CONFIG_PARAMS.COMPONENTSROOT),s=nG.join(n,t);return rG.existsSync(s)?e?t:r.message(Xr.PROJECT_EXISTS):e?r.message(Xr.NO_PROJECT):t}catch(n){return oG.error(n),r.message(Xr.VALIDATION_ERR)}}a(Fm,"checkProjectExists");function xf(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(xf,"checkFilePath");function Tce(e,t,r,n){try{let s=sG.get(iG.CONFIG_PARAMS.COMPONENTSROOT),i=nG.join(s,e,t,r+".js");return rG.existsSync(i)?r:n.message(Xr.NO_FILE)}catch(s){return oG.error(s),n.message(Xr.VALIDATION_ERR)}}a(Tce,"checkFileExists");function gce(e){let t=Oe.object({project:Oe.string().pattern(So).custom(Fm.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),type:Oe.string().valid("helpers","routes").required(),file:Oe.string().pattern(So).custom(Tce.bind(null,e.project,e.type)).custom(xf).required().messages({"string.pattern.base":Xr.BAD_FILE_NAME})});return Yn.validateBySchema(e,t)}a(gce,"getDropCustomFunctionValidator");function Rce(e){let t=Oe.object({project:Oe.string().pattern(So).custom(Fm.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),type:Oe.string().valid("helpers","routes").required(),file:Oe.string().custom(xf).required(),function_content:Oe.string().required()});return Yn.validateBySchema(e,t)}a(Rce,"setCustomFunctionValidator");function Ace(e){let t=Oe.object({project:Oe.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),file:Oe.string().custom(xf).required(),payload:Oe.string().allow("").optional(),encoding:Oe.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Yn.validateBySchema(e,t)}a(Ace,"setComponentFileValidator");function yce(e){let t=Oe.object({project:Oe.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),file:Oe.string().custom(xf).optional()});return Yn.validateBySchema(e,t)}a(yce,"dropComponentFileValidator");function bce(e){let t=Oe.object({project:Oe.string().required(),file:Oe.string().custom(xf).required(),encoding:Oe.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Yn.validateBySchema(e,t)}a(bce,"getComponentFileValidator");function Oce(e){let t=Oe.object({project:Oe.string().pattern(So).custom(Fm.bind(null,!1)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME})});return Yn.validateBySchema(e,t)}a(Oce,"addComponentValidator");function Nce(e){let t=Oe.object({project:Oe.string().pattern(So).custom(Fm.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME})});return Yn.validateBySchema(e,t)}a(Nce,"dropCustomFunctionProjectValidator");function Ice(e){let t=Oe.object({project:Oe.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),skip_node_modules:Oe.boolean()});return Yn.validateBySchema(e,t)}a(Ice,"packageComponentValidator");function wce(e){let t=Oe.object({project:Oe.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),package:Oe.string().optional(),restart:Oe.alternatives().try(Oe.boolean(),Oe.string().valid("rolling")).optional()});return Yn.validateBySchema(e,t)}a(wce,"deployComponentValidator");function Cce(e){let t=Oe.object({name:Oe.string().pattern(Sce).required().messages({"string.pattern.base":Xr.BAD_SSH_KEY_NAME}),key:Oe.string().required(),host:Oe.string().required(),hostname:Oe.string().required(),known_hosts:Oe.string().optional()});return Yn.validateBySchema(e,t)}a(Cce,"addSSHKeyValidator");function Dce(e){let t=Oe.object({name:Oe.string().required(),key:Oe.string().required()});return Yn.validateBySchema(e,t)}a(Dce,"updateSSHKeyValidator");function Pce(e){let t=Oe.object({name:Oe.string().required()});return Yn.validateBySchema(e,t)}a(Pce,"deleteSSHKeyValidator");function Lce(e){let t=Oe.object({known_hosts:Oe.string().required()});return Yn.validateBySchema(e,t)}a(Lce,"setSSHKnownHostsValidator")});var kf=N((BCe,EG)=>{"use strict";var Gm=require("joi"),ma=require("path"),$u=require("fs-extra"),{exec:Mce}=require("child_process"),Uce=require("util"),lG=Uce.promisify(Mce),zc=M(),{handleHDBError:Vu,hdb_errors:vce}=_e(),{HTTP_STATUS_CODES:Ku}=vce,Qc=se(),Bce=Tt(),Jc=W();Qc.initSync();var mO=Qc.get(zc.CONFIG_PARAMS.COMPONENTSROOT),uG="npm install --force --omit=dev --json",Hce=`${uG} --dry-run`,xce=Qc.get(zc.CONFIG_PARAMS.ROOTPATH),qm=ma.join(xce,"ssh");EG.exports={installModules:qce,auditModules:$ce,installAllRootModules:kce,uninstallRootModule:Fce,linkHarperdb:Gce,runCommand:Yu};async function kce(e=!1,t=Qc.get(zc.CONFIG_PARAMS.ROOTPATH)){await $m();let r=!1,n=process.env;$u.pathExistsSync(qm)&&$u.readdirSync(qm).forEach(s=>{s.includes(".key")&&!r&&(n={GIT_SSH_COMMAND:"ssh -F "+ma.join(qm,"config")+" -o UserKnownHostsFile="+ma.join(qm,"known_hosts"),...process.env},r=!0)});try{let s=Qc.get(zc.CONFIG_PARAMS.ROOTPATH),i=ma.join(s,"node_modules","harperdb");$u.lstatSync(i).isSymbolicLink()&&$u.unlinkSync(i)}catch(s){s.code!=="ENOENT"&&Jc.error("Error removing symlink:",s)}await Yu(e?"npm install --force --ignore-scripts":"npm install --force",t,n)}a(kce,"installAllRootModules");async function Fce(e){await Yu(`npm uninstall ${e}`,Qc.get(zc.CONFIG_PARAMS.ROOTPATH))}a(Fce,"uninstallRootModule");async function Gce(){await $m(),await Yu(`npm link ${zc.PACKAGE_ROOT}`,Qc.get(zc.CONFIG_PARAMS.ROOTPATH))}a(Gce,"linkHarperdb");async function Yu(e,t=void 0,r=process.env){let n,s;try{({stdout:n,stderr:s}=await lG(e,{cwd:t,env:r}))}catch(i){throw new Error(i.stderr.replace(`
|
|
19
|
+
`,""))}return s&&!s.includes("Debugger listening")&&!s.includes("warn using --force")&&Jc.error("Error running NPM command:",e,s),Jc.trace(n,s),n?.replace(`
|
|
20
|
+
`,"")}a(Yu,"runCommand");async function qce(e){let t="install_node_modules is deprecated. Dependencies are automatically installed on deploy, and install_node_modules can lead to inconsistent behavior";Jc.warn(t,e);let r=fG(e);if(r)throw Vu(r,r.message,Ku.BAD_REQUEST);let{projects:n,dry_run:s}=e,i=s===!0?Hce:uG;await $m(),await _G(n);let o={};for(let c=0,l=n.length;c<l;c++){let u=n[c];o[u]={npm_output:null,npm_error:null};let d=ma.join(mO,u),_,E=null;try{let{stdout:f,stderr:h}=await lG(i,{cwd:d});_=f?f.replace(`
|
|
21
21
|
`,""):null,E=h?h.replace(`
|
|
22
|
-
`,""):null}catch(f){f.stderr?o[u].npm_error=
|
|
23
|
-
`);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(uG,"parseNPMStdErr");async function qce(e){$u.info(`starting auditModules for request: ${e}`);let t=_G(e);if(t)throw Fu(t,t.message,Gu.BAD_REQUEST);let{projects:r}=e;await $m(),await dG(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=jc.join(mO,o);n[o]={npm_output:null,npm_error:null};try{let l=await Ku("npm audit --json",c);n[o].npm_output=JSON.parse(l)}catch(l){n[o].npm_error=uG(l.stderr)}}return $u.info(`finished auditModules with response ${n}`),n}a(qce,"auditModules");async function $m(){try{return await Ku("npm -v"),!0}catch{throw Fu(new Error,"Unable to install project dependencies: npm is not installed on this instance of HarperDB.",Gu.BAD_REQUEST,void 0,void 0,!0)}}a($m,"checkNPMInstalled");async function dG(e){if(!Array.isArray(e)||e.length===0)throw Fu(new Error,"projects argument must be an array with at least 1 element",Gu.BAD_REQUEST,void 0,void 0,!0);let t=[],r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n],o=jc.join(mO,i.toString());if(!await qm.pathExists(o)){t.push(i);continue}let l=jc.join(o,"package.json");await qm.pathExists(l)||r.push(i)}if(t.length>0)throw Fu(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,Gu.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw Fu(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,Gu.BAD_REQUEST,void 0,void 0,!0)}a(dG,"checkProjectPaths");function _G(e){let t=Fm.object({projects:Fm.array().min(1).items(Fm.string()).required(),dry_run:Fm.boolean().default(!1)});return vce.validateBySchema(e,t)}a(_G,"modulesValidator")});var SO=N((HCe,TG)=>{"use strict";var gs=require("fs-extra"),Gf=require("path"),Ff=W(),EG=te(),Vm=M(),SG=se(),$ce=wt();TG.exports=Vce;async function Vce(){let e=Kce(),t=SG.get(Vm.CONFIG_PARAMS.ROOTPATH),r=Gf.join(t,"package.json"),n={dependencies:{harperdb:"file:"+Vm.PACKAGE_ROOT}},s=Gf.join(t,"node_modules");gs.ensureDirSync(s);let i,o=!0,c=!1;try{i=gs.readJsonSync(r)}catch(l){if(EG.isEmptyOrZeroLength(e))return;if(l.code!==Vm.NODE_ERROR_CODES.ENOENT)throw l;o=!1}if(!EG.isEmptyOrZeroLength(e)){for(let{name:l,package:u}of e){let d=pG(u);n.dependencies[l]=d+u}if(!o){Ff.notify("Installing components"),await mG(r,n,null),await hG(t,e);return}for(let{name:l,package:u}of e){let d=i.dependencies[l],_=pG(u);if(d===void 0||d!==_+u){c=!0;break}if(u.startsWith("file:"))try{if(gs.statSync(new URL(u+"/package.json")).mtimeMs>gs.statSync(r).mtimeMs){c=!0;break}}catch(E){Ff.info(`Error checking ${u}/package.json modification time`,E);break}}}for(let l in i.dependencies)n.dependencies[l]===void 0&&(Ff.notify("Removing component",l),c=!0);c&&(Ff.notify("Updating components."),await mG(r,n,i),await hG(t,e))}a(Vce,"installComponents");function hG(e,t){return Promise.all(t.map(({name:r})=>{let n=Gf.join(e,"node_modules",r),s=Gf.join(e,"components",r);if(gs.existsSync(n)&&gs.lstatSync(n).isDirectory())return gs.move(n,s,{overwrite:!0}).then(()=>{gs.symlink(s,n)})}))}a(hG,"moveModuleToComponents");function Kce(){let e=$ce.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(Kce,"getComponentsConfig");function pG(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":Gf.extname(e)||gs.existsSync(e)?"file:":"github:"}a(pG,"getPkgPrefix");async function mG(e,t,r){Ff.trace("npm installing components package.json",t),gs.writeFileSync(e,JSON.stringify(t,null," "));try{await kf().installAllRootModules(SG.get(Vm.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?gs.writeFileSync(e,JSON.stringify(r,null," ")):gs.unlinkSync(e),n}}a(mG,"installPackages")});var AG={};je(AG,{packageDirectory:()=>Wce});function Wce(e,t){let{skip_node_modules:r,hidden_folders:n}=t;return new Promise((s,i)=>{let o=r?{ignore:a(l=>l.includes(TO.default.join("node_modules"))||l.includes(TO.default.join("cache","webpack")),"ignore")}:{},c=[];gG.default.pack(e,o).pipe((0,RG.createGzip)()).on("data",l=>c.push(l)).on("end",()=>{let l=Buffer.concat(c);s(l)}).on("error",i)})}var TO,gG,Yce,RG,yG=Oe(()=>{TO=L(require("path")),gG=L(require("tar-fs")),Yce=require("node:fs"),RG=require("node:zlib");a(Wce,"packageDirectory")});var AO=N(NG=>{"use strict";var ge=require("fs-extra"),gO=require("fast-glob"),Ce=require("path"),jce=require("tar-fs"),zce=require("gunzip-maybe"),FCe=require("uuid").v4,RO=require("normalize-path"),Rn=aG(),kt=W(),ft=M(),xt=se(),Km=wt(),Qce=te(),{PACKAGE_ROOT:Jce}=M(),{handleHDBError:Ft,hdb_errors:Xce}=_e(),{basename:Zce}=require("path"),ele=SO(),OG=se(),tle=M(),{Readable:rle}=require("stream"),{isMainThread:nle}=require("worker_threads"),{HDB_ERROR_MSGS:zc,HTTP_STATUS_CODES:Gt}=Xce,sle=dt(),{replicateOperation:ti}=(us(),oe(ca)),{packageDirectory:ile}=(yG(),oe(AG)),bG=kf(),ole=Ce.join(Jce,"application-template"),GCe=Ce.join(xt.get(ft.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),"tmp"),ale=xt.get(ft.CONFIG_PARAMS.ROOTPATH),Sa=Ce.join(ale,"ssh"),go=Ce.join(Sa,"known_hosts");function cle(){kt.trace("getting custom api status");let e={};try{e={port:xt.get(ft.CONFIG_PARAMS.HTTP_PORT),directory:xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw Ft(new Error,zc.FUNCTION_STATUS,Gt.INTERNAL_SERVER_ERROR,kt.ERR,t)}return e}a(cle,"customFunctionsStatus");function lle(){kt.trace("getting custom api endpoints");let e={},t=xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT);try{gO.sync(RO(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:gO.sync(RO(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:gO.sync(RO(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw Ft(new Error,zc.GET_FUNCTIONS,Gt.INTERNAL_SERVER_ERROR,kt.ERR,r)}return e}a(lle,"getCustomFunctions");function ule(e){e.project&&(e.project=Ce.parse(e.project).name),e.file&&(e.file=Ce.parse(e.file).name);let t=Rn.getDropCustomFunctionValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);kt.trace("getting custom api endpoint file content");let r=xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=Ce.join(r,n,s,i+".js");try{return ge.readFileSync(o,{encoding:"utf8"})}catch(c){throw Ft(new Error,zc.GET_FUNCTION,Gt.INTERNAL_SERVER_ERROR,kt.ERR,c)}}a(ule,"getCustomFunction");async function dle(e){e.project&&(e.project=Ce.parse(e.project).name),e.file&&(e.file=Ce.parse(e.file).name);let t=Rn.setCustomFunctionValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);kt.trace("setting custom function file content");let r=xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{ge.outputFileSync(Ce.join(r,n,s,i+".js"),o);let c=await ti(e);return c.message=`Successfully updated custom function: ${i}.js`,c}catch(c){throw Ft(new Error,zc.SET_FUNCTION,Gt.INTERNAL_SERVER_ERROR,kt.ERR,c)}}a(dle,"setCustomFunction");async function _le(e){e.project&&(e.project=Ce.parse(e.project).name),e.file&&(e.file=Ce.parse(e.file).name);let t=Rn.getDropCustomFunctionValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);kt.trace("dropping custom function file");let r=xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{ge.unlinkSync(Ce.join(r,n,s,i+".js"));let o=await ti(e);return o.message=`Successfully deleted custom function: ${i}.js`,o}catch(o){throw Ft(new Error,zc.DROP_FUNCTION,Gt.INTERNAL_SERVER_ERROR,kt.ERR,o)}}a(_le,"dropCustomFunction");async function fle(e){e.project&&(e.project=Ce.parse(e.project).name);let t=Rn.addComponentValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);kt.trace("adding component");let r=xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=Ce.join(r,n);ge.mkdirSync(s,{recursive:!0}),ge.copySync(ole,s);let i=await ti(e);return i.message=`Successfully added project: ${n}`,i}catch(s){throw Ft(new Error,zc.ADD_FUNCTION,Gt.INTERNAL_SERVER_ERROR,kt.ERR,s)}}a(fle,"addComponent");async function Ele(e){e.project&&(e.project=Ce.parse(e.project).name);let t=Rn.dropCustomFunctionProjectValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);kt.trace("dropping custom function project");let r=xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=xt.get(ft.CONFIG_PARAMS.APPS);if(!Qce.isEmptyOrZeroLength(s)){let i=!1;for(let[o,c]of s.entries())if(c.name===n){s.splice(o,1),i=!0;break}if(i)return Km.updateConfigValue(ft.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=Ce.join(r,n);ge.rmSync(i,{recursive:!0});let o=await ti(e);return o.message=`Successfully deleted project: ${n}`,o}catch(i){throw Ft(new Error,zc.DROP_FUNCTION_PROJECT,Gt.INTERNAL_SERVER_ERROR,kt.ERR,i)}}a(Ele,"dropCustomFunctionProject");async function hle(e){e.project&&(e.project=Ce.parse(e.project).name);let t=Rn.packageComponentValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);let r=xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;kt.trace("packaging component",n);let s;try{s=await ge.realpath(Ce.join(r,n))}catch(o){if(o.code!==ft.NODE_ERROR_CODES.ENOENT)throw o;try{s=await ge.realpath(Ce.join(xt.get(ft.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(c){if(c.code===ft.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}let i=(await ile(s,e)).toString("base64");return{project:n,payload:i}}a(hle,"packageComponent");async function ple(e){e.project&&(e.project=Ce.parse(e.project).name);let t=Rn.deployComponentValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);let r=xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i,install_command:o}=e;if(kt.trace("deploying component",n),!s&&!i)throw new Error("'payload' or 'package' must be provided");let c;if(s){c=Ce.join(r,n),i="file:"+c,await ge.emptyDir(c);let h=rle.from(s instanceof Buffer?s:Buffer.from(s,"base64"));await new Promise((g,S)=>{h.pipe(zce()).pipe(jce.extract(c,{finish:g})).on("error",S)});let T=await ge.readdir(c);T.length===1&&T[0]==="package"&&(await ge.copy(Ce.join(c,"package"),c),await ge.remove(Ce.join(c,"package")));let m=Ce.join(c,"node_modules");o?await bG.runCommand(o,c):ge.existsSync(m)||await bG.installAllRootModules(!1,c)}else{await Km.addConfig(n,{package:i}),await ele();let h=OG.get(tle.CONFIG_PARAMS.ROOTPATH);c=Ce.join(h,"node_modules",n)}if(nle)return;let l=new Map;l.isWorker=!0;let u=($f(),oe(qf)),d;u.setErrorReporter(h=>d=h);let _=Zce(c),E=u.component_errors.get(_);try{await u.loadComponent(c,l)}finally{u.component_errors.set(_,E)}if(d)throw d;kt.info("Installed component");let f=await ti(e);return e.restart===!0?(sle.restartWorkers("http"),f.message=`Successfully deployed: ${n}, restarting HarperDB`):f.message=`Successfully deployed: ${n}`,f}a(ple,"deployComponent");async function mle(){let e=a(async(s,i)=>{try{let o=await ge.readdir(s,{withFileTypes:!0});for(let c of o){let l=c.name;if(l.startsWith(".")||l==="node_modules")continue;let u=Ce.join(s,l);if(c.isDirectory()||c.isSymbolicLink()){let d={name:l,entries:[]};i.entries.push(d),await e(u,d)}else{let d=await ge.stat(u),_={name:Ce.basename(l),mtime:d.mtime,size:d.size};i.entries.push(_)}}return i}catch(o){return kt.warn("Error loading package",o),{error:o.toString(),entries:[]}}},"walkDir"),t=await e(xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{name:xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT).split(Ce.sep).slice(-1).pop(),entries:[]}),n=($f(),oe(qf)).component_errors;for(let s of t.entries){let i=n.get(s.name);i?s.error=n.get(s.name):i===void 0&&(s.error="The component has not been loaded yet (may need a restart)")}return t}a(mle,"getComponents");async function Sle(e){let t=Rn.getComponentFileValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);let n=Km.getConfigObj()[e.project]||e.project==="harperdb"?Ce.join(OG.get(ft.CONFIG_PARAMS.ROOTPATH),"node_modules"):xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await ge.stat(Ce.join(n,e.project,e.file));return{message:await ge.readFile(Ce.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===ft.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${Ce.join(e.project,e.file)}'`):i}}a(Sle,"getComponentFile");async function Tle(e){let t=Rn.setComponentFileValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=Ce.join(xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);e.payload!==void 0?(await ge.ensureFile(n),await ge.outputFile(n,e.payload,r)):await ge.ensureDir(n);let s=await ti(e);return s.message="Successfully set component: "+e.file,s}a(Tle,"setComponentFile");async function gle(e){let t=Rn.dropComponentFileValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);let{project:r,file:n}=e,s=e.file?Ce.join(r,n):r,i=Ce.join(xt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),s),o=Ce.join(xt.get(ft.CONFIG_PARAMS.ROOTPATH),"node_modules",r);await ge.pathExists(o)&&await ge.unlink(o),await ge.pathExists(i)&&await ge.remove(i);let c=Ce.join(xt.get(ft.CONFIG_PARAMS.ROOTPATH),"package.json");if(await ge.pathExists(c)){let u=JSON.parse(await ge.readFile(c,"utf8"));u?.dependencies?.[r]&&delete u.dependencies[r],await ge.writeFile(c,JSON.stringify(u,null,2),"utf8")}Km.deleteConfigFromFile([r]);let l=await ti(e);return l.message="Successfully dropped: "+s,l}a(gle,"dropComponent");async function Rle(e){let t=Rn.addSSHKeyValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);let{name:r,key:n,host:s,hostname:i,known_hosts:o}=e;kt.trace("adding ssh key",r);let c=Ce.join(Sa,r+".key"),l=Ce.join(Sa,"config");if(await ge.pathExists(c))throw new Error("Key already exists. Use update_ssh_key or delete_ssh_key and then add_ssh_key");await ge.outputFile(c,n),await ge.chmod(c,"0600");let u=`#${r}
|
|
22
|
+
`,""):null}catch(f){f.stderr?o[u].npm_error=dG(f.stderr):o[u].npm_error=f.message;continue}try{o[u].npm_output=JSON.parse(_)}catch{o[u].npm_output=_}try{o[u].npm_error=JSON.parse(E)}catch{o[u].npm_error=E}}return Jc.info(`finished installModules with response ${o}`),o.warning=t,o}a(qce,"installModules");function dG(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(dG,"parseNPMStdErr");async function $ce(e){Jc.info(`starting auditModules for request: ${e}`);let t=fG(e);if(t)throw Vu(t,t.message,Ku.BAD_REQUEST);let{projects:r}=e;await $m(),await _G(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=ma.join(mO,o);n[o]={npm_output:null,npm_error:null};try{let l=await Yu("npm audit --json",c);n[o].npm_output=JSON.parse(l)}catch(l){n[o].npm_error=dG(l.stderr)}}return Jc.info(`finished auditModules with response ${n}`),n}a($ce,"auditModules");async function $m(){try{return await Yu("npm -v"),!0}catch{throw Vu(new Error,"Unable to install project dependencies: npm is not installed on this instance of HarperDB.",Ku.BAD_REQUEST,void 0,void 0,!0)}}a($m,"checkNPMInstalled");async function _G(e){if(!Array.isArray(e)||e.length===0)throw Vu(new Error,"projects argument must be an array with at least 1 element",Ku.BAD_REQUEST,void 0,void 0,!0);let t=[],r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n],o=ma.join(mO,i.toString());if(!await $u.pathExists(o)){t.push(i);continue}let l=ma.join(o,"package.json");await $u.pathExists(l)||r.push(i)}if(t.length>0)throw Vu(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,Ku.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw Vu(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,Ku.BAD_REQUEST,void 0,void 0,!0)}a(_G,"checkProjectPaths");function fG(e){let t=Gm.object({projects:Gm.array().min(1).items(Gm.string()).required(),dry_run:Gm.boolean().default(!1)});return Bce.validateBySchema(e,t)}a(fG,"modulesValidator")});var SO=N((xCe,gG)=>{"use strict";var gs=require("fs-extra"),Gf=require("path"),Ff=W(),hG=te(),Vm=M(),TG=se(),Vce=wt();gG.exports=Kce;async function Kce(){let e=Yce(),t=TG.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(hG.isEmptyOrZeroLength(e))return;if(l.code!==Vm.NODE_ERROR_CODES.ENOENT)throw l;o=!1}if(!hG.isEmptyOrZeroLength(e)){for(let{name:l,package:u}of e){let d=mG(u);n.dependencies[l]=d+u}if(!o){Ff.notify("Installing components"),await SG(r,n,null),await pG(t,e);return}for(let{name:l,package:u}of e){let d=i.dependencies[l],_=mG(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 SG(r,n,i),await pG(t,e))}a(Kce,"installComponents");function pG(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(pG,"moveModuleToComponents");function Yce(){let e=Vce.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(Yce,"getComponentsConfig");function mG(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":Gf.extname(e)||gs.existsSync(e)?"file:":"github:"}a(mG,"getPkgPrefix");async function SG(e,t,r){Ff.trace("npm installing components package.json",t),gs.writeFileSync(e,JSON.stringify(t,null," "));try{await kf().installAllRootModules(TG.get(Vm.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?gs.writeFileSync(e,JSON.stringify(r,null," ")):gs.unlinkSync(e),n}}a(SG,"installPackages")});var yG={};je(yG,{packageDirectory:()=>jce});function jce(e,t){let{skip_node_modules:r,hidden_folders:n}=t;return new Promise((s,i)=>{let o=r?{ignore:a(l=>l.includes(TO.default.join("node_modules"))||l.includes(TO.default.join("cache","webpack")),"ignore")}:{},c=[];RG.default.pack(e,o).pipe((0,AG.createGzip)()).on("data",l=>c.push(l)).on("end",()=>{let l=Buffer.concat(c);s(l)}).on("error",i)})}var TO,RG,Wce,AG,bG=Ne(()=>{TO=L(require("path")),RG=L(require("tar-fs")),Wce=require("node:fs"),AG=require("node:zlib");a(jce,"packageDirectory")});var OO=N(($Ce,wG)=>{var jm=require("clone"),zm=Tt(),zce=te(),Ym=M(),GCe=W(),gO=require("fs"),AO=require("joi"),{string:Wm}=AO.types(),{hdb_errors:Qce,handleHDBError:Km}=_e(),{HDB_ERROR_MSGS:qCe,HTTP_STATUS_CODES:RO}=Qce,{common_validators:Wu}=Ti(),OG=" is required",Jce=["insert","update","upsert"],yO={database:{presence:!1,format:Wu.schema_format,length:Wu.schema_length},schema:{presence:!1,format:Wu.schema_format,length:Wu.schema_length},table:{presence:!0,format:Wu.schema_format,length:Wu.schema_length},action:{inclusion:{within:Jce,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},Xce={schema:Wm.required(),table:Wm.required(),action:Wm.valid("insert","update","upsert")},{AWS_ACCESS_KEY:Zce,AWS_SECRET:ele,AWS_BUCKET:tle,AWS_FILE_KEY:rle,REGION:nle}=Ym.S3_BUCKET_AUTH_KEYS,sle={s3:{presence:!0},[`s3.${Zce}`]:{presence:!0,type:"String"},[`s3.${ele}`]:{presence:!0,type:"String"},[`s3.${tle}`]:{presence:!0,type:"String"},[`s3.${rle}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${nle}`]:{presence:!0,type:"String"}},NG=jm(yO);NG.data.presence={message:OG};var IG=jm(yO);IG.file_path.presence={message:OG};var ile=Object.assign(jm(yO),sle),bO=jm(Xce);bO.csv_url=Wm.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();bO.passthrough_headers=AO.object();function ole(e){let t=zm.validateObject(e,NG);return Qm(e,t)}a(ole,"dataObject");function ale(e){let t=zm.validateBySchema(e,AO.object(bO));return Qm(e,t)}a(ale,"urlObject");function cle(e){let t=zm.validateObject(e,IG);return Qm(e,t)}a(cle,"fileObject");function lle(e){let t=zm.validateObject(e,ile);return Qm(e,t)}a(lle,"s3FileObject");function Qm(e,t){if(!t){let r=zce.checkGlobalSchemaTable(e.schema,e.table);if(r)return Km(new Error,r,RO.BAD_REQUEST);if(e.operation===Ym.OPERATIONS_ENUM.CSV_FILE_LOAD)try{gO.accessSync(e.file_path,gO.constants.R_OK|gO.constants.F_OK)}catch(n){return n.code===Ym.NODE_ERROR_CODES.ENOENT?Km(n,`No such file or directory ${n.path}`,RO.BAD_REQUEST):n.code===Ym.NODE_ERROR_CODES.EACCES?Km(n,`Permission denied ${n.path}`,RO.BAD_REQUEST):Km(n)}}return t}a(Qm,"postValidateChecks");wG.exports={dataObject:ole,urlObject:ale,fileObject:cle,s3FileObject:lle}});var NO=N((KCe,CG)=>{"use strict";var qf=W(),Jm=M();async function ule(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(ule,"callOperationFunctionAsAwait");CG.exports={callOperationFunctionAsAwait:ule}});var IO=N((WCe,PG)=>{"use strict";var{S3:dle,GetObjectCommand:_le}=require("@aws-sdk/client-s3");PG.exports={getFileStreamFromS3:fle,getS3AuthObj:DG};async function fle(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await DG(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new _le(r))).Body}a(fle,"getFileStreamFromS3");function DG(e,t,r){return new dle({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(DG,"getS3AuthObj")});var MG=N((zCe,LG)=>{"use strict";var wO=class{static{a(this,"BulkLoadFileObject")}constructor(t,r,n,s,i,o,c=null){this.op=t,this.action=r,this.schema=n,this.table=s,this.file_path=i,this.file_type=o,this.role_perms=c}},CO=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};LG.exports={BulkLoadFileObject:wO,BulkLoadDataObject:CO}});var vG=N((JCe,UG)=>{"use strict";var DO=class{static{a(this,"PermissionTableResponseObject")}constructor(t,r,n=[],s=[]){this.schema=t,this.table=r,this.required_table_permissions=n,this.required_attribute_permissions=s}};UG.exports=DO});var HG=N((ZCe,BG)=>{"use strict";var PO=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};BG.exports=PO});var MO=N((tDe,kG)=>{"use strict";var xG=vG(),Ele=HG(),{HDB_ERROR_MSGS:hle}=Dn(),LO=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=hle.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 xG(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let l=new Ele(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 xG(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}};kG.exports=LO});var GG=N((nDe,FG)=>{"use strict";var UO=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};FG.exports=UO});var FO=N((lDe,sq)=>{"use strict";var Xm=un(),eS=OO(),ple=require("needle"),ti=M(),iDe=Ct(),ju=te(),{handleHDBError:xt,hdb_errors:QG}=_e(),{HTTP_STATUS_CODES:Mr,HDB_ERROR_MSGS:gr,CHECK_LOGS_WRAPPER:Zc}=QG,zu=W(),vO=require("papaparse");ju.promisifyPapaParse();var ri=require("fs-extra"),mle=require("path"),{chain:qG}=require("stream-chain"),$G=require("stream-json/streamers/StreamArray"),VG=require("stream-json/utils/Batch"),KG=require("stream-chain/utils/comp"),{finished:YG}=require("stream"),Sle=se(),JG=NO(),Tle=IO(),{BulkLoadFileObject:HO,BulkLoadDataObject:gle}=MG(),xO=MO(),{verifyBulkLoadAttributePerms:XG}=tS(),oDe=GG(),aDe=mr(),cDe=to(),{databases:Rle}=(Pe(),oe(lt)),{coerceType:Ale}=($f(),oe(GO)),WG="No records parsed from csv file.",Xc=`${Sle.get("HDB_ROOT")}/tmp`,{schema_regex:yle}=Ti(),jG=1024*1024*2,zG=5e3,ble={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};sq.exports={csvDataLoad:Ole,csvURLLoad:Nle,csvFileLoad:Ile,importFromS3:wle};async function Ole(e,t){let r=eS.dataObject(e);if(r)throw xt(r,r.message,Mr.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=tq(e.schema,e.table),i=vO.parse(e.data,{header:!0,skipEmptyLines:!0,transform:BO.bind(null,s),dynamicTyping:!1}),o=new xO;e.hdb_user&&e.hdb_user?.role&&e.hdb_user?.role?.permission&&e.hdb_user?.role?.permission?.super_user!==!0&&XG(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 xt(new Error,c,Mr.BAD_REQUEST,void 0,void 0,!0);let l=new gle(e.action,e.schema,e.table,i.data);return n=await JG.callOperationFunctionAsAwait(rq,l,null),n.message===WG?WG:nq(n.records,n.number_written)}catch(s){throw el(s)}}a(Ole,"csvDataLoad");async function Nle(e){let t=eS.urlObject(e);if(t)throw xt(t,t.message,Mr.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${Xc}/${r}`;try{await Cle(e,r)}catch(s){throw zu.error(gr.DOWNLOAD_FILE_ERR(r)+" - "+s),xt(s,Zc(gr.DOWNLOAD_FILE_ERR(r)))}try{let s=new HO(this.job_operation_function.name,e.action,e.schema,e.table,n,ti.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission),i=await kO(s);return await Zm(n),i}catch(s){throw await Zm(n),el(s)}}a(Nle,"csvURLLoad");async function Ile(e){let t=eS.fileObject(e);if(t)throw xt(t,t.message,Mr.BAD_REQUEST,void 0,void 0,!0);let r=new HO(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,ti.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission);try{return await kO(r)}catch(n){throw el(n)}}a(Ile,"csvFileLoad");async function wle(e){let t=eS.s3FileObject(e);if(t)throw xt(t,t.message,Mr.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=mle.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${Xc}/${s}`;let i=new HO(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user?.role?.permission);await Dle(s,e);let o=await kO(i);return await Zm(r),o}catch(n){throw await Zm(r),el(n)}}a(wle,"importFromS3");async function Cle(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await ple("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 xt(n,s,n.statusCode,ti.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}Lle(r,e.csv_url),await Ple(t,r.raw)}a(Cle,"downloadCSVFile");async function Dle(e,t){try{let r=`${Xc}/${e}`;await ri.mkdirp(Xc),await ri.writeFile(`${Xc}/${e}`,"",{flag:"a+"});let n=await ri.createWriteStream(r),s=await Tle.getFileStreamFromS3(t);await new Promise((i,o)=>{s.on("error",function(c){o(c)}),s.pipe(n).on("error",function(c){o(c)}).on("close",function(){zu.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw zu.error(gr.S3_DOWNLOAD_ERR+" - "+r),xt(r,Zc(gr.S3_DOWNLOAD_ERR))}}a(Dle,"downloadFileFromS3");async function Ple(e,t){try{await ri.mkdirp(Xc),await ri.writeFile(`${Xc}/${e}`,t)}catch(r){throw zu.error(gr.WRITE_TEMP_FILE_ERR),xt(r,Zc(gr.DEFAULT_BULK_LOAD_ERR))}}a(Ple,"writeFileToTempFolder");async function Zm(e){if(e)try{await ri.access(e),await ri.unlink(e)}catch{zu.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(Zm,"deleteTempFile");function Lle(e,t){if(e.statusCode!==QG.HTTP_STATUS_CODES.OK)throw xt(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,Mr.BAD_REQUEST);if(!ble[e.headers["content-type"]])throw xt(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,Mr.BAD_REQUEST);if(!e.raw)throw xt(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,Mr.BAD_REQUEST)}a(Lle,"validateURLResponse");async function kO(e){try{let t;switch(e.file_type){case ti.VALID_S3_FILE_TYPES.CSV:t=await Mle(e);break;case ti.VALID_S3_FILE_TYPES.JSON:t=await Ule(e);break;default:throw xt(new Error,gr.DEFAULT_BULK_LOAD_ERR,Mr.BAD_REQUEST,ti.LOG_LEVELS.ERROR,gr.INVALID_FILE_EXT_ERR(e))}return nq(t.records,t.number_written)}catch(t){throw el(t)}}a(kO,"fileLoad");async function ZG(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&&XG(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let l=xt(c);r(l)}}a(ZG,"validateChunk");async function eq(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;ju.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!ju.isEmpty(c)&&!ju.isEmpty(c.__parsed_extra)&&delete c.__parsed_extra});else{let c=new Set;i.forEach(l=>{Object.keys(l).forEach(u=>c.add(u))}),o=[...c]}try{let c={schema:e.schema,table:e.table,action:e.action,data:i},l=await JG.callOperationFunctionAsAwait(rq,c,null);t.records+=l.records,t.number_written+=l.number_written,s&&s.resume()}catch(c){let l=xt(c,Zc(gr.INSERT_CSV_ERR),Mr.INTERNAL_SERVER_ERROR,ti.LOG_LEVELS.ERROR,gr.INSERT_CSV_ERR+" - "+c);r(l)}}a(eq,"insertChunk");async function Mle(e){let t={records:0,number_written:0},r=tq(e.schema,e.table);try{let n=new xO,s=ri.createReadStream(e.file_path,{highWaterMark:jG});s.setEncoding("utf8"),await vO.parsePromise(s,ZG.bind(null,e,n),BO.bind(null,r));let i=n.getPermsResponse();if(i)throw xt(new Error,i,Mr.BAD_REQUEST);return s=ri.createReadStream(e.file_path,{highWaterMark:jG}),s.setEncoding("utf8"),await vO.parsePromise(s,eq.bind(null,e,t),BO.bind(null,r)),s.destroy(),t}catch(n){throw xt(n,Zc(gr.PAPA_PARSE_ERR),Mr.INTERNAL_SERVER_ERROR,ti.LOG_LEVELS.ERROR,gr.PAPA_PARSE_ERR+n)}}a(Mle,"callPapaParse");function tq(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=>Ale(i,s));return n}a(tq,"createTransformMap");function BO(e,t,r){let n=e.get(r);return n?n(t):ju.autoCast(t)}a(BO,"typeFunction");async function Ule(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new xO,s=qG([ri.createReadStream(e.file_path,{encoding:"utf-8"}),$G.withParser(),c=>c.value,new VG({batchSize:zG}),KG(async c=>{await ZG(e,n,r,c)})]);await new Promise((c,l)=>{YG(s,u=>{u?l(u):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw xt(new Error,i,Mr.BAD_REQUEST);let o=qG([ri.createReadStream(e.file_path,{encoding:"utf-8"}),$G.withParser(),c=>c.value,new VG({batchSize:zG}),KG(async c=>{await eq(e,t,r,c)})]);return await new Promise((c,l)=>{YG(o,u=>{u?l(u):c()}),o.resume()}),t}catch(n){throw xt(n,Zc(gr.INSERT_JSON_ERR),Mr.INTERNAL_SERVER_ERROR,ti.LOG_LEVELS.ERROR,gr.INSERT_JSON_ERR+n)}}a(Ule,"insertJson");async function rq(e){let t={};try{e.data&&e.data.length>0&&vle(e.data[0])?t=await Ble(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",zu.info(t.message))}catch(r){throw el(r)}return t}a(rq,"callBulkFileLoad");function vle(e){let t=Object.keys(e);for(let r of t)if(!yle.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(vle,"validateColumnNames");async function Ble(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 xt(new Error,gr.INVALID_ACTION_PARAM_ERR(n),Mr.BAD_REQUEST,ti.LOG_LEVELS.ERROR,gr.INVALID_ACTION_PARAM_ERR(n))}try{let o=await i(s),c;switch(n){case"insert":c=o.inserted_hashes;break;case"update":c=o.update_hashes;break;case"upsert":c=o.upserted_hashes;break;default:break}if(Array.isArray(o.skipped_hashes)&&o.skipped_hashes.length>0){let d=global.hdb_schema[t][r].hash_attribute,_=e.length;for(;_--;)o.skipped_hashes.indexOf(e[_][d])>=0&&e.splice(_,1)}let l=ju.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw el(o)}}a(Ble,"bulkFileLoad");function nq(e,t){return`successfully loaded ${t} of ${e} records`}a(nq,"buildResponseMsg");function el(e){return xt(e,Zc(gr.DEFAULT_BULK_LOAD_ERR),Mr.INTERNAL_SERVER_ERROR,ti.LOG_LEVELS.ERROR,gr.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(el,"buildTopLevelErrMsg")});var oq=N((dDe,iq)=>{"use strict";var qO=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};iq.exports=qO});var lq=N((fDe,cq)=>{"use strict";var Hle=M(),aq=require("moment"),xle=require("uuid").v4,$O=class{static{a(this,"JobObject")}constructor(){this.id=xle(),this.type=void 0,this.start_datetime=aq().valueOf(),this.created_datetime=aq().valueOf(),this.end_datetime=void 0,this.status=Hle.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};cq.exports=$O});var VO=N((hDe,dq)=>{"use strict";var Rs=require("joi"),uq=Tt();dq.exports={readTransactionLogValidator:kle,deleteTransactionLogsBeforeValidator:Fle};function kle(e){let t=Rs.object({schema:Rs.string(),database:Rs.string(),table:Rs.string().required(),from:Rs.date().timestamp(),to:Rs.date().timestamp(),limit:Rs.number().min(1)});return uq.validateBySchema(e,t)}a(kle,"readTransactionLogValidator");function Fle(e){let t=Rs.object({schema:Rs.string(),database:Rs.string(),table:Rs.string().required(),timestamp:Rs.date().timestamp().required()});return uq.validateBySchema(e,t)}a(Fle,"deleteTransactionLogsBeforeValidator")});var KO=N((mDe,Tq)=>{"use strict";var Gle=require("uuid").v4,pq=un(),mq=Vr(),qle=$s(),$le=Wl(),Vle=oq(),bt=M(),Kle=lq(),Yle=Hp(),ni=W(),Wle=Jd(),Qu=te(),{promisify:jle}=require("util"),tl=require("moment"),zle=nS(),rS=OO(),_q=yR(),{deleteTransactionLogsBeforeValidator:Qle}=VO(),{handleHDBError:fq,hdb_errors:Jle,ClientError:Xle}=_e(),{HTTP_STATUS_CODES:Eq}=Jle,hq=mq.searchByValue,Zle=mq.searchByHash,eue=pq.insert,tue=jle(zle.evaluateSQL),rue=pq.update;Tq.exports={addJob:iue,updateJob:aue,handleGetJob:nue,handleGetJobsByStartDate:sue,getJobById:Sq};async function nue(e){if(e.id===void 0)throw new Xle("'id' is required");let t=await Sq(e.id);return Qu.isEmptyOrZeroLength(t)||(t[0]={...t[0]},t[0].request!==void 0&&delete t[0].request,delete t[0].__createdtime__,delete t[0].__updatedtime__),t}a(nue,"handleGetJob");async function sue(e){try{let t=await oue(e);if(ni.trace(`Searching for jobs from ${e.from_date} to ${e.to_date}`),t&&t.length>0)for(let r of t)r.start_datetime&&(r.start_datetime_converted=tl(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=tl(r.end_datetime)),r.request!==void 0&&delete r.request,delete r.__createdtime__,delete r.__updatedtime__;return t}catch(t){let r=`There was an error searching jobs by date: ${t}`;throw ni.error(r),new Error(r)}}a(sue,"handleGetJobsByStartDate");async function iue(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||Qu.isEmptyOrZeroLength(e.operation)){let d="job parameter is invalid";return ni.info(d),t.error=d,t}if(!bt.JOB_TYPE_ENUM[e.operation])return ni.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case bt.OPERATIONS_ENUM.CSV_FILE_LOAD:n=rS.fileObject(e);break;case bt.OPERATIONS_ENUM.CSV_URL_LOAD:n=rS.urlObject(e);break;case bt.OPERATIONS_ENUM.CSV_DATA_LOAD:n=rS.dataObject(e);break;case bt.OPERATIONS_ENUM.IMPORT_FROM_S3:n=rS.s3FileObject(e);break;case bt.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case bt.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=_q(e,"date");break;case bt.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=_q(e,"timestamp");break;case bt.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=Qle(e);break;case bt.OPERATIONS_ENUM.RESTART_SERVICE:if(bt.PROCESS_DESCRIPTORS_VALIDATE[e.service]===void 0)throw fq(new Error,"Invalid service",Eq.BAD_REQUEST,void 0,void 0,!0);break;default:break}if(n)throw fq(n,n.message,Eq.BAD_REQUEST,void 0,void 0,!0);let s=new Kle;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 qle(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await hq(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=Gle();try{o=await hq(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 Wle(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),u;try{u=await eue(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(iue,"addJob");async function oue(e){let t=tl(e.from_date,tl.ISO_8601),r=tl(e.to_date,tl.ISO_8601);if(!t.isValid())throw new Error("Invalid 'from' date, must be in ISO-8601 format (YYYY-MM-DD).");if(!r.isValid())throw new Error("Invalid 'to' date, must be in ISO-8601 format (YYYY-MM-DD)");let n=`select * from system.hdb_job where start_datetime > '${t.valueOf()}' and start_datetime < '${r.valueOf()}'`,s=new Vle(n,e.hdb_user);try{return await tue(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(oue,"getJobsInDateRange");async function Sq(e){if(Qu.isEmptyOrZeroLength(e))return Qu.errorizeMessage("Invalid job ID specified.");let t=new $le(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await Zle(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return ni.error(n),Qu.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(Sq,"getJobById");async function aue(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(Qu.isEmptyOrZeroLength(e.id))throw new Error("invalid ID passed to updateJob");(e.status===bt.JOB_STATUS_ENUM.COMPLETE||e.status===bt.JOB_STATUS_ENUM.ERROR)&&(e.end_datetime=tl().valueOf());let t=new Yle(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await rue(t),r}a(aue,"updateJob")});var oS=N((TDe,Oq)=>{"use strict";var YO=M(),Vf=mr(),gq=te(),Rq=se(),Aq=to(),yq=W(),{handleHDBError:sS,hdb_errors:cue}=_e(),{HTTP_STATUS_CODES:iS}=cue,{readTransactionLogValidator:lue,deleteTransactionLogsBeforeValidator:uue}=VO(),bq=Bn(),due="Logs successfully deleted from transaction log.",_ue="All logs successfully deleted from transaction log.";Oq.exports={readTransactionLog:fue,deleteTransactionLogsBefore:hue};async function fue(e){let t=lue(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=gq.checkSchemaTableExist(e.database,e.table);if(r)throw sS(new Error,r,iS.NOT_FOUND,void 0,void 0,!0);return Rq.get(YO.CONFIG_PARAMS.CLUSTERING_ENABLED)?await Eue(e):(yq.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)),bq.readAuditLog(e))}a(fue,"readTransactionLog");async function*Eue(e){let t=Aq.createNatsTableStreamName(e.database,e.table),r=await Vf.viewStreamIterator(t,parseInt(e.from),e.limit);for await(let n of r){let s=Math.floor(n?.nats_timestamp/1e6);if(e.to&&s>e.to)break;let i={operation:n?.entry?.operation,user:n?.entry?.__origin?.user,timestamp:s,records:n?.entry?.records,attributes:n?.entry?.attributes};n?.entry?.operation===YO.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(Eue,"readTransactionLogNats");async function hue(e){let t=uue(e);if(t)throw sS(t,t.message,iS.BAD_REQUEST,void 0,void 0,!0);if(e.database=e.database??e.schema??"data",!Rq.get(YO.CONFIG_PARAMS.CLUSTERING_ENABLED))return yq.info("Delete transaction logs called for Plexus"),bq.deleteAuditLogsBefore(e);let{database:r,table:n,timestamp:s}=e,i=gq.checkSchemaTableExist(r,n);if(i)throw sS(new Error,i,iS.NOT_FOUND,void 0,void 0,!0);let o=Aq.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=due,_,E=new Date(l.state.last_ts).getTime();return s>E?(_=l.state.last_seq+1,d=_ue):_=(await Vf.viewStream(o,parseInt(s),1))[0].nats_sequence,await Vf.purgeTableStream(r,n,{seq:_}),d}a(hue,"deleteTransactionLogsBefore")});var Mq=N((RDe,Lq)=>{"use strict";var Nq=te(),Rr=M(),pue=require("moment"),aS=FO(),Kf=W(),Iq=KO(),wq=cS(),Cq=uc(),Dq=dt(),mue=oS(),Sue=Gu(),{parentPort:Tue,isMainThread:Pq}=require("worker_threads"),{onMessageByType:gue}=dt(),WO=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(Nq.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(Nq.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case Rr.JOB_TYPE_ENUM.csv_file_load:await Li(e,aS.csvFileLoad);break;case Rr.JOB_TYPE_ENUM.csv_url_load:await Li(e,aS.csvURLLoad);break;case Rr.JOB_TYPE_ENUM.csv_data_load:await Li(e,aS.csvDataLoad);break;case Rr.JOB_TYPE_ENUM.import_from_s3:await Li(e,aS.importFromS3);break;case Rr.JOB_TYPE_ENUM.empty_trash:break;case Rr.JOB_TYPE_ENUM.export_local:await Li(e,wq.export_local);break;case Rr.JOB_TYPE_ENUM.export_to_s3:await Li(e,wq.export_to_s3);break;case Rr.JOB_TYPE_ENUM.delete_files_before:case Rr.JOB_TYPE_ENUM.delete_records_before:await Li(e,Cq.deleteFilesBefore);break;case Rr.JOB_TYPE_ENUM.delete_audit_logs_before:await Li(e,Cq.deleteAuditLogsBefore);break;case Rr.JOB_TYPE_ENUM.delete_transaction_logs_before:await Li(e,mue.deleteTransactionLogsBefore);break;case Rr.JOB_TYPE_ENUM.restart_service:return await Li(e,Sue.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(Rue,"parseMessage");async function Li(e,t){try{e.job.status=Rr.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=pue().valueOf(),await Iq.updateJob(e.job),await Aue(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 Iq.updateJob(e.job)}catch(s){throw Kf.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(Li,"runJob");async function Aue(e){Kf.trace("launching job thread:",e),Pq?Dq.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Rr.PROCESS_NAME_ENV_PROP]:`JOB-${e}`}}):Tue.postMessage({type:Rr.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(Aue,"launchJobThread");Pq&&gue(Rr.ITC_EVENT_TYPES.START_JOB,async(e,t)=>{try{Dq.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)}});Lq.exports={parseMessage:Rue,RunnerMessage:WO}});var vq=N((yDe,Uq)=>{"use strict";var jO=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};Uq.exports=jO});var tN=N((NDe,eN)=>{"use strict";var fS=Vr(),JO=nS(),lS=FO(),To=tm(),uS=ro(),Wf=uc(),yue=zy(),Yf=xn(),dS=lf(),Lt=rN(),_S=W(),bue=ob(),Oue=pf(),Bq=Lb(),Nue=Rf(),Iue=vb(),wue=Bb(),Cue=Sm(),Due=Fb(),zO=gm(),Hq=cS(),Pue=tS(),XO=KO(),$=M(),{hdb_errors:zf,handleHDBError:jf}=_e(),{HTTP_STATUS_CODES:xq}=zf,QO=Wb(),kq=Gu(),zq=require("util"),Xu=un(),Lue=ls(),Mue=wu(),Fq=Mq(),Gq=_u(),qq=(km(),oe(Hf)),$q=wt(),Vq=oS(),Kq=kf(),{setServerUtilities:Uue}=($f(),oe(GO)),{CONTEXT:ODe}=(Vs(),oe(_A)),{_assignPackageExport:vue}=fi(),{transformReq:Bue}=te(),{server:Hue}=(qr(),oe(Qa)),Zr=_S.loggerWithTag("operation"),Ju=Xs(),Yq=(xc(),oe(Hc)),xue=NO(),Wq=fS.searchByHash,kue=fS.searchByValue,Fue=zq.promisify(fS.search),Gue=zq.promisify(JO.evaluateSQL),que={[$.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=vq();async function Qq(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 xue.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return que[e.body.operation]&&Lue.setSchemaDataToGlobal(n=>{n&&Zr.error(n)}),r}a(Qq,"processLocalTransaction");var jq=Vue();eN.exports={chooseOperation:Jq,getOperationFunction:Xq,operation:ZO,processLocalTransaction:Qq,executeJob:As};Uue(eN.exports);Hue.operation=ZO;function Jq(e){let t;try{t=Xq(e)}catch(s){throw Zr.error(`Error when selecting operation function - ${s}`),s}let{operation_function:r,job_operation_function:n}=t;try{if(e.operation==="sql"||e.search_operation&&e.search_operation.operation==="sql"){let s=e.operation==="sql"?e.sql:e.search_operation.sql,i=JO.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=JO.checkASTPermissions(e,i);if(o)throw Zr.error(`${xq.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=Pue.verifyPerms(i,s);if(o)throw Zr.error(`${xq.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(Jq,"chooseOperation");function Xq(e){if(Zr.trace(`getOperationFunction with operation: ${e.operation}`),jq.has(e.operation))return jq.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(Xq,"getOperationFunction");vue("operation",ZO);function ZO(e,t,r){e.hdb_user=t?.user,e.bypass_auth=!r;let n=Jq(e);return Qq({body:e},n)}a(ZO,"operation");async function $ue(e){Zr.trace("In serverUtils.catchup");let t=e.transaction,r=t.channel.split(":"),n=r[0],s=r[1];for(let i of t.transactions)try{i.schema=n,i.table=s,i[$.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case $.OPERATIONS_ENUM.INSERT:o=await Xu.insert(i);break;case $.OPERATIONS_ENUM.UPDATE:o=await Xu.update(i);break;case $.OPERATIONS_ENUM.UPSERT:o=await Xu.upsert(i);break;case $.OPERATIONS_ENUM.DELETE:o=await Wf.deleteRecord(i);break;default:Zr.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){Zr.info("Invalid operation in transaction"),Zr.error(o)}}a($ue,"catchup");async function As(e){Bue(e);let t,r;try{r=await XO.addJob(e),t=r.createdJob,Zr.info("addJob result",r);let n=new Fq.RunnerMessage(t,e);return{message:await Fq.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(As,"executeJob");function Vue(){let e=new Map;return e.set($.OPERATIONS_ENUM.INSERT,new J(Xu.insert)),e.set($.OPERATIONS_ENUM.UPDATE,new J(Xu.update)),e.set($.OPERATIONS_ENUM.UPSERT,new J(Xu.upsert)),e.set($.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new J(fS.searchByConditions)),e.set($.OPERATIONS_ENUM.SEARCH_BY_HASH,new J(Wq)),e.set($.OPERATIONS_ENUM.SEARCH_BY_ID,new J(Wq)),e.set($.OPERATIONS_ENUM.SEARCH_BY_VALUE,new J(kue)),e.set($.OPERATIONS_ENUM.SEARCH,new J(Fue)),e.set($.OPERATIONS_ENUM.SQL,new J(Gue)),e.set($.OPERATIONS_ENUM.CSV_DATA_LOAD,new J(As,lS.csvDataLoad)),e.set($.OPERATIONS_ENUM.CSV_FILE_LOAD,new J(As,lS.csvFileLoad)),e.set($.OPERATIONS_ENUM.CSV_URL_LOAD,new J(As,lS.csvURLLoad)),e.set($.OPERATIONS_ENUM.IMPORT_FROM_S3,new J(As,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(bue)),e.set($.OPERATIONS_ENUM.ADD_NODE,new J(Oue)),e.set($.OPERATIONS_ENUM.UPDATE_NODE,new J(Bq)),e.set($.OPERATIONS_ENUM.SET_NODE_REPLICATION,new J(Bq)),e.set($.OPERATIONS_ENUM.REMOVE_NODE,new J(Nue)),e.set($.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new J(Iue)),e.set($.OPERATIONS_ENUM.PURGE_STREAM,new J(wue)),e.set($.OPERATIONS_ENUM.SET_CONFIGURATION,new J($q.setConfiguration)),e.set($.OPERATIONS_ENUM.CLUSTER_STATUS,new J(Cue.clusterStatus)),e.set($.OPERATIONS_ENUM.CLUSTER_NETWORK,new J(Due)),e.set($.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new J(zO.setRoutes)),e.set($.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new J(zO.getRoutes)),e.set($.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new J(zO.deleteRoutes)),e.set($.OPERATIONS_ENUM.EXPORT_TO_S3,new J(As,Hq.export_to_s3)),e.set($.OPERATIONS_ENUM.CREATE_CSR,new J(Ju.createCsr)),e.set($.OPERATIONS_ENUM.SIGN_CERTIFICATE,new J(Ju.signCertificate)),e.set($.OPERATIONS_ENUM.LIST_CERTIFICATES,new J(Ju.listCertificates)),e.set($.OPERATIONS_ENUM.ADD_CERTIFICATES,new J(Ju.addCertificate)),e.set($.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new J(Ju.removeCertificate)),e.set($.OPERATIONS_ENUM.GET_KEY,new J(Ju.getKey)),e.set($.OPERATIONS_ENUM.ADD_NODE_BACK,new J(Yq.addNodeBack)),e.set($.OPERATIONS_ENUM.REMOVE_NODE_BACK,new J(Yq.removeNodeBack)),e.set($.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new J(As,Wf.deleteFilesBefore)),e.set($.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new J(As,Wf.deleteFilesBefore)),e.set($.OPERATIONS_ENUM.EXPORT_LOCAL,new J(As,Hq.export_local)),e.set($.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new J(XO.handleGetJobsByStartDate)),e.set($.OPERATIONS_ENUM.GET_JOB,new J(XO.handleGetJob)),e.set($.OPERATIONS_ENUM.GET_FINGERPRINT,new J(QO.getFingerprint)),e.set($.OPERATIONS_ENUM.SET_LICENSE,new J(QO.setLicense)),e.set($.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new J(QO.getRegistrationInfo)),e.set($.OPERATIONS_ENUM.RESTART,new J(kq.restart)),e.set($.OPERATIONS_ENUM.RESTART_SERVICE,new J(As,kq.restartService)),e.set($.OPERATIONS_ENUM.CATCHUP,new J($ue)),e.set($.OPERATIONS_ENUM.SYSTEM_INFORMATION,new J(Mue.systemInformation)),e.set($.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new J(As,Wf.deleteAuditLogsBefore)),e.set($.OPERATIONS_ENUM.READ_AUDIT_LOG,new J(yue)),e.set($.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new J(Gq.createTokens)),e.set($.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new J(Gq.refreshOperationToken)),e.set($.OPERATIONS_ENUM.LOGIN,new J(qq.login)),e.set($.OPERATIONS_ENUM.LOGOUT,new J(qq.logout)),e.set($.OPERATIONS_ENUM.GET_CONFIGURATION,new J($q.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(Vq.readTransactionLog)),e.set($.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new J(As,Vq.deleteTransactionLogsBefore)),e.set($.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new J(Kq.installModules)),e.set($.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new J(Kq.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(Vue,"initializeOperationFunctionMap")});var rN=N(r$=>{"use strict";var ge=require("fs-extra"),nN=require("fast-glob"),Ce=require("path"),Kue=require("tar-fs"),Yue=require("gunzip-maybe"),wDe=require("uuid").v4,sN=require("normalize-path"),Rn=cG(),Ft=W(),ft=M(),kt=se(),ES=wt(),Wue=te(),{PACKAGE_ROOT:jue}=M(),{handleHDBError:Gt,hdb_errors:zue}=_e(),{basename:Que}=require("path"),Jue=SO(),e$=se(),Xue=M(),{Readable:Zue}=require("stream"),{isMainThread:ede}=require("worker_threads"),{HDB_ERROR_MSGS:rl,HTTP_STATUS_CODES:qt}=zue,t$=dt(),{replicateOperation:si}=(us(),oe(ca)),{packageDirectory:tde}=(bG(),oe(yG)),Zq=kf(),rde=Ce.join(jue,"application-template"),CDe=Ce.join(kt.get(ft.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),"tmp"),nde=kt.get(ft.CONFIG_PARAMS.ROOTPATH),Sa=Ce.join(nde,"ssh"),go=Ce.join(Sa,"known_hosts");function sde(){Ft.trace("getting custom api status");let e={};try{e={port:kt.get(ft.CONFIG_PARAMS.HTTP_PORT),directory:kt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw Gt(new Error,rl.FUNCTION_STATUS,qt.INTERNAL_SERVER_ERROR,Ft.ERR,t)}return e}a(sde,"customFunctionsStatus");function ide(){Ft.trace("getting custom api endpoints");let e={},t=kt.get(ft.CONFIG_PARAMS.COMPONENTSROOT);try{nN.sync(sN(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:nN.sync(sN(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:nN.sync(sN(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw Gt(new Error,rl.GET_FUNCTIONS,qt.INTERNAL_SERVER_ERROR,Ft.ERR,r)}return e}a(ide,"getCustomFunctions");function ode(e){e.project&&(e.project=Ce.parse(e.project).name),e.file&&(e.file=Ce.parse(e.file).name);let t=Rn.getDropCustomFunctionValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);Ft.trace("getting custom api endpoint file content");let r=kt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=Ce.join(r,n,s,i+".js");try{return ge.readFileSync(o,{encoding:"utf8"})}catch(c){throw Gt(new Error,rl.GET_FUNCTION,qt.INTERNAL_SERVER_ERROR,Ft.ERR,c)}}a(ode,"getCustomFunction");async function ade(e){e.project&&(e.project=Ce.parse(e.project).name),e.file&&(e.file=Ce.parse(e.file).name);let t=Rn.setCustomFunctionValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);Ft.trace("setting custom function file content");let r=kt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{ge.outputFileSync(Ce.join(r,n,s,i+".js"),o);let c=await si(e);return c.message=`Successfully updated custom function: ${i}.js`,c}catch(c){throw Gt(new Error,rl.SET_FUNCTION,qt.INTERNAL_SERVER_ERROR,Ft.ERR,c)}}a(ade,"setCustomFunction");async function cde(e){e.project&&(e.project=Ce.parse(e.project).name),e.file&&(e.file=Ce.parse(e.file).name);let t=Rn.getDropCustomFunctionValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);Ft.trace("dropping custom function file");let r=kt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{ge.unlinkSync(Ce.join(r,n,s,i+".js"));let o=await si(e);return o.message=`Successfully deleted custom function: ${i}.js`,o}catch(o){throw Gt(new Error,rl.DROP_FUNCTION,qt.INTERNAL_SERVER_ERROR,Ft.ERR,o)}}a(cde,"dropCustomFunction");async function lde(e){e.project&&(e.project=Ce.parse(e.project).name);let t=Rn.addComponentValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);Ft.trace("adding component");let r=kt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=Ce.join(r,n);ge.mkdirSync(s,{recursive:!0}),ge.copySync(rde,s);let i=await si(e);return i.message=`Successfully added project: ${n}`,i}catch(s){throw Gt(new Error,rl.ADD_FUNCTION,qt.INTERNAL_SERVER_ERROR,Ft.ERR,s)}}a(lde,"addComponent");async function ude(e){e.project&&(e.project=Ce.parse(e.project).name);let t=Rn.dropCustomFunctionProjectValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);Ft.trace("dropping custom function project");let r=kt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=kt.get(ft.CONFIG_PARAMS.APPS);if(!Wue.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=Ce.join(r,n);ge.rmSync(i,{recursive:!0});let o=await si(e);return o.message=`Successfully deleted project: ${n}`,o}catch(i){throw Gt(new Error,rl.DROP_FUNCTION_PROJECT,qt.INTERNAL_SERVER_ERROR,Ft.ERR,i)}}a(ude,"dropCustomFunctionProject");async function dde(e){e.project&&(e.project=Ce.parse(e.project).name);let t=Rn.packageComponentValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let r=kt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;Ft.trace("packaging component",n);let s;try{s=await ge.realpath(Ce.join(r,n))}catch(o){if(o.code!==ft.NODE_ERROR_CODES.ENOENT)throw o;try{s=await ge.realpath(Ce.join(kt.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 tde(s,e)).toString("base64");return{project:n,payload:i}}a(dde,"packageComponent");async function _de(e){e.project&&(e.project=Ce.parse(e.project).name);let t=Rn.deployComponentValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let r=kt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i,install_command:o}=e;if(Ft.trace("deploying component",n),!s&&!i)throw new Error("'payload' or 'package' must be provided");let c;if(s){c=Ce.join(r,n),i="file:"+c,await ge.emptyDir(c);let T=Zue.from(s instanceof Buffer?s:Buffer.from(s,"base64"));await new Promise((S,b)=>{T.pipe(Yue()).pipe(Kue.extract(c,{finish:S})).on("error",b)});let m=await ge.readdir(c);m.length===1&&m[0]==="package"&&(await ge.copy(Ce.join(c,"package"),c),await ge.remove(Ce.join(c,"package")));let g=Ce.join(c,"node_modules");o?await Zq.runCommand(o,c):ge.existsSync(g)||await Zq.installAllRootModules(!1,c)}else{await ES.addConfig(n,{package:i}),await Jue();let T=e$.get(Xue.CONFIG_PARAMS.ROOTPATH);c=Ce.join(T,"node_modules",n)}if(ede)return;let l=new Map;l.isWorker=!0;let u=(Jf(),oe(Qf)),d;u.setErrorReporter(T=>d=T);let _=Que(c),E=u.component_errors.get(_);try{await u.loadComponent(c,l)}finally{u.component_errors.set(_,E)}if(d)throw d;Ft.info("Installed component");let f=e.restart==="rolling";e.restart=f?!1:e.restart;let h=await si(e);if(e.restart===!0)t$.restartWorkers("http"),h.message=`Successfully deployed: ${n}, restarting HarperDB`;else if(f){let m=await tN().executeJob({operation:"restart_service",service:"http",replicated:!0});h.restartJobId=m.job_id,h.message=`Successfully deployed: ${n}, restarting HarperDB`}else h.message=`Successfully deployed: ${n}`;return h}a(_de,"deployComponent");async function fde(){let e=a(async(s,i)=>{try{let o=await ge.readdir(s,{withFileTypes:!0});for(let c of o){let l=c.name;if(l.startsWith(".")||l==="node_modules")continue;let u=Ce.join(s,l);if(c.isDirectory()||c.isSymbolicLink()){let d={name:l,entries:[]};i.entries.push(d),await e(u,d)}else{let d=await ge.stat(u),_={name:Ce.basename(l),mtime:d.mtime,size:d.size};i.entries.push(_)}}return i}catch(o){return Ft.warn("Error loading package",o),{error:o.toString(),entries:[]}}},"walkDir"),t=await e(kt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),{name:kt.get(ft.CONFIG_PARAMS.COMPONENTSROOT).split(Ce.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(fde,"getComponents");async function Ede(e){let t=Rn.getComponentFileValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let n=ES.getConfigObj()[e.project]||e.project==="harperdb"?Ce.join(e$.get(ft.CONFIG_PARAMS.ROOTPATH),"node_modules"):kt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await ge.stat(Ce.join(n,e.project,e.file));return{message:await ge.readFile(Ce.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===ft.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${Ce.join(e.project,e.file)}'`):i}}a(Ede,"getComponentFile");async function hde(e){let t=Rn.setComponentFileValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=Ce.join(kt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);e.payload!==void 0?(await ge.ensureFile(n),await ge.outputFile(n,e.payload,r)):await ge.ensureDir(n);let s=await si(e);return s.message="Successfully set component: "+e.file,s}a(hde,"setComponentFile");async function pde(e){let t=Rn.dropComponentFileValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let{project:r,file:n}=e,s=e.file?Ce.join(r,n):r,i=Ce.join(kt.get(ft.CONFIG_PARAMS.COMPONENTSROOT),s),o=Ce.join(kt.get(ft.CONFIG_PARAMS.ROOTPATH),"node_modules",r);await ge.pathExists(o)&&await ge.unlink(o),await ge.pathExists(i)&&await ge.remove(i);let c=Ce.join(kt.get(ft.CONFIG_PARAMS.ROOTPATH),"package.json");if(await ge.pathExists(c)){let u=JSON.parse(await ge.readFile(c,"utf8"));u?.dependencies?.[r]&&delete u.dependencies[r],await ge.writeFile(c,JSON.stringify(u,null,2),"utf8")}ES.deleteConfigFromFile([r]);let l=await si(e);return e.restart===!0?(t$.restartWorkers("http"),l.message=`Successfully dropped: ${s}, restarting HarperDB`):l.message=`Successfully dropped: ${s}`,l}a(pde,"dropComponent");async function mde(e){let t=Rn.addSSHKeyValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let{name:r,key:n,host:s,hostname:i,known_hosts:o}=e;Ft.trace("adding ssh key",r);let c=Ce.join(Sa,r+".key"),l=Ce.join(Sa,"config");if(await ge.pathExists(c))throw new Error("Key already exists. Use update_ssh_key or delete_ssh_key and then add_ssh_key");await ge.outputFile(c,n),await ge.chmod(c,"0600");let u=`#${r}
|
|
24
24
|
Host ${s}
|
|
25
25
|
HostName ${i}
|
|
26
26
|
User git
|
|
27
27
|
IdentityFile ${c}
|
|
28
28
|
IdentitiesOnly yes`;await ge.pathExists(l)?await ge.appendFile(l,`
|
|
29
29
|
`+u):await ge.outputFile(l,u);let d="";if(await ge.pathExists(go)||(await ge.writeFile(go,""),await ge.chmod(go,"0600")),i=="github.com"&&!(await ge.readFile(go,"utf8")).includes("github.com"))try{let T=(await(await fetch("https://api.github.com/meta")).json()).ssh_keys;for(let m of T)ge.appendFile(go,"github.com "+m+`
|
|
30
|
-
`)}catch{d=". Unable to get known hosts from github.com. Set your known hosts manually using set_ssh_known_hosts."}o&&await ge.appendFile(go,o);let _=await ti(e);return _.message=`Added ssh key: ${r}${d}`,_}a(Rle,"addSSHKey");async function Ale(e){let t=Rn.updateSSHKeyValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);let{name:r,key:n}=e;kt.trace("updating ssh key",r);let s=Ce.join(Sa,r+".key");if(!await ge.pathExists(s))throw new Error("Key does not exist. Use add_ssh_key");await ge.outputFile(s,n);let i=await ti(e);return i.message=`Updated ssh key: ${r}`,i}a(Ale,"updateSSHKey");async function yle(e){let t=Rn.deleteSSHKeyValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);let{name:r}=e;kt.trace("deleting ssh key",r);let n=Ce.join(Sa,r+".key"),s=Ce.join(Sa,"config");if(!await ge.pathExists(n))throw new Error("Key does not exist");let i=await ge.readFile(s,"utf8"),o=new RegExp(`#${r}[\\S\\s]*?IdentitiesOnly yes`,"g");i=i.replace(o,""),await ge.outputFile(s,i),ge.removeSync(n);let c=await ti(e);return c.message=`Deleted ssh key: ${r}`,c}a(yle,"deleteSSHKey");async function ble(e){let t=[];return await ge.pathExists(Sa)&&(await ge.readdir(Sa)).forEach(r=>{r!="known_hosts"&&r!="config"&&t.push({name:r.split(".")[0]})}),t}a(ble,"listSSHKeys");async function Ole(e){let t=Rn.setSSHKnownHostsValidator(e);if(t)throw Ft(t,t.message,Gt.BAD_REQUEST);let{known_hosts:r}=e;await ge.outputFile(go,r);let n=await ti(e);return n.message="Known hosts successfully set",n}a(Ole,"setSSHKnownHosts");async function Nle(e){return await ge.pathExists(go)?{known_hosts:await ge.readFile(go,"utf8")}:{known_hosts:null}}a(Nle,"getSSHKnownHosts");Object.assign(NG,{customFunctionsStatus:cle,getCustomFunctions:lle,getCustomFunction:ule,setCustomFunction:dle,dropCustomFunction:_le,addComponent:fle,dropCustomFunctionProject:Ele,packageComponent:hle,deployComponent:ple,getComponents:mle,getComponentFile:Sle,setComponentFile:Tle,dropComponent:gle,addSSHKey:Rle,updateSSHKey:Ale,deleteSSHKey:yle,listSSHKeys:ble,setSSHKnownHosts:Ole,getSSHKnownHosts:Nle})});var yO=N((VCe,wG)=>{"use strict";var Rs=require("joi"),IG=Tt();wG.exports={readTransactionLogValidator:Ile,deleteTransactionLogsBeforeValidator:wle};function Ile(e){let t=Rs.object({schema:Rs.string(),database:Rs.string(),table:Rs.string().required(),from:Rs.date().timestamp(),to:Rs.date().timestamp(),limit:Rs.number().min(1)});return IG.validateBySchema(e,t)}a(Ile,"readTransactionLogValidator");function wle(e){let t=Rs.object({schema:Rs.string(),database:Rs.string(),table:Rs.string().required(),timestamp:Rs.date().timestamp().required()});return IG.validateBySchema(e,t)}a(wle,"deleteTransactionLogsBeforeValidator")});var jm=N((YCe,UG)=>{"use strict";var bO=M(),Vf=mr(),CG=te(),DG=se(),PG=to(),LG=W(),{handleHDBError:Ym,hdb_errors:Cle}=_e(),{HTTP_STATUS_CODES:Wm}=Cle,{readTransactionLogValidator:Dle,deleteTransactionLogsBeforeValidator:Ple}=yO(),MG=Bn(),Lle="Logs successfully deleted from transaction log.",Mle="All logs successfully deleted from transaction log.";UG.exports={readTransactionLog:Ule,deleteTransactionLogsBefore:Ble};async function Ule(e){let t=Dle(e);if(t)throw Ym(t,t.message,Wm.BAD_REQUEST,void 0,void 0,!0);e.database=e.database??e.schema??"data";let r=CG.checkSchemaTableExist(e.database,e.table);if(r)throw Ym(new Error,r,Wm.NOT_FOUND,void 0,void 0,!0);return DG.get(bO.CONFIG_PARAMS.CLUSTERING_ENABLED)?await vle(e):(LG.info("Reading HarperDB logs used by Plexus"),(e.from||e.to)&&(e.search_type="timestamp",e.search_values=[e.from??0],e.to&&(e.search_values[1]=e.to)),MG.readAuditLog(e))}a(Ule,"readTransactionLog");async function*vle(e){let t=PG.createNatsTableStreamName(e.database,e.table),r=await Vf.viewStreamIterator(t,parseInt(e.from),e.limit);for await(let n of r){let s=Math.floor(n?.nats_timestamp/1e6);if(e.to&&s>e.to)break;let i={operation:n?.entry?.operation,user:n?.entry?.__origin?.user,timestamp:s,records:n?.entry?.records,attributes:n?.entry?.attributes};n?.entry?.operation===bO.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(vle,"readTransactionLogNats");async function Ble(e){let t=Ple(e);if(t)throw Ym(t,t.message,Wm.BAD_REQUEST,void 0,void 0,!0);if(e.database=e.database??e.schema??"data",!DG.get(bO.CONFIG_PARAMS.CLUSTERING_ENABLED))return LG.info("Delete transaction logs called for Plexus"),MG.deleteAuditLogsBefore(e);let{database:r,table:n,timestamp:s}=e,i=CG.checkSchemaTableExist(r,n);if(i)throw Ym(new Error,i,Wm.NOT_FOUND,void 0,void 0,!0);let o=PG.createNatsTableStreamName(r,n),{jsm:c}=await Vf.getNATSReferences(),l=await Vf.getStreamInfo(o),u=new Date(l.state.first_ts).getTime();if(s<=u)return`No transactions exist before: ${s}`;let d=Lle,_,E=new Date(l.state.last_ts).getTime();return s>E?(_=l.state.last_seq+1,d=Mle):_=(await Vf.viewStream(o,parseInt(s),1))[0].nats_sequence,await Vf.purgeTableStream(r,n,{seq:_}),d}a(Ble,"deleteTransactionLogsBefore")});var BG=N((jCe,vG)=>{"use strict";var OO=class{static{a(this,"PermissionTableResponseObject")}constructor(t,r,n=[],s=[]){this.schema=t,this.table=r,this.required_table_permissions=n,this.required_attribute_permissions=s}};vG.exports=OO});var xG=N((QCe,HG)=>{"use strict";var NO=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};HG.exports=NO});var wO=N((XCe,FG)=>{"use strict";var kG=BG(),Hle=xG(),{HDB_ERROR_MSGS:xle}=Dn(),IO=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=xle.OP_AUTH_PERMS_ERROR,this.unauthorized_access={},this.invalid_schema_items=[]}handleUnauthorizedItem(t){return this.invalid_schema_items=[],this.unauthorized_access=[t],this}handleInvalidItem(t){return this.invalid_schema_items=[t],this.unauthorized_access=[],this}addInvalidItem(t,r,n){if(r&&n){let s=`${r}_${n}`;if(this.unauthorized_access[s])return}this.invalid_schema_items.push(t)}addUnauthorizedTable(t,r,n){let s=new kG(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let l=new Hle(c,s[c]);i.push(l)});let o=`${r}_${n}`;if(this.unauthorized_access[o])this.unauthorized_access[o].required_attribute_permissions=i;else{let c=new kG(r,n,[],i);this.unauthorized_access[o]=c}}getPermsResponse(){let t=Object.values(this.unauthorized_access);return t.length>0||this.invalid_schema_items.length>0?(this.unauthorized_access=t,this):null}};FG.exports=IO});var Xm=N((rDe,nq)=>{"use strict";var CO=un(),zm=Vr(),As=em(),Wf=ro(),DO=uc(),kle=zy(),Fle=KH(),jf=xn(),Qm=lf(),gr=W(),Gle=ob(),qle=pf(),$le=Lb(),Vle=Rf(),Kle=vb(),Yle=Bb(),Wle=mm(),jle=Fb(),PO=Tm(),Ro=te(),zle=Fk(),LO=Wb(),$G=xu(),Zr=M(),VG=YF(),Qle=Ou(),KG=lu(),YG=(xm(),oe(Hf)),WG=wt(),or=AO(),Jle=require("alasql"),jG=jm(),zG=kf(),Yu=Xs(),QG=(Hc(),oe(Bc)),JG=wO(),{handleHDBError:An,hdb_errors:XG}=_e(),{addNodeBack:eDe,removeNodeBack:tDe}=(Hc(),oe(Bc)),{HDB_ERROR_MSGS:Mr,HTTP_STATUS_CODES:Kf}=XG,z=new Map,ZG="delete",Ta="insert",Ao="read",Qc="update",Yf="describe",GG=Wf.describeSchema.name,qG=Wf.describeTable.name,eq={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},Xle={insert:!0,delete:!0,deleteRecord:!0,update:!0,updateData:!0,upsert:!0,upsertData:!0},Zle="catchup",eue="handleGetJob",tue="handleGetJobsByStartDate",Jm={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},rue=[As.createTable.name,As.createAttribute.name,As.dropTable.name,As.dropAttribute.name],tq={EXPORT_TO_S3:"export_to_s3",EXPORT_LOCAL:"export_local"},Z=class{static{a(this,"permission")}constructor(t,r){this.requires_su=t,this.perms=r}};z.set(CO.insert.name,new Z(!1,[Ta]));z.set(CO.update.name,new Z(!1,[Qc]));z.set(CO.upsert.name,new Z(!1,[Ta,Qc]));z.set(zm.searchByConditions.name,new Z(!1,[Ao]));z.set(zm.searchByHash.name,new Z(!1,[Ao]));z.set(zm.searchByValue.name,new Z(!1,[Ao]));z.set(zm.search.name,new Z(!1,[Ao]));z.set(As.createSchema.name,new Z(!0,[]));z.set(As.createTable.name,new Z(!0,[]));z.set(As.createAttribute.name,new Z(!1,[Ta]));z.set(As.dropSchema.name,new Z(!0,[]));z.set(As.dropTable.name,new Z(!0,[]));z.set(As.dropAttribute.name,new Z(!0,[]));z.set(Wf.describeSchema.name,new Z(!1,[Ao]));z.set(Wf.describeTable.name,new Z(!1,[Ao]));z.set(DO.deleteRecord.name,new Z(!1,[ZG]));z.set(jf.addUser.name,new Z(!0,[]));z.set(jf.alterUser.name,new Z(!0,[]));z.set(jf.dropUser.name,new Z(!0,[]));z.set(jf.listUsersExternal.name,new Z(!0,[]));z.set(Qm.listRoles.name,new Z(!0,[]));z.set(Qm.addRole.name,new Z(!0,[]));z.set(Qm.alterRole.name,new Z(!0,[]));z.set(Qm.dropRole.name,new Z(!0,[]));z.set(Gle.name,new Z(!0,[]));z.set(qle.name,new Z(!0,[]));z.set($le.name,new Z(!0,[]));z.set(Vle.name,new Z(!0,[]));z.set(Kle.name,new Z(!0,[]));z.set(Yle.name,new Z(!0,[]));z.set(PO.setRoutes.name,new Z(!0,[]));z.set(PO.getRoutes.name,new Z(!0,[]));z.set(PO.deleteRoutes.name,new Z(!0,[]));z.set(WG.setConfiguration.name,new Z(!0,[]));z.set(Wle.clusterStatus.name,new Z(!0,[]));z.set(jle.name,new Z(!0,[]));z.set(LO.getFingerprint.name,new Z(!0,[]));z.set(LO.setLicense.name,new Z(!0,[]));z.set(DO.deleteFilesBefore.name,new Z(!0,[]));z.set(DO.deleteAuditLogsBefore.name,new Z(!0,[]));z.set($G.restart.name,new Z(!0,[]));z.set($G.restartService.name,new Z(!0,[]));z.set(kle.name,new Z(!0,[]));z.set(Fle.name,new Z(!0,[Ao]));z.set(Qle.systemInformation.name,new Z(!0,[]));z.set(WG.getConfiguration.name,new Z(!0,[]));z.set(jG.readTransactionLog.name,new Z(!0,[]));z.set(jG.deleteTransactionLogsBefore.name,new Z(!0,[]));z.set(zG.installModules.name,new Z(!0,[]));z.set(zG.auditModules.name,new Z(!0,[]));z.set(Yu.createCsr.name,new Z(!0,[]));z.set(Yu.signCertificate.name,new Z(!0,[]));z.set(Yu.listCertificates.name,new Z(!0,[]));z.set(Yu.addCertificate.name,new Z(!0,[]));z.set(Yu.removeCertificate.name,new Z(!0,[]));z.set(Yu.getKey.name,new Z(!0,[]));z.set(QG.addNodeBack.name,new Z(!0,[]));z.set(QG.removeNodeBack.name,new Z(!0,[]));z.set(KG.createTokens.name,new Z(!1,[]));z.set(KG.refreshOperationToken.name,new Z(!1,[]));z.set(YG.login.name,new Z(!1,[]));z.set(YG.logout.name,new Z(!1,[]));z.set(or.customFunctionsStatus.name,new Z(!0,[]));z.set(or.getCustomFunctions.name,new Z(!0,[]));z.set(or.getComponents.name,new Z(!0,[]));z.set(or.getComponentFile.name,new Z(!0,[]));z.set(or.setComponentFile.name,new Z(!0,[]));z.set(or.dropComponent.name,new Z(!0,[]));z.set(or.getCustomFunction.name,new Z(!0,[]));z.set(or.setCustomFunction.name,new Z(!0,[]));z.set(or.dropCustomFunction.name,new Z(!0,[]));z.set(or.addComponent.name,new Z(!0,[]));z.set(or.dropCustomFunctionProject.name,new Z(!0,[]));z.set(or.packageComponent.name,new Z(!0,[]));z.set(or.deployComponent.name,new Z(!0,[]));z.set(or.addSSHKey.name,new Z(!0,[]));z.set(or.updateSSHKey.name,new Z(!0,[]));z.set(or.deleteSSHKey.name,new Z(!0,[]));z.set(or.listSSHKeys.name,new Z(!0,[]));z.set(or.setSSHKnownHosts.name,new Z(!0,[]));z.set(or.getSSHKnownHosts.name,new Z(!0,[]));z.set(LO.getRegistrationInfo.name,new Z(!1,[]));z.set(jf.userInfo.name,new Z(!1,[]));z.set(Wf.describeAll.name,new Z(!1,[]));z.set(eue,new Z(!1,[]));z.set(tue,new Z(!0,[]));z.set(Zle,new Z(!0,[]));z.set(Jm.CSV_DATA_LOAD,new Z(!1,[Ta,Qc]));z.set(Jm.CSV_URL_LOAD,new Z(!1,[Ta,Qc]));z.set(Jm.CSV_FILE_LOAD,new Z(!1,[Ta,Qc]));z.set(Jm.IMPORT_FROM_S3,new Z(!1,[Ta,Qc]));z.set(tq.EXPORT_TO_S3,new Z(!0,[]));z.set(tq.EXPORT_LOCAL,new Z(!0,[]));z.set(Zr.VALID_SQL_OPS_ENUM.DELETE,new Z(!1,[ZG]));z.set(Zr.VALID_SQL_OPS_ENUM.SELECT,new Z(!1,[Ao]));z.set(Zr.VALID_SQL_OPS_ENUM.INSERT,new Z(!1,[Ta]));z.set(Zr.VALID_SQL_OPS_ENUM.UPDATE,new Z(!1,[Qc]));nq.exports={verifyPerms:sue,verifyPermsAst:nue,verifyBulkLoadAttributePerms:oue};function nue(e,t,r){if(Ro.isEmptyOrZeroLength(e))throw gr.info("verify_perms_ast has an empty user parameter"),An(new Error);if(Ro.isEmptyOrZeroLength(t))throw gr.info("verify_perms_ast has an empty user parameter"),An(new Error);if(Ro.isEmptyOrZeroLength(r))throw gr.info("verify_perms_ast has a null operation parameter"),An(new Error);try{let n=new JG,s=new zle(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw gr.info("No schemas defined in verifyPermsAst(), will not continue."),An(new Error);let c=!!t.role.permission.super_user,l=i.includes("system");if(l&&eq[r])throw An(new Error,Mr.DROP_SYSTEM,Kf.FORBIDDEN);if(c&&!l)return null;let u=VG.getRolePermissions(t.role);t.role.permission=u,!c&&e instanceof Jle.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(u));for(let _=0;_<i.length;_++){let E=s.getTablesBySchemaName(i[_]);E&&o.set(i[_],E)}let d=rq(t,r,o,n);return d||(o.forEach((_,E)=>{for(let f=0;f<_.length;f++){let h=s.getAttributesBySchemaTableName(E,_[f]),T=UO(t.role.permission,E,_[f]);MO(h,T,r,_[f],E,n)}}),n.getPermsResponse())}catch(n){throw An(n)}}a(nue,"verifyPermsAst");function sue(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw gr.info("null required parameter in verifyPerms"),An(new Error,Mr.DEFAULT_INVALID_REQUEST,Kf.BAD_REQUEST);let r;t instanceof Function?r=t.name:r=t;let n=e.action,s=e.schema??e.database,i=e.table,o=new Map;s&&i&&o.set(s,[i]);let c=new JG;if(Ro.isEmptyOrZeroLength(e.hdb_user?.role)||Ro.isEmptyOrZeroLength(e.hdb_user?.role?.permission))return gr.info(`User ${e.hdb_user?.username} has no role or permissions. Please assign the user a valid role.`),c.handleUnauthorizedItem(Mr.USER_HAS_NO_PERMS(e.hdb_user?.username));let l=!!e.hdb_user?.role?.permission?.super_user,u=e.hdb_user?.role?.permission?.structure_user,d=o.has(Zr.SYSTEM_SCHEMA_NAME)||s===Zr.SYSTEM_SCHEMA_NAME;if(l&&d&&Xle[e.operation]&&(i===Zr.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME||i===Zr.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||i===Zr.SYSTEM_TABLE_NAMES.USER_TABLE_NAME))return null;if(d&&eq[r])throw An(new Error,Mr.DROP_SYSTEM,Kf.FORBIDDEN);if(l&&!d||u===!0&&(r===As.createSchema.name||r===As.dropSchema.name))return null;if(rue.indexOf(r)>=0&&(u===!0||Array.isArray(u)))return u===!0||u.indexOf(s)>=0?null:c.handleUnauthorizedItem(`User does not have access to perform '${e.operation}' against schema '${s}'`);let _=VG.getRolePermissions(e.hdb_user?.role);if(e.hdb_user?.role&&(e.hdb_user.role.permission=_),r===GG||r===qG){if(s===Zr.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(Mr.SCHEMA_PERM_ERROR(s));if(!_.super_user){if(r===GG&&(!_[s]||!_[s][Yf]))return c.handleInvalidItem(Mr.SCHEMA_NOT_FOUND(s));if(r===qG&&(!_[s]||!_[s].tables[i]||!_[s].tables[i][Yf]))return c.handleInvalidItem(Mr.TABLE_NOT_FOUND(s,i))}}let E=rq(e.hdb_user,r,o,c,n);if(E)return E;if(z.get(r)&&z.get(r).perms.length===0)return null;if(!l&&e.get_attributes&&Zr.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let T=[],m=_[s].tables[i];m[Zr.PERMS_CRUD_ENUM.READ]&&(m.attribute_permissions.length>0?m.attribute_permissions.filter(S=>S[Zr.PERMS_CRUD_ENUM.READ]).forEach(S=>{T.push(S.attribute_name)}):T=global.hdb_schema[s][i].attributes.map(g=>g.attribute),e.get_attributes=T)}let f=iue(e),h=UO(e.hdb_user?.role?.permission,s,i);return MO(f,h,r,i,s,c,n),c.getPermsResponse()}a(sue,"verifyPerms");function rq(e,t,r,n,s){if(Ro.arrayHasEmptyValues([e,t,r]))throw gr.info("hasPermissions has an invalid parameter"),An(new Error);let i=r.has("system"),o=e.role.permission;if(o.super_user&&(!i||z.get(t).requires_su))return null;if(!z.get(t))throw gr.info(`operation ${t} not found.`),An(new Error,Mr.OP_NOT_FOUND(t),Kf.BAD_REQUEST);if(z.get(t)&&z.get(t).requires_su)return gr.info(`operation ${t} requires SU permissions.`),n.handleUnauthorizedItem(Mr.OP_IS_SU_ONLY(t));let c=r.keys();for(let l of c){try{if(l&&!o[l]||o[l][Yf]===!1){n.addInvalidItem(Mr.SCHEMA_NOT_FOUND(l));continue}}catch{n.addInvalidItem(Mr.SCHEMA_NOT_FOUND(l));continue}let u=r.get(l);for(let d of u){let _=o[l].tables[d];if(!_||_[Yf]===!1)n.addInvalidItem(Mr.TABLE_NOT_FOUND(l,d));else try{let E=[],f=z.get(t).perms;!Ro.isEmpty(s)&&f.includes(s)&&(f=[s]);for(let h=0;h<f.length;h++){let T=f[h],m=_[T];(m==null||m===!1)&&(gr.info(`Required ${T} permission not found for ${t} ${s?`${s} `:""}operation in role ${e.role.id}`),E.push(T))}E.length>0&&n.addUnauthorizedTable(l,d,E)}catch(E){let f=Mr.UNKNOWN_OP_AUTH_ERROR(t,l,d);throw gr.error(f),gr.error(E),An(XG.CHECK_LOGS_WRAPPER(f))}}}return r.size<2?n.getPermsResponse():null}a(rq,"hasPermissions");function MO(e,t,r,n,s,i,o){if(!e||!t)throw gr.info("no attributes specified in checkAttributePerms."),An(new Error);let c=z.get(r).perms;if(!c||c==="")throw gr.info(`no permissions found for ${r} in checkAttributePerms().`),An(new Error);if(Ro.isEmptyOrZeroLength(t))return gr.info("No role permissions set (this is OK)."),null;o&&c.includes(o)&&(c=[o]);let l={};for(let d of e){let _=t.get(d);if(_){if(_[Yf]===!1){i.addInvalidItem(Mr.ATTR_NOT_FOUND(s,n,d),s,n);continue}if(c)for(let E of c){if(Zr.TIME_STAMP_NAMES.includes(_.attribute_name)&&E!==Ao)throw An(new Error,Mr.SYSTEM_TIMESTAMP_PERMS_ERR,Kf.FORBIDDEN);_[E]===!1&&(l[_.attribute_name]?l[_.attribute_name].push(E):l[_.attribute_name]=[E])}}else i.addInvalidItem(Mr.ATTR_NOT_FOUND(s,n,d),s,n)}let u=Object.keys(l);u.length>0&&i.addUnauthorizedAttributes(u,s,n,l)}a(MO,"checkAttributePerms");function iue(e){let t=new Set;try{if(e.action)return t;if(e.operation===Zr.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS&&e.conditions.forEach(r=>{t.add(r.search_attribute)}),e&&e.search_attribute&&t.add(e.search_attribute),!e.records||e.records.length===0){if(!e.get_attributes||!e.get_attributes.length===0)return t;for(let r=0;r<e.get_attributes.length;r++)t.add(e.get_attributes[r])}else for(let r=0;r<e.records.length;r++){let n=Object.keys(e.records[r]);for(let s=0;s<n.length;s++)t.add(n[s])}}catch(r){gr.info(r)}return t}a(iue,"getRecordAttributes");function UO(e,t,r){let n=new Map;if(Ro.isEmpty(e))return gr.info("no hdb_user specified in getAttributePermissions"),n;if(e.super_user||!t||!r)return n;try{e[t].tables[r].attribute_permissions.forEach(s=>{n.has(s.attribute_name)||n.set(s.attribute_name,s)})}catch{gr.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(UO,"getAttributePermissions");function oue(e,t,r,n,s,i,o){let c=new Set(i),l=UO(e,n,s);MO(c,l,t,s,n,o,r)}a(oue,"verifyBulkLoadAttributePerms")});var eS=N((sDe,cq)=>{"use strict";cq.exports={evaluateSQL:Tue,processAST:aq,convertSQLToAST:oq,checkASTPermissions:iq};var aue=un(),sq=require("util"),cue=sq.callbackify(aue.insert),lue=Vr().search,uue=Zv().update,due=sq.callbackify(uue),_ue=t0().convertDelete,ga=require("alasql"),fue=Xm(),Zm=W(),Eue=Ep(),hue=te(),zf=M(),{hdb_errors:pue,handleHDBError:vO}=_e(),{HTTP_STATUS_CODES:BO}=pue;Eue(ga);var mue=403,Sue="There was a problem performing this insert. Please check the logs and try again.",HO=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function Tue(e,t){let r=e.parsed_sql_object;if(!r){r=oq(e.sql);let n,s=r.ast.statements[0];if(s instanceof ga.yy.Insert?n=s.into.databaseid:s instanceof ga.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof ga.yy.Update||s instanceof ga.yy.Delete?n=s.table.databaseid:Zm.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof ga.yy.Select)&&hue.isEmptyOrZeroLength(n))return t("No schema specified",null)}aq(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(Tue,"evaluateSQL");function iq(e,t){let r;try{r=fue.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(iq,"checkASTPermissions");function oq(e){let t=new HO;if(!e)throw vO(new Error,"The 'sql' parameter is missing from the request body",BO.BAD_REQUEST);try{let r=e.trim(),n=ga.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
|
|
31
|
-
`);throw n[1]?vO(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,BO.BAD_REQUEST):vO(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",BO.BAD_REQUEST)}return t}a(oq,"convertSQLToAST");function aq(e,t,r){try{let n=gue;if(!e.bypass_auth&&!t.permissions_checked){let i=iq(e,t);if(i&&i.length>0)return r(mue,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case zf.VALID_SQL_OPS_ENUM.SELECT:n=lue,s=t.ast.statements[0];break;case zf.VALID_SQL_OPS_ENUM.INSERT:n=Rue;break;case zf.VALID_SQL_OPS_ENUM.UPDATE:n=due;break;case zf.VALID_SQL_OPS_ENUM.DELETE:n=_ue;break;default:throw new Error(`unsupported SQL type ${t.variant} in SQL: ${e}`)}n(s,(i,o)=>{if(i){r(i);return}r(null,o)})}catch(n){return r(n)}}a(aq,"processAST");function gue(e,t){Zm.info(e),t("unknown sql statement")}a(gue,"nullFunction");function Rue({statement:e,hdb_user:t},r){let n=e.into,s={schema:n.databaseid,table:n.tableid,operation:"insert",hdb_user:t},i=e.columns.map(o=>o.columnid);try{s.records=Aue(i,e.values)}catch(o){return r(o)}cue(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(l){Zm.error(`Error delete new_attributes from insert response: ${l}`)}r(null,c)})}a(Rue,"convertInsert");function Aue(e,t){try{return t.map(r=>{if(e.length!==r.length)throw"number of values do not match number of columns in insert";let n={};return r.forEach((s,i)=>{if(s.columnid)throw"cannot use a column in insert value";"value"in s?n[e[i]]=s.value:n[e[i]]=ga.compile(`SELECT ${s.toString()} AS [${zf.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw Zm.error(r),new Error(Sue)}}a(Aue,"createDataObjects")});var xO=N((oDe,uq)=>{"use strict";var{S3:yue,GetObjectCommand:bue}=require("@aws-sdk/client-s3");uq.exports={getFileStreamFromS3:Oue,getS3AuthObj:lq};async function Oue(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await lq(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new bue(r))).Body}a(Oue,"getFileStreamFromS3");function lq(e,t,r){return new yue({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(lq,"getS3AuthObj")});var tS=N((cDe,Tq)=>{"use strict";var FO=Vr(),Nue=eS(),Iue=xO(),{AsyncParser:wue,Transform:Cue}=require("json2csv"),Jf=require("stream"),Wn=te(),kO=require("fs-extra"),Due=require("path"),ys=W(),{promisify:fq}=require("util"),Qf=te(),{handleHDBError:ar,hdb_errors:Pue}=_e(),{HDB_ERROR_MSGS:yn,HTTP_STATUS_CODES:cr}=Pue,{streamAsJSON:Lue}=(Ug(),oe(MD)),{Upload:Mue}=require("@aws-sdk/lib-storage"),dq=["search_by_value","search_by_hash","sql","search_by_conditions"],_q=["json","csv"],Eq="json",hq="csv",Uue="Successfully exported JSON locally.",vue="Successfully exported CSV locally.",Bue=1e3,Hue=FO.searchByHash,xue=FO.searchByValue,kue=fq(Nue.evaluateSQL),Fue=fq(Jf.finished);Tq.exports={export_to_s3:Vue,export_local:Gue,toCsvStream:pq};async function Gue(e){ys.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=mq(e);if(!Wn.isEmpty(t))throw ys.error(t),ar(new Error,t,cr.BAD_REQUEST,void 0,void 0,!0);if(Wn.isEmpty(e.path))throw ys.error(yn.MISSING_VALUE("path")),ar(new Error,yn.MISSING_VALUE("path"),cr.BAD_REQUEST,void 0,void 0,!0);let r=(Wn.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(Due.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=Wn.buildFolderPath(e.path,r);await que(e.path);let s=await Sq(e);return await $ue(n,e.format,s)}a(Gue,"export_local");async function que(e){if(ys.trace("in confirmPath"),Wn.isEmptyOrZeroLength(e))throw ar(new Error,`Invalid path: ${e}`,cr.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await kO.stat(e)}catch(r){let n;throw r.code==="ENOENT"?n=`path '${e}' does not exist`:r.code==="EACCES"?n=`access to path '${e}' is denied`:n=r.message,ys.error(n),ar(new Error,n,cr.BAD_REQUEST,void 0,void 0,!0)}if(!t.isDirectory()){let r=`path '${e}' is not a directory, please supply a valid folder path`;throw ys.error(r),ar(new Error,r,cr.BAD_REQUEST,void 0,void 0,!0)}return!0}a(que,"confirmPath");async function $ue(e,t,r){if(ys.trace("in saveToLocal"),Qf.isEmptyOrZeroLength(e))throw ar(new Error,yn.INVALID_VALUE("file_path"),cr.BAD_REQUEST,void 0,void 0,!0);if(Qf.isEmptyOrZeroLength(t))throw ar(new Error,yn.INVALID_VALUE("Source format"),cr.BAD_REQUEST,void 0,void 0,!0);if(Qf.isEmpty(r))throw ar(new Error,yn.NOT_FOUND("Data"),cr.BAD_REQUEST,void 0,void 0,!0);if(t===Eq){let n=kO.createWriteStream(e);return Lue(r).pipe(n),await Fue(n),{message:Uue,path:e}}else if(t===hq){let n=kO.createWriteStream(e),s=Jf.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(d=>({label:d,value:d})));let c={objectMode:!0};return await new wue(i,c).fromInput(s).toOutput(n).promise(!1),{message:vue,path:e}}throw ar(new Error,yn.INVALID_VALUE("format"),cr.BAD_REQUEST)}a($ue,"saveToLocal");async function Vue(e){if(!e.s3||Object.keys(e.s3).length===0)throw ar(new Error,yn.MISSING_VALUE("S3 object"),cr.BAD_REQUEST);if(Wn.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw ar(new Error,yn.MISSING_VALUE("aws_access_key_id"),cr.BAD_REQUEST);if(Wn.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw ar(new Error,yn.MISSING_VALUE("aws_secret_access_key"),cr.BAD_REQUEST);if(Wn.isEmptyOrZeroLength(e.s3.bucket))throw ar(new Error,yn.MISSING_VALUE("bucket"),cr.BAD_REQUEST);if(Wn.isEmptyOrZeroLength(e.s3.key))throw ar(new Error,yn.MISSING_VALUE("key"),cr.BAD_REQUEST);if(Wn.isEmptyOrZeroLength(e.s3.region))throw ar(new Error,yn.MISSING_VALUE("region"),cr.BAD_REQUEST);let t=mq(e);if(!Wn.isEmpty(t))throw ar(new Error,t,cr.BAD_REQUEST);ys.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await Sq(e)}catch(l){throw ys.error(l),l}let n,s=await Iue.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new Jf.PassThrough;if(e.format===hq){i=e.s3.key+".csv";let l=pq(r,r.getColumns?.());l.on("error",u=>{throw u}),l.pipe(o)}else if(e.format===Eq){i=e.s3.key+".json";let l=new Jf.Readable;l.pipe(o),l.on("error",_=>{throw _}),l.push("[");let u=r.length,d="";for(let[_,E]of r.entries()){let f=_===u-1?JSON.stringify(E):JSON.stringify(E)+",";d+=f,_!==0&&_%Bue===0&&(l.push(d),d="")}d.length!==0&&l.push(d),l.push("]"),l.push(null)}else throw ar(new Error,yn.INVALID_VALUE("format"),cr.BAD_REQUEST);return new Mue({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(Vue,"export_to_s3");function pq(e,t){let r=Jf.Readable.from(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator]?e:[e]),n={};t&&(n.fields=t.map(o=>({label:o,value:o})));let s={objectMode:!0},i=new Cue(n,s);return r.pipe(i)}a(pq,"toCsvStream");function mq(e){if(ys.trace("in exportCoreValidation"),Wn.isEmpty(e.format))return"format missing";if(_q.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${_q.join(", ")}`;let t=e.search_operation.operation;if(Wn.isEmpty(t))return"search_operation.operation missing";if(dq.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${dq.join(", ")}`}a(mq,"exportCoreValidation");async function Sq(e){ys.trace("in getRecords");let t,r;if(Qf.isEmpty(e.search_operation)||Qf.isEmptyOrZeroLength(e.search_operation.operation))throw ar(new Error,yn.INVALID_VALUE("Search operation"),cr.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=xue;break;case"search_by_hash":t=Hue;break;case"search_by_conditions":t=FO.searchByConditions;break;case"sql":t=kue;break;default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,ys.error(r),ar(new Error,r,cr.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(Sq,"getRecords")});var Iq={};je(Iq,{contentTypes:()=>KO,findBestSerializer:()=>sS,getDeserializer:()=>bo,registerContentHandlers:()=>YO,serialize:()=>eE,serializeMessage:()=>Yc});function Kue(e){try{return e?.[0]===123?VO(e):e}catch{return e}}function YO(e){e.register(Wue,{serializers:[{regex:/^application\/json$/,serializer:Xd},{regex:/^application\/cbor$/,serializer:a(function(t){return new Jc.EncoderStream(Zf).end(t)},"serializer")},{regex:/^application\/(x-)?msgpack$/,serializer:a(function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?nS.Readable.from((0,Li.encodeIter)(t,Zf)):(0,Li.pack)(t)},"serializer")},{regex:/^text\/csv$/,serializer:a(function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),(0,rS.toCsvStream)(t)},"serializer")}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Li.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Jc.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function sS(e){let t=e.headers.asObject||e.headers,r=e.requestedContentType??t.accept,n,s=0,i,o,c=r?r.toLowerCase().split(/\s*,\s*/):[];for(let l of c){let[u,...d]=l.split(/\s*;\s*/),_=1,E={q:1};for(let h of d){let T=h.indexOf("=");E[h.substring(0,T)]=h.substring(T+1)}_=+E.q;let f=en.get(u);if(f){let h=(f.q||1)*_;h>s&&(n=f,i=f.type||u,s=h,o=E)}}if(!n){if(r)throw new Aq.ClientError("No supported content types found in Accept header, supported types include: "+Array.from(en.keys()).join(", "),406);n=en.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function eE(e,t,r){let n=Rq&&t.headers.asObject?.["accept-encoding"]?.includes("br"),s;if(e?.contentType!=null&&e.data!=null)r.headers.set("Content-Type",e.contentType),r.headers.set("Vary","Accept-Encoding"),s=e.data;else if(e instanceof Uint8Array)r.headers.set("Content-Type","application/octet-stream"),r.headers.set("Vary","Accept-Encoding"),s=e;else{let i=sS(t);if(i.serializer.compressible===!1&&(n=!1),r.headers.set("Vary","Accept, Accept-Encoding"),r.headers.set("Content-Type",i.type),typeof e=="object"&&e&&(e[Symbol.iterator]||e[Symbol.asyncIterator])&&i.serializer.serializeStream){if(e.mapError){let c=e.getColumns;e=e.mapError(l=>(l.toJSON=()=>({error:l.name,message:l.message,...l.partialObject}),$O.default.warn?.(`Error serializing error ${t?.url||t}: ${l}`),l)),e.getColumns=c}let o=i.serializer.serializeStream(e,r);return n&&(r.headers.set("Content-Encoding","br"),o=o.pipe((0,yo.createBrotliCompress)({params:{[yo.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?yo.constants.BROTLI_MODE_TEXT:yo.constants.BROTLI_MODE_GENERIC,[yo.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>Rq?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,yo.brotliCompress)(s,(c,l)=>{c?o(c):i(l)}))):s}function Yc(e,t){if(e?.contentType!=null&&e.data!=null)return e.data;if(!t)return Xf(e);let r=t.serialize;if(r)return r(e);let n=sS(t);return r=t.serialize=n.serializer.serialize,r(e)}function jue(e){return new Promise((t,r)=>{let n=[];e.on("data",s=>n.push(s)),e.on("end",()=>t(Buffer.concat(n))),e.on("error",r)})}function Que(e){return zue.includes(e)}function Jue(e){let t=e.indexOf(";"),r;if(t>-1){r={};let n=e.slice(t+1).split(";");for(let s of n){let[i,o]=s.split("=");r[i.trim()]=o.trim()}e=e.slice(0,t)}return{type:e,parameters:r}}function bo(e="",t=!1){let r=Jue(e),n=r.type&&en.get(r.type)?.deserialize||Xue(r);return t?s=>jue(s).then(n):n}function Xue(e){return e.type.startsWith("text/")?(e.parameters?.charset&&!Que(e.parameters.charset)&&$O.default.info(`Unknown Buffer encoding ${e.parameters.charset} in content-type. Proceeding anyways.`),t=>({contentType:e.type,data:t.toString(e.parameters?.charset||"utf-8")})):e.type==="application/octet-stream"?t=>t:t=>{if(e.type==="")try{if(t?.[0]===123)return VO(t)}catch{}return{contentType:e.type||"application/octet-stream",data:t}}}function Zue(e,t){return{[Symbol.asyncIterator](){let r=e[Symbol.asyncIterator]?e[Symbol.asyncIterator]():e[Symbol.iterator]();return{next(){let n=r.next();return n.then?n.then(s=>({value:t(s.value),done:s.done})):{value:t(n.value),done:n.done}},return(n){return r.return(n)},throw(n){return r.throw(n)}}}}}var rS,Li,Jc,yo,Aq,nS,yq,GO,qO,bq,$O,Oq,Xf,VO,Zf,en,KO,gq,Nq,Yue,Wue,Rq,zue,Wc=Oe(()=>{Ug();rS=L(tS()),Li=require("msgpackr"),Jc=require("cbor-x"),yo=require("zlib"),Aq=L(_e()),nS=require("stream");qr();yq=L(fi()),GO=L(se()),qO=L(M()),bq=L(require("yaml")),$O=L(bc()),Oq=GO.default.get(qO.CONFIG_PARAMS.SERIALIZATION_BIGINT)!==!1,Xf=Oq?Za:JSON.stringify,VO=Oq?Mg:JSON.parse,Zf={useRecords:!1,useToJSON:!0},en=new Map,KO=en;it.contentTypes=KO;(0,yq._assignPackageExport)("contentTypes",KO);en.set("application/json",{serializeStream:Xd,serialize:Xf,deserialize(e){return VO(e)},q:.8});gq=new Jc.Encoder(Zf);en.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new Jc.EncoderStream(Zf).end(e)},serialize:gq.encode,deserialize:gq.decode,q:1});en.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?nS.Readable.from((0,Li.encodeIter)(e,Zf)):(0,Li.pack)(e)},serialize:Li.pack,deserialize:Li.unpack,q:.9});en.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),(0,rS.toCsvStream)(e,e?.getColumns?.())},serialize(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),e&&!e[Symbol.iterator]&&(e=[e.toJSON?e.toJSON():e]),(0,rS.toCsvStream)(e,e?.getColumns?.())},q:.1});en.set("text/plain",{serialize(e){return e.toString()},deserialize(e){return e.toString()},q:.2});en.set("text/yaml",{serialize(e){return bq.stringify(e,{aliasDuplicateObjects:!1})},q:.7});en.set("text/event-stream",{serializeStream:a(function(e){return nS.Readable.from(Zue(e,this.serialize))},"serializeStream"),serialize:a(function(e){if(e.acknowledge&&e.acknowledge(),typeof e=="object"&&"value"in e&&e.timestamp&&(e={data:e.value,event:e.type,id:e.timestamp}),e.data||e.event){let t="";if(e.event&&(t+="event: "+e.event+`
|
|
32
|
-
`),e.data){let r=e.data;typeof r=="object"&&(r=
|
|
30
|
+
`)}catch{d=". Unable to get known hosts from github.com. Set your known hosts manually using set_ssh_known_hosts."}o&&await ge.appendFile(go,o);let _=await si(e);return _.message=`Added ssh key: ${r}${d}`,_}a(mde,"addSSHKey");async function Sde(e){let t=Rn.updateSSHKeyValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let{name:r,key:n}=e;Ft.trace("updating ssh key",r);let s=Ce.join(Sa,r+".key");if(!await ge.pathExists(s))throw new Error("Key does not exist. Use add_ssh_key");await ge.outputFile(s,n);let i=await si(e);return i.message=`Updated ssh key: ${r}`,i}a(Sde,"updateSSHKey");async function Tde(e){let t=Rn.deleteSSHKeyValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let{name:r}=e;Ft.trace("deleting ssh key",r);let n=Ce.join(Sa,r+".key"),s=Ce.join(Sa,"config");if(!await ge.pathExists(n))throw new Error("Key does not exist");let i=await ge.readFile(s,"utf8"),o=new RegExp(`#${r}[\\S\\s]*?IdentitiesOnly yes`,"g");i=i.replace(o,""),await ge.outputFile(s,i),ge.removeSync(n);let c=await si(e);return c.message=`Deleted ssh key: ${r}`,c}a(Tde,"deleteSSHKey");async function gde(e){let t=[];return await ge.pathExists(Sa)&&(await ge.readdir(Sa)).forEach(r=>{r!="known_hosts"&&r!="config"&&t.push({name:r.split(".")[0]})}),t}a(gde,"listSSHKeys");async function Rde(e){let t=Rn.setSSHKnownHostsValidator(e);if(t)throw Gt(t,t.message,qt.BAD_REQUEST);let{known_hosts:r}=e;await ge.outputFile(go,r);let n=await si(e);return n.message="Known hosts successfully set",n}a(Rde,"setSSHKnownHosts");async function Ade(e){return await ge.pathExists(go)?{known_hosts:await ge.readFile(go,"utf8")}:{known_hosts:null}}a(Ade,"getSSHKnownHosts");Object.assign(r$,{customFunctionsStatus:sde,getCustomFunctions:ide,getCustomFunction:ode,setCustomFunction:ade,dropCustomFunction:cde,addComponent:lde,dropCustomFunctionProject:ude,packageComponent:dde,deployComponent:_de,getComponents:fde,getComponentFile:Ede,setComponentFile:hde,dropComponent:pde,addSSHKey:mde,updateSSHKey:Sde,deleteSSHKey:Tde,listSSHKeys:gde,setSSHKnownHosts:Rde,getSSHKnownHosts:Ade})});var tS=N((UDe,T$)=>{"use strict";var iN=un(),hS=Vr(),ys=tm(),eE=ro(),oN=uc(),yde=zy(),bde=YH(),tE=xn(),pS=lf(),Ar=W(),Ode=ob(),Nde=pf(),Ide=Lb(),wde=Rf(),Cde=vb(),Dde=Bb(),Pde=Sm(),Lde=Fb(),aN=gm(),Ro=te(),Mde=Gk(),cN=Wb(),i$=Gu(),en=M(),o$=WF(),Ude=wu(),a$=_u(),c$=(km(),oe(Hf)),l$=wt(),or=rN(),vde=require("alasql"),u$=oS(),d$=kf(),Zu=Xs(),_$=(xc(),oe(Hc)),f$=MO(),{handleHDBError:An,hdb_errors:E$}=_e(),{addNodeBack:LDe,removeNodeBack:MDe}=(xc(),oe(Hc)),{HDB_ERROR_MSGS:Ur,HTTP_STATUS_CODES:Xf}=E$,z=new Map,h$="delete",Ta="insert",Ao="read",nl="update",Zf="describe",n$=eE.describeSchema.name,s$=eE.describeTable.name,p$={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},Bde={insert:!0,delete:!0,deleteRecord:!0,update:!0,updateData:!0,upsert:!0,upsertData:!0},Hde="catchup",xde="handleGetJob",kde="handleGetJobsByStartDate",mS={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},Fde=[ys.createTable.name,ys.createAttribute.name,ys.dropTable.name,ys.dropAttribute.name],m$={EXPORT_TO_S3:"export_to_s3",EXPORT_LOCAL:"export_local"},Z=class{static{a(this,"permission")}constructor(t,r){this.requires_su=t,this.perms=r}};z.set(iN.insert.name,new Z(!1,[Ta]));z.set(iN.update.name,new Z(!1,[nl]));z.set(iN.upsert.name,new Z(!1,[Ta,nl]));z.set(hS.searchByConditions.name,new Z(!1,[Ao]));z.set(hS.searchByHash.name,new Z(!1,[Ao]));z.set(hS.searchByValue.name,new Z(!1,[Ao]));z.set(hS.search.name,new Z(!1,[Ao]));z.set(ys.createSchema.name,new Z(!0,[]));z.set(ys.createTable.name,new Z(!0,[]));z.set(ys.createAttribute.name,new Z(!1,[Ta]));z.set(ys.dropSchema.name,new Z(!0,[]));z.set(ys.dropTable.name,new Z(!0,[]));z.set(ys.dropAttribute.name,new Z(!0,[]));z.set(eE.describeSchema.name,new Z(!1,[Ao]));z.set(eE.describeTable.name,new Z(!1,[Ao]));z.set(oN.deleteRecord.name,new Z(!1,[h$]));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(Ode.name,new Z(!0,[]));z.set(Nde.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(aN.setRoutes.name,new Z(!0,[]));z.set(aN.getRoutes.name,new Z(!0,[]));z.set(aN.deleteRoutes.name,new Z(!0,[]));z.set(l$.setConfiguration.name,new Z(!0,[]));z.set(Pde.clusterStatus.name,new Z(!0,[]));z.set(Lde.name,new Z(!0,[]));z.set(cN.getFingerprint.name,new Z(!0,[]));z.set(cN.setLicense.name,new Z(!0,[]));z.set(oN.deleteFilesBefore.name,new Z(!0,[]));z.set(oN.deleteAuditLogsBefore.name,new Z(!0,[]));z.set(i$.restart.name,new Z(!0,[]));z.set(i$.restartService.name,new Z(!0,[]));z.set(yde.name,new Z(!0,[]));z.set(bde.name,new Z(!0,[Ao]));z.set(Ude.systemInformation.name,new Z(!0,[]));z.set(l$.getConfiguration.name,new Z(!0,[]));z.set(u$.readTransactionLog.name,new Z(!0,[]));z.set(u$.deleteTransactionLogsBefore.name,new Z(!0,[]));z.set(d$.installModules.name,new Z(!0,[]));z.set(d$.auditModules.name,new Z(!0,[]));z.set(Zu.createCsr.name,new Z(!0,[]));z.set(Zu.signCertificate.name,new Z(!0,[]));z.set(Zu.listCertificates.name,new Z(!0,[]));z.set(Zu.addCertificate.name,new Z(!0,[]));z.set(Zu.removeCertificate.name,new Z(!0,[]));z.set(Zu.getKey.name,new Z(!0,[]));z.set(_$.addNodeBack.name,new Z(!0,[]));z.set(_$.removeNodeBack.name,new Z(!0,[]));z.set(a$.createTokens.name,new Z(!1,[]));z.set(a$.refreshOperationToken.name,new Z(!1,[]));z.set(c$.login.name,new Z(!1,[]));z.set(c$.logout.name,new Z(!1,[]));z.set(or.customFunctionsStatus.name,new Z(!0,[]));z.set(or.getCustomFunctions.name,new Z(!0,[]));z.set(or.getComponents.name,new Z(!0,[]));z.set(or.getComponentFile.name,new Z(!0,[]));z.set(or.setComponentFile.name,new Z(!0,[]));z.set(or.dropComponent.name,new Z(!0,[]));z.set(or.getCustomFunction.name,new Z(!0,[]));z.set(or.setCustomFunction.name,new Z(!0,[]));z.set(or.dropCustomFunction.name,new Z(!0,[]));z.set(or.addComponent.name,new Z(!0,[]));z.set(or.dropCustomFunctionProject.name,new Z(!0,[]));z.set(or.packageComponent.name,new Z(!0,[]));z.set(or.deployComponent.name,new Z(!0,[]));z.set(or.addSSHKey.name,new Z(!0,[]));z.set(or.updateSSHKey.name,new Z(!0,[]));z.set(or.deleteSSHKey.name,new Z(!0,[]));z.set(or.listSSHKeys.name,new Z(!0,[]));z.set(or.setSSHKnownHosts.name,new Z(!0,[]));z.set(or.getSSHKnownHosts.name,new Z(!0,[]));z.set(cN.getRegistrationInfo.name,new Z(!1,[]));z.set(tE.userInfo.name,new Z(!1,[]));z.set(eE.describeAll.name,new Z(!1,[]));z.set(xde,new Z(!1,[]));z.set(kde,new Z(!0,[]));z.set(Hde,new Z(!0,[]));z.set(mS.CSV_DATA_LOAD,new Z(!1,[Ta,nl]));z.set(mS.CSV_URL_LOAD,new Z(!1,[Ta,nl]));z.set(mS.CSV_FILE_LOAD,new Z(!1,[Ta,nl]));z.set(mS.IMPORT_FROM_S3,new Z(!1,[Ta,nl]));z.set(m$.EXPORT_TO_S3,new Z(!0,[]));z.set(m$.EXPORT_LOCAL,new Z(!0,[]));z.set(en.VALID_SQL_OPS_ENUM.DELETE,new Z(!1,[h$]));z.set(en.VALID_SQL_OPS_ENUM.SELECT,new Z(!1,[Ao]));z.set(en.VALID_SQL_OPS_ENUM.INSERT,new Z(!1,[Ta]));z.set(en.VALID_SQL_OPS_ENUM.UPDATE,new Z(!1,[nl]));T$.exports={verifyPerms:qde,verifyPermsAst:Gde,verifyBulkLoadAttributePerms:Vde};function Gde(e,t,r){if(Ro.isEmptyOrZeroLength(e))throw Ar.info("verify_perms_ast has an empty user parameter"),An(new Error);if(Ro.isEmptyOrZeroLength(t))throw Ar.info("verify_perms_ast has an empty user parameter"),An(new Error);if(Ro.isEmptyOrZeroLength(r))throw Ar.info("verify_perms_ast has a null operation parameter"),An(new Error);try{let n=new f$,s=new Mde(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw Ar.info("No schemas defined in verifyPermsAst(), will not continue."),An(new Error);let c=!!t.role.permission.super_user,l=i.includes("system");if(l&&p$[r])throw An(new Error,Ur.DROP_SYSTEM,Xf.FORBIDDEN);if(c&&!l)return null;let u=o$.getRolePermissions(t.role);t.role.permission=u,!c&&e instanceof vde.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(u));for(let _=0;_<i.length;_++){let E=s.getTablesBySchemaName(i[_]);E&&o.set(i[_],E)}let d=S$(t,r,o,n);return d||(o.forEach((_,E)=>{for(let f=0;f<_.length;f++){let h=s.getAttributesBySchemaTableName(E,_[f]),T=uN(t.role.permission,E,_[f]);lN(h,T,r,_[f],E,n)}}),n.getPermsResponse())}catch(n){throw An(n)}}a(Gde,"verifyPermsAst");function qde(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw Ar.info("null required parameter in verifyPerms"),An(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 f$;if(Ro.isEmptyOrZeroLength(e.hdb_user?.role)||Ro.isEmptyOrZeroLength(e.hdb_user?.role?.permission))return Ar.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&&Bde[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&&p$[r])throw An(new Error,Ur.DROP_SYSTEM,Xf.FORBIDDEN);if(l&&!d||u===!0&&(r===ys.createSchema.name||r===ys.dropSchema.name))return null;if(Fde.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 _=o$.getRolePermissions(e.hdb_user?.role);if(e.hdb_user?.role&&(e.hdb_user.role.permission=_),r===n$||r===s$){if(s===en.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(Ur.SCHEMA_PERM_ERROR(s));if(!_.super_user){if(r===n$&&(!_[s]||!_[s][Zf]))return c.handleInvalidItem(Ur.SCHEMA_NOT_FOUND(s));if(r===s$&&(!_[s]||!_[s].tables[i]||!_[s].tables[i][Zf]))return c.handleInvalidItem(Ur.TABLE_NOT_FOUND(s,i))}}let E=S$(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=$de(e),h=uN(e.hdb_user?.role?.permission,s,i);return lN(f,h,r,i,s,c,n),c.getPermsResponse()}a(qde,"verifyPerms");function S$(e,t,r,n,s){if(Ro.arrayHasEmptyValues([e,t,r]))throw Ar.info("hasPermissions has an invalid parameter"),An(new Error);let i=r.has("system"),o=e.role.permission;if(o.super_user&&(!i||z.get(t).requires_su))return null;if(!z.get(t))throw Ar.info(`operation ${t} not found.`),An(new Error,Ur.OP_NOT_FOUND(t),Xf.BAD_REQUEST);if(z.get(t)&&z.get(t).requires_su)return Ar.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;!Ro.isEmpty(s)&&f.includes(s)&&(f=[s]);for(let h=0;h<f.length;h++){let T=f[h],m=_[T];(m==null||m===!1)&&(Ar.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 Ar.error(f),Ar.error(E),An(E$.CHECK_LOGS_WRAPPER(f))}}}return r.size<2?n.getPermsResponse():null}a(S$,"hasPermissions");function lN(e,t,r,n,s,i,o){if(!e||!t)throw Ar.info("no attributes specified in checkAttributePerms."),An(new Error);let c=z.get(r).perms;if(!c||c==="")throw Ar.info(`no permissions found for ${r} in checkAttributePerms().`),An(new Error);if(Ro.isEmptyOrZeroLength(t))return Ar.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!==Ao)throw An(new Error,Ur.SYSTEM_TIMESTAMP_PERMS_ERR,Xf.FORBIDDEN);_[E]===!1&&(l[_.attribute_name]?l[_.attribute_name].push(E):l[_.attribute_name]=[E])}}else i.addInvalidItem(Ur.ATTR_NOT_FOUND(s,n,d),s,n)}let u=Object.keys(l);u.length>0&&i.addUnauthorizedAttributes(u,s,n,l)}a(lN,"checkAttributePerms");function $de(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){Ar.info(r)}return t}a($de,"getRecordAttributes");function uN(e,t,r){let n=new Map;if(Ro.isEmpty(e))return Ar.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{Ar.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(uN,"getAttributePermissions");function Vde(e,t,r,n,s,i,o){let c=new Set(i),l=uN(e,n,s);lN(c,l,t,s,n,o,r)}a(Vde,"verifyBulkLoadAttributePerms")});var nS=N((BDe,b$)=>{"use strict";b$.exports={evaluateSQL:n_e,processAST:y$,convertSQLToAST:A$,checkASTPermissions:R$};var Kde=un(),g$=require("util"),Yde=g$.callbackify(Kde.insert),Wde=Vr().search,jde=e0().update,zde=g$.callbackify(jde),Qde=r0().convertDelete,ga=require("alasql"),Jde=tS(),SS=W(),Xde=Ep(),Zde=te(),rE=M(),{hdb_errors:e_e,handleHDBError:dN}=_e(),{HTTP_STATUS_CODES:_N}=e_e;Xde(ga);var t_e=403,r_e="There was a problem performing this insert. Please check the logs and try again.",fN=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function n_e(e,t){let r=e.parsed_sql_object;if(!r){r=A$(e.sql);let n,s=r.ast.statements[0];if(s instanceof ga.yy.Insert?n=s.into.databaseid:s instanceof ga.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof ga.yy.Update||s instanceof ga.yy.Delete?n=s.table.databaseid:SS.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof ga.yy.Select)&&Zde.isEmptyOrZeroLength(n))return t("No schema specified",null)}y$(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(n_e,"evaluateSQL");function R$(e,t){let r;try{r=Jde.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(R$,"checkASTPermissions");function A$(e){let t=new fN;if(!e)throw dN(new Error,"The 'sql' parameter is missing from the request body",_N.BAD_REQUEST);try{let r=e.trim(),n=ga.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
|
|
31
|
+
`);throw n[1]?dN(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,_N.BAD_REQUEST):dN(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",_N.BAD_REQUEST)}return t}a(A$,"convertSQLToAST");function y$(e,t,r){try{let n=s_e;if(!e.bypass_auth&&!t.permissions_checked){let i=R$(e,t);if(i&&i.length>0)return r(t_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=Wde,s=t.ast.statements[0];break;case rE.VALID_SQL_OPS_ENUM.INSERT:n=i_e;break;case rE.VALID_SQL_OPS_ENUM.UPDATE:n=zde;break;case rE.VALID_SQL_OPS_ENUM.DELETE:n=Qde;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(y$,"processAST");function s_e(e,t){SS.info(e),t("unknown sql statement")}a(s_e,"nullFunction");function i_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=o_e(i,e.values)}catch(o){return r(o)}Yde(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(i_e,"convertInsert");function o_e(e,t){try{return t.map(r=>{if(e.length!==r.length)throw"number of values do not match number of columns in insert";let n={};return r.forEach((s,i)=>{if(s.columnid)throw"cannot use a column in insert value";"value"in s?n[e[i]]=s.value:n[e[i]]=ga.compile(`SELECT ${s.toString()} AS [${rE.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw SS.error(r),new Error(r_e)}}a(o_e,"createDataObjects")});var cS=N((xDe,M$)=>{"use strict";var hN=Vr(),a_e=nS(),c_e=IO(),{AsyncParser:l_e,Transform:u_e}=require("json2csv"),sE=require("stream"),Wn=te(),EN=require("fs-extra"),d_e=require("path"),bs=W(),{promisify:I$}=require("util"),nE=te(),{handleHDBError:ar,hdb_errors:__e}=_e(),{HDB_ERROR_MSGS:yn,HTTP_STATUS_CODES:cr}=__e,{streamAsJSON:f_e}=(Ug(),oe(UD)),{Upload:E_e}=require("@aws-sdk/lib-storage"),O$=["search_by_value","search_by_hash","sql","search_by_conditions"],N$=["json","csv"],w$="json",C$="csv",h_e="Successfully exported JSON locally.",p_e="Successfully exported CSV locally.",m_e=1e3,S_e=hN.searchByHash,T_e=hN.searchByValue,g_e=I$(a_e.evaluateSQL),R_e=I$(sE.finished);M$.exports={export_to_s3:O_e,export_local:A_e,toCsvStream:D$};async function A_e(e){bs.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=P$(e);if(!Wn.isEmpty(t))throw bs.error(t),ar(new Error,t,cr.BAD_REQUEST,void 0,void 0,!0);if(Wn.isEmpty(e.path))throw bs.error(yn.MISSING_VALUE("path")),ar(new Error,yn.MISSING_VALUE("path"),cr.BAD_REQUEST,void 0,void 0,!0);let r=(Wn.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(d_e.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=Wn.buildFolderPath(e.path,r);await y_e(e.path);let s=await L$(e);return await b_e(n,e.format,s)}a(A_e,"export_local");async function y_e(e){if(bs.trace("in confirmPath"),Wn.isEmptyOrZeroLength(e))throw ar(new Error,`Invalid path: ${e}`,cr.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await EN.stat(e)}catch(r){let n;throw r.code==="ENOENT"?n=`path '${e}' does not exist`:r.code==="EACCES"?n=`access to path '${e}' is denied`:n=r.message,bs.error(n),ar(new Error,n,cr.BAD_REQUEST,void 0,void 0,!0)}if(!t.isDirectory()){let r=`path '${e}' is not a directory, please supply a valid folder path`;throw bs.error(r),ar(new Error,r,cr.BAD_REQUEST,void 0,void 0,!0)}return!0}a(y_e,"confirmPath");async function b_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===w$){let n=EN.createWriteStream(e);return f_e(r).pipe(n),await R_e(n),{message:h_e,path:e}}else if(t===C$){let n=EN.createWriteStream(e),s=sE.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(d=>({label:d,value:d})));let c={objectMode:!0};return await new l_e(i,c).fromInput(s).toOutput(n).promise(!1),{message:p_e,path:e}}throw ar(new Error,yn.INVALID_VALUE("format"),cr.BAD_REQUEST)}a(b_e,"saveToLocal");async function O_e(e){if(!e.s3||Object.keys(e.s3).length===0)throw ar(new Error,yn.MISSING_VALUE("S3 object"),cr.BAD_REQUEST);if(Wn.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw ar(new Error,yn.MISSING_VALUE("aws_access_key_id"),cr.BAD_REQUEST);if(Wn.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw ar(new Error,yn.MISSING_VALUE("aws_secret_access_key"),cr.BAD_REQUEST);if(Wn.isEmptyOrZeroLength(e.s3.bucket))throw ar(new Error,yn.MISSING_VALUE("bucket"),cr.BAD_REQUEST);if(Wn.isEmptyOrZeroLength(e.s3.key))throw ar(new Error,yn.MISSING_VALUE("key"),cr.BAD_REQUEST);if(Wn.isEmptyOrZeroLength(e.s3.region))throw ar(new Error,yn.MISSING_VALUE("region"),cr.BAD_REQUEST);let t=P$(e);if(!Wn.isEmpty(t))throw ar(new Error,t,cr.BAD_REQUEST);bs.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await L$(e)}catch(l){throw bs.error(l),l}let n,s=await c_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===C$){i=e.s3.key+".csv";let l=D$(r,r.getColumns?.());l.on("error",u=>{throw u}),l.pipe(o)}else if(e.format===w$){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&&_%m_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 E_e({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(O_e,"export_to_s3");function D$(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 u_e(n,s);return r.pipe(i)}a(D$,"toCsvStream");function P$(e){if(bs.trace("in exportCoreValidation"),Wn.isEmpty(e.format))return"format missing";if(N$.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${N$.join(", ")}`;let t=e.search_operation.operation;if(Wn.isEmpty(t))return"search_operation.operation missing";if(O$.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${O$.join(", ")}`}a(P$,"exportCoreValidation");async function L$(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=T_e;break;case"search_by_hash":t=S_e;break;case"search_by_conditions":t=hN.searchByConditions;break;case"sql":t=g_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(L$,"getRecords")});var G$={};je(G$,{contentTypes:()=>gN,findBestSerializer:()=>RS,getDeserializer:()=>bo,registerContentHandlers:()=>RN,serialize:()=>aE,serializeMessage:()=>Wc});function N_e(e){try{return e?.[0]===123?TN(e):e}catch{return e}}function RN(e){e.register(w_e,{serializers:[{regex:/^application\/json$/,serializer:Zd},{regex:/^application\/cbor$/,serializer:a(function(t){return new sl.EncoderStream(oE).end(t)},"serializer")},{regex:/^application\/(x-)?msgpack$/,serializer:a(function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?gS.Readable.from((0,Mi.encodeIter)(t,oE)):(0,Mi.pack)(t)},"serializer")},{regex:/^text\/csv$/,serializer:a(function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),(0,TS.toCsvStream)(t)},"serializer")}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Mi.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,sl.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function RS(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 B$.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=v$&&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=RS(t);if(i.serializer.compressible===!1&&(n=!1),r.headers.set("Vary","Accept, Accept-Encoding"),r.headers.set("Content-Type",i.type),typeof e=="object"&&e&&(e[Symbol.iterator]||e[Symbol.asyncIterator])&&i.serializer.serializeStream){if(e.mapError){let c=e.getColumns;e=e.mapError(l=>(l.toJSON=()=>({error:l.name,message:l.message,...l.partialObject}),SN.default.warn?.(`Error serializing error ${t?.url||t}: ${l}`),l)),e.getColumns=c}let o=i.serializer.serializeStream(e,r);return n&&(r.headers.set("Content-Encoding","br"),o=o.pipe((0,yo.createBrotliCompress)({params:{[yo.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?yo.constants.BROTLI_MODE_TEXT:yo.constants.BROTLI_MODE_GENERIC,[yo.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>v$?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,yo.brotliCompress)(s,(c,l)=>{c?o(c):i(l)}))):s}function Wc(e,t){if(e?.contentType!=null&&e.data!=null)return e.data;if(!t)return iE(e);let r=t.serialize;if(r)return r(e);let n=RS(t);return r=t.serialize=n.serializer.serialize,r(e)}function C_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 P_e(e){return D_e.includes(e)}function L_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=L_e(e),n=r.type&&tn.get(r.type)?.deserialize||M_e(r);return t?s=>C_e(s).then(n):n}function M_e(e){return e.type.startsWith("text/")?(e.parameters?.charset&&!P_e(e.parameters.charset)&&SN.default.info(`Unknown Buffer encoding ${e.parameters.charset} in content-type. Proceeding anyways.`),t=>({contentType:e.type,data:t.toString(e.parameters?.charset||"utf-8")})):e.type==="application/octet-stream"?t=>t:t=>{if(e.type==="")try{if(t?.[0]===123)return TN(t)}catch{}return{contentType:e.type||"application/octet-stream",data:t}}}function U_e(e,t){return{[Symbol.asyncIterator](){let r=e[Symbol.asyncIterator]?e[Symbol.asyncIterator]():e[Symbol.iterator]();return{next(){let n=r.next();return n.then?n.then(s=>({value:t(s.value),done:s.done})):{value:t(n.value),done:n.done}},return(n){return r.return(n)},throw(n){return r.throw(n)}}}}}var TS,Mi,sl,yo,B$,gS,H$,pN,mN,x$,SN,k$,iE,TN,oE,tn,gN,U$,F$,I_e,w_e,v$,D_e,jc=Ne(()=>{Ug();TS=L(cS()),Mi=require("msgpackr"),sl=require("cbor-x"),yo=require("zlib"),B$=L(_e()),gS=require("stream");qr();H$=L(fi()),pN=L(se()),mN=L(M()),x$=L(require("yaml")),SN=L(bc()),k$=pN.default.get(mN.CONFIG_PARAMS.SERIALIZATION_BIGINT)!==!1,iE=k$?Za:JSON.stringify,TN=k$?Mg:JSON.parse,oE={useRecords:!1,useToJSON:!0},tn=new Map,gN=tn;it.contentTypes=gN;(0,H$._assignPackageExport)("contentTypes",gN);tn.set("application/json",{serializeStream:Zd,serialize:iE,deserialize(e){return TN(e)},q:.8});U$=new sl.Encoder(oE);tn.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new sl.EncoderStream(oE).end(e)},serialize:U$.encode,deserialize:U$.decode,q:1});tn.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?gS.Readable.from((0,Mi.encodeIter)(e,oE)):(0,Mi.pack)(e)},serialize:Mi.pack,deserialize:Mi.unpack,q:.9});tn.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),(0,TS.toCsvStream)(e,e?.getColumns?.())},serialize(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),e&&!e[Symbol.iterator]&&(e=[e.toJSON?e.toJSON():e]),(0,TS.toCsvStream)(e,e?.getColumns?.())},q:.1});tn.set("text/plain",{serialize(e){return e.toString()},deserialize(e){return e.toString()},q:.2});tn.set("text/yaml",{serialize(e){return x$.stringify(e,{aliasDuplicateObjects:!1})},q:.7});tn.set("text/event-stream",{serializeStream:a(function(e){return gS.Readable.from(U_e(e,this.serialize))},"serializeStream"),serialize:a(function(e){if(e.acknowledge&&e.acknowledge(),typeof e=="object"&&"value"in e&&e.timestamp&&(e={data:e.value,event:e.type,id:e.timestamp}),e.data||e.event){let t="";if(e.event&&(t+="event: "+e.event+`
|
|
32
|
+
`),e.data){let r=e.data;typeof r=="object"&&(r=iE(r)),t+="data: "+r+`
|
|
33
33
|
`}return e.id&&(t+="id: "+e.id+`
|
|
34
34
|
`),e.retry&&(t+="retry: "+e.retry+`
|
|
35
35
|
`),t+`
|
|
36
|
-
`}else return typeof e=="object"?`data: ${
|
|
36
|
+
`}else return typeof e=="object"?`data: ${iE(e)}
|
|
37
37
|
|
|
38
38
|
`:`data: ${e}
|
|
39
39
|
|
|
40
|
-
`},"serialize"),compressible:!1,q:.8});en.set("application/x-www-form-urlencoded",{deserialize(e){let t={};for(let[r,n]of new URLSearchParams(e))if(t.hasOwnProperty(r)){let s=t[r];Array.isArray(s)?s.push(n):t.key=[s,n]}else t[r]=n},serialize(e){let t=new URLSearchParams;for(let r in e)t.set(r,e);return t.toString()}});Nq={type:"application/json",serializeStream:Xd,serialize:Xf,deserialize:Kue,q:.5};en.set("*/*",Nq);en.set("",Nq);a(Kue,"tryJSONParse");a(YO,"registerContentHandlers");Yue=require("fastify-plugin"),Wue=Yue(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=sS(n.raw);s.type(c),s.serializer(function(l){let u;if(typeof l=="object"&&l&&(l[Symbol.iterator]||l[Symbol.asyncIterator])&&o.serializeStream){if(l.mapError){let d=l.getColumns;l=l.mapError(_=>(_.toJSON=()=>({error:_.name,message:_.message,..._.partialObject}),_)),l.getColumns=d}u=o.serializeStream}else u=o.serialize;return u(l,{headers:{set:a((d,_)=>{s.header(d,_)},"set")}})})}),r()},{name:"content-type-negotiation"});a(sS,"findBestSerializer");Rq=GO.default.get(qO.CONFIG_PARAMS.HTTP_COMPRESSIONTHRESHOLD);a(eE,"serialize");a(Yc,"serializeMessage");a(jue,"streamToBuffer");zue=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(Que,"isBufferEncoding");a(Jue,"parseContentType");a(bo,"getDeserializer");a(Xue,"deserializerUnknownType");a(Zue,"transformIterable")});var jO={};je(jO,{start:()=>cde});function ede(e){if(e.kind!==Le.Kind.OPERATION_DEFINITION&&e.kind!==Le.Kind.FRAGMENT_DEFINITION)throw new Ur(`Unexpected non-executable definition type ${e.kind}.`)}function wq(e){if(typeof e!="object"||e===null)throw new Mi("Request body must be an object.");if(!("query"in e))throw new Mi("Request body must contain a `query` field.");if(typeof e.query!="string")throw new Mi("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new Mi("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new Mi("Request body `operationName` field must be a string.")}function WO(e){return parseInt(e.value,10)}function Dq(e){return parseFloat(e.value)}function Pq(e,t,r){let n=r.get(e.name.value);return Lq(n)?Mq(n,t):{attribute:t,value:n}}function Lq(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function Mq(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],Lq(n)?Mq(n,t):{attribute:t,value:n}))}function tde(e,t,r){switch(t=[...t,e.name.value],e.value.kind){case Le.Kind.NULL:return{attribute:t,value:null};case Le.Kind.INT:return{attribute:t,value:WO(e.value)};case Le.Kind.FLOAT:return{attribute:t,value:Dq(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:t,value:e.value.value};case Le.Kind.VARIABLE:return Pq(e.value,t,r);case Le.Kind.OBJECT:return Uq(e.value,t,r);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Ur(`Value type, ${e.value.kind}, is not supported.`)}}function Uq(e,t,r){return e.fields.flatMap(n=>tde(n,t,r))}function rde(e,t){switch(e.value.kind){case Le.Kind.NULL:return{attribute:e.name.value,value:null};case Le.Kind.INT:return{attribute:e.name.value,value:WO(e.value)};case Le.Kind.FLOAT:return{attribute:e.name.value,value:Dq(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Le.Kind.VARIABLE:return Pq(e.value,e.name.value,t);case Le.Kind.OBJECT:return Uq(e.value,[e.name.value],t);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Ur(`Argument type, ${e.value.kind}, is not supported.`)}}function nde(e,t){return e.flatMap(r=>rde(r,t))}function iS(e,t){return e.selections.flatMap(r=>{switch(r.kind){case Le.Kind.FIELD:return r;case Le.Kind.FRAGMENT_SPREAD:{let n=r.name.value,s=t.get(n);if(s==null)throw new Ur(`Fragment \`${n}\` not found.`);return iS(s.selectionSet,t)}case Le.Kind.INLINE_FRAGMENT:return iS(r.selectionSet,t)}})}function vq(e,t){return iS(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:vq(r.selectionSet,t)}:r.name.value)}async function sde(e,t,r,n){let i=wi.getMatch(e.name.value,"graphql").Resource,o={select:vq(e.selectionSet,r),conditions:nde(e.arguments,t)},c=[];n.authorize=!0;for await(let l of i.search(o,n))c.push(l);return[e.name.value,c]}function Bq(e){switch(e.kind){case Le.Kind.NULL:return null;case Le.Kind.INT:return WO(e);case Le.Kind.FLOAT:return parseFloat(e.value);case Le.Kind.STRING:case Le.Kind.BOOLEAN:return e.value;case Le.Kind.OBJECT:return e.fields.reduce((t,r)=>({[r.name.value]:Bq(r.value),...t}),{});case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Ur(`Value type, ${e.kind}, is not supported.`)}}function ide(e,t){let r=new Map;for(let n of e){let s=n.variable.name.value,i=t?.[s];if(i===void 0&&n.defaultValue!==void 0&&(i=Bq(n.defaultValue)),n.type.kind===Le.Kind.NON_NULL_TYPE&&!(s in t)&&i===void 0)throw new Ur(`Variable $${s} is required, but not provided.`);r.set(n.variable.name.value,i??null)}return r}async function ode(e,t,r,n){if(e.operation===Le.OperationTypeNode.SUBSCRIPTION)throw new Ur("Subscriptions are not supported.");if(e.operation===Le.OperationTypeNode.MUTATION)throw new Ur("Mutations are not supported yet.");let s=ide(e.variableDefinitions,t),i=await Promise.all(iS(e.selectionSet,r).map(c=>sde(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function Cq({query:e,variables:t={},operationName:r},n){let s=Le.parse(e),i=new Map,o=new Map;for(let u of s.definitions)if(ede(u),u.kind===Le.Kind.FRAGMENT_DEFINITION)o.set(u.name.value,u);else{if(u.name===void 0&&s.definitions.length>1)throw new Ur("Unnamed operations are only allowed when there is a single operation in the document.");let d=u.name?.value??"Unnamed Query";if(i.has(d))throw new Ur(`Duplicate operation definition: ${d}`);i.set(d,u)}let c;if(r==null)if(i.size===1)c=i.entries().next().value[1];else throw new Ur("Operation name is required when there are multiple operations in the document.");else if(c=i.get(r),c==null)throw new Ur(`Operation \`${r}\` not found.`);let l=await ode(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function ade(e){switch(e.method){case"GET":{let t=new URLSearchParams(e.url.split("?")[1]),r={};for(let[n,s]of t)r[n]=n==="variables"||n==="extensions"?JSON.parse(s):s;return wq(r),Cq(r,e)}case"POST":{let r=await bo(e.headers.get("content-type"),!0)(e._nodeRequest);return wq(r),Cq(r,e)}default:throw new Mi("Method Not Allowed",405,{Allow:"GET, POST"})}}function cde(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await ade(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof Mi)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json",...n.headers}};if(n instanceof Le.GraphQLError)return{status:200,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/json"}};if(n instanceof Ur)return{status:200,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};break}default:logger.info(`Unsupported accept header, ${s}, defaulting to application/graphql-response+json`);case"application/graphql-response+json":{if(n instanceof Mi)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json",...n.headers}};if(n instanceof Le.GraphQLError)return{status:400,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Ur)return{status:400,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};break}}throw n}})}var Le,Ur,Mi,Hq=Oe(()=>{Le=L(require("graphql"));Wc();eu();a(ede,"assertExecutableDefinitionNode");a(wq,"assertRequestParams");a(WO,"processIntValueNode");a(Dq,"processFloatValueNode");a(Pq,"processVariableNode");a(Lq,"isObject");a(Mq,"transformObjectIntoQueryCondition");a(tde,"processObjectFieldNode");a(Uq,"processObjectValueNode");a(rde,"processArgumentNode");a(nde,"buildConditionsQuery");a(iS,"fillInFragments");a(vq,"buildSelectQuery");a(sde,"processFieldNode");a(Bq,"processConstValueNode");a(ide,"resolveVariables");a(ode,"executeOperation");a(Cq,"resolver");Ur=class extends Error{static{a(this,"GraphQLQueryingError")}},Mi=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a(ade,"graphqlQueryingHandler");a(cde,"start")});var zO={};je(zO,{start:()=>Fq,startOnMainThread:()=>dde});function Fq({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,xq.parseDocument)(r.toString(),{simpleKeys:!0}).toJSON();for(let s in n){let i=n[s];i.permission||(i={permission:i},i.permission.access&&(i.access=i.permission.access,delete i.permission.access));for(let o in i.permission){if(lde.includes(o))continue;let c=i.permission[o];c.tables||(i.permission[o]=c={tables:c});for(let l in c.tables){let u=c.tables[l];if(u.read=!!u.read,u.insert=!!u.insert,u.update=!!u.update,u.delete=!!u.delete,u.attributes){let d=[];for(let _ in u.attributes){let E=u.attributes[_];E.attribute_name=_,d.push(E)}u.attribute_permissions=d,delete u.attributes}if(u.attribute_permissions){if(!Array.isArray(u.attribute_permissions))throw new Error("attribute_permissions must be an array if defined");for(let d of u.attribute_permissions)d.read=!!d.read,d.insert=!!d.insert,d.update=!!d.update}else u.attribute_permissions=null}}i.role=i.id=s,await ude(i)}}}async function ude(e){let t=ut().system.hdb_role;for await(let r of t.search([{attribute:"role",value:e.role}])){let{__createdtime__:n,__updatedtime__:s,...i}=r;return(0,kq.isEqual)(i,e)?void 0:(e.id=r.id,(0,oS.alterRole)(e))}return(0,oS.addRole)(e)}var oS,xq,kq,lde,dde,Gq=Oe(()=>{Pe();oS=L(lf()),xq=require("yaml"),kq=require("lodash"),lde=["super_user","cluster_user","structure_user"];a(Fq,"start");a(ude,"ensureRole");dde=Fq});async function aS(e){let t=(0,Vq.pathToFileURL)(e).toString();return _de?(tE||(tE=fde(hde)),(await(await tE).import(t)).namespace):import(t)}async function fde(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),tE=new Compartment({console,Math,Date,fetch:Ede,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,$q.extname)(r)||(r+=".js"),r)},importHook:a(async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Lr,tables:jn,databases:We})}};let n=await(0,qq.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),tE}function Ede(e,t){let r=typeof e=="string"||e.url;if(new URL(r).protocol!="https")throw new Error("Only https is allowed in fetch");return fetch(e,t)}function hde(){return{Resource:Lr,tables:jn}}var qq,$q,Vq,_de,tE,QO=Oe(()=>{Vs();Pe();qq=require("fs/promises"),$q=require("path"),Vq=require("url"),_de=!1;a(aS,"secureImport");a(fde,"getCompartment");a(Ede,"secureOnlyFetch");a(hde,"getGlobalVars")});var XO={};je(XO,{handleFile:()=>pde});async function pde(e,t,r,n){let s=new Map,i=await aS(r);c(i.default)&&n.set((0,JO.dirname)(t),i.default),o(i,(0,JO.dirname)(t));function o(l,u){for(let d in l){let _=l[d];c(_)?n.set(u+"/"+d,_):typeof _=="object"&&o(_,u+"/"+d)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var JO,Kq=Oe(()=>{QO();JO=require("path");a(pde,"handleFile")});var eN={};je(eN,{start:()=>mde});function mde({resources:e}){e.set("login",ZO),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var ZO,Yq=Oe(()=>{Vs();a(mde,"start");ZO=class extends Lr{static{a(this,"Login")}static async get(t,r,n){}static async post(t,r,n){let{username:s,password:i,redirect:o}=r;return{data:await n.login(s,i)}}}});function rN(e,t,r,n,s,i,o,c){let l=e[0];if(t==="or"){let _=u(l);for(let f=1;f<e.length;f++){let h=e[f],T=u(h);_=_.concat(T)}let E=new Set;return _.filter(f=>{let h=f.key??f;return E.has(h)?!1:(E.add(h),!0)})}else{let _=u(l),E=d(e.slice(1),!0,l.estimated_count);return E.length>0?o(_,E):_}function u(_){return _.conditions?rN(_.conditions,_.operator,r,n,s,i,o,c):zu(_,n,_.descending||s.reverse===!0,r,s.allowFullScan,c)}a(u,"executeCondition");function d(_,E,f){return _.map((h,T)=>{if(h.conditions){let S=h.operator==="or",b=d(h.conditions,!S,f);return S?(I,B)=>b.some(H=>H(I,B)):(I,B)=>b.every(H=>H(I,B))}let m=(h.attribute||h[0])===r.primaryKey,g=sE(h,r,i,c,m,f);return E&&T<_.length-1&&f&&(f=Nde(r.primaryStore,h.estimated_count,f)),g}).filter(Boolean)}a(d,"mapConditionsToFilters")}function zu(e,t,r,n,s,i){let o=e[0]??e.attribute,c=e[1]??e.value,l=e.comparator;if(c===void 0&&l!=="sort")throw new On.ClientError(`Search condition for ${o} must have a value`);if(Array.isArray(o)){let S=o[0],b=vi(n.attributes,S);if(b.relationship){if(o.length<2)throw new On.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let I=b.definition?.tableClass||b.elements?.definition?.tableClass,B=new Map,H=zu({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,I,s,B);if(b.relationship.to){i[o[0]]=B;let X=!!vi(I.attributes,b.relationship.to)?.elements;H=Ade(H,b,I.primaryStore,X,B)}if(b.relationship.from){let X=a(Y=>(Y?.key!==void 0&&(Y=Y.key),zu({attribute:b.relationship.from,value:Y},t,r,n,s,B)),"searchEntry");b.elements?(i[o[0]]=B,H=yde(H,b,I.primaryStore,B,X)):H=H.flatMap(X)}return H}else if(o.length===1)o=o[0];else throw new On.ClientError("Unable to query by attribute "+JSON.stringify(o))}let u,d,_,E;c instanceof Date&&(c=c.getTime());let f;switch(nN[l]||l){case"lt":u=!0,d=c;break;case"le":u=!0,d=c,_=!0;break;case"gt":u=c,E=!0;break;case"ge":u=c;break;case"prefix":Array.isArray(c)?c[c.length-1]!=null&&(c=c.concat(null)):c=[c,null],u=c,d=c.slice(0),d[d.length-1]=Ui.MAXIMUM_KEY;break;case"starts_with":u=c.toString(),d=c+"\uFFFF";break;case"between":case"gele":case"gelt":case"gtlt":case"gtle":u=c[0],u instanceof Date&&(u=u.getTime()),d=c[1],d instanceof Date&&(d=d.getTime()),_=l==="gele"||l==="gtle"||l==="between",E=l==="gtlt"||l==="gtle";break;case"equals":case void 0:u=c,d=c,_=!0;break;case"ne":if(c===null){u=c,E=!0;break}case"sort":case"contains":case"ends_with":u=!0,f=!0;break;default:throw new On.ClientError(`Unknown query comparator "${l}"`)}let h,T=o===n.primaryKey||o==null;if(typeof u=="string"&&u.length>bs.MAX_SEARCH_KEY_LENGTH&&(u=u.slice(0,bs.MAX_SEARCH_KEY_LENGTH)+bs.OVERFLOW_MARKER,E=!1,h=sE(e,n,null,i,T)),typeof d=="string"&&d.length>bs.MAX_SEARCH_KEY_LENGTH&&(d=d.slice(0,bs.MAX_SEARCH_KEY_LENGTH)+bs.OVERFLOW_MARKER,_=!0,h=h??sE(e,n,null,i,T)),r){let S=u;u=d,d=S,S=!E,E=!_,_=S}let m=T?n.primaryStore:n.indices[o];if(!m||m.isIndexing||f||c===null&&!m.indexNulls){if(s===!1&&!m)throw new On.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&f)throw new On.ClientError(`Can not use ${l||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(m?.isIndexing)throw new On.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&m&&!m.indexNulls)throw new On.ClientError(`"${o}" is not indexed for nulls, index needs to be rebuilt to search for nulls, can not search for this attribute`,400);if(h=h??sE(e,n,null,i,T),!h)throw new On.ClientError(`Unknown search operator ${e.comparator}`)}let g={start:u,end:d,inclusiveEnd:_,exclusiveStart:E,values:!0,versions:T,transaction:t,reverse:r};if(T){let S=m.getRange(g).map(h?function({key:b,value:I}){return this?.isSync?I&&h(I)?b:Ra.SKIP:new Promise((B,H)=>setImmediate(()=>{try{B(I&&h(I)?b:Ra.SKIP)}catch(X){H(X)}}))}:b=>b.value==null&&!(b.metadataFlags&(Os|ya))?Ra.SKIP:b);return S.hasEntries=!0,S}else return m?m.getRange(g).map(h?function({key:S,value:b}){let I;return typeof S=="string"&&S.length>bs.MAX_SEARCH_KEY_LENGTH?I=n.primaryStore.get(b):I={[o]:S},this.isSync?h(I)?b:Ra.SKIP:new Promise((B,H)=>setImmediate(()=>{try{B(h(I)?b:Ra.SKIP)}catch(X){H(X)}}))}:({value:S})=>S):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:S,value:b}){return this.isSync?b&&h(b)?S:Ra.SKIP:new Promise((I,B)=>setImmediate(()=>{try{I(b&&h(b)?S:Ra.SKIP)}catch(H){B(H)}}))})}function vi(e,t){if(Array.isArray(t))if(t.length>1){let r=vi(e,t[0]),n=(r?.definition?.tableClass||r?.elements?.definition?.tableClass)?.attributes??r?.properties;return n?vi(n,t.slice(1)):void 0}else t=t.toString();else typeof t!="string"&&(t=t.toString());return e.find(r=>r.name===t)}function Ade(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i;return s.hasMappings=!0,{next(){if(!i){let c=t.relationship.to,l=a((u,d)=>{let _=s.get(u);_?_.push(d):s.set(u,_=[d])},"add_entry");for(let u of e){let d=u.value??r.get(u.key??u),_=d?.[c];if(_!=null&&!s.filters?.some(E=>!E(d)))if(n)for(let E=0;E<_.length;E++)l(_[E],u);else l(_,u)}return i=s.keys()[Symbol.iterator](),this.next()}let o=i.next();return o.done?o:{value:o.value}},return(){if(i?.return)return i.return()}}}})}function yde(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i,o,c=new Set;return{next(){let l;if(o)for(;l=o.next(),!l.done;){let u=l.value;if(!c.has(u))return c.add(u),l}if(!i){let u=new Set;n.fromRecord=d=>d[t.relationship.from]?.filter?.(_=>u.has(_));for(let d of e){if(n.filters){let _=r.get(d);if(n.filters.some(E=>!E(_)))continue}u.add(d)}return i=u[Symbol.iterator](),this.next()}do{let u=i.next();return u.done?u:(o=s(u.value)[Symbol.iterator](),this.next())}while(!0)},return(){return o?.return?.()},throw(){return o?.throw?.()}}}})}function sE(e,t,r,n,s,i){let o=e.comparator,c=e[0]??e.attribute,l=e[1]??e.value;if(Array.isArray(c)){if(c.length===0)return()=>!0;if(c.length===1)c=c[0];else if(c.length>1){let d=c[0],_=vi(t.attributes,d),E=_.definition?.tableClass||_.elements.definition?.tableClass,f=n?.[d],h=sE({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:o},E,r,f?.[d]?.joined,c[1]===E.primaryKey,i);if(!h)return;if(f){f.filters||(f.filters=[]),f.filters.push(h);return}let T=t.propertyResolvers?.[d],m,g=a((S,b)=>{let I,B;if(T){if(T.from&&h.idFilter){if(!m)if(h.idFilter.idSet?.size===1){for(let X of h.idFilter.idSet)e={attribute:T.from,value:X};m=u(T.from,h.idFilter,!0,!0)}else m=u(T.from,h.idFilter,!1,!0);let H=m(S);return m.idFilter&&(g.idFilter=m.idFilter),H}B=T(S,r,b),I=B?.value}else I=S[d];return I?Array.isArray(I)?I.some(h):h(I,B):!1},"recordFilter");return g}}switch(l instanceof Date&&(l=l.getTime()),nN[o]||o){case bs.SEARCH_TYPES.EQUALS:case void 0:return u(c,d=>d===l,!0);case"contains":return u(c,d=>d?.toString().includes(l));case"ends_with":return u(c,d=>d?.toString().endsWith(l));case"starts_with":return u(c,d=>typeof d=="string"&&d.startsWith(l),!0);case"prefix":return Array.isArray(l)?l[l.length-1]==null&&(l=l.slice(0,-1)):l=[l],u(c,d=>{if(!Array.isArray(d))return!1;for(let _=0,E=l.length;_<E;_++)if(d[_]!==l[_])return!1;return!0},!0);case"between":return l[0]instanceof Date&&(l[0]=l[0].getTime()),l[1]instanceof Date&&(l[1]=l[1].getTime()),u(c,d=>(0,Ui.compareKeys)(d,l[0])>=0&&(0,Ui.compareKeys)(d,l[1])<=0,!0);case"gt":return u(c,d=>(0,Ui.compareKeys)(d,l)>0);case"ge":return u(c,d=>(0,Ui.compareKeys)(d,l)>=0);case"lt":return u(c,d=>(0,Ui.compareKeys)(d,l)<0);case"le":return u(c,d=>(0,Ui.compareKeys)(d,l)<=0);case"ne":return u(c,d=>(0,Ui.compareKeys)(d,l)!==0,!1,!0);case"sort":return()=>!0;default:throw new On.ClientError(`Unknown query comparator "${o}"`)}function u(d,_,E,f){let h;E=E&&!s&&t?.indices[d]&&i>3,E&&(e.estimated_count==null&&lS(t)(e),h=e.estimated_count>>4,(isNaN(h)||h>=i)&&(E=!1));let T=0,m=3;function g(S){let b=S[d],I;if(typeof b!="object"||!b||f?I=_(b):Array.isArray(b)?I=b.some(_):b instanceof Date&&(I=_(b.getTime())),E&&(m++,!I&&!g.idFilter&&++T/m*(i-m)>h)){let B=zu(e,r.transaction.getReadTxn(),!1,t).map(Qu),H=new Set(B);g.idFilter=X=>H.has(Qu(X)),g.idFilter.idSet=H}return I}return a(g,"recordFilter"),s&&(g.idFilter=_),g}a(u,"attributeComparator")}function lS(e){function t(r){if(r.estimated_count===void 0){if(r.conditions){let s;if(r.operator==="or"){s=0;for(let i of r.conditions)t(i),s+=i.estimated_count}else{s=1/0;for(let i of r.conditions)t(i),s=isFinite(s)?s*i.estimated_count/Oo(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=nN[n]||n,n===bs.SEARCH_TYPES.EQUALS||!n){let s=r[0]??r.attribute;if(s==null||s===e.primaryKey)r.estimated_count=1;else if(Array.isArray(s)&&s.length>1){let i=vi(e.attributes,s[0]),o=i.definition?.tableClass||i.elements.definition?.tableClass,c=lS(o)({value:r.value,attribute:s.length>2?s.slice(1):s[1],comparator:"equals"}),l=e.indices[i.relationship.from];r.estimated_count=c+(l?c*Oo(e.indices[i.relationship.from])/(Oo(o.primaryStore)||1):c)}else{let i=e.indices[s];r.estimated_count=i?i.getValuesCount(r[1]??r.value):1/0}}else if(n==="contains"||n==="ends_with"||n==="ne"){let s=r[0]??r.attribute,i=e.indices[s];r.value===null&&n==="ne"?r.estimated_count=Oo(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=gde*Oo(e.primaryStore)+1:n==="between"?r.estimated_count=Tde*Oo(e.primaryStore)+1:n==="sort"?r.estimated_count=Oo(e.primaryStore)+1:r.estimated_count=Sde*Oo(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function uS(e){if(e)if(Aa=e,Wu.lastIndex=0,bde.test(e))try{let t=rE(new ju,"");if(bn!==Aa.length)throw new SyntaxError("Unable to parse query, unexpected end of query");return t}catch(t){throw t.statusCode=400,t.message=`Unable to parse query, ${t.message} at position ${bn} in '${Aa}'`,t}else return new URLSearchParams(e)}function rE(e,t){let r=Wu,n,s,i,o,c,l=decodeURIComponent,u;for(;n=r.exec(Aa);){bn=r.lastIndex;let[,d,_]=n;if(o){if(d)throw new SyntaxError(`expected operator, but encountered '${d}'`);o=!1,c=!1}else c=!0;let E;switch(_){case"=":if(s!=null){if(d.length<=2)i=d;else throw new SyntaxError(`invalid FIQL operator ${d}`);l=Wq}else{if(l=decodeURIComponent,i="equals",!d)throw new SyntaxError("attribute must be specified before equality comparator");s=nE(d)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=Rde[_],l=tN[i]?Wq:decodeURIComponent,!d)throw new SyntaxError(`attribute must be specified before comparator ${_}`);s=nE(d);break;case"&=":case"|=":case"|":case"&":case"":case void 0:if(s==null){if(s===void 0)throw t?new SyntaxError(`expected '${t}', but encountered ${_[0]?"'"+_[0]+"'":"end of string"}}`):new SyntaxError(`no comparison specified before ${_?"'"+_+"'":"end of string"}`)}else{if(!e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");let h={comparator:i,attribute:s||null,value:l(d)};if(i==="eq"&&jq(h,d),s===""){let T=e.conditions[e.conditions.length-1];T.chainedConditions=T.chainedConditions||[],T.chainedConditions.push(h),T.operator=u}else cS(e,u),e.conditions.push(h)}_==="&"?(u="and",s=void 0):_==="|"?(u="or",s=void 0):_==="&="?(u="and",s=""):_==="|="&&(u="or",s="");break;case",":if(e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");e.push(nE(d)),s=void 0;break;case"(":Wu.lastIndex=bn;let f=rE(d?[]:new ju,")");switch(d){case"":cS(e,u),e.conditions.push(f);break;case"limit":switch(f.length){case 1:e.limit=+f[0];break;case 2:e.offset=+f[0],e.limit=f[1]-e.offset;break;default:throw new SyntaxError("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(f[0])&&f.length===1&&!f[0].name?(e.select=f[0],e.select.asArray=!0):f.length===1?e.select=f[0]:f.length===2&&f[1]===""?e.select=f.slice(0,1):e.select=f;break;case"group-by":throw new SyntaxError("group by is not implemented yet");case"sort":e.sort=zq(f);break;default:throw new SyntaxError(`unknown query function call ${d}`)}Aa[bn]===","?r.lastIndex=++bn:o=!0,s=null;break;case"{":if(e.conditions)throw new SyntaxError("property sets are not allowed in a queries");if(!d)throw new SyntaxError("property sets must have a defined parent property name");Wu.lastIndex=bn,E=rE([],"}"),E.name=d,e.push(E),Aa[bn]===","?r.lastIndex=++bn:o=!0;break;case"[":Wu.lastIndex=bn,d?(E=rE(new ju,"]"),E.name=d):E=rE(e.conditions?new ju:[],"]"),e.conditions?(cS(e,u),e.conditions.push(E),s=null):e.push(E),Aa[bn]===","?r.lastIndex=++bn:o=!0;break;case")":case"]":case"}":if(t===_[0]){if(e.conditions){if(s){let h={comparator:i||"equals",attribute:s,value:l(d)};i==="eq"&&jq(h,d),cS(e,u),e.conditions.push(h)}else if(d)throw new SyntaxError("no attribute or comparison specified")}else(d||e.length>0&&c)&&e.push(nE(d));return e}else throw t?new SyntaxError(`expected '${t}', but encountered '${_[0]}'`):new SyntaxError(`unexpected token '${_[0]}'`);default:throw new SyntaxError(`unexpected operator '${_}'`)}if(t!==")"&&(r=s?Ode:Wu,r.lastIndex=bn),bn===Aa.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function cS(e,t){if(e.conditions.length>0)if(e.operator){if(e.operator!==t)throw new SyntaxError("Can not mix operators within a condition grouping")}else e.operator=t}function nE(e){return e.indexOf(".")>-1?e.split(".").map(nE):decodeURIComponent(e)}function Wq(e){if(e==="null")return null;if(e.indexOf(":")>-1){let[t,r]=e.split(":");if(t==="number")return r[0]==="$"?parseInt(r.slice(1),36):+r;if(t==="boolean")return r==="true";if(t==="date")return new Date(isNaN(r)?decodeURIComponent(r):+r);if(t==="string")return decodeURIComponent(r);throw new On.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function jq(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new On.ClientError("wildcard can only be used at the end of a string")}function zq(e){let t=Qq(e[0]);return e.length>1&&(t.next=zq(e.slice(1))),t}function Qq(e){if(Array.isArray(e)){let t=Qq(e[0]);return e[0]=t.attribute,t.attribute=e,t}if(typeof e=="string")switch(e[0]){case"-":return{attribute:e.slice(1),descending:!0};case"+":return{attribute:e.slice(1),descending:!1};default:return{attribute:e,descending:!1}}throw new SyntaxError(`Unknown sort type ${e}`)}function Qu(e){return Array.isArray(e)?e.join("\0"):e}function Oo(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function Nde(e,t,r){return t*r/Oo(e)}var On,bs,Ui,Ra,Sde,Tde,gde,Rde,tN,nN,bde,Wu,Ode,bn,Aa,ju,Xc,iE=Oe(()=>{On=L(_e()),bs=L(Bt()),Ui=require("ordered-binary"),Ra=require("lmdb");oE();Sde=.3,Tde=.1,gde=.05,Rde={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},tN={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(rN,"executeConditions");a(zu,"searchByIndex");a(vi,"findAttribute");a(Ade,"joinTo");a(yde,"joinFrom");nN={eq:"equals",greater_than:"gt",greaterThan:"gt",greater_than_equal:"ge",greaterThanEqual:"ge",less_than:"lt",lessThan:"lt",less_than_equal:"le",lessThanEqual:"le",not_equal:"ne",notEqual:"ne",equal:"equals",sw:"starts_with",startsWith:"starts_with",ew:"ends_with",endsWith:"ends_with",ct:"contains",">":"gt",">=":"ge","<":"lt","<=":"le","...":"between"};a(sE,"filterByType");a(lS,"estimateCondition");bde=/[()[\]|!<>.]|(=\w*=)/,Wu=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,Ode=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(uS,"parseQuery");a(rE,"parseBlock");a(cS,"assignOperator");a(nE,"decodeProperty");a(Wq,"typedDecoding");a(jq,"wildcardDecoding");a(zq,"toSortObject");a(Qq,"toSortEntry");ju=class{static{a(this,"Query")}constructor(){this.conditions=[]}[Symbol.iterator](){return this.conditions[Symbol.iterator]()}get(t){for(let r=0;r<this.conditions.length;r++){let n=this.conditions[r];if(n.attribute===t)return n.value}}};a(Qu,"flattenKey");a(Oo,"estimatedEntryCount");a(Nde,"intersectionEstimate");Xc=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});function t$(e){let t={openapi:Ide,info:{title:"HarperDB HTTP REST interface",version:(0,e$.version)()},paths:{},components:{schemas:{},securitySchemes:{basicAuth:{type:"http",scheme:"basic"},bearerAuth:{type:"http",scheme:"bearer",bearerFormat:"JWT"}}}},r=[{basicAuth:[],bearerAuth:[]}];for(let[,n]of e){if(!n.path||n.Resource.isError)continue;let{path:s}=n,i=s.split("/").slice(-1),{attributes:o,primaryKey:c,prototype:l}=n.Resource;if(c=c??"id",!c)continue;let u={},d=[];if(o)for(let{type:b,name:I,elements:B,relationship:H,definition:X}of o){if(H)b==="array"?u[I]={type:"array",items:{$ref:ba+B.type}}:u[I]={$ref:ba+b};else{let Y=X??B?.definition;if(Y){if(!t.components.schemas[Y.type]){let V={};Y.properties.forEach(ne=>{V[ne.name]=new aN(sN[ne.type],ne.type)}),t.components.schemas[Y.type]=new Zq(V)}b==="array"?u[I]={type:"array",items:{$ref:ba+Y.type}}:u[I]={$ref:ba+Y.type}}else b==="array"?B.type==="Any"||B.type=="ID"?u[I]={type:"array",items:{format:B.type}}:u[I]={type:"array",items:new aN(sN[B.type],B.type)}:b==="Any"||b=="ID"?u[I]={format:b}:u[I]=new aN(sN[b],b)}d.push(new cN(I,"query",u[I]))}let _=Object.keys(u),E=new cN(c,"path",{format:"ID"});E.required=!0,E.description="primary key of record";let f=new cN("property","path",{enum:_});f.required=!0,t.components.schemas[i]=new Zq(u);let h=l.post!==Resource.prototype.post||l.update,T=typeof l.put=="function",m=typeof l.get=="function",g=typeof l.delete=="function",S="/"+s+"/";h&&(t.paths[S]={},t.paths[S].post=new wde(i,r,"create a new record auto-assigning a primary key")),m&&(t.paths[S]||(t.paths[S]={}),t.paths[S].get=new iN(d,r,{200:new oN({$ref:ba+i})},"search for records by the specified property name and value pairs")),g&&(t.paths[S]||(t.paths[S]={}),t.paths[S].delete=new Xq(d,r,"delete all the records that match the provided query",{204:new Jq})),S="/"+s+"/{"+c+"}",m&&(t.paths[S]={},t.paths[S].get=new iN([E],r,{200:new oN({$ref:ba+i})},"retrieve a record by its primary key")),T&&(t.paths[S]||(t.paths[S]={}),t.paths[S].put=new Cde([E],r,i,"create or update the record with the URL path that maps to the record's primary key")),g&&(t.paths[S]||(t.paths[S]={}),t.paths[S].delete=new Xq([E],r,"delete a record with the given primary key",{204:new Jq})),m&&f.schema.enum.length>0&&(S="/"+s+"/{"+c+"}.{property}",t.paths[S]={},t.paths[S].get=new iN([E,f],r,{200:new oN({enum:_})},"used to retrieve the specified property of the specified record"))}return t}function wde(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:ba+e}}}},this.security=t,this.responses={200:{description:lN,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function iN(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function oN(e){this.description=lN,this.content={"application/json":{schema:e}}}function Jq(){this.description="successfully processed request, no content returned to client"}function Cde(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:ba+r}}}},this.responses={200:{description:lN}}}function Xq(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function Zq(e){this.type="object",this.properties=e}function aN(e,t){this.type=e,this.format=t}function cN(e,t,r){this.name=e,this.in=t,this.schema=r}var e$,Ide,sN,ba,lN,r$=Oe(()=>{e$=L(Uc()),Ide="3.0.3",sN={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},ba="#/components/schemas/",lN="successful operation";a(t$,"generateJsonApi");a(wde,"Post");a(iN,"Get");a(oN,"Response200");a(Jq,"Response204");a(Cde,"Put");a(Xq,"Delete");a(Zq,"ResourceSchema");a(aN,"Type");a(cN,"Parameter")});var _S={};je(_S,{parseHeaderValue:()=>dN,start:()=>Lde});async function Pde(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream",s=n?"CONNECT":e.method;e.search&&uS(e);let i=new So;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==n$){let m=dS.getMatch(o,n?"sse":"rest");if(!m)return t(e);e.handlerPath=m.path,c=new Xc(m.relativeURL),c.async=!0,l=m.Resource}if(l?.isCaching){let m=r["cache-control"];if(m){let g=dN(m);for(let S of g)switch(S.name){case"max-age":e.expiresAt=S.value*1e3+Date.now();break;case"only-if-cached":e.onlyIfCached=!0;break;case"no-cache":e.noCache=!0;break;case"no-store":e.noCacheStore=!0;break;case"stale-if-error":e.staleIfError=!0;break;case"must-revalidate":e.mustRevalidate=!0;break}}}let u=r["x-replicate-to"];if(u){let m=dN(u).map(g=>(g.next?.name==="confirm"&&g.next.value>=0&&(e.replicatedConfirmation=+g.next.value),g.name));e.replicateTo=m.length===1&&+m[0]>=0?+m[0]:m[0]==="*"?void 0:m}r["x-replicate-from"]==="none"&&(e.replicateFrom=!1);let _=await Dt(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=bo(r["content-type"],!0)(e.body,e.headers)}catch(m){throw new Ju.ClientError(m,400)}if(e.authorize=!0,o===n$&&s==="GET"){if(e?.user?.role?.permission?.super_user)return t$(dS);throw new Ju.ServerError("Forbidden",403)}switch(s){case"GET":case"HEAD":return l.get(c,e);case"POST":return l.post(c,e.data,e);case"PUT":return l.put(c,e.data,e);case"DELETE":return l.delete(c,e);case"PATCH":return l.patch(c,e.data,e);case"OPTIONS":i.setIfNone("Allow","GET, HEAD, POST, PUT, DELETE, PATCH, OPTIONS, TRACE, QUERY, COPY, MOVE");return;case"CONNECT":return l.connect(c,null,e);case"TRACE":return"HarperDB is the terminating server";case"QUERY":return l.query(c,e.data,e);case"COPY":return l.copy(c,r.destination,e);case"MOVE":return l.move(c,r.destination,e);case"BREW":throw new Ju.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Ju.ServerError(`Method ${s} is not recognized`,501)}}),E=200,f;if(_==null)E=s==="GET"||s==="HEAD"?404:204,uN.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(_.status>0&&_.headers){let m=hO(_.headers,i);return _.headers!==m&&(_.headers=m),_.data!==void 0&&(_.body=eE(_.data,e,_)),_}else if(f=e.lastModified){Dde[0]=f;let m=String.fromCharCode(34,(vr[0]&63)+62,(vr[0]>>6)+(vr[1]<<2&63)+62,(vr[1]>>4)+(vr[2]<<4&63)+62,(vr[2]>>2)+62,(vr[3]&63)+62,(vr[3]>>6)+(vr[4]<<2&63)+62,(vr[4]>>4)+(vr[5]<<4&63)+62,(vr[5]>>2)+62,(vr[6]&63)+62,(vr[6]>>6)+(vr[7]<<2&63)+62,34),g=r["if-none-match"];g&&m==g?(_?.onDone&&_.onDone(),E=304,_=void 0):i.setIfNone("ETag",m),uN.lastModified&&i.setIfNone("Last-Modified",new Date(f).toUTCString())}e.createdResource&&(E=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let h={status:E,headers:i,body:void 0},T=_?.wasLoadedFromSource?.();return T!==void 0&&(h.wasCacheMiss=T,!T&&f&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||f))/1e3))),_!==void 0&&(h.body=eE(_,e,h),s==="HEAD"&&(h.body=void 0)),h}catch(o){o.statusCode?o.statusCode===500?Bi.warn(o):Bi.info(o):Bi.error(o),o.statusCode===405&&(o.method&&(o.message+=` to handle HTTP method ${o.method.toUpperCase()||""}`),o.allow&&(o.allow.push("trace","head","options"),i.setIfNone("Allow",o.allow.map(l=>l.toUpperCase()).join(", "))));let c={status:o.statusCode||500,headers:i,body:void 0};return c.body=eE(o.contentType?o:o.toString(),e,c),c}}function Lde(e){uN=e,!s$&&(s$=!0,dS=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return Pde(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{aE++;let s=new Mn;i$||(i$=!0,x_(l=>{aE>0&&l.push({metric:"ws-connections",connections:aE,byThread:!0})}));let i;t.on("error",l=>{i=!0,Bi.warn(l)});let o;t.on("message",a(function(u){o||(o=bo(r.requestedContentType??r.headers.asObject["content-type"],!1));let d=o(u);s.push(d)},"message"));let c;t.on("close",()=>{aE--,qn(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),u=dS.getMatch(l,"ws");if(qn(!!u,"connection","ws","connect"),u){r.handlerPath=u.path,pr(h=>({count:h.count,total:aE}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let d=new Xc(u.relativeURL),_=u.Resource;c=(await Dt(r,()=>_.connect(d,s,r)))[Symbol.asyncIterator]();let f;for(;!(f=await c.next()).done;){let h=Yc(f.value,r);t.send(h),pr(h.length,"bytes-sent",r.handlerPath,"message","ws")}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){l.statusCode?l.statusCode===500?Bi.warn(l):Bi.info(l):Bi.error(l),t.close(Mde[l.statusCode]||1011,l.toString())}t.close()},e))}function dN(e){return e.trim().split(",").map(t=>{let r,n=t.trim().split(";"),s;for(;s=n.pop();)if(s.includes("=")){let[i,o]=s.trim().split("=");i=i.trim(),o&&(o=o.trim()),r={name:i.toLowerCase(),value:o,next:r}}else r={name:s.toLowerCase(),next:r};return r})}var Bi,Ju,vr,Dde,uN,n$,s$,dS,i$,aE,Mde,o$=Oe(()=>{Wc();Ni();Bi=L(W()),Ju=L(_e());iE();wl();mc();Bf();r$();iE();vr=new Uint8Array(8),Dde=new Float64Array(vr.buffer,0,1),uN={},n$="openapi";a(Pde,"http");aE=0;a(Lde,"start");Mde={401:3e3,403:3003};a(dN,"parseHeaderValue")});var _N=N((GDe,c$)=>{var{recordAction:fS,recordActionBinary:a$}=(Ni(),oe(k_)),Ude=require("fastify-plugin"),vde=200;c$.exports=Ude(function(e,t,r){e.addHook("onResponse",async(n,s)=>{let i=s.elapsedTime}),e.addHook("onSend",async(n,s,i)=>{let o=s.elapsedTime,c=performance.now(),l=s.request.routeOptions,u,d,_;l.config?.isOperation?(u=n.body?.operation,d="operation"):(u=l.url,d="fastify-route",_=l.method),fS(o,"duration",u,_,d),a$(s.raw.statusCode<400,"success",u,_,d),a$(1,"response_"+s.raw.statusCode,u,_,d);let E=vde;i?.pipe?(i.on("data",m=>{E+=m.length}),i.on("end",()=>{fS(performance.now()-c,"transfer",u,_,d),fS(E,"bytes-sent",u,_,d)})):(E+=i?.length||0,fS(E,"bytes-sent",u,_,d));let f=o.toFixed(3),h=s.getHeader("Server-Timing"),T=`db;dur=${f}`;s.header("Server-Timing",h?`${h}, ${T}`:T)}),r()},{name:"hdb-request-time"})});var SN=N((VDe,_$)=>{var mS=require("clone"),SS=Tt(),Bde=te(),hS=M(),qDe=W(),fN=require("fs"),hN=require("joi"),{string:pS}=hN.types(),{hdb_errors:Hde,handleHDBError:ES}=_e(),{HDB_ERROR_MSGS:$De,HTTP_STATUS_CODES:EN}=Hde,{common_validators:Xu}=Ti(),l$=" is required",xde=["insert","update","upsert"],pN={database:{presence:!1,format:Xu.schema_format,length:Xu.schema_length},schema:{presence:!1,format:Xu.schema_format,length:Xu.schema_length},table:{presence:!0,format:Xu.schema_format,length:Xu.schema_length},action:{inclusion:{within:xde,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},kde={schema:pS.required(),table:pS.required(),action:pS.valid("insert","update","upsert")},{AWS_ACCESS_KEY:Fde,AWS_SECRET:Gde,AWS_BUCKET:qde,AWS_FILE_KEY:$de,REGION:Vde}=hS.S3_BUCKET_AUTH_KEYS,Kde={s3:{presence:!0},[`s3.${Fde}`]:{presence:!0,type:"String"},[`s3.${Gde}`]:{presence:!0,type:"String"},[`s3.${qde}`]:{presence:!0,type:"String"},[`s3.${$de}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${Vde}`]:{presence:!0,type:"String"}},u$=mS(pN);u$.data.presence={message:l$};var d$=mS(pN);d$.file_path.presence={message:l$};var Yde=Object.assign(mS(pN),Kde),mN=mS(kde);mN.csv_url=pS.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();mN.passthrough_headers=hN.object();function Wde(e){let t=SS.validateObject(e,u$);return TS(e,t)}a(Wde,"dataObject");function jde(e){let t=SS.validateBySchema(e,hN.object(mN));return TS(e,t)}a(jde,"urlObject");function zde(e){let t=SS.validateObject(e,d$);return TS(e,t)}a(zde,"fileObject");function Qde(e){let t=SS.validateObject(e,Yde);return TS(e,t)}a(Qde,"s3FileObject");function TS(e,t){if(!t){let r=Bde.checkGlobalSchemaTable(e.schema,e.table);if(r)return ES(new Error,r,EN.BAD_REQUEST);if(e.operation===hS.OPERATIONS_ENUM.CSV_FILE_LOAD)try{fN.accessSync(e.file_path,fN.constants.R_OK|fN.constants.F_OK)}catch(n){return n.code===hS.NODE_ERROR_CODES.ENOENT?ES(n,`No such file or directory ${n.path}`,EN.BAD_REQUEST):n.code===hS.NODE_ERROR_CODES.EACCES?ES(n,`Permission denied ${n.path}`,EN.BAD_REQUEST):ES(n)}}return t}a(TS,"postValidateChecks");_$.exports={dataObject:Wde,urlObject:jde,fileObject:zde,s3FileObject:Qde}});var TN=N((YDe,f$)=>{"use strict";var cE=W(),gS=M();async function Jde(e,t,r,n=void 0){if(!e||typeof e!="function")throw new Error("Invalid function parameter");let s;try{return s=await e(t),r&&await r(t,s,n),t.operation===gS.OPERATIONS_ENUM.INSERT||t.operation===gS.OPERATIONS_ENUM.UPDATE||t.operation===gS.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===gS.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(cE.info(i.message),i):i.http_resp_msg?(cE.error(`Error calling operation: ${e.name}`),cE.error(i.http_resp_msg),i):(cE.error(`Error calling operation: ${e.name}`),cE.error(i),i)}}a(Jde,"callOperationFunctionAsAwait");f$.exports={callOperationFunctionAsAwait:Jde}});var h$=N((jDe,E$)=>{"use strict";var gN=class{static{a(this,"BulkLoadFileObject")}constructor(t,r,n,s,i,o,c=null){this.op=t,this.action=r,this.schema=n,this.table=s,this.file_path=i,this.file_type=o,this.role_perms=c}},RN=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};E$.exports={BulkLoadFileObject:gN,BulkLoadDataObject:RN}});var m$=N((QDe,p$)=>{"use strict";var AN=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};p$.exports=AN});var wN=N((rPe,U$)=>{"use strict";var RS=un(),yS=SN(),Xde=require("needle"),ri=M(),XDe=Ct(),Zu=te(),{handleHDBError:qt,hdb_errors:N$}=_e(),{HTTP_STATUS_CODES:Br,HDB_ERROR_MSGS:Rr,CHECK_LOGS_WRAPPER:el}=N$,ed=W(),yN=require("papaparse");Zu.promisifyPapaParse();var ni=require("fs-extra"),Zde=require("path"),{chain:S$}=require("stream-chain"),T$=require("stream-json/streamers/StreamArray"),g$=require("stream-json/utils/Batch"),R$=require("stream-chain/utils/comp"),{finished:A$}=require("stream"),e_e=se(),I$=TN(),t_e=xO(),{BulkLoadFileObject:ON,BulkLoadDataObject:r_e}=h$(),NN=wO(),{verifyBulkLoadAttributePerms:w$}=Xm(),ZDe=m$(),ePe=mr(),tPe=to(),{databases:n_e}=(Pe(),oe(lt)),{coerceType:s_e}=(oE(),oe(CN)),y$="No records parsed from csv file.",Zc=`${e_e.get("HDB_ROOT")}/tmp`,{schema_regex:i_e}=Ti(),b$=1024*1024*2,O$=5e3,o_e={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};U$.exports={csvDataLoad:a_e,csvURLLoad:c_e,csvFileLoad:l_e,importFromS3:u_e};async function a_e(e,t){let r=yS.dataObject(e);if(r)throw qt(r,r.message,Br.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=P$(e.schema,e.table),i=yN.parse(e.data,{header:!0,skipEmptyLines:!0,transform:bN.bind(null,s),dynamicTyping:!1}),o=new NN;e.hdb_user&&e.hdb_user?.role&&e.hdb_user?.role?.permission&&e.hdb_user?.role?.permission?.super_user!==!0&&w$(e.hdb_user?.role?.permission,this.job_operation_function.name,e.action,e.schema,e.table,i.meta.fields,o);let c=o.getPermsResponse();if(c)throw qt(new Error,c,Br.BAD_REQUEST,void 0,void 0,!0);let l=new r_e(e.action,e.schema,e.table,i.data);return n=await I$.callOperationFunctionAsAwait(L$,l,null),n.message===y$?y$:M$(n.records,n.number_written)}catch(s){throw tl(s)}}a(a_e,"csvDataLoad");async function c_e(e){let t=yS.urlObject(e);if(t)throw qt(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${Zc}/${r}`;try{await d_e(e,r)}catch(s){throw ed.error(Rr.DOWNLOAD_FILE_ERR(r)+" - "+s),qt(s,el(Rr.DOWNLOAD_FILE_ERR(r)))}try{let s=new ON(this.job_operation_function.name,e.action,e.schema,e.table,n,ri.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission),i=await IN(s);return await AS(n),i}catch(s){throw await AS(n),tl(s)}}a(c_e,"csvURLLoad");async function l_e(e){let t=yS.fileObject(e);if(t)throw qt(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r=new ON(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,ri.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission);try{return await IN(r)}catch(n){throw tl(n)}}a(l_e,"csvFileLoad");async function u_e(e){let t=yS.s3FileObject(e);if(t)throw qt(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=Zde.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${Zc}/${s}`;let i=new ON(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user?.role?.permission);await __e(s,e);let o=await IN(i);return await AS(r),o}catch(n){throw await AS(r),tl(n)}}a(u_e,"importFromS3");async function d_e(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await Xde("get",e.csv_url,n)}catch(n){let s=`Error downloading CSV file from ${e.csv_url}, status code: ${n.statusCode}. Check the log for more information.`;throw qt(n,s,n.statusCode,ri.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}E_e(r,e.csv_url),await f_e(t,r.raw)}a(d_e,"downloadCSVFile");async function __e(e,t){try{let r=`${Zc}/${e}`;await ni.mkdirp(Zc),await ni.writeFile(`${Zc}/${e}`,"",{flag:"a+"});let n=await ni.createWriteStream(r),s=await t_e.getFileStreamFromS3(t);await new Promise((i,o)=>{s.on("error",function(c){o(c)}),s.pipe(n).on("error",function(c){o(c)}).on("close",function(){ed.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw ed.error(Rr.S3_DOWNLOAD_ERR+" - "+r),qt(r,el(Rr.S3_DOWNLOAD_ERR))}}a(__e,"downloadFileFromS3");async function f_e(e,t){try{await ni.mkdirp(Zc),await ni.writeFile(`${Zc}/${e}`,t)}catch(r){throw ed.error(Rr.WRITE_TEMP_FILE_ERR),qt(r,el(Rr.DEFAULT_BULK_LOAD_ERR))}}a(f_e,"writeFileToTempFolder");async function AS(e){if(e)try{await ni.access(e),await ni.unlink(e)}catch{ed.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(AS,"deleteTempFile");function E_e(e,t){if(e.statusCode!==N$.HTTP_STATUS_CODES.OK)throw qt(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,Br.BAD_REQUEST);if(!o_e[e.headers["content-type"]])throw qt(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,Br.BAD_REQUEST);if(!e.raw)throw qt(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,Br.BAD_REQUEST)}a(E_e,"validateURLResponse");async function IN(e){try{let t;switch(e.file_type){case ri.VALID_S3_FILE_TYPES.CSV:t=await h_e(e);break;case ri.VALID_S3_FILE_TYPES.JSON:t=await p_e(e);break;default:throw qt(new Error,Rr.DEFAULT_BULK_LOAD_ERR,Br.BAD_REQUEST,ri.LOG_LEVELS.ERROR,Rr.INVALID_FILE_EXT_ERR(e))}return M$(t.records,t.number_written)}catch(t){throw tl(t)}}a(IN,"fileLoad");async function C$(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;s&&s.pause();let o={operation:e.action,schema:e.schema,table:e.table,records:i};try{let{attributes:c}=await RS.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&w$(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let l=qt(c);r(l)}}a(C$,"validateChunk");async function D$(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;Zu.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Zu.isEmpty(c)&&!Zu.isEmpty(c.__parsed_extra)&&delete c.__parsed_extra});else{let c=new Set;i.forEach(l=>{Object.keys(l).forEach(u=>c.add(u))}),o=[...c]}try{let c={schema:e.schema,table:e.table,action:e.action,data:i},l=await I$.callOperationFunctionAsAwait(L$,c,null);t.records+=l.records,t.number_written+=l.number_written,s&&s.resume()}catch(c){let l=qt(c,el(Rr.INSERT_CSV_ERR),Br.INTERNAL_SERVER_ERROR,ri.LOG_LEVELS.ERROR,Rr.INSERT_CSV_ERR+" - "+c);r(l)}}a(D$,"insertChunk");async function h_e(e){let t={records:0,number_written:0},r=P$(e.schema,e.table);try{let n=new NN,s=ni.createReadStream(e.file_path,{highWaterMark:b$});s.setEncoding("utf8"),await yN.parsePromise(s,C$.bind(null,e,n),bN.bind(null,r));let i=n.getPermsResponse();if(i)throw qt(new Error,i,Br.BAD_REQUEST);return s=ni.createReadStream(e.file_path,{highWaterMark:b$}),s.setEncoding("utf8"),await yN.parsePromise(s,D$.bind(null,e,t),bN.bind(null,r)),s.destroy(),t}catch(n){throw qt(n,el(Rr.PAPA_PARSE_ERR),Br.INTERNAL_SERVER_ERROR,ri.LOG_LEVELS.ERROR,Rr.PAPA_PARSE_ERR+n)}}a(h_e,"callPapaParse");function P$(e,t){let r=n_e[e][t].attributes,n=new Map;for(let s of r)s.type&&!s.computed&&!s.relationship&&n.set(s.name,i=>s_e(i,s));return n}a(P$,"createTransformMap");function bN(e,t,r){let n=e.get(r);return n?n(t):Zu.autoCast(t)}a(bN,"typeFunction");async function p_e(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new NN,s=S$([ni.createReadStream(e.file_path,{encoding:"utf-8"}),T$.withParser(),c=>c.value,new g$({batchSize:O$}),R$(async c=>{await C$(e,n,r,c)})]);await new Promise((c,l)=>{A$(s,u=>{u?l(u):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw qt(new Error,i,Br.BAD_REQUEST);let o=S$([ni.createReadStream(e.file_path,{encoding:"utf-8"}),T$.withParser(),c=>c.value,new g$({batchSize:O$}),R$(async c=>{await D$(e,t,r,c)})]);return await new Promise((c,l)=>{A$(o,u=>{u?l(u):c()}),o.resume()}),t}catch(n){throw qt(n,el(Rr.INSERT_JSON_ERR),Br.INTERNAL_SERVER_ERROR,ri.LOG_LEVELS.ERROR,Rr.INSERT_JSON_ERR+n)}}a(p_e,"insertJson");async function L$(e){let t={};try{e.data&&e.data.length>0&&m_e(e.data[0])?t=await S_e(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",ed.info(t.message))}catch(r){throw tl(r)}return t}a(L$,"callBulkFileLoad");function m_e(e){let t=Object.keys(e);for(let r of t)if(!i_e.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(m_e,"validateColumnNames");async function S_e(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=RS.insert;break;case"update":i=RS.update;break;case"upsert":i=RS.upsert;break;default:throw qt(new Error,Rr.INVALID_ACTION_PARAM_ERR(n),Br.BAD_REQUEST,ri.LOG_LEVELS.ERROR,Rr.INVALID_ACTION_PARAM_ERR(n))}try{let o=await i(s),c;switch(n){case"insert":c=o.inserted_hashes;break;case"update":c=o.update_hashes;break;case"upsert":c=o.upserted_hashes;break;default:break}if(Array.isArray(o.skipped_hashes)&&o.skipped_hashes.length>0){let d=global.hdb_schema[t][r].hash_attribute,_=e.length;for(;_--;)o.skipped_hashes.indexOf(e[_][d])>=0&&e.splice(_,1)}let l=Zu.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw tl(o)}}a(S_e,"bulkFileLoad");function M$(e,t){return`successfully loaded ${t} of ${e} records`}a(M$,"buildResponseMsg");function tl(e){return qt(e,el(Rr.DEFAULT_BULK_LOAD_ERR),Br.INTERNAL_SERVER_ERROR,ri.LOG_LEVELS.ERROR,Rr.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(tl,"buildTopLevelErrMsg")});var B$=N((sPe,v$)=>{"use strict";var DN=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};v$.exports=DN});var k$=N((oPe,x$)=>{"use strict";var T_e=M(),H$=require("moment"),g_e=require("uuid").v4,PN=class{static{a(this,"JobObject")}constructor(){this.id=g_e(),this.type=void 0,this.start_datetime=H$().valueOf(),this.created_datetime=H$().valueOf(),this.end_datetime=void 0,this.status=T_e.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};x$.exports=PN});var LN=N((cPe,W$)=>{"use strict";var R_e=require("uuid").v4,V$=un(),K$=Vr(),A_e=$s(),y_e=Vl(),b_e=B$(),bt=M(),O_e=k$(),N_e=Hp(),Ns=W(),I_e=Qd(),td=te(),{promisify:w_e}=require("util"),rl=require("moment"),C_e=eS(),bS=SN(),F$=yR(),{deleteTransactionLogsBeforeValidator:D_e}=yO(),{handleHDBError:G$,hdb_errors:P_e}=_e(),{HTTP_STATUS_CODES:q$}=P_e,$$=K$.searchByValue,L_e=K$.searchByHash,M_e=V$.insert,U_e=w_e(C_e.evaluateSQL),v_e=V$.update;W$.exports={addJob:x_e,updateJob:F_e,handleGetJob:B_e,handleGetJobsByStartDate:H_e,getJobById:Y$};async function B_e(e){try{let t=await Y$(e.id);return td.isEmptyOrZeroLength(t)||(t[0]={...t[0]},t[0].request!==void 0&&delete t[0].request,delete t[0].__createdtime__,delete t[0].__updatedtime__),t}catch(t){let r=`There was an error getting job: ${t}`;throw Ns.error("There was an error getting job",t),new Error(r)}}a(B_e,"handleGetJob");async function H_e(e){try{let t=await k_e(e);if(Ns.trace(`Searching for jobs from ${e.from_date} to ${e.to_date}`),t&&t.length>0)for(let r of t)r.start_datetime&&(r.start_datetime_converted=rl(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=rl(r.end_datetime)),r.request!==void 0&&delete r.request,delete r.__createdtime__,delete r.__updatedtime__;return t}catch(t){let r=`There was an error searching jobs by date: ${t}`;throw Ns.error(r),new Error(r)}}a(H_e,"handleGetJobsByStartDate");async function x_e(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||td.isEmptyOrZeroLength(e.operation)){let d="job parameter is invalid";return Ns.info(d),t.error=d,t}if(!bt.JOB_TYPE_ENUM[e.operation])return Ns.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case bt.OPERATIONS_ENUM.CSV_FILE_LOAD:n=bS.fileObject(e);break;case bt.OPERATIONS_ENUM.CSV_URL_LOAD:n=bS.urlObject(e);break;case bt.OPERATIONS_ENUM.CSV_DATA_LOAD:n=bS.dataObject(e);break;case bt.OPERATIONS_ENUM.IMPORT_FROM_S3:n=bS.s3FileObject(e);break;case bt.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case bt.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=F$(e,"date");break;case bt.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=F$(e,"timestamp");break;case bt.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=D_e(e);break;case bt.OPERATIONS_ENUM.RESTART_SERVICE:if(bt.PROCESS_DESCRIPTORS_VALIDATE[e.service]===void 0)throw G$(new Error,"Invalid service",q$.BAD_REQUEST,void 0,void 0,!0);break;default:break}if(n)throw G$(n,n.message,q$.BAD_REQUEST,void 0,void 0,!0);let s=new O_e;s.type=e.operation===bt.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE?bt.OPERATIONS_ENUM.DELETE_FILES_BEFORE:e.operation,s.type=e.operation,s.user=e.hdb_user?.username;let i=new A_e(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await $$(i))}catch(d){let _=`There was an error inserting a new job: ${d}`;return Ns.error(_),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=R_e();try{o=await $$(i)}catch(d){let _=`There was an error inserting a new job: ${d}`;return Ns.error(_),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return Ns.error("Error creating a job, could not find a unique job id."),t}s.request=e;let l=new I_e(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),u;try{u=await M_e(l)}catch(d){return Ns.error(`There was an error inserting a job for job type: ${e.operation} -- ${d}`),t.success=!1,t}if(u.inserted_hashes.length===0)t.message=`Had a problem creating a job with type ${s.operation} and id ${s.id}`;else{let d=`Created a job with type ${s.type} and id ${s.id}`;t.message=d,t.createdJob=s,t.success=!0,Ns.trace(d)}return t}a(x_e,"addJob");async function k_e(e){let t=rl(e.from_date,rl.ISO_8601),r=rl(e.to_date,rl.ISO_8601);if(!t.isValid())throw new Error("Invalid 'from' date, must be in ISO-8601 format (YYYY-MM-DD).");if(!r.isValid())throw new Error("Invalid 'to' date, must be in ISO-8601 format (YYYY-MM-DD)");let n=`select * from system.hdb_job where start_datetime > '${t.valueOf()}' and start_datetime < '${r.valueOf()}'`,s=new b_e(n,e.hdb_user);try{return await U_e(s)}catch(i){throw Ns.error(`there was a problem searching for jobs from date ${e.from_date} to date ${e.to_date} ${i}`),new Error("there was an error searching for jobs. Please check the log for details.")}}a(k_e,"getJobsInDateRange");async function Y$(e){if(td.isEmptyOrZeroLength(e))return td.errorizeMessage("Invalid job ID specified.");let t=new y_e(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await L_e(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return Ns.error(n),td.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(Y$,"getJobById");async function F_e(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(td.isEmptyOrZeroLength(e.id))throw new Error("invalid ID passed to updateJob");(e.status===bt.JOB_STATUS_ENUM.COMPLETE||e.status===bt.JOB_STATUS_ENUM.ERROR)&&(e.end_datetime=rl().valueOf());let t=new N_e(bt.SYSTEM_SCHEMA_NAME,bt.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await v_e(t),r}a(F_e,"updateJob")});var tV=N((uPe,eV)=>{"use strict";var j$=te(),Ar=M(),G_e=require("moment"),OS=wN(),lE=W(),z$=LN(),Q$=tS(),J$=uc(),X$=dt(),q_e=jm(),$_e=xu(),{parentPort:V_e,isMainThread:Z$}=require("worker_threads"),{onMessageByType:K_e}=dt(),MN=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function Y_e(e){if(!e||Object.keys(e).length===0)throw new Error("Empty runner passed to parseMessage");if(!e.json||Object.keys(e.json).length===0)throw new Error("Empty JSON passed to parseMessage");if(!e.job||Object.keys(e.job).length===0)throw new Error("Empty job passed to parseMessage");if(j$.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(j$.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case Ar.JOB_TYPE_ENUM.csv_file_load:await Hi(e,OS.csvFileLoad);break;case Ar.JOB_TYPE_ENUM.csv_url_load:await Hi(e,OS.csvURLLoad);break;case Ar.JOB_TYPE_ENUM.csv_data_load:await Hi(e,OS.csvDataLoad);break;case Ar.JOB_TYPE_ENUM.import_from_s3:await Hi(e,OS.importFromS3);break;case Ar.JOB_TYPE_ENUM.empty_trash:break;case Ar.JOB_TYPE_ENUM.export_local:await Hi(e,Q$.export_local);break;case Ar.JOB_TYPE_ENUM.export_to_s3:await Hi(e,Q$.export_to_s3);break;case Ar.JOB_TYPE_ENUM.delete_files_before:case Ar.JOB_TYPE_ENUM.delete_records_before:await Hi(e,J$.deleteFilesBefore);break;case Ar.JOB_TYPE_ENUM.delete_audit_logs_before:await Hi(e,J$.deleteAuditLogsBefore);break;case Ar.JOB_TYPE_ENUM.delete_transaction_logs_before:await Hi(e,q_e.deleteTransactionLogsBefore);break;case Ar.JOB_TYPE_ENUM.restart_service:return await Hi(e,$_e.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(Y_e,"parseMessage");async function Hi(e,t){try{e.job.status=Ar.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=G_e().valueOf(),await z$.updateJob(e.job),await W_e(e.job.id)}catch(r){let n=r.message!==void 0?r.message:r;typeof n=="string"?(n=`There was an error running ${t.name} job with id ${e.job.id} - ${n}`,r.message=n):lE.error(`There was an error running ${t.name} job with id ${e.job.id}`),lE.error(n),e.job.message=n,e.job.status=Ar.JOB_STATUS_ENUM.ERROR;try{await z$.updateJob(e.job)}catch(s){throw lE.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(Hi,"runJob");async function W_e(e){lE.trace("launching job thread:",e),Z$?X$.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Ar.PROCESS_NAME_ENV_PROP]:`JOB-${e}`}}):V_e.postMessage({type:Ar.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(W_e,"launchJobThread");Z$&&K_e(Ar.ITC_EVENT_TYPES.START_JOB,async(e,t)=>{try{X$.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Ar.PROCESS_NAME_ENV_PROP]:`JOB-${e.jobId}`}})}catch(r){lE.error(r)}});eV.exports={parseMessage:Y_e,RunnerMessage:MN}});var nV=N((_Pe,rV)=>{"use strict";var UN=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};rV.exports=UN});var RV=N((hPe,FN)=>{"use strict";var DS=Vr(),HN=eS(),NS=wN(),No=em(),IS=ro(),dE=uc(),j_e=zy(),uE=xn(),wS=lf(),Lt=AO(),CS=W(),z_e=ob(),Q_e=pf(),sV=Lb(),J_e=Rf(),X_e=vb(),Z_e=Bb(),efe=mm(),tfe=Fb(),vN=Tm(),iV=tS(),rfe=Xm(),xN=LN(),$=M(),{hdb_errors:fE,handleHDBError:_E}=_e(),{HTTP_STATUS_CODES:oV}=fE,BN=Wb(),aV=xu(),mV=require("util"),nd=un(),nfe=ls(),sfe=Ou(),cV=tV(),lV=lu(),uV=(xm(),oe(Hf)),dV=wt(),_V=jm(),fV=kf(),{setServerUtilities:ife}=(oE(),oe(CN)),{CONTEXT:EPe}=(Vs(),oe(_A)),{_assignPackageExport:ofe}=fi(),{transformReq:afe}=te(),{server:cfe}=(qr(),oe(Qa)),tn=CS.loggerWithTag("operation"),rd=Xs(),EV=(Hc(),oe(Bc)),lfe=TN(),hV=DS.searchByHash,ufe=DS.searchByValue,dfe=mV.promisify(DS.search),_fe=mV.promisify(HN.evaluateSQL),ffe={[$.OPERATIONS_ENUM.CREATE_ATTRIBUTE]:!0,[$.OPERATIONS_ENUM.CREATE_TABLE]:!0,[$.OPERATIONS_ENUM.CREATE_SCHEMA]:!0,[$.OPERATIONS_ENUM.DROP_ATTRIBUTE]:!0,[$.OPERATIONS_ENUM.DROP_TABLE]:!0,[$.OPERATIONS_ENUM.DROP_SCHEMA]:!0},J=nV();async function SV(e,t){try{if(e.body.operation!=="read_log"&&(CS.log_level===$.LOG_LEVELS.INFO||CS.log_level===$.LOG_LEVELS.DEBUG||CS.log_level===$.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,payload:o,...c}=e.body;tn.info(c)}}catch(n){tn.error(n)}let r=await lfe.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return ffe[e.body.operation]&&nfe.setSchemaDataToGlobal(n=>{n&&tn.error(n)}),r}a(SV,"processLocalTransaction");var pV=hfe();FN.exports={chooseOperation:TV,getOperationFunction:gV,operation:kN,processLocalTransaction:SV};ife(FN.exports);cfe.operation=kN;function TV(e){let t;try{t=gV(e)}catch(s){throw tn.error(`Error when selecting operation function - ${s}`),s}let{operation_function:r,job_operation_function:n}=t;try{if(e.operation==="sql"||e.search_operation&&e.search_operation.operation==="sql"){let s=e.operation==="sql"?e.sql:e.search_operation.sql,i=HN.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=HN.checkASTPermissions(e,i);if(o)throw tn.error(`${oV.FORBIDDEN} from operation ${e.operation}`),tn.warn(`User '${e.hdb_user?.username}' is not permitted to ${e.operation}`),_E(new Error,o,fE.HTTP_STATUS_CODES.FORBIDDEN,void 0,void 0,!0)}}else if(!e.bypass_auth&&e.operation!==$.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.operation!==$.OPERATIONS_ENUM.LOGIN&&e.operation!==$.OPERATIONS_ENUM.LOGOUT){let s=n===void 0?r:n,i=e.search_operation?e.search_operation:e;i.hdb_user||(i.hdb_user=e.hdb_user);let o=rfe.verifyPerms(i,s);if(o)throw tn.error(`${oV.FORBIDDEN} from operation ${e.operation}`),tn.warn(`User '${i.hdb_user?.username}' is not permitted to ${i.operation}`),_E(new Error,o,fE.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw _E(s,"There was an error when trying to choose an operation path")}return r}a(TV,"chooseOperation");function gV(e){if(tn.trace(`getOperationFunction with operation: ${e.operation}`),pV.has(e.operation))return pV.get(e.operation);throw _E(new Error,fE.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),fE.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(gV,"getOperationFunction");ofe("operation",kN);function kN(e,t,r){e.hdb_user=t?.user,e.bypass_auth=!r;let n=TV(e);return SV({body:e},n)}a(kN,"operation");async function Efe(e){tn.trace("In serverUtils.catchup");let t=e.transaction,r=t.channel.split(":"),n=r[0],s=r[1];for(let i of t.transactions)try{i.schema=n,i.table=s,i[$.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case $.OPERATIONS_ENUM.INSERT:o=await nd.insert(i);break;case $.OPERATIONS_ENUM.UPDATE:o=await nd.update(i);break;case $.OPERATIONS_ENUM.UPSERT:o=await nd.upsert(i);break;case $.OPERATIONS_ENUM.DELETE:o=await dE.deleteRecord(i);break;default:tn.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){tn.info("Invalid operation in transaction"),tn.error(o)}}a(Efe,"catchup");async function si(e){afe(e);let t,r;try{r=await xN.addJob(e),t=r.createdJob,tn.info("addJob result",r);let n=new cV.RunnerMessage(t,e);return{message:await cV.parseMessage(n)??`Starting job with id ${t.id}`,job_id:t.id}}catch(n){let s=`There was an error executing job: ${n.http_resp_msg?n.http_resp_msg:n}`;throw tn.error(s),_E(n,s)}}a(si,"executeJob");function hfe(){let e=new Map;return e.set($.OPERATIONS_ENUM.INSERT,new J(nd.insert)),e.set($.OPERATIONS_ENUM.UPDATE,new J(nd.update)),e.set($.OPERATIONS_ENUM.UPSERT,new J(nd.upsert)),e.set($.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new J(DS.searchByConditions)),e.set($.OPERATIONS_ENUM.SEARCH_BY_HASH,new J(hV)),e.set($.OPERATIONS_ENUM.SEARCH_BY_ID,new J(hV)),e.set($.OPERATIONS_ENUM.SEARCH_BY_VALUE,new J(ufe)),e.set($.OPERATIONS_ENUM.SEARCH,new J(dfe)),e.set($.OPERATIONS_ENUM.SQL,new J(_fe)),e.set($.OPERATIONS_ENUM.CSV_DATA_LOAD,new J(si,NS.csvDataLoad)),e.set($.OPERATIONS_ENUM.CSV_FILE_LOAD,new J(si,NS.csvFileLoad)),e.set($.OPERATIONS_ENUM.CSV_URL_LOAD,new J(si,NS.csvURLLoad)),e.set($.OPERATIONS_ENUM.IMPORT_FROM_S3,new J(si,NS.importFromS3)),e.set($.OPERATIONS_ENUM.CREATE_SCHEMA,new J(No.createSchema)),e.set($.OPERATIONS_ENUM.CREATE_DATABASE,new J(No.createSchema)),e.set($.OPERATIONS_ENUM.CREATE_TABLE,new J(No.createTable)),e.set($.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new J(No.createAttribute)),e.set($.OPERATIONS_ENUM.DROP_SCHEMA,new J(No.dropSchema)),e.set($.OPERATIONS_ENUM.DROP_DATABASE,new J(No.dropSchema)),e.set($.OPERATIONS_ENUM.DROP_TABLE,new J(No.dropTable)),e.set($.OPERATIONS_ENUM.DROP_ATTRIBUTE,new J(No.dropAttribute)),e.set($.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new J(IS.describeSchema)),e.set($.OPERATIONS_ENUM.DESCRIBE_DATABASE,new J(IS.describeSchema)),e.set($.OPERATIONS_ENUM.DESCRIBE_TABLE,new J(IS.describeTable)),e.set($.OPERATIONS_ENUM.DESCRIBE_ALL,new J(IS.describeAll)),e.set($.OPERATIONS_ENUM.DELETE,new J(dE.deleteRecord)),e.set($.OPERATIONS_ENUM.ADD_USER,new J(uE.addUser)),e.set($.OPERATIONS_ENUM.ALTER_USER,new J(uE.alterUser)),e.set($.OPERATIONS_ENUM.DROP_USER,new J(uE.dropUser)),e.set($.OPERATIONS_ENUM.LIST_USERS,new J(uE.listUsersExternal)),e.set($.OPERATIONS_ENUM.LIST_ROLES,new J(wS.listRoles)),e.set($.OPERATIONS_ENUM.ADD_ROLE,new J(wS.addRole)),e.set($.OPERATIONS_ENUM.ALTER_ROLE,new J(wS.alterRole)),e.set($.OPERATIONS_ENUM.DROP_ROLE,new J(wS.dropRole)),e.set($.OPERATIONS_ENUM.USER_INFO,new J(uE.userInfo)),e.set($.OPERATIONS_ENUM.READ_LOG,new J(z_e)),e.set($.OPERATIONS_ENUM.ADD_NODE,new J(Q_e)),e.set($.OPERATIONS_ENUM.UPDATE_NODE,new J(sV)),e.set($.OPERATIONS_ENUM.SET_NODE_REPLICATION,new J(sV)),e.set($.OPERATIONS_ENUM.REMOVE_NODE,new J(J_e)),e.set($.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new J(X_e)),e.set($.OPERATIONS_ENUM.PURGE_STREAM,new J(Z_e)),e.set($.OPERATIONS_ENUM.SET_CONFIGURATION,new J(dV.setConfiguration)),e.set($.OPERATIONS_ENUM.CLUSTER_STATUS,new J(efe.clusterStatus)),e.set($.OPERATIONS_ENUM.CLUSTER_NETWORK,new J(tfe)),e.set($.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new J(vN.setRoutes)),e.set($.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new J(vN.getRoutes)),e.set($.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new J(vN.deleteRoutes)),e.set($.OPERATIONS_ENUM.EXPORT_TO_S3,new J(si,iV.export_to_s3)),e.set($.OPERATIONS_ENUM.CREATE_CSR,new J(rd.createCsr)),e.set($.OPERATIONS_ENUM.SIGN_CERTIFICATE,new J(rd.signCertificate)),e.set($.OPERATIONS_ENUM.LIST_CERTIFICATES,new J(rd.listCertificates)),e.set($.OPERATIONS_ENUM.ADD_CERTIFICATES,new J(rd.addCertificate)),e.set($.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new J(rd.removeCertificate)),e.set($.OPERATIONS_ENUM.GET_KEY,new J(rd.getKey)),e.set($.OPERATIONS_ENUM.ADD_NODE_BACK,new J(EV.addNodeBack)),e.set($.OPERATIONS_ENUM.REMOVE_NODE_BACK,new J(EV.removeNodeBack)),e.set($.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new J(si,dE.deleteFilesBefore)),e.set($.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new J(si,dE.deleteFilesBefore)),e.set($.OPERATIONS_ENUM.EXPORT_LOCAL,new J(si,iV.export_local)),e.set($.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new J(xN.handleGetJobsByStartDate)),e.set($.OPERATIONS_ENUM.GET_JOB,new J(xN.handleGetJob)),e.set($.OPERATIONS_ENUM.GET_FINGERPRINT,new J(BN.getFingerprint)),e.set($.OPERATIONS_ENUM.SET_LICENSE,new J(BN.setLicense)),e.set($.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new J(BN.getRegistrationInfo)),e.set($.OPERATIONS_ENUM.RESTART,new J(aV.restart)),e.set($.OPERATIONS_ENUM.RESTART_SERVICE,new J(si,aV.restartService)),e.set($.OPERATIONS_ENUM.CATCHUP,new J(Efe)),e.set($.OPERATIONS_ENUM.SYSTEM_INFORMATION,new J(sfe.systemInformation)),e.set($.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new J(si,dE.deleteAuditLogsBefore)),e.set($.OPERATIONS_ENUM.READ_AUDIT_LOG,new J(j_e)),e.set($.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new J(lV.createTokens)),e.set($.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new J(lV.refreshOperationToken)),e.set($.OPERATIONS_ENUM.LOGIN,new J(uV.login)),e.set($.OPERATIONS_ENUM.LOGOUT,new J(uV.logout)),e.set($.OPERATIONS_ENUM.GET_CONFIGURATION,new J(dV.getConfiguration)),e.set($.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new J(Lt.customFunctionsStatus)),e.set($.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new J(Lt.getCustomFunctions)),e.set($.OPERATIONS_ENUM.GET_COMPONENT_FILE,new J(Lt.getComponentFile)),e.set($.OPERATIONS_ENUM.GET_COMPONENTS,new J(Lt.getComponents)),e.set($.OPERATIONS_ENUM.SET_COMPONENT_FILE,new J(Lt.setComponentFile)),e.set($.OPERATIONS_ENUM.DROP_COMPONENT,new J(Lt.dropComponent)),e.set($.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new J(Lt.getCustomFunction)),e.set($.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new J(Lt.setCustomFunction)),e.set($.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new J(Lt.dropCustomFunction)),e.set($.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new J(Lt.addComponent)),e.set($.OPERATIONS_ENUM.ADD_COMPONENT,new J(Lt.addComponent)),e.set($.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new J(Lt.dropCustomFunctionProject)),e.set($.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new J(Lt.packageComponent)),e.set($.OPERATIONS_ENUM.PACKAGE_COMPONENT,new J(Lt.packageComponent)),e.set($.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new J(Lt.deployComponent)),e.set($.OPERATIONS_ENUM.DEPLOY_COMPONENT,new J(Lt.deployComponent)),e.set($.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new J(_V.readTransactionLog)),e.set($.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new J(si,_V.deleteTransactionLogsBefore)),e.set($.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new J(fV.installModules)),e.set($.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new J(fV.auditModules)),e.set($.OPERATIONS_ENUM.GET_BACKUP,new J(No.getBackup)),e.set($.OPERATIONS_ENUM.ADD_SSH_KEY,new J(Lt.addSSHKey)),e.set($.OPERATIONS_ENUM.UPDATE_SSH_KEY,new J(Lt.updateSSHKey)),e.set($.OPERATIONS_ENUM.DELETE_SSH_KEY,new J(Lt.deleteSSHKey)),e.set($.OPERATIONS_ENUM.LIST_SSH_KEYS,new J(Lt.listSSHKeys)),e.set($.OPERATIONS_ENUM.SET_SSH_KNOWN_HOSTS,new J(Lt.setSSHKnownHosts)),e.set($.OPERATIONS_ENUM.GET_SSH_KNOWN_HOSTS,new J(Lt.getSSHKnownHosts)),e}a(hfe,"initializeOperationFunctionMap")});var LS=N((mPe,bV)=>{"use strict";var GN=M(),pfe=te(),EE=W(),{handleHDBError:qN,hdb_errors:PS}=_e(),{isMainThread:mfe}=require("worker_threads"),{Readable:Sfe}=require("stream"),AV=require("os"),Tfe=require("util"),gfe=cb(),Rfe=Tfe.promisify(gfe.authorize),yV=RV(),{createGzip:Afe,constants:yfe}=require("zlib");function bfe(e){let t=`Found an uncaught exception with message: ${e.message}. ${AV.EOL}Stack: ${e.stack} ${AV.EOL}Terminating ${mfe?"HDB":"thread"}.`;console.error(t),EE.fatal(t),process.exit(1)}a(bfe,"handleServerUncaughtException");function Ofe(e,t,r){if(EE[e.logLevel||"error"](e),e.statusCode)return typeof e.http_resp_msg!="object"?r.code(e.statusCode).send({error:e.http_resp_msg||e.message}):r.code(e.statusCode).send(e.http_resp_msg);let n=e.statusCode?e.statusCode:PS.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR;return typeof e=="string"?r.code(n).send({error:e}):r.code(n).send(e.message?{error:e.message}:e)}a(Ofe,"serverErrorHandler");function Nfe(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=qN(new Error,"Invalid JSON.",PS.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(pfe.isEmpty(e.body.operation)){let n=qN(new Error,"Request body must include an 'operation' property.",PS.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(Nfe,"reqBodyValidationHandler");function Ife(e,t,r){let n;e.body.operation!==GN.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.body.operation!==GN.OPERATIONS_ENUM.LOGIN&&e.body.operation!==GN.OPERATIONS_ENUM.LOGOUT?Rfe(e,t).then(s=>{n=s,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(s=>{EE.warn(s),EE.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${s.stack}"`);let i=typeof s=="string"?{error:s}:{error:s.message};r(qN(s,i,PS.HTTP_STATUS_CODES.UNAUTHORIZED),null)}):(e.body.hdb_user=null,e.body.hdb_auth_header=e.headers.authorization,e.body.baseRequest=e.raw?.baseRequest,e.body.baseResponse=t.raw?.baseResponse,e.body.fastifyResponse=t,r())}a(Ife,"authHandler");async function wfe(e,t,r=!1){let n;try{e.body.bypass_auth&&delete e.body.bypass_auth,n=yV.chooseOperation(e.body);let s=await yV.processLocalTransaction(e,n);if(s instanceof Sfe&&s.headers){for(let[i,o]of s.headers)t.header(i,o);e.headers["accept-encoding"]?.includes("gzip")&&(t.header("content-encoding","gzip"),s=s.pipe(Afe({level:yfe.Z_BEST_SPEED})))}return s}catch(s){throw EE.error(s),s}}a(wfe,"handlePostRequest");bV.exports={authHandler:Ife,handlePostRequest:wfe,handleServerUncaughtException:bfe,serverErrorHandler:Ofe,reqBodyValidationHandler:Nfe}});var wV=N((TPe,IV)=>{"use strict";var Cfe=require("fastify-plugin"),{handlePostRequest:OV,authHandler:Dfe,reqBodyValidationHandler:Pfe}=LS();async function Lfe(e){e.decorate("hdbCore",{preValidation:[Pfe,Dfe],request:a(t=>NV(OV(t,response)),"request"),requestWithoutAuthentication:a((t,r)=>NV(OV(t,r,!0)),"requestWithoutAuthentication")})}a(Lfe,"hdbCore");async function NV(e){if(e=await e,e?.[Symbol.asyncIterator]&&!e[Symbol.iterator]){let t=[];for await(let r of e)t.push(r);return t}return e}a(NV,"convertAsyncIterators");IV.exports=Cfe(Lfe)});var DV=N((APe,CV)=>{"use strict";var RPe=require("fs"),MS=se();MS.initSync();var{CONFIG_PARAMS:$N}=M(),Mfe=1024*1024*1024;function Ufe(e){let t=MS.get($N.HTTP_TIMEOUT),r=MS.get($N.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:Mfe,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,maxParamLength:MS.get($N.HTTP_MAXPARAMLENGTH)??1e3,https:e}}a(Ufe,"getServerOptions");CV.exports=Ufe});var MV=N((bPe,LV)=>{"use strict";var VN=se();VN.initSync();var{CONFIG_PARAMS:PV}=M();function vfe(){let e=VN.get(PV.HTTP_CORSACCESSLIST),t=VN.get(PV.HTTP_CORS),r;return t&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},e&&e.length>0&&e[0]!==null&&e[0]!=="*"&&(r.origin=(n,s)=>s(null,e.indexOf(n)!==-1))),r}a(vfe,"getCORSOptions");LV.exports=vfe});var BV=N((NPe,vV)=>{"use strict";var UV=se();UV.initSync();var Bfe=M();function Hfe(){return UV.get(Bfe.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(Hfe,"getHeaderTimeoutConfig");vV.exports=Hfe});var YN={};je(YN,{customFunctionsServer:()=>Ffe,ready:()=>JV,start:()=>kfe});function kfe(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){Io||(Io=QV(t),it.http((await Io).server));let o=await Io,c=(0,KN.dirname)(s),l=(0,KN.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!HV.has(c)){HV.add(c);try{o.register(qfe(c,l))}catch(u){if(u.message==="Root plugin has already booted")mt.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw u}}},ready:JV}}async function Ffe(){try{mt.info("In Custom Functions Fastify server"+process.cwd()),mt.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),mt.debug(`Custom Functions server process ${process.pid} starting up.`),await Gfe();let e=$V.get(VV.CONFIG_PARAMS.HTTP_SECUREPORT)>0,t;try{t=Io=await QV(e)}catch(r){throw mt.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw mt.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){mt.error(`Custom Functions ${process.pid} Error: ${e}`),mt.error(e),process.exit(1)}}async function Gfe(){try{mt.info("Custom Functions starting configuration."),await KV.setUsersToGlobal(),mt.info("Custom Functions completed configuration.")}catch(e){mt.error(e)}}function qfe(e,t){return async function(r){try{mt.info("Custom Functions starting buildRoutes"),mt.trace("Loading fastify routes folder "+e),(0,xV.existsSync)(e)&&r.register(qV.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:mt.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?mt.error(s.message):s&&mt.error(s),o()})}catch(n){mt.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function QV(e){mt.info("Custom Functions starting buildServer.");let t=(0,YV.default)(e),r=(0,kV.default)(t);r.server.headersTimeout=(0,jV.default)(),r.setErrorHandler(zV.serverErrorHandler);let n=(0,WV.default)();return n&&r.register(FV.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,l){r.server.emit("unhandled",c.raw,l.raw)}),o()}),r.register(GV.default),await r.register(xfe),await r.after(),YO(r),mt.info("Custom Functions completed buildServer."),r}function JV(){if(Io)return Io.then?Io.then(e=>e.ready()):Io.ready()}var KN,xV,kV,FV,GV,qV,$V,VV,mt,xfe,KV,YV,WV,jV,zV,Io,HV,XV=Oe(()=>{KN=require("path"),xV=require("fs"),kV=L(require("fastify")),FV=L(require("@fastify/cors")),GV=L(_N()),qV=L(require("@fastify/autoload")),$V=L(se()),VV=L(M()),mt=L(W()),xfe=L(wV()),KV=L(xn()),YV=L(DV()),WV=L(MV()),jV=L(BV()),zV=L(LS());Wc();qr();HV=new Set;a(kfe,"start");a(Ffe,"customFunctionsServer");a(Gfe,"setUp");a(qfe,"buildRouteFolder");a(QV,"buildServer");a(JV,"ready")});var WN={};je(WN,{start:()=>$fe});function $fe(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,n1.default)(r,e);return e.server.http(async(s,i)=>{if(!s.isWebSocket)return new Promise(o=>n(s._nodeRequest,s._nodeResponse,()=>{o(i(s))}))}),!0}},handleFile(t,r,n){e1||(e1=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=ZV.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,t1.default)(s,(0,r1.realpathSync)(o))}}return i(s)},{runFirst:!0})),ZV.set(r,n)}}}var t1,r1,n1,ZV,e1,s1=Oe(()=>{t1=L(require("send")),r1=require("fs"),n1=L(require("serve-static")),ZV=new Map;a($fe,"start")});var JN={};je(JN,{Request:()=>jN,createReuseportFd:()=>US});var i1,jN,zN,QN,US,vS=Oe(()=>{i1=require("os"),jN=class{static{a(this,"Request")}#e;constructor(t,r){this.method=t.method;let n=t.url;this._nodeRequest=t,this._nodeResponse=r,this.url=n,this.headers=new QN(t.headers)}get absoluteURL(){return this.protocol+"://"+this.host+this.url}get pathname(){let t=this.url.indexOf("?");return t>-1?this.url.slice(0,t):this.url}set pathname(t){let r=this.url.indexOf("?");r>-1?this.url=t+this.url.slice(r):this.url=t}get protocol(){return this._nodeRequest.socket.encrypted?"https":"http"}get ip(){return this._nodeRequest.socket.remoteAddress}get authorized(){return this._nodeRequest.socket.authorized}get peerCertificate(){return this._nodeRequest.socket.getPeerCertificate()}get mtlsConfig(){return this._nodeRequest.socket.server.mtlsConfig}get body(){return this.#e||(this.#e=new zN(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}},zN=class{static{a(this,"RequestBody")}#e;constructor(t){this.#e=t}on(t,r){return this.#e.on(t,r),this}pipe(t,r){return this.#e.pipe(t,r)}},QN=class{constructor(t){this.asObject=t}static{a(this,"Headers")}set(t,r){this.asObject[t.toLowerCase()]=r}get(t){return this.asObject[t.toLowerCase()]}has(t){return this.asObject.hasOwnProperty(t.toLowerCase())}[Symbol.iterator](){return Object.entries(this.asObject)[Symbol.iterator]()}keys(){return Object.keys(this.asObject)}values(){return Object.values(this.asObject)}delete(t){delete this.asObject[t.toLowerCase()]}forEach(t){for(let[r,n]of this)t(n,r,this)}};(0,i1.platform)()!="win32"&&(US=require("node-unix-socket").createReuseportFd)});var ZN=N((MPe,o1)=>{"use strict";var hE=se();hE.initSync();var sd=require("fs-extra"),XN=require("path"),id=M(),Vfe=require("crypto"),Kfe=require("uuid").v4;o1.exports=Yfe;function Yfe(){if(hE.getHdbBasePath()!==void 0){let e=XN.join(hE.getHdbBasePath(),id.LICENSE_KEY_DIR_NAME,id.JWT_ENUM.JWT_PRIVATE_KEY_NAME),t=XN.join(hE.getHdbBasePath(),id.LICENSE_KEY_DIR_NAME,id.JWT_ENUM.JWT_PUBLIC_KEY_NAME),r=XN.join(hE.getHdbBasePath(),id.LICENSE_KEY_DIR_NAME,id.JWT_ENUM.JWT_PASSPHRASE_NAME);try{sd.accessSync(r),sd.accessSync(e),sd.accessSync(t)}catch(n){if(n.code==="ENOENT"){let s=Kfe(),i=Vfe.generateKeyPairSync("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem",cipher:"aes-256-cbc",passphrase:s}});sd.writeFileSync(r,s),sd.writeFileSync(e,i.privateKey),sd.writeFileSync(t,i.publicKey)}else throw n}}}a(Yfe,"checkJWTTokenExist")});var c1=N((vPe,a1)=>{"use strict";var eI=class{static{a(this,"HdbInfoInsertObject")}constructor(t,r,n){this.info_id=t,this.data_version_num=r,this.hdb_version_num=n}};a1.exports={HdbInfoInsertObject:eI}});var d1=N((HPe,u1)=>{"use strict";var l1=M(),tI=class{static{a(this,"UpgradeObject")}constructor(t,r){this[l1.UPGRADE_JSON_FIELD_NAMES_ENUM.DATA_VERSION]=t,this[l1.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION]=r}};u1.exports={UpgradeObject:tI}});var BS=N((kPe,f1)=>{"use strict";var Is=require("prompt"),od=require("chalk"),_1=W(),ii=require("os"),rI=Wa(),nI=["yes","y"];async function Wfe(e){let t=`${ii.EOL}`+od.bold.green("Your current HarperDB version requires that we complete an update process.")+`${ii.EOL}If a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${ii.EOL}${ii.EOL}You can read more about the changes in this upgrade at https://harperdb.io/developers/release-notes/${ii.EOL}`;Is.override=rI(["CONFIRM_UPGRADE"]),Is.start(),Is.message=t;let r={properties:{CONFIRM_UPGRADE:{description:od.magenta(`${ii.EOL}[CONFIRM_UPGRADE] Do you want to upgrade your HDB instance now? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"no",required:!0}}},n;try{n=await Is.get([r])}catch(s){return _1.error("There was an error when prompting user about an upgrade."),_1.error(s),!1}return nI.includes(n.CONFIRM_UPGRADE)}a(Wfe,"forceUpdatePrompt");async function jfe(e){let t=`${ii.EOL}`+od.bold.green(`Your installed HarperDB version is older than the version used to create your data. Downgrading is not recommended as it is not tested and guaranteed to work. However, if you need to downgrade, and a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${ii.EOL}`);Is.override=rI(["CONFIRM_DOWNGRADE"]),Is.start(),Is.message=t;let r={properties:{CONFIRM_DOWNGRADE:{description:od.magenta(`${ii.EOL}[CONFIRM_DOWNGRADE] Do you want to proceed with using your downgraded HDB instance now? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"no",required:!0}}},n=await Is.get([r]);return nI.includes(n.CONFIRM_DOWNGRADE)}a(jfe,"forceDowngradePrompt");async function zfe(){let e=`${ii.EOL}`+od.bold.green("We now require a Certifacte Authority certificate. HarperDB can generate all new certificates for you (your existing certificates will be backed up) or you can keep any existing certificates and add your own CA certificate. To add your own CA certificate set the <certificateAuthority> parameter in harperdb-config.yaml");Is.override=rI(["GENERATE_CERTS"]),Is.start(),Is.message=e;let t={properties:{GENERATE_CERTS:{description:od.magenta(`${ii.EOL}[GENERATE_CERTS] Do you want HarperDB to generate all new certificates? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"yes",required:!0}}},r=await Is.get([t]);return nI.includes(r.GENERATE_CERTS)}a(zfe,"upgradeCertsPrompt");f1.exports={forceUpdatePrompt:Wfe,forceDowngradePrompt:jfe,upgradeCertsPrompt:zfe}});var iI=N((GPe,E1)=>{"use strict";var sI=class{static{a(this,"UpgradeDirective")}constructor(t){this.version=t,this.sync_functions=[],this.async_functions=[]}};E1.exports=sI});var p1=N((WPe,h1)=>{"use strict";var Qfe=te(),Jfe=wt(),$Pe=W(),VPe=require("path"),KPe=require("fs"),YPe=M();h1.exports={getOldPropsValue:Xfe};function Xfe(e,t,r=!1){let n=t.getRaw(e);return Qfe.isNotEmptyAndHasValue(n)?n:r?Jfe.getDefaultConfig(e):""}a(Xfe,"getOldPropsValue")});var g1=N((zPe,T1)=>{"use strict";var Oa=require("path"),Na=require("fs-extra"),Zfe=require("properties-reader"),eEe=iI(),lr=W(),{getOldPropsValue:St}=p1(),{HDB_SETTINGS_NAMES:he,CONFIG_PARAMS:nl}=M(),sl=wt(),HS=se(),m1=te(),xi=M(),oI=new eEe("3.1.0"),S1=[];function tEe(){let e=Zfe(HS.get(he.SETTINGS_PATH_KEY)),t="Updating settings file for version 3.1.0";console.log(t),lr.info(t);let r=` ;Settings for the HarperDB process.
|
|
40
|
+
`},"serialize"),compressible:!1,q:.8});tn.set("application/x-www-form-urlencoded",{deserialize(e){let t={};for(let[r,n]of new URLSearchParams(e))if(t.hasOwnProperty(r)){let s=t[r];Array.isArray(s)?s.push(n):t.key=[s,n]}else t[r]=n},serialize(e){let t=new URLSearchParams;for(let r in e)t.set(r,e);return t.toString()}});F$={type:"application/json",serializeStream:Zd,serialize:iE,deserialize:N_e,q:.5};tn.set("*/*",F$);tn.set("",F$);a(N_e,"tryJSONParse");a(RN,"registerContentHandlers");I_e=require("fastify-plugin"),w_e=I_e(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=RS(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(RS,"findBestSerializer");v$=pN.default.get(mN.CONFIG_PARAMS.HTTP_COMPRESSIONTHRESHOLD);a(aE,"serialize");a(Wc,"serializeMessage");a(C_e,"streamToBuffer");D_e=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(P_e,"isBufferEncoding");a(L_e,"parseContentType");a(bo,"getDeserializer");a(M_e,"deserializerUnknownType");a(U_e,"transformIterable")});var yN={};je(yN,{start:()=>$_e});function v_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 q$(e){if(typeof e!="object"||e===null)throw new Ui("Request body must be an object.");if(!("query"in e))throw new Ui("Request body must contain a `query` field.");if(typeof e.query!="string")throw new Ui("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new Ui("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new Ui("Request body `operationName` field must be a string.")}function AN(e){return parseInt(e.value,10)}function V$(e){return parseFloat(e.value)}function K$(e,t,r){let n=r.get(e.name.value);return Y$(n)?W$(n,t):{attribute:t,value:n}}function Y$(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function W$(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],Y$(n)?W$(n,t):{attribute:t,value:n}))}function B_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:V$(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:t,value:e.value.value};case Le.Kind.VARIABLE:return K$(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=>B_e(n,t,r))}function H_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:V$(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Le.Kind.VARIABLE:return K$(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 x_e(e,t){return e.flatMap(r=>H_e(r,t))}function AS(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 AS(s.selectionSet,t)}case Le.Kind.INLINE_FRAGMENT:return AS(r.selectionSet,t)}})}function z$(e,t){return AS(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:z$(r.selectionSet,t)}:r.name.value)}async function k_e(e,t,r,n){let i=wi.getMatch(e.name.value,"graphql").Resource,o={select:z$(e.selectionSet,r),conditions:x_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 Q$(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]:Q$(r.value),...t}),{});case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new vr(`Value type, ${e.kind}, is not supported.`)}}function F_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=Q$(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 G_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=F_e(e.variableDefinitions,t),i=await Promise.all(AS(e.selectionSet,r).map(c=>k_e(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function $$({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(v_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 G_e(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function q_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 q$(r),$$(r,e)}case"POST":{let r=await bo(e.headers.get("content-type"),!0)(e._nodeRequest);return q$(r),$$(r,e)}default:throw new Ui("Method Not Allowed",405,{Allow:"GET, POST"})}}function $_e(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await q_e(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof Ui)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json",...n.headers}};if(n instanceof Le.GraphQLError)return{status:200,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/json"}};if(n instanceof vr)return{status:200,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};break}default:logger.info(`Unsupported accept header, ${s}, defaulting to application/graphql-response+json`);case"application/graphql-response+json":{if(n instanceof Ui)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json",...n.headers}};if(n instanceof Le.GraphQLError)return{status:400,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof vr)return{status:400,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};break}}throw n}})}var Le,vr,Ui,J$=Ne(()=>{Le=L(require("graphql"));jc();nu();a(v_e,"assertExecutableDefinitionNode");a(q$,"assertRequestParams");a(AN,"processIntValueNode");a(V$,"processFloatValueNode");a(K$,"processVariableNode");a(Y$,"isObject");a(W$,"transformObjectIntoQueryCondition");a(B_e,"processObjectFieldNode");a(j$,"processObjectValueNode");a(H_e,"processArgumentNode");a(x_e,"buildConditionsQuery");a(AS,"fillInFragments");a(z$,"buildSelectQuery");a(k_e,"processFieldNode");a(Q$,"processConstValueNode");a(F_e,"resolveVariables");a(G_e,"executeOperation");a($$,"resolver");vr=class extends Error{static{a(this,"GraphQLQueryingError")}},Ui=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a(q_e,"graphqlQueryingHandler");a($_e,"start")});var bN={};je(bN,{start:()=>eV,startOnMainThread:()=>Y_e});function eV({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,X$.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(V_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 K_e(i)}}}async function K_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,Z$.isEqual)(i,e)?void 0:(e.id=r.id,(0,yS.alterRole)(e))}return(0,yS.addRole)(e)}var yS,X$,Z$,V_e,Y_e,tV=Ne(()=>{Pe();yS=L(lf()),X$=require("yaml"),Z$=require("lodash"),V_e=["super_user","cluster_user","structure_user"];a(eV,"start");a(K_e,"ensureRole");Y_e=eV});async function bS(e){let t=(0,sV.pathToFileURL)(e).toString();return W_e?(cE||(cE=j_e(Q_e)),(await(await cE).import(t)).namespace):import(t)}async function j_e(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),cE=new Compartment({console,Math,Date,fetch:z_e,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,nV.extname)(r)||(r+=".js"),r)},importHook:a(async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Lr,tables:jn,databases:We})}};let n=await(0,rV.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),cE}function z_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 Q_e(){return{Resource:Lr,tables:jn}}var rV,nV,sV,W_e,cE,ON=Ne(()=>{Vs();Pe();rV=require("fs/promises"),nV=require("path"),sV=require("url"),W_e=!1;a(bS,"secureImport");a(j_e,"getCompartment");a(z_e,"secureOnlyFetch");a(Q_e,"getGlobalVars")});var IN={};je(IN,{handleFile:()=>J_e});async function J_e(e,t,r,n){let s=new Map,i=await bS(r);c(i.default)&&n.set((0,NN.dirname)(t),i.default),o(i,(0,NN.dirname)(t));function o(l,u){for(let d in l){let _=l[d];c(_)?n.set(u+"/"+d,_):typeof _=="object"&&o(_,u+"/"+d)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var NN,iV=Ne(()=>{ON();NN=require("path");a(J_e,"handleFile")});var CN={};je(CN,{start:()=>X_e});function X_e({resources:e}){e.set("login",wN),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var wN,oV=Ne(()=>{Vs();a(X_e,"start");wN=class extends Lr{static{a(this,"Login")}static async get(t,r,n){}static async post(t,r,n){let{username:s,password:i,redirect:o}=r;return{data:await n.login(s,i)}}}});function PN(e,t,r,n,s,i,o,c){let l=e[0];if(t==="or"){let _=u(l);for(let f=1;f<e.length;f++){let h=e[f],T=u(h);_=_.concat(T)}let E=new Set;return _.filter(f=>{let h=f.key??f;return E.has(h)?!1:(E.add(h),!0)})}else{let _=u(l),E=d(e.slice(1),!0,l.estimated_count);return E.length>0?o(_,E):_}function u(_){return _.conditions?PN(_.conditions,_.operator,r,n,s,i,o,c):rd(_,n,_.descending||s.reverse===!0,r,s.allowFullScan,c)}a(u,"executeCondition");function d(_,E,f){return _.map((h,T)=>{if(h.conditions){let S=h.operator==="or",b=d(h.conditions,!S,f);return S?(I,B)=>b.some(H=>H(I,B)):(I,B)=>b.every(H=>H(I,B))}let m=(h.attribute||h[0])===r.primaryKey,g=dE(h,r,i,c,m,f);return E&&T<_.length-1&&f&&(f=afe(r.primaryStore,h.estimated_count,f)),g}).filter(Boolean)}a(d,"mapConditionsToFilters")}function rd(e,t,r,n,s,i){let o=e[0]??e.attribute,c=e[1]??e.value,l=e.comparator;if(c===void 0&&l!=="sort")throw new On.ClientError(`Search condition for ${o} must have a value`);if(Array.isArray(o)){let S=o[0],b=Bi(n.attributes,S);if(b.relationship){if(o.length<2)throw new On.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let I=b.definition?.tableClass||b.elements?.definition?.tableClass,B=new Map,H=rd({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,I,s,B);if(b.relationship.to){i[o[0]]=B;let X=!!Bi(I.attributes,b.relationship.to)?.elements;H=nfe(H,b,I.primaryStore,X,B)}if(b.relationship.from){let X=a(Y=>(Y?.key!==void 0&&(Y=Y.key),rd({attribute:b.relationship.from,value:Y},t,r,n,s,B)),"searchEntry");b.elements?(i[o[0]]=B,H=sfe(H,b,I.primaryStore,B,X)):H=H.flatMap(X)}return H}else if(o.length===1)o=o[0];else throw new On.ClientError("Unable to query by attribute "+JSON.stringify(o))}let u,d,_,E;c instanceof Date&&(c=c.getTime());let f;switch(LN[l]||l){case"lt":u=!0,d=c;break;case"le":u=!0,d=c,_=!0;break;case"gt":u=c,E=!0;break;case"ge":u=c;break;case"prefix":Array.isArray(c)?c[c.length-1]!=null&&(c=c.concat(null)):c=[c,null],u=c,d=c.slice(0),d[d.length-1]=vi.MAXIMUM_KEY;break;case"starts_with":u=c.toString(),d=c+"\uFFFF";break;case"between":case"gele":case"gelt":case"gtlt":case"gtle":u=c[0],u instanceof Date&&(u=u.getTime()),d=c[1],d instanceof Date&&(d=d.getTime()),_=l==="gele"||l==="gtle"||l==="between",E=l==="gtlt"||l==="gtle";break;case"equals":case void 0:u=c,d=c,_=!0;break;case"ne":if(c===null){u=c,E=!0;break}case"sort":case"contains":case"ends_with":u=!0,f=!0;break;default:throw new On.ClientError(`Unknown query comparator "${l}"`)}let h,T=o===n.primaryKey||o==null;if(typeof u=="string"&&u.length>Os.MAX_SEARCH_KEY_LENGTH&&(u=u.slice(0,Os.MAX_SEARCH_KEY_LENGTH)+Os.OVERFLOW_MARKER,E=!1,h=dE(e,n,null,i,T)),typeof d=="string"&&d.length>Os.MAX_SEARCH_KEY_LENGTH&&(d=d.slice(0,Os.MAX_SEARCH_KEY_LENGTH)+Os.OVERFLOW_MARKER,_=!0,h=h??dE(e,n,null,i,T)),r){let S=u;u=d,d=S,S=!E,E=!_,_=S}let m=T?n.primaryStore:n.indices[o];if(!m||m.isIndexing||f||c===null&&!m.indexNulls){if(s===!1&&!m)throw new On.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&f)throw new On.ClientError(`Can not use ${l||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(m?.isIndexing)throw new On.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&m&&!m.indexNulls)throw new On.ClientError(`"${o}" is not indexed for nulls, index needs to be rebuilt to search for nulls, can not search for this attribute`,400);if(h=h??dE(e,n,null,i,T),!h)throw new On.ClientError(`Unknown search operator ${e.comparator}`)}let g={start:u,end:d,inclusiveEnd:_,exclusiveStart:E,values:!0,versions:T,transaction:t,reverse:r};if(T){let S=m.getRange(g).map(h?function({key:b,value:I}){return this?.isSync?I&&h(I)?b:Ra.SKIP:new Promise((B,H)=>setImmediate(()=>{try{B(I&&h(I)?b:Ra.SKIP)}catch(X){H(X)}}))}:b=>b.value==null&&!(b.metadataFlags&(Ns|ya))?Ra.SKIP:b);return S.hasEntries=!0,S}else return m?m.getRange(g).map(h?function({key:S,value:b}){let I;return typeof S=="string"&&S.length>Os.MAX_SEARCH_KEY_LENGTH?I=n.primaryStore.get(b):I={[o]:S},this.isSync?h(I)?b:Ra.SKIP:new Promise((B,H)=>setImmediate(()=>{try{B(h(I)?b:Ra.SKIP)}catch(X){H(X)}}))}:({value:S})=>S):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:S,value:b}){return this.isSync?b&&h(b)?S:Ra.SKIP:new Promise((I,B)=>setImmediate(()=>{try{I(b&&h(b)?S:Ra.SKIP)}catch(H){B(H)}}))})}function Bi(e,t){if(Array.isArray(t))if(t.length>1){let r=Bi(e,t[0]),n=(r?.definition?.tableClass||r?.elements?.definition?.tableClass)?.attributes??r?.properties;return n?Bi(n,t.slice(1)):void 0}else t=t.toString();else typeof t!="string"&&(t=t.toString());return e.find(r=>r.name===t)}function nfe(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 sfe(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i,o,c=new Set;return{next(){let l;if(o)for(;l=o.next(),!l.done;){let u=l.value;if(!c.has(u))return c.add(u),l}if(!i){let u=new Set;n.fromRecord=d=>d[t.relationship.from]?.filter?.(_=>u.has(_));for(let d of e){if(n.filters){let _=r.get(d);if(n.filters.some(E=>!E(_)))continue}u.add(d)}return i=u[Symbol.iterator](),this.next()}do{let u=i.next();return u.done?u:(o=s(u.value)[Symbol.iterator](),this.next())}while(!0)},return(){return o?.return?.()},throw(){return o?.throw?.()}}}})}function dE(e,t,r,n,s,i){let o=e.comparator,c=e[0]??e.attribute,l=e[1]??e.value;if(Array.isArray(c)){if(c.length===0)return()=>!0;if(c.length===1)c=c[0];else if(c.length>1){let d=c[0],_=Bi(t.attributes,d),E=_.definition?.tableClass||_.elements.definition?.tableClass,f=n?.[d],h=dE({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:o},E,r,f?.[d]?.joined,c[1]===E.primaryKey,i);if(!h)return;if(f){f.filters||(f.filters=[]),f.filters.push(h);return}let T=t.propertyResolvers?.[d],m,g=a((S,b)=>{let I,B;if(T){if(T.from&&h.idFilter){if(!m)if(h.idFilter.idSet?.size===1){for(let X of h.idFilter.idSet)e={attribute:T.from,value:X};m=u(T.from,h.idFilter,!0,!0)}else m=u(T.from,h.idFilter,!1,!0);let H=m(S);return m.idFilter&&(g.idFilter=m.idFilter),H}B=T(S,r,b),I=B?.value}else I=S[d];return I?Array.isArray(I)?I.some(h):h(I,B):!1},"recordFilter");return g}}switch(l instanceof Date&&(l=l.getTime()),LN[o]||o){case Os.SEARCH_TYPES.EQUALS:case void 0:return u(c,d=>d===l,!0);case"contains":return u(c,d=>d?.toString().includes(l));case"ends_with":return u(c,d=>d?.toString().endsWith(l));case"starts_with":return u(c,d=>typeof d=="string"&&d.startsWith(l),!0);case"prefix":return Array.isArray(l)?l[l.length-1]==null&&(l=l.slice(0,-1)):l=[l],u(c,d=>{if(!Array.isArray(d))return!1;for(let _=0,E=l.length;_<E;_++)if(d[_]!==l[_])return!1;return!0},!0);case"between":return l[0]instanceof Date&&(l[0]=l[0].getTime()),l[1]instanceof Date&&(l[1]=l[1].getTime()),u(c,d=>(0,vi.compareKeys)(d,l[0])>=0&&(0,vi.compareKeys)(d,l[1])<=0,!0);case"gt":return u(c,d=>(0,vi.compareKeys)(d,l)>0);case"ge":return u(c,d=>(0,vi.compareKeys)(d,l)>=0);case"lt":return u(c,d=>(0,vi.compareKeys)(d,l)<0);case"le":return u(c,d=>(0,vi.compareKeys)(d,l)<=0);case"ne":return u(c,d=>(0,vi.compareKeys)(d,l)!==0,!1,!0);case"sort":return()=>!0;default:throw new On.ClientError(`Unknown query comparator "${o}"`)}function u(d,_,E,f){let h;E=E&&!s&&t?.indices[d]&&i>3,E&&(e.estimated_count==null&&NS(t)(e),h=e.estimated_count>>4,(isNaN(h)||h>=i)&&(E=!1));let T=0,m=3;function g(S){let b=S[d],I;if(typeof b!="object"||!b||f?I=_(b):Array.isArray(b)?I=b.some(_):b instanceof Date&&(I=_(b.getTime())),E&&(m++,!I&&!g.idFilter&&++T/m*(i-m)>h)){let B=rd(e,r.transaction.getReadTxn(),!1,t).map(nd),H=new Set(B);g.idFilter=X=>H.has(nd(X)),g.idFilter.idSet=H}return I}return a(g,"recordFilter"),s&&(g.idFilter=_),g}a(u,"attributeComparator")}function NS(e){function t(r){if(r.estimated_count===void 0){if(r.conditions){let s;if(r.operator==="or"){s=0;for(let i of r.conditions)t(i),s+=i.estimated_count}else{s=1/0;for(let i of r.conditions)t(i),s=isFinite(s)?s*i.estimated_count/Oo(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=LN[n]||n,n===Os.SEARCH_TYPES.EQUALS||!n){let s=r[0]??r.attribute;if(s==null||s===e.primaryKey)r.estimated_count=1;else if(Array.isArray(s)&&s.length>1){let i=Bi(e.attributes,s[0]),o=i.definition?.tableClass||i.elements.definition?.tableClass,c=NS(o)({value:r.value,attribute:s.length>2?s.slice(1):s[1],comparator:"equals"}),l=e.indices[i.relationship.from];r.estimated_count=c+(l?c*Oo(e.indices[i.relationship.from])/(Oo(o.primaryStore)||1):c)}else{let i=e.indices[s];r.estimated_count=i?i.getValuesCount(r[1]??r.value):1/0}}else if(n==="contains"||n==="ends_with"||n==="ne"){let s=r[0]??r.attribute,i=e.indices[s];r.value===null&&n==="ne"?r.estimated_count=Oo(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=tfe*Oo(e.primaryStore)+1:n==="between"?r.estimated_count=efe*Oo(e.primaryStore)+1:n==="sort"?r.estimated_count=Oo(e.primaryStore)+1:r.estimated_count=Z_e*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(Aa=e,ed.lastIndex=0,ife.test(e))try{let t=lE(new td,"");if(bn!==Aa.length)throw new SyntaxError("Unable to parse query, unexpected end of query");return t}catch(t){throw t.statusCode=400,t.message=`Unable to parse query, ${t.message} at position ${bn} in '${Aa}'`,t}else return new URLSearchParams(e)}function lE(e,t){let r=ed,n,s,i,o,c,l=decodeURIComponent,u;for(;n=r.exec(Aa);){bn=r.lastIndex;let[,d,_]=n;if(o){if(d)throw new SyntaxError(`expected operator, but encountered '${d}'`);o=!1,c=!1}else c=!0;let E;switch(_){case"=":if(s!=null){if(d.length<=2)i=d;else throw new SyntaxError(`invalid FIQL operator ${d}`);l=aV}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=rfe[_],l=DN[i]?aV: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"&&cV(h,d),s===""){let T=e.conditions[e.conditions.length-1];T.chainedConditions=T.chainedConditions||[],T.chainedConditions.push(h),T.operator=u}else OS(e,u),e.conditions.push(h)}_==="&"?(u="and",s=void 0):_==="|"?(u="or",s=void 0):_==="&="?(u="and",s=""):_==="|="&&(u="or",s="");break;case",":if(e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");e.push(uE(d)),s=void 0;break;case"(":ed.lastIndex=bn;let f=lE(d?[]:new td,")");switch(d){case"":OS(e,u),e.conditions.push(f);break;case"limit":switch(f.length){case 1:e.limit=+f[0];break;case 2:e.offset=+f[0],e.limit=f[1]-e.offset;break;default:throw new SyntaxError("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(f[0])&&f.length===1&&!f[0].name?(e.select=f[0],e.select.asArray=!0):f.length===1?e.select=f[0]:f.length===2&&f[1]===""?e.select=f.slice(0,1):e.select=f;break;case"group-by":throw new SyntaxError("group by is not implemented yet");case"sort":e.sort=lV(f);break;default:throw new SyntaxError(`unknown query function call ${d}`)}Aa[bn]===","?r.lastIndex=++bn:o=!0,s=null;break;case"{":if(e.conditions)throw new SyntaxError("property sets are not allowed in a queries");if(!d)throw new SyntaxError("property sets must have a defined parent property name");ed.lastIndex=bn,E=lE([],"}"),E.name=d,e.push(E),Aa[bn]===","?r.lastIndex=++bn:o=!0;break;case"[":ed.lastIndex=bn,d?(E=lE(new td,"]"),E.name=d):E=lE(e.conditions?new td:[],"]"),e.conditions?(OS(e,u),e.conditions.push(E),s=null):e.push(E),Aa[bn]===","?r.lastIndex=++bn:o=!0;break;case")":case"]":case"}":if(t===_[0]){if(e.conditions){if(s){let h={comparator:i||"equals",attribute:s,value:l(d)};i==="eq"&&cV(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?ofe:ed,r.lastIndex=bn),bn===Aa.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 aV(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 cV(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 lV(e){let t=uV(e[0]);return e.length>1&&(t.next=lV(e.slice(1))),t}function uV(e){if(Array.isArray(e)){let t=uV(e[0]);return e[0]=t.attribute,t.attribute=e,t}if(typeof e=="string")switch(e[0]){case"-":return{attribute:e.slice(1),descending:!0};case"+":return{attribute:e.slice(1),descending:!1};default:return{attribute:e,descending:!1}}throw new SyntaxError(`Unknown sort type ${e}`)}function nd(e){return Array.isArray(e)?e.join("\0"):e}function Oo(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function afe(e,t,r){return t*r/Oo(e)}var On,Os,vi,Ra,Z_e,efe,tfe,rfe,DN,LN,ife,ed,ofe,bn,Aa,td,il,_E=Ne(()=>{On=L(_e()),Os=L(Bt()),vi=require("ordered-binary"),Ra=require("lmdb");$f();Z_e=.3,efe=.1,tfe=.05,rfe={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},DN={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(PN,"executeConditions");a(rd,"searchByIndex");a(Bi,"findAttribute");a(nfe,"joinTo");a(sfe,"joinFrom");LN={eq:"equals",greater_than:"gt",greaterThan:"gt",greater_than_equal:"ge",greaterThanEqual:"ge",less_than:"lt",lessThan:"lt",less_than_equal:"le",lessThanEqual:"le",not_equal:"ne",notEqual:"ne",equal:"equals",sw:"starts_with",startsWith:"starts_with",ew:"ends_with",endsWith:"ends_with",ct:"contains",">":"gt",">=":"ge","<":"lt","<=":"le","...":"between"};a(dE,"filterByType");a(NS,"estimateCondition");ife=/[()[\]|!<>.]|(=\w*=)/,ed=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,ofe=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(IS,"parseQuery");a(lE,"parseBlock");a(OS,"assignOperator");a(uE,"decodeProperty");a(aV,"typedDecoding");a(cV,"wildcardDecoding");a(lV,"toSortObject");a(uV,"toSortEntry");td=class{static{a(this,"Query")}constructor(){this.conditions=[]}[Symbol.iterator](){return this.conditions[Symbol.iterator]()}get(t){for(let r=0;r<this.conditions.length;r++){let n=this.conditions[r];if(n.attribute===t)return n.value}}};a(nd,"flattenKey");a(Oo,"estimatedEntryCount");a(afe,"intersectionEstimate");il=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});function hV(e){let t={openapi:cfe,info:{title:"HarperDB HTTP REST interface",version:(0,EV.version)()},paths:{},components:{schemas:{},securitySchemes:{basicAuth:{type:"http",scheme:"basic"},bearerAuth:{type:"http",scheme:"bearer",bearerFormat:"JWT"}}}},r=[{basicAuth:[],bearerAuth:[]}];for(let[,n]of e){if(!n.path||n.Resource.isError)continue;let{path:s}=n,i=s.split("/").slice(-1),{attributes:o,primaryKey:c,prototype:l}=n.Resource;if(c=c??"id",!c)continue;let u={},d=[];if(o)for(let{type:b,name:I,elements:B,relationship:H,definition:X}of o){if(H)b==="array"?u[I]={type:"array",items:{$ref:ba+B.type}}:u[I]={$ref:ba+b};else{let Y=X??B?.definition;if(Y){if(!t.components.schemas[Y.type]){let V={};Y.properties.forEach(ne=>{V[ne.name]=new BN(MN[ne.type],ne.type)}),t.components.schemas[Y.type]=new fV(V)}b==="array"?u[I]={type:"array",items:{$ref:ba+Y.type}}:u[I]={$ref:ba+Y.type}}else b==="array"?B.type==="Any"||B.type=="ID"?u[I]={type:"array",items:{format:B.type}}:u[I]={type:"array",items:new BN(MN[B.type],B.type)}:b==="Any"||b=="ID"?u[I]={format:b}:u[I]=new BN(MN[b],b)}d.push(new HN(I,"query",u[I]))}let _=Object.keys(u),E=new HN(c,"path",{format:"ID"});E.required=!0,E.description="primary key of record";let f=new HN("property","path",{enum:_});f.required=!0,t.components.schemas[i]=new fV(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 lfe(i,r,"create a new record auto-assigning a primary key")),m&&(t.paths[S]||(t.paths[S]={}),t.paths[S].get=new UN(d,r,{200:new vN({$ref:ba+i})},"search for records by the specified property name and value pairs")),g&&(t.paths[S]||(t.paths[S]={}),t.paths[S].delete=new _V(d,r,"delete all the records that match the provided query",{204:new dV})),S="/"+s+"/{"+c+"}",m&&(t.paths[S]={},t.paths[S].get=new UN([E],r,{200:new vN({$ref:ba+i})},"retrieve a record by its primary key")),T&&(t.paths[S]||(t.paths[S]={}),t.paths[S].put=new ufe([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 _V([E],r,"delete a record with the given primary key",{204:new dV})),m&&f.schema.enum.length>0&&(S="/"+s+"/{"+c+"}.{property}",t.paths[S]={},t.paths[S].get=new UN([E,f],r,{200:new vN({enum:_})},"used to retrieve the specified property of the specified record"))}return t}function lfe(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:ba+e}}}},this.security=t,this.responses={200:{description:xN,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function UN(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function vN(e){this.description=xN,this.content={"application/json":{schema:e}}}function dV(){this.description="successfully processed request, no content returned to client"}function ufe(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:ba+r}}}},this.responses={200:{description:xN}}}function _V(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function fV(e){this.type="object",this.properties=e}function BN(e,t){this.type=e,this.format=t}function HN(e,t,r){this.name=e,this.in=t,this.schema=r}var EV,cfe,MN,ba,xN,pV=Ne(()=>{EV=L(vc()),cfe="3.0.3",MN={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},ba="#/components/schemas/",xN="successful operation";a(hV,"generateJsonApi");a(lfe,"Post");a(UN,"Get");a(vN,"Response200");a(dV,"Response204");a(ufe,"Put");a(_V,"Delete");a(fV,"ResourceSchema");a(BN,"Type");a(HN,"Parameter")});var CS={};je(CS,{parseHeaderValue:()=>FN,start:()=>ffe});async function _fe(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!==mV){let m=wS.getMatch(o,n?"sse":"rest");if(!m)return t(e);e.handlerPath=m.path,c=new il(m.relativeURL),c.async=!0,l=m.Resource}if(l?.isCaching){let m=r["cache-control"];if(m){let g=FN(m);for(let S of g)switch(S.name){case"max-age":e.expiresAt=S.value*1e3+Date.now();break;case"only-if-cached":e.onlyIfCached=!0;break;case"no-cache":e.noCache=!0;break;case"no-store":e.noCacheStore=!0;break;case"stale-if-error":e.staleIfError=!0;break;case"must-revalidate":e.mustRevalidate=!0;break}}}let u=r["x-replicate-to"];if(u){let m=FN(u).map(g=>(g.next?.name==="confirm"&&g.next.value>=0&&(e.replicatedConfirmation=+g.next.value),g.name));e.replicateTo=m.length===1&&+m[0]>=0?+m[0]:m[0]==="*"?void 0:m}r["x-replicate-from"]==="none"&&(e.replicateFrom=!1);let _=await Dt(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=bo(r["content-type"],!0)(e.body,e.headers)}catch(m){throw new sd.ClientError(m,400)}if(e.authorize=!0,o===mV&&s==="GET"){if(e?.user?.role?.permission?.super_user)return hV(wS);throw new sd.ServerError("Forbidden",403)}switch(s){case"GET":case"HEAD":return l.get(c,e);case"POST":return l.post(c,e.data,e);case"PUT":return l.put(c,e.data,e);case"DELETE":return l.delete(c,e);case"PATCH":return l.patch(c,e.data,e);case"OPTIONS":i.setIfNone("Allow","GET, HEAD, POST, PUT, DELETE, PATCH, OPTIONS, TRACE, QUERY, COPY, MOVE");return;case"CONNECT":return l.connect(c,null,e);case"TRACE":return"HarperDB is the terminating server";case"QUERY":return l.query(c,e.data,e);case"COPY":return l.copy(c,r.destination,e);case"MOVE":return l.move(c,r.destination,e);case"BREW":throw new sd.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new sd.ServerError(`Method ${s} is not recognized`,501)}}),E=200,f;if(_==null)E=s==="GET"||s==="HEAD"?404:204,kN.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(_.status>0&&_.headers){let m=hO(_.headers,i);return _.headers!==m&&(_.headers=m),_.data!==void 0&&(_.body=aE(_.data,e,_)),_}else if(f=e.lastModified){dfe[0]=f;let m=String.fromCharCode(34,(Br[0]&63)+62,(Br[0]>>6)+(Br[1]<<2&63)+62,(Br[1]>>4)+(Br[2]<<4&63)+62,(Br[2]>>2)+62,(Br[3]&63)+62,(Br[3]>>6)+(Br[4]<<2&63)+62,(Br[4]>>4)+(Br[5]<<4&63)+62,(Br[5]>>2)+62,(Br[6]&63)+62,(Br[6]>>6)+(Br[7]<<2&63)+62,34),g=r["if-none-match"];g&&m==g?(_?.onDone&&_.onDone(),E=304,_=void 0):i.setIfNone("ETag",m),kN.lastModified&&i.setIfNone("Last-Modified",new Date(f).toUTCString())}e.createdResource&&(E=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let h={status:E,headers:i,body:void 0},T=_?.wasLoadedFromSource?.();return T!==void 0&&(h.wasCacheMiss=T,!T&&f&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||f))/1e3))),_!==void 0&&(h.body=aE(_,e,h),s==="HEAD"&&(h.body=void 0)),h}catch(o){o.statusCode?o.statusCode===500?Hi.warn(o):Hi.info(o):Hi.error(o),o.statusCode===405&&(o.method&&(o.message+=` to handle HTTP method ${o.method.toUpperCase()||""}`),o.allow&&(o.allow.push("trace","head","options"),i.setIfNone("Allow",o.allow.map(l=>l.toUpperCase()).join(", "))));let c={status:o.statusCode||500,headers:i,body:void 0};return c.body=aE(o.contentType?o:o.toString(),e,c),c}}function ffe(e){kN=e,!SV&&(SV=!0,wS=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return _fe(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{fE++;let s=new Mn;TV||(TV=!0,k_(l=>{fE>0&&l.push({metric:"ws-connections",connections:fE,byThread:!0})}));let i;t.on("error",l=>{i=!0,Hi.warn(l)});let o;t.on("message",a(function(u){o||(o=bo(r.requestedContentType??r.headers.asObject["content-type"],!1));let d=o(u);s.push(d)},"message"));let c;t.on("close",()=>{fE--,qn(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),u=wS.getMatch(l,"ws");if(qn(!!u,"connection","ws","connect"),u){r.handlerPath=u.path,pr(h=>({count:h.count,total:fE}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let d=new il(u.relativeURL),_=u.Resource;c=(await Dt(r,()=>_.connect(d,s,r)))[Symbol.asyncIterator]();let f;for(;!(f=await c.next()).done;){let h=Wc(f.value,r);t.send(h),pr(h.length,"bytes-sent",r.handlerPath,"message","ws")}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){l.statusCode?l.statusCode===500?Hi.warn(l):Hi.info(l):Hi.error(l),t.close(Efe[l.statusCode]||1011,l.toString())}t.close()},e))}function FN(e){return e.trim().split(",").map(t=>{let r,n=t.trim().split(";"),s;for(;s=n.pop();)if(s.includes("=")){let[i,o]=s.trim().split("=");i=i.trim(),o&&(o=o.trim()),r={name:i.toLowerCase(),value:o,next:r}}else r={name:s.toLowerCase(),next:r};return r})}var Hi,sd,Br,dfe,kN,mV,SV,wS,TV,fE,Efe,gV=Ne(()=>{jc();Ni();Hi=L(W()),sd=L(_e());_E();Pl();mc();Bf();pV();_E();Br=new Uint8Array(8),dfe=new Float64Array(Br.buffer,0,1),kN={},mV="openapi";a(_fe,"http");fE=0;a(ffe,"start");Efe={401:3e3,403:3003};a(FN,"parseHeaderValue")});var GN=N((mPe,AV)=>{var{recordAction:DS,recordActionBinary:RV}=(Ni(),oe(F_)),hfe=require("fastify-plugin"),pfe=200;AV.exports=hfe(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),RV(s.raw.statusCode<400,"success",u,_,d),RV(1,"response_"+s.raw.statusCode,u,_,d);let E=pfe;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((SPe,OV)=>{"use strict";var qN=M(),mfe=te(),EE=W(),{handleHDBError:$N,hdb_errors:PS}=_e(),{isMainThread:Sfe}=require("worker_threads"),{Readable:Tfe}=require("stream"),yV=require("os"),gfe=require("util"),Rfe=cb(),Afe=gfe.promisify(Rfe.authorize),bV=tN(),{createGzip:yfe,constants:bfe}=require("zlib");function Ofe(e){let t=`Found an uncaught exception with message: ${e.message}. ${yV.EOL}Stack: ${e.stack} ${yV.EOL}Terminating ${Sfe?"HDB":"thread"}.`;console.error(t),EE.fatal(t),process.exit(1)}a(Ofe,"handleServerUncaughtException");function Nfe(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(Nfe,"serverErrorHandler");function Ife(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=$N(new Error,"Invalid JSON.",PS.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(mfe.isEmpty(e.body.operation)){let n=$N(new Error,"Request body must include an 'operation' property.",PS.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(Ife,"reqBodyValidationHandler");function wfe(e,t,r){let n;e.body.operation!==qN.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.body.operation!==qN.OPERATIONS_ENUM.LOGIN&&e.body.operation!==qN.OPERATIONS_ENUM.LOGOUT?Afe(e,t).then(s=>{n=s,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(s=>{EE.warn(s),EE.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${s.stack}"`);let i=typeof s=="string"?{error:s}:{error:s.message};r($N(s,i,PS.HTTP_STATUS_CODES.UNAUTHORIZED),null)}):(e.body.hdb_user=null,e.body.hdb_auth_header=e.headers.authorization,e.body.baseRequest=e.raw?.baseRequest,e.body.baseResponse=t.raw?.baseResponse,e.body.fastifyResponse=t,r())}a(wfe,"authHandler");async function Cfe(e,t,r=!1){let n;try{e.body.bypass_auth&&delete e.body.bypass_auth,n=bV.chooseOperation(e.body);let s=await bV.processLocalTransaction(e,n);if(s instanceof Tfe&&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(yfe({level:bfe.Z_BEST_SPEED})))}return s}catch(s){throw EE.error(s),s}}a(Cfe,"handlePostRequest");OV.exports={authHandler:wfe,handlePostRequest:Cfe,handleServerUncaughtException:Ofe,serverErrorHandler:Nfe,reqBodyValidationHandler:Ife}});var CV=N((gPe,wV)=>{"use strict";var Dfe=require("fastify-plugin"),{handlePostRequest:NV,authHandler:Pfe,reqBodyValidationHandler:Lfe}=LS();async function Mfe(e){e.decorate("hdbCore",{preValidation:[Lfe,Pfe],request:a(t=>IV(NV(t,response)),"request"),requestWithoutAuthentication:a((t,r)=>IV(NV(t,r,!0)),"requestWithoutAuthentication")})}a(Mfe,"hdbCore");async function IV(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(IV,"convertAsyncIterators");wV.exports=Dfe(Mfe)});var PV=N((yPe,DV)=>{"use strict";var APe=require("fs"),MS=se();MS.initSync();var{CONFIG_PARAMS:VN}=M(),Ufe=1024*1024*1024;function vfe(e){let t=MS.get(VN.HTTP_TIMEOUT),r=MS.get(VN.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:Ufe,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,maxParamLength:MS.get(VN.HTTP_MAXPARAMLENGTH)??1e3,https:e}}a(vfe,"getServerOptions");DV.exports=vfe});var UV=N((OPe,MV)=>{"use strict";var KN=se();KN.initSync();var{CONFIG_PARAMS:LV}=M();function Bfe(){let e=KN.get(LV.HTTP_CORSACCESSLIST),t=KN.get(LV.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(Bfe,"getCORSOptions");MV.exports=Bfe});var HV=N((IPe,BV)=>{"use strict";var vV=se();vV.initSync();var Hfe=M();function xfe(){return vV.get(Hfe.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(xfe,"getHeaderTimeoutConfig");BV.exports=xfe});var WN={};je(WN,{customFunctionsServer:()=>Gfe,ready:()=>XV,start:()=>Ffe});function Ffe(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){No||(No=JV(t),it.http((await No).server));let o=await No,c=(0,YN.dirname)(s),l=(0,YN.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!xV.has(c)){xV.add(c);try{o.register($fe(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:XV}}async function Gfe(){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 qfe();let e=VV.get(KV.CONFIG_PARAMS.HTTP_SECUREPORT)>0,t;try{t=No=await JV(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 qfe(){try{mt.info("Custom Functions starting configuration."),await YV.setUsersToGlobal(),mt.info("Custom Functions completed configuration.")}catch(e){mt.error(e)}}function $fe(e,t){return async function(r){try{mt.info("Custom Functions starting buildRoutes"),mt.trace("Loading fastify routes folder "+e),(0,kV.existsSync)(e)&&r.register($V.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 JV(e){mt.info("Custom Functions starting buildServer.");let t=(0,WV.default)(e),r=(0,FV.default)(t);r.server.headersTimeout=(0,zV.default)(),r.setErrorHandler(QV.serverErrorHandler);let n=(0,jV.default)();return n&&r.register(GV.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,l){r.server.emit("unhandled",c.raw,l.raw)}),o()}),r.register(qV.default),await r.register(kfe),await r.after(),RN(r),mt.info("Custom Functions completed buildServer."),r}function XV(){if(No)return No.then?No.then(e=>e.ready()):No.ready()}var YN,kV,FV,GV,qV,$V,VV,KV,mt,kfe,YV,WV,jV,zV,QV,No,xV,ZV=Ne(()=>{YN=require("path"),kV=require("fs"),FV=L(require("fastify")),GV=L(require("@fastify/cors")),qV=L(GN()),$V=L(require("@fastify/autoload")),VV=L(se()),KV=L(M()),mt=L(W()),kfe=L(CV()),YV=L(xn()),WV=L(PV()),jV=L(UV()),zV=L(HV()),QV=L(LS());jc();qr();xV=new Set;a(Ffe,"start");a(Gfe,"customFunctionsServer");a(qfe,"setUp");a($fe,"buildRouteFolder");a(JV,"buildServer");a(XV,"ready")});var jN={};je(jN,{start:()=>Vfe});function Vfe(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,s1.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){t1||(t1=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=e1.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,r1.default)(s,(0,n1.realpathSync)(o))}}return i(s)},{runFirst:!0})),e1.set(r,n)}}}var r1,n1,s1,e1,t1,i1=Ne(()=>{r1=L(require("send")),n1=require("fs"),s1=L(require("serve-static")),e1=new Map;a(Vfe,"start")});var XN={};je(XN,{Request:()=>zN,createReuseportFd:()=>US});var o1,zN,QN,JN,US,vS=Ne(()=>{o1=require("os"),zN=class{static{a(this,"Request")}#e;constructor(t,r){this.method=t.method;let n=t.url;this._nodeRequest=t,this._nodeResponse=r,this.url=n,this.headers=new JN(t.headers)}get absoluteURL(){return this.protocol+"://"+this.host+this.url}get pathname(){let t=this.url.indexOf("?");return t>-1?this.url.slice(0,t):this.url}set pathname(t){let r=this.url.indexOf("?");r>-1?this.url=t+this.url.slice(r):this.url=t}get protocol(){return this._nodeRequest.socket.encrypted?"https":"http"}get ip(){return this._nodeRequest.socket.remoteAddress}get authorized(){return this._nodeRequest.socket.authorized}get peerCertificate(){return this._nodeRequest.socket.getPeerCertificate()}get mtlsConfig(){return this._nodeRequest.socket.server.mtlsConfig}get body(){return this.#e||(this.#e=new QN(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}},QN=class{static{a(this,"RequestBody")}#e;constructor(t){this.#e=t}on(t,r){return this.#e.on(t,r),this}pipe(t,r){return this.#e.pipe(t,r)}},JN=class{constructor(t){this.asObject=t}static{a(this,"Headers")}set(t,r){this.asObject[t.toLowerCase()]=r}get(t){return this.asObject[t.toLowerCase()]}has(t){return this.asObject.hasOwnProperty(t.toLowerCase())}[Symbol.iterator](){return Object.entries(this.asObject)[Symbol.iterator]()}keys(){return Object.keys(this.asObject)}values(){return Object.values(this.asObject)}delete(t){delete this.asObject[t.toLowerCase()]}forEach(t){for(let[r,n]of this)t(n,r,this)}};(0,o1.platform)()!="win32"&&(US=require("node-unix-socket").createReuseportFd)});var eI=N((UPe,a1)=>{"use strict";var hE=se();hE.initSync();var id=require("fs-extra"),ZN=require("path"),od=M(),Kfe=require("crypto"),Yfe=require("uuid").v4;a1.exports=Wfe;function Wfe(){if(hE.getHdbBasePath()!==void 0){let e=ZN.join(hE.getHdbBasePath(),od.LICENSE_KEY_DIR_NAME,od.JWT_ENUM.JWT_PRIVATE_KEY_NAME),t=ZN.join(hE.getHdbBasePath(),od.LICENSE_KEY_DIR_NAME,od.JWT_ENUM.JWT_PUBLIC_KEY_NAME),r=ZN.join(hE.getHdbBasePath(),od.LICENSE_KEY_DIR_NAME,od.JWT_ENUM.JWT_PASSPHRASE_NAME);try{id.accessSync(r),id.accessSync(e),id.accessSync(t)}catch(n){if(n.code==="ENOENT"){let s=Yfe(),i=Kfe.generateKeyPairSync("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem",cipher:"aes-256-cbc",passphrase:s}});id.writeFileSync(r,s),id.writeFileSync(e,i.privateKey),id.writeFileSync(t,i.publicKey)}else throw n}}}a(Wfe,"checkJWTTokenExist")});var l1=N((BPe,c1)=>{"use strict";var tI=class{static{a(this,"HdbInfoInsertObject")}constructor(t,r,n){this.info_id=t,this.data_version_num=r,this.hdb_version_num=n}};c1.exports={HdbInfoInsertObject:tI}});var _1=N((xPe,d1)=>{"use strict";var u1=M(),rI=class{static{a(this,"UpgradeObject")}constructor(t,r){this[u1.UPGRADE_JSON_FIELD_NAMES_ENUM.DATA_VERSION]=t,this[u1.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION]=r}};d1.exports={UpgradeObject:rI}});var BS=N((FPe,E1)=>{"use strict";var Is=require("prompt"),ad=require("chalk"),f1=W(),ii=require("os"),nI=Wa(),sI=["yes","y"];async function jfe(e){let t=`${ii.EOL}`+ad.bold.green("Your current HarperDB version requires that we complete an update process.")+`${ii.EOL}If a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${ii.EOL}${ii.EOL}You can read more about the changes in this upgrade at https://harperdb.io/developers/release-notes/${ii.EOL}`;Is.override=nI(["CONFIRM_UPGRADE"]),Is.start(),Is.message=t;let r={properties:{CONFIRM_UPGRADE:{description:ad.magenta(`${ii.EOL}[CONFIRM_UPGRADE] Do you want to upgrade your HDB instance now? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"no",required:!0}}},n;try{n=await Is.get([r])}catch(s){return f1.error("There was an error when prompting user about an upgrade."),f1.error(s),!1}return sI.includes(n.CONFIRM_UPGRADE)}a(jfe,"forceUpdatePrompt");async function zfe(e){let t=`${ii.EOL}`+ad.bold.green(`Your installed HarperDB version is older than the version used to create your data. Downgrading is not recommended as it is not tested and guaranteed to work. However, if you need to downgrade, and a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${ii.EOL}`);Is.override=nI(["CONFIRM_DOWNGRADE"]),Is.start(),Is.message=t;let r={properties:{CONFIRM_DOWNGRADE:{description:ad.magenta(`${ii.EOL}[CONFIRM_DOWNGRADE] Do you want to proceed with using your downgraded HDB instance now? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"no",required:!0}}},n=await Is.get([r]);return sI.includes(n.CONFIRM_DOWNGRADE)}a(zfe,"forceDowngradePrompt");async function Qfe(){let e=`${ii.EOL}`+ad.bold.green("We now require a Certifacte Authority certificate. HarperDB can generate all new certificates for you (your existing certificates will be backed up) or you can keep any existing certificates and add your own CA certificate. To add your own CA certificate set the <certificateAuthority> parameter in harperdb-config.yaml");Is.override=nI(["GENERATE_CERTS"]),Is.start(),Is.message=e;let t={properties:{GENERATE_CERTS:{description:ad.magenta(`${ii.EOL}[GENERATE_CERTS] Do you want HarperDB to generate all new certificates? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"yes",required:!0}}},r=await Is.get([t]);return sI.includes(r.GENERATE_CERTS)}a(Qfe,"upgradeCertsPrompt");E1.exports={forceUpdatePrompt:jfe,forceDowngradePrompt:zfe,upgradeCertsPrompt:Qfe}});var oI=N((qPe,h1)=>{"use strict";var iI=class{static{a(this,"UpgradeDirective")}constructor(t){this.version=t,this.sync_functions=[],this.async_functions=[]}};h1.exports=iI});var m1=N((jPe,p1)=>{"use strict";var Jfe=te(),Xfe=wt(),VPe=W(),KPe=require("path"),YPe=require("fs"),WPe=M();p1.exports={getOldPropsValue:Zfe};function Zfe(e,t,r=!1){let n=t.getRaw(e);return Jfe.isNotEmptyAndHasValue(n)?n:r?Xfe.getDefaultConfig(e):""}a(Zfe,"getOldPropsValue")});var R1=N((QPe,g1)=>{"use strict";var Oa=require("path"),Na=require("fs-extra"),eEe=require("properties-reader"),tEe=oI(),lr=W(),{getOldPropsValue:St}=m1(),{HDB_SETTINGS_NAMES:he,CONFIG_PARAMS:ol}=M(),al=wt(),HS=se(),S1=te(),xi=M(),aI=new tEe("3.1.0"),T1=[];function rEe(){let e=eEe(HS.get(he.SETTINGS_PATH_KEY)),t="Updating settings file for version 3.1.0";console.log(t),lr.info(t);let r=` ;Settings for the HarperDB process.
|
|
41
41
|
|
|
42
42
|
;The directory selected during install where the database files reside.
|
|
43
43
|
${he.HDB_ROOT_KEY} = ${St(he.HDB_ROOT_KEY,e)}
|
|
@@ -60,9 +60,9 @@ ${he.SERVER_KEEP_ALIVE_TIMEOUT_KEY} = ${St(he.SERVER_KEEP_ALIVE_TIMEOUT_KEY,e,!0
|
|
|
60
60
|
;Limit the amount of time the parser will wait to receive the complete HTTP headers.. Defaults to 60,000 ms (1 minute).
|
|
61
61
|
${he.SERVER_HEADERS_TIMEOUT_KEY} = ${St(he.SERVER_HEADERS_TIMEOUT_KEY,e,!0)}
|
|
62
62
|
;Define whether to log to file or not.
|
|
63
|
-
${he.LOG_TO_FILE} = ${
|
|
63
|
+
${he.LOG_TO_FILE} = ${al.getDefaultConfig(ol.LOGGING_FILE)}
|
|
64
64
|
;Define whether to log to stdout/stderr or not. NOTE HarperDB must run in foreground in order to receive the std stream from HarperDB.
|
|
65
|
-
${he.LOG_TO_STDSTREAMS} = ${
|
|
65
|
+
${he.LOG_TO_STDSTREAMS} = ${al.getDefaultConfig(ol.LOGGING_STDSTREAMS)}
|
|
66
66
|
;Set to control amount of logging generated. Accepted levels are trace, debug, warn, error, fatal.
|
|
67
67
|
${he.LOG_LEVEL_KEY} = ${St(he.LOG_LEVEL_KEY,e)}
|
|
68
68
|
;The path where log files will be written. If there is no file name included in the path, the log file will be created by default as 'hdb_log.log'
|
|
@@ -95,39 +95,39 @@ ${he.OPERATION_TOKEN_TIMEOUT_KEY} = ${St(he.OPERATION_TOKEN_TIMEOUT_KEY,e,!0)}
|
|
|
95
95
|
;Defines the length of time a refresh token will be valid until it expires. Example values: https://github.com/vercel/ms
|
|
96
96
|
${he.REFRESH_TOKEN_TIMEOUT_KEY} = ${St(he.REFRESH_TOKEN_TIMEOUT_KEY,e,!0)}
|
|
97
97
|
;The port the IPC server will run on.
|
|
98
|
-
${he.IPC_SERVER_PORT} = ${
|
|
98
|
+
${he.IPC_SERVER_PORT} = ${al.getDefaultConfig(ol.IPC_NETWORK_PORT)}
|
|
99
99
|
;Run HDB in the foreground.
|
|
100
|
-
${he.RUN_IN_FOREGROUND} = ${
|
|
100
|
+
${he.RUN_IN_FOREGROUND} = ${al.getDefaultConfig(ol.OPERATIONSAPI_FOREGROUND)}
|
|
101
101
|
;Set to true to enable custom API endpoints. Requires a valid enterprise license.
|
|
102
|
-
${he.CUSTOM_FUNCTIONS_ENABLED_KEY} = ${
|
|
102
|
+
${he.CUSTOM_FUNCTIONS_ENABLED_KEY} = ${al.getDefaultConfig(ol.CUSTOMFUNCTIONS_ENABLED)}
|
|
103
103
|
;The port used to access the custom functions server.
|
|
104
|
-
${he.CUSTOM_FUNCTIONS_PORT_KEY} = ${
|
|
104
|
+
${he.CUSTOM_FUNCTIONS_PORT_KEY} = ${al.getDefaultConfig(ol.HTTP_PORT)}
|
|
105
105
|
;The path to the folder containing HarperDB custom function files.
|
|
106
106
|
${he.CUSTOM_FUNCTIONS_DIRECTORY_KEY} = ${Oa.join(St(he.HDB_ROOT_KEY,e),"custom_functions")}
|
|
107
107
|
;Set the max number of processes HarperDB will start for the Custom Functions server
|
|
108
|
-
${he.MAX_CUSTOM_FUNCTION_PROCESSES} = ${
|
|
109
|
-
`,n=HS.get("settings_path"),s=Oa.dirname(n),i=Oa.join(s,"3_1_0_upgrade_settings.bak");try{lr.info(`Backing up old settings file to: ${i}`),Na.copySync(n,i)}catch(c){throw lr.error(c),console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),c}try{lr.info("New settings file values for 3.1.0 upgrade:",r),lr.info(`Creating new/upgraded settings file at '${n}'`),Na.writeFileSync(n,r),lr.info("Updating env variables with new settings values")}catch(c){throw console.error("There was a problem writing the new settings file. Please check the log for details."),lr.error("Attempting to reset the settings file to its original state. Use the '.bak' file if this fails."),lr.error(c),Na.copySync(i,n),c}HS.initSync();let o="New settings file for 3.1.0 upgrade successfully created.";return console.log(o),lr.info(o),o}a(
|
|
108
|
+
${he.MAX_CUSTOM_FUNCTION_PROCESSES} = ${al.getDefaultConfig(ol.HTTP_THREADS)}
|
|
109
|
+
`,n=HS.get("settings_path"),s=Oa.dirname(n),i=Oa.join(s,"3_1_0_upgrade_settings.bak");try{lr.info(`Backing up old settings file to: ${i}`),Na.copySync(n,i)}catch(c){throw lr.error(c),console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),c}try{lr.info("New settings file values for 3.1.0 upgrade:",r),lr.info(`Creating new/upgraded settings file at '${n}'`),Na.writeFileSync(n,r),lr.info("Updating env variables with new settings values")}catch(c){throw console.error("There was a problem writing the new settings file. Please check the log for details."),lr.error("Attempting to reset the settings file to its original state. Use the '.bak' file if this fails."),lr.error(c),Na.copySync(i,n),c}HS.initSync();let o="New settings file for 3.1.0 upgrade successfully created.";return console.log(o),lr.info(o),o}a(rEe,"updateSettingsFile_3_1_0");function nEe(){let e=Oa.join(S1.getHomeDir(),xi.HDB_HOME_DIR_NAME,xi.LICENSE_KEY_DIR_NAME,xi.LICENSE_FILE_NAME),t=Oa.join(S1.getHomeDir(),xi.HDB_HOME_DIR_NAME,xi.LICENSE_KEY_DIR_NAME,xi.REG_KEY_FILE_NAME),r=Oa.join(HS.getHdbBasePath(),xi.LICENSE_KEY_DIR_NAME,xi.LICENSE_FILE_NAME),n=Oa.join(r,xi.LICENSE_FILE_NAME),s=Oa.join(r,xi.REG_KEY_FILE_NAME),i="Move license files for version 3.1.0";console.log(i),lr.info(i);let o="Creating .license directory";console.log(o),lr.info(o),Na.mkdirpSync(r);try{Na.accessSync(e);try{let c="Moving licence file";console.log(c),lr.info(c),Na.moveSync(e,n);let l="License file successfully moved.";console.log(l),lr.info(l)}catch{let l="moving license file failed";console.error(l),lr.error(l)}}catch{let l=`license file '${e}' does not exist.`;console.warn(l),lr.warn(l)}try{Na.accessSync(t);try{let c="Moving registration file";console.log(c),lr.info(c),Na.moveSync(t,s);let l="Registration file successfully moved.";console.log(l),lr.info(l)}catch{let l="moving registration file failed";console.error(l),lr.error(l)}}catch{let l=`registration file '${t}' does not exist.`;console.warn(l),lr.warn(l)}}a(nEe,"moveLicenseFiles");aI.sync_functions.push(rEe);aI.sync_functions.push(nEe);T1.push(aI);g1.exports=T1});var N1=N((XPe,O1)=>{"use strict";var zn=ht(),{insertRecords:sEe}=sc(),iEe=cn(),Ia=Bt(),oEe=te(),Io=W(),aEe=te(),ki=require("fs-extra"),wo=require("path"),cEe=require("cli-progress"),pE=require("assert"),lEe=require("pino"),uEe=se();O1.exports=dEe;var xS,A1,kS,cI,rn,mE=!1;async function dEe(e=!0){return xS=uEe.getHdbBasePath(),A1=wo.join(xS,"schema"),kS=wo.join(xS,"4_0_0_upgrade_tmp"),cI=wo.join(xS,"transactions"),console.info("Reindexing upgrade started for schemas"),Io.notify("Reindexing upgrade started for schemas"),await y1(A1,!1,e),await ki.pathExists(cI)&&(console.info(`
|
|
110
110
|
|
|
111
|
-
Reindexing upgrade started for transaction logs`),
|
|
112
|
-
install_user = ${l}`;try{wa.writeFileSync(o,u)}catch(_){throw console.log("There was a problem updating the HarperDB boot properties file. Please check the log for details."),_}try{cI.initSync(!0)}catch(_){throw console.error("Unable to initialize new properties. Please check the log for details."),_}let d="New settings file for 4.0.0 upgrade successfully created.";try{wa.removeSync(r),console.log(d),il.info(d)}catch(_){throw console.error("There was a problem deleting the old settings file and directory. Please check the log for details."),_}}a(DEe,"updateSettingsFile_4_0_0");gE.async_functions.push(DEe);gE.async_functions.push(wEe);gE.async_functions.push(NEe);gE.async_functions.push(CEe);w1.push(gE);C1.exports=w1});var lI=N((rLe,U1)=>{"use strict";var ol=te(),PEe=M(),P1=W(),{DATA_VERSION:LEe,UPGRADE_VERSION:MEe}=PEe.UPGRADE_JSON_FIELD_NAMES_ENUM,L1=g1(),qS=D1(),al=new Map;L1&&L1.forEach(e=>{al.set(e.version,e)});qS&&qS.forEach(e=>{al.set(e.version,e)});qS&&qS.forEach(e=>{al.set(e.version,e)});function UEe(){return[...al.keys()].sort(ol.compareVersions)}a(UEe,"getSortedVersions");function M1(e){let t=e[LEe],r=e[MEe];return ol.isEmptyOrZeroLength(t)||ol.isEmptyOrZeroLength(r)?(P1.info(`There is an issue with the version data in your instance of HDB. Current version data: ${e}`),P1.error("There was an error when trying to evaluate the version information for your instance. Trying to start the server anyways but it may fail. If you continue to have this problem, please contact support@harperdb.io."),[]):[...al.keys()].sort(ol.compareVersions).filter(function(n){return ol.compareVersions(n,t)>0&&ol.compareVersions(n,r)<=0})}a(M1,"getVersionsForUpgrade");function vEe(e){return M1(e).length>0}a(vEe,"hasUpgradesRequired");function BEe(e){return ol.isEmptyOrZeroLength(e)?null:al.has(e)?al.get(e):null}a(BEe,"getDirectiveByVersion");U1.exports={getSortedVersions:UEe,getDirectiveByVersion:BEe,getVersionsForUpgrade:M1,hasUpgradesRequired:vEe}});var VS=N((sLe,k1)=>{"use strict";var HEe=require("util"),uI=require("chalk"),xEe=require("os"),B1=un(),kEe=Vr(),Qn=M(),H1=c1(),_I=wR(),{UpgradeObject:v1}=d1(),{forceDowngradePrompt:FEe}=BS(),GEe=Uc(),$S=W(),ad=te(),fI=ls(),qEe=(Pe(),oe(lt)),$Ee=lI(),VEe=HEe.promisify(fI.setSchemaDataToGlobal),KEe=kEe.searchByValue,YEe="info_id",WEe="2.9.9",jEe="3.0.0";async function zEe(e){let t=new H1.HdbInfoInsertObject(1,e,e),r=new _I.InsertObject(Qn.OPERATIONS_ENUM.INSERT,Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,Qn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,[t]);return fI.setSchemaDataToGlobal(),B1.insert(r)}a(zEe,"insertHdbInstallInfo");async function dI(e){let t,r=await x1(),n=new Map([[0,{}]]);for(let c of r)n.set(c.info_id,c);let i=Math.max.apply(null,[...n.keys()])+1;t=new H1.HdbInfoInsertObject(i,e,e);let o=new _I.InsertObject(Qn.OPERATIONS_ENUM.INSERT,Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,Qn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,[t]);return await VEe(),B1.insert(o)}a(dI,"insertHdbUpgradeInfo");async function x1(){let e=new _I.NoSQLSeachObject(Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,YEe,Qn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,["*"],"*"),t=[];try{t=Array.from(await KEe(e))}catch(r){console.error(r)}return t}a(x1,"getAllHdbInfoRecords");async function QEe(){let e=await x1();if(e.length===0)return;let t,r=new Map;for(let s of e)r.set(s.info_id,s);let n=Math.max.apply(null,[...r.keys()]);return t=r.get(n),t}a(QEe,"getLatestHdbInfoRecord");async function JEe(){$S.info("Checking if HDB software has been updated");try{let e=GEe.version(),t=await QEe(),r;if(ad.isEmpty(t))r=WEe;else if(r=t.data_version_num,ad.compareVersions(r.toString(),e.toString())>0){if(!ad.isCompatibleDataVersion(r.toString(),e.toString()))throw console.log(uI.yellow(`This instance's data was last run on version ${r}`)),console.error(uI.red(`You have installed a version lower than the version that your data was created on or was upgraded to. This may cause issues and is currently not supported.${xEe.EOL}${Qn.SUPPORT_HELP_MSG}`)),new Error("Trying to downgrade major HDB versions is not supported.");ad.isCompatibleDataVersion(r.toString(),e.toString(),!0)||(console.log(uI.yellow(`This instance's data was last run on version ${r}`)),await FEe(new v1(r,e))?await dI(e.toString()):(console.log("Cancelled downgrade, closing HarperDB"),process.exit(0)))}if(fI.setSchemaDataToGlobal(),XEe(r),e.toString()===r.toString())return;let n=new v1(r,e);if($Ee.hasUpgradesRequired(n))return n;ad.compareVersions(n.data_version.toString(),n.upgrade_version.toString())<0&&(await dI(n.upgrade_version),$S.notify(`HarperDB running on upgraded version: ${n.upgrade_version}`))}catch(e){throw $S.fatal("Error while trying to evaluate the state of hdb data and the installed hdb version"),$S.fatal(e),e}}a(JEe,"getVersionUpdateInfo");function XEe(e){let t=`You are attempting to upgrade from an old instance of HarperDB that is no longer supported. In order to upgrade to this version, you must do a fresh install. If you need support, please contact ${Qn.HDB_SUPPORT_ADDRESS}`;if(!("hdb_info"in qEe.databases.system))throw console.log(t),new Error(t);if(!ad.isEmpty(e)&&e<jEe)throw console.log(t),new Error(t)}a(XEe,"checkIfInstallIsSupported");k1.exports={insertHdbInstallInfo:zEe,insertHdbUpgradeInfo:dI,getVersionUpdateInfo:JEe}});var $1=N((oLe,q1)=>{"use strict";var KS=require("joi"),{boolean:ZEe,string:EI,number:ehe}=KS.types(),F1=require("fs-extra"),RE=M(),G1=require("path"),the=Tt();q1.exports=rhe;function rhe(e){let t=EI.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),r=KS.object({[RE.INSTALL_PROMPTS.ROOTPATH]:KS.custom(nhe),[RE.INSTALL_PROMPTS.OPERATIONSAPI_NETWORK_PORT]:KS.alternatives([ehe.min(0),EI]).allow("null",null),[RE.INSTALL_PROMPTS.TC_AGREEMENT]:EI.valid("yes","YES","Yes"),[RE.INSTALL_PROMPTS.CLUSTERING_NODENAME]:t,[RE.INSTALL_PROMPTS.CLUSTERING_ENABLED]:ZEe});return the.validateBySchema(e,r)}a(rhe,"installValidator");function nhe(e,t){if(F1.existsSync(G1.join(e,"system/hdb_user/data.mdb"))||F1.existsSync(G1.join(e,"system/hdb_user.mdb")))return t.message(`'${e}' is already in use. Please enter a different path.`)}a(nhe,"validateRootAvailable")});var K1=N((cLe,V1)=>{"use strict";var{mkdirpSync:she,copySync:ihe}=require("fs-extra"),Ca=require("path"),cd=M(),pI=W(),ohe=Bn(),hI=Zi(),ahe=gt();V1.exports=che;async function che(e){pI.trace("Mounting HarperDB"),cl(e),cl(Ca.join(e,"backup")),cl(Ca.join(e,"keys")),cl(Ca.join(e,"keys",cd.LICENSE_FILE_NAME)),cl(Ca.join(e,"log")),cl(Ca.join(e,"database")),cl(Ca.join(e,"components")),ihe(Ca.resolve(cd.PACKAGE_ROOT,"./utility/install/README.md"),Ca.join(e,"README.md")),await lhe()}a(che,"mountHdb");async function lhe(){let e=I_(),t=Object.keys(hI);for(let r=0;r<t.length;r++){let n=t[r],s=hI[n].hash_attribute;try{ahe.initSystemSchemaPaths(cd.SYSTEM_SCHEMA_NAME,n);let i=new e(cd.SYSTEM_SCHEMA_NAME,n,s);i.attributes=hI[n].attributes;let o=i.attributes.find(({attribute:c})=>c===s);o.isPrimaryKey=!0,["hdb_user","hdb_role"].includes(n)&&(i.audit=!0),await ohe.createTable(n,i)}catch(i){throw pI.error(`issue creating environment for ${cd.SYSTEM_SCHEMA_NAME}.${n}: ${i}`),i}}}a(lhe,"createLMDBTables");function cl(e){she(e,{mode:cd.HDB_FILE_PERMISSIONS}),pI.info(`Directory ${e} created`)}a(cl,"makeDirectory")});var iK=N((_Le,sK)=>{"use strict";var SI=require("os"),Q1=require("inquirer"),Cs=require("fs-extra"),uhe=require("properties-reader"),ul=require("chalk"),Gi=require("path"),dhe=require("human-readable-ids").hri,_he=require("ora"),fhe=require("yaml"),ur=W(),Da=se(),AE=te(),WS=Wa(),J1=VS(),X1=Uc(),ue=M(),{CONFIG_PARAM_MAP:uLe,CONFIG_PARAMS:Mt}=ue,Ehe=$1(),hhe=K1(),TI=wt(),phe=xn(),mhe=lf(),She=ZN(),The=ls(),ghe=require("util").promisify,Rhe=ghe(The.setSchemaDataToGlobal),Y1=Xs(),ll=a(e=>e,"PROMPT_ANSWER_TRANSFORMER"),xr=a(e=>ul.magenta.bold(e),"HDB_PROMPT_MSG"),Ahe="https://harperdb.io/legal/end-user-license-agreement",Pa=SI.EOL,Do="",yhe="yes",W1="Starting HarperDB install...",j1="HarperDB installation was successful.",z1="Terms & Conditions acceptance is required to proceed with installation. Exiting install...",bhe="An out of date version of HarperDB is already installed.",mI="It appears that HarperDB is already installed. Exiting install...",Ohe="Aborting install",dLe=new RegExp(/^([0-9]{1,4}|[1-5][0-9]{4}|6[0-4][0-9]{3}|65[0-4][0-9]{2}|655[0-2][0-9]|6553[0-5])$/),Nhe=new RegExp(/^[^\s.,*>]+$/),Ihe=SI.homedir(),whe=Gi.join(Ihe,ue.HDB_ROOT_DIR_NAME),Che="HDB_ADMIN",Dhe="CLUSTER_USER",Phe="dev",Lhe="localhost",YS={[Mt.HTTP_CORS]:!0,[Mt.HTTP_CORSACCESSLIST]:["*"],[Mt.HTTP_PORT]:9926,[Mt.AUTHENTICATION_AUTHORIZELOCAL]:!0,[Mt.THREADS_COUNT]:1,[Mt.THREADS_DEBUG]:!0,[Mt.LOGGING_STDSTREAMS]:!0,[Mt.LOGGING_LEVEL]:"info",[Mt.OPERATIONSAPI_NETWORK_PORT]:9925,[Mt.LOCALSTUDIO_ENABLED]:!0},Hr={DESTINATION:"Please enter a destination for HarperDB:",HDB_USERNAME:"Please enter a username for the administrative user:",HDB_PASS:"Please enter a password for the administrative user:",NODE_NAME:"Please enter a unique name for this node:",CLUSTER_USERNAME:"Please enter a username for the CLUSTER_USER:",CLUSTER_PASS:"Please enter a password for the CLUSTER_USER:",DEFAULTS_MODE:"Default Config - dev (easy access/debugging) or prod (security/performance): (dev/prod)",REPLICATION_HOSTNAME:"Please enter the hostname for this server:"},La=WS([ue.INSTALL_PROMPTS.HDB_CONFIG]),Fi,Z1=!1,gI=!1,eK=!1;sK.exports={install:tK,updateConfigEnv:$he,setIgnoreExisting:Vhe};tK.createSuperUser=nK;async function tK(){console.log(xr(Pa+W1+Pa)),ur.notify(W1);let e;La[ue.INSTALL_PROMPTS.HDB_CONFIG]&&(e=Mhe());let t=vhe();Object.assign(t,e),t[ue.INSTALL_PROMPTS.TC_AGREEMENT]&&t[ue.INSTALL_PROMPTS.ROOTPATH]&&t[ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME]&&t[ue.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]&&t[ue.INSTALL_PROMPTS.DEFAULTS_MODE]===void 0&&(eK=!0,t[ue.INSTALL_PROMPTS.DEFAULTS_MODE]="prod");let r=Ehe(t);if(r)throw r.message;await Bhe(),await Hhe(t);let n=await Uhe(t);Fi=n[ue.INSTALL_PROMPTS.ROOTPATH],La[ue.INSTALL_PROMPTS.HDB_CONFIG]&&Gi.dirname(La[ue.INSTALL_PROMPTS.HDB_CONFIG])===Fi&&(Z1=!0),!gI&&!La[ue.INSTALL_PROMPTS.HDB_CONFIG]&&await Cs.pathExists(Gi.join(Fi,ue.HDB_CONFIG_FILE))&&(console.error(mI),process.exit());let s=_he({prefixText:xr("Installing"),color:"magenta",spinner:"simpleDots"});if(s.start(),AE.isEmpty(Fi))throw new Error("Installer should have the HDB root param at the stage it is in but it does not.");Da.setHdbBasePath(Fi),await hhe(Fi),await xhe(),await khe(n),ur.initLogSettings(!0),await nK(n),await Ghe(n),await Y1.updateConfigCert(),await Y1.generateCertsKeys(),await qhe(),She(),s.stop(),console.log(xr(Pa+j1+Pa)),ur.notify(j1)}a(tK,"install");function Mhe(){let e=fhe.parseDocument(Cs.readFileSync(La[ue.INSTALL_PROMPTS.HDB_CONFIG],"utf8"),{simpleKeys:!0}),t=TI.flattenConfig(e.toJSON());return t[ue.CONFIG_PARAMS.ROOTPATH.toLowerCase()]&&(t.ROOTPATH=t[ue.CONFIG_PARAMS.ROOTPATH.toLowerCase()]),t}a(Mhe,"getConfigFromFile");async function Uhe(e){ur.trace("Getting install prompts and params.");let t,r=[{type:"input",transformer:ll,when:Po(e[ue.INSTALL_PROMPTS.ROOTPATH],Hr.DESTINATION),name:ue.INSTALL_PROMPTS.ROOTPATH,prefix:Do,default:whe,validate:a(async s=>ws(s)?ws(s):await Cs.pathExists(Gi.join(s,"system","hdb_user.mdb"))?`'${s}' is already in use. Please enter a different path.`:!0,"validate"),message:xr(Hr.DESTINATION)},{type:"input",transformer:ll,when:Po(e[ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],Hr.HDB_USERNAME),name:ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME,prefix:Do,default:Che,validate:a(s=>ws(s)?ws(s):(t=s,!0),"validate"),message:xr(Hr.HDB_USERNAME)},{type:"password",when:Po(e[ue.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD],Hr.HDB_PASS),name:ue.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD,prefix:Do,validate:a(s=>ws(s)?ws(s):!0,"validate"),message:xr(Hr.HDB_PASS)},{type:"input",transformer:ll,when:Po(e[ue.INSTALL_PROMPTS.DEFAULTS_MODE],Hr.DEFAULTS_MODE),name:ue.INSTALL_PROMPTS.DEFAULTS_MODE,prefix:Do,default:Phe,validate:a(s=>ws(s)?ws(s):s!=="dev"&&s!=="prod"?`Invalid response '${s}', options are 'dev' or 'prod'.`:!0,"validate"),message:xr(Hr.DEFAULTS_MODE)}];if(eK||r.push({type:"input",name:ue.INSTALL_PROMPTS.REPLICATION_HOSTNAME,transformer:ll,when:Po(e[ue.INSTALL_PROMPTS.REPLICATION_HOSTNAME],Hr.REPLICATION_HOSTNAME),prefix:Do,default:Lhe,message:xr(Hr.REPLICATION_HOSTNAME)}),AE.autoCastBoolean(e[ue.INSTALL_PROMPTS.CLUSTERING_ENABLED])===!0){let s=[{type:"input",transformer:ll,when:Po(e[ue.INSTALL_PROMPTS.CLUSTERING_NODENAME],Hr.NODE_NAME),name:ue.INSTALL_PROMPTS.CLUSTERING_NODENAME,prefix:Do,default:dhe.random(),validate:a(i=>Nhe.test(i)?!0:"Invalid node name, must not contain ., * or >","validate"),message:xr(Hr.NODE_NAME)},{type:"input",transformer:ll,when:Po(e[ue.INSTALL_PROMPTS.CLUSTERING_USER],Hr.CLUSTER_USERNAME),name:ue.INSTALL_PROMPTS.CLUSTERING_USER,prefix:Do,default:Dhe,validate:a(i=>ws(i)?ws(i):i.toLowerCase()===t.toLowerCase()?"Username is already in use.":!0,"validate"),message:xr(Hr.CLUSTER_USERNAME)},{type:"password",when:Po(e[ue.INSTALL_PROMPTS.CLUSTERING_PASSWORD],Hr.CLUSTER_PASS),name:ue.INSTALL_PROMPTS.CLUSTERING_PASSWORD,prefix:Do,validate:a(i=>ws(i)?ws(i):!0,"validate"),message:xr(Hr.CLUSTER_PASS)}];r.push(...s)}let n=await Q1.prompt(r);if(Object.keys(n).length===0)return e;for(let s in n)e[s]===void 0&&(e[s]=n[s]);return e}a(Uhe,"installPrompts");function Po(e,t){return e!==void 0?(t.includes("password")?(console.log(`${xr(t)} ${ul.gray("[hidden]")}`),ur.trace(`${xr(t)} [hidden]`)):(console.log(`${xr(t)} ${e}`),ur.trace(`${xr(t)} ${e}`)),!1):!0}a(Po,"displayCmdEnvVar");function ws(e){let t=e.replace(/ /g,"");if(t===""||t==="''"||t==='""')return"Value cannot be empty."}a(ws,"checkForEmptyValue");function vhe(){let e=Object.keys(ue.INSTALL_PROMPTS),t=WS(e),r=WS(Object.keys(ue.CONFIG_PARAM_MAP),!0),n={};for(let s of e){let i=ue.CONFIG_PARAM_MAP[s.toLowerCase()];t[s]?i===void 0?n[s]=t[s]:n[i.toUpperCase()]=t[s]:i!==void 0&&r[i.toLowerCase()]&&(n[s]=r[i.toLowerCase()])}return n}a(vhe,"checkForPromptOverride");async function Bhe(){ur.trace("Checking for existing install.");let e=AE.getPropsFilePath(),t=await Cs.pathExists(e),r;if(t){ur.trace(`Install found an existing boot prop file at:${e}`);let n=uhe(e),s=TI.getConfigValue(ue.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)||n.get(ue.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY);r=await Cs.pathExists(s)}if(!t&&AE.noBootFile()&&(r=!0),r&&!gI){if(ur.trace(`Install found existing HDB config at:${e}`),await J1.getVersionUpdateInfo()){let s=`Please use \`harperdb upgrade\` to update to ${X1.version()}. Exiting install...`;console.log(Pa+ul.magenta.bold(bhe)),console.log(ul.magenta.bold(s)),ur.error(s)}else console.log(Pa+ul.magenta.bold(mI)),ur.error(mI);process.exit(0)}}a(Bhe,"checkForExistingInstall");async function Hhe(e){ur.info("Asking for terms agreement.");let t=`Terms & Conditions can be found at ${Ahe}${Pa}and can be viewed by typing or copying and pasting the URL into your web browser.${Pa}I agree to the HarperDB Terms and Conditions: (yes/no)`,r={prefix:Do,transformer:ll,when:Po(e[ue.INSTALL_PROMPTS.TC_AGREEMENT],t),name:ue.INSTALL_PROMPTS.TC_AGREEMENT,message:xr(t),validate:a(s=>s.toLowerCase()==="yes"||s.toLowerCase()==="no"?!0:ul.yellow("Please enter 'yes' or 'no'"),"validate")},n=await Q1.prompt([r]);n[ue.INSTALL_PROMPTS.TC_AGREEMENT]&&n[ue.INSTALL_PROMPTS.TC_AGREEMENT].toLowerCase()!==yhe&&(console.log(ul.yellow(z1)),ur.error(z1),process.exit(0))}a(Hhe,"termsAgreement");async function xhe(){let e=Gi.join(Fi,ue.HDB_CONFIG_FILE),t;try{t=SI.userInfo().username}catch{t=process.env.USERNAME||process.env.USER||process.env.LOGNAME||process.env.LNAME||process.env.SUDO_USER}if(t){let r=`settings_path = ${e}
|
|
113
|
-
install_user = ${t}`,n=AE.getHomeDir(),s=Gi.join(n,ue.HDB_HOME_DIR_NAME),i=Gi.join(s,ue.LICENSE_KEY_DIR_NAME);try{Cs.mkdirpSync(s,{mode:ue.HDB_FILE_PERMISSIONS}),Cs.mkdirpSync(i,{mode:ue.HDB_FILE_PERMISSIONS})}catch{console.error(`Could not make settings directory ${ue.HDB_HOME_DIR_NAME} in home directory. Please check your permissions and try again.`)}let o=Gi.join(s,ue.BOOT_PROPS_FILE_NAME);try{await Cs.writeFile(o,r)}catch(c){throw ur.error(`There was an error creating the boot file at path: ${o}`),c}Da.setProperty(ue.HDB_SETTINGS_NAMES.INSTALL_USER,`${t}`),Da.setProperty(ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,e),Da.setProperty(Da.BOOT_PROPS_FILE_PATH,o)}}a(xhe,"createBootPropertiesFile");async function khe(e){ur.trace("Creating HarperDB config file");let t=WS(Object.keys(ue.CONFIG_PARAM_MAP),!0);if(Object.assign(t,e),e[ue.INSTALL_PROMPTS.DEFAULTS_MODE]==="dev"){process.env.DEV_MODE="true";for(let r in YS){if(r===Mt.HTTP_PORT&&t[Mt.HTTP_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??YS[r],t[Mt.HTTP_SECUREPORT]=null;continue}else if(r===Mt.HTTP_PORT)continue;if(r===Mt.OPERATIONSAPI_NETWORK_PORT&&t[Mt.OPERATIONSAPI_NETWORK_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??YS[r],t[Mt.OPERATIONSAPI_NETWORK_SECUREPORT]=null;continue}else if(r===Mt.OPERATIONSAPI_NETWORK_PORT)continue;t[r.toLowerCase()]===void 0&&(t[r]=YS[r])}}else t[Mt.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]&&(t[Mt.OPERATIONSAPI_NETWORK_SECUREPORT]=null),t[Mt.HTTP_PORT.toLowerCase()]&&(t[Mt.HTTP_SECUREPORT]=null);try{La[ue.INSTALL_PROMPTS.HDB_CONFIG]||TI.createConfigFile(t),Da.initSync()}catch(r){Fhe(r)}}a(khe,"createConfigFile");function Fhe(e){ur.error(`Error creating HarperDB config file. Rolling back install - ${e}`),console.error(e),console.error(Ohe);let t=Gi.resolve(Da.get(Da.BOOT_PROPS_FILE_PATH),"../");t&&Cs.removeSync(t),Fi&&(Z1?Cs.readdirSync(Fi,{withFileTypes:!0}).forEach(n=>{let s=Gi.join(n.path,n.name);s!==La[ue.INSTALL_PROMPTS.HDB_CONFIG]&&Cs.removeSync(s)}):Cs.removeSync(Fi)),process.exit(1)}a(Fhe,"rollbackInstall");async function rK(e,t){ur.trace("Creating admin user"),await Rhe();let r;try{r=await mhe.addRole(e)}catch(n){if(n.message.includes("already exists"))t=void 0;else throw n.message+="Error creating role",n}if(t)try{t.role=r.role,await phe.addUser(t)}catch(n){throw n.message=`Error creating user - ${n}`,n}}a(rK,"createAdminUser");async function nK(e){ur.trace("Creating Super user.");let t={role:"super_user",permission:{super_user:!0}},r={username:e[ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME].toString(),password:e[ue.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD].toString(),active:!0};await rK(t,r),delete e[ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],delete e[ue.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]}a(nK,"createSuperUser");async function Ghe(e){ur.trace("Creating Cluster user.");let t;e[ue.INSTALL_PROMPTS.CLUSTERING_USER]&&e[ue.INSTALL_PROMPTS.CLUSTERING_PASSWORD]&&(t={username:e[ue.INSTALL_PROMPTS.CLUSTERING_USER].toString(),password:e[ue.INSTALL_PROMPTS.CLUSTERING_PASSWORD].toString(),active:!0}),await rK({role:"cluster_user",permission:{cluster_user:!0}},t),delete e[ue.INSTALL_PROMPTS.CLUSTERING_USER],delete e[ue.INSTALL_PROMPTS.CLUSTERING_PASSWORD]}a(Ghe,"createClusterUser");async function qhe(){let e=X1.version();if(e)await J1.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(qhe,"insertHdbVersionInfo");function $he(e){La[ue.INSTALL_PROMPTS.HDB_CONFIG]=e}a($he,"updateConfigEnv");function Vhe(e){gI=e}a(Vhe,"setIgnoreExisting")});var cK=N((ELe,aK)=>{"use strict";var RI=te(),Jn=W(),oK=lI();aK.exports={processDirectives:Khe};async function Khe(e){console.log("Starting upgrade process...");let t=oK.getVersionsForUpgrade(e),r=jhe(t),n=[],s=r.length;for(let i=0;i<s;i++){let o=r[i],c=`Running upgrade for version ${o.version}`;Jn.notify(c),console.log(c);let l=[],u=[];try{l=Yhe(o.sync_functions)}catch(d){throw Jn.error(`Error while running an upgrade script for ${o.version}`),d}try{u=await Whe(o.async_functions)}catch(d){throw Jn.error(`Error while running an upgrade script for ${o.version}`),d}n.push(...l,...u)}return n}a(Khe,"processDirectives");function Yhe(e){if(RI.isEmptyOrZeroLength(e))return Jn.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return Jn.info("Passed parameter is not an array"),[];let t=[];for(let r of e){if(Jn.info(`Running function ${r.name}`),!(r instanceof Function)){Jn.info("Variable being processed is not a function");continue}let n=r();Jn.info(n),t.push(n)}return t}a(Yhe,"runSyncFunctions");async function Whe(e){if(RI.isEmptyOrZeroLength(e))return Jn.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return Jn.info("Passed parameter is not an array"),[];let t=[],r=e.length;for(let n=0;n<r;n++){let s=e[n];if(Jn.info(`Running function ${s.name}`),!(s instanceof Function)){Jn.info("Variable being processed is not a function");continue}let i=await s();Jn.info(i),t.push(i)}return t}a(Whe,"runAsyncFunctions");function jhe(e){if(RI.isEmptyOrZeroLength(e))return[];let t=[];for(let r of e){let n=oK.getDirectiveByVersion(r);n&&t.push(n)}return t}a(jhe,"getUpgradeDirectivesToInstall")});var hK=N((pLe,EK)=>{"use strict";var jS=se();jS.initSync();var _K=require("chalk"),lK=require("fs-extra"),Mo=W(),Lo=M(),uK=Uc(),zhe=cK(),AI=te(),fK=VS(),Qhe=BS(),dK=hg(),Jhe=ls(),Xhe=require("util").promisify,Zhe=Xhe(Jhe.setSchemaDataToGlobal),yI,{UPGRADE_VERSION:zS}=Lo.UPGRADE_JSON_FIELD_NAMES_ENUM;EK.exports={upgrade:epe};async function epe(e){await Zhe(),yI===void 0&&(yI=Uu()),lK.existsSync(jS.get(jS.BOOT_PROPS_FILE_PATH))||(yE("The hdb_boot_properties file was not found. Please install HDB.",Lo.LOG_LEVELS.ERROR),process.exit(1)),lK.existsSync(jS.get(Lo.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))||(yE("The hdb settings file was not found. Please make sure HDB is installed.",Lo.LOG_LEVELS.ERROR),process.exit(1));let t=e;t||(t=await fK.getVersionUpdateInfo(),t||(console.log("HarperDB version is current"),process.exit(0))),yE(`This version of HarperDB is ${uK.version()}`,Lo.LOG_LEVELS.INFO);let r=t[zS]?t[zS]:uK.version();r||(console.log(`Current Version field missing from the package.json file. Cannot continue with upgrade. If you need support, please contact ${Lo.HDB_SUPPORT_ADDRESS}`),Mo.notify("Missing new version field from upgrade info object"),process.exit(1)),await tpe();let n,s=0;try{n=await Qhe.forceUpdatePrompt(t)}catch(i){Mo.error("There was an error when prompting user about upgrade."),Mo.error(i),n=!1,s=1}n||(console.log("Cancelled upgrade, closing HarperDB"),process.exit(s)),Mo.info(`Starting upgrade to version ${r}`),await rpe(t),yE(`HarperDB was successfully upgraded to version ${t[zS]}`,Lo.LOG_LEVELS.INFO)}a(epe,"upgrade");async function tpe(){let e=!1,t=await dK.findPs(Lo.HDB_PROC_NAME);if(AI.isEmptyOrZeroLength(t)||(e=!0),!e){let r=await dK.findPs("hdb_express");AI.isEmptyOrZeroLength(r)||(e=!0)}if(!e){let r=await yI.list();AI.isEmptyOrZeroLength(r)||(e=!0)}if(e){let r="HarperDB is running, please stop all HarperDB services with 'harperdb stop' and run the upgrade command again.";console.log(_K.red(r)),Mo.error(r),process.exit(1)}}a(tpe,"checkIfRunning");async function rpe(e){try{await zhe.processDirectives(e)}catch(t){throw yE("There was an error during the data upgrade. Please check the logs.",Lo.LOG_LEVELS.ERROR),t}try{await fK.insertHdbUpgradeInfo(e[zS])}catch(t){Mo.error("Error updating the 'hdb_info' system table."),Mo.error(t)}}a(rpe,"runUpgrade");function yE(e,t=void 0){t||(t=Mo.info),Mo[t](e),console.log(_K.magenta(e))}a(yE,"printToLogAndConsole")});var gK=N((SLe,TK)=>{"use strict";var{promises:OI,createReadStream:npe,createWriteStream:spe}=require("fs"),{createGzip:ipe}=require("zlib"),{promisify:ope}=require("util"),{pipeline:ape}=require("stream"),cpe=ope(ape),lpe=require("path"),_l=se();_l.initSync();var dl=W(),{CONFIG_PARAMS:bE,ITC_EVENT_TYPES:upe}=M(),{onMessageFromWorkers:dpe}=dt(),_pe=6e4,fpe="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",Epe="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",bI,mK;TK.exports=SK;dpe(e=>{e.type===upe.RESTART&&(_l.initSync(!0),clearInterval(mK),_l.get(bE.LOGGING_ROTATION_ENABLED)&&SK())});async function SK(){try{let e=dl.getLogFilePath(),t=_l.get(bE.LOGGING_ROTATION_MAXSIZE),r=_l.get(bE.LOGGING_ROTATION_INTERVAL);if(!t&&!r){dl.error(fpe);return}let n=_l.get(bE.LOGGING_ROTATION_PATH);if(!n){dl.error(Epe);return}let s;if(t){let o=t.slice(-1),c=t.slice(0,-1);o==="G"?s=c*1e9:o==="M"?s=c*1e6:s=c*1e3}let i;if(r){let o=r.slice(-1),c=r.slice(0,-1);o==="D"?i=c*1440:o==="H"?i=c*60:i=c}bI=Date.now()/6e4,dl.trace("Log rotate enabled, maxSize:",t,"interval:",r),mK=setInterval(async()=>{if(s){let o;o=await OI.stat(e),o.size>=s&&await pK(e,n)}i&&Date.now()/6e4-bI>=i&&(await pK(e,n),bI=Date.now()/6e4)},_pe).unref()}catch(e){dl.error(e)}}a(SK,"logRotator");async function pK(e,t){let r=_l.get(bE.LOGGING_ROTATION_COMPRESS),n=lpe.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.${r?"log.gz":"log"}`);r?(await cpe(npe(e),ipe(),spe(n)),await OI.unlink(e)):await OI.rename(e,n),dl.closeLogFile(),dl.notify(`hdb.log rotated, old log moved to ${n}`)}a(pK,"moveLogFile")});var wK=N(IK=>{"use strict";var pe=se();pe.initSync();var gLe=xu(),Xt=M(),Xn=W(),Uo=require("fs-extra"),vo=require("path"),hpe=require("systeminformation"),ppe=ZN(),{install:mpe}=iK(),NI=require("chalk"),Spe=jl(),Bo=te(),II=wt(),AK=Wa(),RK=bm(),Tpe=hK(),gpe=gK(),{compactOnStart:Rpe}=(oO(),oe(iO)),Ape=require("minimist"),ype=Xs(),{PACKAGE_ROOT:bpe,CONFIG_PARAMS:we}=M(),{startHTTPThreads:Ope,startSocketServer:RLe,mostIdleRouting:ALe,remoteAffinityRouting:yLe}=(wI(),oe(CK)),Npe=VS(),{isMainThread:Ipe}=require("worker_threads"),bLe=Zi(),OLe=ro(),NLe=mA(),ILe=I_(),QS=M(),qi,ld,yK=!1,wpe="Upgrade complete. Starting HarperDB.",Cpe="Got an error while trying to upgrade your HarperDB instance. Exiting HarperDB.",Dpe="HarperDB not found, starting install process.",Ppe="There was an error during install, check install_log.log for more details. Exiting.",Lpe="HarperDB successfully started.";function Mpe(){if(!yK){let e=a(()=>{Uo.removeSync(vo.join(pe.get(Xt.CONFIG_PARAMS.ROOTPATH),Xt.HDB_PID_FILE)),process.exit(0)},"remove_hdb_pid");process.on("exit",()=>{e()}),process.on("SIGINT",()=>{e()}),process.on("SIGQUIT",()=>{e()}),process.on("SIGTERM",()=>{e()})}}a(Mpe,"addExitListeners");async function bK(e=!1,t=!1){if(console.log(NI.magenta("Starting HarperDB...")),Xn.suppressLogging?.(()=>{console.log(NI.magenta(""+Uo.readFileSync(vo.join(bpe,"utility/install/ascii_logo.txt"))))}),await NK()===!1){console.log(Dpe);try{await mpe()}catch(o){console.error(Ppe,o),Xn.error(o),process.exit(1)}}if(!e){let o=AK(Object.keys(Xt.CONFIG_PARAM_MAP),!0);!Bo.isEmpty(o)&&!Bo.isEmptyOrZeroLength(Object.keys(o))&&II.updateConfigValue(void 0,void 0,o,!0,!0)}let r,n=ld?.service==="clustering";ld?.service&&!n&&(console.error("Unrecognized service argument"),process.exit(1));try{let o=Number.parseInt(await Uo.readFile(vo.join(pe.get(Xt.CONFIG_PARAMS.ROOTPATH),Xt.HDB_PID_FILE),"utf8")),c=await hpe.processes();for(let l of c.list)if(l.pid===o){n?r=!0:console.log("HarperDB appears to be already running.");break}}catch{}qi===void 0&&(qi=Uu()),n&&(r||(console.error("HarperDB must be running to start clustering."),process.exit()),pe.get(Xt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY)||(console.error("Clustering must be setup and enabled in harperdb-config."),process.exit()),console.log("Starting clustering."),await RK.generateNatsConfig(),await qi.startClusteringProcesses(!0),process.exit()),Mpe(),await Uo.writeFile(vo.join(pe.get(QS.CONFIG_PARAMS.ROOTPATH),QS.HDB_PID_FILE),`${process.pid}`),Xn.info("HarperDB PID",process.pid);let s;try{let o=await Npe.getVersionUpdateInfo();o!==void 0&&(s=o[Xt.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION],await Tpe.upgrade(o),console.log(wpe))}catch(o){s?(console.error(`Got an error while trying to upgrade your HarperDB instance to version ${s}. Exiting HarperDB.`,o),Xn.error(o)):(console.error(Cpe,o),Xn.error(o)),process.exit(1)}ppe(),Bpe(),await ype.reviewSelfSignedCert(),Bo.autoCastBoolean(pe.get(Xt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&Ipe&&await RK.generateNatsConfig(t)}a(bK,"initialize");async function Upe(e=!1){try{ld=Ape(process.argv),ld.ROOTPATH&&II.updateConfigObject("settings_path",vo.join(ld.ROOTPATH,Xt.HDB_CONFIG_FILE)),await bK(e,!0),pe.get(Xt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await Rpe();let t=process.env.IS_SCRIPTED_SERVICE&&!ld.service;Bo.autoCastBoolean(pe.get(Xt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&(t||await qi.startClusteringProcesses(),await qi.startClusteringThreads()),await Ope(process.env.DEV_MODE?1:pe.get(QS.CONFIG_PARAMS.THREADS_COUNT)??pe.get(QS.CONFIG_PARAMS.THREADS)),pe.get(Xt.CONFIG_PARAMS.LOGGING_ROTATION_ENABLED)&&await gpe(),t||OK()}catch(t){console.error(t),Xn.error(t),process.exit(1)}}a(Upe,"main");function OK(){Xn.suppressLogging(()=>{console.log(NI.magenta(`HarperDB ${Spe.version} successfully started`))}),Xn.notify(Lpe)}a(OK,"started");async function vpe(e=!0){yK=!e;try{qi===void 0&&(qi=Uu()),qi.enterPM2Mode(),await bK(),Bo.autoCastBoolean(pe.get(Xt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&await qi.startClusteringProcesses(),await qi.startService(Xt.PROCESS_DESCRIPTORS.HDB),OK(),e&&process.exit(0)}catch(t){console.error(t),Xn.error(t),process.exit(1)}}a(vpe,"launch");function Bpe(){let e=vo.join(pe.get(Xt.CONFIG_PARAMS.ROOTPATH),Xt.LICENSE_KEY_DIR_NAME,Xt.LICENSE_FILE_NAME),t=vo.join(e,Xt.LICENSE_FILE_NAME),r=vo.join(e,Xt.REG_KEY_FILE_NAME);try{let{HARPERDB_FINGERPRINT:n,HARPERDB_LICENSE:s}=AK(["HARPERDB_FINGERPRINT","HARPERDB_LICENSE"]);if(Bo.isEmpty(n)||Bo.isEmpty(s))return;Uo.mkdirpSync(e),Uo.writeFileSync(r,n),Uo.writeFileSync(t,s)}catch(n){let s=`Failed to write license & fingerprint due to: ${n.message}`;console.error(s),Xn.error(s)}}a(Bpe,"writeLicenseFromVars");Object.assign(IK,{launch:vpe,main:Upe,isHdbInstalled:NK,startupLog:Hpe});async function NK(){try{await Uo.stat(Bo.getPropsFilePath()),await Uo.stat(pe.get(Xt.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}catch(e){if(Bo.noBootFile())return!0;if(e.code==="ENOENT")return!1;throw Xn.error(`Error checking for HDB install - ${e}`),e}return!0}a(NK,"isHdbInstalled");function Hpe(e){let r=a(f=>f.padEnd(20),"pad"),n=`
|
|
111
|
+
Reindexing upgrade started for transaction logs`),Io.notify("Reindexing upgrade started for transaction logs"),await y1(cI,!0,e)),Io.notify("Reindexing upgrade complete"),"Reindexing for 4.0.0 upgrade complete"+(mE?", but errors occurred":"")}a(dEe,"reindexUpgrade");async function y1(e,t,r){let n=await ki.readdir(e),s=n.length;for(let i=0;i<s;i++){let o=n[i],c=wo.join(e,o.toString());if(o===".DS_Store")continue;let l=await ki.readdir(c),u=l.length;for(let d=0;d<u;d++){let _=l[d];if(_!==".DS_Store"&&ki.statSync(wo.join(c,_)).isDirectory())try{await _Ee(o,_,t),rn.info(`Reindexing started for ${o}.${_}`),Io.notify(`${t?"Transaction":"Schema"} reindexing started for ${o}.${_}`),await EEe(o,_,c,t,r),rn.info(`Reindexing completed for ${o}.${_}`),Io.notify(`Reindexing completed for ${o}.${_}`)}catch(E){mE=!0,E.schema_path=c,E.table_name=_,Io.error("There was an error with the reindex upgrade, check the logs in hdb/3_0_0_upgrade_tmp for more details"),Io.error(E),rn.error(E),console.error(E)}}}if(!mE)try{await ki.rm(kS,{recursive:!0})}catch{}}a(y1,"processTables");async function _Ee(e,t,r){let s=`${e}_${t}_${r?"transaction_reindex":"schema_reindex"}.log`,i=wo.join(kS,s);await ki.ensureDir(kS),await ki.writeFile(i,""),rn=lEe({level:"debug",formatters:{bindings(){}}},i)}a(_Ee,"initPinoLogger");var fEe=20;async function EEe(e,t,r,n,s){let i;try{i=await zn.openEnvironment(r,t,n)}catch(S){if(S.message==="MDB_INVALID: File is not an LMDB file"){Io.notify(`${e}.${t} file is not from the old environment and has been skipped`),console.info(`${e}.${t} file is not from the old environment and has been skipped`),rn.error(S);return}throw S}let o=mEe(i.dbis),c=zn.openDBI(i,o),l=Object.keys(i.dbis),u=zn.statDBI(i,o);rn.info(`Old environment stats: ${JSON.stringify(u)}`);let d=new cEe.SingleBar({format:`${e}.${t} |{bar}| {percentage}% || {value}/{total} records`,barCompleteChar:"\u2588",barIncompleteChar:"\u2591",hideCursor:!0,clearOnComplete:!1});d.start(u.entryCount,0,{});let _=await zn.createEnvironment(r,t,!1);zn.createDBI(_,o,!1,!0);let E=[];try{for(let S of c.getRange({start:!1}))S.value={...S.value},E.push(S),n||e==="system"&&(t==="hdb_schema"&&(S.key=S.key.toString(),S.value.name=S.value.name.toString()),t==="hdb_table"&&(S.key=S.key.toString(),S.value.schema=S.value.schema.toString(),S.value.name=S.value.name.toString()),t==="hdb_attribute"&&(S.key=S.key.toString(),S.value.schema=S.value.schema.toString(),S.value.table=S.value.table.toString(),S.value.attribute=S.value.attribute.toString())),E.length>fEe&&await f();await f()}catch(S){throw mE=!0,rn.error(S),S}async function f(){let S,b=E.map(({value:B})=>B);n?S=await Promise.all(b.map(B=>hEe(_,B))):S=await sEe(_,o,l.filter(B=>B!=="__blob__"),b,!1);for(let B=0,H=E.length;B<H;B++){let{key:X,value:Y}=E[B];rn.info(`Record hash value: ${X} hash: ${o}`);let V;n?V=S[B]:V=S.written_hashes.indexOf(X)>-1,pE(V,!0),pEe(_,o,Y[o],n),rn.info(`Insert success, written hashes: ${S.written_hashes}`),d.increment()}E=[],d.value/d.total*100%10===0&&Io.notify(`${e}.${t} ${d.value}/${d.total} records inserted`),rn.info(`${d.value}/${d.total} records inserted`)}a(f,"finishOutstanding"),d.stop();let h=zn.statDBI(i,o),T=zn.statDBI(_,o);if(rn.info(`Old stats entry count: ${h.entryCount}. New stats entry count: ${T.entryCount}`),pE.deepStrictEqual(h.entryCount,T.entryCount),await zn.closeEnvironment(i),await zn.closeEnvironment(_),delete global.lmdb_map[`${e}.${t}`],s){let S=wo.join(r,t),b=wo.join(S,"data.mdb"),I=wo.join(S,"lock.mdb");await ki.unlink(b),await ki.unlink(I),await ki.rmdir(S),rn.info(`Deleted old environment files from schema folder: ${b}, ${I}`)}let m=await zn.openEnvironment(r,t),g=zn.statDBI(m,o);rn.info(`New stats: ${JSON.stringify(T)}. New stats after move: ${JSON.stringify(g)}`),pE.deepStrictEqual(g.entryCount,T.entryCount),await zn.closeEnvironment(m),delete global.lmdb_map[`${e}.${t}`]}a(EEe,"processTable");async function hEe(e,t){zn.initializeDBIs(e,Ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Ia.TRANSACTIONS_DBIS);let r=t.timestamp;return e.dbis[Ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(r,()=>{e.dbis[Ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(r,t),aEe.isEmpty(t.user_name)||e.dbis[Ia.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(t.user_name,r);for(let n of t.hash_values)e.dbis[Ia.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(n,r)})}a(hEe,"insertTransaction");function pEe(e,t,r,n){let i=e.dbis[t].get(r);pE.deepStrictEqual(typeof i,"object");let o;if(n){let c={[Ia.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME]:i.user_name,[Ia.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE]:i.hash_values};o=Object.entries(c)}else o=Object.entries(i);for(let[c,l]of o)if(c!==t&&e.dbis[c]!==void 0&&!oEe.isEmptyOrZeroLength(l))if(n&&c==="hash_value")for(let u=0,d=l.length;u<d;u++){let _=l[u];b1(e,c,_,r)}else b1(e,c,l,r)}a(pEe,"validateIndices");function b1(e,t,r,n){try{let s=!1,i=iEe.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(b1,"validateIndex");function mEe(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(mEe,"getHashDBI")});var P1=N((tLe,D1)=>{"use strict";var FS=require("path"),wa=require("fs-extra"),SEe=oI(),cl=W(),I1=wt(),lI=se(),oi=M(),GS=te(),TEe=require("properties-reader"),gEe=$s(),REe=Hp(),AEe=Vr(),eLe=require("util"),yEe=AEe.searchByValue,bEe=un(),OEe=gm(),NEe=Ct(),IEe=N1(),w1=Xs(),wEe=BS(),gE=new SEe("4.0.0"),C1=[],SE,TE;async function CEe(){try{if(await wEe.upgradeCertsPrompt()){if(console.log("Generating new certificates."),SE){let t=GS.changeExtension(SE,".bak");await wa.move(SE,t)}if(TE){let t=GS.changeExtension(TE,".bak");await wa.move(TE,t)}await w1.generateKeys()}else console.log("Using existing certificates."),w1.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(CEe,"generateNewKeys");async function DEe(){console.log("Updating HarperDB nodes."),cl.info("Updating HarperDB nodes.");let e=[];try{let t=new gEe(oi.SYSTEM_SCHEMA_NAME,oi.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*","name",["*"]),r=Array.from(await yEe(t)),n=[];for(let i=0,o=r.length;i<o;i++){let c=r[i];if(!NEe.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 REe(oi.SYSTEM_SCHEMA_NAME,oi.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,n);await bEe.update(s)}catch(t){throw console.error("There was a problem updating the hdb_nodes table. Please check the log for details."),t}try{OEe.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(DEe,"updateNodes");async function PEe(){let e=lI.get(oi.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);if(!e.includes(FS.join("config","settings.js"))){cl.info("pre 4.0.0 settings.js file not found, skipping settings file update");return}let t="Updating settings file for version 4.0.0";console.log(t),cl.info(t);let r=FS.dirname(e),n=lI.get(oi.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),s=FS.join(n,"backup","4_0_0_upgrade_settings.bak"),i=FS.join(n,oi.HDB_CONFIG_FILE);try{cl.info(`Backing up old settings file to: ${s}`),console.log(`Backing up old settings file to: ${s}`),wa.copySync(e,s)}catch(_){throw console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),_}try{cl.info(`Creating new/upgraded settings file at '${i}'`),console.log(`Creating new/upgraded settings file at '${i}'`),cl.info("Updating env variables with new settings values");let _=I1.initOldConfig(e);SE=_[oi.CONFIG_PARAMS.TLS_CERTIFICATE.toLowerCase()],TE=_[oi.CONFIG_PARAMS.TLS_PRIVATEKEY.toLowerCase()],I1.createConfigFile(_)}catch(_){throw console.log("There was a problem creating the new HarperDB config file. Please check the log for details."),_}let o=GS.getPropsFilePath();wa.accessSync(o,wa.constants.F_OK|wa.constants.R_OK);let l=TEe(o).get(oi.HDB_SETTINGS_NAMES.INSTALL_USER),u=`settings_path = ${i}
|
|
112
|
+
install_user = ${l}`;try{wa.writeFileSync(o,u)}catch(_){throw console.log("There was a problem updating the HarperDB boot properties file. Please check the log for details."),_}try{lI.initSync(!0)}catch(_){throw console.error("Unable to initialize new properties. Please check the log for details."),_}let d="New settings file for 4.0.0 upgrade successfully created.";try{wa.removeSync(r),console.log(d),cl.info(d)}catch(_){throw console.error("There was a problem deleting the old settings file and directory. Please check the log for details."),_}}a(PEe,"updateSettingsFile_4_0_0");gE.async_functions.push(PEe);gE.async_functions.push(CEe);gE.async_functions.push(IEe);gE.async_functions.push(DEe);C1.push(gE);D1.exports=C1});var uI=N((nLe,v1)=>{"use strict";var ll=te(),LEe=M(),L1=W(),{DATA_VERSION:MEe,UPGRADE_VERSION:UEe}=LEe.UPGRADE_JSON_FIELD_NAMES_ENUM,M1=R1(),qS=P1(),ul=new Map;M1&&M1.forEach(e=>{ul.set(e.version,e)});qS&&qS.forEach(e=>{ul.set(e.version,e)});qS&&qS.forEach(e=>{ul.set(e.version,e)});function vEe(){return[...ul.keys()].sort(ll.compareVersions)}a(vEe,"getSortedVersions");function U1(e){let t=e[MEe],r=e[UEe];return ll.isEmptyOrZeroLength(t)||ll.isEmptyOrZeroLength(r)?(L1.info(`There is an issue with the version data in your instance of HDB. Current version data: ${e}`),L1.error("There was an error when trying to evaluate the version information for your instance. Trying to start the server anyways but it may fail. If you continue to have this problem, please contact support@harperdb.io."),[]):[...ul.keys()].sort(ll.compareVersions).filter(function(n){return ll.compareVersions(n,t)>0&&ll.compareVersions(n,r)<=0})}a(U1,"getVersionsForUpgrade");function BEe(e){return U1(e).length>0}a(BEe,"hasUpgradesRequired");function HEe(e){return ll.isEmptyOrZeroLength(e)?null:ul.has(e)?ul.get(e):null}a(HEe,"getDirectiveByVersion");v1.exports={getSortedVersions:vEe,getDirectiveByVersion:HEe,getVersionsForUpgrade:U1,hasUpgradesRequired:BEe}});var VS=N((iLe,F1)=>{"use strict";var xEe=require("util"),dI=require("chalk"),kEe=require("os"),H1=un(),FEe=Vr(),Qn=M(),x1=l1(),fI=wR(),{UpgradeObject:B1}=_1(),{forceDowngradePrompt:GEe}=BS(),qEe=vc(),$S=W(),cd=te(),EI=ls(),$Ee=(Pe(),oe(lt)),VEe=uI(),KEe=xEe.promisify(EI.setSchemaDataToGlobal),YEe=FEe.searchByValue,WEe="info_id",jEe="2.9.9",zEe="3.0.0";async function QEe(e){let t=new x1.HdbInfoInsertObject(1,e,e),r=new fI.InsertObject(Qn.OPERATIONS_ENUM.INSERT,Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,Qn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,[t]);return EI.setSchemaDataToGlobal(),H1.insert(r)}a(QEe,"insertHdbInstallInfo");async function _I(e){let t,r=await k1(),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 x1.HdbInfoInsertObject(i,e,e);let o=new fI.InsertObject(Qn.OPERATIONS_ENUM.INSERT,Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,Qn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,[t]);return await KEe(),H1.insert(o)}a(_I,"insertHdbUpgradeInfo");async function k1(){let e=new fI.NoSQLSeachObject(Qn.SYSTEM_SCHEMA_NAME,Qn.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,WEe,Qn.SYSTEM_TABLE_HASH_ATTRIBUTES.INFO_TABLE_ATTRIBUTE,["*"],"*"),t=[];try{t=Array.from(await YEe(e))}catch(r){console.error(r)}return t}a(k1,"getAllHdbInfoRecords");async function JEe(){let e=await k1();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(JEe,"getLatestHdbInfoRecord");async function XEe(){$S.info("Checking if HDB software has been updated");try{let e=qEe.version(),t=await JEe(),r;if(cd.isEmpty(t))r=jEe;else if(r=t.data_version_num,cd.compareVersions(r.toString(),e.toString())>0){if(!cd.isCompatibleDataVersion(r.toString(),e.toString()))throw console.log(dI.yellow(`This instance's data was last run on version ${r}`)),console.error(dI.red(`You have installed a version lower than the version that your data was created on or was upgraded to. This may cause issues and is currently not supported.${kEe.EOL}${Qn.SUPPORT_HELP_MSG}`)),new Error("Trying to downgrade major HDB versions is not supported.");cd.isCompatibleDataVersion(r.toString(),e.toString(),!0)||(console.log(dI.yellow(`This instance's data was last run on version ${r}`)),await GEe(new B1(r,e))?await _I(e.toString()):(console.log("Cancelled downgrade, closing HarperDB"),process.exit(0)))}if(EI.setSchemaDataToGlobal(),ZEe(r),e.toString()===r.toString())return;let n=new B1(r,e);if(VEe.hasUpgradesRequired(n))return n;cd.compareVersions(n.data_version.toString(),n.upgrade_version.toString())<0&&(await _I(n.upgrade_version),$S.notify(`HarperDB running on upgraded version: ${n.upgrade_version}`))}catch(e){throw $S.fatal("Error while trying to evaluate the state of hdb data and the installed hdb version"),$S.fatal(e),e}}a(XEe,"getVersionUpdateInfo");function ZEe(e){let t=`You are attempting to upgrade from an old instance of HarperDB that is no longer supported. In order to upgrade to this version, you must do a fresh install. If you need support, please contact ${Qn.HDB_SUPPORT_ADDRESS}`;if(!("hdb_info"in $Ee.databases.system))throw console.log(t),new Error(t);if(!cd.isEmpty(e)&&e<zEe)throw console.log(t),new Error(t)}a(ZEe,"checkIfInstallIsSupported");F1.exports={insertHdbInstallInfo:QEe,insertHdbUpgradeInfo:_I,getVersionUpdateInfo:XEe}});var V1=N((aLe,$1)=>{"use strict";var KS=require("joi"),{boolean:ehe,string:hI,number:the}=KS.types(),G1=require("fs-extra"),RE=M(),q1=require("path"),rhe=Tt();$1.exports=nhe;function nhe(e){let t=hI.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),r=KS.object({[RE.INSTALL_PROMPTS.ROOTPATH]:KS.custom(she),[RE.INSTALL_PROMPTS.OPERATIONSAPI_NETWORK_PORT]:KS.alternatives([the.min(0),hI]).allow("null",null),[RE.INSTALL_PROMPTS.TC_AGREEMENT]:hI.valid("yes","YES","Yes"),[RE.INSTALL_PROMPTS.CLUSTERING_NODENAME]:t,[RE.INSTALL_PROMPTS.CLUSTERING_ENABLED]:ehe});return rhe.validateBySchema(e,r)}a(nhe,"installValidator");function she(e,t){if(G1.existsSync(q1.join(e,"system/hdb_user/data.mdb"))||G1.existsSync(q1.join(e,"system/hdb_user.mdb")))return t.message(`'${e}' is already in use. Please enter a different path.`)}a(she,"validateRootAvailable")});var Y1=N((lLe,K1)=>{"use strict";var{mkdirpSync:ihe,copySync:ohe}=require("fs-extra"),Ca=require("path"),ld=M(),mI=W(),ahe=Bn(),pI=Zi(),che=gt();K1.exports=lhe;async function lhe(e){mI.trace("Mounting HarperDB"),dl(e),dl(Ca.join(e,"backup")),dl(Ca.join(e,"keys")),dl(Ca.join(e,"keys",ld.LICENSE_FILE_NAME)),dl(Ca.join(e,"log")),dl(Ca.join(e,"database")),dl(Ca.join(e,"components")),ohe(Ca.resolve(ld.PACKAGE_ROOT,"./utility/install/README.md"),Ca.join(e,"README.md")),await uhe()}a(lhe,"mountHdb");async function uhe(){let e=w_(),t=Object.keys(pI);for(let r=0;r<t.length;r++){let n=t[r],s=pI[n].hash_attribute;try{che.initSystemSchemaPaths(ld.SYSTEM_SCHEMA_NAME,n);let i=new e(ld.SYSTEM_SCHEMA_NAME,n,s);i.attributes=pI[n].attributes;let o=i.attributes.find(({attribute:c})=>c===s);o.isPrimaryKey=!0,["hdb_user","hdb_role"].includes(n)&&(i.audit=!0),await ahe.createTable(n,i)}catch(i){throw mI.error(`issue creating environment for ${ld.SYSTEM_SCHEMA_NAME}.${n}: ${i}`),i}}}a(uhe,"createLMDBTables");function dl(e){ihe(e,{mode:ld.HDB_FILE_PERMISSIONS}),mI.info(`Directory ${e} created`)}a(dl,"makeDirectory")});var oK=N((fLe,iK)=>{"use strict";var TI=require("os"),J1=require("inquirer"),Cs=require("fs-extra"),dhe=require("properties-reader"),fl=require("chalk"),Gi=require("path"),_he=require("human-readable-ids").hri,fhe=require("ora"),Ehe=require("yaml"),ur=W(),Da=se(),AE=te(),WS=Wa(),X1=VS(),Z1=vc(),ue=M(),{CONFIG_PARAM_MAP:dLe,CONFIG_PARAMS:Mt}=ue,hhe=V1(),phe=Y1(),gI=wt(),mhe=xn(),She=lf(),The=eI(),ghe=ls(),Rhe=require("util").promisify,Ahe=Rhe(ghe.setSchemaDataToGlobal),W1=Xs(),_l=a(e=>e,"PROMPT_ANSWER_TRANSFORMER"),xr=a(e=>fl.magenta.bold(e),"HDB_PROMPT_MSG"),yhe="https://harperdb.io/legal/end-user-license-agreement",Pa=TI.EOL,Co="",bhe="yes",j1="Starting HarperDB install...",z1="HarperDB installation was successful.",Q1="Terms & Conditions acceptance is required to proceed with installation. Exiting install...",Ohe="An out of date version of HarperDB is already installed.",SI="It appears that HarperDB is already installed. Exiting install...",Nhe="Aborting install",_Le=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])$/),Ihe=new RegExp(/^[^\s.,*>]+$/),whe=TI.homedir(),Che=Gi.join(whe,ue.HDB_ROOT_DIR_NAME),Dhe="HDB_ADMIN",Phe="CLUSTER_USER",Lhe="dev",Mhe="localhost",YS={[Mt.HTTP_CORS]:!0,[Mt.HTTP_CORSACCESSLIST]:["*"],[Mt.HTTP_PORT]:9926,[Mt.AUTHENTICATION_AUTHORIZELOCAL]:!0,[Mt.THREADS_COUNT]:1,[Mt.THREADS_DEBUG]:!0,[Mt.LOGGING_STDSTREAMS]:!0,[Mt.LOGGING_LEVEL]:"info",[Mt.OPERATIONSAPI_NETWORK_PORT]:9925,[Mt.LOCALSTUDIO_ENABLED]:!0},Hr={DESTINATION:"Please enter a destination for HarperDB:",HDB_USERNAME:"Please enter a username for the administrative user:",HDB_PASS:"Please enter a password for the administrative user:",NODE_NAME:"Please enter a unique name for this node:",CLUSTER_USERNAME:"Please enter a username for the CLUSTER_USER:",CLUSTER_PASS:"Please enter a password for the CLUSTER_USER:",DEFAULTS_MODE:"Default Config - dev (easy access/debugging) or prod (security/performance): (dev/prod)",REPLICATION_HOSTNAME:"Please enter the hostname for this server:"},La=WS([ue.INSTALL_PROMPTS.HDB_CONFIG]),Fi,eK=!1,RI=!1,tK=!1;iK.exports={install:rK,updateConfigEnv:Vhe,setIgnoreExisting:Khe};rK.createSuperUser=sK;async function rK(){console.log(xr(Pa+j1+Pa)),ur.notify(j1);let e;La[ue.INSTALL_PROMPTS.HDB_CONFIG]&&(e=Uhe());let t=Bhe();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&&(tK=!0,t[ue.INSTALL_PROMPTS.DEFAULTS_MODE]="prod");let r=hhe(t);if(r)throw r.message;await Hhe(),await xhe(t);let n=await vhe(t);Fi=n[ue.INSTALL_PROMPTS.ROOTPATH],La[ue.INSTALL_PROMPTS.HDB_CONFIG]&&Gi.dirname(La[ue.INSTALL_PROMPTS.HDB_CONFIG])===Fi&&(eK=!0),!RI&&!La[ue.INSTALL_PROMPTS.HDB_CONFIG]&&await Cs.pathExists(Gi.join(Fi,ue.HDB_CONFIG_FILE))&&(console.error(SI),process.exit());let s=fhe({prefixText:xr("Installing"),color:"magenta",spinner:"simpleDots"});if(s.start(),AE.isEmpty(Fi))throw new Error("Installer should have the HDB root param at the stage it is in but it does not.");Da.setHdbBasePath(Fi),await phe(Fi),await khe(),await Fhe(n),ur.initLogSettings(!0),await sK(n),await qhe(n),await W1.updateConfigCert(),await W1.generateCertsKeys(),await $he(),The(),s.stop(),console.log(xr(Pa+z1+Pa)),ur.notify(z1)}a(rK,"install");function Uhe(){let e=Ehe.parseDocument(Cs.readFileSync(La[ue.INSTALL_PROMPTS.HDB_CONFIG],"utf8"),{simpleKeys:!0}),t=gI.flattenConfig(e.toJSON());return t[ue.CONFIG_PARAMS.ROOTPATH.toLowerCase()]&&(t.ROOTPATH=t[ue.CONFIG_PARAMS.ROOTPATH.toLowerCase()]),t}a(Uhe,"getConfigFromFile");async function vhe(e){ur.trace("Getting install prompts and params.");let t,r=[{type:"input",transformer:_l,when:Do(e[ue.INSTALL_PROMPTS.ROOTPATH],Hr.DESTINATION),name:ue.INSTALL_PROMPTS.ROOTPATH,prefix:Co,default:Che,validate:a(async s=>ws(s)?ws(s):await Cs.pathExists(Gi.join(s,"system","hdb_user.mdb"))?`'${s}' is already in use. Please enter a different path.`:!0,"validate"),message:xr(Hr.DESTINATION)},{type:"input",transformer:_l,when:Do(e[ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],Hr.HDB_USERNAME),name:ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME,prefix:Co,default:Dhe,validate:a(s=>ws(s)?ws(s):(t=s,!0),"validate"),message:xr(Hr.HDB_USERNAME)},{type:"password",when:Do(e[ue.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD],Hr.HDB_PASS),name:ue.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD,prefix:Co,validate:a(s=>ws(s)?ws(s):!0,"validate"),message:xr(Hr.HDB_PASS)},{type:"input",transformer:_l,when:Do(e[ue.INSTALL_PROMPTS.DEFAULTS_MODE],Hr.DEFAULTS_MODE),name:ue.INSTALL_PROMPTS.DEFAULTS_MODE,prefix:Co,default:Lhe,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(tK||r.push({type:"input",name:ue.INSTALL_PROMPTS.REPLICATION_HOSTNAME,transformer:_l,when:Do(e[ue.INSTALL_PROMPTS.REPLICATION_HOSTNAME],Hr.REPLICATION_HOSTNAME),prefix:Co,default:Mhe,message:xr(Hr.REPLICATION_HOSTNAME)}),AE.autoCastBoolean(e[ue.INSTALL_PROMPTS.CLUSTERING_ENABLED])===!0){let s=[{type:"input",transformer:_l,when:Do(e[ue.INSTALL_PROMPTS.CLUSTERING_NODENAME],Hr.NODE_NAME),name:ue.INSTALL_PROMPTS.CLUSTERING_NODENAME,prefix:Co,default:_he.random(),validate:a(i=>Ihe.test(i)?!0:"Invalid node name, must not contain ., * or >","validate"),message:xr(Hr.NODE_NAME)},{type:"input",transformer:_l,when:Do(e[ue.INSTALL_PROMPTS.CLUSTERING_USER],Hr.CLUSTER_USERNAME),name:ue.INSTALL_PROMPTS.CLUSTERING_USER,prefix:Co,default:Phe,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 J1.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(vhe,"installPrompts");function Do(e,t){return e!==void 0?(t.includes("password")?(console.log(`${xr(t)} ${fl.gray("[hidden]")}`),ur.trace(`${xr(t)} [hidden]`)):(console.log(`${xr(t)} ${e}`),ur.trace(`${xr(t)} ${e}`)),!1):!0}a(Do,"displayCmdEnvVar");function ws(e){let t=e.replace(/ /g,"");if(t===""||t==="''"||t==='""')return"Value cannot be empty."}a(ws,"checkForEmptyValue");function Bhe(){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(Bhe,"checkForPromptOverride");async function Hhe(){ur.trace("Checking for existing install.");let e=AE.getPropsFilePath(),t=await Cs.pathExists(e),r;if(t){ur.trace(`Install found an existing boot prop file at:${e}`);let n=dhe(e),s=gI.getConfigValue(ue.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)||n.get(ue.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY);r=await Cs.pathExists(s)}if(!t&&AE.noBootFile()&&(r=!0),r&&!RI){if(ur.trace(`Install found existing HDB config at:${e}`),await X1.getVersionUpdateInfo()){let s=`Please use \`harperdb upgrade\` to update to ${Z1.version()}. Exiting install...`;console.log(Pa+fl.magenta.bold(Ohe)),console.log(fl.magenta.bold(s)),ur.error(s)}else console.log(Pa+fl.magenta.bold(SI)),ur.error(SI);process.exit(0)}}a(Hhe,"checkForExistingInstall");async function xhe(e){ur.info("Asking for terms agreement.");let t=`Terms & Conditions can be found at ${yhe}${Pa}and can be viewed by typing or copying and pasting the URL into your web browser.${Pa}I agree to the HarperDB Terms and Conditions: (yes/no)`,r={prefix:Co,transformer:_l,when:Do(e[ue.INSTALL_PROMPTS.TC_AGREEMENT],t),name:ue.INSTALL_PROMPTS.TC_AGREEMENT,message:xr(t),validate:a(s=>s.toLowerCase()==="yes"||s.toLowerCase()==="no"?!0:fl.yellow("Please enter 'yes' or 'no'"),"validate")},n=await J1.prompt([r]);n[ue.INSTALL_PROMPTS.TC_AGREEMENT]&&n[ue.INSTALL_PROMPTS.TC_AGREEMENT].toLowerCase()!==bhe&&(console.log(fl.yellow(Q1)),ur.error(Q1),process.exit(0))}a(xhe,"termsAgreement");async function khe(){let e=Gi.join(Fi,ue.HDB_CONFIG_FILE),t;try{t=TI.userInfo().username}catch{t=process.env.USERNAME||process.env.USER||process.env.LOGNAME||process.env.LNAME||process.env.SUDO_USER}if(t){let r=`settings_path = ${e}
|
|
113
|
+
install_user = ${t}`,n=AE.getHomeDir(),s=Gi.join(n,ue.HDB_HOME_DIR_NAME),i=Gi.join(s,ue.LICENSE_KEY_DIR_NAME);try{Cs.mkdirpSync(s,{mode:ue.HDB_FILE_PERMISSIONS}),Cs.mkdirpSync(i,{mode:ue.HDB_FILE_PERMISSIONS})}catch{console.error(`Could not make settings directory ${ue.HDB_HOME_DIR_NAME} in home directory. Please check your permissions and try again.`)}let o=Gi.join(s,ue.BOOT_PROPS_FILE_NAME);try{await Cs.writeFile(o,r)}catch(c){throw ur.error(`There was an error creating the boot file at path: ${o}`),c}Da.setProperty(ue.HDB_SETTINGS_NAMES.INSTALL_USER,`${t}`),Da.setProperty(ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,e),Da.setProperty(Da.BOOT_PROPS_FILE_PATH,o)}}a(khe,"createBootPropertiesFile");async function Fhe(e){ur.trace("Creating HarperDB config file");let t=WS(Object.keys(ue.CONFIG_PARAM_MAP),!0);if(Object.assign(t,e),e[ue.INSTALL_PROMPTS.DEFAULTS_MODE]==="dev"){process.env.DEV_MODE="true";for(let r in YS){if(r===Mt.HTTP_PORT&&t[Mt.HTTP_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??YS[r],t[Mt.HTTP_SECUREPORT]=null;continue}else if(r===Mt.HTTP_PORT)continue;if(r===Mt.OPERATIONSAPI_NETWORK_PORT&&t[Mt.OPERATIONSAPI_NETWORK_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??YS[r],t[Mt.OPERATIONSAPI_NETWORK_SECUREPORT]=null;continue}else if(r===Mt.OPERATIONSAPI_NETWORK_PORT)continue;t[r.toLowerCase()]===void 0&&(t[r]=YS[r])}}else t[Mt.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]&&(t[Mt.OPERATIONSAPI_NETWORK_SECUREPORT]=null),t[Mt.HTTP_PORT.toLowerCase()]&&(t[Mt.HTTP_SECUREPORT]=null);try{La[ue.INSTALL_PROMPTS.HDB_CONFIG]||gI.createConfigFile(t),Da.initSync()}catch(r){Ghe(r)}}a(Fhe,"createConfigFile");function Ghe(e){ur.error(`Error creating HarperDB config file. Rolling back install - ${e}`),console.error(e),console.error(Nhe);let t=Gi.resolve(Da.get(Da.BOOT_PROPS_FILE_PATH),"../");t&&Cs.removeSync(t),Fi&&(eK?Cs.readdirSync(Fi,{withFileTypes:!0}).forEach(n=>{let s=Gi.join(n.path,n.name);s!==La[ue.INSTALL_PROMPTS.HDB_CONFIG]&&Cs.removeSync(s)}):Cs.removeSync(Fi)),process.exit(1)}a(Ghe,"rollbackInstall");async function nK(e,t){ur.trace("Creating admin user"),await Ahe();let r;try{r=await She.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 mhe.addUser(t)}catch(n){throw n.message=`Error creating user - ${n}`,n}}a(nK,"createAdminUser");async function sK(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 nK(t,r),delete e[ue.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],delete e[ue.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]}a(sK,"createSuperUser");async function qhe(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 nK({role:"cluster_user",permission:{cluster_user:!0}},t),delete e[ue.INSTALL_PROMPTS.CLUSTERING_USER],delete e[ue.INSTALL_PROMPTS.CLUSTERING_PASSWORD]}a(qhe,"createClusterUser");async function $he(){let e=Z1.version();if(e)await X1.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a($he,"insertHdbVersionInfo");function Vhe(e){La[ue.INSTALL_PROMPTS.HDB_CONFIG]=e}a(Vhe,"updateConfigEnv");function Khe(e){RI=e}a(Khe,"setIgnoreExisting")});var lK=N((hLe,cK)=>{"use strict";var AI=te(),Jn=W(),aK=uI();cK.exports={processDirectives:Yhe};async function Yhe(e){console.log("Starting upgrade process...");let t=aK.getVersionsForUpgrade(e),r=zhe(t),n=[],s=r.length;for(let i=0;i<s;i++){let o=r[i],c=`Running upgrade for version ${o.version}`;Jn.notify(c),console.log(c);let l=[],u=[];try{l=Whe(o.sync_functions)}catch(d){throw Jn.error(`Error while running an upgrade script for ${o.version}`),d}try{u=await jhe(o.async_functions)}catch(d){throw Jn.error(`Error while running an upgrade script for ${o.version}`),d}n.push(...l,...u)}return n}a(Yhe,"processDirectives");function Whe(e){if(AI.isEmptyOrZeroLength(e))return Jn.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return Jn.info("Passed parameter is not an array"),[];let t=[];for(let r of e){if(Jn.info(`Running function ${r.name}`),!(r instanceof Function)){Jn.info("Variable being processed is not a function");continue}let n=r();Jn.info(n),t.push(n)}return t}a(Whe,"runSyncFunctions");async function jhe(e){if(AI.isEmptyOrZeroLength(e))return Jn.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return Jn.info("Passed parameter is not an array"),[];let t=[],r=e.length;for(let n=0;n<r;n++){let s=e[n];if(Jn.info(`Running function ${s.name}`),!(s instanceof Function)){Jn.info("Variable being processed is not a function");continue}let i=await s();Jn.info(i),t.push(i)}return t}a(jhe,"runAsyncFunctions");function zhe(e){if(AI.isEmptyOrZeroLength(e))return[];let t=[];for(let r of e){let n=aK.getDirectiveByVersion(r);n&&t.push(n)}return t}a(zhe,"getUpgradeDirectivesToInstall")});var pK=N((mLe,hK)=>{"use strict";var jS=se();jS.initSync();var fK=require("chalk"),uK=require("fs-extra"),Lo=W(),Po=M(),dK=vc(),Qhe=lK(),yI=te(),EK=VS(),Jhe=BS(),_K=hg(),Xhe=ls(),Zhe=require("util").promisify,epe=Zhe(Xhe.setSchemaDataToGlobal),bI,{UPGRADE_VERSION:zS}=Po.UPGRADE_JSON_FIELD_NAMES_ENUM;hK.exports={upgrade:tpe};async function tpe(e){await epe(),bI===void 0&&(bI=Hu()),uK.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)),uK.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 EK.getVersionUpdateInfo(),t||(console.log("HarperDB version is current"),process.exit(0))),yE(`This version of HarperDB is ${dK.version()}`,Po.LOG_LEVELS.INFO);let r=t[zS]?t[zS]:dK.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 rpe();let n,s=0;try{n=await Jhe.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 npe(t),yE(`HarperDB was successfully upgraded to version ${t[zS]}`,Po.LOG_LEVELS.INFO)}a(tpe,"upgrade");async function rpe(){let e=!1,t=await _K.findPs(Po.HDB_PROC_NAME);if(yI.isEmptyOrZeroLength(t)||(e=!0),!e){let r=await _K.findPs("hdb_express");yI.isEmptyOrZeroLength(r)||(e=!0)}if(!e){let r=await bI.list();yI.isEmptyOrZeroLength(r)||(e=!0)}if(e){let r="HarperDB is running, please stop all HarperDB services with 'harperdb stop' and run the upgrade command again.";console.log(fK.red(r)),Lo.error(r),process.exit(1)}}a(rpe,"checkIfRunning");async function npe(e){try{await Qhe.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 EK.insertHdbUpgradeInfo(e[zS])}catch(t){Lo.error("Error updating the 'hdb_info' system table."),Lo.error(t)}}a(npe,"runUpgrade");function yE(e,t=void 0){t||(t=Lo.info),Lo[t](e),console.log(fK.magenta(e))}a(yE,"printToLogAndConsole")});var RK=N((TLe,gK)=>{"use strict";var{promises:NI,createReadStream:spe,createWriteStream:ipe}=require("fs"),{createGzip:ope}=require("zlib"),{promisify:ape}=require("util"),{pipeline:cpe}=require("stream"),lpe=ape(cpe),upe=require("path"),hl=se();hl.initSync();var El=W(),{CONFIG_PARAMS:bE,ITC_EVENT_TYPES:dpe}=M(),{onMessageFromWorkers:_pe}=dt(),fpe=6e4,Epe="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",hpe="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",OI,SK;gK.exports=TK;_pe(e=>{e.type===dpe.RESTART&&(hl.initSync(!0),clearInterval(SK),hl.get(bE.LOGGING_ROTATION_ENABLED)&&TK())});async function TK(){try{let e=El.getLogFilePath(),t=hl.get(bE.LOGGING_ROTATION_MAXSIZE),r=hl.get(bE.LOGGING_ROTATION_INTERVAL);if(!t&&!r){El.error(Epe);return}let n=hl.get(bE.LOGGING_ROTATION_PATH);if(!n){El.error(hpe);return}let s;if(t){let o=t.slice(-1),c=t.slice(0,-1);o==="G"?s=c*1e9:o==="M"?s=c*1e6:s=c*1e3}let i;if(r){let o=r.slice(-1),c=r.slice(0,-1);o==="D"?i=c*1440:o==="H"?i=c*60:i=c}OI=Date.now()/6e4,El.trace("Log rotate enabled, maxSize:",t,"interval:",r),SK=setInterval(async()=>{if(s){let o;o=await NI.stat(e),o.size>=s&&await mK(e,n)}i&&Date.now()/6e4-OI>=i&&(await mK(e,n),OI=Date.now()/6e4)},fpe).unref()}catch(e){El.error(e)}}a(TK,"logRotator");async function mK(e,t){let r=hl.get(bE.LOGGING_ROTATION_COMPRESS),n=upe.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.${r?"log.gz":"log"}`);r?(await lpe(spe(e),ope(),ipe(n)),await NI.unlink(e)):await NI.rename(e,n),El.closeLogFile(),El.notify(`hdb.log rotated, old log moved to ${n}`)}a(mK,"moveLogFile")});var CK=N(wK=>{"use strict";var pe=se();pe.initSync();var RLe=Gu(),Xt=M(),Xn=W(),Mo=require("fs-extra"),Uo=require("path"),ppe=require("systeminformation"),mpe=eI(),{install:Spe}=oK(),II=require("chalk"),Tpe=Jl(),vo=te(),wI=wt(),yK=Wa(),AK=Om(),gpe=pK(),Rpe=RK(),{compactOnStart:Ape}=(oO(),oe(iO)),ype=require("minimist"),bpe=Xs(),{PACKAGE_ROOT:Ope,CONFIG_PARAMS:we}=M(),{startHTTPThreads:Npe,startSocketServer:ALe,mostIdleRouting:yLe,remoteAffinityRouting:bLe}=(CI(),oe(DK)),Ipe=VS(),{isMainThread:wpe}=require("worker_threads"),OLe=Zi(),NLe=ro(),ILe=mA(),wLe=w_(),QS=M(),qi,ud,bK=!1,Cpe="Upgrade complete. Starting HarperDB.",Dpe="Got an error while trying to upgrade your HarperDB instance. Exiting HarperDB.",Ppe="HarperDB not found, starting install process.",Lpe="There was an error during install, check install_log.log for more details. Exiting.",Mpe="HarperDB successfully started.";function Upe(){if(!bK){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(Upe,"addExitListeners");async function OK(e=!1,t=!1){if(console.log(II.magenta("Starting HarperDB...")),Xn.suppressLogging?.(()=>{console.log(II.magenta(""+Mo.readFileSync(Uo.join(Ope,"utility/install/ascii_logo.txt"))))}),await IK()===!1){console.log(Ppe);try{await Spe()}catch(o){console.error(Lpe,o),Xn.error(o),process.exit(1)}}if(!e){let o=yK(Object.keys(Xt.CONFIG_PARAM_MAP),!0);!vo.isEmpty(o)&&!vo.isEmptyOrZeroLength(Object.keys(o))&&wI.updateConfigValue(void 0,void 0,o,!0,!0)}let r,n=ud?.service==="clustering";ud?.service&&!n&&(console.error("Unrecognized service argument"),process.exit(1));try{let o=Number.parseInt(await Mo.readFile(Uo.join(pe.get(Xt.CONFIG_PARAMS.ROOTPATH),Xt.HDB_PID_FILE),"utf8")),c=await ppe.processes();for(let l of c.list)if(l.pid===o){n?r=!0:console.log("HarperDB appears to be already running.");break}}catch{}qi===void 0&&(qi=Hu()),n&&(r||(console.error("HarperDB must be running to start clustering."),process.exit()),pe.get(Xt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY)||(console.error("Clustering must be setup and enabled in harperdb-config."),process.exit()),console.log("Starting clustering."),await AK.generateNatsConfig(),await qi.startClusteringProcesses(!0),process.exit()),Upe(),await Mo.writeFile(Uo.join(pe.get(QS.CONFIG_PARAMS.ROOTPATH),QS.HDB_PID_FILE),`${process.pid}`),Xn.info("HarperDB PID",process.pid);let s;try{let o=await Ipe.getVersionUpdateInfo();o!==void 0&&(s=o[Xt.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION],await gpe.upgrade(o),console.log(Cpe))}catch(o){s?(console.error(`Got an error while trying to upgrade your HarperDB instance to version ${s}. Exiting HarperDB.`,o),Xn.error(o)):(console.error(Dpe,o),Xn.error(o)),process.exit(1)}mpe(),Hpe(),await bpe.reviewSelfSignedCert(),vo.autoCastBoolean(pe.get(Xt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&wpe&&await AK.generateNatsConfig(t)}a(OK,"initialize");async function vpe(e=!1){try{ud=ype(process.argv),ud.ROOTPATH&&wI.updateConfigObject("settings_path",Uo.join(ud.ROOTPATH,Xt.HDB_CONFIG_FILE)),await OK(e,!0),pe.get(Xt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await Ape();let t=process.env.IS_SCRIPTED_SERVICE&&!ud.service;vo.autoCastBoolean(pe.get(Xt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&(t||await qi.startClusteringProcesses(),await qi.startClusteringThreads()),await Npe(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 Rpe(),t||NK()}catch(t){console.error(t),Xn.error(t),process.exit(1)}}a(vpe,"main");function NK(){Xn.suppressLogging(()=>{console.log(II.magenta(`HarperDB ${Tpe.version} successfully started`))}),Xn.notify(Mpe)}a(NK,"started");async function Bpe(e=!0){bK=!e;try{qi===void 0&&(qi=Hu()),qi.enterPM2Mode(),await OK(),vo.autoCastBoolean(pe.get(Xt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&await qi.startClusteringProcesses(),await qi.startService(Xt.PROCESS_DESCRIPTORS.HDB),NK(),e&&process.exit(0)}catch(t){console.error(t),Xn.error(t),process.exit(1)}}a(Bpe,"launch");function Hpe(){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}=yK(["HARPERDB_FINGERPRINT","HARPERDB_LICENSE"]);if(vo.isEmpty(n)||vo.isEmpty(s))return;Mo.mkdirpSync(e),Mo.writeFileSync(r,n),Mo.writeFileSync(t,s)}catch(n){let s=`Failed to write license & fingerprint due to: ${n.message}`;console.error(s),Xn.error(s)}}a(Hpe,"writeLicenseFromVars");Object.assign(wK,{launch:Bpe,main:vpe,isHdbInstalled:IK,startupLog:xpe});async function IK(){try{await Mo.stat(vo.getPropsFilePath()),await Mo.stat(pe.get(Xt.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}catch(e){if(vo.noBootFile())return!0;if(e.code==="ENOENT")return!1;throw Xn.error(`Error checking for HDB install - ${e}`),e}return!0}a(IK,"isHdbInstalled");function xpe(e){let r=a(f=>f.padEnd(20),"pad"),n=`
|
|
114
114
|
`;pe.get(we.REPLICATION_HOSTNAME)&&(n+=`${r("Hostname:")}${pe.get(we.REPLICATION_HOSTNAME)}
|
|
115
115
|
`),pe.get(we.REPLICATION_URL)&&(n+=`${r("Replication Url:")}${pe.get(we.REPLICATION_URL)}
|
|
116
116
|
`),n+=`${r("Worker Threads:")}${pe.get(we.THREADS_COUNT)}
|
|
117
117
|
`,n+=`${r("Root Path:")}${pe.get(we.ROOTPATH)}
|
|
118
118
|
`,pe.get(we.THREADS_DEBUG)!==!1&&(n+=`${r("Debugging:")}enabled: true`,n+=pe.get(we.THREADS_DEBUG_PORT)?`, TCP: ${pe.get(we.THREADS_DEBUG_PORT)}
|
|
119
119
|
`:`
|
|
120
|
-
`);let s=
|
|
120
|
+
`);let s=Uo.join(pe.get(we.LOGGING_ROOT),"hdb.log");n+=`${r("Logging:")}level: ${pe.get(we.LOGGING_LEVEL)}, location: ${s+(pe.get(we.LOGGING_STDSTREAMS)?", stdout/err":"")}
|
|
121
121
|
`,n+=r("Default:"),n+=pe.get(we.HTTP_PORT)?`HTTP (and WS): ${pe.get(we.HTTP_PORT)}, `:"",n+=pe.get(we.HTTP_SECUREPORT)?`HTTPS (and WS): ${pe.get(we.HTTP_SECUREPORT)}, `:"",n+=`CORS: ${pe.get(we.HTTP_CORS)?`enabled for ${pe.get(we.HTTP_CORSACCESSLIST)}`:"disabled"}
|
|
122
122
|
`,n+=r("Operations API:"),n+=pe.get(we.OPERATIONSAPI_NETWORK_PORT)?`HTTP: ${pe.get(we.OPERATIONSAPI_NETWORK_PORT)}, `:"",n+=pe.get(we.OPERATIONSAPI_NETWORK_SECUREPORT)?`HTTPS: ${pe.get(we.OPERATIONSAPI_NETWORK_SECUREPORT)}, `:"",n+=`CORS: ${pe.get(we.OPERATIONSAPI_NETWORK_CORS)?`enabled for ${pe.get(we.OPERATIONSAPI_NETWORK_CORSACCESSLIST)}`:"disabled"}`,n+=`, unix socket: ${pe.get(we.OPERATIONSAPI_NETWORK_DOMAINSOCKET)}
|
|
123
123
|
`,n+=r("MQTT:"),n+=pe.get(we.MQTT_NETWORK_PORT)?`TCP: ${pe.get(we.MQTT_NETWORK_PORT)}, `:"",n+=pe.get(we.MQTT_NETWORK_SECUREPORT)?`TLS: ${pe.get(we.MQTT_NETWORK_SECUREPORT)}`:"",n+=pe.get(we.MQTT_WEBSOCKET)&&pe.get(we.HTTP_PORT)?`, WS: ${pe.get(we.HTTP_PORT)}`:"",n+=pe.get(we.MQTT_WEBSOCKET)&&pe.get(we.HTTP_SECUREPORT)?`, WSS: ${pe.get(we.HTTP_SECUREPORT)}
|
|
124
124
|
`:`
|
|
125
125
|
`;let i=pe.get(we.REPLICATION_PORT)??pe.get(we.OPERATIONSAPI_NETWORK_PORT),o=pe.get(we.REPLICATION_SECUREPORT)??pe.get(we.OPERATIONSAPI_NETWORK_SECUREPORT),c=r("Replication:");c+=i?`WS: ${i}, `:"",c+=o?`WSS: ${o} `:"",n+=`${c.slice(0,-2)}
|
|
126
|
-
`;let l=[],u=
|
|
126
|
+
`;let l=[],u=wI.getConfigObj();for(let f in u)u[f].package&&l.push(f);let d={},_=`${r("REST:")}`;for(let[f,h]of e)for(let T of h){let m=T.name;m==="rest"&&(_+=`${T.protocol_name}: ${f}, `),l.includes(m)&&(d[m]?d[m]+=`${T.protocol_name}: ${f}, `:d[m]=`${T.protocol_name}: ${f}, `)}_.length>21&&(_=_.slice(0,-2),n+=`${_}
|
|
127
127
|
`);let E=pe.get(we.HTTP_PORT)?`HTTP: ${pe.get(we.HTTP_PORT)}, `:"";E+=pe.get(we.HTTP_SECUREPORT)?`HTTPS: ${pe.get(we.HTTP_SECUREPORT)}, `:"",E.length>21&&(E=E.slice(0,-2));for(let f of l)d[f]?n+=`${r(f+": ")}${d[f].slice(0,-2)}
|
|
128
128
|
`:n+=`${r(f+": ")}${E}
|
|
129
|
-
`;console.log(n),pe.get(we.LOGGING_STDSTREAMS)&&Xn.logsAtLevel("info")&&Xn.suppressLogging(()=>{console.log(`Note that log messages are being sent to the console (stdout and stderr) in addition to the log file ${s}. This can be disabled by setting logging.stdStreams to false, and the log file can be directly monitored/tailed.`)})}a(
|
|
129
|
+
`;console.log(n),pe.get(we.LOGGING_STDSTREAMS)&&Xn.logsAtLevel("info")&&Xn.suppressLogging(()=>{console.log(`Note that log messages are being sent to the console (stdout and stderr) in addition to the log file ${s}. This can be disabled by setting logging.stdStreams to false, and the log file can be directly monitored/tailed.`)})}a(xpe,"startupLog")});var kI=N(Bo=>{"use strict";var{isMainThread:DI,parentPort:wE,threadId:XS,workerData:kpe}=require("worker_threads"),{Socket:Fpe,createServer:Gpe}=require("net"),{createServer:qpe,IncomingMessage:$pe}=require("http"),{createServer:Vpe}=require("https"),{unlinkSync:xK,existsSync:Kpe}=require("fs"),Nn=W(),Rt=se(),Zt=M(),{server:CE}=(qr(),oe(Qa)),{WebSocketServer:Ype}=require("ws"),{createServer:Wpe}=require("node:tls"),{getTicketKeys:jpe,restartNumber:zpe,getWorkerIndex:dd}=dt(),{Headers:PI,appendHeader:Qpe}=(Bf(),oe(jF)),{recordAction:OE,recordActionBinary:PK}=(Ni(),oe(F_)),{Request:kK,createReuseportFd:IE}=(vS(),oe(XN)),{checkMemoryLimit:Jpe}=dc(),{createTLSSelector:FK}=Xs(),{resolvePath:GK}=wt(),{startupLog:Xpe}=CK(),{Readable:LK}=require("node:stream"),Zpe=fi(),qK=Rt.get(Zt.CONFIG_PARAMS.THREADS_DEBUG);if(qK){let e;if(DI)e=Rt.get(Zt.CONFIG_PARAMS.THREADS_DEBUG_PORT)??9229,process.on(["SIGINT","SIGTERM","SIGQUIT","exit"],()=>{try{require("inspector").close()}catch(t){Nn.info("Could not close debugger",t)}});else{let t=Rt.get(Zt.CONFIG_PARAMS.THREADS_DEBUG_STARTINGPORT);t&&dd()>=0&&(e=t+dd())}if(e){let t=Rt.get(Zt.CONFIG_PARAMS.THREADS_DEBUG_HOST),r=Rt.get(Zt.CONFIG_PARAMS.THREADS_DEBUG_WAITFORDEBUGGER);try{require("inspector").open(e,t,r)}catch(n){Nn.trace(`Could not start debugging on port ${e}, you may already be debugging:`,n.message)}}}else if(process.env.DEV_MODE&&DI)try{require("inspector").open(9229)}catch(e){zpe<=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:PLe,CONFIG_PARAMS:eme}=Zt;Rt.initSync();var tme=Rt.get(eme.HTTP_SESSIONAFFINITY),$i={},LI=new Map;Bo.registerServer=BI;Bo.httpServer=xI;Bo.deliverSocket=vI;Bo.startServers=$K;Bo.listenOnPorts=VK;Bo.globals=Zpe;Bo.when_components_loaded=null;CE.http=xI;CE.request=nme;CE.socket=sme;CE.ws=ime;CE.upgrade=WK;var NE={},JS={},ZS={},MI=[];function $K(){return Bo.when_components_loaded=nT().loadRootComponents(!0).then(()=>{wE?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)vI(n,r,s);else if(t.requestId)rme(t);else if(t.type===Zt.ITC_EVENT_TYPES.SHUTDOWN){Nn.trace("received shutdown request",XS);for(let i in $i){let o=$i[i],c;if(o.closeIdleConnections){let u=Object.getOwnPropertySymbols(o).find(E=>E.description.includes("connections")),d=0,_=setInterval(()=>{d++;let E=d>=100,f=o[u][E?"all":"idle"]();if(f.length===0){E&&clearInterval(_);return}d===1?Nn.info(`Closing ${f.length} idle connections`):E&&Nn.warn(`Forcefully closing ${f.length} active connections`);for(let h=0,T=f.length;h<T;h++){let m=f[h].socket;m._httpMessage&&!m._httpMessage.finished&&!E||(E?m.destroySoon():m.end(`HTTP/1.1 408 Request Timeout\r
|
|
130
130
|
Connection: close\r
|
|
131
131
|
\r
|
|
132
|
-
`))}},25).unref()}o.close?.(()=>{if(Rt.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&
|
|
133
|
-
`)}a(BK,"defaultNotFound")});var CK={};je(CK,{startHTTPThreads:()=>ome,startSocketServer:()=>$I,updateWorkerIdleness:()=>eY});async function ome(e=2,t){try{if(t)GI(0,1,!0);else{let{loadRootComponents:r}=nT();if(e===0)return(0,Ds.setMainIsWorker)(!0),await xI().startServers(),Promise.resolve([]);await r()}ZK();for(let r=0;r<e;r++)GI(r,e);return Promise.all(XK)}finally{(0,Ds.threadsHaveStarted)()}}function ZK(){let e=(0,QK.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),FI=setInterval(()=>{oT.notify(e)},ime).unref())}function GI(e,t=1,r){if(kI++,(0,Ds.startWorker)("server/threads/threadServer.js",{name:hd.THREAD_TYPES.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(u){u.type===hd.CLUSTER_MESSAGE_TYPE_ENUM.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});XK.push(s),await s,dd.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=iT.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=dd.indexOf(n);o>-1&&dd.splice(o,1)}if(a(i,"removeWorker"),_d){let o=_d;_d=[];for(let c of o)JK[c.localPort](null,c)}}}),r){let n=setInterval(()=>{qI?qI=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,Ds.shutdownWorkers)(),kI=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function $I(e=0,t){if(typeof e=="string")try{(0,aT.existsSync)(e)&&(0,aT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=ame:r=cme(t):r=VI;let n=(0,fd.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);if(n._handle){n._handle.onconnection=JK[e]=function(i,o){r.readsData||(o.reading=!1,o.readStop()),qI=!0,r(o,(c,l)=>{if(!c){if(WK){let d=o._socket||new fd.Socket({handle:o,writable:!0,readable:!0});WK.deliverSocket(d,e,l),d.resume()}else kI>0?(_d.length===0&&setTimeout(()=>{_d.length>0&&console.warn("Incoming sockets/requests have been queued for workers to start, and no workers have handled them. Check to make sure an error is not preventing workers from starting")},1e4).unref(),o.localPort=e,_d.push(o)):(console.log("start up a dynamic thread to handle request"),GI(0));pr(!1,"socket-routed");return}c.requests++;let u=o.fd;if(u>=0)c.postMessage({port:e,fd:u,data:l});else{let d=o._socket||new fd.Socket({handle:o,writable:!0,readable:!0});dme(d,c,e)}pr(!0,"socket-routed")})};let s=jl();oT.info(`HarperDB ${s.version} Server running on port ${e}`)}return n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function VI(e,t){let r,n=0;for(let s of dd){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=sT)return sT=i,t(r);n=i}sT=0,t(r)}function ame(e,t){let r={};e.getpeername(r);let n=r.address,s=Ed.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);VI(e,o=>{Ed.set(n,{worker:o,lastUsed:i}),t(o)})}function cme(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new fd.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let l=o.toString("latin1").match(t)?.[1],u=Ed.get(l),d=Date.now();if(u&&u.worker.threadId!==-1)return u.lastUsed=d,s(u.worker);VI(n,_=>{Ed.set(l,{worker:_,lastUsed:d}),s(_,o)})})}a(r,"findByHeaderAffinity")}function eY(){sT=0;for(let e of dd)e.expectedIdle=e.recentELU.idle+lme,e.requests=1;dd.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function dme(e,t,r){let n=ume++;t.postMessage({port:r,requestId:n,event:"connection"}),e.on("data",s=>{let i=s.toString("latin1");t.postMessage({port:r,requestId:n,data:i,event:"data"})}).on("close",s=>{t.postMessage({port:r,requestId:n,event:"close",hadError:s})}).on("error",s=>{t.postMessage({port:r,requestId:n,event:"error",error:s})}).on("drain",s=>{t.postMessage({port:r,requestId:n,event:"drain",error:s})}).on("end",()=>{t.postMessage({port:r,requestId:n,event:"end"})}).resume(),iT.set(n,s=>{s.event=="data"&&e.write(Buffer.from(s.data,"latin1")),s.event=="end"&&(e.end(s.data&&Buffer.from(s.data,"latin1")),iT.delete(n)),s.event=="destroy"&&(e.destroy(),iT.delete(n))})}var Ds,fd,hd,oT,aT,zK,QK,dd,_d,JK,WK,kI,XK,FI,ime,qI,sT,jK,Ed,lme,iT,ume,wI=Oe(()=>{Ds=L(dt()),fd=require("net"),hd=L(M()),oT=L(W()),aT=require("fs");Ni();zK=require("worker_threads"),QK=L(dc()),dd=[],_d=[],JK=[],kI=0,XK=[];zK.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,Ds.onMessageFromWorkers)(e=>{e.type===hd.ITC_EVENT_TYPES.RESTART&&FI&&(clearInterval(FI),ZK())}));ime=6e5;a(ome,"startHTTPThreads");a(ZK,"licenseWarning");a(GI,"startHTTPWorker");a($I,"startSocketServer");sT=0;a(VI,"findMostIdleWorker");jK=36e5,Ed=new Map;a(ame,"findByRemoteAddressAffinity");a(cme,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of Ed)r.lastUsed+jK<e&&Ed.delete(t)},jK).unref();lme=1e3;a(eY,"updateWorkerIdleness");(0,Ds.setMonitorListener)(eY);iT=new Map,ume=1;a(dme,"proxySocket")});var sY=N((FLe,nY)=>{"use strict";var _me=require("cluster"),fl=se();fl.initSync();var rY=M(),vLe=require("util"),xo=W(),BLe=require("fs"),fme=require("fastify"),HLe=jl(),Eme=require("@fastify/cors"),hme=require("@fastify/compress"),pme=require("@fastify/static"),mme=_N(),Sme=require("path"),{PACKAGE_ROOT:Tme}=M(),gme=ls(),Rme=te(),Ame=xn(),yme=dc(),{server:bme}=(qr(),oe(Qa)),{node_request_key:xLe}=(vS(),oe(JN)),{authHandler:Ome,handlePostRequest:Nme,serverErrorHandler:Ime,reqBodyValidationHandler:wme}=LS(),kLe=require("net"),{registerContentHandlers:Cme}=(Wc(),oe(Iq)),Dme=6e4,Pme=1024*1024*1024,Lme="TRUE",{CONFIG_PARAMS:DE}=rY,pd;nY.exports={hdbServer:tY,start:tY};async function tY(e){try{xo.debug("In Fastify server"+process.cwd()),xo.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),xo.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=_me.isMaster,await Mme();let t=e.securePort>0;pd=Ume(t),await pd.ready(),e||(e={}),e.isOperationsServer=!0;try{bme.http(pd.server,e),pd.server.closeIdleConnections||await pd.listen({port:0,host:"::"})}catch(r){throw pd.close(),xo.error(r),xo.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),xo.fatal(t),process.exit(1)}}a(tY,"operationsServer");async function Mme(){xo.trace("Configuring HarperDB process."),gme.setSchemaDataToGlobal(),await Ame.setUsersToGlobal(),await yme.getLicense()}a(Mme,"setUp");function Ume(e){xo.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=vme(e),r=fme(t);r.server.headersTimeout=Hme(),r.setErrorHandler(Ime);let n=Bme();n&&r.register(Eme,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,u){r.server.emit("unhandled",l.raw,u.raw)}),c()}),r.register(mme),r.register(hme),r.register(pme,{root:Sme.join(Tme,"studio/build-local")}),Cme(r);let s=fl.get(rY.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!Rme.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[wme,Ome],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),Nme(i,o)}),r.get("/health",()=>"HarperDB is running."),xo.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(Ume,"buildServer");function vme(e){let t=fl.get(DE.OPERATIONSAPI_NETWORK_TIMEOUT),r=fl.get(DE.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:Pme,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(vme,"getServerOptions");function Bme(){let e=fl.get(DE.OPERATIONSAPI_NETWORK_CORS),t=fl.get(DE.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===Lme)&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},t&&t.length>0&&t[0]!==null&&t[0]!=="*"&&(r.origin=(n,s)=>s(null,t.indexOf(n)!==-1))),r}a(Bme,"getCORSOpts");function Hme(){return fl.get(DE.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??Dme}a(Hme,"getHeaderTimeoutConfig")});var QI={};je(QI,{disableNATS:()=>kme,publishToStream:()=>uT,setNATSReplicator:()=>KI,setPublishToStream:()=>Fme,setSubscription:()=>zI,start:()=>xme});function xme(){PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_ENABLED)&&qme()}function kme(e=!0){lY=e}function Fme(e,t){uT=e,zI=t}function qme(){if(lY||process.env._DISABLE_NATS)return;let e=ut(),t=Object.keys(e);t.push("system");for(let r of t){let n=e[r];for(let s in n){let i=n[s];KI(s,r,i)}}Dc((r,n)=>{KI(r.tableName,r.databaseName,r),n&&dY(r)}),!iY&&(iY=!0)}function KI(e,t,r){if(t==="system"&&$me.includes(e))return;if(!r)return console.error(`Attempt to replicate non-existent table ${e} from database ${t}`);if(r.sources.some(s=>s?.isNATSReplicator))return;r.sourcedFrom(class extends Lr{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this[ze],record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this[ze]})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this[ze],record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this[ze],record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this[ze]})}static defineSchema(i){dY(i)}static subscribe(){let i=new Mn;return zI(t,e,i),i}static subscribeOnThisThread(i){return i<(PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??Gme)}static isEqual(i){return i.isNATSReplicator}static isNATSReplicator=!0;static shouldReceiveInvalidations=!0},{intermediateSource:!0});function n(s){let i=s?.transaction?.nats;if(!i)if(s?.transaction){s.transaction.nats=i=new cT(s.transaction,s);let o=s.transaction;for(;o.next;)o=o.next;o.next=s.transaction.nats,i.user=s.user,i.context=s}else i=uY;return i}a(n,"getNATSTransaction")}function dY(e){let t=PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_NODENAME);uT(`${WI.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,jI.createNatsTableStreamName)(e.databaseName,e.tableName),void 0,{operation:"define_schema",schema:e.databaseName,table:e.tableName,attributes:e.attributes,__origin:{timestamp:Date.now(),node_name:t}})}var oY,WI,jI,aY,cY,PE,LE,lT,lY,uT,zI,Gme,uY,iY,$me,cT,YI,_Y=Oe(()=>{Pe();Vs();oY=L(mr()),WI=L(Ct()),jI=L(to());wl();aY=L(ey()),cY=L(cn()),PE=L(se()),LE=L(M()),lT=L(W());a(xme,"start");a(kme,"disableNATS");uT=oY.publishToStream,zI=aY.setSubscription;a(Fme,"setPublishToStream");Gme=2;a(qme,"assignReplicationSource");$me=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(KI,"setNATSReplicator");a(dY,"publishSchema");cT=class{constructor(t,r){this.transaction=t;this.options=r}static{a(this,"NATSTransaction")}user;writes_by_db=new Map;addWrite(t,r){r.expiresAt=this.context?.expiresAt;let n=this.writes_by_db.get(t);n||this.writes_by_db.set(t,n=[]),n.push(r)}commit({timestamp:t}){let r=PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],l,u;for(let d of i){let _=d.table,E=d.operation=="put"?"upsert":d.operation;l||(lT.trace(`Sending transaction event ${E}`),u=l={operation:E,schema:s,table:_,__origin:{user:this.user?.username,timestamp:t,node_name:r}},l.hash_values=c,E!=="delete"&&E!=="invalidate"&&(l.records=o)),l.table===_&&l.operation===E?(o.push(d.record),c.push(d.id)):u=u.next={operation:E,table:_,id:d.id,record:d.record},d.expiresAt&&(u.expiresAt=d.expiresAt)}l&&n.push(uT(`${WI.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,jI.createNatsTableStreamName)(s,l.table),void 0,l)?.catch(d=>{throw lT.error("An error has occurred trying to replicate transaction",l,d),d.statusCode=504,d}))}return Promise.all(n)}},YI=class extends cT{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,cY.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};uY=new YI});async function mY({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await JI.get(e,{returnNonexistent:!0});i=new ew(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await JI.get(e);o&&o.delete()}i=new _T(e,t)}return n&&(n.id=e,n.user={username:t?.username},ME.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function XI(){return dT++,dT>65500&&(dT=1),dT}function ZI(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=wi.getMatch(n,"mqtt");if(!i)throw new Error(`Can not publish to topic ${n} as it does not exist, no resource has been defined to handle this topic`);e.url=i.relativeURL;let o=i.Resource;return Dt(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var EY,Ma,hY,pY,fY,JI,ME,dT,_T,ew,SY=Oe(()=>{Pe();eu();EY=L(cn()),Ma=L(W());mc();hY=L(dt()),pY=L(xI());qr();fY=100,JI=Et({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),ME=Et({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,hY.getWorkerIndex)()===0&&(async()=>{await pY.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of ME.search({})){let t=e.data,r={...e};r.user?.username&&(r.user=await it.getUser(r.user.username));try{await ZI(r,t,r)}catch{(0,Ma.warn)("Failed to publish will",t)}ME.delete(e.id)}})();a(mY,"getSession");dT=1;a(XI,"getNextMessageId");_T=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;request;socket;subscriptions=[];awaitingAcks;sessionWasPresent;keepalive;keepaliveTimer;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),l,u;if(c>-1?(l=s.slice(c),u=s.slice(0,c)):u=s,!u)throw new Error("No topic provided");if(u.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let d=this.subscriptions.find(g=>g.topic===s),_;d?(_=i>0,d.end(),this.subscriptions.splice(this.subscriptions.indexOf(d),1)):_=i===2;let E={search:l,async:!0,user:this.user,startTime:o,omitCurrent:_,url:""};o&&(0,Ma.trace)("Resuming subscription from",s,"from",o);let f=wi.getMatch(u,"mqtt");if(!f){let g=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw g.statusCode=404,g}if(E.url=f.relativeURL,E.url.indexOf("+")>-1||E.url.indexOf("#")>-1){let g=E.url.slice(1);if(g.indexOf("#")>-1&&g.indexOf("#")!==g.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(E.isCollection=!0,g.indexOf("+")===g.length-1)E.onlyChildren=!0,E.url="/"+g.slice(0,g.length-1);else{let S=g.split("/"),b;for(let H=0;H<S.length;H++)if(S[H].indexOf("+")>-1)if(S[H]==="+")b=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&b)throw new Error("Filters can not be combined");let I=!0;S[S.length-1]==="#"&&(S.length--,I=!1),b&&(n=a(H=>{let X=H.id;if(!Array.isArray(X)||I&&X.length!==S.length)return!1;for(let Y=0;Y<S.length;Y++)if(S[Y]!=="+"&&S[Y]!==X[Y])return!1;return!0},"filter"));let B=S.indexOf("+");E.url="/"+(B>-1?S.slice(0,B):S).concat("").join("/")}}let h=f.path,T=f.Resource,m=await Dt(E,async()=>{let g=this.createContext();g.topic=s,g.retainHandling=i;let S=await T.subscribe(E,g);if(!S)return;if(!S[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let b=(async()=>{for await(let I of S)try{let B;if(I.type&&I.type!=="put"&&I.type!=="delete"&&I.type!=="message"&&I.type!=="patch"||n&&!n(I))continue;r?(I.topic=s,B=this.needsAcknowledge(I)):(I.acknowledge?.(),B=XI());let H=I.id;if(Array.isArray(H)&&(H=Zl(H)),H==null&&(H=""),await this.listener(h+"/"+H,I.value,B,t)===!1)break;this.awaitingAcks?.size>fY?await new Promise(Y=>setTimeout(Y,this.awaitingAcks.size-fY)):await new Promise(setImmediate)}catch(B){(0,Ma.warn)(B)}})();return S});return m.topic=s,m.qos=t.qos,this.subscriptions.push(m),m}resume(){}needsAcknowledge(t){let r=XI();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,{acknowledge:t.acknowledge})),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r.acknowledge())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),this.subscriptions.splice(this.subscriptions.indexOf(r),1),!0}async publish(t,r){return ZI(t,r,this.createContext())}createContext(){let t={session:this,socket:this.socket,user:this.user,authorize:!0};return this.request&&(t.request=this.request,t.url=this.request.url,t.headers=this.request.headers),t}setListener(t){this.listener=t}disconnect(t){this.keepaliveTimer&&clearTimeout(this.keepaliveTimer);let r=this.createContext();Dt(r,async()=>{try{if(!t){let n=await ME.get(this.sessionId);n?.doesExist()&&await ZI(n,n.data,r)}}finally{await ME.delete(this.sessionId)}}).catch(n=>{(0,Ma.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}receivedPacket(){this.keepalive&&(clearTimeout(this.keepaliveTimer),this.keepaliveTimer=setTimeout(()=>{this.socket?.destroy?this.socket.destroy(new Error("Keepalive timeout")):this.socket?.terminate()},this.keepalive*1500))}};a(ZI,"publish");ew=class extends _T{static{a(this,"DurableSubscriptionsSession")}sessionRecord;constructor(t,r,n){super(t,r),this.sessionRecord=n||{id:t,subscriptions:[]}}async resume(){for(let t of this.sessionRecord.subscriptions||[])await this.resumeSubscription({omitCurrent:!0,topic:t.topic,qos:t.qos,startTime:t.startTime},!0,t.acks?r=>!t.acks.includes(r.localTime):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=XI(),n={topic:t.topic,timestamp:t.localTime};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks?.get(t);if(!r)return;this.awaitingAcks?.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,Ma.trace)("Received ack",n,r.timestamp),this.sessionRecord.update();return}}for(let s of this.sessionRecord.subscriptions)s.topic===n&&(s.startTime=r.timestamp);this.sessionRecord.update()}async addSubscription(t,r){await this.resumeSubscription(t,r);let{qos:n,startTime:s}=t;return n>0&&!s&&this.saveSubscriptions(),t.qos}removeSubscription(t){let r=this.subscriptions.find(s=>s.topic===t),n=super.removeSubscription(t);return r.qos>0&&this.saveSubscriptions(),n}saveSubscriptions(){this.sessionRecord.subscriptions=this.subscriptions.map(t=>{let r=t.startTime;return r||(r=t.startTime=(0,EY.getNextMonotonicTime)()),(0,Ma.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),JI.put(this.sessionRecord)}}});var rw={};je(rw,{bypassAuth:()=>Vme,start:()=>Kme});function Vme(){yY=!0}function Kme({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new AY.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c=[],l=r?.mtls;return n&&(c=e.ws((u,d,_,E)=>{if(d.headers.get("sec-websocket-protocol")!=="mqtt")return E(u,d,_);o.events.emit("connection",u),dr.debug?.("Received WebSocket connection for MQTT from",u._socket.remoteAddress);let{onMessage:f,onClose:h}=gY(u,T=>{u.send(T)},d,Promise.resolve(_).then(()=>d?.user),o);u.on("message",f),u.on("close",h),u.on("error",T=>{dr.info?.("WebSocket error",T)})},{...n})),(t||s)&&c.push(e.socket(async u=>{let d;if(o.events.emit("connection",u),dr.debug?.(`Received ${u.getCertificate?"SSL":"TCP"} connection for MQTT from ${u.remoteAddress}`),l){if(u.authorized)try{let f=l.user;if(f!==null){(f===void 0||f==="Common Name"||f==="CN")&&(f=u.getPeerCertificate().subject.CN);try{d=await e.getUser(f,null,null),(0,md.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ET.notify?.({username:d?.username,status:kr.AUTH_AUDIT_STATUS.SUCCESS,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:u.remoteAddress})}catch(h){throw(0,md.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ET.error?.({username:f,status:kr.AUTH_AUDIT_STATUS.FAILURE,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:u.remoteAddress}),h}}else dr.debug?.("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",u.remoteAddress)}catch(f){o.events.emit("error",f,u),dr.error?.(f)}else if(l.required)return dr.info?.(`Unauthorized connection attempt, no authorized client certificate provided, error: ${u.authorizationError}`),u.end()}!d&&yY&&u.remoteAddress.includes("127.0.0.1")&&(d=await(0,RY.getSuperUser)(),dr.debug?.("Auto-authorizing local connection",d?.username));let{onMessage:_,onClose:E}=gY(u,f=>u.write(f),null,d,o);u.on("data",_),u.on("close",E),u.on("error",f=>{dr.info?.("Socket error",f)})},{port:t,securePort:s,mtls:l})),c}function gY(e,t,r,n,s){TY||(TY=!0,x_(_=>{fT>0&&_.push({metric:"mqtt-connections",connections:fT,byThread:!0})}));let i;fT++;let o,c={protocolVersion:4},l=(0,hT.parser)({protocolVersion:5});function u(_){l.parse(_)}a(u,"onMessage");function d(){fT--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),qn(!1,"connection","mqtt","disconnect"),dr.debug?.("MQTT connection was closed",e.remoteAddress))}return a(d,"onClose"),l.on("packet",async _=>{n?.then&&(n=await n);let E=_.cmd;if(o)o.then&&await o;else if(E!=="connect"){dr.info?.("Received packet before connection was established, closing connection"),e?.destroy?e.destroy():e?.terminate();return}let f=_.topic,h=f?.indexOf("/",1),T=h>0?f.slice(0,h):f;pr(_.length,"bytes-received",T,g(_),"mqtt");try{switch(o?.receivedPacket?.(),E){case"connect":if(c.protocolVersion=_.protocolVersion,_.username)try{n=await it.getUser(_.username,_.password.toString(),r),(0,md.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ET.notify?.({username:n?.username,status:kr.AUTH_AUDIT_STATUS.SUCCESS,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(V){return(0,md.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ET.error?.({username:_.username,status:kr.AUTH_AUDIT_STATUS.FAILURE,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",_,e,V),qn(!1,"connection","mqtt","connect"),m({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",_,e),qn(!1,"connection","mqtt","connect"),m({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(_,n),_.will){let V=e.deserialize||(e.deserialize=bo(r?.headers.get?.("content-type")));_.will.data=_.will.payload?.length>0?V(_.will.payload):void 0,delete _.will.payload}o=mY({user:n,..._}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(V){return dr.error?.(V),s.events.emit("auth-failed",_,e,V),qn(!1,"connection","mqtt","connect"),m({cmd:"connack",reasonCode:V.code||5,returnCode:V.code||128})}s.events.emit("connected",o,e),qn(!0,"connection","mqtt","connect"),m({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0}),o.setListener((V,ne,Q,de)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",V);let j=V.indexOf("/",1),ae=j>0?V.slice(0,j):V;m({cmd:"publish",topic:V,payload:S(ne),messageId:Q||Math.floor(Math.random()*1e8),qos:de.qos},ae);let Ae=e._socket??e;return Ae.writableNeedDrain?new Promise(ye=>Ae.once("drain",ye)):!Ae.closed}catch(j){return dr.error?.(j),o?.disconnect(),s.sessions.delete(o),!1}}),o.sessionWasPresent&&await o.resume();break;case"subscribe":let b=[];for(let V of _.subscriptions){let ne;try{let Q=await o.addSubscription(V,V.qos>=1);ne=Q?Q.qos||0:c.protocolVersion<5?128:143}catch(Q){s.events.emit("error",Q,e,V,o),Q.statusCode?Q.statusCode===500?dr.warn?.(Q):dr.info?.(Q):dr.error?.(Q),ne=c.protocolVersion<5?128:Q.statusCode===403?135:Q.statusCode===404?143:128}b.push(ne)}await o.committed,m({cmd:"suback",granted:b,messageId:_.messageId});break;case"unsubscribe":{let V=[];for(let ne of _.unsubscriptions)V.push(o.removeSubscription(ne)?0:17);m({cmd:"unsuback",granted:V,messageId:_.messageId});break}case"pubrel":m({cmd:"pubcomp",messageId:_.messageId,reasonCode:0});return;case"publish":let I=_.qos===2?"pubrec":"puback",B=e.deserialize||(e.deserialize=bo(r?.headers.get?.("content-type"))),X=(_.payload?.length||0)>0?B(_.payload):void 0,Y;try{Y=await o.publish(_,X)}catch(V){s.events.emit("error",V,e,_,o),dr.warn?.(V),_.qos>0&&m({cmd:I,messageId:_.messageId,reasonCode:128},_.topic);break}_.qos>0&&m({cmd:I,messageId:_.messageId,reasonCode:Y===!1?144:0},_.topic);break;case"pubrec":m({cmd:"pubrel",messageId:_.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(_.messageId);break;case"pingreq":m({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),qn(!0,"connection","mqtt","disconnect"),dr.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(b){s.events.emit("error",b,e,_,o),dr.error?.(b),m({cmd:"disconnect"})}function m(b,I){let B=(0,hT.generate)(b,c);t(B),pr(B.length,"bytes-sent",I,g(b),"mqtt")}a(m,"sendPacket");function g(b){return b.qos>0?b.cmd+",qos="+b.qos:b.cmd}a(g,"packetMethodName");function S(b){return Yc(b,r)}a(S,"serialize")}),l.on("error",_=>{dr.warn("MQTT parsing error, closing connection:",_.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:u,onClose:d}}var hT,RY,md,kr,tw,AY,ET,dr,yY,TY,fT,bY=Oe(()=>{hT=require("mqtt-packet");SY();RY=L(xn());Wc();Ni();qr();md=L(se()),kr=L(M()),tw=L(bc()),AY=require("events"),ET=(0,tw.loggerWithTag)("auth-event"),dr=(0,tw.loggerWithTag)("mqtt"),yY=(0,md.get)(kr.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(Vme,"bypassAuth");a(Kme,"start");fT=0;a(gY,"onSocket")});var qf={};je(qf,{component_errors:()=>Td,getComponentName:()=>Qme,loadComponent:()=>ST,loadComponentDirectories:()=>PY,setErrorReporter:()=>zme});function PY(e,t){t&&(sw=t),e&&(iw=e);let r=[];if((0,Nt.existsSync)(nw)){let s=(0,Nt.readdirSync)(nw,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,Ot.join)(nw,o);r.push(ST(c,sw,"hdb",!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(ST(n,sw,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{DY=!0})}function zme(e){UE=e}async function ST(e,t,r,n,s,i){let o=(0,Nt.realpathSync)(e);if(pT.has(o))return pT.get(o);pT.set(o,!0),s&&(iw=s);try{let c;n&&(Td=new Map);let l=(0,Ot.join)(e,n?"harperdb-config.yaml":"config.yaml");(0,Nt.existsSync)(l)?c=n?(0,TT.getConfigObj)():(0,NY.parseDocument)((0,Nt.readFileSync)(l,"utf8")).toJSON():c=ow;let u=(0,Ot.join)(e,"node_modules","harperdb");try{El.isMainThread&&(n||(0,Nt.existsSync)(u)&&(0,Nt.realpathSync)(Rd.PACKAGE_ROOT)!==(0,Nt.realpathSync)(u))&&((0,Nt.rmSync)(u,{recursive:!0,force:!0}),(0,Nt.existsSync)((0,Ot.join)(e,"node_modules"))||(0,Nt.mkdirSync)((0,Ot.join)(e,"node_modules")),(0,Nt.symlinkSync)(Rd.PACKAGE_ROOT,u,"dir"))}catch(E){Sd.default.error("Error symlinking harperdb module",E)}let d=mT,_=n;for(let E in c){mT=E;let f=c[E];if(Td.set(n?E:(0,Ot.basename)(e),!1),!f)continue;let h,T=f.package;try{if(T){let I=e,B;for(;!(0,Nt.existsSync)(B=(0,Ot.join)(I,"node_modules",E));)if(I=(0,Ot.dirname)(I),I.length<(0,CY.getHdbBasePath)().length){B=null;break}if(B)h=await ST(B,t,r,!1),_=!0;else throw new Error(`Unable to find package ${E}:${T}`)}else h=jme[E];if(!h)continue;let m=a(I=>(I.origin=r,Et(I)),"ensureTable"),g=f.network||(f.port||f.securePort)&&f,S=g?.securePort||g?.https&&g.port,b=!g?.https&&g?.port;if(El.isMainThread&&(h=await h.startOnMainThread?.({server:it,ensureTable:m,port:b,securePort:S,resources:t,...f})||h,n&&g))for(let I of[b,S])try{if(+I&&!OY.includes(I)){let B=aw.get(Rd.CONFIG_PARAMS.HTTP_SESSIONAFFINITY);B&&Sd.default.warn("Session affinity is not recommended and may cause memory leaks"),(B||!US)&&(OY.push(I),$I(I,B))}}catch(B){console.error("Error listening on socket",I,B,E)}if(t.isWorker&&(h=await h.start?.({server:it,ensureTable:m,port:b,securePort:S,resources:t,...f})||h),iw.set(h,!0),(h.handleFile||h.handleDirectory||h.setupFile||h.setupDirectory)&&f.files!=null){if(f.files.includes(".."))throw(0,wY.handleHDBError)("Can not reference parent directories");let I=(0,Ot.join)(e,f.files).replace(/\\/g,"/"),B=I.indexOf("/*");if(B>-1&&f.files!==ow[E]?.files&&!(0,Nt.existsSync)(I.slice(0,B)))throw new Error(`The path '${I.slice(0,B)}' does not exist and cannot be used as the base of the resolved 'files' path value '${f.files}'`);let H=(0,Ot.basename)(e),X=f.path||"/";X=X.startsWith("/")?X:X.startsWith("./")?"/"+H+X.slice(2):X==="."?"/"+H:"/"+H+"/"+X;let Y,V,ne;if(f.root){let de=f.root;de.startsWith("/")&&(de=de.slice(1)),de.endsWith("/")&&(de=de.slice(0,-1)),de+="/",V=(0,Ot.join)(e,de)}else(ne=I.indexOf("/*"))>-1?(V=I.slice(0,ne+1),Y=(0,Ot.relative)(e,V)):f.files.indexOf("/")>-1&&(V=I.slice(0,I.lastIndexOf("/")+1),Y=(0,Ot.relative)(e,V));let Q=!1;if(El.isMainThread&&h.setupDirectory&&(Q=await h.setupDirectory?.(X,V,t)),t.isWorker&&h.handleDirectory&&(Q=await h.handleDirectory?.(X,V,t)),Q){_=!0;continue}for(let de of await(0,IY.default)(I,{onlyFiles:!1,objectMode:!0})){let{path:j,dirent:ae}=de;_=!0;let Ae=(0,Ot.relative)(e,j).replace(/\\/g,"/");if(Y)if(Ae.startsWith(Y))Ae=Ae.slice(Y.length+1);else throw new Error(`The root path '${f.root}' does not reference a valid part of the file path '${Ae}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let ye=X+(X.endsWith("/")?"":"/")+Ae;try{if(ae.isFile()){let Me=await Wme(j);El.isMainThread&&await h.setupFile?.(Me,ye,j,t),t.isWorker&&await h.handleFile?.(Me,ye,j,t)}else El.isMainThread&&await h.setupDirectory?.(ye,j,t),t.isWorker&&await h.handleDirectory?.(ye,j,t)}catch(Me){Me.message=`Could not load ${ae.isFile()?"file":"directory"} '${j}'${f.module?" using '"+f.module+"'":""} for application '${e}' due to: ${Me.message}`,UE?.(Me),((0,gd.getWorkerIndex)()===0?console:Sd.default).error(Me),t.set(f.path||"/",new ta(Me)),Td.set(n?E:(0,Ot.basename)(e),Me.message)}}}}catch(m){m.message=`Could not load component '${E}' for application '${(0,Ot.basename)(e)}' due to: ${m.message}`,UE?.(m),((0,gd.getWorkerIndex)()===0?console:Sd.default).error(m),t.set(f.path||"/",new ta(m),null,!0),Td.set(n?E:(0,Ot.basename)(e),m.message)}}if(mT=d,El.isMainThread&&!DY&&i&&(0,gd.watchDir)(e,async()=>PY()),c.extensionModule){let E=await aS((0,Ot.join)(e,c.extensionModule));return pT.set(o,E),E}if(!_&&t.isWorker){let E=`${e} did not load any modules, resources, or files, is this a valid component?`;UE?.(new Error(E)),((0,gd.getWorkerIndex)()===0?console:Sd.default).error(E),Td.set((0,Ot.basename)(e),E)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,UE?.(c),t.set("",new ta(c))}}var Nt,Ot,El,NY,aw,Rd,IY,gd,Sd,wY,CY,Yme,TT,Wme,nw,iw,DY,sw,Td,jme,ow,OY,pT,UE,mT,Qme,$f=Oe(()=>{Nt=require("fs"),Ot=require("path"),El=require("worker_threads"),NY=require("yaml"),aw=L(se()),Rd=L(M());ND();Hq();Gq();Kq();Yq();o$();XV();s1();IY=L(require("fast-glob")),gd=L(dt()),Sd=L(W());QO();qr();wY=L(_e());Pe();wI();CY=L(se()),Yme=L(sY());xm();_Y();us();bY();TT=L(wt());vS();fy();({readFile:Wme}=Nt.promises),nw=(0,TT.resolvePath)(aw.get(Rd.CONFIG_PARAMS.COMPONENTSROOT)),iw=new Map,Td=new Map;a(PY,"loadComponentDirectories");jme={REST:_S,rest:_S,graphql:jO,graphqlSchema:Pg,roles:zO,jsResource:XO,fastifyRoutes:YN,login:eN,static:WN,operationsApi:Yme,customFunctions:{},http:{},clustering:QI,replication:ca,authentication:Hf,mqtt:rw},ow={rest:!0,graphql:!0,graphqlSchema:{files:"*.graphql"},roles:{files:"roles.yaml"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(ow,"static",{value:{files:"web/**"}});OY=[],pT=new Map;a(zme,"setErrorReporter");Qme=a(()=>mT,"getComponentName");a(ST,"loadComponent")});var nT=N((EMe,MY)=>{var{isMainThread:LY}=require("worker_threads"),{getTables:Jme,getDatabases:_Me,table:fMe}=(Pe(),oe(lt)),{loadComponentDirectories:Xme,loadComponent:Zme}=($f(),oe(qf)),{resetResources:eSe}=(eu(),oe(sB)),tSe=SO(),rSe=wt(),{dirname:nSe}=require("path"),{getConnection:sSe}=mr(),iSe=se(),{CONFIG_PARAMS:oSe}=M(),{loadCertificates:aSe}=Xs(),cw=new Map;async function cSe(e=!1){!LY&&iSe.get(oSe.CLUSTERING_ENABLED)&&sSe();try{LY&&await tSe()}catch(n){console.error(n)}let t=eSe();Jme(),t.isWorker=e,await aSe(),await Zme(nSe(rSe.getConfigFilePath()),t,"hdb",!0,cw),await Xme(cw,t);let r=[];for(let[n]of cw)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(cSe,"loadRootComponents");MY.exports.loadRootComponents=cSe});var dt=N((pMe,ai)=>{"use strict";var{Worker:lSe,MessageChannel:uSe,parentPort:Vi,isMainThread:fw,threadId:dSe,workerData:Ki}=require("worker_threads"),{PACKAGE_ROOT:_Se}=M(),{join:HY,isAbsolute:fSe,extname:ESe}=require("path"),{server:xY}=(qr(),oe(Qa)),{watch:hSe,readdir:pSe}=require("fs/promises"),{totalmem:UY}=require("os"),vE=M(),kY=se(),Yi=W(),{randomBytes:mSe}=require("crypto"),{_assignPackageExport:SSe}=fi(),TSe=M(),vY=1024*1024,Ua=[],Ps=[],gSe=50,Ew=1e4,RSe="restart",FY="request_thread_info",GY="resource_report",qY="thread_info",$Y="added-port",ASe="ack",lw;SSe("threads",Ps);ai.exports={startWorker:uw,restartWorkers:pw,shutdownWorkers:ISe,workers:Ua,setMonitorListener:vSe,onMessageFromWorkers:wSe,onMessageByType:QY,broadcast:DSe,broadcastWithAcknowledgement:LSe,setChildListenerByType:NSe,getWorkerIndex:VY,getWorkerCount:KY,getTicketKeys:WY,setMainIsWorker:bSe,setTerminateTimeout:ySe,restartNumber:Ki?.restartNumber||1};Ps.onMessageByType=QY;Ps.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=Ps.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};ai.exports.whenThreadsStarted=new Promise(e=>{ai.exports.threadsHaveStarted=e});var hw;function ySe(e){Ew=e}a(ySe,"setTerminateTimeout");function VY(){return Ki?Ki.workerIndex:hw?0:void 0}a(VY,"getWorkerIndex");function KY(){return Ki?Ki.workerCount:hw?1:void 0}a(KY,"getWorkerCount");function bSe(e){hw=e,ai.exports.threadsHaveStarted()}a(bSe,"setMainIsWorker");var YY=1,gT;function WY(){return gT||(gT=fw?mSe(48):Ki.ticketKeys,gT)}a(WY,"getTicketKeys");Object.defineProperty(xY,"workerIndex",{get(){return VY()}});Object.defineProperty(xY,"workerCount",{get(){return KY()}});var jY={[FY](e,t){MSe(t)},[GY](e,t){USe(t,e)}};function uw(e,t={}){let r=process.constrainedMemory?.()||UY();r=Math.min(r,UY(),2e4*vY);let n=kY.get(vE.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/vY/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let l of Ps){let u=new uSe;u.existingPort=l,i.push(u),o.push(u.port2)}ESe(e)||(e+=".js");let c=new lSe(fSe(e)?e:HY(_Se,e),{resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps"],argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(l=>l.existingPort.threadId),workerIndex:t.workerIndex,workerCount:YY=t.threadCount,name:t.name,restartNumber:ai.exports.restartNumber,ticketKeys:WY()},transferList:o,...t});for(let{port1:l,existingPort:u}of i)u.postMessage({type:$Y,port:l,threadId:c.threadId},[l]);return AT(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>uw(e,t),c.on("error",l=>{Yi.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{Ua.splice(Ua.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<gSe?(t.unexpectedRestarts=c.unexpectedRestarts+1,uw(e,t)):Yi.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{jY[l.type]?.(l,c)}),Ua.push(c),HSe(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(uw,"startWorker");var OSe=[vE.THREAD_TYPES.HTTP];async function pw(e=null,t=Math.max(YY>3,1),r=!0){if(fw){if(r){let{loadRootComponents:o}=nT();await o()}ai.exports.restartNumber++,t<1&&(t=t*Ua.length);let n=[],s=[];for(let o of Ua.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;Yi.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:ai.exports.restartNumber,type:vE.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=OSe.indexOf(o.name)>-1,l=new Promise(u=>{let d=setTimeout(()=>{Yi.warn("Thread did not voluntarily terminate, terminating from the outside",o.threadId),o.terminate()},Ew*2).unref();o.on("exit",()=>{clearTimeout(d),n.splice(n.indexOf(l)),!c&&r&&o.startCopy(),u()})});if(n.push(l),c&&r){let u=o.startCopy(),d=new Promise(_=>{let E=a(f=>{f.type===TSe.ITC_EVENT_TYPES.CHILD_STARTED&&(Yi.trace("Worker has started",u.threadId),_(),s.splice(s.indexOf(d)),u.off("message",E))},"startListener");Yi.trace("Waiting for worker to start",u.threadId),u.on("message",E)});s.push(d),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=xu();r&&(e==="http"||!e)&&kY.get(vE.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else Vi.postMessage({type:RSe,workerType:e})}a(pw,"restartWorkers");function NSe(e,t){jY[e]=t}a(NSe,"setChildListenerByType");function ISe(e){return pw(e,1/0,!1)}a(ISe,"shutdownWorkers");var zY=[];function wSe(e){zY.push(e)}a(wSe,"onMessageFromWorkers");var dw=new Map;function QY(e,t){let r=dw.get(e);r||dw.set(e,r=[]),r.push(t)}a(QY,"onMessageByType");var CSe=10;async function DSe(e,t){let r=0;for(let n of Ps)try{n.postMessage(e),r++>CSe&&(r=0,await new Promise(setImmediate))}catch(s){Yi.error("Unable to send message to worker",s)}t&&XY(e,null)}a(DSe,"broadcast");var RT=new Map,PSe=1;function LSe(e){return new Promise(t=>{let r=0;for(let n of Ps)try{let s=PSe++,i=a(()=>{RT.delete(s),--r===0&&t(),n!==Vi&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,RT.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of RT)o.port===n&&o()})),n.postMessage(e),r++}catch(s){Yi.error("Unable to send message to worker",s)}r===0&&t()})}a(LSe,"broadcastWithAcknowledgement");function MSe(e){e.postMessage({type:qY,workers:JY()})}a(MSe,"sendThreadInfo");function JY(){let e=Date.now();return Ua.map(t=>({threadId:t.threadId,name:t.name,heapTotal:t.resources?.heapTotal,heapUsed:t.resources?.heapUsed,externalMemory:t.resources?.external,arrayBuffers:t.resources?.arrayBuffers,sinceLastUpdate:e-t.resources?.updated,...t.recentELU}))}a(JY,"getChildWorkerInfo");function USe(e,t){e.resources=t,e.resources.updated=Date.now()}a(USe,"recordResourceReport");var _w;function vSe(e){_w=e}a(vSe,"setMonitorListener");var BSe=1e3,BY=!1;function HSe(){BY||(BY=!0,setInterval(()=>{for(let e of Ua){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}_w&&_w()},BSe).unref())}a(HSe,"startMonitoring");var xSe=1e3;if(Vi&&Ki?.addPorts){AT(Vi);for(let e=0,t=Ki.addPorts.length;e<t;e++){let r=Ki.addPorts[e];r.threadId=Ki.addThreadIds[e],AT(r)}setInterval(()=>{let e=process.memoryUsage();Vi.postMessage({type:GY,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},xSe).unref(),lw=a(()=>new Promise((e,t)=>{Vi.on("message",r),Vi.postMessage({type:FY});function r(n){n.type===qY&&(Vi.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else lw=JY;ai.exports.getThreadInfo=lw;function AT(e,t){Ps.push(e),e.on("message",r=>{if(r.type===$Y)r.port.threadId=r.threadId,AT(r.port);else if(r.type===ASe){let n=RT.get(r.id);n&&n()}else XY(r,e)}).on("close",()=>{Ps.splice(Ps.indexOf(e),1)}).on("exit",()=>{Ps.splice(Ps.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(AT,"addPort");function XY(e,t){for(let n of zY)n(e,t);let r=dw.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){Yi.error(s)}}a(XY,"notifyMessageListeners");if(fw){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await pSe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(HY(s,o.name));try{for await(let{filename:o}of hSe(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await pw(),console.log("Reloaded HarperDB components, changed files:",Array.from(r)),r.clear()},100)}catch(o){console.warn("Error trying to watch component directory",s,o)}},"watch_dir");ai.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else Vi.on("message",async e=>{let{type:t}=e;t===vE.ITC_EVENT_TYPES.SHUTDOWN&&(ai.exports.restartNumber=e.restartNumber,Vi.unref(),setTimeout(()=>{Yi.warn("Thread did not voluntarily terminate",dSe),process.exit(0)},Ew).unref())})});var uv={};je(uv,{AUDIT_STORE_OPTIONS:()=>Pf,Decoder:()=>Cc,HAS_CURRENT_RESIDENCY_ID:()=>tc,HAS_EXPIRATION_EXTENDED_TYPE:()=>i_,HAS_ORIGINATING_OPERATION:()=>s_,HAS_PREVIOUS_RESIDENCY_ID:()=>rc,REMOTE_SEQUENCE_UPDATE:()=>Kp,createAuditEntry:()=>Dl,getLastRemoved:()=>Yy,openAuditStore:()=>IT,readAuditEntry:()=>Ht,removeAuditEntry:()=>wT,setAuditRetention:()=>FSe,transactionKeyEncoder:()=>cW});function IT(e){let t=e.auditStore=e.openDB(mw.AUDIT_STORE_NAME,{create:!1,...Pf});t||(t=e.auditStore=e.openDB(mw.AUDIT_STORE_NAME,Pf),eW(t,1)),t.rootStore=e;let r=[];t.addDeleteRemovalCallback=function(i,o){return r[i]=o,t.deleteCallbacks=r,{remove(){delete r[i]}}};let n=null;function s(i=yT){clearTimeout(n),n=setTimeout(async()=>{if(t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let o=0,c,l;try{for(let{key:u,value:d}of t.getRange({start:1,snapshot:!1,end:Date.now()-Sw}))if(c=wT(t,u,d),l=u,await new Promise(setImmediate),++o>=kSe){i=10;break}await c}finally{o===0?i=Math.min(i<<1,Sw/10):eW(t,l),s(i)}},i).unref()}if(a(s,"scheduleAuditCleanup"),t.scheduleAuditCleanup=s,(0,HE.getWorkerIndex)()===(0,HE.getWorkerCount)()-1&&s(yT),(0,HE.getWorkerIndex)()===0&&!ZY)for(let i of t.getKeys({reverse:!0,limit:1}))i>Date.now()&&(ZY=!0,NT.error("The current time is before the last recorded entry in the audit log. Time reversal can undermine the integrity of data tracking and certificate validation and the time must be corrected."));return t}function wT(e,t,r){if((GSe(r)&15)===Tw){let n=Ht(r),s=n.tableId;e.deleteCallbacks?.[s]?.(n.recordId)}return e.remove(t)}function eW(e,t){gw[0]=t,e.put(Symbol.for("last-removed"),lW)}function Yy(e){let t=e.get(Symbol.for("last-removed"));if(t)return lW.set(t),gw[0]}function FSe(e,t=yT){Sw=e,yT=t}function Dl(e,t,r,n,s,i,o,c,l,u,d,_,E){let f=uW[o];if(!f)throw new Error(`Invalid audit entry type ${o}`);let h=1;if(n&&(n>1?va.setFloat64(0,n):Ls.set(jg),h=9),l){if(l&16761087)throw new Error("Illegal extended type");h++}g(s),g(t),m(r),va.setFloat64(h,e),h+=8,l&tc&&g(u),l&rc&&g(d),l&i_&&(va.setFloat64(h,_),h+=8),l&s_&&g(dW[E]),i?m(i):Ls[h++]=0,l?va.setUint16(n?8:0,f|l|32768):Ls[n?8:0]=f;let T=Ls.subarray(0,h);if(c)return Buffer.concat([T,c]);return T;function m(S){let b=h;h+=1,h=(0,hl.writeKey)(S,Ls,h);let I=h-b-1;I>127?I>16383?(NT.error("Key or username was too large for audit entry",S),h=b+1,Ls[b]=0):(Ls.copyWithin(b+2,b+1,h),va.setUint16(b,I|32768),h++):Ls[b]=I}function g(S){S<128?Ls[h++]=S:S<16384?(va.setUint16(h,S|32768),h+=2):S<1056964608?(va.setUint32(h,S|3221225472),h+=4):(Ls[h]=255,va.setUint32(h+1,S),h+=5)}}function GSe(e){let t=0;e[0]==66&&(t=8);let r=e[t];if(r<128)return r;let n=e.dataView||(e.dataView=new Cc(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function Ht(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new Cc(e.buffer,e.byteOffset,e.byteLength));n.position=t;let s;e[n.position]==66&&(s=n.readFloat64());let i=n.readInt(),o=n.readInt(),c=n.readInt(),l=n.readInt(),u=n.position,d=n.position+=l,_=n.readFloat64(),E,f,h,T;if(i&tc&&(E=n.readInt()),i&rc&&(f=n.readInt()),i&i_&&(h=n.readFloat64()),i&s_){let S=n.readInt();T=dW[S]}l=n.readInt();let m=n.position,g=n.position+=l;return{type:uW[i&7],tableId:c,nodeId:o,get recordId(){return(0,hl.readKey)(e,u,d)},getBinaryRecordId(){return e.subarray(u,d)},version:_,previousLocalTime:s,get user(){return g>m?(0,hl.readKey)(e,m,g):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(S,b,I){if(i&bT||i&BE&&!b)return S.decoder.decode(e.subarray(n.position,r));if(i&BE&&I)return Rw(S.getEntry(this.recordId),I,S)},getBinaryValue(){return i&(bT|BE)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:E,previousResidencyId:f,expiresAt:h,originatingOperation:T}}catch(n){return NT.error("Reading audit entry error",n,e),{}}}var hl,OT,mw,oW,HE,aW,NT,Ls,va,cW,Pf,Sw,kSe,gw,lW,yT,ZY,bT,BE,tW,Tw,rW,nW,sW,iW,Kp,tc,rc,s_,i_,uW,dW,Cc,Ji=Oe(()=>{hl=require("ordered-binary"),OT=L(se()),mw=L(Bt()),oW=L(M()),HE=L(dt()),aW=L(te());Pl();NT=L(W());CT();(0,OT.initSync)();Ls=Buffer.alloc(1024),va=new DataView(Ls.buffer,Ls.byteOffset,1024),cW={writeKey(e,t,r){return e===n_?(t.set(n_,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,hl.writeKey)(e,t,r)},readKey(e,t,r){return e[t]===66?(e.dataView||(e.dataView=new DataView(e.buffer,e.byteOffset,e.byteLength))).getFloat64(t):(0,hl.readKey)(e,t,r)}},Pf={encoding:"binary",keyEncoder:cW},Sw=(0,aW.convertToMS)((0,OT.get)(oW.CONFIG_PARAMS.LOGGING_AUDITRETENTION))||86400*3,kSe=1e3,gw=new Float64Array(1),lW=new Uint8Array(gw.buffer),yT=1e4,ZY=!1;a(IT,"openAuditStore");a(wT,"removeAuditEntry");a(eW,"updateLastRemoved");a(Yy,"getLastRemoved");a(FSe,"setAuditRetention");bT=16,BE=32,tW=1,Tw=2,rW=3,nW=4,sW=5,iW=6,Kp=11,tc=512,rc=1024,s_=2048,i_=4096,uW={put:tW|bT,[tW]:"put",delete:Tw,[Tw]:"delete",message:rW|bT,[rW]:"message",invalidate:nW|BE,[nW]:"invalidate",patch:sW|BE,[sW]:"patch",relocate:iW,[iW]:"relocate"},dW={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};a(Dl,"createAuditEntry");a(GSe,"readAction");a(Ht,"readAuditEntry");Cc=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t;return t=this.getUint8(this.position++),t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch(t){throw t.message=`Error reading float64: ${t.message} at position ${this.position}`,t}}}});var Aw={};je(Aw,{add:()=>DT,applyReverse:()=>_W,getRecordAtTime:()=>Rw,rebuildUpdateBefore:()=>PT});function DT(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n+BigInt(r.value):isNaN(e[t])?e[t]=r.value:e[t]=n+r.value}function PT(e,t,r){let n=null;for(let s in e)if(s in t){let i=t[s];if(i?.__op__){let o=e[s];if(o?.__op__)if(o.__op__===i.__op__)n||(n={}),n[s]=o;else throw new Error("Can not merge updates with different operations");else n||(n={}),n[s]=o,DT(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function _W(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=qSe[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=fW}}function Rw(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),u=Ht(l);switch(u.type){case"put":s=u.getValue(r);break;case"patch":_W(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===fW&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),u=Ht(l),d;switch(u.type){case"put":d=u.getValue(r);break;case"patch":d=u.getValue(r);break}for(let _ in d)o[_]&&(s[_]=d[_],o[_]=!1,c--);i=u.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var qSe,fW,CT=Oe(()=>{Ji();a(DT,"add");DT.reverse=function(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n-BigInt(r.value):isNaN(e[t])||(e[t]=n-r.value)};qSe={add:DT};a(PT,"rebuildUpdateBefore");a(_W,"applyReverse");fW={};a(Rw,"getRecordAtTime")});function Zn(e){return e[_r]||(e[_r]=Object.create(null))}function BT(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let o of s){let c=o.name,l,u;if(o.resolve)u={get(){return o.resolve(this,this[ke])},set(d){return o.set(this,d)},configurable:!0};else{switch(o.type){case"String":l=a(function(d){if(!(typeof d=="string"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a string, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"ID":l=a(function(d){if(!(typeof d=="string"||d?.length>0&&d.every?.(_=>typeof _=="string")||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a string, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Float":case"Number":l=a(function(d){let _=d?.__op__?d.value:d;if(!(typeof _=="number"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a number, attempt to assign ${_}`);Zn(this)[c]=d},"set");break;case"Int":l=a(function(d){let _=d?.__op__?d.value:d;if(!(_>>0===_||d==null&&o.nullable!==!1))if(typeof _=="number"&&Math.abs((_>>0)-_)<=1)_=Math.round(_),d?.__op__?d.value=_:d=_;else throw new Ms.ClientError(`${c} must be an integer between -2147483648 and 2147483647, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Long":l=a(function(d){let _=d?.__op__?d.value:d;if(!(Math.round(_)===d&&Math.abs(_)<=9007199254740992||d==null&&o.nullable!==!1))if(typeof _=="number"&&Math.abs(_)<=9007199254740992)_=Math.round(_),d?.__op__?d.value=_:d=_;else throw new Ms.ClientError(`${c} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"BigInt":l=a(function(d){let _=d?.__op__?d.value:d;if(!(typeof _=="bigint"||d==null&&o.nullable!==!1))if(typeof _=="string"||typeof _=="number")_=BigInt(_),d?.__op__?d.value=_:d=_;else throw new Ms.ClientError(`${c} must be a number, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Boolean":l=a(function(d){if(!(typeof d=="boolean"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a boolean, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Date":l=a(function(d){if(!(d instanceof Date||d==null&&o.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=new Date(d);else throw new Ms.ClientError(`${c} must be a Date, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Bytes":l=a(function(d){if(!(d instanceof Uint8Array||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a Buffer or Uint8Array, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Any":case void 0:l=a(function(d){Zn(this)[c]=d},"set");break;default:l=a(function(d){if(!(typeof d=="object"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be an object, attempt to assign ${d}`);Zn(this)[c]=d},"set")}u={get(){let d=this[_r];if(d&&c in d){let E=d[c];if(E?.__op__){let f=this[ve]?.[c];return E.update(f)}return E}let _=this[ve]?.[c];if(_&&typeof _=="object"){let E=hW(_,o);if(E)return d||(d=this[_r]=Object.create(null)),d[c]=E}return _},set:l,enumerable:!0,configurable:!0}}u.get.isAttribute=!0,n[c]=u,(!(c in r)||Object.getOwnPropertyDescriptor(r,c)?.get?.isAttribute)&&Object.defineProperty(r,c,u)}i("getProperty",function(o){let c=n[o];if(c)return c.get.call(this);let l=this[_r];return l?.[o]!==void 0?l[o]:this[ve]?.[o]}),i("set",function(o,c){let l=n[o];if(l)return l.set.call(this,c);if(t.sealed)throw new Ms.ClientError("Can not add a property to a sealed table schema");Zn(this)[o]=c}),i("deleteProperty",function(o){Zn(this)[o]=void 0}),i("toJSON",function(){let o=this[_r],c;for(let u in o){c||(c={...this[ve]});let d=o[u];if(d?.__op__){let _=c[u];d=d.update(_)}c[u]=d}return Object.keys(this).length>0&&(c||(c={...this[ve]}),Object.assign(c,this)),c||this[ve]}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty);function i(o,c){Object.defineProperty(r,o,{value:c,configurable:!0})}a(i,"setMethod")}function hW(e,t){let r;switch(e.constructor){case Object:return t?((r=t.TrackedObject)||(t.TrackedObject=r=class{static{a(this,"TrackedObject")}constructor(s){if(s?.[ve])throw new Error("Can not track an already tracked object, check for circular references");this[ve]=s}},BT(r,t)),new r(e)):new LT(e);case Array:let n=new UT(e.length);n[ve]=e;for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=hW(o,t?.elements)),n[s]=o}return n;default:return e}}function dp(e){let t=e[_r],r;for(let s in t){r||(r={...e[ve]});let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=dp(i);r[s]=i}return Object.keys(e).length>0&&(r||(r={...e[ve]}),Object.assign(r,e)),r||e[ve]}function ml(e,t=e[_r]){let r;if(EW.call(e,ve)&&e.constructor===Array&&!Object.isFrozen(e)){r=e;for(let n=0,s=e.length;n<s;n++){let i=e[n];if(i&&typeof i=="object"){let o=ml(i);o!==i&&r===e&&(r=e.slice(0)),i=o}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r={...e[ve]});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=Aw[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=ml(s);r[n]=s}return r?Object.freeze(r):EW.call(e,ve)?e[ve]:e}function MT(e){let t=e[ve];if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[pl]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.[ve]===s){if(MT(i))return!0}else return!0}}else{let r=e[_r];if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s[ve]===i){if(MT(s))return!0}else return!0}else return!0}}return!1}var Ms,_r,LT,EW,pl,UT,vT,_p=Oe(()=>{Vs();Ms=L(_e());CT();_r=Symbol("own-data");a(Zn,"getChanges");a(BT,"assignTrackedAccessors");a(hW,"trackObject");LT=class{static{a(this,"GenericTrackedObject")}constructor(t){if(t?.[ve])throw new Error("Can not track an already tracked object, check for circular references");this[ve]=t}};BT(LT,{});a(dp,"collapseData");EW=Object.prototype.hasOwnProperty;a(ml,"updateAndFreeze");a(MT,"hasChanges");pl=Symbol.for("has-array-changes"),UT=class extends Array{static{a(this,"TrackedArray")}[pl];constructor(t){super(t)}splice(...t){return this[pl]=!0,super.splice(...t)}push(...t){return this[pl]=!0,super.push(...t)}pop(){return this[pl]=!0,super.pop()}unshift(...t){return this[pl]=!0,super.unshift(...t)}shift(){return this[pl]=!0,super.shift()}};UT.prototype.constructor=Array;vT=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var _A={};je(_A,{CONTEXT:()=>ke,ID_PROPERTY:()=>ze,IS_COLLECTION:()=>ci,MultiPartId:()=>xT,RECORD_PROPERTY:()=>ve,Resource:()=>Lr,snake_case:()=>VSe,transformForSelect:()=>kT});function VSe(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function pW(e,t){if(Sl=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(Sl=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new xT;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Sl=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return Sl=!0,null;e[e.length-1]==="/"&&(Sl=!0)}return t.coerceId(decodeURIComponent(e))}function es(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,l,u,d;if(r?(o?(d=i,o=o[ke]||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(d=s,c=d[this.primaryKey]??null,o=i[ke]||i):d=i:(d=s,s=void 0,c=d[ze]??d[this.primaryKey]),c===null&&(u=!0)):i?o=i[ke]||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="object"&&s){if(l=s,typeof(c=s.url)=="string"){let f=c.indexOf("?");if(f>-1){let T=this.parseQuery(c.slice(f+1));l?T&&(l=Object.assign(T,l)):l=T,c=c.slice(0,f)}let h=this.parsePath(c,o,l);h?.id!==void 0?(h.query&&(l?l=Object.assign(h.query,l):l=h.query),u=h.isCollection,c=h.id):c=h}else if(s[Symbol.iterator]){c=[],u=!0;for(let f of s){if(typeof f=="object"&&f)break;c.push(f)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=null,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new Xc(c),c==null&&(u=!0);o||(o={});let _;if(l?.ensureLoaded!=null||l?.async||u?(_={...t},l?.ensureLoaded!=null&&(_.ensureLoaded=l.ensureLoaded),l?.async&&(_.async=l.async),u&&(_.isCollection=!0)):_=t,o.transaction){let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)}else return Dt(o,()=>{let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)},_);function E(f){if(o.authorize){o.authorize=!1;let h=t.type==="read"?f.allowRead(o.user,l,o):t.type==="update"?f.doesExist?.()===!1?f.allowCreate(o.user,d,o):f.allowUpdate(o.user,d,o):t.type==="create"?f.allowCreate(o.user,d,o):f.allowDelete(o.user,l,o);if(h?.then)return h.then(T=>{if(!T)throw new HT(o.user);return typeof d?.then=="function"?d.then(m=>e(f,l,o,m)):e(f,l,o,d)});if(!h)throw new HT(o.user)}return typeof d?.then=="function"?d.then(h=>e(f,l,o,h)):e(f,l,o,d)}a(E,"authorizeActionOnResource")}}function ts(e,t){let r=new TW.ClientError(`The ${e.constructor.name} does not have a ${t} method implemented`,405);r.allow=[],r.method=t;for(let n of["get","put","post","delete","query","move","copy"])typeof e[n]=="function"&&r.allow.push(n);throw r}function yw(e,t,r){let n=e[ve];if(n){let s=e[_r];return i=>{let o,c;return e.hasOwnProperty(i)&&typeof(o=e[i])!="function"?o:s&&i in s?s[i]:(c=t?.[i])?c(e,r):n[i]}}else return t?s=>{let i=t[s];return i?i(e,r):e[s]}:s=>e[s]}function kT(e,t){let r=t?.propertyResolvers,n=t[ke],s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):yw(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(c);let u=[],d=i(yw(l,r,n));for(let _ of e)u.push(d(_));return u},"transform");let o=e.forceNulls;return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(E=>E&&typeof E=="object"?c(E):E);let u={},d=i(yw(l,r,n)),_;for(let E of e){let f=d(E);f===void 0&&o&&(f=null),f?.then?(_||(_=[]),_.push(f.then(h=>u[E.name||E]=h))):u[E.name||E]=f}return _?Promise.all(_).then(()=>u):u},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(o){return c=>{if(typeof c=="string")return o(c);if(typeof c=="object")if(c.name){s||(s={});let l=s[c.name];if(!l){let d=r[c.name]?.definition?.tableClass;l=s[c.name]=kT(c.select||c,d)}let u=o(c.name);return l(u)}else return o(c);else return c}}a(i,"handleProperty")}var mW,SW,TW,ke,ze,ci,ve,$Se,Lr,HT,Sl,xT,Vs=Oe(()=>{mW=require("crypto");wl();SW=L(fi()),TW=L(_e());_p();mc();iE();ke=Symbol.for("context"),ze=Symbol.for("primary-key"),ci=Symbol("is-collection"),ve=Symbol("stored-record"),$Se={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Lr=class{static{a(this,"Resource")}static transactions;constructor(t,r){this[ze]=t;let n=r?.[ke];this[ke]=n!==void 0?n:r||null}static get=es(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let l;if((l=r?.select)&&c!=null&&!c.selectApplied){let u=kT(l,t.constructor);return typeof c?.map=="function"?c.map(u):u(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=es(function(t,r,n,s){if(Array.isArray(s)&&t[ci]){let i=[],o=n.authorize;for(let c of s){let l=t.constructor,u=l.getResource(c[l.primaryKey],n,{async:!0});u.then?i.push(u.then(d=>d.put(c,n))):i.push(u.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):ts(t,"put")},{hasContent:!0,type:"update"});static patch=es(function(t,r,n,s){return t.patch?t.patch(s,r):ts(t,"patch")},{hasContent:!0,type:"update"});static delete=es(function(t,r,n,s){return t.delete?t.delete(r):ts(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,mW.randomUUID)()}static create(t,r,n){let s;return t==null?s=r?.[this.primaryKey]??this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=r?.[this.primaryKey]??[...t,this.getNewId()]:typeof t!="object"?s=r?.[this.primaryKey]??[t,this.getNewId()]:(s=t?.[this.primaryKey]??this.getNewId(),n=r||{},r=t),n||(n={}),Dt(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):ts(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=es(function(t,r,n,s){return t.invalidate?t.invalidate(r):ts(t,"delete")},{hasContent:!1,type:"update"});static post=es(function(t,r,n,s){return t[ze]!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=es(function(t,r,n,s){return t.connect?t.connect(s,r):ts(t,"connect")},{hasContent:!0,type:"read"});static subscribe=es(function(t,r,n,s){return t.subscribe?t.subscribe(r):ts(t,"subscribe")},{type:"read"});static publish=es(function(t,r,n,s){return t[ze]!=null&&t.update?.(),t.publish?t.publish(s,r):ts(t,"publish")},{hasContent:!0,type:"create"});static search=es(function(t,r,n,s){let i=t.search?t.search(r):ts(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=kT(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=es(function(t,r,n,s){return t.search?t.search(s,r):ts(t,"search")},{hasContent:!0,type:"read"});static copy=es(function(t,r,n,s){return t.copy?t.copy(s,r):ts(t,"copy")},{hasContent:!0,type:"create"});static move=es(function(t,r,n,s){return t.move?t.move(s,r):ts(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this[ci])return(await this.constructor.create(this[ze],t,this[ke]))[ze];ts(this,"post")}static isCollection(t){return t?.[ci]}static coerceId(t){return t}static parseQuery(t){return uS(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1);t=t.slice(0,s);let c=r?.headers&&$Se[o];if(c)r.requestedContentType=c;else if(n)n.property=o;else return{query:{property:o},id:pW(t,this),isCollection:Sl}}let i=pW(t,this);return Sl?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r[ke],o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let u=l.asMap.get(t);if(s=u?.find(d=>d.constructor===c),s)return s;u||l.asMap.set(t,u=[]),u.push(s=new c(t,i))}else{if(s=l.find(u=>u[ze]===t&&u.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let u=new Map;for(let d of l){let _=d[ze],E=u.get(_);E?E.push(d):u.set(_,[d])}i.resourceCache.length=0,i.resourceCache.asMap=u}}}else s=new c(t,i);return o&&(s[ci]=!0),s}subscribe(t){return new Mn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new Mn}allowRead(t){return t?.role.permission.super_user}allowUpdate(t){return t?.role.permission.super_user}allowCreate(t){return t?.role.permission.super_user}allowDelete(t){return t?.role.permission.super_user}getId(){return this[ze]}getContext(){return this[ke]}};Lr.prototype[ke]=null;(0,SW._assignPackageExport)("Resource",Lr);a(VSe,"snake_case");HT=class extends Error{static{a(this,"AccessError")}constructor(t){t?(super("Unauthorized access to resource"),this.statusCode=403):(super("Must login"),this.statusCode=401)}};a(pW,"pathToId");xT=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(es,"transactional");a(ts,"missingMethod");a(yw,"selectFromObject");a(kT,"transformForSelect")});var CN={};je(CN,{EVICTED:()=>ya,INVALIDATED:()=>Os,coerceType:()=>GT,makeTable:()=>VT,setServerUtilities:()=>ZSe,updateResource:()=>qT});function VT(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:l,schemaDefined:u,dbisDB:d,sealed:_,splitSegments:E,replicate:f}=e,{expirationMS:h,evictionMS:T,audit:m,trackDeletes:g}=e,{attributes:S}=e;S||(S=[]);let b=Jg(i,n,l),I,B,H={},X=Promise.resolve(),Y,V,ne;for(let U of S)(U.assignCreatedTime||U.name==="__createdtime__")&&(Y=U),(U.assignUpdatedTime||U.name==="__updatedtime__")&&(V=U),U.expiresAt&&(ne=U),U.isPrimaryKey&&(H=U);let Q,de=[],j=[],ae=1,Ae=2,ye={},Me={},Gr=864e5,wd,ka,wn,Cd=!1,Al,Uw=new Map,jE=new Map,vt,Fa,Ga=yd.get(Us.CONFIG_PARAMS.REPLICATION_DATABASES);if(Array.isArray(Ga)){for(let U of Ga)if(U.name===c&&U.replicateTo>=0){Fa=U.replicateTo;break}}let vs=i.getRange({start:!1,end:!1}).constructor,Bs=10,zE=6;m&&ie();class Ve extends Lr{static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=m;static databasePath=o;static databaseName=c;static attributes=S;static replicate=f;static sealed=_;static splitSegments=E??!0;static createdTimeProperty=Y;static updatedTimeProperty=V;static propertyResolvers;static userResolvers={};static sources=[];static get expirationMS(){return h}static dbisDB=d;static schemaDefined=u;static sourcedFrom(p,R){if(R&&(this.sourceOptions=R,(R.expiration||R.eviction||R.scanInterval)&&this.setTTLExpiration(R)),R?.intermediateSource)p.intermediateSource=!0,this.sources.unshift(p);else{if(this.sources.some(O=>!O.intermediateSource)){if(this.sources.some(O=>O.name===p.name))return;throw new Error("Can not have multiple canonical (non-intermediate) sources")}this.sources.push(p)}B=B||p.get&&(!p.get.reliesOnPrototype||p.prototype.get),I=I||p.load;let w=a(O=>{let v=this.sources;if(v=v.filter(k=>k.intermediateSource&&k[O]&&(!k[O].reliesOnPrototype||k.prototype[O])),v.length>0)if(v.length===1){let k=v[0];return(C,F,x)=>{if(C?.source!==k)return k[O](F,x,C)}}else return(k,C,F)=>{let x=[];for(let q of v){if(k?.source===q)break;x.push(q[O](C,F,k))}return Promise.all(x)}},"getApplyToIntermediateSource"),A=this.sources[this.sources.length-1];A.intermediateSource&&(A={});let y=a(O=>{if(A[O]&&(!A[O].reliesOnPrototype||A.prototype[O]))return(v,k,C)=>{if(!v?.source)return A[O](k,C,v)}},"getApplyToCanonicalSource");ye={put:y("put"),patch:y("patch"),delete:y("delete"),publish:y("publish")},Me={put:w("put"),patch:w("patch"),delete:w("delete"),publish:w("publish"),invalidate:w("invalidate")};let D=A.shouldRevalidateEvents;return(async()=>{let O=!1,v,k=a(async(C,F)=>{let x=C.value,q=C.table?We[c][C.table]:Ve;if(c===Us.SYSTEM_SCHEMA_NAME&&(C.table===Us.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||C.table===Us.SYSTEM_TABLE_NAMES.USER_TABLE_NAME)&&(O=!0),C.id===void 0&&(C.id=x[q.primaryKey],C.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(C));C.source=p;let ee={residencyId:tt(C.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:C.nodeId},G=await q.getResource(C.id,F,ee);switch(C.type){case"put":return D?G._writeInvalidate(ee):G._writeUpdate(x,!0,ee);case"patch":return D?G._writeInvalidate(ee):G._writeUpdate(x,!1,ee);case"delete":return G._writeDelete(ee);case"publish":return G._writePublish(x,ee);case"invalidate":return G._writeInvalidate(ee);case"relocate":return G._writeRelocate(ee);default:Ge.default.error?.("Unknown operation",C.type,C.id)}},"writeUpdate");try{let C=p.subscribe;C&&g==null&&(g=!0);let F={crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0},x=p.subscribeOnThisThread?p.subscribeOnThisThread((0,Tl.getWorkerIndex)(),F):(0,Tl.getWorkerIndex)()===0,q=C&&x&&await p.subscribe?.(F);if(q){let ee;for await(let G of q)try{if(!(G.type==="transaction"?G.writes[0]:G)){Ge.default.error?.("Bad subscription event",G);continue}if(G.source=p,G.type==="end_txn"){if(ee?.resolve(),G.localTime&&v!==G.localTime){if(G.remoteNodeIds?.length>0){let Re=[Symbol.for("seq"),G.remoteNodeIds[0]],re=d.get(Re),K=re?.nodes;K||(K=[]);for(let Be of G.remoteNodeIds.slice(1)){let Ie=K.find(ce=>ce.id===Be);K=K.filter(ce=>ce.id!==Be||ce===Ie),Ie||(Ie={id:Be,seqId:0},K.push(Ie)),Ie.seqId=Math.max(re?.seqId??1,G.localTime),Be===ee?.nodeId&&(Ie.lastTxnTime=G.timestamp)}let Te=Math.max(re?.seqId??1,G.localTime);Ge.default.trace?.("Received txn",c,Te,G.localTime,G.remoteNodeIds),d.put(Re,{seqId:Te,nodes:K})}v=G.localTime}G.onCommit&&ee?.committed.then(G.onCommit);continue}if(ee)if(G.beginTxn)ee.resolve();else{ee.write_promises.push(k(G,ee));continue}!G.timestamp&&G.version&&(G.timestamp=G.version);let Ee=Dt(G,()=>{if(G.type==="transaction"){let Re=[];for(let re of G.writes)try{Re.push(k(re,G))}catch(K){throw K.message+=" writing "+JSON.stringify(re)+" of event "+JSON.stringify(G),K}return Promise.all(Re)}else if(G.type==="define_schema"){let Re=this.attributes.slice(0),re;for(let K of G.attributes)Re.find(Te=>Te.name===K.name)||(Re.push(K),re=!0);re&&(Et({table:s,database:c,attributes:Re,origin:"cluster"}),GE.signalSchemaChange(new qE.SchemaEventMsg(process.pid,Us.OPERATIONS_ENUM.CREATE_TABLE,c,s)))}else return G.beginTxn?(ee=G,ee.write_promises=[k(G,G)],new Promise(Re=>{ee.resolve=()=>Re(Promise.all(ee.write_promises))})):k(G,G)});ee&&(ee.committed=Ee),O&&Ee&&!Ee?.waitingForUserChange&&(Ee.then(()=>GE.signalUserChange(new qE.UserEventMsg(process.pid))),Ee.waitingForUserChange=!0),G.onCommit&&(Ee?Ee.then(G.onCommit):G.onCommit())}catch(be){Ge.default.error?.("error in subscription handler",be)}}}catch(C){Ge.default.error?.(C)}})(),this}static get isCaching(){return B}static get shouldRevalidateEvents(){return this.prototype.get!==Ve.prototype.get}static getResource(p,R,w){let A=super.getResource(p,R,w);if(p!=null){ji(p);try{if(A.hasOwnProperty(ve))return A;if(typeof p=="object"&&p&&!Array.isArray(p))throw new Error(`Invalid id ${JSON.stringify(p)}`);let y=!w?.async||i.cache?.get?.(p),D=Ir(R),O=D.getReadTxn();if(O?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return $a(p,R,{transaction:O,ensureLoaded:w?.ensureLoaded},y,v=>{if(v?qT(A,v):A[ve]=null,R.onlyIfCached&&R.noCacheStore){if(!A.doesExist())throw new Nr.ServerError("Entry is not cached",504)}else if(w?.ensureLoaded){let k=Dd(p,v,R,A);if(k)return D?.disregardReadTxn(),A[bw]=!0,Nw(k,C=>(qT(A,C),A))}return A})}catch(y){throw y.message.includes("Unable to serialize object")&&(y.message+=": "+JSON.stringify(p)),y}}return A}ensureLoaded(){let p=Dd(this[ze],this[Fr],this[ke]);if(p)return this[bw]=!0,Nw(p,R=>{this[Fr]=R,this[ve]=R.value,this[kE]=R.version})}static getNewId(){let p=H?.type;if(p==="String"||p==="ID")return super.getNewId();if(!vt){let y=i.getEntry(Symbol.for("id_allocation")),D=y?.value,O;if(D&&D.nodeName===server.hostname&&(!tTe(i)||D.pid===process.pid)){let v=D.start,k=D.end;O=v;for(let C of i.getKeys({start:k,end:v,limit:1,reverse:!0}))O=C}else D=A(y?.version??null),O=D.start;vt=new BigInt64Array([BigInt(O)+1n]),vt=new BigInt64Array(i.getUserSharedBuffer("id",vt.buffer)),vt.maxSafeId=D.end}let R=Number(Atomics.add(vt,0,1n)),w=p==="Int"?512:1048576;if(R+w>=vt.maxSafeId){let y=a(D=>{vt.maxSafeId=R+(p==="Int"?1023:4194303);let O=(p==="Int"?Math.pow(2,31):Math.pow(2,49))-1,v=D?void 0:i.useReadTransaction(),k=Number(vt[0]);for(let x of i.getKeys({start:k+1,end:O,limit:1,transaction:v}))O=x;v?.done();let{value:C,version:F}=i.getEntry(Symbol.for("id_allocation"));if(vt.maxSafeId<O){if(C.end>vt.maxSafeId-100)return;Ge.default.info?.("New id allocation",R,vt.maxSafeId,F),i.put(Symbol.for("id_allocation"),{start:C.start,end:vt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),F)}else{Ge.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${vt.maxSafeId}, but id of ${O} detected`);let x=A(F);x.alreadyUpdated||Atomics.store(vt,0,BigInt(x.start+1)),vt.maxSafeId=x.end}},"updateEnd");R+w===vt.maxSafeId?setImmediate(y):R+100>=vt.maxSafeId&&(Ge.default.warn?.(`Synchronous id allocation required on table ${s}${p=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>y(!0)))}return R;function A(y){let D=(p==="Int"?Math.pow(2,31):Math.pow(2,49))-1,O=D/4,v,k,C=!1,F,x;do{F=Math.floor(Math.random()*D),x={start:F,end:F+(p==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},v=0;for(let q of i.getKeys({start:F,limit:1,reverse:!0}))v=q;k=D;for(let q of i.getKeys({start:F+1,end:D,limit:1}))k=q;O*=.875,O<1e3&&!C&&(C=!0,Ge.default.error?.(`Id allocation in table ${s} is very dense, limited safe range of numbers to allocate ids in${p==="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`,F,v,k,O))}while(!(O<k-F&&(O<F-v||v===0)));return i.transactionSync(()=>{let q=i.getEntry(Symbol.for("id_allocation"));return(q?.version??null)==y?(Ge.default.info?.("Allocated new id range",x),i.put(Symbol.for("id_allocation"),x,Date.now()),x):(Ge.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...q.value})})}}static setTTLExpiration(p){if(typeof p=="number")h=p*1e3,T||(T=0);else if(p&&typeof p=="object")h=p.expiration*1e3,T=(p.eviction||0)*1e3,Gr=p.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(h<0)throw new Error("Expiration can not be negative");Gr=Gr||(h+T)/4,ko()}static getResidencyRecord(p){return d.get([Symbol.for("residency_by_id"),p])}static setResidency(p){Ve.getResidency=p}static setResidencyById(p){Ve.getResidencyById=p}static getResidency(p,R,w){if(Ve.getResidencyById)return Ve.getResidencyById(p[t]);let A=Fa;if(R.replicateTo!=null){if(Array.isArray(R.replicateTo))return R.replicateTo.includes(server.hostname)?R.replicateTo:[server.hostname,...R.replicateTo];R.replicateTo>=0&&(A=R.replicateTo)}if(A>=0&&server.nodes){let y=[server.hostname];if(w)y.push(...w.slice(0,A));else{let D=server.nodes.map(k=>k.name),O=Math.floor(D.length*Math.random());y.push(...D.slice(O,O+A));let v=O+A-D.length;v>0&&y.push(...D.slice(0,v))}return y}}static enableAuditing(p=!0){m=p,p&&ie(),Ve.audit=p}static coerceId(p){return p===""?null:GT(p,H)}static async dropTable(){if(delete We[c][s],c===o){for(let p of S)d.remove(Ve.tableName+"/"+p.name),r[p.name]?.drop();d.remove(Ve.tableName+"/"),i.drop(),await d.committed}else console.log("legacy dropTable"),await i.close(),await fs.remove(data_path),await fs.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));GE.signalSchemaChange(new qE.SchemaEventMsg(process.pid,Us.OPERATIONS_ENUM.DROP_TABLE,c,s))}get(p){if(typeof p=="string")return this.getProperty(p);if(this[ci])return this.search(p);if(this[ze]===null){if(p?.conditions)return this.search(p);let R=Ve.getRecordCount();return{recordCount:R.recordCount,estimatedRecordRange:R.estimatedRange,records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:S}}if(p?.property)return this.getProperty(p.property);if(this.doesExist()||p?.ensureLoaded===!1||this[ke]?.returnNonexistent)return this}allowRead(p,R){let w=Va(p);if(w?.read){if(w.isSuperUser)return!0;let A=w.attribute_permissions,y=R?.select;if(A?.length>0||Cd&&y){if(R||(R={}),y){let D=A?.length>0&&Ow(A,"read");R.select=y.map(O=>{let v=O.name||O;if(!D||D[v]){let k=wn[v]?.definition?.tableClass;if(k){if(O.name||(O={name:O}),!k.prototype.allowRead.call(null,p,O))return!1;if(!O.select)return O.name}return O}}).filter(Boolean)}else R.select=A.filter(D=>D.read&&!wn[D.attribute_name]).map(D=>D.attribute_name);return R}else return!0}}allowUpdate(p,R){let w=Va(p);if(w?.update){let A=w.attribute_permissions;if(A?.length>0){let y=Ow(A,"update");for(let D in R)if(!y[D])return!1;for(let D of A){let O=D.attribute_name;!D.update&&!(O in R)&&(R[O]=this.getProperty(O))}}return Ka(this[ke])}}allowCreate(p,R){if(this[ci]){let w=Va(p);if(w?.insert){let A=w.attribute_permissions;if(A?.length>0){let y=Ow(A,"insert");for(let D in R)if(!y[D])return!1;return Ka(this[ke])}else return Ka(this[ke])}}else return this.allowUpdate(p,{})}allowDelete(p){return Va(p)?.delete&&Ka(this[ke])}update(p,R){if(!Ir(this[ke]))throw new Error("Can not update a table resource outside of a transaction");if(p===!1)return this;let A;return typeof p=="object"&&p&&(R?(Object.isFrozen(p)&&(p={...p}),this[ve]={},this[_r]=p):(A=this[_r],A&&(p=Object.assign(A,p)),this[_r]=A=p)),this._writeUpdate(this[_r],R),this}addTo(p,R){if(typeof R=="number"||typeof R=="bigint")this[xE]===RW?this.set(p,(+this.getProperty(p)||0)+R):(this[xE]||this.update(),this.set(p,new vT(R)));else throw new Error("Can not add a non-numeric value")}subtractFrom(p,R){if(typeof R=="number")return this.addTo(p,-R);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this[Fr]}invalidate(){this._writeInvalidate()}_writeInvalidate(p){let R=this[ke],w=this[ze];ji(w),Ir(this[ke]).addWrite({key:w,store:i,invalidated:!0,entry:this[Fr],before:ye.invalidate?.bind(this,R,w),beforeIntermediate:Me.invalidate?.bind(this,R,w),commit:a((y,D)=>{if(di(y,D,p?.nodeId)<=0)return;let O=null;for(let v in r)O||(O={}),O[v]=this.getProperty(v);Ge.default.trace?.(`Invalidating entry id: ${w}, timestamp: ${new Date(y).toISOString()}`),b(w,O,this[Fr],y,Os,m,{user:R?.user,residencyId:p?.residencyId,nodeId:p?.nodeId},"invalidate")},"commit")})}_writeRelocate(p){let R=this[ke],w=this[ze];ji(w),Ir(this[ke]).addWrite({key:w,store:i,invalidated:!0,entry:this[Fr],before:ye.relocate?.bind(this,R,w),beforeIntermediate:Me.relocate?.bind(this,R,w),commit:a((y,D)=>{if(di(y,D,p?.nodeId)<=0)return;let O=Ve.getResidencyRecord(p.residencyId),v=0,k=null,C=D?.value;if(O&&!O.includes(server.hostname)){for(let F in r)k||(k={}),k[F]=C(F);v=Os}else k=C;Ge.default.trace?.(`Relocating entry id: ${w}, timestamp: ${new Date(y).toISOString()}`),b(w,k,this[Fr],y,v,m,{user:R.user,residencyId:p.residencyId,nodeId:p.nodeId,expiresAt:p.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(p,R){let w={previousResidency:this.getResidencyRecord(p.residencyId),isRelocation:!0},A=this.getResidency(R.value,w),y;if(A){if(!Array.isArray(A))throw new Error("Residency must be an array, but was: "+A);if(!A.includes(server.hostname))return;y=tt(A)}let O=b(p.key,R.value,p,p.version,0,!0,{residencyId:y,expiresAt:R.expiresAt},"relocate",!1,null)}static evict(p,R,w){let A=this.Source,y;if(!((B||m)&&(!R||(y=i.getEntry(p),!y||!R)||y.version!==w))){if(B){if(i.hasLock(p,y.version))return;let D;for(let O in r)D||(D={}),D[O]=R[O];if(D)return b(p,D,y,w,ya,null,null,null,!0)}return i.ifVersion(p,w,()=>{qa(p,R,null)}),m?b(p,null,y,w,ya,null,null,null,!0):i.remove(p,w)}}lock(){throw new Error("Not yet implemented")}static operation(p,R){return p.table||=s,p.schema||=c,CW.operation(p,R)}put(p){this.update(p,!0)}patch(p){this.update(p,!1)}_writeUpdate(p,R,w){let A=this[ke],y=Ir(A),D=this[ze];ji(D);let O=this[Fr];this[xE]=R?RW:QSe;let v={key:D,store:i,entry:O,nodeName:A?.nodeName,validate:a(k=>{p||(p=this[_r]),R||p&&MT(this[_r]===p?this:p)?A?.source||(y.checkOverloaded(),this.validate(p,!R),V&&(p[V.name]=V.type==="Date"?new Date(k):V.type==="String"?new Date(k).toISOString():k),R&&(t&&p[t]!==D&&(p[t]=D),Y&&(O?.value?p[Y.name]=O?.value[Y.name]:p[Y.name]=Y.type==="Date"?new Date(k):Y.type==="String"?new Date(k).toISOString():k),p=ml(p))):y.removeWrite(v)},"validate"),before:R?ye.put?()=>ye.put(A,D,p):null:ye.patch?()=>ye.patch(A,D,p):ye.put?()=>ye.put(A,D,ml(this)):null,beforeIntermediate:R?Me.put?()=>Me.put(A,D,p):null:Me.patch?()=>Me.patch(A,D,p):Me.put?()=>Me.put(A,D,ml(this)):null,commit:a((k,C,F)=>{if(F){if(A&&C?.version>(A.lastModified||0)&&(A.lastModified=C.version),this[Fr]=C,C?.value?.[ve])throw new Error("Can not assign a record to a record, check for circular references");R||(this[ve]=C?.value??null)}this[_r]=void 0,this[kE]=k;let x=C?.value,q=p;this[xE]=0;let ee=di(k,C,w?.nodeId),G;if(ee<=0)if(m){let K=C.localTime,Te=C.version;Ge.default.trace?.("Applying CRDT update to record with id: ",D,"applying later update:",Te);let Be=[];for(;K>k||Te>=k&&K>0;){let Ie=l.get(K);if(!Ie)break;let ce=Ht(Ie);if(Te=ce.version,Te>=k){if(Te===k){if(ee=di(k,{version:Te,localTime:K},w?.nodeId),ee===0)return;if(ee>0)continue}if(ce.type==="patch")Be.push(ce),G=p;else if(ce.type==="put"||ce.type==="delete")return}K=ce.previousLocalTime}Be.sort((Ie,ce)=>Ie.version-ce.version);for(let Ie of Be){let ce=Ie.getValue(i);if(q=PT(q,ce,R),Ge.default.debug?.("Rebuilding update with future patch:",q),!q)return}}else{if(R)return;q=PT(q,x,R),Ge.default.debug?.("Rebuilding update without audit:",q)}let be;if(R?be=q:(this[ve]=x,be=ml(this,q)),this[ve]=be,be?.[ve])throw new Error("Can not assign a record to a record, check for circular references");let Ee;if(w?.residencyId!=null)Ee=w.residencyId;else{O?.residencyId&&(A.previousResidency=Ve.getResidencyRecord(O.residencyId));let K=Ve.getResidency(be,A);if(K){if(!Array.isArray(K))throw new Error("Residency must be an array, got: "+K);K.includes(server.hostname)||K.push(server.hostname)}Ee=tt(K)}R||(G=p);let Re=A?.expiresAt??(h?h+Date.now():-1);Ge.default.trace?.(`Saving record with id: ${D}, timestamp: ${new Date(k).toISOString()}${Re?", expires at: "+new Date(Re).toISOString():""}${C?", replaces entry from: "+new Date(C.version).toISOString():", new entry"}`,be),qa(D,x,be);let re=R?"put":"patch";b(D,be,C,k,0,m,{user:A?.user,residencyId:Ee,expiresAt:Re,nodeId:w?.nodeId,originatingOperation:A?.originatingOperation},re,!1,G),A.expiresAt&&ko()},"commit")};y.addWrite(v)}async delete(p){if(typeof p=="string")return this.deleteProperty(p);if(this[ci]){for await(let R of this.search(p))(await Ve.getResource(R[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(p);return}return this[ve]?this._writeDelete(p):!1}_writeDelete(p){let R=Ir(this[ke]),w=this[ze];ji(w);let A=this[ke];return R.addWrite({key:w,store:i,resource:this,nodeName:A?.nodeName,before:ye.delete?.bind(this,A,w),beforeIntermediate:Me.delete?.bind(this,A,w),commit:a((y,D,O)=>{let v=D?.value;O&&(A&&D?.version>(A.lastModified||0)&&(A.lastModified=D.version),qT(this,D)),!(di(y,D,p?.nodeId)<=0)&&(qa(this[ze],v),Ge.default.trace?.(`Deleting record with id: ${w}, txn timestamp: ${new Date(y).toISOString()}`),m||g?(b(w,null,this[Fr],y,0,m,{user:A?.user,nodeId:p?.nodeId},"delete"),m||ko()):i.remove(this[ze]))},"commit")}),!0}search(p){let R=this[ke],w=Ir(R);if(!p)throw new Error("No query provided");let A=p.conditions;A?A.length===void 0&&(A=A[Symbol.iterator]?Array.from(A):[A]):A=Array.isArray(p)?p:p[Symbol.iterator]?Array.from(p):[],this[ze]&&(A=[{attribute:null,comparator:Array.isArray(this[ze])?"prefix":"starts_with",value:this[ze]}].concat(A));let y,D={};function O(K,Te){let Be;switch(Te){case"and":case void 0:if(K.length<1)throw new Error('An "and" operator requires at least one condition');Be=!0;break;case"or":if(K.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+Te)}for(let Ie of K){if(Ie.conditions){Ie.conditions=O(Ie.conditions,Ie.operator);continue}let ce=Ie[0]??Ie.attribute,Ye=ce==null?H:vi(S,ce);if(Ye)(Ye.type||tN[Ie.comparator])&&(Ie[1]===void 0?Ie.value=k(Ie.value,Ye):Ie[1]=k(Ie[1],Ye));else if(ce!=null)throw(0,Nr.handleHDBError)(new Error,`${ce} is not a defined attribute`,404);if(Ie.chainedConditions)if(Ie.chainedConditions.length===1&&(!Ie.operator||Ie.operator=="and")){let rt=Ie.chainedConditions[0],Ze,st;if(rt.comparator==="gt"||rt.comparator==="greater_than"||rt.comparator==="ge"||rt.comparator==="greater_than_equal"?(Ze=Ie,st=rt):(Ze=rt,st=Ie),Ze.comparator!=="lt"&&Ze.comparator!=="less_than"&&Ze.comparator!=="le"&&Ze.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let Kt=st.comparator==="ge"||st.comparator==="greater_than_equal",Fo=Ze.comparator==="le"||Ze.comparator==="less_than_equal";Ie.comparator=(Kt?"ge":"gt")+(Fo?"le":"lt"),Ie.value=[st.value,Ze.value]}else throw new Error("Multiple chained conditions are not currently supported")}return K}a(O,"prepareConditions");function v(K,Te){if(p.enforceExecutionOrder)return K;for(let Be of K)Be.conditions&&(Be.conditions=v(Be.conditions,Be.operator));return K.length>1&&Te!=="or"?(0,IW.sortBy)(K,lS(Ve)):K}a(v,"orderConditions");function k(K,Te){return Array.isArray(K)?K.map(Be=>GT(Be,Te)):GT(K,Te)}a(k,"coerceTypedValues");let C=p.operator;(A.length>0||C)&&(A=O(A,C));let F=typeof p.sort=="object"&&p.sort,x;if(F&&C!=="or"){let K=F.attribute;if(K==null)throw new Nr.ClientError("Sort requires an attribute");if(y=A.find(Te=>Qu(Te.attribute)===Qu(K)),!y){let Te=vi(S,K);if(!Te)throw(0,Nr.handleHDBError)(new Error,`${Array.isArray(K)?K.join("."):K} is not a defined attribute`,404);if(Te.indexed)y={attribute:K,comparator:"sort"},A.push(y);else if(A.length===0&&!p.allowFullScan)throw(0,Nr.handleHDBError)(new Error,`${Array.isArray(K)?K.join("."):K} is not indexed and not combined with any other conditions`,404)}y&&(y.descending=!!F.descending)}A=v(A,C),F&&(y&&A[0]===y?F.next&&(x={dbOrderedAttribute:F.attribute,attribute:F.next.attribute,descending:F.next.descending,next:F.next.next}):(y&&A.splice(A.indexOf(y),1),x=F));let q=p.select;if(A.length===0&&(A=[{attribute:t,comparator:"greater_than",value:!0}]),p.explain)return{conditions:A,operator:C,postOrdering:x,selectApplied:!!q};let ee=w.useReadTxn(),G=rN(A,C,Ve,ee,p,R,(K,Te)=>Pd(K,q,R,ee,Te),D),be=p.ensureLoaded!==!1;x||(G=re(G));let Ee=Ve.transformEntryForSelect(q,R,ee,D,be,!0),Re=Ve.transformToOrderedSelect(G,q,x,ee,R,Ee);function re(K){return p.offset||p.limit!==void 0?K.slice(p.offset,p.limit!==void 0?(p.offset||0)+p.limit:void 0):K}return a(re,"applyOffset"),x&&(Re=re(Re)),Re.onDone=()=>{Re.onDone=null,w.doneReadTxn()},Re.selectApplied=!0,Re.getColumns=()=>{if(q){let K=[];for(let Te of q)Te==="*"?K.push(...S.map(Be=>Be.name)):K.push(Te.name||Te);return K}return S.filter(K=>!K.computed&&!K.relationship).map(K=>K.name)},Re}static transformToOrderedSelect(p,R,w,A,y,D){let O=new vs;if(w){p=Pd(p,R,A,y,null);let v;O.iterate=function(){let C,F=p[Symbol.asyncIterator]?p[Symbol.asyncIterator]():p[Symbol.iterator](),x,q=w.dbOrderedAttribute,ee,G,be=!0;function Ee(re){let K=re.next&&Ee(re.next),Te=re.descending;return(Be,Ie)=>{let ce=yl(Be,re.attribute,A),Ye=yl(Ie,re.attribute,A),rt=Te?(0,gl.compareKeys)(Ye,ce):(0,gl.compareKeys)(ce,Ye);return rt===0?K?.(Be,Ie)||0:rt}}a(Ee,"createComparator");let Re=Ee(w);return{async next(){let re;if(C)if(re=C.next(),re.done){if(x)return O.onDone&&O.onDone(),re}else return{value:await D.call(this,re.value)};v=[],ee&&v.push(ee);do if(re=await F.next(),re.done){if(x=!0,v.length)break;return O.onDone&&O.onDone(),re}else{let K=re.value;if(K?.then&&(K=await K),q){let Te=yl(K,q,A);if(be)be=!1,G=Te;else if(Te!==G){G=Te,ee=K;break}}v.push(K)}while(!0);return w.isGrouped,v.sort(Re),C=v[Symbol.iterator](),re=C.next(),re.done?(O.onDone&&O.onDone(),re):{value:await D.call(this,re.value)}},return(){O.onDone&&O.onDone(),F.return()},throw(){O.onDone&&O.onDone(),F.throw()}}};let k=a(C=>{if(typeof R=="object"&&Array.isArray(C.attribute))for(let F=0;F<R.length;F++){let x=R[F],q;if(x.name===C.attribute[0]){for(q=x.sort||(x.sort={});q.next;)q=q.next;q.attribute=C.attribute.slice(1),q.descending=C.descending}else x===C.attribute[0]&&(R[F]=q={name:x,sort:{attribute:C.attribute.slice(1),descending:C.descending}})}C.next&&k(C.next)},"applySortingOnSelect");k(w)}else O.iterate=(p[Symbol.asyncIterator]||p[Symbol.iterator]).bind(p),O=O.map(function(v){try{let k=D.call(this,v);return typeof k?.catch=="function"?k.catch(C=>{throw C.partialObject={[t]:v.key},C}):k}catch(k){throw k.partialObject={[t]:v.key},k}});return O}static transformEntryForSelect(p,R,w,A,y,D){if(p&&(p===t||p?.length===1&&p[0]===t&&Array.isArray(p))){let C=a(F=>(R?.transaction?.stale&&(R.transaction.stale=!1),F?.key??F),"transform");return p===t?C:p.asArray?F=>[C(F)]:F=>({[t]:C(F)})}let O;y&&B&&!(typeof p=="string"?[p]:p)?.every(C=>{let F;return typeof C=="object"?F=C.name:F=C,r[F]||F===t})&&(O=!0);let v,k=a(function(C){let F;if(R?.transaction?.stale&&(R.transaction.stale=!1),C!=null){if(F=C.value||C.deref?.()?.value,!F&&(C.key===void 0||C.deref)||C.metadataFlags&Os){if(C.metadataFlags&Os&&R.replicateFrom===!1&&D&&C.residencyId)return Ba.SKIP;if(C=$a(C.key??C,R,{transaction:w,lazy:p?.length<4,ensureLoaded:y},this?.isSync,x=>x),C?.then)return C.then(k.bind(this));F=C?.value}if(O&&C?.metadataFlags&(Os|ya)||C?.expiresAt!=null&&C?.expiresAt<Date.now()){if(R.onlyIfCached&&R.noCacheStore)return{[t]:C.key,message:"This entry has expired"};let x=Dd(C.key??C,C,R);if(x?.then)return x.then(k)}}if(F==null)return D?Ba.SKIP:F;if(p&&!(p[0]==="*"&&p.length===1)){let x,q=a((G,be)=>{let Ee;typeof G=="object"?Ee=G.name:Ee=G;let Re=wn?.[Ee],re;if(Re){let K=A?.[Ee];if(K)if(K.hasMappings){let Be=Re.from?F[Re.from]:Qu(C.key);re=K.get(Be),re||(re=[])}else re=K.fromRecord?.(F);else re=Re(F,R,C);let Te=a(Be=>{if(Be&&typeof Be=="object"){let Ie=Re.definition?.tableClass||Ve;v||(v={});let ce=v[Ee]||(v[Ee]=Ie.transformEntryForSelect(Ee===G?null:G.select||(Array.isArray(G)?G:null),R,w,K,y));if(Array.isArray(Be)){let Ye=[],rt=Ie.transformToOrderedSelect(Be,G.select,typeof G.sort=="object"&&G.sort,R,w,ce)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),Ze=a(Kt=>{for(;!Kt.done;){if(Kt?.then)return Kt.then(Ze);Ye.push(Kt.value),Kt=rt.next()}be(Ye,Ee)},"nextValue"),st=Ze(rt.next());st&&(x||(x=[]),x.push(st));return}else if(Be=ce.call(this,Be),Be?.then){x||(x=[]),x.push(Be.then(Ye=>be(Ye,Ee)));return}}be(Be,Ee)},"handleResolvedValue");re?.then?(x||(x=[]),x.push(re.then(Te))):Te(re);return}else re=F[Ee],re&&typeof re=="object"&&Ee!==G&&(re=Ve.transformEntryForSelect(G.select||G,R,w,null)({value:re}));be(re,Ee)},"selectAttribute"),ee;if(typeof p=="string")q(p,G=>{ee=G});else if(Array.isArray(p))if(p.asArray)ee=[],p.forEach((G,be)=>{G==="*"?p[be]=F:q(G,Ee=>ee[be]=Ee)});else{ee={};let G=p.forceNulls;for(let be of p)if(be==="*")for(let Ee in F)ee[Ee]=F[Ee];else q(be,(Ee,Re)=>{Ee===void 0&&G&&(Ee=null),ee[Re]=Ee})}else throw new Nr.ClientError("Invalid select"+p);return x?Promise.all(x).then(()=>ee):ee}return F},"transform");return k}async subscribe(p){if(!l)throw new Error("Can not subscribe to a table without an audit log");m||Et({table:s,database:c,schemaDefined:u,attributes:S,audit:!0}),p||(p={});let R=!p.rawEvents,w=[],A=this,y=py(Ve,this[ze]??null,function(O,v,k,C){try{let F=v.getValue?.(i,R),x=v.type;if(!F&&x==="patch"&&R){let ee=i.getEntry(O);ee?.version===v.version?F=ee.value:F=v.getValue?.(i,!0,k),x="put"}let q={id:O,localTime:k,value:F,version:v.version,type:x,beginTxn:C};w?w.push(q):this.send(q)}catch(F){Ge.default.error?.(F)}},p.startTime||0,p),D=(async()=>{this[ci]&&(y.includeDescendants=!0,p.onlyChildren&&(y.onlyChildren=!0)),p.supportsTransactions&&(y.supportsTransactions=!0);let O=this[ze],v=p.previousCount;v>1e3&&(v=1e3);let k=p.startTime;if(this[ci]){if(k){if(v)throw new Nr.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:C,value:F}of l.getRange({start:k,exclusiveStart:!0,snapshot:!1})){let x=Ht(F);if(x.tableId!==n)continue;let q=x.recordId;if(O==null||OW(O,q)){let ee=x.getValue(i,R,C);if(y.send({id:q,localTime:C,value:ee,version:x.version,type:x.type}),y.queue?.length>yW&&await y.waitForDrain()===!1)return}y.startTime=C}}else if(v){let C=[];for(let{key:F,value:x}of l.getRange({start:"z",end:!1,reverse:!0}))try{let q=Ht(x);if(q.tableId!==n)continue;let ee=q.recordId;if(O==null||OW(O,ee)){let G=q.getValue(i,R,F);if(C.push({id:ee,localTime:F,value:G,version:q.version,type:q.type}),--v<=0)break}}catch(q){Ge.default.error("Error getting history entry",F,q)}for(let F=C.length;F>0;)y.send(C[--F]);C[0]&&(y.startTime=C[0].localTime)}else if(!p.omitCurrent){for(let{key:C,value:F,version:x,localTime:q}of i.getRange({start:O??!1,end:O==null?void 0:[O,gl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(F&&(y.send({id:C,localTime:q,value:F,version:x,type:"put"}),y.queue?.length>yW&&await y.waitForDrain()===!1))return}}else{v&&!k&&(k=0);let C=this[Fr]?.localTime;if(C===Qg&&(i.cache?.delete(O),this[Fr]=i.getEntry(O),Ge.default.trace?.("re-retrieved record",C,this[Fr]?.localTime),C=this[Fr]?.localTime),Ge.default.trace?.("Subscription from",k,"from",O,C),k<C){let F=[],x=C;do{let q=l.get(x);if(q){p.omitCurrent=!0;let ee=Ht(q),G=ee.getValue(i,R,x);R&&(ee.type="put"),F.push({id:O,value:G,localTime:x,...ee}),x=ee.previousLocalTime}else break;v&&v--}while(x>k&&v!==0);for(let q=F.length;q>0;)y.send(F[--q]);y.startTime=C}!p.omitCurrent&&this.doesExist()&&y.send({id:O,localTime:C,value:this[ve],version:this[kE],type:"put"})}for(let C of w)y.send(C);w=null})();return p.listener&&y.on("data",p.listener),y}static subscribeOnThisThread(p,R){return p===0||R?.crossThreads===!1}doesExist(){return!!(this[ve]||this[xE])}publish(p,R){this._writePublish(p,R)}_writePublish(p,R){let w=Ir(this[ke]),A=this[ze]||null;A!=null&&ji(A);let y=this[ke];w.addWrite({key:A,store:i,entry:this[Fr],nodeName:y?.nodeName,validate:a(()=>{y?.source||(w.checkOverloaded(),this.validate(p))},"validate"),before:ye.publish?.bind(this,y,A,p),beforeIntermediate:Me.publish?.bind(this,y,A,p),commit:a((D,O,v)=>{O===void 0&&g&&!m&&ko(),Ge.default.trace?.(`Publishing message to id: ${A}, timestamp: ${new Date(D).toISOString()}`),b(A,O?.value??null,O,O?.version||D,0,!0,{user:y?.user,residencyId:R?.residencyId,expiresAt:y?.expiresAt,nodeId:R?.nodeId},"message",!1,p)},"commit")})}validate(p,R){let w,A=a((y,D,O)=>{if(D.type&&y!=null)if(R&&y.__op__&&(y=y.value),D.properties){typeof y!="object"&&(w||(w=[])).push(`Value ${li(y)} in property ${O} must be an object${D.type?" ("+D.type+")":""}`);let v=D.properties;for(let k=0,C=v.length;k<C;k++){let F=v[k],x=A(y[F.name],F,O+"."+F.name);x&&(y[F.name]=x)}if(D.sealed&&y!=null&&typeof y=="object")for(let k in y)v.find(C=>C.name===k)||(w||(w=[])).push(`Property ${k} is not allowed within object in property ${O}`)}else switch(D.type){case"Int":(typeof y!="number"||y>>0!==y)&&(w||(w=[])).push(`Value ${li(y)} in property ${O} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof y!="number"||!(Math.floor(y)===y&&Math.abs(y)<=9007199254740992))&&(w||(w=[])).push(`Value ${li(y)} in property ${O} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof y!="number"&&(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a number`);break;case"ID":typeof y=="string"||y?.length>0&&y.every?.(v=>typeof v=="string")||(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a string, or an array of strings`);break;case"String":typeof y!="string"&&(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a string`);break;case"Boolean":typeof y!="boolean"&&(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a boolean`);break;case"Date":if(!(y instanceof Date)){if(typeof y=="string"||typeof y=="number")return new Date(y);(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a Date`)}break;case"BigInt":if(typeof y!="bigint"){if(typeof y=="string"||typeof y=="number")return BigInt(y);(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a bigint`)}break;case"Bytes":y instanceof Uint8Array||(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a Buffer or Uint8Array`);break;case"array":if(Array.isArray(y)){if(D.elements)for(let v=0,k=y.length;v<k;v++){let C=y[v],F=A(C,D.elements,O+"[*]");F&&(y[v]=F)}}else(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a Buffer or Uint8Array`);break}D.nullable===!1&&y==null&&(w||(w=[])).push(`Property ${O} is required (and not does not allow null values)`)},"validateValue");for(let y=0,D=S.length;y<D;y++){let O=S[y];if(!(O.relationship||O.computed)&&(!R||O.name in p)){let v=A(p[O.name],O,O.name);v&&(p[O.name]=v)}}if(_)for(let y in p)S.find(D=>D.name===y)||(w||(w=[])).push(`Property ${y} is not allowed`);if(w)throw new Nr.ClientError(w.join(". "))}getUpdatedTime(){return this[kE]}wasLoadedFromSource(){return B?!!this[bw]:void 0}static async addAttributes(p){let R=S.slice(0);for(let w of p){if(!w.name)throw new Nr.ClientError("Attribute name is required");if(w.name.match(/[`/]/))throw new Nr.ClientError("Attribute names cannot include backticks or forward slashes");(0,wW.validateAttribute)(w.name),R.push(w)}return Et({table:s,database:c,schemaDefined:u,attributes:R}),Ve.indexingOperation}static async removeAttributes(p){let R=S.filter(w=>!p.includes(w.name));return Et({table:s,database:c,schemaDefined:u,attributes:R}),Ve.indexingOperation}static getSize(p){let R=i.getStats();return(R.treeBranchPageCount+R.treeLeafPageCount+R.overflowPages)*R.pageSize}static getRecordCount(p){let R=i.getStats().entryCount,w=1e3/2,A=performance.now(),y=Math.floor(R/2),D=p?.exactCount,O=0,v=0,k;for(let{value:C}of i.getRange({start:!0,lazy:!0}))if(C!=null&&O++,v++,!D&&v<y&&performance.now()-A>w){k=v;break}if(k){let C=O;O=0;for(let{value:re}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:k}))re!=null&&O++;let F=k*2,x=(O+C)/F,q=Math.pow((O-C+1)/k/2,2)+x*(1-x)/F,ee=Math.max(Math.sqrt(q)*R,1),G=Math.round(x*R),be=Math.max(G-1.96*ee,O+C),Ee=Math.min(G+1.96*ee,R),Re=Math.pow(10,Math.round(Math.log10(ee)));return Re>G&&(Re=Re/10),O=Math.round(G/Re)*Re,{recordCount:O,estimatedRange:[Math.round(be),Math.round(Ee)]}}return{recordCount:O}}static updatedAttributes(){wn=this.propertyResolvers={$id:a((p,R,w)=>({value:w.key}),"$id"),$updatedtime:a((p,R,w)=>w.version,"$updatedtime"),$record:a((p,R,w)=>w?{value:p}:p,"$record")};for(let p of this.attributes){p.resolve=null;let R=p.relationship,w=p.computed;if(R)if(p.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),w&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),Cd=!0,R.to)p.elements?.definition?(wn[p.name]=p.resolve=(A,y,D)=>{let O=A[R.from?R.from:t],v=p.elements.definition.tableClass;return D?zu({attribute:R.to,value:O},Ir(y).getReadTxn(),!1,v,!1).asArray:v.search([{attribute:R.to,value:O}],y).asArray},p.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},p.resolve.definition=p.elements.definition,R.from&&(p.resolve.from=R.from)):console.error(`The one-to-many/many-to-many relationship property "${p.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(R.from){let A=p.definition||p.elements?.definition;A?(wn[p.name]=p.resolve=(y,D,O)=>{let v=y[R.from];if(v!==void 0){if(p.elements){let k,C=v?.map(F=>{let x=O?A.tableClass.primaryStore.getEntry(F,{transaction:Ir(D).getReadTxn()}):A.tableClass.get(F,D);return x?.then&&(k=!0),x});return R.filterMissing?k?Promise.all(C).then(F=>F.filter(NW)):C.filter(NW):k?Promise.all(C):C}return O?A.tableClass.primaryStore.getEntry(v,{transaction:Ir(D).getReadTxn()}):A.tableClass.get(v,D)}},p.set=(y,D)=>{if(Array.isArray(D)){let O=D.map(v=>v[ze]||v[A.tableClass.primaryKey]);y[R.from]=O}else{let O=D[ze]||D[A.tableClass.primaryKey];y[R.from]=O}},p.resolve.definition=p.definition||p.elements?.definition,p.resolve.from=R.from):console.error(`The relationship property "${p.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${p.name}" in table "${s}" must use either "from" or "to" arguments`);else w&&(typeof w.from=="function"&&this.setComputedAttribute(p.name,w.from),wn[p.name]=p.resolve=(A,y,D)=>{let O=typeof w.from=="string"?A[w.from]:A,v=this.userResolvers[p.name];if(v)return v(O,y,D);Ge.default.warn(`Computed attribute "${p.name}" does not have a function assigned to it. Please use setComputedAttribute('${p.name}', resolver) to assign a resolver function.`),this.userResolvers[p.name]=()=>{}})}BT(this,this)}static setComputedAttribute(p,R){let w=vi(S,p);if(!w){console.error(`The attribute "${p}" does not exist in the table "${s}"`);return}if(!w.computed){console.error(`The attribute "${p}" is not defined as computed in the table "${s}"`);return}this.userResolvers[p]=R}static async deleteHistory(p=0,R=!1){let w;for(let{key:A,value:y}of l.getRange({start:0,end:p}))await Ad(),Ht(y).tableId===n&&(w=wT(l,A,y));if(R)for(let{key:A,value:y,localTime:D}of i.getRange({start:0,versions:!0}))await Ad(),y===null&&D<p&&(w=i.remove(A));await w}static async*getHistory(p=0,R=1/0){for(let{key:w,value:A}of l.getRange({start:p||1,end:R})){await Ad();let y=Ht(A);y.tableId===n&&(yield{id:y.recordId,localTime:w,version:y.version,type:y.type,value:y.getValue(i,!0,w),user:y.user,operation:y.originatingOperation})}}static async getHistoryOfRecord(p){let R=[];if(p==null)throw new Error("An id is required");let w=i.getEntry(p);if(!w)return R;let A=w.localTime;if(!A)throw new Error("The entry does not have a local audit time");let y=0;do{await Ad();let D=l.get(A);if(D){let O=Ht(D);R.push({id:O.recordId,localTime:A,version:O.version,type:O.type,value:O.getValue(i,!0,A),user:O.user}),A=O.previousLocalTime}else break}while(y<1e3&&A);return R.reverse()}static cleanup(){Q?.remove()}}Ve.updatedAttributes();let ss=Ve.prototype;return ss[zSe]=!0,h&&Ve.setTTLExpiration(h/1e3),ne&&Se(),Ve;function qa(U,p,R){let w;for(let A in r){let y=r[A],D=y.isIndexing,O=wn[A],v=R&&(O?O(R):R[A]),k=p&&(O?O(p):p[A]);if(v===k&&!D)continue;w=!0;let C=y.indexNulls,F=(0,FE.getIndexedValues)(v,C),x=(0,FE.getIndexedValues)(k,C);if(x?.length>0){let q=new Set(x);if(F=F?F.filter(ee=>{if(q.has(ee))q.delete(ee);else return!0}):[],x=Array.from(q),(x.length>0||F.length>0)&&gW){let ee=x.concat(F).map(G=>({key:G,value:U}));y.prefetch(ee,bW)}for(let ee=0,G=x.length;ee<G;ee++)y.remove(x[ee],U)}else F?.length>0&&gW&&y.prefetch(F.map(q=>({key:q,value:U})),bW);if(F)for(let q=0,ee=F.length;q<ee;q++)y.put(F[q],U)}return w}a(qa,"updateIndices");function ji(U){switch(typeof U){case"number":return!0;case"string":if(U.length<659)return!0;if(U.length>AW)throw new Error("Primary key size is too large: "+U.length);break;case"object":if(U===null)throw new Error("Invalid primary key of null");break;case"bigint":if(U<2n**64n&&U>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof U)}if((0,gl.writeKey)(U,JSe,0)>AW)throw new Error("Primary key size is too large: "+U.length);return!0}a(ji,"checkValidId");function $a(U,p,R,w,A){if(Ve.getResidencyById&&R.ensureLoaded&&p?.replicateFrom!==!1){let D=Ve.getResidencyById(U);if(D&&!D.includes(server.hostname)&&I)return I({key:U,residency:D}).then(A)}let y=a(()=>{if(p?.transaction?.stale&&(p.transaction.stale=!1),R.transaction?.isDone)return A(null,U);let D=i.getEntry(U,R);return D?.residencyId&&D.metadataFlags&Os&&I&&R.ensureLoaded&&p?.replicateFrom!==!1?I(D).then(O=>A(O,U)):(D&&p&&(D?.version>(p.lastModified||0)&&(p.lastModified=D.version),D?.localTime&&!p.lastRefreshed&&(p.lastRefreshed=D.localTime)),A(D,U))},"whenPrefetched");return w?y():ae>0?(ae--,y()):new Promise((D,O)=>{ae===0?(ae--,i.prefetch([U],()=>{v(),k()})):(de.push(U),j.push(k),de.length>zE&&(ae--,v()));function v(){if(de.length>0){let C=j;i.prefetch(de,()=>{ae===-1?v():ae++;for(let F of C)F()}),de=[],j=[],Ae>2&&Ae--}else ae=Ae,Ae<Bs&&Ae++}a(v,"prefetch");function k(){try{D(y())}catch(C){O(C)}}a(k,"load")})}a($a,"loadLocalRecord");function Va(U){if(!U?.role)return;let p=U.role.permission;if(p.super_user)return XSe;let R=p[c],w,A=R?.tables;if(A)return A[s];if(c==="data"&&(w=p[s])&&!w.tables)return w}a(Va,"getTablePermissions");function Dd(U,p,R,w){if(B){let A=!1;if(R.noCache?A=!0:(p?(!p.value||p.metadataFlags&(Os|ya)||p.expiresAt!=null&&p.expiresAt<Date.now())&&(A=!0):A=!0,qn(!A,"cache-hit",s)),A){let y=Ld(U,p,R).then(D=>(D?.value?.[ve]&&Ge.default.error?.("Can not assign a record with a record property"),R&&(D?.version>(R.lastModified||0)&&(R.lastModified=D.version),R.lastRefreshed=Date.now()),D));if(R?.onlyIfCached||p?.value&&w?.allowStaleWhileRevalidate?.(p,U)){if(y.catch(D=>Ge.default.warn?.(D)),R?.onlyIfCached&&!w.doesExist())throw new Nr.ServerError("Entry is not cached",504);return}else return y}}else if(p?.value&&p.expiresAt!=null&&p.expiresAt<Date.now())return Ve.evict(p.key,p.value,p.version),p.value=null,{then(A){return A(p)}}}a(Dd,"ensureLoadedFromSource");function Ir(U){let p=U?.transaction;if(p){if(!p.lmdbDb)return p.lmdbDb=i,p;do{if(p.lmdbDb?.path===i.path)return p;let R=p.next;if(!R)return p=p.next=new pc,p.lmdbDb=i,p;p=R}while(!0)}else return new cp}a(Ir,"txnForContext");function yl(U,p,R){if(!U)return;let w=U.value||i.getEntry(U.key)?.value;if(typeof p=="object"){let y=wn,D=w;for(let O=0,v=p.length;O<v;O++){let k=p[O],C=y?.[k];D=C&&D?C(D,R,!0)?.value:D?.[k],y=C?.definition?.tableClass?.propertyResolvers}return D}let A=wn[p];return A?A(w,R):w[p]}a(yl,"getAttributeValue");function Pd(U,p,R,w,A){let y=A?.length,D={transaction:w,lazy:y>0||typeof p=="string"||p?.length<4,alwaysPrefetch:!0},O;function v(k,C){let F=k?.value;if(!F)return Ba.SKIP;for(let x=0;x<y;x++)if(!O?.includes(x)&&!A[x](F,k))return Ba.SKIP;return C!==void 0&&(k.key=C),k}if(a(v,"processEntry"),y>0||!U.hasEntries){let k=U.map(C=>{if(O=null,typeof C=="object"&&C?.key!==void 0)return y>0?v(C):C;if(C==null)return Ba.SKIP;for(let F=0;F<y;F++){let q=A[F].idFilter;if(q){if(!q(C))return Ba.SKIP;O||(O=[]),O.push(F)}}return $a(C,R,D,!1,v)});return Array.isArray(U)&&(k=k.filter(C=>C!==Ba.SKIP)),k.hasEntries=!0,k}return U}a(Pd,"transformToEntries");function di(U,p,R=server.replication?.getThisNodeId(l)){if(U<=p?.version){if(p?.version===U&&R!==void 0){let w=server.replication?.exportIdMapping(l),A=p.localTime,y=A&&l.get(A);if(y){let D,O,v=Ht(y);for(let k in w)w[k]===R&&(D=k),w[k]===v.nodeId&&(O=k);if(D>O)return 1;if(D===O)return 0}}return-1}return 1}a(di,"precedesExistingVersion");async function Ld(U,p,R){let w=p?.metadataFlags,A=p?.version,y,D;if(!i.attemptLock(U,A,()=>{clearTimeout(D);let C=i.getEntry(U);!C||!C.value||C.metadataFlags&(Os|ya)?y(Ld(U,i.getEntry(U),R)):y(C)}))return new Promise(C=>{y=C,D=setTimeout(()=>{i.unlock(U,A)},jSe)});let O=p?.value,v={requestContext:R,replacingRecord:O,replacingEntry:p,replacingVersion:A,noCacheStore:!1,source:null,resourceCache:R?.resourceCache},k=R?.responseHeaders;return new Promise((C,F)=>{let x;Nw(Dt(v,async q=>{let ee=performance.now(),G,be,Ee;try{for(let Te of Ve.sources)if(Te.get&&(!Te.get.reliesOnPrototype||Te.prototype.get)){if(Te.available?.(p)===!1)continue;if(v.source=Te,G=await Te.get(U,v),G)break}Ee=w&Os;let re=v.lastModified||Ee&&A;be=Ee||re>A||!O,re||(re=(0,FE.getNextMonotonicTime)());let K=performance.now()-ee;if(pr(K,"cache-resolution",s,null,"success"),k&&vm(k,"Server-Timing",`cache-resolve;dur=${K.toFixed(2)}`,!0),q.timestamp=re,h&&v.expiresAt==null&&(v.expiresAt=Date.now()+h),G){if(typeof G!="object")throw new Error("Only objects can be cached and stored in tables");if(G.status>0&&G.headers)if(G.status>=300)if(G.status===304)G=O,re=A;else throw new Nr.ServerError(G.body||"Error from source",G.status);else G=G.body;typeof G.toJSON=="function"&&(G=G.toJSON()),t&&G[t]!==U&&(G[t]=U)}x=!0,C({key:U,version:re,value:G})}catch(re){re.message+=` while resolving record ${U} for ${s}`,O&&((re.code==="ECONNRESET"||re.code==="ECONNREFUSED"||re.code==="EAI_AGAIN")&&!R?.mustRevalidate||R?.staleIfError&&(re.statusCode===500||re.statusCode===502||re.statusCode===503||re.statusCode===504))?(C({key:U,version:A,value:O}),Ge.default.trace?.(re.message,"(returned stale record)")):F(re);let K=performance.now()-ee;pr(K,"cache-resolution",s,null,"fail"),k&&vm(k,"Server-Timing",`cache-resolve;dur=${K.toFixed(2)}`,!0),v.transaction.abort();return}if(R?.noCacheStore||v.noCacheStore){v.transaction.abort();return}Ir(v).addWrite({key:U,store:i,entry:p,nodeName:"source",commit:a((re,K)=>{if(K?.version!==A)return;let Te=qa(U,O,G);G?(Me.put?.(v,U,G),Ge.default.trace?.(`Writing resolved record from source with id: ${U}, timestamp: ${new Date(re).toISOString()}`),b(U,G,K,re,0,m&&be||null,{user:v?.user,expiresAt:v.expiresAt},"put",!!Ee)):K&&(Me.delete?.(v,U),Ge.default.trace?.(`Deleting resolved record from source with id: ${U}, timestamp: ${new Date(re).toISOString()}`),m||g?b(U,null,K,re,0,m&&be||null,{user:v?.user},"delete",!!Ee):i.remove(U,A))},"commit")})}),()=>{i.unlock(U,A)},q=>{i.unlock(U,A),x&&Ge.default.error?.("Error committing cache update",q)})})}a(Ld,"getFromSource");function Ka(U){if(!U||U.user?.role?.permission?.super_user)return!0;if(U.replicateTo)throw new Nr.ClientError("Can not specify replication parameters without super user permissions",403);if(U.replicatedConfirmation)throw new Nr.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}a(Ka,"checkContextPermissions");function ko(){if(Gr!==wd&&(wd=Gr,(0,Tl.getWorkerIndex)()===(0,Tl.getWorkerCount)()-1)){if(ka&&clearTimeout(ka),!Gr)return;let U=new Date;U.setMonth(0),U.setDate(1),U.setHours(0),U.setMinutes(0),U.setSeconds(0);let p=Math.ceil((Date.now()-U.getTime())/Gr)*Gr+U.getTime(),R=a(w=>{Ge.default.trace?.(`Scheduled next cleanup scan at ${new Date(w)}ms`),ka=setTimeout(()=>X=X.then(async()=>{if(R(Math.max(w+Gr,Date.now())),i.rootStore.status!=="open"){clearTimeout(ka);return}let A=50,y=new Array(A),D=0;Ge.default.info?.(`Starting cleanup scan for ${s}`);try{let O=0;for(let{key:v,value:k,version:C,expiresAt:F}of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let x;k===null&&!m&&C+WSe<Date.now()?x=i.remove(v,C):F!=null&&F+T<Date.now()&&(x=Ve.evict(v,k,C),O++),x&&(await y[D],y[D]=x.catch(q=>{Ge.default.error?.("Cleanup error",q)}),++D>=A&&(D=0)),await Ad()}Ge.default.info?.(`Finished cleanup scan for ${s}, evicted ${O} entries`)}catch(O){Ge.default.warn?.(`Error in cleanup scan for ${s}:`,O)}}),Math.min(w-Date.now(),2147483647)).unref()},"startNextTimer");R(p)}}a(ko,"scheduleCleanup");function ie(){Q=l?.addDeleteRemovalCallback(n,U=>{let p=i.getEntry(U);p?.value===null&&i.remove(U,p.version)})}a(ie,"addDeleteRemoval");function Se(){(0,Tl.getWorkerIndex)()===0&&setInterval(async()=>{if(!Al){Al=!0;try{let U=ne.name,p=r[U];if(!p)throw new Error(`expiresAt attribute ${ne} must be indexed`);for(let R of p.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let w of p.getValues(R)){let A=i.getEntry(w);A?.value?A.value[U]<Date.now()&&Ve.evict(w,A.value,A.version):i.ifVersion(w,A?.version,()=>p.remove(R,w))}await Ad()}}catch(U){Ge.default.error?.("Error in evicting old records",U)}finally{Al=!1}}},YSe).unref()}a(Se,"runRecordExpirationEviction");function tt(U){if(U){let p=U.join(","),R=d.get([Symbol.for("residency_by_set"),p]);return R||(d.put([Symbol.for("residency_by_set"),p],R=Math.floor(Math.random()*2147483647)),d.put([Symbol.for("residency_by_id"),R],U),R)}}a(tt,"getResidencyId")}function Ow(e,t){let r=e.attr_object||(e.attr_object={}),n=r[t];if(n)return n;n=r[t]=Object.create(null);for(let s of e)n[s.attribute_name]=s[t];return n}function bW(){}function ZSe(e){CW=e}function GT(e,t){let r=t?.type;if(e===null)return e;if(e===""&&r&&r!=="String"&&r!=="Any")return null;try{switch(r){case"Int":case"Long":if(e[0]==="$")return FT(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return FT(+e);case"Float":return e==="null"?null:FT(+e);case"BigInt":return e==="null"?null:BigInt(e);case"Boolean":return e==="true"?!0:e==="false"?!1:e;case"Date":if(isNaN(e)){if(e==="null")return null;eTe.test(e)||(e+="Z");let n=new Date(e);return FT(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,$T.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function FT(e){if(isNaN(e))throw new SyntaxError;return e}function OW(e,t){if(e==null)return!0;if(!Array.isArray(t))return e===t||t.startsWith?.(e);if(Array.isArray(e)){let r=e.length;if(e[r-1]===null&&r--,t.length>=r){for(let n=0;n<r;n++)if(t[n]!==e[n])return!1;return!0}return!1}else if(t[0]===e)return!0}function Nw(e,t,r){return e?.then?e.then(t,r):t(e)}function qT(e,t){e[Fr]=t,e[ve]=t?.value??null,e[kE]=t?.version}function NW(e){return e!=null}function li(e){try{return JSON.stringify(e)}catch{return e}}function tTe(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var Us,Ba,FE,IW,wW,yd,Nr,GE,qE,Ge,gl,Tl,$T,KSe,CW,YSe,WSe,gW,jSe,kE,zSe,Fr,xE,RW,QSe,bw,Os,ya,JSe,AW,yW,XSe,YMe,eTe,Ad,oE=Oe(()=>{Us=L(M()),Ba=require("lmdb"),FE=L(cn()),IW=require("lodash"),wW=L(Jd());Vs();lp();yd=L(se());my();Nr=L(_e()),GE=L(no()),qE=L(qs());Pe();iE();Ge=L(bc());_p();mc();gl=require("ordered-binary"),Tl=L(dt());Ji();$T=L(te());Pl();Ni();CT();Bf();KSe=new Uint8Array(9);KSe[8]=192;YSe=6e4,WSe=864e5;yd.initSync();gW=yd.get(Us.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),jSe=1e4,kE=Symbol.for("version"),zSe=Symbol.for("incremental-update"),Fr=Symbol("entry"),xE=Symbol("is-saving"),RW=1,QSe=2,bw=Symbol("loaded-from-source"),Os=1,ya=8,JSe=Buffer.allocUnsafeSlow(8192),AW=1978,yW=100,XSe={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},YMe=(0,$T.convertToMS)(yd.get(Us.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(VT,"makeTable");a(Ow,"attributesAsObject");a(bW,"noop");a(ZSe,"setServerUtilities");eTe=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(GT,"coerceType");a(FT,"rejectNaN");a(OW,"isDescendantId");Ad=a(()=>new Promise(setImmediate),"rest");a(Nw,"when");a(qT,"updateResource");a(NW,"exists");a(li,"stringify");a(tTe,"hasOtherProcesses")});var lt={};je(lt,{database:()=>Yl,databases:()=>We,dropDatabase:()=>xA,dropTableMeta:()=>oTe,getDatabases:()=>ut,getDefaultCompression:()=>Pm,getTables:()=>rTe,onRemovedDB:()=>nf,onUpdatedTable:()=>Dc,readMetaDb:()=>$E,resetDatabases:()=>vu,table:()=>Et,tables:()=>jn});function rTe(){return jT||ut(),jn||{}}function ut(){if(jT)return We;jT=!0,Nd=new Map;let e=(0,er.getHdbBasePath)()&&(0,Ut.join)((0,er.getHdbBasePath)(),yr.DATABASES_DIR_NAME),t=(0,er.get)(yr.CONFIG_PARAMS.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,er.get)(yr.CONFIG_PARAMS.STORAGE_PATH)||e&&((0,rs.existsSync)(e)?e:(0,Ut.join)((0,er.getHdbBasePath)(),yr.LEGACY_DATABASES_DIR_NAME)),!e)return;if((0,rs.existsSync)(e))for(let n of(0,rs.readdirSync)(e,{withFileTypes:!0})){let s=(0,Ut.basename)(n.name,".mdb");n.isFile()&&(0,Ut.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&$E((0,Ut.join)(e,n.name),null,s)}if((0,rs.existsSync)((0,Od.getBaseSchemaPath)())){for(let n of(0,rs.readdirSync)((0,Od.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,Ut.join)((0,Od.getBaseSchemaPath)(),n.name),i=(0,Ut.join)((0,Od.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,rs.readdirSync)(s,{withFileTypes:!0}))if(o.isFile()&&(0,Ut.extname)(o.name).toLowerCase()===".mdb"){let c=(0,Ut.join)(i,o.name);$E((0,Ut.join)(s,o.name),(0,Ut.basename)(o.name,".mdb"),n.name,c,!0)}}}if(t)for(let n in t){let s=t[n],i=s.path;if((0,rs.existsSync)(i))for(let c of(0,rs.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,Ut.extname)(c.name).toLowerCase()===".mdb"&&$E((0,Ut.join)(i,c.name),(0,Ut.basename)(c.name,".mdb"),n);let o=s.tables;if(o)for(let c in o){let l=o[c],u=(0,Ut.join)(l.path,(0,Ut.basename)(c+".mdb"));(0,rs.existsSync)(u)&&$E(u,c,n,null,!0)}}for(let n in We){let s=Nd.get(n);if(s){let i=We[n];n.includes("delete")&&$t.trace(`defined tables ${Array.from(s.keys())}`);for(let o in i)s.has(o)||($t.trace(`delete table class ${o}`),delete i[o])}else if(delete We[n],n==="data"){for(let i in jn)delete jn[i];delete jn[zT]}}let r=["hdb_temp","hdb_certificate","hdb_analytics","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if(We.system)for(let n of r)We.system[n]&&(We.system[n].replicate=!1);return Nd=null,We}function vu(){jT=!1;for(let[,e]of Ha)e.needsDeletion=!0;ut();for(let[e,t]of Ha)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),Ha.delete(e),delete We[t.databaseName],KE.forEach(r=>r(t.databaseName)));return We}function $E(e,t,r=Cw,n,s){let i=new Iw.default(e,!1);try{let o=Ha.get(e);o?o.needsDeletion=!1:(o=(0,Id.open)(i),Ha.set(e,o));let c=new Rl.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(KT.INTERNAL_DBIS_NAME,c)),u=o.auditStore;u||(n?(0,rs.existsSync)(n)&&(i.path=n,u=(0,Id.open)(i),u.isLegacy=!0):u=IT(o));let d=MW(r),_=d[zT],E=new Map;for(let{key:f,value:h}of l.getRange({start:!1})){let[T,m]=f.toString().split("/");m===""?m=h.name:m||(m=T,T=t,h.name||(h.name=m,h.indexed=!h.is_hash_attribute)),_?.add(T);let g=E.get(T);g||E.set(T,g={attributes:[]}),(m==null||h.is_hash_attribute)&&(g.primary=h),m!=null&&g.attributes.push(h),Object.defineProperty(h,"key",{value:f,configurable:!0})}for(let[f,h]of E){let{attributes:T,primary:m}=h;if(!m){for(let j of T)if(j.is_hash_attribute||j.isPrimaryKey){m=j;break}if(!m){$t.warn(`Unable to find a primary key attribute on table ${f}, with attributes: ${JSON.stringify(T)}`);continue}}let g=d[f],S={},b=[],I,B,H=typeof m.audit=="boolean"?m.audit:(0,er.get)(yr.CONFIG_PARAMS.LOGGING_AUDITLOG),X=m.trackDeletes,Y=m.expiration,V=m.eviction,ne=m.sealed,Q=m.splitSegments,de=m.replicate;if(g)S=g.indices,b=g.attributes,g.schemaVersion++;else{I=m.tableId,I?I>=(l.get(bd)||0)&&(l.putSync(bd,I+1),$t.info(`Updating next table id (it was out of sync) to ${I+1} for ${f}`)):(m.tableId=I=l.get(bd),I||(I=1),$t.debug("Table {table_name} missing an id, assigning {table_id}"),l.putSync(bd,I+1),l.putSync(m.key,m));let j=new Rl.default(!m.is_hash_attribute,m.is_hash_attribute);if(j.compression=m.compression,j.compression){let ae=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||LW;j.compression.threshold=ae}B=Nh(o.openDB(m.key,j)),o.databaseName=r,B.rootStore=o,B.tableId=I}for(let j of T){j.attribute=j.name;try{if(!j.is_hash_attribute&&(j.indexed||j.attribute&&!j.name)){if(!S[j.name]){let Ae=new Rl.default(!j.is_hash_attribute,j.is_hash_attribute);S[j.name]=o.openDB(j.key,Ae),S[j.name].indexNulls=j.indexNulls}let ae=b.find(Ae=>Ae.name===j.name);ae?b.splice(b.indexOf(ae),1,j):b.push(j)}}catch(ae){$t.error("Error trying to update attribute",j,b,S,ae)}}if(!g){g=UW(d,f,VT({primaryStore:B,auditStore:u,audit:H,sealed:ne,splitSegments:Q,replicate:de,expirationMS:Y&&Y*1e3,evictionMS:V&&V*1e3,trackDeletes:X,tableName:f,tableId:I,primaryKey:m.name,databasePath:s?r+"/"+f:r,databaseName:r,indices:S,attributes:T,schemaDefined:m.schemaDefined,dbisDB:l})),g.schemaVersion=1;for(let j of VE)j(g)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function MW(e){let t=We[e];if(t||(e==="data"?t=We[e]=jn:e==="system"?Object.defineProperty(We,"system",{value:t=Object.create(null),configurable:!0}):t=We[e]=Object.create(null)),Nd&&!Nd.has(e)){let r=new Set;t[zT]=r,Nd.set(e,r)}return t}function UW(e,t,r){return e[t]=r,r}function Yl({database:e,table:t}){e||(e=Cw),ut();let r=MW(e),n=(0,Ut.join)((0,er.getHdbBasePath)(),yr.DATABASES_DIR_NAME),s=(0,er.get)(yr.CONFIG_PARAMS.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,er.get)(yr.CONFIG_PARAMS.STORAGE_PATH)||((0,rs.existsSync)(n)?n:(0,Ut.join)((0,er.getHdbBasePath)(),yr.LEGACY_DATABASES_DIR_NAME));let o=(0,Ut.join)(n,(i?t:e)+".mdb"),c=Ha.get(o);if(!c||c.status==="closed"){let l=new Iw.default(o,!1);c=(0,Id.open)(l),Ha.set(o,c)}return c.auditStore||(c.auditStore=IT(c)),c}async function xA(e){if(!We[e])throw new Error("Schema does not exist");let t=We[e],r;for(let n in t)r=t[n].primaryStore.rootStore,Ha.delete(r.path),r.status==="open"&&(await r.close(),await YE.remove(r.path));if(r||(r=Yl({database:e,table:null}),r.status==="open"&&(await r.close(),await YE.remove(r.path))),e==="data"){for(let n in jn)delete jn[n];delete jn[zT]}delete We[e],KE.forEach(n=>n(e))}function Et(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:o,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:_,schemaDefined:E,origin:f}=e;r||(r=Cw);let h=Yl({database:r,table:t}),T=We[r];$t.trace(`Defining ${t} in ${r}`);let m=T?.[t];if(h.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let g,S,b;E==null&&(E=!0);let I=new Rl.default(!1);for(let Q of o)Q.attribute&&!Q.name?(Q.name=Q.attribute,Q.indexed=!0):Q.attribute=Q.name,Q.expiresAt&&(Q.indexed=!0);let B,H;if(m){if(g=m.primaryKey,m.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);u==null&&(u=m.splitSegments),m.attributes.splice(0,m.attributes.length,...o)}else{let Q=h.auditStore;S=o.find(Ae=>Ae.isPrimaryKey)||{},g=S.name,S.is_hash_attribute=S.isPrimaryKey=!0,S.schemaDefined=E,S.compression=Pm(),_&&(S.trackDeletes=!0),c=S.audit=typeof c=="boolean"?c:(0,er.get)(yr.CONFIG_PARAMS.LOGGING_AUDITLOG),n&&(S.expiration=n),s&&(S.eviction=s),S.splitSegments=!1,typeof l=="boolean"&&(S.sealed=l),typeof d=="boolean"&&(S.replicate=d),f&&(S.origins?S.origins.includes(f)||S.origins.push(f):S.origins=[f]),$t.trace(`${t} table loading, opening primary store`);let de=new Rl.default(!1,!0);de.compression=S.compression;let j=t+"/";if(b=h.dbisDb=h.openDB(KT.INTERNAL_DBIS_NAME,I),ne(),b.get(j))return H&&H(),vu(),Et(e);let ae=Nh(h.openDB(j,de));h.databaseName=r,ae.rootStore=h,ae.tableId=b.get(bd),$t.trace(`Assigning new table id ${ae.tableId} for ${t}`),ae.tableId||(ae.tableId=1),b.put(bd,ae.tableId+1),S.tableId=ae.tableId,m=UW(T,t,VT({primaryStore:ae,auditStore:Q,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:_,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:g,tableName:t,tableId:ae.tableId,databasePath:r,databaseName:r,indices:{},attributes:o,schemaDefined:E,dbisDB:b})),m.schemaVersion=1,B=!0,b.put(j,S)}let X=m.indices;b=b||(h.dbisDb=h.openDB(KT.INTERNAL_DBIS_NAME,I)),m.dbisDB=b;let Y=[];for(let{key:Q,value:de}of b.getRange({start:!0})){let[j,ae]=Q.toString().split("/");if(ae===""&&(ae=de.name),ae){if(j!==t)continue}else continue;let Ae=o.find(Me=>Me.name===ae),ye=!Ae?.indexed&&de.indexed&&!de.isPrimaryKey;if((!Ae||ye)&&(ne(),B=!0,Ae||b.remove(Q),ye)){let Me=m.indices[j];Me&&Y.push(Me)}}let V=[];try{for(let Q of o||[]){if((Q.relationship||Q.computed)&&(B=!0,Q.relationship))continue;let de=t+"/"+(Q.name||"");Object.defineProperty(Q,"key",{value:de,configurable:!0});let j=b.get(de);if(Q.isPrimaryKey){if(j=j||b.get(de=t+"/")||{},c!==void 0&&c!==m.audit||l!==void 0&&l!==m.sealed||d!==void 0&&d!==m.replicate||(+n||void 0)!==(+j.expiration||void 0)||(+s||void 0)!==(+j.eviction||void 0)){let Ae={...j};typeof c=="boolean"&&(c&&m.enableAuditing(c),Ae.audit=c),n&&(Ae.expiration=+n),s&&(Ae.eviction=+s),l!==void 0&&(Ae.sealed=l),d!==void 0&&(Ae.replicate=d),B=!0,ne(),b.put(de,Ae)}continue}j?.attribute&&!j.name&&(j.indexed=!0);let ae=!j||j.type!==Q.type||j.indexed!==Q.indexed||j.nullable!==Q.nullable||j.version!==Q.version||JSON.stringify(j.properties)!==JSON.stringify(Q.properties)||JSON.stringify(j.elements)!==JSON.stringify(Q.elements);if(Q.indexed){let Ae=new Rl.default(!0,!1),ye=h.openDB(de,Ae);(ae||j.indexingPID&&j.indexingPID!==process.pid||j.restartNumber<WE.workerData?.restartNumber)&&(B=!0,ne(),j=b.get(de),(ae||j.indexingPID&&j.indexingPID!==process.pid||j.restartNumber<WE.workerData?.restartNumber)&&(B=!0,Q.indexNulls===void 0&&(Q.indexNulls=!0),m.primaryStore.getStats().entryCount>0&&(Q.lastIndexedKey=j?.lastIndexedKey??void 0,Q.indexingPID=process.pid,ye.isIndexing=!0,Object.defineProperty(Q,"dbi",{value:ye}),V.push(Q))),b.put(de,Q)),j?.indexNulls&&Q.indexNulls===void 0&&(Q.indexNulls=!0),ye.indexNulls=Q.indexNulls,X[Q.name]=ye}else ae&&(B=!0,ne(),b.put(de,Q))}}finally{H&&H()}if(B&&(m.schemaVersion++,m.updatedAttributes()),$t.trace(`${t} table loading, running index`),V.length>0||Y.length>0?m.indexingOperation=iTe(m,V,Y):B&&YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"schema-change",m.databaseName,m.tableName)),m.origin=f,B)for(let Q of VE)Q(m,f!=="cluster");return(n||s||i)&&m.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),$t.trace(`${t} table loaded`),m;function ne(){H||h.transactionSync(()=>({then(Q){H=Q}}))}a(ne,"startTxn")}async function iTe(e,t,r){try{$t.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o={},c=0,l=t.length;if(await new Promise(u=>setImmediate(u)),l>0){let u;for(let _ of t)(0,Id.compareKeys)(_.lastIndexedKey,u)<0&&(u=_.lastIndexedKey),_.lastIndexedKey==null&&_.dbi.clearAsync();let d=0;for(let{key:_,value:E,version:f}of e.primaryStore.getRange({start:u,lazy:l<4,versions:!0,snapshot:!1}))if(E){if(d++,s=e.primaryStore.ifVersion(_,f,()=>{for(let h=0;h<l;h++){let T=t[h],m=T.name;try{let g=T.resolve,S=E&&(g?g(E):E[m]),b=(0,DW.getIndexedValues)(S);if(b)for(let I=0,B=b.length;I<B;I++)T.dbi.put(b[I],_)}catch(g){o[m]||(o[m]=!0,$t.error(`Error indexing attribute ${m}`,g))}}}),s.then(()=>d--,h=>{d--,$t.error(h)}),WE.workerData&&WE.workerData.restartNumber!==PW.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=_,e.dbisDB.put(h.key,h);if(i)return}d>nTe?await s:d>sTe&&await new Promise(h=>setImmediate(h))}for(let _ of t)delete _.lastIndexedKey,delete _.indexingPID,_.dbi.isIndexing=!1,s=e.dbisDB.put(_.key,_)}await s,await YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),$t.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){$t.error("Error in indexing",n)}}function oTe({table:e,database:t}){let r=Yl({database:t,table:e}),n=[],s=r.dbisDb;for(let i of s.getKeys({start:e+"/",end:e+"0"}))n.push(s.remove(i));return Promise.all(n)}function Dc(e){return VE.push(e),{remove(){let t=VE.indexOf(e);t>-1&&VE.splice(t,1)}}}function nf(e){return KE.push(e),{remove(){let t=KE.indexOf(e);t>-1&&KE.splice(t,1)}}}function Pm(){let e=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION),t=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION_DICTIONARY),r=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||LW,n={startingOffset:32};return t&&(n.dictionary=YE.readFileSync(t)),r&&(n.threshold=r),e&&n}var er,KT,Id,Ut,rs,Od,Rl,Iw,yr,YE,ww,DW,YT,WT,WE,$t,PW,Cw,zT,LW,jn,We,bd,VE,KE,jT,Ha,Nd,nTe,sTe,Pe=Oe(()=>{er=L(se()),KT=L(Bt()),Id=require("lmdb"),Ut=require("path"),rs=require("fs"),Od=L(gt());oE();Rl=L(o_()),Iw=L(a_()),yr=L(M()),YE=L(require("fs-extra")),ww=L(fi()),DW=L(cn()),YT=L(no()),WT=L(qs()),WE=require("worker_threads"),$t=L(W()),PW=L(dt());Ji();Pl();Cw="data",zT=Symbol("defined-tables"),LW=((0,er.get)(yr.CONFIG_PARAMS.STORAGE_PAGESIZE)||4096)-60;(0,er.initSync)();jn=Object.create(null),We=Object.create(null);(0,ww._assignPackageExport)("databases",We);(0,ww._assignPackageExport)("tables",jn);bd=Symbol.for("next-table-id"),VE=[],KE=[],Ha=new Map;a(rTe,"getTables");a(ut,"getDatabases");a(vu,"resetDatabases");a($E,"readMetaDb");a(MW,"ensureDB");a(UW,"setTable");a(Yl,"database");a(xA,"dropDatabase");a(Et,"table");nTe=1e3,sTe=10;a(iTe,"runIndexing");a(oTe,"dropTableMeta");a(Dc,"onUpdatedTable");a(nf,"onRemovedDB");a(Pm,"getDefaultCompression")});var te=N((tUe,jW)=>{"use strict";var xa=require("path"),kW=require("fs-extra"),In=W(),vW=require("fs-extra"),QT=require("os"),aTe=require("net"),cTe=require("recursive-iterator"),Vt=M(),lTe=hg(),BW=require("papaparse"),JT=require("moment"),{inspect:uTe}=require("util"),HW=require("is-number"),eUe=require("lodash"),dTe=require("minimist"),_Te=require("https"),fTe=require("http"),{hdb_errors:XT}=_e(),ETe=/^((\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d\.\d+([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z)))$/,FW=require("util").promisify(setTimeout),hTe=100,pTe=5,mTe="",STe=4,xW={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};jW.exports={isEmpty:ns,isEmptyOrZeroLength:Wi,arrayHasEmptyValues:RTe,arrayHasEmptyOrZeroLengthValues:ATe,buildFolderPath:yTe,isBoolean:GW,errorizeMessage:TTe,stripFileExtension:OTe,autoCast:NTe,autoCastJSON:qW,autoCastJSONDeep:Pw,removeDir:ITe,compareVersions:wTe,isCompatibleDataVersion:CTe,escapeRawValue:DTe,unescapeValue:PTe,stringifyProps:LTe,timeoutPromise:UTe,isClusterOperation:BTe,getClusterUser:xTe,checkGlobalSchemaTable:HTe,getHomeDir:VW,getPropsFilePath:MTe,promisifyPapaParse:kTe,removeBOM:KW,createEventPromise:FTe,checkProcessRunning:GTe,checkSchemaTableExist:qTe,checkSchemaExists:YW,checkTableExists:WW,getStartOfTomorrowInSeconds:$Te,getLimitKey:VTe,isObject:bTe,isNotEmptyAndHasValue:gTe,autoCasterIsNumberCheck:$W,backtickASTSchemaItems:KTe,isPortTaken:vTe,createForkArgs:YTe,autoCastBoolean:WTe,async_set_timeout:FW,getTableHashAttribute:jTe,doesSchemaExist:zTe,doesTableExist:QTe,stringifyObj:JTe,ms_to_time:XTe,changeExtension:ZTe,getEnvCliRootPath:Lw,noBootFile:ege,httpRequest:tge,transformReq:rge,convertToMS:nge,PACKAGE_ROOT:Vt.PACKAGE_ROOT};function TTe(e){return e instanceof Error?e:new Error(e)}a(TTe,"errorizeMessage");function ns(e){return e==null}a(ns,"isEmpty");function gTe(e){return!ns(e)&&(e||e===0||e===""||GW(e))}a(gTe,"isNotEmptyAndHasValue");function Wi(e){return ns(e)||e.length===0||e.size===0}a(Wi,"isEmptyOrZeroLength");function RTe(e){if(ns(e))return!0;for(let t=0;t<e.length;t++)if(ns(e[t]))return!0;return!1}a(RTe,"arrayHasEmptyValues");function ATe(e){if(Wi(e))return!0;for(let t=0;t<e.length;t++)if(Wi(e[t]))return!0;return!1}a(ATe,"arrayHasEmptyOrZeroLengthValues");function yTe(...e){try{return e.join(xa.sep)}catch{console.error(e)}}a(yTe,"buildFolderPath");function GW(e){return ns(e)?!1:e===!0||e===!1}a(GW,"isBoolean");function bTe(e){return ns(e)?!1:typeof e=="object"}a(bTe,"isObject");function OTe(e){return Wi(e)?mTe:e.slice(0,-STe)}a(OTe,"stripFileExtension");function NTe(e){return ns(e)||e===""||typeof e!="string"?e:xW[e]!==void 0?xW[e]:$W(e)===!0?Number(e):ETe.test(e)?new Date(e):e}a(NTe,"autoCast");function qW(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(qW,"autoCastJSON");function Pw(e){if(e&&typeof e=="object"){if(Array.isArray(e))for(let t=0,r=e.length;t<r;t++){let n=e[t],s=Pw(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=Pw(r);n!==r&&(e[t]=n)}return e}else return qW(e)}a(Pw,"autoCastJSONDeep");function $W(e){if(e.startsWith("0.")&&HW(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&HW(e))}a($W,"autoCasterIsNumberCheck");async function ITe(e){if(Wi(e))throw new Error(`Directory path: ${e} does not exist`);try{await vW.emptyDir(e),await vW.remove(e)}catch(t){throw In.error(`Error removing files in ${e} -- ${t}`),t}}a(ITe,"removeDir");function wTe(e,t){if(Wi(e)){In.info("Invalid current version sent as parameter.");return}if(Wi(t)){In.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,o=s.replace(n,"").split("."),c=i.replace(n,"").split("."),l=Math.min(o.length,c.length);for(let u=0;u<l;u++)if(r=parseInt(o[u],10)-parseInt(c[u],10),r)return r;return o.length-c.length}a(wTe,"compareVersions");function CTe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(CTe,"isCompatibleDataVersion");function DTe(e){if(ns(e))return e;let t=String(e);return t==="."?Vt.UNICODE_PERIOD:t===".."?Vt.UNICODE_PERIOD+Vt.UNICODE_PERIOD:t.replace(Vt.FORWARD_SLASH_REGEX,Vt.UNICODE_FORWARD_SLASH)}a(DTe,"escapeRawValue");function PTe(e){if(ns(e))return e;let t=String(e);return t===Vt.UNICODE_PERIOD?".":t===Vt.UNICODE_PERIOD+Vt.UNICODE_PERIOD?"..":String(e).replace(Vt.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(PTe,"unescapeValue");function LTe(e,t){if(ns(e))return In.info("Properties object is null"),"";let r="";return e.each(function(n,s){try{if(t&&t[n]){let i=t[n];for(let o of i)r+=";"+o+QT.EOL}!Wi(n)&&n[0]===";"?r+=" "+n+s+QT.EOL:Wi(n)||(r+=n+"="+s+QT.EOL)}catch{In.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(LTe,"stringifyProps");function VW(){let e;try{e=QT.homedir()}catch{e=process.env.HOME}return e}a(VW,"getHomeDir");function MTe(){let e=xa.join(VW(),Vt.HDB_HOME_DIR_NAME,Vt.BOOT_PROPS_FILE_NAME);return kW.existsSync(e)||(e=xa.join(__dirname,"../","hdb_boot_properties.file")),e}a(MTe,"getPropsFilePath");function UTe(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:a(function(){clearTimeout(r)},"cancel")}}a(UTe,"timeoutPromise");async function vTe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=aTe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(vTe,"isPortTaken");function BTe(e){try{return Vt.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){In.error(`Error checking operation against cluster ops ${t}`)}return!1}a(BTe,"isClusterOperation");function HTe(e,t){let r=(Pe(),oe(lt)).getDatabases();if(!r[e])return XT.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return XT.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(HTe,"checkGlobalSchemaTable");function xTe(e,t){if(ns(t)){In.warn("No CLUSTERING_USER defined, clustering disabled");return}if(ns(e)||Wi(e)){In.warn("No users to search.");return}let r;try{let n=e.get(t);n&&n.role.permission.cluster_user===!0&&n.active===!0&&(r=n)}catch(n){In.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){In.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(xTe,"getClusterUser");function kTe(){BW.parsePromise=function(e,t,r){return new Promise(function(n,s){BW.parse(e,{header:!0,transformHeader:KW,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(kTe,"promisifyPapaParse");function KW(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(KW,"removeBOM");function FTe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;In.info(`Got cluster status event response: ${uTe(s)}`);try{i.cancel()}catch{In.error("Error trying to cancel timeout.")}n(s)})})}a(FTe,"createEventPromise");async function GTe(e){let t=!0,r=0;do await FW(hTe*r++),(await lTe.findPs(e)).length>0&&(t=!1);while(t&&r<pTe);if(t)throw new Error(`process ${e} was not started`)}a(GTe,"checkProcessRunning");function qTe(e,t){let r=YW(e);if(r)return r;let n=WW(e,t);if(n)return n}a(qTe,"checkSchemaTableExist");function YW(e){let{getDatabases:t}=(Pe(),oe(lt));if(!t()[e])return XT.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(YW,"checkSchemaExists");function WW(e,t){let{getDatabases:r}=(Pe(),oe(lt));if(!r()[e][t])return XT.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(WW,"checkTableExists");function $Te(){let e=JT().utc().add(1,Vt.MOMENT_DAYS_TAG).startOf(Vt.MOMENT_DAYS_TAG).unix(),t=JT().utc().unix();return e-t}a($Te,"getStartOfTomorrowInSeconds");function VTe(){return JT().utc().format("DD-MM-YYYY")}a(VTe,"getLimitKey");function KTe(e){try{let t=new cTe(e);for(let{node:r}of t)r&&(r.columnid&&typeof r.columnid!="string"&&(r.columnid=r.columnid.toString()),r.columnid&&!r.columnid.startsWith("`")&&(r.columnid_orig=r.columnid,r.columnid=`\`${r.columnid}\``),r.tableid&&!r.tableid.startsWith("`")&&(r.tableid_orig=r.tableid,r.tableid=`\`${r.tableid}\``),r.databaseid&&!r.databaseid.startsWith("`")&&(r.databaseid_orig=r.databaseid,r.databaseid=`\`${r.databaseid}\``),r.as&&typeof r.as=="string"&&!r.as.startsWith("[")&&(r.as_orig=r.as,r.as=`\`${r.as}\``))}catch(t){In.error("Got an error back ticking items."),In.error(t)}}a(KTe,"backtickASTSchemaItems");function YTe(e){return[e]}a(YTe,"createForkArgs");function WTe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(WTe,"autoCastBoolean");function jTe(e,t){let{getDatabases:r}=(Pe(),oe(lt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(jTe,"getTableHashAttribute");function zTe(e){let{getDatabases:t}=(Pe(),oe(lt));return t()[e]!==void 0}a(zTe,"doesSchemaExist");function QTe(e,t){let{getDatabases:r}=(Pe(),oe(lt));return r()[e]?.[t]!==void 0}a(QTe,"doesTableExist");function JTe(e){try{return JSON.stringify(e)}catch{return e}}a(JTe,"stringifyObj");function XTe(e){let t=JT.duration(e),r=t.seconds()>0?t.seconds()+"s":"",n=t.minutes()>0?t.minutes()+"m ":"",s=t.hours()>0?t.hours()+"h ":"",i=t.days()>0?t.days()+"d ":"";return(t.years()>0?t.years()+"y ":"")+i+s+n+r}a(XTe,"ms_to_time");function ZTe(e,t){let r=xa.basename(e,xa.extname(e));return xa.join(xa.dirname(e),r+t)}a(ZTe,"changeExtension");function Lw(){if(process.env[Vt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[Vt.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=dTe(process.argv);if(e[Vt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[Vt.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(Lw,"getEnvCliRootPath");var Dw;function ege(){if(Dw)return Dw;let e=Lw();if(Lw()&&kW.pathExistsSync(xa.join(e,Vt.HDB_CONFIG_FILE)))return Dw=!0,!0}a(ege,"noBootFile");function tge(e,t){let r;return e.protocol==="http:"?r=fTe:r=_Te,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8"),o.body="",o.on("data",c=>{o.body+=c}),o.on("end",()=>{n(o)})});i.on("error",o=>{s(o)}),i.write(t instanceof Buffer?t:JSON.stringify(t)),i.end()})}a(tge,"httpRequest");function rge(e){if(!e.schema&&!e.database){e.schema=Vt.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(rge,"transformReq");function nge(e){let t=0;if(typeof e=="number"&&(t=e),typeof e=="string")switch(t=parseFloat(e),e.slice(-1)){case"M":t*=86400*30;break;case"D":case"d":t*=86400;break;case"H":case"h":t*=3600;break;case"m":t*=60;break}return t*1e3}a(nge,"convertToMS")});var QW=N((sUe,zW)=>{"use strict";var Mw=M(),sge=te(),ige=Di(),ui=W(),oge=mm(),age=pf(),nUe=Uu(),cge=ls(),lge=Rf(),uge=require("semver/functions/gte"),dge=3e4,_ge=7;zW.exports=fge;async function fge(){try{ui.notify("Starting update nodes. This process will attempt to update any node connections the need to be reestablished after a 4.0.0 upgrade"),await cge.setSchemaDataToGlobalAsync();let e=await ige.getAllNodeRecords(),t=[];for(let r=0,n=e.length;r<n;r++){let s=e[r];s.system_info.hdb_version===Mw.PRE_4_0_0_VERSION&&t.push(Ege(s))}await Promise.allSettled(t),ui.notify("Shutting down 4.0.0 clustering upgrade process")}catch(e){throw ui.error(e),e}}a(fge,"updateAllNodes");async function Ege(e){try{let{name:t,subscriptions:r}=e;ui.notify("Running 4.0.0 update on node:",t);let n=!1,s=0;for(;s<_ge;){let i=[];if(await oge.buildNodeStatus(e,i),ui.trace("Received status:",i[0].status,"from node:",t),i[0].status==="open"&&uge(i[0].system_info.hdb_version,"4.0.0")){ui.notify("Received open status from node:",t,"calling add node");let o={operation:Mw.OPERATIONS_ENUM.ADD_NODE,node_name:t,subscriptions:r};await age(o,!0),ui.notify("Successfully added node",t),n=!0;break}s=(Date.now()-e.__updatedtime__)/(1e3*60*60*24),ui.trace("Update node has been running for",s,"days. Calling node status again for node:",t),await sge.async_set_timeout(dge)}n||(ui.error("4.0.0 node update was unable to update connection to node:",t),ui.error("Removing following node record from hdb_nodes",e),await lge({operation:Mw.OPERATIONS_ENUM.REMOVE_NODE,node_name:t}))}catch(t){throw ui.error(t),t}}a(Ege,"updateNode")});var hge=QW();(async()=>{try{await hge()}catch(e){console.error("Error launching 4.0.0 node update"),console.error(e),process.exit(1)}})();
|
|
132
|
+
`))}},25).unref()}o.close?.(()=>{if(Rt.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&dd()==0)try{xK(GK(Rt.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,XS),o.cantCleanupProperly||Nn.warn("Had to forcefully exit the thread",XS),process.exit(0)},5e3).unref()})}if(qK||process.env.DEV_MODE)try{require("inspector").close()}catch(i){Nn.info("Could not close debugger",i)}}}).ref();let e;IE&&!tme&&(e=VK()),Promise.resolve(e).then(()=>{if(dd()===0)try{Xpe(LI)}catch(t){console.error("Error displaying start-up log",t)}wE?.postMessage({type:Zt.ITC_EVENT_TYPES.CHILD_STARTED})})})}a($K,"startServers");function VK(){let e=[];for(let t in $i){let r=$i[t];if(t.includes?.("/")&&dd()==0){Kpe(t)&&xK(t),e.push(new Promise((o,c)=>{r.listen({path:t},()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),Nn.info("Domain socket listening on "+t)}).on("error",c)}));continue}let n,s=Rt.get(Zt.CONFIG_PARAMS.HTTP_THREADRANGE);if(s){let o=typeof s=="string"?s.split("-"):s,c=dd();if(c<o[0]||c>o[1])continue}let i;try{let o=t.lastIndexOf(":");o>0?IE?n={fd:IE(+t.slice(o+1).replace(/[\[\]]/g,""),t.slice(0,o))}:n={host:+t.slice(o+1).replace(/[\[\]]/g,""),port:t.slice(0,o)}:IE?n={fd:IE(+t,"::")}:n={port:t}}catch(o){console.error(`Unable to bind to port ${t}`,o);continue}e.push(new Promise((o,c)=>{r.listen(n,()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),Nn.trace("Listening on port "+t,XS)}).on("error",c)}))}return Promise.all(e)}a(VK,"listenOnPorts");!DI&&!kpe?.noServerStart&&$K();function vI(e,t,r){let n=e?.read?e:new Fpe({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=$i[t];if(s.isSecure&&(n.startTime=performance.now()),s)typeof s=="function"?s(n):s.emit("connection",n),r&&n.emit("data",r);else{let i=a(o=>{setTimeout(()=>{let c=$i[t];c?(typeof c=="function"?c(n):c.emit("connection",n),r&&n.emit("data",r)):o<5?i(o+1):(Nn.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a(vI,"deliverSocket");var MK=new Map;function rme(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=MK.get(s),r){case"connection":i=vI(void 0,t),MK.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(rme,"proxyRequest");var{getComponentName:eT}=(Jf(),oe(Qf));function BI(e,t,r=!0){t||(t=Rt.get(Zt.CONFIG_PARAMS.HTTP_PORT));let n=$i[t];if(n){let s=n.lastServer||n;if(s===e)throw new Error(`Can not register the same server twice for the same port ${t}`);if(r&&!!s.sessionIdContext!=!!e.sessionIdContext&&+t)throw new Error(`Can not mix secure HTTPS and insecure HTTP on the same port ${t}`);s.off("unhandled",HK),s.on("unhandled",(i,o)=>{e.cantCleanupProperly&&(n.cantCleanupProperly=!0),e.emit("request",i,o)}),n.lastServer=e}else $i[t]=e;e.on("unhandled",HK)}a(BI,"registerServer");function HI(e){let t=[],r=e?.securePort;return r&&t.push({port:r,secure:!0}),r=e?.port,r&&t.push({port:r,secure:!1}),t.length===0&&(t=[],Rt.get(Zt.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:Rt.get(Zt.CONFIG_PARAMS.HTTP_PORT),secure:Rt.get(Zt.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),Rt.get(Zt.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:Rt.get(Zt.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&Rt.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:GK(Rt.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)),secure:!1}),t}a(HI,"getPorts");function xI(e,t){let r=[];for(let{port:n,secure:s}of HI(t))r.push(KK(n,s,t?.isOperationsServer,t?.mtls)),typeof e=="function"?MI[t?.runFirst?"unshift":"push"]({listener:e,port:t?.port||n}):(e.isSecure=s,BI(e,n,!1)),ZS[n]=rT(MI,n);return r}a(xI,"httpServer");function tT(e,t){let r=LI.get(e)??[];LI.set(e,[...r,t])}a(tT,"setPortServerMap");function KK(e,t,r,n){if(tT(e,{protocol_name:t?"HTTPS":"HTTP",name:eT()}),!JS[e]){let s=r?"operationsApi_network":"http",i=Rt.get(s+"_keepAliveTimeout"),o=Rt.get(s+"_timeout"),c=Rt.get(s+"_headersTimeout"),l={noDelay:!0,keepAliveTimeout:i,headersTimeout:c,requestTimeout:o,highWaterMark:128*1024,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,maxHeaderSize:Rt.get(Zt.CONFIG_PARAMS.HTTP_MAXHEADERSIZE)},u=Rt.get(s+"_mtls"),d=Rt.get(s+"_mtls_required");t&&Object.assign(l,{allowHTTP1:!0,rejectUnauthorized:!!d,requestCert:!!(u||n),ticketKeys:jpe(),SNICallback:FK(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 _=Jpe(),E=JS[e]=(t?Vpe:qpe)(l,async(f,h)=>{try{let m=performance.now(),g=new kK(f,h);r&&(g.isOperationsServer=!0);let S=await ZS[e](g);if(!S){if(g._nodeResponse.statusCode)return;S=YK(g)}if(S.headers?.set||(S.headers=new PI(S.headers)),_?S.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):S.headers?.set?.("Server","HarperDB"),S.status===-1){for(let ne of S.headers||[])h.setHeader(ne[0],ne[1]);return f.baseRequest=g,h.baseResponse=S,JS[e].emit("unhandled",f,h)}let b=S.status||200,I=performance.now(),B=I-m,H=S.body,X;if(!S.handlesHeaders){let ne=S.headers||new PI;H?H.length>=0&&(typeof H=="string"?ne.set("Content-Length",Buffer.byteLength(H)):ne.set("Content-Length",H.length),X=!0):(ne.set("Content-Length","0"),X=!0);let Q=`hdb;dur=${B.toFixed(2)}`;S.wasCacheMiss&&(Q+=", miss"),Qpe(ne,"Server-Timing",Q,!0),h.headersSent||h.writeHead(b,ne&&(ne[Symbol.iterator]?Array.from(ne):ne)),X&&h.end(H)}let Y=g.handlerPath,V=g.method;if(OE(B,"duration",Y,V,S.wasCacheMiss==null?void 0:S.wasCacheMiss?"cache-miss":"cache-hit"),PK(b<400,"success",Y,V),PK(1,"response_"+b,Y,V),!X)if(H instanceof ReadableStream&&(H=LK.fromWeb(H)),(H[Symbol.iterator]||H[Symbol.asyncIterator])&&(H=LK.from(H)),H?.pipe){H.pipe(h),H.destroy&&h.on("close",()=>{H.destroy()});let ne=0;H.on("data",Q=>{ne+=Q.length}),H.on("end",()=>{OE(performance.now()-I,"transfer",Y,V),OE(ne,"bytes-sent",Y,V)})}else H?.then?H.then(ne=>{h.end(ne)},T):h.end(H)}catch(m){T(m)}function T(m){let g=m.headers;h.writeHead(m.statusCode||500,g&&(g[Symbol.iterator]?Array.from(g):g)),h.end(m.toString()),m.statusCode?m.statusCode===500?Nn.warn(m):Nn.info(m):Nn.error(m)}a(T,"onError")});i>=0&&(E.keepAliveTimeout=i),c>=0&&(E.headersTimeout=c),t&&(E.ports||(E.ports=[]),E.ports.push(e),l.SNICallback.initialize(E),u&&(E.mtlsConfig=u),E.on("secureConnection",f=>{f._parent.startTime&&OE(performance.now()-f._parent.startTime,"tls-handshake",e),OE(f.isSessionReused(),"tls-reused",e)}),E.isSecure=!0),BI(E,e)}return JS[e]}a(KK,"getHTTPServer");function rT(e,t){let r=YK;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 YK(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new PI}}a(YK,"unhandled");function nme(e,t){xI(e,{requestOnly:!0,...t})}a(nme,"onRequest");function sme(e,t){let r;if(t.securePort){tT(t.securePort,{protocol_name:"TLS",name:eT()});let n=FK("server",t.mtls);r=Wpe({rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,SNICallback:n},e),n.initialize(r),$i[t.securePort]=r}return t.port&&(tT(t.port,{protocol_name:"TCP",name:eT()}),r=Gpe(e,{noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600}),$i[t.port]=r),r}a(sme,"onSocket");Object.defineProperty($pe.prototype,"upgrade",{get(){return"connection"in this.headers&&"upgrade"in this.headers&&this.headers.connection.includes("Upgrade")&&this.headers.upgrade.toLowerCase()=="websocket"},set(e){}});var UK=[],UI={};function WK(e,t){for(let{port:r}of HI(t))UK[t?.runFirst?"unshift":"push"]({listener:e,port:r}),UI[r]=rT(UK,r)}a(WK,"onUpgrade");var vK=[],BK={};function ime(e,t){let r=[];for(let{port:n,secure:s}of HI(t)){tT(n,{protocol_name:s?"WSS":"WS",name:eT()});let i=KK(n,s,t?.isOperationsServer,t?.mtls);NE[n]||(NE[n]=new Ype({noServer:!0,maxPayload:t.maxPayload??100*1024*1024}),NE[n].on("connection",(o,c)=>{let l=new kK(c);l.isWebSocket=!0;let u=ZS[n](l);BK[n](o,l,u)}),WK((o,c,l,u)=>o.__harperdb_request_upgraded?u(o,c,l):NE[n].handleUpgrade(o,c,l,d=>{o.__harperdb_request_upgraded=!0,u(o,c,l),NE[n].emit("connection",d,o)}),{port:n}),i.on("upgrade",(o,c,l)=>{UI[n]&&UI[n](o,c,l)})),r.push(i),vK[t?.runFirst?"unshift":"push"]({listener:e,port:n}),BK[n]=rT(vK,n),ZS[n]=rT(MI,n)}return r}a(ime,"onWebSocket");function HK(e,t){t.writeHead(404),t.end(`Not found
|
|
133
|
+
`)}a(HK,"defaultNotFound")});var DK={};je(DK,{startHTTPThreads:()=>ame,startSocketServer:()=>VI,updateWorkerIdleness:()=>tY});async function ame(e=2,t){try{if(t)qI(0,1,!0);else{let{loadRootComponents:r}=nT();if(e===0)return(0,Ds.setMainIsWorker)(!0),await kI().startServers(),Promise.resolve([]);await r()}eY();for(let r=0;r<e;r++)qI(r,e);return Promise.all(ZK)}finally{(0,Ds.threadsHaveStarted)()}}function eY(){let e=(0,JK.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),GI=setInterval(()=>{oT.notify(e)},ome).unref())}function qI(e,t=1,r){if(FI++,(0,Ds.startWorker)("server/threads/threadServer.js",{name:pd.THREAD_TYPES.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(u){u.type===pd.CLUSTER_MESSAGE_TYPE_ENUM.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});ZK.push(s),await s,_d.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=iT.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=_d.indexOf(n);o>-1&&_d.splice(o,1)}if(a(i,"removeWorker"),fd){let o=fd;fd=[];for(let c of o)XK[c.localPort](null,c)}}}),r){let n=setInterval(()=>{$I?$I=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,Ds.shutdownWorkers)(),FI=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function VI(e=0,t){if(typeof e=="string")try{(0,aT.existsSync)(e)&&(0,aT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=cme:r=lme(t):r=KI;let n=(0,Ed.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);if(n._handle){n._handle.onconnection=XK[e]=function(i,o){r.readsData||(o.reading=!1,o.readStop()),$I=!0,r(o,(c,l)=>{if(!c){if(jK){let d=o._socket||new Ed.Socket({handle:o,writable:!0,readable:!0});jK.deliverSocket(d,e,l),d.resume()}else FI>0?(fd.length===0&&setTimeout(()=>{fd.length>0&&console.warn("Incoming sockets/requests have been queued for workers to start, and no workers have handled them. Check to make sure an error is not preventing workers from starting")},1e4).unref(),o.localPort=e,fd.push(o)):(console.log("start up a dynamic thread to handle request"),qI(0));pr(!1,"socket-routed");return}c.requests++;let u=o.fd;if(u>=0)c.postMessage({port:e,fd:u,data:l});else{let d=o._socket||new Ed.Socket({handle:o,writable:!0,readable:!0});_me(d,c,e)}pr(!0,"socket-routed")})};let s=Jl();oT.info(`HarperDB ${s.version} Server running on port ${e}`)}return n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function KI(e,t){let r,n=0;for(let s of _d){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=sT)return sT=i,t(r);n=i}sT=0,t(r)}function cme(e,t){let r={};e.getpeername(r);let n=r.address,s=hd.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);KI(e,o=>{hd.set(n,{worker:o,lastUsed:i}),t(o)})}function lme(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new Ed.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let l=o.toString("latin1").match(t)?.[1],u=hd.get(l),d=Date.now();if(u&&u.worker.threadId!==-1)return u.lastUsed=d,s(u.worker);KI(n,_=>{hd.set(l,{worker:_,lastUsed:d}),s(_,o)})})}a(r,"findByHeaderAffinity")}function tY(){sT=0;for(let e of _d)e.expectedIdle=e.recentELU.idle+ume,e.requests=1;_d.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function _me(e,t,r){let n=dme++;t.postMessage({port:r,requestId:n,event:"connection"}),e.on("data",s=>{let i=s.toString("latin1");t.postMessage({port:r,requestId:n,data:i,event:"data"})}).on("close",s=>{t.postMessage({port:r,requestId:n,event:"close",hadError:s})}).on("error",s=>{t.postMessage({port:r,requestId:n,event:"error",error:s})}).on("drain",s=>{t.postMessage({port:r,requestId:n,event:"drain",error:s})}).on("end",()=>{t.postMessage({port:r,requestId:n,event:"end"})}).resume(),iT.set(n,s=>{s.event=="data"&&e.write(Buffer.from(s.data,"latin1")),s.event=="end"&&(e.end(s.data&&Buffer.from(s.data,"latin1")),iT.delete(n)),s.event=="destroy"&&(e.destroy(),iT.delete(n))})}var Ds,Ed,pd,oT,aT,QK,JK,_d,fd,XK,jK,FI,ZK,GI,ome,$I,sT,zK,hd,ume,iT,dme,CI=Ne(()=>{Ds=L(dt()),Ed=require("net"),pd=L(M()),oT=L(W()),aT=require("fs");Ni();QK=require("worker_threads"),JK=L(dc()),_d=[],fd=[],XK=[],FI=0,ZK=[];QK.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,Ds.onMessageFromWorkers)(e=>{e.type===pd.ITC_EVENT_TYPES.RESTART&&GI&&(clearInterval(GI),eY())}));ome=6e5;a(ame,"startHTTPThreads");a(eY,"licenseWarning");a(qI,"startHTTPWorker");a(VI,"startSocketServer");sT=0;a(KI,"findMostIdleWorker");zK=36e5,hd=new Map;a(cme,"findByRemoteAddressAffinity");a(lme,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of hd)r.lastUsed+zK<e&&hd.delete(t)},zK).unref();ume=1e3;a(tY,"updateWorkerIdleness");(0,Ds.setMonitorListener)(tY);iT=new Map,dme=1;a(_me,"proxySocket")});var iY=N((GLe,sY)=>{"use strict";var fme=require("cluster"),pl=se();pl.initSync();var nY=M(),BLe=require("util"),Ho=W(),HLe=require("fs"),Eme=require("fastify"),xLe=Jl(),hme=require("@fastify/cors"),pme=require("@fastify/compress"),mme=require("@fastify/static"),Sme=GN(),Tme=require("path"),{PACKAGE_ROOT:gme}=M(),Rme=ls(),Ame=te(),yme=xn(),bme=dc(),{server:Ome}=(qr(),oe(Qa)),{node_request_key:kLe}=(vS(),oe(XN)),{authHandler:Nme,handlePostRequest:Ime,serverErrorHandler:wme,reqBodyValidationHandler:Cme}=LS(),FLe=require("net"),{registerContentHandlers:Dme}=(jc(),oe(G$)),Pme=6e4,Lme=1024*1024*1024,Mme="TRUE",{CONFIG_PARAMS:DE}=nY,md;sY.exports={hdbServer:rY,start:rY};async function rY(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=fme.isMaster,await Ume();let t=e.securePort>0;md=vme(t),await md.ready(),e||(e={}),e.isOperationsServer=!0;try{Ome.http(md.server,e),md.server.closeIdleConnections||await md.listen({port:0,host:"::"})}catch(r){throw md.close(),Ho.error(r),Ho.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),Ho.fatal(t),process.exit(1)}}a(rY,"operationsServer");async function Ume(){Ho.trace("Configuring HarperDB process."),Rme.setSchemaDataToGlobal(),await yme.setUsersToGlobal(),await bme.getLicense()}a(Ume,"setUp");function vme(e){Ho.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=Bme(e),r=Eme(t);r.server.headersTimeout=xme(),r.setErrorHandler(wme);let n=Hme();n&&r.register(hme,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,u){r.server.emit("unhandled",l.raw,u.raw)}),c()}),r.register(Sme),r.register(pme),r.register(mme,{root:Tme.join(gme,"studio/build-local")}),Dme(r);let s=pl.get(nY.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!Ame.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[Cme,Nme],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),Ime(i,o)}),r.get("/health",()=>"HarperDB is running."),Ho.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(vme,"buildServer");function Bme(e){let t=pl.get(DE.OPERATIONSAPI_NETWORK_TIMEOUT),r=pl.get(DE.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:Lme,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(Bme,"getServerOptions");function Hme(){let e=pl.get(DE.OPERATIONSAPI_NETWORK_CORS),t=pl.get(DE.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===Mme)&&(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(Hme,"getCORSOpts");function xme(){return pl.get(DE.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??Pme}a(xme,"getHeaderTimeoutConfig")});var JI={};je(JI,{disableNATS:()=>Fme,publishToStream:()=>uT,setNATSReplicator:()=>YI,setPublishToStream:()=>Gme,setSubscription:()=>QI,start:()=>kme});function kme(){PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_ENABLED)&&$me()}function Fme(e=!0){uY=e}function Gme(e,t){uT=e,QI=t}function $me(){if(uY||process.env._DISABLE_NATS)return;let e=ut(),t=Object.keys(e);t.push("system");for(let r of t){let n=e[r];for(let s in n){let i=n[s];YI(s,r,i)}}Pc((r,n)=>{YI(r.tableName,r.databaseName,r),n&&_Y(r)}),!oY&&(oY=!0)}function YI(e,t,r){if(t==="system"&&Vme.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){_Y(i)}static subscribe(){let i=new Mn;return QI(t,e,i),i}static subscribeOnThisThread(i){return i<(PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??qme)}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=dY;return i}a(n,"getNATSTransaction")}function _Y(e){let t=PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_NODENAME);uT(`${jI.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,zI.createNatsTableStreamName)(e.databaseName,e.tableName),void 0,{operation:"define_schema",schema:e.databaseName,table:e.tableName,attributes:e.attributes,__origin:{timestamp:Date.now(),node_name:t}})}var aY,jI,zI,cY,lY,PE,LE,lT,uY,uT,QI,qme,dY,oY,Vme,cT,WI,fY=Ne(()=>{Pe();Vs();aY=L(mr()),jI=L(Ct()),zI=L(to());Pl();cY=L(ey()),lY=L(cn()),PE=L(se()),LE=L(M()),lT=L(W());a(kme,"start");a(Fme,"disableNATS");uT=aY.publishToStream,QI=cY.setSubscription;a(Gme,"setPublishToStream");qme=2;a($me,"assignReplicationSource");Vme=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(YI,"setNATSReplicator");a(_Y,"publishSchema");cT=class{constructor(t,r){this.transaction=t;this.options=r}static{a(this,"NATSTransaction")}user;writes_by_db=new Map;addWrite(t,r){r.expiresAt=this.context?.expiresAt;let n=this.writes_by_db.get(t);n||this.writes_by_db.set(t,n=[]),n.push(r)}commit({timestamp:t}){let r=PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],l,u;for(let d of i){let _=d.table,E=d.operation=="put"?"upsert":d.operation;l||(lT.trace(`Sending transaction event ${E}`),u=l={operation:E,schema:s,table:_,__origin:{user:this.user?.username,timestamp:t,node_name:r}},l.hash_values=c,E!=="delete"&&E!=="invalidate"&&(l.records=o)),l.table===_&&l.operation===E?(o.push(d.record),c.push(d.id)):u=u.next={operation:E,table:_,id:d.id,record:d.record},d.expiresAt&&(u.expiresAt=d.expiresAt)}l&&n.push(uT(`${jI.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,zI.createNatsTableStreamName)(s,l.table),void 0,l)?.catch(d=>{throw lT.error("An error has occurred trying to replicate transaction",l,d),d.statusCode=504,d}))}return Promise.all(n)}},WI=class extends cT{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,lY.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};dY=new WI});async function SY({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await XI.get(e,{returnNonexistent:!0});i=new tw(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await XI.get(e);o&&o.delete()}i=new _T(e,t)}return n&&(n.id=e,n.user={username:t?.username},ME.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function ZI(){return dT++,dT>65500&&(dT=1),dT}function ew(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=wi.getMatch(n,"mqtt");if(!i)throw new Error(`Can not publish to topic ${n} as it does not exist, no resource has been defined to handle this topic`);e.url=i.relativeURL;let o=i.Resource;return Dt(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var hY,Ma,pY,mY,EY,XI,ME,dT,_T,tw,TY=Ne(()=>{Pe();nu();hY=L(cn()),Ma=L(W());mc();pY=L(dt()),mY=L(kI());qr();EY=100,XI=Et({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),ME=Et({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,pY.getWorkerIndex)()===0&&(async()=>{await mY.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of ME.search({})){let t=e.data,r={...e};r.user?.username&&(r.user=await it.getUser(r.user.username));try{await ew(r,t,r)}catch{(0,Ma.warn)("Failed to publish will",t)}ME.delete(e.id)}})();a(SY,"getSession");dT=1;a(ZI,"getNextMessageId");_T=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;request;socket;subscriptions=[];awaitingAcks;sessionWasPresent;keepalive;keepaliveTimer;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),l,u;if(c>-1?(l=s.slice(c),u=s.slice(0,c)):u=s,!u)throw new Error("No topic provided");if(u.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let d=this.subscriptions.find(g=>g.topic===s),_;d?(_=i>0,d.end(),this.subscriptions.splice(this.subscriptions.indexOf(d),1)):_=i===2;let E={search:l,async:!0,user:this.user,startTime:o,omitCurrent:_,url:""};o&&(0,Ma.trace)("Resuming subscription from",s,"from",o);let f=wi.getMatch(u,"mqtt");if(!f){let g=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw g.statusCode=404,g}if(E.url=f.relativeURL,E.url.indexOf("+")>-1||E.url.indexOf("#")>-1){let g=E.url.slice(1);if(g.indexOf("#")>-1&&g.indexOf("#")!==g.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(E.isCollection=!0,g.indexOf("+")===g.length-1)E.onlyChildren=!0,E.url="/"+g.slice(0,g.length-1);else{let S=g.split("/"),b;for(let H=0;H<S.length;H++)if(S[H].indexOf("+")>-1)if(S[H]==="+")b=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&b)throw new Error("Filters can not be combined");let I=!0;S[S.length-1]==="#"&&(S.length--,I=!1),b&&(n=a(H=>{let X=H.id;if(!Array.isArray(X)||I&&X.length!==S.length)return!1;for(let Y=0;Y<S.length;Y++)if(S[Y]!=="+"&&S[Y]!==X[Y])return!1;return!0},"filter"));let B=S.indexOf("+");E.url="/"+(B>-1?S.slice(0,B):S).concat("").join("/")}}let h=f.path,T=f.Resource,m=await Dt(E,async()=>{let g=this.createContext();g.topic=s,g.retainHandling=i;let S=await T.subscribe(E,g);if(!S)return;if(!S[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let b=(async()=>{for await(let I of S)try{let B;if(I.type&&I.type!=="put"&&I.type!=="delete"&&I.type!=="message"&&I.type!=="patch"||n&&!n(I))continue;r?(I.topic=s,B=this.needsAcknowledge(I)):(I.acknowledge?.(),B=ZI());let H=I.id;if(Array.isArray(H)&&(H=ru(H)),H==null&&(H=""),await this.listener(h+"/"+H,I.value,B,t)===!1)break;this.awaitingAcks?.size>EY?await new Promise(Y=>setTimeout(Y,this.awaitingAcks.size-EY)):await new Promise(setImmediate)}catch(B){(0,Ma.warn)(B)}})();return S});return m.topic=s,m.qos=t.qos,this.subscriptions.push(m),m}resume(){}needsAcknowledge(t){let r=ZI();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,{acknowledge:t.acknowledge})),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r.acknowledge())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),this.subscriptions.splice(this.subscriptions.indexOf(r),1),!0}async publish(t,r){return ew(t,r,this.createContext())}createContext(){let t={session:this,socket:this.socket,user:this.user,authorize:!0};return this.request&&(t.request=this.request,t.url=this.request.url,t.headers=this.request.headers),t}setListener(t){this.listener=t}disconnect(t){this.keepaliveTimer&&clearTimeout(this.keepaliveTimer);let r=this.createContext();Dt(r,async()=>{try{if(!t){let n=await ME.get(this.sessionId);n?.doesExist()&&await ew(n,n.data,r)}}finally{await ME.delete(this.sessionId)}}).catch(n=>{(0,Ma.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}receivedPacket(){this.keepalive&&(clearTimeout(this.keepaliveTimer),this.keepaliveTimer=setTimeout(()=>{this.socket?.destroy?this.socket.destroy(new Error("Keepalive timeout")):this.socket?.terminate()},this.keepalive*1500))}};a(ew,"publish");tw=class extends _T{static{a(this,"DurableSubscriptionsSession")}sessionRecord;constructor(t,r,n){super(t,r),this.sessionRecord=n||{id:t,subscriptions:[]}}async resume(){for(let t of this.sessionRecord.subscriptions||[])await this.resumeSubscription({omitCurrent:!0,topic:t.topic,qos:t.qos,startTime:t.startTime},!0,t.acks?r=>!t.acks.includes(r.localTime):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=ZI(),n={topic:t.topic,timestamp:t.localTime};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks?.get(t);if(!r)return;this.awaitingAcks?.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,Ma.trace)("Received ack",n,r.timestamp),this.sessionRecord.update();return}}for(let s of this.sessionRecord.subscriptions)s.topic===n&&(s.startTime=r.timestamp);this.sessionRecord.update()}async addSubscription(t,r){await this.resumeSubscription(t,r);let{qos:n,startTime:s}=t;return n>0&&!s&&this.saveSubscriptions(),t.qos}removeSubscription(t){let r=this.subscriptions.find(s=>s.topic===t),n=super.removeSubscription(t);return r.qos>0&&this.saveSubscriptions(),n}saveSubscriptions(){this.sessionRecord.subscriptions=this.subscriptions.map(t=>{let r=t.startTime;return r||(r=t.startTime=(0,hY.getNextMonotonicTime)()),(0,Ma.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),XI.put(this.sessionRecord)}}});var nw={};je(nw,{bypassAuth:()=>Kme,start:()=>Yme});function Kme(){bY=!0}function Yme({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new yY.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}=RY(u,T=>{u.send(T)},d,Promise.resolve(_).then(()=>d?.user),o);u.on("message",f),u.on("close",h),u.on("error",T=>{dr.info?.("WebSocket error",T)})},{...n})),(t||s)&&c.push(e.socket(async u=>{let d;if(o.events.emit("connection",u),dr.debug?.(`Received ${u.getCertificate?"SSL":"TCP"} connection for MQTT from ${u.remoteAddress}`),l){if(u.authorized)try{let f=l.user;if(f!==null){(f===void 0||f==="Common Name"||f==="CN")&&(f=u.getPeerCertificate().subject.CN);try{d=await e.getUser(f,null,null),(0,Sd.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ET.notify?.({username:d?.username,status:kr.AUTH_AUDIT_STATUS.SUCCESS,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:u.remoteAddress})}catch(h){throw(0,Sd.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ET.error?.({username:f,status:kr.AUTH_AUDIT_STATUS.FAILURE,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:u.remoteAddress}),h}}else dr.debug?.("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",u.remoteAddress)}catch(f){o.events.emit("error",f,u),dr.error?.(f)}else if(l.required)return dr.info?.(`Unauthorized connection attempt, no authorized client certificate provided, error: ${u.authorizationError}`),u.end()}!d&&bY&&u.remoteAddress.includes("127.0.0.1")&&(d=await(0,AY.getSuperUser)(),dr.debug?.("Auto-authorizing local connection",d?.username));let{onMessage:_,onClose:E}=RY(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 RY(e,t,r,n,s){gY||(gY=!0,k_(_=>{fT>0&&_.push({metric:"mqtt-connections",connections:fT,byThread:!0})}));let i;fT++;let o,c={protocolVersion:4},l=(0,hT.parser)({protocolVersion:5});function u(_){l.parse(_)}a(u,"onMessage");function d(){fT--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),qn(!1,"connection","mqtt","disconnect"),dr.debug?.("MQTT connection was closed",e.remoteAddress))}return a(d,"onClose"),l.on("packet",async _=>{n?.then&&(n=await n);let E=_.cmd;if(o)o.then&&await o;else if(E!=="connect"){dr.info?.("Received packet before connection was established, closing connection"),e?.destroy?e.destroy():e?.terminate();return}let f=_.topic,h=f?.indexOf("/",1),T=h>0?f.slice(0,h):f;pr(_.length,"bytes-received",T,g(_),"mqtt");try{switch(o?.receivedPacket?.(),E){case"connect":if(c.protocolVersion=_.protocolVersion,_.username)try{n=await it.getUser(_.username,_.password.toString(),r),(0,Sd.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ET.notify?.({username:n?.username,status:kr.AUTH_AUDIT_STATUS.SUCCESS,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(V){return(0,Sd.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ET.error?.({username:_.username,status:kr.AUTH_AUDIT_STATUS.FAILURE,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",_,e,V),qn(!1,"connection","mqtt","connect"),m({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",_,e),qn(!1,"connection","mqtt","connect"),m({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(_,n),_.will){let V=e.deserialize||(e.deserialize=bo(r?.headers.get?.("content-type")));_.will.data=_.will.payload?.length>0?V(_.will.payload):void 0,delete _.will.payload}o=SY({user:n,..._}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(V){return dr.error?.(V),s.events.emit("auth-failed",_,e,V),qn(!1,"connection","mqtt","connect"),m({cmd:"connack",reasonCode:V.code||5,returnCode:V.code||128})}s.events.emit("connected",o,e),qn(!0,"connection","mqtt","connect"),m({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0}),o.setListener((V,ne,Q,de)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",V);let j=V.indexOf("/",1),ae=j>0?V.slice(0,j):V;m({cmd:"publish",topic:V,payload:S(ne),messageId:Q||Math.floor(Math.random()*1e8),qos:de.qos},ae);let Ae=e._socket??e;return Ae.writableNeedDrain?new Promise(ye=>Ae.once("drain",ye)):!Ae.closed}catch(j){return dr.error?.(j),o?.disconnect(),s.sessions.delete(o),!1}}),o.sessionWasPresent&&await o.resume();break;case"subscribe":let b=[];for(let V of _.subscriptions){let ne;try{let Q=await o.addSubscription(V,V.qos>=1);ne=Q?Q.qos||0:c.protocolVersion<5?128:143}catch(Q){s.events.emit("error",Q,e,V,o),Q.statusCode?Q.statusCode===500?dr.warn?.(Q):dr.info?.(Q):dr.error?.(Q),ne=c.protocolVersion<5?128:Q.statusCode===403?135:Q.statusCode===404?143:128}b.push(ne)}await o.committed,m({cmd:"suback",granted:b,messageId:_.messageId});break;case"unsubscribe":{let V=[];for(let ne of _.unsubscriptions)V.push(o.removeSubscription(ne)?0:17);m({cmd:"unsuback",granted:V,messageId:_.messageId});break}case"pubrel":m({cmd:"pubcomp",messageId:_.messageId,reasonCode:0});return;case"publish":let I=_.qos===2?"pubrec":"puback",B=e.deserialize||(e.deserialize=bo(r?.headers.get?.("content-type"))),X=(_.payload?.length||0)>0?B(_.payload):void 0,Y;try{Y=await o.publish(_,X)}catch(V){s.events.emit("error",V,e,_,o),dr.warn?.(V),_.qos>0&&m({cmd:I,messageId:_.messageId,reasonCode:128},_.topic);break}_.qos>0&&m({cmd:I,messageId:_.messageId,reasonCode:Y===!1?144:0},_.topic);break;case"pubrec":m({cmd:"pubrel",messageId:_.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(_.messageId);break;case"pingreq":m({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),qn(!0,"connection","mqtt","disconnect"),dr.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(b){s.events.emit("error",b,e,_,o),dr.error?.(b),m({cmd:"disconnect"})}function m(b,I){let B=(0,hT.generate)(b,c);t(B),pr(B.length,"bytes-sent",I,g(b),"mqtt")}a(m,"sendPacket");function g(b){return b.qos>0?b.cmd+",qos="+b.qos:b.cmd}a(g,"packetMethodName");function S(b){return Wc(b,r)}a(S,"serialize")}),l.on("error",_=>{dr.warn("MQTT parsing error, closing connection:",_.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:u,onClose:d}}var hT,AY,Sd,kr,rw,yY,ET,dr,bY,gY,fT,OY=Ne(()=>{hT=require("mqtt-packet");TY();AY=L(xn());jc();Ni();qr();Sd=L(se()),kr=L(M()),rw=L(bc()),yY=require("events"),ET=(0,rw.loggerWithTag)("auth-event"),dr=(0,rw.loggerWithTag)("mqtt"),bY=(0,Sd.get)(kr.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(Kme,"bypassAuth");a(Yme,"start");fT=0;a(RY,"onSocket")});var Qf={};je(Qf,{component_errors:()=>gd,getComponentName:()=>Jme,loadComponent:()=>ST,loadComponentDirectories:()=>LY,setErrorReporter:()=>Qme});function LY(e,t){t&&(iw=t),e&&(ow=e);let r=[];if((0,Nt.existsSync)(sw)){let s=(0,Nt.readdirSync)(sw,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,Ot.join)(sw,o);r.push(ST(c,iw,"hdb",!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(ST(n,iw,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{PY=!0})}function Qme(e){UE=e}async function ST(e,t,r,n,s,i){let o=(0,Nt.realpathSync)(e);if(pT.has(o))return pT.get(o);pT.set(o,!0),s&&(ow=s);try{let c;n&&(gd=new Map);let l=(0,Ot.join)(e,n?"harperdb-config.yaml":"config.yaml");(0,Nt.existsSync)(l)?c=n?(0,TT.getConfigObj)():(0,IY.parseDocument)((0,Nt.readFileSync)(l,"utf8")).toJSON():c=aw;let u=(0,Ot.join)(e,"node_modules","harperdb");try{ml.isMainThread&&(n||(0,Nt.existsSync)(u)&&(0,Nt.realpathSync)(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){Td.default.error("Error symlinking harperdb module",E)}let d=mT,_=n;for(let E in c){mT=E;let f=c[E];if(gd.set(n?E:(0,Ot.basename)(e),!1),!f)continue;let h,T=f.package;try{if(T){let I=e,B;for(;!(0,Nt.existsSync)(B=(0,Ot.join)(I,"node_modules",E));)if(I=(0,Ot.dirname)(I),I.length<(0,DY.getHdbBasePath)().length){B=null;break}if(B)h=await ST(B,t,r,!1),_=!0;else throw new Error(`Unable to find package ${E}:${T}`)}else h=zme[E];if(!h)continue;let m=a(I=>(I.origin=r,Et(I)),"ensureTable"),g=f.network||(f.port||f.securePort)&&f,S=g?.securePort||g?.https&&g.port,b=!g?.https&&g?.port;if(ml.isMainThread&&(h=await h.startOnMainThread?.({server:it,ensureTable:m,port:b,securePort:S,resources:t,...f})||h,n&&g))for(let I of[b,S])try{if(+I&&!NY.includes(I)){let B=cw.get(Ad.CONFIG_PARAMS.HTTP_SESSIONAFFINITY);B&&Td.default.warn("Session affinity is not recommended and may cause memory leaks"),(B||!US)&&(NY.push(I),VI(I,B))}}catch(B){console.error("Error listening on socket",I,B,E)}if(t.isWorker&&(h=await h.start?.({server:it,ensureTable:m,port:b,securePort:S,resources:t,...f})||h),ow.set(h,!0),(h.handleFile||h.handleDirectory||h.setupFile||h.setupDirectory)&&f.files!=null){if(f.files.includes(".."))throw(0,CY.handleHDBError)("Can not reference parent directories");let I=(0,Ot.join)(e,f.files).replace(/\\/g,"/"),B=I.indexOf("/*");if(B>-1&&f.files!==aw[E]?.files&&!(0,Nt.existsSync)(I.slice(0,B)))throw new Error(`The path '${I.slice(0,B)}' does not exist and cannot be used as the base of the resolved 'files' path value '${f.files}'`);let H=(0,Ot.basename)(e),X=f.path||"/";X=X.startsWith("/")?X:X.startsWith("./")?"/"+H+X.slice(2):X==="."?"/"+H:"/"+H+"/"+X;let Y,V,ne;if(f.root){let de=f.root;de.startsWith("/")&&(de=de.slice(1)),de.endsWith("/")&&(de=de.slice(0,-1)),de+="/",V=(0,Ot.join)(e,de)}else(ne=I.indexOf("/*"))>-1?(V=I.slice(0,ne+1),Y=(0,Ot.relative)(e,V)):f.files.indexOf("/")>-1&&(V=I.slice(0,I.lastIndexOf("/")+1),Y=(0,Ot.relative)(e,V));let Q=!1;if(ml.isMainThread&&h.setupDirectory&&(Q=await h.setupDirectory?.(X,V,t)),t.isWorker&&h.handleDirectory&&(Q=await h.handleDirectory?.(X,V,t)),Q){_=!0;continue}for(let de of await(0,wY.default)(I,{onlyFiles:!1,objectMode:!0})){let{path:j,dirent:ae}=de;_=!0;let Ae=(0,Ot.relative)(e,j).replace(/\\/g,"/");if(Y)if(Ae.startsWith(Y))Ae=Ae.slice(Y.length+1);else throw new Error(`The root path '${f.root}' does not reference a valid part of the file path '${Ae}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let ye=X+(X.endsWith("/")?"":"/")+Ae;try{if(ae.isFile()){let Me=await jme(j);ml.isMainThread&&await h.setupFile?.(Me,ye,j,t),t.isWorker&&await h.handleFile?.(Me,ye,j,t)}else ml.isMainThread&&await h.setupDirectory?.(ye,j,t),t.isWorker&&await h.handleDirectory?.(ye,j,t)}catch(Me){Me.message=`Could not load ${ae.isFile()?"file":"directory"} '${j}'${f.module?" using '"+f.module+"'":""} for application '${e}' due to: ${Me.message}`,UE?.(Me),((0,Rd.getWorkerIndex)()===0?console:Td.default).error(Me),t.set(f.path||"/",new ea(Me)),gd.set(n?E:(0,Ot.basename)(e),Me.message)}}}}catch(m){m.message=`Could not load component '${E}' for application '${(0,Ot.basename)(e)}' due to: ${m.message}`,UE?.(m),((0,Rd.getWorkerIndex)()===0?console:Td.default).error(m),t.set(f.path||"/",new ea(m),null,!0),gd.set(n?E:(0,Ot.basename)(e),m.message)}}if(mT=d,ml.isMainThread&&!PY&&i&&(0,Rd.watchDir)(e,async()=>LY()),c.extensionModule){let E=await bS((0,Ot.join)(e,c.extensionModule));return pT.set(o,E),E}if(!_&&t.isWorker){let E=`${e} did not load any modules, resources, or files, is this a valid component?`;UE?.(new Error(E)),((0,Rd.getWorkerIndex)()===0?console:Td.default).error(E),gd.set((0,Ot.basename)(e),E)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,UE?.(c),t.set("",new ea(c))}}var Nt,Ot,ml,IY,cw,Ad,wY,Rd,Td,CY,DY,Wme,TT,jme,sw,ow,PY,iw,gd,zme,aw,NY,pT,UE,mT,Jme,Jf=Ne(()=>{Nt=require("fs"),Ot=require("path"),ml=require("worker_threads"),IY=require("yaml"),cw=L(se()),Ad=L(M());ID();J$();tV();iV();oV();gV();ZV();i1();wY=L(require("fast-glob")),Rd=L(dt()),Td=L(W());ON();qr();CY=L(_e());Pe();CI();DY=L(se()),Wme=L(iY());km();fY();us();OY();TT=L(wt());vS();fy();({readFile:jme}=Nt.promises),sw=(0,TT.resolvePath)(cw.get(Ad.CONFIG_PARAMS.COMPONENTSROOT)),ow=new Map,gd=new Map;a(LY,"loadComponentDirectories");zme={REST:CS,rest:CS,graphql:yN,graphqlSchema:Pg,roles:bN,jsResource:IN,fastifyRoutes:WN,login:CN,static:jN,operationsApi:Wme,customFunctions:{},http:{},clustering:JI,replication:ca,authentication:Hf,mqtt:nw},aw={rest:!0,graphql:!0,graphqlSchema:{files:"*.graphql"},roles:{files:"roles.yaml"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(aw,"static",{value:{files:"web/**"}});NY=[],pT=new Map;a(Qme,"setErrorReporter");Jme=a(()=>mT,"getComponentName");a(ST,"loadComponent")});var nT=N((hMe,UY)=>{var{isMainThread:MY}=require("worker_threads"),{getTables:Xme,getDatabases:fMe,table:EMe}=(Pe(),oe(lt)),{loadComponentDirectories:Zme,loadComponent:eSe}=(Jf(),oe(Qf)),{resetResources:tSe}=(nu(),oe(iB)),rSe=SO(),nSe=wt(),{dirname:sSe}=require("path"),{getConnection:iSe}=mr(),oSe=se(),{CONFIG_PARAMS:aSe}=M(),{loadCertificates:cSe}=Xs(),lw=new Map;async function lSe(e=!1){!MY&&oSe.get(aSe.CLUSTERING_ENABLED)&&iSe();try{MY&&await rSe()}catch(n){console.error(n)}let t=tSe();Xme(),t.isWorker=e,await cSe(),await eSe(sSe(nSe.getConfigFilePath()),t,"hdb",!0,lw),await Zme(lw,t);let r=[];for(let[n]of lw)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(lSe,"loadRootComponents");UY.exports.loadRootComponents=lSe});var dt=N((mMe,ai)=>{"use strict";var{Worker:uSe,MessageChannel:dSe,parentPort:Vi,isMainThread:Ew,threadId:_Se,workerData:Ki}=require("worker_threads"),{PACKAGE_ROOT:fSe}=M(),{join:xY,isAbsolute:ESe,extname:hSe}=require("path"),{server:kY}=(qr(),oe(Qa)),{watch:pSe,readdir:mSe}=require("fs/promises"),{totalmem:vY}=require("os"),vE=M(),FY=se(),Yi=W(),{randomBytes:SSe}=require("crypto"),{_assignPackageExport:TSe}=fi(),gSe=M(),BY=1024*1024,Ua=[],Ps=[],RSe=50,hw=1e4,ASe="restart",GY="request_thread_info",qY="resource_report",$Y="thread_info",VY="added-port",ySe="ack",uw;TSe("threads",Ps);ai.exports={startWorker:dw,restartWorkers:mw,shutdownWorkers:wSe,workers:Ua,setMonitorListener:BSe,onMessageFromWorkers:CSe,onMessageByType:JY,broadcast:PSe,broadcastWithAcknowledgement:MSe,setChildListenerByType:ISe,getWorkerIndex:KY,getWorkerCount:YY,getTicketKeys:jY,setMainIsWorker:OSe,setTerminateTimeout:bSe,restartNumber:Ki?.restartNumber||1};Ps.onMessageByType=JY;Ps.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=Ps.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};ai.exports.whenThreadsStarted=new Promise(e=>{ai.exports.threadsHaveStarted=e});var pw;function bSe(e){hw=e}a(bSe,"setTerminateTimeout");function KY(){return Ki?Ki.workerIndex:pw?0:void 0}a(KY,"getWorkerIndex");function YY(){return Ki?Ki.workerCount:pw?1:void 0}a(YY,"getWorkerCount");function OSe(e){pw=e,ai.exports.threadsHaveStarted()}a(OSe,"setMainIsWorker");var WY=1,gT;function jY(){return gT||(gT=Ew?SSe(48):Ki.ticketKeys,gT)}a(jY,"getTicketKeys");Object.defineProperty(kY,"workerIndex",{get(){return KY()}});Object.defineProperty(kY,"workerCount",{get(){return YY()}});var zY={[GY](e,t){USe(t)},[qY](e,t){vSe(t,e)}};function dw(e,t={}){let r=process.constrainedMemory?.()||vY();r=Math.min(r,vY(),2e4*BY);let n=FY.get(vE.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/BY/(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 dSe;u.existingPort=l,i.push(u),o.push(u.port2)}hSe(e)||(e+=".js");let c=new uSe(ESe(e)?e:xY(fSe,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:WY=t.threadCount,name:t.name,restartNumber:ai.exports.restartNumber,ticketKeys:jY()},transferList:o,...t});for(let{port1:l,existingPort:u}of i)u.postMessage({type:VY,port:l,threadId:c.threadId},[l]);return AT(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>dw(e,t),c.on("error",l=>{Yi.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{Ua.splice(Ua.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<RSe?(t.unexpectedRestarts=c.unexpectedRestarts+1,dw(e,t)):Yi.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{zY[l.type]?.(l,c)}),Ua.push(c),xSe(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(dw,"startWorker");var NSe=[vE.THREAD_TYPES.HTTP];async function mw(e=null,t=Math.max(WY>3,1),r=!0){if(Ew){if(r){let{loadRootComponents:o}=nT();await o()}ai.exports.restartNumber++,t<1&&(t=t*Ua.length);let n=[],s=[];for(let o of Ua.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;Yi.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:ai.exports.restartNumber,type:vE.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=NSe.indexOf(o.name)>-1,l=new Promise(u=>{let d=setTimeout(()=>{Yi.warn("Thread did not voluntarily terminate, terminating from the outside",o.threadId),o.terminate()},hw*2).unref();o.on("exit",()=>{clearTimeout(d),n.splice(n.indexOf(l)),!c&&r&&o.startCopy(),u()})});if(n.push(l),c&&r){let u=o.startCopy(),d=new Promise(_=>{let E=a(f=>{f.type===gSe.ITC_EVENT_TYPES.CHILD_STARTED&&(Yi.trace("Worker has started",u.threadId),_(),s.splice(s.indexOf(d)),u.off("message",E))},"startListener");Yi.trace("Waiting for worker to start",u.threadId),u.on("message",E)});s.push(d),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=Gu();r&&(e==="http"||!e)&&FY.get(vE.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else Vi.postMessage({type:ASe,workerType:e})}a(mw,"restartWorkers");function ISe(e,t){zY[e]=t}a(ISe,"setChildListenerByType");function wSe(e){return mw(e,1/0,!1)}a(wSe,"shutdownWorkers");var QY=[];function CSe(e){QY.push(e)}a(CSe,"onMessageFromWorkers");var _w=new Map;function JY(e,t){let r=_w.get(e);r||_w.set(e,r=[]),r.push(t)}a(JY,"onMessageByType");var DSe=10;async function PSe(e,t){let r=0;for(let n of Ps)try{n.postMessage(e),r++>DSe&&(r=0,await new Promise(setImmediate))}catch(s){Yi.error("Unable to send message to worker",s)}t&&ZY(e,null)}a(PSe,"broadcast");var RT=new Map,LSe=1;function MSe(e){return new Promise(t=>{let r=0;for(let n of Ps)try{let s=LSe++,i=a(()=>{RT.delete(s),--r===0&&t(),n!==Vi&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,RT.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of RT)o.port===n&&o()})),n.postMessage(e),r++}catch(s){Yi.error("Unable to send message to worker",s)}r===0&&t()})}a(MSe,"broadcastWithAcknowledgement");function USe(e){e.postMessage({type:$Y,workers:XY()})}a(USe,"sendThreadInfo");function XY(){let e=Date.now();return Ua.map(t=>({threadId:t.threadId,name:t.name,heapTotal:t.resources?.heapTotal,heapUsed:t.resources?.heapUsed,externalMemory:t.resources?.external,arrayBuffers:t.resources?.arrayBuffers,sinceLastUpdate:e-t.resources?.updated,...t.recentELU}))}a(XY,"getChildWorkerInfo");function vSe(e,t){e.resources=t,e.resources.updated=Date.now()}a(vSe,"recordResourceReport");var fw;function BSe(e){fw=e}a(BSe,"setMonitorListener");var HSe=1e3,HY=!1;function xSe(){HY||(HY=!0,setInterval(()=>{for(let e of Ua){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}fw&&fw()},HSe).unref())}a(xSe,"startMonitoring");var kSe=1e3;if(Vi&&Ki?.addPorts){AT(Vi);for(let e=0,t=Ki.addPorts.length;e<t;e++){let r=Ki.addPorts[e];r.threadId=Ki.addThreadIds[e],AT(r)}setInterval(()=>{let e=process.memoryUsage();Vi.postMessage({type:qY,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},kSe).unref(),uw=a(()=>new Promise((e,t)=>{Vi.on("message",r),Vi.postMessage({type:GY});function r(n){n.type===$Y&&(Vi.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else uw=XY;ai.exports.getThreadInfo=uw;function AT(e,t){Ps.push(e),e.on("message",r=>{if(r.type===VY)r.port.threadId=r.threadId,AT(r.port);else if(r.type===ySe){let n=RT.get(r.id);n&&n()}else ZY(r,e)}).on("close",()=>{Ps.splice(Ps.indexOf(e),1)}).on("exit",()=>{Ps.splice(Ps.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(AT,"addPort");function ZY(e,t){for(let n of QY)n(e,t);let r=_w.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){Yi.error(s)}}a(ZY,"notifyMessageListeners");if(Ew){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await mSe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(xY(s,o.name));try{for await(let{filename:o}of pSe(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await mw(),console.log("Reloaded HarperDB components, changed files:",Array.from(r)),r.clear()},100)}catch(o){console.warn("Error trying to watch component directory",s,o)}},"watch_dir");ai.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else Vi.on("message",async e=>{let{type:t}=e;t===vE.ITC_EVENT_TYPES.SHUTDOWN&&(ai.exports.restartNumber=e.restartNumber,Vi.unref(),setTimeout(()=>{Yi.warn("Thread did not voluntarily terminate",_Se),process.exit(0)},hw).unref())})});var dv={};je(dv,{AUDIT_STORE_OPTIONS:()=>Pf,Decoder:()=>Dc,HAS_CURRENT_RESIDENCY_ID:()=>tc,HAS_EXPIRATION_EXTENDED_TYPE:()=>o_,HAS_ORIGINATING_OPERATION:()=>i_,HAS_PREVIOUS_RESIDENCY_ID:()=>rc,REMOTE_SEQUENCE_UPDATE:()=>Kp,createAuditEntry:()=>Ml,getLastRemoved:()=>Yy,openAuditStore:()=>IT,readAuditEntry:()=>Ht,removeAuditEntry:()=>wT,setAuditRetention:()=>GSe,transactionKeyEncoder:()=>lW});function IT(e){let t=e.auditStore=e.openDB(Sw.AUDIT_STORE_NAME,{create:!1,...Pf});t||(t=e.auditStore=e.openDB(Sw.AUDIT_STORE_NAME,Pf),tW(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>=FSe){i=10;break}await c}finally{o===0?i=Math.min(i<<1,Tw/10):tW(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&&!eW)for(let i of t.getKeys({reverse:!0,limit:1}))i>Date.now()&&(eW=!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((qSe(r)&15)===gw){let n=Ht(r),s=n.tableId;e.deleteCallbacks?.[s]?.(n.recordId)}return e.remove(t)}function tW(e,t){Rw[0]=t,e.put(Symbol.for("last-removed"),uW)}function Yy(e){let t=e.get(Symbol.for("last-removed"));if(t)return uW.set(t),Rw[0]}function GSe(e,t=yT){Tw=e,yT=t}function Ml(e,t,r,n,s,i,o,c,l,u,d,_,E){let f=dW[o];if(!f)throw new Error(`Invalid audit entry type ${o}`);let h=1;if(n&&(n>1?va.setFloat64(0,n):Ls.set(jg),h=9),l){if(l&16761087)throw new Error("Illegal extended type");h++}g(s),g(t),m(r),va.setFloat64(h,e),h+=8,l&tc&&g(u),l&rc&&g(d),l&o_&&(va.setFloat64(h,_),h+=8),l&i_&&g(_W[E]),i?m(i):Ls[h++]=0,l?va.setUint16(n?8:0,f|l|32768):Ls[n?8:0]=f;let T=Ls.subarray(0,h);if(c)return Buffer.concat([T,c]);return T;function m(S){let b=h;h+=1,h=(0,Sl.writeKey)(S,Ls,h);let I=h-b-1;I>127?I>16383?(NT.error("Key or username was too large for audit entry",S),h=b+1,Ls[b]=0):(Ls.copyWithin(b+2,b+1,h),va.setUint16(b,I|32768),h++):Ls[b]=I}function g(S){S<128?Ls[h++]=S:S<16384?(va.setUint16(h,S|32768),h+=2):S<1056964608?(va.setUint32(h,S|3221225472),h+=4):(Ls[h]=255,va.setUint32(h+1,S),h+=5)}}function qSe(e){let t=0;e[0]==66&&(t=8);let r=e[t];if(r<128)return r;let n=e.dataView||(e.dataView=new Dc(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function Ht(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new Dc(e.buffer,e.byteOffset,e.byteLength));n.position=t;let s;e[n.position]==66&&(s=n.readFloat64());let i=n.readInt(),o=n.readInt(),c=n.readInt(),l=n.readInt(),u=n.position,d=n.position+=l,_=n.readFloat64(),E,f,h,T;if(i&tc&&(E=n.readInt()),i&rc&&(f=n.readInt()),i&o_&&(h=n.readFloat64()),i&i_){let S=n.readInt();T=_W[S]}l=n.readInt();let m=n.position,g=n.position+=l;return{type:dW[i&7],tableId:c,nodeId:o,get recordId(){return(0,Sl.readKey)(e,u,d)},getBinaryRecordId(){return e.subarray(u,d)},version:_,previousLocalTime:s,get user(){return g>m?(0,Sl.readKey)(e,m,g):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(S,b,I){if(i&bT||i&BE&&!b)return S.decoder.decode(e.subarray(n.position,r));if(i&BE&&I)return 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 Sl,OT,Sw,aW,HE,cW,NT,Ls,va,lW,Pf,Tw,FSe,Rw,uW,yT,eW,bT,BE,rW,gw,nW,sW,iW,oW,Kp,tc,rc,i_,o_,dW,_W,Dc,Ji=Ne(()=>{Sl=require("ordered-binary"),OT=L(se()),Sw=L(Bt()),aW=L(M()),HE=L(dt()),cW=L(te());Ul();NT=L(W());CT();(0,OT.initSync)();Ls=Buffer.alloc(1024),va=new DataView(Ls.buffer,Ls.byteOffset,1024),lW={writeKey(e,t,r){return e===s_?(t.set(s_,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,Sl.writeKey)(e,t,r)},readKey(e,t,r){return e[t]===66?(e.dataView||(e.dataView=new DataView(e.buffer,e.byteOffset,e.byteLength))).getFloat64(t):(0,Sl.readKey)(e,t,r)}},Pf={encoding:"binary",keyEncoder:lW},Tw=(0,cW.convertToMS)((0,OT.get)(aW.CONFIG_PARAMS.LOGGING_AUDITRETENTION))||86400*3,FSe=1e3,Rw=new Float64Array(1),uW=new Uint8Array(Rw.buffer),yT=1e4,eW=!1;a(IT,"openAuditStore");a(wT,"removeAuditEntry");a(tW,"updateLastRemoved");a(Yy,"getLastRemoved");a(GSe,"setAuditRetention");bT=16,BE=32,rW=1,gw=2,nW=3,sW=4,iW=5,oW=6,Kp=11,tc=512,rc=1024,i_=2048,o_=4096,dW={put:rW|bT,[rW]:"put",delete:gw,[gw]:"delete",message:nW|bT,[nW]:"message",invalidate:sW|BE,[sW]:"invalidate",patch:iW|BE,[iW]:"patch",relocate:oW,[oW]:"relocate"},_W={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};a(Ml,"createAuditEntry");a(qSe,"readAction");a(Ht,"readAuditEntry");Dc=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t;return t=this.getUint8(this.position++),t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch(t){throw t.message=`Error reading float64: ${t.message} at position ${this.position}`,t}}}});var yw={};je(yw,{add:()=>DT,applyReverse:()=>fW,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 fW(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=$Se[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=EW}}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=Ht(l);switch(u.type){case"put":s=u.getValue(r);break;case"patch":fW(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===EW&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),u=Ht(l),d;switch(u.type){case"put":d=u.getValue(r);break;case"patch":d=u.getValue(r);break}for(let _ in d)o[_]&&(s[_]=d[_],o[_]=!1,c--);i=u.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var $Se,EW,CT=Ne(()=>{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)};$Se={add:DT};a(PT,"rebuildUpdateBefore");a(fW,"applyReverse");EW={};a(Aw,"getRecordAtTime")});function Zn(e){return e[_r]||(e[_r]=Object.create(null))}function BT(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let o of s){let c=o.name,l,u;if(o.resolve)u={get(){return o.resolve(this,this[ke])},set(d){return o.set(this,d)},configurable:!0};else{switch(o.type){case"String":l=a(function(d){if(!(typeof d=="string"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a string, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"ID":l=a(function(d){if(!(typeof d=="string"||d?.length>0&&d.every?.(_=>typeof _=="string")||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a string, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Float":case"Number":l=a(function(d){let _=d?.__op__?d.value:d;if(!(typeof _=="number"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a number, attempt to assign ${_}`);Zn(this)[c]=d},"set");break;case"Int":l=a(function(d){let _=d?.__op__?d.value:d;if(!(_>>0===_||d==null&&o.nullable!==!1))if(typeof _=="number"&&Math.abs((_>>0)-_)<=1)_=Math.round(_),d?.__op__?d.value=_:d=_;else throw new Ms.ClientError(`${c} must be an integer between -2147483648 and 2147483647, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Long":l=a(function(d){let _=d?.__op__?d.value:d;if(!(Math.round(_)===d&&Math.abs(_)<=9007199254740992||d==null&&o.nullable!==!1))if(typeof _=="number"&&Math.abs(_)<=9007199254740992)_=Math.round(_),d?.__op__?d.value=_:d=_;else throw new Ms.ClientError(`${c} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"BigInt":l=a(function(d){let _=d?.__op__?d.value:d;if(!(typeof _=="bigint"||d==null&&o.nullable!==!1))if(typeof _=="string"||typeof _=="number")_=BigInt(_),d?.__op__?d.value=_:d=_;else throw new Ms.ClientError(`${c} must be a number, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Boolean":l=a(function(d){if(!(typeof d=="boolean"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a boolean, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Date":l=a(function(d){if(!(d instanceof Date||d==null&&o.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=new Date(d);else throw new Ms.ClientError(`${c} must be a Date, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Bytes":l=a(function(d){if(!(d instanceof Uint8Array||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a Buffer or Uint8Array, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Any":case void 0:l=a(function(d){Zn(this)[c]=d},"set");break;default:l=a(function(d){if(!(typeof d=="object"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be an object, attempt to assign ${d}`);Zn(this)[c]=d},"set")}u={get(){let d=this[_r];if(d&&c in d){let E=d[c];if(E?.__op__){let f=this[ve]?.[c];return E.update(f)}return E}let _=this[ve]?.[c];if(_&&typeof _=="object"){let E=pW(_,o);if(E)return d||(d=this[_r]=Object.create(null)),d[c]=E}return _},set:l,enumerable:!0,configurable:!0}}u.get.isAttribute=!0,n[c]=u,(!(c in r)||Object.getOwnPropertyDescriptor(r,c)?.get?.isAttribute)&&Object.defineProperty(r,c,u)}i("getProperty",function(o){let c=n[o];if(c)return c.get.call(this);let l=this[_r];return l?.[o]!==void 0?l[o]:this[ve]?.[o]}),i("set",function(o,c){let l=n[o];if(l)return l.set.call(this,c);if(t.sealed)throw new Ms.ClientError("Can not add a property to a sealed table schema");Zn(this)[o]=c}),i("deleteProperty",function(o){Zn(this)[o]=void 0}),i("toJSON",function(){let o=this[_r],c;for(let u in o){c||(c={...this[ve]});let d=o[u];if(d?.__op__){let _=c[u];d=d.update(_)}c[u]=d}return Object.keys(this).length>0&&(c||(c={...this[ve]}),Object.assign(c,this)),c||this[ve]}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty);function i(o,c){Object.defineProperty(r,o,{value:c,configurable:!0})}a(i,"setMethod")}function pW(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=pW(o,t?.elements)),n[s]=o}return n;default:return e}}function dp(e){let t=e[_r],r;for(let s in t){r||(r={...e[ve]});let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=dp(i);r[s]=i}return Object.keys(e).length>0&&(r||(r={...e[ve]}),Object.assign(r,e)),r||e[ve]}function gl(e,t=e[_r]){let r;if(hW.call(e,ve)&&e.constructor===Array&&!Object.isFrozen(e)){r=e;for(let n=0,s=e.length;n<s;n++){let i=e[n];if(i&&typeof i=="object"){let o=gl(i);o!==i&&r===e&&(r=e.slice(0)),i=o}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r={...e[ve]});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=yw[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=gl(s);r[n]=s}return r?Object.freeze(r):hW.call(e,ve)?e[ve]:e}function MT(e){let t=e[ve];if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[Tl]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.[ve]===s){if(MT(i))return!0}else return!0}}else{let r=e[_r];if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s[ve]===i){if(MT(s))return!0}else return!0}else return!0}}return!1}var Ms,_r,LT,hW,Tl,UT,vT,_p=Ne(()=>{Vs();Ms=L(_e());CT();_r=Symbol("own-data");a(Zn,"getChanges");a(BT,"assignTrackedAccessors");a(pW,"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");hW=Object.prototype.hasOwnProperty;a(gl,"updateAndFreeze");a(MT,"hasChanges");Tl=Symbol.for("has-array-changes"),UT=class extends Array{static{a(this,"TrackedArray")}[Tl];constructor(t){super(t)}splice(...t){return this[Tl]=!0,super.splice(...t)}push(...t){return this[Tl]=!0,super.push(...t)}pop(){return this[Tl]=!0,super.pop()}unshift(...t){return this[Tl]=!0,super.unshift(...t)}shift(){return this[Tl]=!0,super.shift()}};UT.prototype.constructor=Array;vT=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var _A={};je(_A,{CONTEXT:()=>ke,ID_PROPERTY:()=>ze,IS_COLLECTION:()=>ci,MultiPartId:()=>xT,RECORD_PROPERTY:()=>ve,Resource:()=>Lr,snake_case:()=>KSe,transformForSelect:()=>kT});function KSe(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function mW(e,t){if(Rl=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(Rl=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new xT;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Rl=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return Rl=!0,null;e[e.length-1]==="/"&&(Rl=!0)}return t.coerceId(decodeURIComponent(e))}function es(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,l,u,d;if(r?(o?(d=i,o=o[ke]||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(d=s,c=d[this.primaryKey]??null,o=i[ke]||i):d=i:(d=s,s=void 0,c=d[ze]??d[this.primaryKey]),c===null&&(u=!0)):i?o=i[ke]||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="object"&&s){if(l=s,typeof(c=s.url)=="string"){let f=c.indexOf("?");if(f>-1){let T=this.parseQuery(c.slice(f+1));l?T&&(l=Object.assign(T,l)):l=T,c=c.slice(0,f)}let h=this.parsePath(c,o,l);h?.id!==void 0?(h.query&&(l?l=Object.assign(h.query,l):l=h.query),u=h.isCollection,c=h.id):c=h}else if(s[Symbol.iterator]){c=[],u=!0;for(let f of s){if(typeof f=="object"&&f)break;c.push(f)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=null,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new il(c),c==null&&(u=!0);o||(o={});let _;if(l?.ensureLoaded!=null||l?.async||u?(_={...t},l?.ensureLoaded!=null&&(_.ensureLoaded=l.ensureLoaded),l?.async&&(_.async=l.async),u&&(_.isCollection=!0)):_=t,o.transaction){let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)}else return Dt(o,()=>{let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)},_);function E(f){if(o.authorize){o.authorize=!1;let h=t.type==="read"?f.allowRead(o.user,l,o):t.type==="update"?f.doesExist?.()===!1?f.allowCreate(o.user,d,o):f.allowUpdate(o.user,d,o):t.type==="create"?f.allowCreate(o.user,d,o):f.allowDelete(o.user,l,o);if(h?.then)return h.then(T=>{if(!T)throw new HT(o.user);return typeof d?.then=="function"?d.then(m=>e(f,l,o,m)):e(f,l,o,d)});if(!h)throw new HT(o.user)}return typeof d?.then=="function"?d.then(h=>e(f,l,o,h)):e(f,l,o,d)}a(E,"authorizeActionOnResource")}}function ts(e,t){let r=new gW.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[ke],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 SW,TW,gW,ke,ze,ci,ve,VSe,Lr,HT,Rl,xT,Vs=Ne(()=>{SW=require("crypto");Pl();TW=L(fi()),gW=L(_e());_p();mc();_E();ke=Symbol.for("context"),ze=Symbol.for("primary-key"),ci=Symbol("is-collection"),ve=Symbol("stored-record"),VSe={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Lr=class{static{a(this,"Resource")}static transactions;constructor(t,r){this[ze]=t;let n=r?.[ke];this[ke]=n!==void 0?n:r||null}static get=es(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let l;if((l=r?.select)&&c!=null&&!c.selectApplied){let u=kT(l,t.constructor);return typeof c?.map=="function"?c.map(u):u(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=es(function(t,r,n,s){if(Array.isArray(s)&&t[ci]){let i=[],o=n.authorize;for(let c of s){let l=t.constructor,u=l.getResource(c[l.primaryKey],n,{async:!0});u.then?i.push(u.then(d=>d.put(c,n))):i.push(u.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):ts(t,"put")},{hasContent:!0,type:"update"});static patch=es(function(t,r,n,s){return t.patch?t.patch(s,r):ts(t,"patch")},{hasContent:!0,type:"update"});static delete=es(function(t,r,n,s){return t.delete?t.delete(r):ts(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,SW.randomUUID)()}static create(t,r,n){let s;return t==null?s=r?.[this.primaryKey]??this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=r?.[this.primaryKey]??[...t,this.getNewId()]:typeof t!="object"?s=r?.[this.primaryKey]??[t,this.getNewId()]:(s=t?.[this.primaryKey]??this.getNewId(),n=r||{},r=t),n||(n={}),Dt(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):ts(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=es(function(t,r,n,s){return t.invalidate?t.invalidate(r):ts(t,"delete")},{hasContent:!1,type:"update"});static post=es(function(t,r,n,s){return t[ze]!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=es(function(t,r,n,s){return t.connect?t.connect(s,r):ts(t,"connect")},{hasContent:!0,type:"read"});static subscribe=es(function(t,r,n,s){return t.subscribe?t.subscribe(r):ts(t,"subscribe")},{type:"read"});static publish=es(function(t,r,n,s){return t[ze]!=null&&t.update?.(),t.publish?t.publish(s,r):ts(t,"publish")},{hasContent:!0,type:"create"});static search=es(function(t,r,n,s){let i=t.search?t.search(r):ts(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=kT(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=es(function(t,r,n,s){return t.search?t.search(s,r):ts(t,"search")},{hasContent:!0,type:"read"});static copy=es(function(t,r,n,s){return t.copy?t.copy(s,r):ts(t,"copy")},{hasContent:!0,type:"create"});static move=es(function(t,r,n,s){return t.move?t.move(s,r):ts(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this[ci])return(await this.constructor.create(this[ze],t,this[ke]))[ze];ts(this,"post")}static isCollection(t){return t?.[ci]}static coerceId(t){return t}static parseQuery(t){return 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&&VSe[o];if(c)r.requestedContentType=c;else if(n)n.property=o;else return{query:{property:o},id:mW(t,this),isCollection:Rl}}let i=mW(t,this);return Rl?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r[ke],o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let u=l.asMap.get(t);if(s=u?.find(d=>d.constructor===c),s)return s;u||l.asMap.set(t,u=[]),u.push(s=new c(t,i))}else{if(s=l.find(u=>u[ze]===t&&u.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let u=new Map;for(let d of l){let _=d[ze],E=u.get(_);E?E.push(d):u.set(_,[d])}i.resourceCache.length=0,i.resourceCache.asMap=u}}}else s=new c(t,i);return o&&(s[ci]=!0),s}subscribe(t){return new Mn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new Mn}allowRead(t){return t?.role.permission.super_user}allowUpdate(t){return t?.role.permission.super_user}allowCreate(t){return t?.role.permission.super_user}allowDelete(t){return t?.role.permission.super_user}getId(){return this[ze]}getContext(){return this[ke]}};Lr.prototype[ke]=null;(0,TW._assignPackageExport)("Resource",Lr);a(KSe,"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(mW,"pathToId");xT=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(es,"transactional");a(ts,"missingMethod");a(bw,"selectFromObject");a(kT,"transformForSelect")});var GO={};je(GO,{EVICTED:()=>ya,INVALIDATED:()=>Ns,coerceType:()=>GT,makeTable:()=>VT,setServerUtilities:()=>eTe,updateResource:()=>qT});function VT(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:l,schemaDefined:u,dbisDB:d,sealed:_,splitSegments:E,replicate:f}=e,{expirationMS:h,evictionMS:T,audit:m,trackDeletes:g}=e,{attributes:S}=e;S||(S=[]);let b=Jg(i,n,l),I,B,H={},X=Promise.resolve(),Y,V,ne;for(let U of S)(U.assignCreatedTime||U.name==="__createdtime__")&&(Y=U),(U.assignUpdatedTime||U.name==="__updatedtime__")&&(V=U),U.expiresAt&&(ne=U),U.isPrimaryKey&&(H=U);let Q,de=[],j=[],ae=1,Ae=2,ye={},Me={},Gr=864e5,Cd,ka,wn,Dd=!1,Ol,vw=new Map,jE=new Map,vt,Fa,Ga=bd.get(Us.CONFIG_PARAMS.REPLICATION_DATABASES);if(Array.isArray(Ga)){for(let U of Ga)if(U.name===c&&U.replicateTo>=0){Fa=U.replicateTo;break}}let vs=i.getRange({start:!1,end:!1}).constructor,Bs=10,zE=6;m&&ie();class Ve extends Lr{static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=m;static databasePath=o;static databaseName=c;static attributes=S;static replicate=f;static sealed=_;static splitSegments=E??!0;static createdTimeProperty=Y;static updatedTimeProperty=V;static propertyResolvers;static userResolvers={};static sources=[];static get expirationMS(){return h}static dbisDB=d;static schemaDefined=u;static sourcedFrom(p,R){if(R&&(this.sourceOptions=R,(R.expiration||R.eviction||R.scanInterval)&&this.setTTLExpiration(R)),R?.intermediateSource)p.intermediateSource=!0,this.sources.unshift(p);else{if(this.sources.some(O=>!O.intermediateSource)){if(this.sources.some(O=>O.name===p.name))return;throw new Error("Can not have multiple canonical (non-intermediate) sources")}this.sources.push(p)}B=B||p.get&&(!p.get.reliesOnPrototype||p.prototype.get),I=I||p.load;let w=a(O=>{let v=this.sources;if(v=v.filter(k=>k.intermediateSource&&k[O]&&(!k[O].reliesOnPrototype||k.prototype[O])),v.length>0)if(v.length===1){let k=v[0];return(C,F,x)=>{if(C?.source!==k)return k[O](F,x,C)}}else return(k,C,F)=>{let x=[];for(let q of v){if(k?.source===q)break;x.push(q[O](C,F,k))}return Promise.all(x)}},"getApplyToIntermediateSource"),A=this.sources[this.sources.length-1];A.intermediateSource&&(A={});let y=a(O=>{if(A[O]&&(!A[O].reliesOnPrototype||A.prototype[O]))return(v,k,C)=>{if(!v?.source)return A[O](k,C,v)}},"getApplyToCanonicalSource");ye={put:y("put"),patch:y("patch"),delete:y("delete"),publish:y("publish")},Me={put:w("put"),patch:w("patch"),delete:w("delete"),publish:w("publish"),invalidate:w("invalidate")};let D=A.shouldRevalidateEvents;return(async()=>{let O=!1,v,k=a(async(C,F)=>{let x=C.value,q=C.table?We[c][C.table]:Ve;if(c===Us.SYSTEM_SCHEMA_NAME&&(C.table===Us.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||C.table===Us.SYSTEM_TABLE_NAMES.USER_TABLE_NAME)&&(O=!0),C.id===void 0&&(C.id=x[q.primaryKey],C.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(C));C.source=p;let ee={residencyId:tt(C.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:C.nodeId},G=await q.getResource(C.id,F,ee);switch(C.type){case"put":return D?G._writeInvalidate(ee):G._writeUpdate(x,!0,ee);case"patch":return D?G._writeInvalidate(ee):G._writeUpdate(x,!1,ee);case"delete":return G._writeDelete(ee);case"publish":return G._writePublish(x,ee);case"invalidate":return G._writeInvalidate(ee);case"relocate":return G._writeRelocate(ee);default:Ge.default.error?.("Unknown operation",C.type,C.id)}},"writeUpdate");try{let C=p.subscribe;C&&g==null&&(g=!0);let F={crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0},x=p.subscribeOnThisThread?p.subscribeOnThisThread((0,Al.getWorkerIndex)(),F):(0,Al.getWorkerIndex)()===0,q=C&&x&&await p.subscribe?.(F);if(q){let ee;for await(let G of q)try{if(!(G.type==="transaction"?G.writes[0]:G)){Ge.default.error?.("Bad subscription event",G);continue}if(G.source=p,G.type==="end_txn"){if(ee?.resolve(),G.localTime&&v!==G.localTime){if(G.remoteNodeIds?.length>0){let Re=[Symbol.for("seq"),G.remoteNodeIds[0]],re=d.get(Re),K=re?.nodes;K||(K=[]);for(let Be of G.remoteNodeIds.slice(1)){let Ie=K.find(ce=>ce.id===Be);K=K.filter(ce=>ce.id!==Be||ce===Ie),Ie||(Ie={id:Be,seqId:0},K.push(Ie)),Ie.seqId=Math.max(re?.seqId??1,G.localTime),Be===ee?.nodeId&&(Ie.lastTxnTime=G.timestamp)}let Te=Math.max(re?.seqId??1,G.localTime);Ge.default.trace?.("Received txn",c,Te,G.localTime,G.remoteNodeIds),d.put(Re,{seqId:Te,nodes:K})}v=G.localTime}G.onCommit&&ee?.committed.then(G.onCommit);continue}if(ee)if(G.beginTxn)ee.resolve();else{ee.write_promises.push(k(G,ee));continue}!G.timestamp&&G.version&&(G.timestamp=G.version);let Ee=Dt(G,()=>{if(G.type==="transaction"){let Re=[];for(let re of G.writes)try{Re.push(k(re,G))}catch(K){throw K.message+=" writing "+JSON.stringify(re)+" of event "+JSON.stringify(G),K}return Promise.all(Re)}else if(G.type==="define_schema"){let Re=this.attributes.slice(0),re;for(let K of G.attributes)Re.find(Te=>Te.name===K.name)||(Re.push(K),re=!0);re&&(Et({table:s,database:c,attributes:Re,origin:"cluster"}),GE.signalSchemaChange(new qE.SchemaEventMsg(process.pid,Us.OPERATIONS_ENUM.CREATE_TABLE,c,s)))}else return G.beginTxn?(ee=G,ee.write_promises=[k(G,G)],new Promise(Re=>{ee.resolve=()=>Re(Promise.all(ee.write_promises))})):k(G,G)});ee&&(ee.committed=Ee),O&&Ee&&!Ee?.waitingForUserChange&&(Ee.then(()=>GE.signalUserChange(new qE.UserEventMsg(process.pid))),Ee.waitingForUserChange=!0),G.onCommit&&(Ee?Ee.then(G.onCommit):G.onCommit())}catch(be){Ge.default.error?.("error in subscription handler",be)}}}catch(C){Ge.default.error?.(C)}})(),this}static get isCaching(){return B}static get shouldRevalidateEvents(){return this.prototype.get!==Ve.prototype.get}static getResource(p,R,w){let A=super.getResource(p,R,w);if(p!=null){ji(p);try{if(A.hasOwnProperty(ve))return A;if(typeof p=="object"&&p&&!Array.isArray(p))throw new Error(`Invalid id ${JSON.stringify(p)}`);let y=!w?.async||i.cache?.get?.(p),D=Ir(R),O=D.getReadTxn();if(O?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return $a(p,R,{transaction:O,ensureLoaded:w?.ensureLoaded},y,v=>{if(v?qT(A,v):A[ve]=null,R.onlyIfCached&&R.noCacheStore){if(!A.doesExist())throw new Nr.ServerError("Entry is not cached",504)}else if(w?.ensureLoaded){let k=Pd(p,v,R,A);if(k)return D?.disregardReadTxn(),A[Ow]=!0,Iw(k,C=>(qT(A,C),A))}return A})}catch(y){throw y.message.includes("Unable to serialize object")&&(y.message+=": "+JSON.stringify(p)),y}}return A}ensureLoaded(){let p=Pd(this[ze],this[Fr],this[ke]);if(p)return this[Ow]=!0,Iw(p,R=>{this[Fr]=R,this[ve]=R.value,this[kE]=R.version})}static getNewId(){let p=H?.type;if(p==="String"||p==="ID")return super.getNewId();if(!vt){let y=i.getEntry(Symbol.for("id_allocation")),D=y?.value,O;if(D&&D.nodeName===server.hostname&&(!rTe(i)||D.pid===process.pid)){let v=D.start,k=D.end;O=v;for(let C of i.getKeys({start:k,end:v,limit:1,reverse:!0}))O=C}else D=A(y?.version??null),O=D.start;vt=new BigInt64Array([BigInt(O)+1n]),vt=new BigInt64Array(i.getUserSharedBuffer("id",vt.buffer)),vt.maxSafeId=D.end}let R=Number(Atomics.add(vt,0,1n)),w=p==="Int"?512:1048576;if(R+w>=vt.maxSafeId){let y=a(D=>{vt.maxSafeId=R+(p==="Int"?1023:4194303);let O=(p==="Int"?Math.pow(2,31):Math.pow(2,49))-1,v=D?void 0:i.useReadTransaction(),k=Number(vt[0]);for(let x of i.getKeys({start:k+1,end:O,limit:1,transaction:v}))O=x;v?.done();let{value:C,version:F}=i.getEntry(Symbol.for("id_allocation"));if(vt.maxSafeId<O){if(C.end>vt.maxSafeId-100)return;Ge.default.info?.("New id allocation",R,vt.maxSafeId,F),i.put(Symbol.for("id_allocation"),{start:C.start,end:vt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),F)}else{Ge.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${vt.maxSafeId}, but id of ${O} detected`);let x=A(F);x.alreadyUpdated||Atomics.store(vt,0,BigInt(x.start+1)),vt.maxSafeId=x.end}},"updateEnd");R+w===vt.maxSafeId?setImmediate(y):R+100>=vt.maxSafeId&&(Ge.default.warn?.(`Synchronous id allocation required on table ${s}${p=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>y(!0)))}return R;function A(y){let D=(p==="Int"?Math.pow(2,31):Math.pow(2,49))-1,O=D/4,v,k,C=!1,F,x;do{F=Math.floor(Math.random()*D),x={start:F,end:F+(p==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},v=0;for(let q of i.getKeys({start:F,limit:1,reverse:!0}))v=q;k=D;for(let q of i.getKeys({start:F+1,end:D,limit:1}))k=q;O*=.875,O<1e3&&!C&&(C=!0,Ge.default.error?.(`Id allocation in table ${s} is very dense, limited safe range of numbers to allocate ids in${p==="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`,F,v,k,O))}while(!(O<k-F&&(O<F-v||v===0)));return i.transactionSync(()=>{let q=i.getEntry(Symbol.for("id_allocation"));return(q?.version??null)==y?(Ge.default.info?.("Allocated new id range",x),i.put(Symbol.for("id_allocation"),x,Date.now()),x):(Ge.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...q.value})})}}static setTTLExpiration(p){if(typeof p=="number")h=p*1e3,T||(T=0);else if(p&&typeof p=="object")h=p.expiration*1e3,T=(p.eviction||0)*1e3,Gr=p.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(h<0)throw new Error("Expiration can not be negative");Gr=Gr||(h+T)/4,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,R,w){if(Ve.getResidencyById)return Ve.getResidencyById(p[t]);let A=Fa;if(R.replicateTo!=null){if(Array.isArray(R.replicateTo))return R.replicateTo.includes(server.hostname)?R.replicateTo:[server.hostname,...R.replicateTo];R.replicateTo>=0&&(A=R.replicateTo)}if(A>=0&&server.nodes){let y=[server.hostname];if(w)y.push(...w.slice(0,A));else{let D=server.nodes.map(k=>k.name),O=Math.floor(D.length*Math.random());y.push(...D.slice(O,O+A));let v=O+A-D.length;v>0&&y.push(...D.slice(0,v))}return y}}static enableAuditing(p=!0){m=p,p&&ie(),Ve.audit=p}static coerceId(p){return p===""?null:GT(p,H)}static async dropTable(){if(delete We[c][s],c===o){for(let p of S)d.remove(Ve.tableName+"/"+p.name),r[p.name]?.drop();d.remove(Ve.tableName+"/"),i.drop(),await d.committed}else console.log("legacy dropTable"),await i.close(),await fs.remove(data_path),await fs.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));GE.signalSchemaChange(new qE.SchemaEventMsg(process.pid,Us.OPERATIONS_ENUM.DROP_TABLE,c,s))}get(p){if(typeof p=="string")return this.getProperty(p);if(this[ci])return this.search(p);if(this[ze]===null){if(p?.conditions)return this.search(p);let R=Ve.getRecordCount();return{recordCount:R.recordCount,estimatedRecordRange:R.estimatedRange,records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:S}}if(p?.property)return this.getProperty(p.property);if(this.doesExist()||p?.ensureLoaded===!1||this[ke]?.returnNonexistent)return this}allowRead(p,R){let w=Va(p);if(w?.read){if(w.isSuperUser)return!0;let A=w.attribute_permissions,y=R?.select;if(A?.length>0||Dd&&y){if(R||(R={}),y){let D=A?.length>0&&Nw(A,"read");R.select=y.map(O=>{let v=O.name||O;if(!D||D[v]){let k=wn[v]?.definition?.tableClass;if(k){if(O.name||(O={name:O}),!k.prototype.allowRead.call(null,p,O))return!1;if(!O.select)return O.name}return O}}).filter(Boolean)}else R.select=A.filter(D=>D.read&&!wn[D.attribute_name]).map(D=>D.attribute_name);return R}else return!0}}allowUpdate(p,R){let w=Va(p);if(w?.update){let A=w.attribute_permissions;if(A?.length>0){let y=Nw(A,"update");for(let D in R)if(!y[D])return!1;for(let D of A){let O=D.attribute_name;!D.update&&!(O in R)&&(R[O]=this.getProperty(O))}}return Ka(this[ke])}}allowCreate(p,R){if(this[ci]){let w=Va(p);if(w?.insert){let A=w.attribute_permissions;if(A?.length>0){let y=Nw(A,"insert");for(let D in R)if(!y[D])return!1;return Ka(this[ke])}else return Ka(this[ke])}}else return this.allowUpdate(p,{})}allowDelete(p){return Va(p)?.delete&&Ka(this[ke])}update(p,R){if(!Ir(this[ke]))throw new Error("Can not update a table resource outside of a transaction");if(p===!1)return this;let A;return typeof p=="object"&&p&&(R?(Object.isFrozen(p)&&(p={...p}),this[ve]={},this[_r]=p):(A=this[_r],A&&(p=Object.assign(A,p)),this[_r]=A=p)),this._writeUpdate(this[_r],R),this}addTo(p,R){if(typeof R=="number"||typeof R=="bigint")this[xE]===AW?this.set(p,(+this.getProperty(p)||0)+R):(this[xE]||this.update(),this.set(p,new vT(R)));else throw new Error("Can not add a non-numeric value")}subtractFrom(p,R){if(typeof R=="number")return this.addTo(p,-R);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this[Fr]}invalidate(){this._writeInvalidate()}_writeInvalidate(p){let R=this[ke],w=this[ze];ji(w),Ir(this[ke]).addWrite({key:w,store:i,invalidated:!0,entry:this[Fr],before:ye.invalidate?.bind(this,R,w),beforeIntermediate:Me.invalidate?.bind(this,R,w),commit:a((y,D)=>{if(di(y,D,p?.nodeId)<=0)return;let O=null;for(let v in r)O||(O={}),O[v]=this.getProperty(v);Ge.default.trace?.(`Invalidating entry id: ${w}, timestamp: ${new Date(y).toISOString()}`),b(w,O,this[Fr],y,Ns,m,{user:R?.user,residencyId:p?.residencyId,nodeId:p?.nodeId},"invalidate")},"commit")})}_writeRelocate(p){let R=this[ke],w=this[ze];ji(w),Ir(this[ke]).addWrite({key:w,store:i,invalidated:!0,entry:this[Fr],before:ye.relocate?.bind(this,R,w),beforeIntermediate:Me.relocate?.bind(this,R,w),commit:a((y,D)=>{if(di(y,D,p?.nodeId)<=0)return;let O=Ve.getResidencyRecord(p.residencyId),v=0,k=null,C=D?.value;if(O&&!O.includes(server.hostname)){for(let F in r)k||(k={}),k[F]=C(F);v=Ns}else k=C;Ge.default.trace?.(`Relocating entry id: ${w}, timestamp: ${new Date(y).toISOString()}`),b(w,k,this[Fr],y,v,m,{user:R.user,residencyId:p.residencyId,nodeId:p.nodeId,expiresAt:p.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(p,R){let w={previousResidency:this.getResidencyRecord(p.residencyId),isRelocation:!0},A=this.getResidency(R.value,w),y;if(A){if(!Array.isArray(A))throw new Error("Residency must be an array, but was: "+A);if(!A.includes(server.hostname))return;y=tt(A)}let O=b(p.key,R.value,p,p.version,0,!0,{residencyId:y,expiresAt:R.expiresAt},"relocate",!1,null)}static evict(p,R,w){let A=this.Source,y;if(!((B||m)&&(!R||(y=i.getEntry(p),!y||!R)||y.version!==w))){if(B){if(i.hasLock(p,y.version))return;let D;for(let O in r)D||(D={}),D[O]=R[O];if(D)return b(p,D,y,w,ya,null,null,null,!0)}return i.ifVersion(p,w,()=>{qa(p,R,null)}),m?b(p,null,y,w,ya,null,null,null,!0):i.remove(p,w)}}lock(){throw new Error("Not yet implemented")}static operation(p,R){return p.table||=s,p.schema||=c,DW.operation(p,R)}put(p){this.update(p,!0)}patch(p){this.update(p,!1)}_writeUpdate(p,R,w){let A=this[ke],y=Ir(A),D=this[ze];ji(D);let O=this[Fr];this[xE]=R?AW:JSe;let v={key:D,store:i,entry:O,nodeName:A?.nodeName,validate:a(k=>{p||(p=this[_r]),R||p&&MT(this[_r]===p?this:p)?A?.source||(y.checkOverloaded(),this.validate(p,!R),V&&(p[V.name]=V.type==="Date"?new Date(k):V.type==="String"?new Date(k).toISOString():k),R&&(t&&p[t]!==D&&(p[t]=D),Y&&(O?.value?p[Y.name]=O?.value[Y.name]:p[Y.name]=Y.type==="Date"?new Date(k):Y.type==="String"?new Date(k).toISOString():k),p=gl(p))):y.removeWrite(v)},"validate"),before:R?ye.put?()=>ye.put(A,D,p):null:ye.patch?()=>ye.patch(A,D,p):ye.put?()=>ye.put(A,D,gl(this)):null,beforeIntermediate:R?Me.put?()=>Me.put(A,D,p):null:Me.patch?()=>Me.patch(A,D,p):Me.put?()=>Me.put(A,D,gl(this)):null,commit:a((k,C,F)=>{if(F){if(A&&C?.version>(A.lastModified||0)&&(A.lastModified=C.version),this[Fr]=C,C?.value?.[ve])throw new Error("Can not assign a record to a record, check for circular references");R||(this[ve]=C?.value??null)}this[_r]=void 0,this[kE]=k;let x=C?.value,q=p;this[xE]=0;let ee=di(k,C,w?.nodeId),G;if(ee<=0)if(m){let K=C.localTime,Te=C.version;Ge.default.trace?.("Applying CRDT update to record with id: ",D,"applying later update:",Te);let Be=[];for(;K>k||Te>=k&&K>0;){let Ie=l.get(K);if(!Ie)break;let ce=Ht(Ie);if(Te=ce.version,Te>=k){if(Te===k){if(ee=di(k,{version:Te,localTime:K},w?.nodeId),ee===0)return;if(ee>0)continue}if(ce.type==="patch")Be.push(ce),G=p;else if(ce.type==="put"||ce.type==="delete")return}K=ce.previousLocalTime}Be.sort((Ie,ce)=>Ie.version-ce.version);for(let Ie of Be){let ce=Ie.getValue(i);if(q=PT(q,ce,R),Ge.default.debug?.("Rebuilding update with future patch:",q),!q)return}}else{if(R)return;q=PT(q,x,R),Ge.default.debug?.("Rebuilding update without audit:",q)}let be;if(R?be=q:(this[ve]=x,be=gl(this,q)),this[ve]=be,be?.[ve])throw new Error("Can not assign a record to a record, check for circular references");let Ee;if(w?.residencyId!=null)Ee=w.residencyId;else{O?.residencyId&&(A.previousResidency=Ve.getResidencyRecord(O.residencyId));let K=Ve.getResidency(be,A);if(K){if(!Array.isArray(K))throw new Error("Residency must be an array, got: "+K);K.includes(server.hostname)||K.push(server.hostname)}Ee=tt(K)}R||(G=p);let Re=A?.expiresAt??(h?h+Date.now():-1);Ge.default.trace?.(`Saving record with id: ${D}, timestamp: ${new Date(k).toISOString()}${Re?", expires at: "+new Date(Re).toISOString():""}${C?", replaces entry from: "+new Date(C.version).toISOString():", new entry"}`,be),qa(D,x,be);let re=R?"put":"patch";b(D,be,C,k,0,m,{user:A?.user,residencyId:Ee,expiresAt:Re,nodeId:w?.nodeId,originatingOperation:A?.originatingOperation},re,!1,G),A.expiresAt&&xo()},"commit")};y.addWrite(v)}async delete(p){if(typeof p=="string")return this.deleteProperty(p);if(this[ci]){for await(let R of this.search(p))(await Ve.getResource(R[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(p);return}return this[ve]?this._writeDelete(p):!1}_writeDelete(p){let R=Ir(this[ke]),w=this[ze];ji(w);let A=this[ke];return R.addWrite({key:w,store:i,resource:this,nodeName:A?.nodeName,before:ye.delete?.bind(this,A,w),beforeIntermediate:Me.delete?.bind(this,A,w),commit:a((y,D,O)=>{let v=D?.value;O&&(A&&D?.version>(A.lastModified||0)&&(A.lastModified=D.version),qT(this,D)),!(di(y,D,p?.nodeId)<=0)&&(qa(this[ze],v),Ge.default.trace?.(`Deleting record with id: ${w}, txn timestamp: ${new Date(y).toISOString()}`),m||g?(b(w,null,this[Fr],y,0,m,{user:A?.user,nodeId:p?.nodeId},"delete"),m||xo()):i.remove(this[ze]))},"commit")}),!0}search(p){let R=this[ke],w=Ir(R);if(!p)throw new Error("No query provided");let A=p.conditions;A?A.length===void 0&&(A=A[Symbol.iterator]?Array.from(A):[A]):A=Array.isArray(p)?p:p[Symbol.iterator]?Array.from(p):[],this[ze]&&(A=[{attribute:null,comparator:Array.isArray(this[ze])?"prefix":"starts_with",value:this[ze]}].concat(A));let y,D={};function O(K,Te){let Be;switch(Te){case"and":case void 0:if(K.length<1)throw new Error('An "and" operator requires at least one condition');Be=!0;break;case"or":if(K.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+Te)}for(let Ie of K){if(Ie.conditions){Ie.conditions=O(Ie.conditions,Ie.operator);continue}let ce=Ie[0]??Ie.attribute,Ye=ce==null?H:Bi(S,ce);if(Ye)(Ye.type||DN[Ie.comparator])&&(Ie[1]===void 0?Ie.value=k(Ie.value,Ye):Ie[1]=k(Ie[1],Ye));else if(ce!=null)throw(0,Nr.handleHDBError)(new Error,`${ce} is not a defined attribute`,404);if(Ie.chainedConditions)if(Ie.chainedConditions.length===1&&(!Ie.operator||Ie.operator=="and")){let rt=Ie.chainedConditions[0],Ze,st;if(rt.comparator==="gt"||rt.comparator==="greater_than"||rt.comparator==="ge"||rt.comparator==="greater_than_equal"?(Ze=Ie,st=rt):(Ze=rt,st=Ie),Ze.comparator!=="lt"&&Ze.comparator!=="less_than"&&Ze.comparator!=="le"&&Ze.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let Kt=st.comparator==="ge"||st.comparator==="greater_than_equal",ko=Ze.comparator==="le"||Ze.comparator==="less_than_equal";Ie.comparator=(Kt?"ge":"gt")+(ko?"le":"lt"),Ie.value=[st.value,Ze.value]}else throw new Error("Multiple chained conditions are not currently supported")}return K}a(O,"prepareConditions");function v(K,Te){if(p.enforceExecutionOrder)return K;for(let Be of K)Be.conditions&&(Be.conditions=v(Be.conditions,Be.operator));return K.length>1&&Te!=="or"?(0,wW.sortBy)(K,NS(Ve)):K}a(v,"orderConditions");function k(K,Te){return Array.isArray(K)?K.map(Be=>GT(Be,Te)):GT(K,Te)}a(k,"coerceTypedValues");let C=p.operator;(A.length>0||C)&&(A=O(A,C));let F=typeof p.sort=="object"&&p.sort,x;if(F&&C!=="or"){let K=F.attribute;if(K==null)throw new Nr.ClientError("Sort requires an attribute");if(y=A.find(Te=>nd(Te.attribute)===nd(K)),!y){let Te=Bi(S,K);if(!Te)throw(0,Nr.handleHDBError)(new Error,`${Array.isArray(K)?K.join("."):K} is not a defined attribute`,404);if(Te.indexed)y={attribute:K,comparator:"sort"},A.push(y);else if(A.length===0&&!p.allowFullScan)throw(0,Nr.handleHDBError)(new Error,`${Array.isArray(K)?K.join("."):K} is not indexed and not combined with any other conditions`,404)}y&&(y.descending=!!F.descending)}A=v(A,C),F&&(y&&A[0]===y?F.next&&(x={dbOrderedAttribute:F.attribute,attribute:F.next.attribute,descending:F.next.descending,next:F.next.next}):(y&&A.splice(A.indexOf(y),1),x=F));let q=p.select;if(A.length===0&&(A=[{attribute:t,comparator:"greater_than",value:!0}]),p.explain)return{conditions:A,operator:C,postOrdering:x,selectApplied:!!q};let ee=w.useReadTxn(),G=PN(A,C,Ve,ee,p,R,(K,Te)=>Ld(K,q,R,ee,Te),D),be=p.ensureLoaded!==!1;x||(G=re(G));let Ee=Ve.transformEntryForSelect(q,R,ee,D,be,!0),Re=Ve.transformToOrderedSelect(G,q,x,ee,R,Ee);function re(K){return p.offset||p.limit!==void 0?K.slice(p.offset,p.limit!==void 0?(p.offset||0)+p.limit:void 0):K}return a(re,"applyOffset"),x&&(Re=re(Re)),Re.onDone=()=>{Re.onDone=null,w.doneReadTxn()},Re.selectApplied=!0,Re.getColumns=()=>{if(q){let K=[];for(let Te of q)Te==="*"?K.push(...S.map(Be=>Be.name)):K.push(Te.name||Te);return K}return S.filter(K=>!K.computed&&!K.relationship).map(K=>K.name)},Re}static transformToOrderedSelect(p,R,w,A,y,D){let O=new vs;if(w){p=Ld(p,R,A,y,null);let v;O.iterate=function(){let C,F=p[Symbol.asyncIterator]?p[Symbol.asyncIterator]():p[Symbol.iterator](),x,q=w.dbOrderedAttribute,ee,G,be=!0;function Ee(re){let K=re.next&&Ee(re.next),Te=re.descending;return(Be,Ie)=>{let ce=Nl(Be,re.attribute,A),Ye=Nl(Ie,re.attribute,A),rt=Te?(0,yl.compareKeys)(Ye,ce):(0,yl.compareKeys)(ce,Ye);return rt===0?K?.(Be,Ie)||0:rt}}a(Ee,"createComparator");let Re=Ee(w);return{async next(){let re;if(C)if(re=C.next(),re.done){if(x)return O.onDone&&O.onDone(),re}else return{value:await D.call(this,re.value)};v=[],ee&&v.push(ee);do if(re=await F.next(),re.done){if(x=!0,v.length)break;return O.onDone&&O.onDone(),re}else{let K=re.value;if(K?.then&&(K=await K),q){let Te=Nl(K,q,A);if(be)be=!1,G=Te;else if(Te!==G){G=Te,ee=K;break}}v.push(K)}while(!0);return w.isGrouped,v.sort(Re),C=v[Symbol.iterator](),re=C.next(),re.done?(O.onDone&&O.onDone(),re):{value:await D.call(this,re.value)}},return(){O.onDone&&O.onDone(),F.return()},throw(){O.onDone&&O.onDone(),F.throw()}}};let k=a(C=>{if(typeof R=="object"&&Array.isArray(C.attribute))for(let F=0;F<R.length;F++){let x=R[F],q;if(x.name===C.attribute[0]){for(q=x.sort||(x.sort={});q.next;)q=q.next;q.attribute=C.attribute.slice(1),q.descending=C.descending}else x===C.attribute[0]&&(R[F]=q={name:x,sort:{attribute:C.attribute.slice(1),descending:C.descending}})}C.next&&k(C.next)},"applySortingOnSelect");k(w)}else O.iterate=(p[Symbol.asyncIterator]||p[Symbol.iterator]).bind(p),O=O.map(function(v){try{let k=D.call(this,v);return typeof k?.catch=="function"?k.catch(C=>{throw C.partialObject={[t]:v.key},C}):k}catch(k){throw k.partialObject={[t]:v.key},k}});return O}static transformEntryForSelect(p,R,w,A,y,D){if(p&&(p===t||p?.length===1&&p[0]===t&&Array.isArray(p))){let C=a(F=>(R?.transaction?.stale&&(R.transaction.stale=!1),F?.key??F),"transform");return p===t?C:p.asArray?F=>[C(F)]:F=>({[t]:C(F)})}let O;y&&B&&!(typeof p=="string"?[p]:p)?.every(C=>{let F;return typeof C=="object"?F=C.name:F=C,r[F]||F===t})&&(O=!0);let v,k=a(function(C){let F;if(R?.transaction?.stale&&(R.transaction.stale=!1),C!=null){if(F=C.value||C.deref?.()?.value,!F&&(C.key===void 0||C.deref)||C.metadataFlags&Ns){if(C.metadataFlags&Ns&&R.replicateFrom===!1&&D&&C.residencyId)return Ba.SKIP;if(C=$a(C.key??C,R,{transaction:w,lazy:p?.length<4,ensureLoaded:y},this?.isSync,x=>x),C?.then)return C.then(k.bind(this));F=C?.value}if(O&&C?.metadataFlags&(Ns|ya)||C?.expiresAt!=null&&C?.expiresAt<Date.now()){if(R.onlyIfCached&&R.noCacheStore)return{[t]:C.key,message:"This entry has expired"};let x=Pd(C.key??C,C,R);if(x?.then)return x.then(k)}}if(F==null)return D?Ba.SKIP:F;if(p&&!(p[0]==="*"&&p.length===1)){let x,q=a((G,be)=>{let Ee;typeof G=="object"?Ee=G.name:Ee=G;let Re=wn?.[Ee],re;if(Re){let K=A?.[Ee];if(K)if(K.hasMappings){let Be=Re.from?F[Re.from]:nd(C.key);re=K.get(Be),re||(re=[])}else re=K.fromRecord?.(F);else re=Re(F,R,C);let Te=a(Be=>{if(Be&&typeof Be=="object"){let Ie=Re.definition?.tableClass||Ve;v||(v={});let ce=v[Ee]||(v[Ee]=Ie.transformEntryForSelect(Ee===G?null:G.select||(Array.isArray(G)?G:null),R,w,K,y));if(Array.isArray(Be)){let Ye=[],rt=Ie.transformToOrderedSelect(Be,G.select,typeof G.sort=="object"&&G.sort,R,w,ce)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),Ze=a(Kt=>{for(;!Kt.done;){if(Kt?.then)return Kt.then(Ze);Ye.push(Kt.value),Kt=rt.next()}be(Ye,Ee)},"nextValue"),st=Ze(rt.next());st&&(x||(x=[]),x.push(st));return}else if(Be=ce.call(this,Be),Be?.then){x||(x=[]),x.push(Be.then(Ye=>be(Ye,Ee)));return}}be(Be,Ee)},"handleResolvedValue");re?.then?(x||(x=[]),x.push(re.then(Te))):Te(re);return}else re=F[Ee],re&&typeof re=="object"&&Ee!==G&&(re=Ve.transformEntryForSelect(G.select||G,R,w,null)({value:re}));be(re,Ee)},"selectAttribute"),ee;if(typeof p=="string")q(p,G=>{ee=G});else if(Array.isArray(p))if(p.asArray)ee=[],p.forEach((G,be)=>{G==="*"?p[be]=F:q(G,Ee=>ee[be]=Ee)});else{ee={};let G=p.forceNulls;for(let be of p)if(be==="*")for(let Ee in F)ee[Ee]=F[Ee];else q(be,(Ee,Re)=>{Ee===void 0&&G&&(Ee=null),ee[Re]=Ee})}else throw new Nr.ClientError("Invalid select"+p);return x?Promise.all(x).then(()=>ee):ee}return F},"transform");return k}async subscribe(p){if(!l)throw new Error("Can not subscribe to a table without an audit log");m||Et({table:s,database:c,schemaDefined:u,attributes:S,audit:!0}),p||(p={});let R=!p.rawEvents,w=[],A=this,y=py(Ve,this[ze]??null,function(O,v,k,C){try{let F=v.getValue?.(i,R),x=v.type;if(!F&&x==="patch"&&R){let ee=i.getEntry(O);ee?.version===v.version?F=ee.value:F=v.getValue?.(i,!0,k),x="put"}let q={id:O,localTime:k,value:F,version:v.version,type:x,beginTxn:C};w?w.push(q):this.send(q)}catch(F){Ge.default.error?.(F)}},p.startTime||0,p),D=(async()=>{this[ci]&&(y.includeDescendants=!0,p.onlyChildren&&(y.onlyChildren=!0)),p.supportsTransactions&&(y.supportsTransactions=!0);let O=this[ze],v=p.previousCount;v>1e3&&(v=1e3);let k=p.startTime;if(this[ci]){if(k){if(v)throw new Nr.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:C,value:F}of l.getRange({start:k,exclusiveStart:!0,snapshot:!1})){let x=Ht(F);if(x.tableId!==n)continue;let q=x.recordId;if(O==null||NW(O,q)){let ee=x.getValue(i,R,C);if(y.send({id:q,localTime:C,value:ee,version:x.version,type:x.type}),y.queue?.length>bW&&await y.waitForDrain()===!1)return}y.startTime=C}}else if(v){let C=[];for(let{key:F,value:x}of l.getRange({start:"z",end:!1,reverse:!0}))try{let q=Ht(x);if(q.tableId!==n)continue;let ee=q.recordId;if(O==null||NW(O,ee)){let G=q.getValue(i,R,F);if(C.push({id:ee,localTime:F,value:G,version:q.version,type:q.type}),--v<=0)break}}catch(q){Ge.default.error("Error getting history entry",F,q)}for(let F=C.length;F>0;)y.send(C[--F]);C[0]&&(y.startTime=C[0].localTime)}else if(!p.omitCurrent){for(let{key:C,value:F,version:x,localTime:q}of i.getRange({start:O??!1,end:O==null?void 0:[O,yl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(F&&(y.send({id:C,localTime:q,value:F,version:x,type:"put"}),y.queue?.length>bW&&await y.waitForDrain()===!1))return}}else{v&&!k&&(k=0);let C=this[Fr]?.localTime;if(C===Qg&&(i.cache?.delete(O),this[Fr]=i.getEntry(O),Ge.default.trace?.("re-retrieved record",C,this[Fr]?.localTime),C=this[Fr]?.localTime),Ge.default.trace?.("Subscription from",k,"from",O,C),k<C){let F=[],x=C;do{let q=l.get(x);if(q){p.omitCurrent=!0;let ee=Ht(q),G=ee.getValue(i,R,x);R&&(ee.type="put"),F.push({id:O,value:G,localTime:x,...ee}),x=ee.previousLocalTime}else break;v&&v--}while(x>k&&v!==0);for(let q=F.length;q>0;)y.send(F[--q]);y.startTime=C}!p.omitCurrent&&this.doesExist()&&y.send({id:O,localTime:C,value:this[ve],version:this[kE],type:"put"})}for(let C of w)y.send(C);w=null})();return p.listener&&y.on("data",p.listener),y}static subscribeOnThisThread(p,R){return p===0||R?.crossThreads===!1}doesExist(){return!!(this[ve]||this[xE])}publish(p,R){this._writePublish(p,R)}_writePublish(p,R){let w=Ir(this[ke]),A=this[ze]||null;A!=null&&ji(A);let y=this[ke];w.addWrite({key:A,store:i,entry:this[Fr],nodeName:y?.nodeName,validate:a(()=>{y?.source||(w.checkOverloaded(),this.validate(p))},"validate"),before:ye.publish?.bind(this,y,A,p),beforeIntermediate:Me.publish?.bind(this,y,A,p),commit:a((D,O,v)=>{O===void 0&&g&&!m&&xo(),Ge.default.trace?.(`Publishing message to id: ${A}, timestamp: ${new Date(D).toISOString()}`),b(A,O?.value??null,O,O?.version||D,0,!0,{user:y?.user,residencyId:R?.residencyId,expiresAt:y?.expiresAt,nodeId:R?.nodeId},"message",!1,p)},"commit")})}validate(p,R){let w,A=a((y,D,O)=>{if(D.type&&y!=null)if(R&&y.__op__&&(y=y.value),D.properties){typeof y!="object"&&(w||(w=[])).push(`Value ${li(y)} in property ${O} must be an object${D.type?" ("+D.type+")":""}`);let v=D.properties;for(let k=0,C=v.length;k<C;k++){let F=v[k],x=A(y[F.name],F,O+"."+F.name);x&&(y[F.name]=x)}if(D.sealed&&y!=null&&typeof y=="object")for(let k in y)v.find(C=>C.name===k)||(w||(w=[])).push(`Property ${k} is not allowed within object in property ${O}`)}else switch(D.type){case"Int":(typeof y!="number"||y>>0!==y)&&(w||(w=[])).push(`Value ${li(y)} in property ${O} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof y!="number"||!(Math.floor(y)===y&&Math.abs(y)<=9007199254740992))&&(w||(w=[])).push(`Value ${li(y)} in property ${O} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof y!="number"&&(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a number`);break;case"ID":typeof y=="string"||y?.length>0&&y.every?.(v=>typeof v=="string")||(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a string, or an array of strings`);break;case"String":typeof y!="string"&&(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a string`);break;case"Boolean":typeof y!="boolean"&&(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a boolean`);break;case"Date":if(!(y instanceof Date)){if(typeof y=="string"||typeof y=="number")return new Date(y);(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a Date`)}break;case"BigInt":if(typeof y!="bigint"){if(typeof y=="string"||typeof y=="number")return BigInt(y);(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a bigint`)}break;case"Bytes":y instanceof Uint8Array||(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a Buffer or Uint8Array`);break;case"array":if(Array.isArray(y)){if(D.elements)for(let v=0,k=y.length;v<k;v++){let C=y[v],F=A(C,D.elements,O+"[*]");F&&(y[v]=F)}}else(w||(w=[])).push(`Value ${li(y)} in property ${O} must be a Buffer or Uint8Array`);break}D.nullable===!1&&y==null&&(w||(w=[])).push(`Property ${O} is required (and not does not allow null values)`)},"validateValue");for(let y=0,D=S.length;y<D;y++){let O=S[y];if(!(O.relationship||O.computed)&&(!R||O.name in p)){let v=A(p[O.name],O,O.name);v&&(p[O.name]=v)}}if(_)for(let y in p)S.find(D=>D.name===y)||(w||(w=[])).push(`Property ${y} is not allowed`);if(w)throw new Nr.ClientError(w.join(". "))}getUpdatedTime(){return this[kE]}wasLoadedFromSource(){return B?!!this[Ow]:void 0}static async addAttributes(p){let R=S.slice(0);for(let w of p){if(!w.name)throw new Nr.ClientError("Attribute name is required");if(w.name.match(/[`/]/))throw new Nr.ClientError("Attribute names cannot include backticks or forward slashes");(0,CW.validateAttribute)(w.name),R.push(w)}return Et({table:s,database:c,schemaDefined:u,attributes:R}),Ve.indexingOperation}static async removeAttributes(p){let R=S.filter(w=>!p.includes(w.name));return Et({table:s,database:c,schemaDefined:u,attributes:R}),Ve.indexingOperation}static getSize(){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 R=i.getStats().entryCount,w=1e3/2,A=performance.now(),y=Math.floor(R/2),D=p?.exactCount,O=0,v=0,k;for(let{value:C}of i.getRange({start:!0,lazy:!0}))if(C!=null&&O++,v++,!D&&v<y&&performance.now()-A>w){k=v;break}if(k){let C=O;O=0;for(let{value:re}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:k}))re!=null&&O++;let F=k*2,x=(O+C)/F,q=Math.pow((O-C+1)/k/2,2)+x*(1-x)/F,ee=Math.max(Math.sqrt(q)*R,1),G=Math.round(x*R),be=Math.max(G-1.96*ee,O+C),Ee=Math.min(G+1.96*ee,R),Re=Math.pow(10,Math.round(Math.log10(ee)));return Re>G&&(Re=Re/10),O=Math.round(G/Re)*Re,{recordCount:O,estimatedRange:[Math.round(be),Math.round(Ee)]}}return{recordCount:O}}static updatedAttributes(){wn=this.propertyResolvers={$id:a((p,R,w)=>({value:w.key}),"$id"),$updatedtime:a((p,R,w)=>w.version,"$updatedtime"),$record:a((p,R,w)=>w?{value:p}:p,"$record")};for(let p of this.attributes){p.resolve=null;let R=p.relationship,w=p.computed;if(R)if(p.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),w&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),Dd=!0,R.to)p.elements?.definition?(wn[p.name]=p.resolve=(A,y,D)=>{let O=A[R.from?R.from:t],v=p.elements.definition.tableClass;return D?rd({attribute:R.to,value:O},Ir(y).getReadTxn(),!1,v,!1).asArray:v.search([{attribute:R.to,value:O}],y).asArray},p.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},p.resolve.definition=p.elements.definition,R.from&&(p.resolve.from=R.from)):console.error(`The one-to-many/many-to-many relationship property "${p.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(R.from){let A=p.definition||p.elements?.definition;A?(wn[p.name]=p.resolve=(y,D,O)=>{let v=y[R.from];if(v!==void 0){if(p.elements){let k,C=v?.map(F=>{let x=O?A.tableClass.primaryStore.getEntry(F,{transaction:Ir(D).getReadTxn()}):A.tableClass.get(F,D);return x?.then&&(k=!0),x});return R.filterMissing?k?Promise.all(C).then(F=>F.filter(IW)):C.filter(IW):k?Promise.all(C):C}return O?A.tableClass.primaryStore.getEntry(v,{transaction:Ir(D).getReadTxn()}):A.tableClass.get(v,D)}},p.set=(y,D)=>{if(Array.isArray(D)){let O=D.map(v=>v[ze]||v[A.tableClass.primaryKey]);y[R.from]=O}else{let O=D[ze]||D[A.tableClass.primaryKey];y[R.from]=O}},p.resolve.definition=p.definition||p.elements?.definition,p.resolve.from=R.from):console.error(`The relationship property "${p.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${p.name}" in table "${s}" must use either "from" or "to" arguments`);else w&&(typeof w.from=="function"&&this.setComputedAttribute(p.name,w.from),wn[p.name]=p.resolve=(A,y,D)=>{let O=typeof w.from=="string"?A[w.from]:A,v=this.userResolvers[p.name];if(v)return v(O,y,D);Ge.default.warn(`Computed attribute "${p.name}" does not have a function assigned to it. Please use setComputedAttribute('${p.name}', resolver) to assign a resolver function.`),this.userResolvers[p.name]=()=>{}})}BT(this,this)}static setComputedAttribute(p,R){let w=Bi(S,p);if(!w){console.error(`The attribute "${p}" does not exist in the table "${s}"`);return}if(!w.computed){console.error(`The attribute "${p}" is not defined as computed in the table "${s}"`);return}this.userResolvers[p]=R}static async deleteHistory(p=0,R=!1){let w;for(let{key:A,value:y}of l.getRange({start:0,end:p}))await yd(),Ht(y).tableId===n&&(w=wT(l,A,y));if(R)for(let{key:A,value:y,localTime:D}of i.getRange({start:0,versions:!0}))await yd(),y===null&&D<p&&(w=i.remove(A));await w}static async*getHistory(p=0,R=1/0){for(let{key:w,value:A}of l.getRange({start:p||1,end:R})){await yd();let y=Ht(A);y.tableId===n&&(yield{id:y.recordId,localTime:w,version:y.version,type:y.type,value:y.getValue(i,!0,w),user:y.user,operation:y.originatingOperation})}}static async getHistoryOfRecord(p){let R=[];if(p==null)throw new Error("An id is required");let w=i.getEntry(p);if(!w)return R;let A=w.localTime;if(!A)throw new Error("The entry does not have a local audit time");let y=0;do{await yd();let D=l.get(A);if(D){let O=Ht(D);R.push({id:O.recordId,localTime:A,version:O.version,type:O.type,value:O.getValue(i,!0,A),user:O.user}),A=O.previousLocalTime}else break}while(y<1e3&&A);return R.reverse()}static cleanup(){Q?.remove()}}Ve.updatedAttributes();let ss=Ve.prototype;return ss[QSe]=!0,h&&Ve.setTTLExpiration(h/1e3),ne&&Se(),Ve;function qa(U,p,R){let w;for(let A in r){let y=r[A],D=y.isIndexing,O=wn[A],v=R&&(O?O(R):R[A]),k=p&&(O?O(p):p[A]);if(v===k&&!D)continue;w=!0;let C=y.indexNulls,F=(0,FE.getIndexedValues)(v,C),x=(0,FE.getIndexedValues)(k,C);if(x?.length>0){let q=new Set(x);if(F=F?F.filter(ee=>{if(q.has(ee))q.delete(ee);else return!0}):[],x=Array.from(q),(x.length>0||F.length>0)&&RW){let ee=x.concat(F).map(G=>({key:G,value:U}));y.prefetch(ee,OW)}for(let ee=0,G=x.length;ee<G;ee++)y.remove(x[ee],U)}else F?.length>0&&RW&&y.prefetch(F.map(q=>({key:q,value:U})),OW);if(F)for(let q=0,ee=F.length;q<ee;q++)y.put(F[q],U)}return w}a(qa,"updateIndices");function ji(U){switch(typeof U){case"number":return!0;case"string":if(U.length<659)return!0;if(U.length>yW)throw new Error("Primary key size is too large: "+U.length);break;case"object":if(U===null)throw new Error("Invalid primary key of null");break;case"bigint":if(U<2n**64n&&U>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof U)}if((0,yl.writeKey)(U,XSe,0)>yW)throw new Error("Primary key size is too large: "+U.length);return!0}a(ji,"checkValidId");function $a(U,p,R,w,A){if(Ve.getResidencyById&&R.ensureLoaded&&p?.replicateFrom!==!1){let D=Ve.getResidencyById(U);if(D&&!D.includes(server.hostname)&&I)return I({key:U,residency:D}).then(A)}let y=a(()=>{if(p?.transaction?.stale&&(p.transaction.stale=!1),R.transaction?.isDone)return A(null,U);let D=i.getEntry(U,R);return D?.residencyId&&D.metadataFlags&Ns&&I&&R.ensureLoaded&&p?.replicateFrom!==!1?I(D).then(O=>A(O,U)):(D&&p&&(D?.version>(p.lastModified||0)&&(p.lastModified=D.version),D?.localTime&&!p.lastRefreshed&&(p.lastRefreshed=D.localTime)),A(D,U))},"whenPrefetched");return w?y():ae>0?(ae--,y()):new Promise((D,O)=>{ae===0?(ae--,i.prefetch([U],()=>{v(),k()})):(de.push(U),j.push(k),de.length>zE&&(ae--,v()));function v(){if(de.length>0){let C=j;i.prefetch(de,()=>{ae===-1?v():ae++;for(let F of C)F()}),de=[],j=[],Ae>2&&Ae--}else ae=Ae,Ae<Bs&&Ae++}a(v,"prefetch");function k(){try{D(y())}catch(C){O(C)}}a(k,"load")})}a($a,"loadLocalRecord");function Va(U){if(!U?.role)return;let p=U.role.permission;if(p.super_user)return ZSe;let R=p[c],w,A=R?.tables;if(A)return A[s];if(c==="data"&&(w=p[s])&&!w.tables)return w}a(Va,"getTablePermissions");function Pd(U,p,R,w){if(B){let A=!1;if(R.noCache?A=!0:(p?(!p.value||p.metadataFlags&(Ns|ya)||p.expiresAt!=null&&p.expiresAt<Date.now())&&(A=!0):A=!0,qn(!A,"cache-hit",s)),A){let y=Md(U,p,R).then(D=>(D?.value?.[ve]&&Ge.default.error?.("Can not assign a record with a record property"),R&&(D?.version>(R.lastModified||0)&&(R.lastModified=D.version),R.lastRefreshed=Date.now()),D));if(R?.onlyIfCached||p?.value&&w?.allowStaleWhileRevalidate?.(p,U)){if(y.catch(D=>Ge.default.warn?.(D)),R?.onlyIfCached&&!w.doesExist())throw new Nr.ServerError("Entry is not cached",504);return}else return y}}else if(p?.value&&p.expiresAt!=null&&p.expiresAt<Date.now())return Ve.evict(p.key,p.value,p.version),p.value=null,{then(A){return A(p)}}}a(Pd,"ensureLoadedFromSource");function Ir(U){let p=U?.transaction;if(p){if(!p.lmdbDb)return p.lmdbDb=i,p;do{if(p.lmdbDb?.path===i.path)return p;let R=p.next;if(!R)return p=p.next=new pc,p.lmdbDb=i,p;p=R}while(!0)}else return new cp}a(Ir,"txnForContext");function Nl(U,p,R){if(!U)return;let w=U.value||i.getEntry(U.key)?.value;if(typeof p=="object"){let y=wn,D=w;for(let O=0,v=p.length;O<v;O++){let k=p[O],C=y?.[k];D=C&&D?C(D,R,!0)?.value:D?.[k],y=C?.definition?.tableClass?.propertyResolvers}return D}let A=wn[p];return A?A(w,R):w[p]}a(Nl,"getAttributeValue");function Ld(U,p,R,w,A){let y=A?.length,D={transaction:w,lazy:y>0||typeof p=="string"||p?.length<4,alwaysPrefetch:!0},O;function v(k,C){let F=k?.value;if(!F)return Ba.SKIP;for(let x=0;x<y;x++)if(!O?.includes(x)&&!A[x](F,k))return Ba.SKIP;return C!==void 0&&(k.key=C),k}if(a(v,"processEntry"),y>0||!U.hasEntries){let k=U.map(C=>{if(O=null,typeof C=="object"&&C?.key!==void 0)return y>0?v(C):C;if(C==null)return Ba.SKIP;for(let F=0;F<y;F++){let q=A[F].idFilter;if(q){if(!q(C))return Ba.SKIP;O||(O=[]),O.push(F)}}return $a(C,R,D,!1,v)});return Array.isArray(U)&&(k=k.filter(C=>C!==Ba.SKIP)),k.hasEntries=!0,k}return U}a(Ld,"transformToEntries");function di(U,p,R=server.replication?.getThisNodeId(l)){if(U<=p?.version){if(p?.version===U&&R!==void 0){let w=server.replication?.exportIdMapping(l),A=p.localTime,y=A&&l.get(A);if(y){let D,O,v=Ht(y);for(let k in w)w[k]===R&&(D=k),w[k]===v.nodeId&&(O=k);if(D>O)return 1;if(D===O)return 0}}return-1}return 1}a(di,"precedesExistingVersion");async function Md(U,p,R){let w=p?.metadataFlags,A=p?.version,y,D;if(!i.attemptLock(U,A,()=>{clearTimeout(D);let C=i.getEntry(U);!C||!C.value||C.metadataFlags&(Ns|ya)?y(Md(U,i.getEntry(U),R)):y(C)}))return new Promise(C=>{y=C,D=setTimeout(()=>{i.unlock(U,A)},zSe)});let O=p?.value,v={requestContext:R,replacingRecord:O,replacingEntry:p,replacingVersion:A,noCacheStore:!1,source:null,resourceCache:R?.resourceCache},k=R?.responseHeaders;return new Promise((C,F)=>{let x;Iw(Dt(v,async q=>{let ee=performance.now(),G,be,Ee;try{for(let Te of Ve.sources)if(Te.get&&(!Te.get.reliesOnPrototype||Te.prototype.get)){if(Te.available?.(p)===!1)continue;if(v.source=Te,G=await Te.get(U,v),G)break}Ee=w&Ns;let re=v.lastModified||Ee&&A;be=Ee||re>A||!O,re||(re=(0,FE.getNextMonotonicTime)());let K=performance.now()-ee;if(pr(K,"cache-resolution",s,null,"success"),k&&Bm(k,"Server-Timing",`cache-resolve;dur=${K.toFixed(2)}`,!0),q.timestamp=re,h&&v.expiresAt==null&&(v.expiresAt=Date.now()+h),G){if(typeof G!="object")throw new Error("Only objects can be cached and stored in tables");if(G.status>0&&G.headers)if(G.status>=300)if(G.status===304)G=O,re=A;else throw new Nr.ServerError(G.body||"Error from source",G.status);else G=G.body;typeof G.toJSON=="function"&&(G=G.toJSON()),t&&G[t]!==U&&(G[t]=U)}x=!0,C({key:U,version:re,value:G})}catch(re){re.message+=` while resolving record ${U} for ${s}`,O&&((re.code==="ECONNRESET"||re.code==="ECONNREFUSED"||re.code==="EAI_AGAIN")&&!R?.mustRevalidate||R?.staleIfError&&(re.statusCode===500||re.statusCode===502||re.statusCode===503||re.statusCode===504))?(C({key:U,version:A,value:O}),Ge.default.trace?.(re.message,"(returned stale record)")):F(re);let K=performance.now()-ee;pr(K,"cache-resolution",s,null,"fail"),k&&Bm(k,"Server-Timing",`cache-resolve;dur=${K.toFixed(2)}`,!0),v.transaction.abort();return}if(R?.noCacheStore||v.noCacheStore){v.transaction.abort();return}Ir(v).addWrite({key:U,store:i,entry:p,nodeName:"source",commit:a((re,K)=>{if(K?.version!==A)return;let Te=qa(U,O,G);G?(Me.put?.(v,U,G),Ge.default.trace?.(`Writing resolved record from source with id: ${U}, timestamp: ${new Date(re).toISOString()}`),b(U,G,K,re,0,m&&be||null,{user:v?.user,expiresAt:v.expiresAt},"put",!!Ee)):K&&(Me.delete?.(v,U),Ge.default.trace?.(`Deleting resolved record from source with id: ${U}, timestamp: ${new Date(re).toISOString()}`),m||g?b(U,null,K,re,0,m&&be||null,{user:v?.user},"delete",!!Ee):i.remove(U,A))},"commit")})}),()=>{i.unlock(U,A)},q=>{i.unlock(U,A),x&&Ge.default.error?.("Error committing cache update",q)})})}a(Md,"getFromSource");function Ka(U){if(!U||U.user?.role?.permission?.super_user)return!0;if(U.replicateTo)throw new Nr.ClientError("Can not specify replication parameters without super user permissions",403);if(U.replicatedConfirmation)throw new Nr.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}a(Ka,"checkContextPermissions");function xo(){if(Gr!==Cd&&(Cd=Gr,(0,Al.getWorkerIndex)()===(0,Al.getWorkerCount)()-1)){if(ka&&clearTimeout(ka),!Gr)return;let U=new Date;U.setMonth(0),U.setDate(1),U.setHours(0),U.setMinutes(0),U.setSeconds(0);let p=Math.ceil((Date.now()-U.getTime())/Gr)*Gr+U.getTime(),R=a(w=>{Ge.default.trace?.(`Scheduled next cleanup scan at ${new Date(w)}ms`),ka=setTimeout(()=>X=X.then(async()=>{if(R(Math.max(w+Gr,Date.now())),i.rootStore.status!=="open"){clearTimeout(ka);return}let A=50,y=new Array(A),D=0;Ge.default.info?.(`Starting cleanup scan for ${s}`);try{let O=0;for(let{key:v,value:k,version:C,expiresAt:F}of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let x;k===null&&!m&&C+jSe<Date.now()?x=i.remove(v,C):F!=null&&F+T<Date.now()&&(x=Ve.evict(v,k,C),O++),x&&(await y[D],y[D]=x.catch(q=>{Ge.default.error?.("Cleanup error",q)}),++D>=A&&(D=0)),await yd()}Ge.default.info?.(`Finished cleanup scan for ${s}, evicted ${O} entries`)}catch(O){Ge.default.warn?.(`Error in cleanup scan for ${s}:`,O)}}),Math.min(w-Date.now(),2147483647)).unref()},"startNextTimer");R(p)}}a(xo,"scheduleCleanup");function ie(){Q=l?.addDeleteRemovalCallback(n,U=>{let p=i.getEntry(U);p?.value===null&&i.remove(U,p.version)})}a(ie,"addDeleteRemoval");function Se(){(0,Al.getWorkerIndex)()===0&&setInterval(async()=>{if(!Ol){Ol=!0;try{let U=ne.name,p=r[U];if(!p)throw new Error(`expiresAt attribute ${ne} must be indexed`);for(let R of p.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let w of p.getValues(R)){let A=i.getEntry(w);A?.value?A.value[U]<Date.now()&&Ve.evict(w,A.value,A.version):i.ifVersion(w,A?.version,()=>p.remove(R,w))}await yd()}}catch(U){Ge.default.error?.("Error in evicting old records",U)}finally{Ol=!1}}},WSe).unref()}a(Se,"runRecordExpirationEviction");function tt(U){if(U){let p=U.join(","),R=d.get([Symbol.for("residency_by_set"),p]);return R||(d.put([Symbol.for("residency_by_set"),p],R=Math.floor(Math.random()*2147483647)),d.put([Symbol.for("residency_by_id"),R],U),R)}}a(tt,"getResidencyId")}function 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 OW(){}function eTe(e){DW=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;tTe.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 NW(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 IW(e){return e!=null}function li(e){try{return JSON.stringify(e)}catch{return e}}function rTe(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var Us,Ba,FE,wW,CW,bd,Nr,GE,qE,Ge,yl,Al,$T,YSe,DW,WSe,jSe,RW,zSe,kE,QSe,Fr,xE,AW,JSe,Ow,Ns,ya,XSe,yW,bW,ZSe,WMe,tTe,yd,$f=Ne(()=>{Us=L(M()),Ba=require("lmdb"),FE=L(cn()),wW=require("lodash"),CW=L(Xd());Vs();lp();bd=L(se());my();Nr=L(_e()),GE=L(no()),qE=L(qs());Pe();_E();Ge=L(bc());_p();mc();yl=require("ordered-binary"),Al=L(dt());Ji();$T=L(te());Ul();Ni();CT();Bf();YSe=new Uint8Array(9);YSe[8]=192;WSe=6e4,jSe=864e5;bd.initSync();RW=bd.get(Us.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),zSe=1e4,kE=Symbol.for("version"),QSe=Symbol.for("incremental-update"),Fr=Symbol("entry"),xE=Symbol("is-saving"),AW=1,JSe=2,Ow=Symbol("loaded-from-source"),Ns=1,ya=8,XSe=Buffer.allocUnsafeSlow(8192),yW=1978,bW=100,ZSe={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},WMe=(0,$T.convertToMS)(bd.get(Us.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(VT,"makeTable");a(Nw,"attributesAsObject");a(OW,"noop");a(eTe,"setServerUtilities");tTe=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(GT,"coerceType");a(FT,"rejectNaN");a(NW,"isDescendantId");yd=a(()=>new Promise(setImmediate),"rest");a(Iw,"when");a(qT,"updateResource");a(IW,"exists");a(li,"stringify");a(rTe,"hasOtherProcesses")});var lt={};je(lt,{database:()=>zl,databases:()=>We,dropDatabase:()=>xA,dropTableMeta:()=>aTe,getDatabases:()=>ut,getDefaultCompression:()=>Lm,getTables:()=>nTe,onRemovedDB:()=>sf,onUpdatedTable:()=>Pc,readMetaDb:()=>$E,resetDatabases:()=>xu,table:()=>Et,tables:()=>jn});function nTe(){return jT||ut(),jn||{}}function ut(){if(jT)return We;jT=!0,Id=new Map;let e=(0,er.getHdbBasePath)()&&(0,Ut.join)((0,er.getHdbBasePath)(),yr.DATABASES_DIR_NAME),t=(0,er.get)(yr.CONFIG_PARAMS.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,er.get)(yr.CONFIG_PARAMS.STORAGE_PATH)||e&&((0,rs.existsSync)(e)?e:(0,Ut.join)((0,er.getHdbBasePath)(),yr.LEGACY_DATABASES_DIR_NAME)),!e)return;if((0,rs.existsSync)(e))for(let n of(0,rs.readdirSync)(e,{withFileTypes:!0})){let s=(0,Ut.basename)(n.name,".mdb");n.isFile()&&(0,Ut.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&$E((0,Ut.join)(e,n.name),null,s)}if((0,rs.existsSync)((0,Nd.getBaseSchemaPath)())){for(let n of(0,rs.readdirSync)((0,Nd.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,Ut.join)((0,Nd.getBaseSchemaPath)(),n.name),i=(0,Ut.join)((0,Nd.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,rs.readdirSync)(s,{withFileTypes:!0}))if(o.isFile()&&(0,Ut.extname)(o.name).toLowerCase()===".mdb"){let c=(0,Ut.join)(i,o.name);$E((0,Ut.join)(s,o.name),(0,Ut.basename)(o.name,".mdb"),n.name,c,!0)}}}if(t)for(let n in t){let s=t[n],i=s.path;if((0,rs.existsSync)(i))for(let c of(0,rs.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,Ut.extname)(c.name).toLowerCase()===".mdb"&&$E((0,Ut.join)(i,c.name),(0,Ut.basename)(c.name,".mdb"),n);let o=s.tables;if(o)for(let c in o){let l=o[c],u=(0,Ut.join)(l.path,(0,Ut.basename)(c+".mdb"));(0,rs.existsSync)(u)&&$E(u,c,n,null,!0)}}for(let n in We){let s=Id.get(n);if(s){let i=We[n];n.includes("delete")&&$t.trace(`defined tables ${Array.from(s.keys())}`);for(let o in i)s.has(o)||($t.trace(`delete table class ${o}`),delete i[o])}else if(delete We[n],n==="data"){for(let i in jn)delete jn[i];delete jn[zT]}}let r=["hdb_temp","hdb_certificate","hdb_analytics","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if(We.system)for(let n of r)We.system[n]&&(We.system[n].replicate=!1);return Id=null,We}function xu(){jT=!1;for(let[,e]of Ha)e.needsDeletion=!0;ut();for(let[e,t]of Ha)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),Ha.delete(e),delete We[t.databaseName],KE.forEach(r=>r(t.databaseName)));return We}function $E(e,t,r=Dw,n,s){let i=new ww.default(e,!1);try{let o=Ha.get(e);o?o.needsDeletion=!1:(o=(0,wd.open)(i),Ha.set(e,o));let c=new bl.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(KT.INTERNAL_DBIS_NAME,c)),u=o.auditStore;u||(n?(0,rs.existsSync)(n)&&(i.path=n,u=(0,wd.open)(i),u.isLegacy=!0):u=IT(o));let d=UW(r),_=d[zT],E=new Map;for(let{key:f,value:h}of l.getRange({start:!1})){let[T,m]=f.toString().split("/");m===""?m=h.name:m||(m=T,T=t,h.name||(h.name=m,h.indexed=!h.is_hash_attribute)),_?.add(T);let g=E.get(T);g||E.set(T,g={attributes:[]}),(m==null||h.is_hash_attribute)&&(g.primary=h),m!=null&&g.attributes.push(h),Object.defineProperty(h,"key",{value:f,configurable:!0})}for(let[f,h]of E){let{attributes:T,primary:m}=h;if(!m){for(let j of T)if(j.is_hash_attribute||j.isPrimaryKey){m=j;break}if(!m){$t.warn(`Unable to find a primary key attribute on table ${f}, with attributes: ${JSON.stringify(T)}`);continue}}let g=d[f],S={},b=[],I,B,H=typeof m.audit=="boolean"?m.audit:(0,er.get)(yr.CONFIG_PARAMS.LOGGING_AUDITLOG),X=m.trackDeletes,Y=m.expiration,V=m.eviction,ne=m.sealed,Q=m.splitSegments,de=m.replicate;if(g)S=g.indices,b=g.attributes,g.schemaVersion++;else{I=m.tableId,I?I>=(l.get(Od)||0)&&(l.putSync(Od,I+1),$t.info(`Updating next table id (it was out of sync) to ${I+1} for ${f}`)):(m.tableId=I=l.get(Od),I||(I=1),$t.debug("Table {table_name} missing an id, assigning {table_id}"),l.putSync(Od,I+1),l.putSync(m.key,m));let j=new bl.default(!m.is_hash_attribute,m.is_hash_attribute);if(j.compression=m.compression,j.compression){let ae=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||MW;j.compression.threshold=ae}B=Nh(o.openDB(m.key,j)),o.databaseName=r,B.rootStore=o,B.tableId=I}for(let j of T){j.attribute=j.name;try{if(!j.is_hash_attribute&&(j.indexed||j.attribute&&!j.name)){if(!S[j.name]){let Ae=new bl.default(!j.is_hash_attribute,j.is_hash_attribute);S[j.name]=o.openDB(j.key,Ae),S[j.name].indexNulls=j.indexNulls}let ae=b.find(Ae=>Ae.name===j.name);ae?b.splice(b.indexOf(ae),1,j):b.push(j)}}catch(ae){$t.error("Error trying to update attribute",j,b,S,ae)}}if(!g){g=vW(d,f,VT({primaryStore:B,auditStore:u,audit:H,sealed:ne,splitSegments:Q,replicate:de,expirationMS:Y&&Y*1e3,evictionMS:V&&V*1e3,trackDeletes:X,tableName:f,tableId:I,primaryKey:m.name,databasePath:s?r+"/"+f:r,databaseName:r,indices:S,attributes:T,schemaDefined:m.schemaDefined,dbisDB:l})),g.schemaVersion=1;for(let j of VE)j(g)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function UW(e){let t=We[e];if(t||(e==="data"?t=We[e]=jn:e==="system"?Object.defineProperty(We,"system",{value:t=Object.create(null),configurable:!0}):t=We[e]=Object.create(null)),Id&&!Id.has(e)){let r=new Set;t[zT]=r,Id.set(e,r)}return t}function vW(e,t,r){return e[t]=r,r}function zl({database:e,table:t}){e||(e=Dw),ut();let r=UW(e),n=(0,Ut.join)((0,er.getHdbBasePath)(),yr.DATABASES_DIR_NAME),s=(0,er.get)(yr.CONFIG_PARAMS.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,er.get)(yr.CONFIG_PARAMS.STORAGE_PATH)||((0,rs.existsSync)(n)?n:(0,Ut.join)((0,er.getHdbBasePath)(),yr.LEGACY_DATABASES_DIR_NAME));let o=(0,Ut.join)(n,(i?t:e)+".mdb"),c=Ha.get(o);if(!c||c.status==="closed"){let l=new ww.default(o,!1);c=(0,wd.open)(l),Ha.set(o,c)}return c.auditStore||(c.auditStore=IT(c)),c}async function xA(e){if(!We[e])throw new Error("Schema does not exist");let t=We[e],r;for(let n in t)r=t[n].primaryStore.rootStore,Ha.delete(r.path),r.status==="open"&&(await r.close(),await YE.remove(r.path));if(r||(r=zl({database:e,table:null}),r.status==="open"&&(await r.close(),await YE.remove(r.path))),e==="data"){for(let n in jn)delete jn[n];delete jn[zT]}delete We[e],KE.forEach(n=>n(e))}function Et(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:o,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:_,schemaDefined:E,origin:f}=e;r||(r=Dw);let h=zl({database:r,table:t}),T=We[r];$t.trace(`Defining ${t} in ${r}`);let m=T?.[t];if(h.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let g,S,b;E==null&&(E=!0);let I=new bl.default(!1);for(let Q of o)Q.attribute&&!Q.name?(Q.name=Q.attribute,Q.indexed=!0):Q.attribute=Q.name,Q.expiresAt&&(Q.indexed=!0);let B,H;if(m){if(g=m.primaryKey,m.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);u==null&&(u=m.splitSegments),m.attributes.splice(0,m.attributes.length,...o)}else{let Q=h.auditStore;S=o.find(Ae=>Ae.isPrimaryKey)||{},g=S.name,S.is_hash_attribute=S.isPrimaryKey=!0,S.schemaDefined=E,S.compression=Lm(),_&&(S.trackDeletes=!0),c=S.audit=typeof c=="boolean"?c:(0,er.get)(yr.CONFIG_PARAMS.LOGGING_AUDITLOG),n&&(S.expiration=n),s&&(S.eviction=s),S.splitSegments=!1,typeof l=="boolean"&&(S.sealed=l),typeof d=="boolean"&&(S.replicate=d),f&&(S.origins?S.origins.includes(f)||S.origins.push(f):S.origins=[f]),$t.trace(`${t} table loading, opening primary store`);let de=new bl.default(!1,!0);de.compression=S.compression;let j=t+"/";if(b=h.dbisDb=h.openDB(KT.INTERNAL_DBIS_NAME,I),ne(),b.get(j))return H&&H(),xu(),Et(e);let ae=Nh(h.openDB(j,de));h.databaseName=r,ae.rootStore=h,ae.tableId=b.get(Od),$t.trace(`Assigning new table id ${ae.tableId} for ${t}`),ae.tableId||(ae.tableId=1),b.put(Od,ae.tableId+1),S.tableId=ae.tableId,m=vW(T,t,VT({primaryStore:ae,auditStore:Q,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:_,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:g,tableName:t,tableId:ae.tableId,databasePath:r,databaseName:r,indices:{},attributes:o,schemaDefined:E,dbisDB:b})),m.schemaVersion=1,B=!0,b.put(j,S)}let X=m.indices;b=b||(h.dbisDb=h.openDB(KT.INTERNAL_DBIS_NAME,I)),m.dbisDB=b;let Y=[];for(let{key:Q,value:de}of b.getRange({start:!0})){let[j,ae]=Q.toString().split("/");if(ae===""&&(ae=de.name),ae){if(j!==t)continue}else continue;let Ae=o.find(Me=>Me.name===ae),ye=!Ae?.indexed&&de.indexed&&!de.isPrimaryKey;if((!Ae||ye)&&(ne(),B=!0,Ae||b.remove(Q),ye)){let Me=m.indices[j];Me&&Y.push(Me)}}let V=[];try{for(let Q of o||[]){if((Q.relationship||Q.computed)&&(B=!0,Q.relationship))continue;let de=t+"/"+(Q.name||"");Object.defineProperty(Q,"key",{value:de,configurable:!0});let j=b.get(de);if(Q.isPrimaryKey){if(j=j||b.get(de=t+"/")||{},c!==void 0&&c!==m.audit||l!==void 0&&l!==m.sealed||d!==void 0&&d!==m.replicate||(+n||void 0)!==(+j.expiration||void 0)||(+s||void 0)!==(+j.eviction||void 0)){let Ae={...j};typeof c=="boolean"&&(c&&m.enableAuditing(c),Ae.audit=c),n&&(Ae.expiration=+n),s&&(Ae.eviction=+s),l!==void 0&&(Ae.sealed=l),d!==void 0&&(Ae.replicate=d),B=!0,ne(),b.put(de,Ae)}continue}j?.attribute&&!j.name&&(j.indexed=!0);let ae=!j||j.type!==Q.type||j.indexed!==Q.indexed||j.nullable!==Q.nullable||j.version!==Q.version||JSON.stringify(j.properties)!==JSON.stringify(Q.properties)||JSON.stringify(j.elements)!==JSON.stringify(Q.elements);if(Q.indexed){let Ae=new bl.default(!0,!1),ye=h.openDB(de,Ae);(ae||j.indexingPID&&j.indexingPID!==process.pid||j.restartNumber<WE.workerData?.restartNumber)&&(B=!0,ne(),j=b.get(de),(ae||j.indexingPID&&j.indexingPID!==process.pid||j.restartNumber<WE.workerData?.restartNumber)&&(B=!0,Q.indexNulls===void 0&&(Q.indexNulls=!0),m.primaryStore.getStats().entryCount>0&&(Q.lastIndexedKey=j?.lastIndexedKey??void 0,Q.indexingPID=process.pid,ye.isIndexing=!0,Object.defineProperty(Q,"dbi",{value:ye}),V.push(Q))),b.put(de,Q)),j?.indexNulls&&Q.indexNulls===void 0&&(Q.indexNulls=!0),ye.indexNulls=Q.indexNulls,X[Q.name]=ye}else ae&&(B=!0,ne(),b.put(de,Q))}}finally{H&&H()}if(B&&(m.schemaVersion++,m.updatedAttributes()),$t.trace(`${t} table loading, running index`),V.length>0||Y.length>0?m.indexingOperation=oTe(m,V,Y):B&&YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"schema-change",m.databaseName,m.tableName)),m.origin=f,B)for(let Q of VE)Q(m,f!=="cluster");return(n||s||i)&&m.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),$t.trace(`${t} table loaded`),m;function ne(){H||h.transactionSync(()=>({then(Q){H=Q}}))}a(ne,"startTxn")}async function oTe(e,t,r){try{$t.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o={},c=0,l=t.length;if(await new Promise(u=>setImmediate(u)),l>0){let u;for(let _ of t)(0,wd.compareKeys)(_.lastIndexedKey,u)<0&&(u=_.lastIndexedKey),_.lastIndexedKey==null&&_.dbi.clearAsync();let d=0;for(let{key:_,value:E,version:f}of e.primaryStore.getRange({start:u,lazy:l<4,versions:!0,snapshot:!1}))if(E){if(d++,s=e.primaryStore.ifVersion(_,f,()=>{for(let h=0;h<l;h++){let T=t[h],m=T.name;try{let g=T.resolve,S=E&&(g?g(E):E[m]),b=(0,PW.getIndexedValues)(S);if(b)for(let I=0,B=b.length;I<B;I++)T.dbi.put(b[I],_)}catch(g){o[m]||(o[m]=!0,$t.error(`Error indexing attribute ${m}`,g))}}}),s.then(()=>d--,h=>{d--,$t.error(h)}),WE.workerData&&WE.workerData.restartNumber!==LW.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=_,e.dbisDB.put(h.key,h);if(i)return}d>sTe?await s:d>iTe&&await new Promise(h=>setImmediate(h))}for(let _ of t)delete _.lastIndexedKey,delete _.indexingPID,_.dbi.isIndexing=!1,s=e.dbisDB.put(_.key,_)}await s,await YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),$t.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){$t.error("Error in indexing",n)}}function aTe({table:e,database:t}){let r=zl({database:t,table:e}),n=[],s=r.dbisDb;for(let i of s.getKeys({start:e+"/",end:e+"0"}))n.push(s.remove(i));return Promise.all(n)}function Pc(e){return VE.push(e),{remove(){let t=VE.indexOf(e);t>-1&&VE.splice(t,1)}}}function sf(e){return KE.push(e),{remove(){let t=KE.indexOf(e);t>-1&&KE.splice(t,1)}}}function Lm(){let e=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION),t=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION_DICTIONARY),r=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||MW,n={startingOffset:32};return t&&(n.dictionary=YE.readFileSync(t)),r&&(n.threshold=r),e&&n}var er,KT,wd,Ut,rs,Nd,bl,ww,yr,YE,Cw,PW,YT,WT,WE,$t,LW,Dw,zT,MW,jn,We,Od,VE,KE,jT,Ha,Id,sTe,iTe,Pe=Ne(()=>{er=L(se()),KT=L(Bt()),wd=require("lmdb"),Ut=require("path"),rs=require("fs"),Nd=L(gt());$f();bl=L(a_()),ww=L(c_()),yr=L(M()),YE=L(require("fs-extra")),Cw=L(fi()),PW=L(cn()),YT=L(no()),WT=L(qs()),WE=require("worker_threads"),$t=L(W()),LW=L(dt());Ji();Ul();Dw="data",zT=Symbol("defined-tables"),MW=((0,er.get)(yr.CONFIG_PARAMS.STORAGE_PAGESIZE)||4096)-60;(0,er.initSync)();jn=Object.create(null),We=Object.create(null);(0,Cw._assignPackageExport)("databases",We);(0,Cw._assignPackageExport)("tables",jn);Od=Symbol.for("next-table-id"),VE=[],KE=[],Ha=new Map;a(nTe,"getTables");a(ut,"getDatabases");a(xu,"resetDatabases");a($E,"readMetaDb");a(UW,"ensureDB");a(vW,"setTable");a(zl,"database");a(xA,"dropDatabase");a(Et,"table");sTe=1e3,iTe=10;a(oTe,"runIndexing");a(aTe,"dropTableMeta");a(Pc,"onUpdatedTable");a(sf,"onRemovedDB");a(Lm,"getDefaultCompression")});var te=N((rUe,zW)=>{"use strict";var xa=require("path"),FW=require("fs-extra"),In=W(),BW=require("fs-extra"),QT=require("os"),cTe=require("net"),lTe=require("recursive-iterator"),Vt=M(),uTe=hg(),HW=require("papaparse"),JT=require("moment"),{inspect:dTe}=require("util"),xW=require("is-number"),tUe=require("lodash"),_Te=require("minimist"),fTe=require("https"),ETe=require("http"),{hdb_errors:XT}=_e(),hTe=/^((\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)))$/,GW=require("util").promisify(setTimeout),pTe=100,mTe=5,STe="",TTe=4,kW={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};zW.exports={isEmpty:ns,isEmptyOrZeroLength:Wi,arrayHasEmptyValues:ATe,arrayHasEmptyOrZeroLengthValues:yTe,buildFolderPath:bTe,isBoolean:qW,errorizeMessage:gTe,stripFileExtension:NTe,autoCast:ITe,autoCastJSON:$W,autoCastJSONDeep:Lw,removeDir:wTe,compareVersions:CTe,isCompatibleDataVersion:DTe,escapeRawValue:PTe,unescapeValue:LTe,stringifyProps:MTe,timeoutPromise:vTe,isClusterOperation:HTe,getClusterUser:kTe,checkGlobalSchemaTable:xTe,getHomeDir:KW,getPropsFilePath:UTe,promisifyPapaParse:FTe,removeBOM:YW,createEventPromise:GTe,checkProcessRunning:qTe,checkSchemaTableExist:$Te,checkSchemaExists:WW,checkTableExists:jW,getStartOfTomorrowInSeconds:VTe,getLimitKey:KTe,isObject:OTe,isNotEmptyAndHasValue:RTe,autoCasterIsNumberCheck:VW,backtickASTSchemaItems:YTe,isPortTaken:BTe,createForkArgs:WTe,autoCastBoolean:jTe,async_set_timeout:GW,getTableHashAttribute:zTe,doesSchemaExist:QTe,doesTableExist:JTe,stringifyObj:XTe,ms_to_time:ZTe,changeExtension:ege,getEnvCliRootPath:Mw,noBootFile:tge,httpRequest:rge,transformReq:nge,convertToMS:sge,PACKAGE_ROOT:Vt.PACKAGE_ROOT};function gTe(e){return e instanceof Error?e:new Error(e)}a(gTe,"errorizeMessage");function ns(e){return e==null}a(ns,"isEmpty");function RTe(e){return!ns(e)&&(e||e===0||e===""||qW(e))}a(RTe,"isNotEmptyAndHasValue");function Wi(e){return ns(e)||e.length===0||e.size===0}a(Wi,"isEmptyOrZeroLength");function ATe(e){if(ns(e))return!0;for(let t=0;t<e.length;t++)if(ns(e[t]))return!0;return!1}a(ATe,"arrayHasEmptyValues");function yTe(e){if(Wi(e))return!0;for(let t=0;t<e.length;t++)if(Wi(e[t]))return!0;return!1}a(yTe,"arrayHasEmptyOrZeroLengthValues");function bTe(...e){try{return e.join(xa.sep)}catch{console.error(e)}}a(bTe,"buildFolderPath");function qW(e){return ns(e)?!1:e===!0||e===!1}a(qW,"isBoolean");function OTe(e){return ns(e)?!1:typeof e=="object"}a(OTe,"isObject");function NTe(e){return Wi(e)?STe:e.slice(0,-TTe)}a(NTe,"stripFileExtension");function ITe(e){return ns(e)||e===""||typeof e!="string"?e:kW[e]!==void 0?kW[e]:VW(e)===!0?Number(e):hTe.test(e)?new Date(e):e}a(ITe,"autoCast");function $W(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a($W,"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 $W(e)}a(Lw,"autoCastJSONDeep");function VW(e){if(e.startsWith("0.")&&xW(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&xW(e))}a(VW,"autoCasterIsNumberCheck");async function wTe(e){if(Wi(e))throw new Error(`Directory path: ${e} does not exist`);try{await BW.emptyDir(e),await BW.remove(e)}catch(t){throw In.error(`Error removing files in ${e} -- ${t}`),t}}a(wTe,"removeDir");function CTe(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(CTe,"compareVersions");function DTe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(DTe,"isCompatibleDataVersion");function PTe(e){if(ns(e))return e;let t=String(e);return t==="."?Vt.UNICODE_PERIOD:t===".."?Vt.UNICODE_PERIOD+Vt.UNICODE_PERIOD:t.replace(Vt.FORWARD_SLASH_REGEX,Vt.UNICODE_FORWARD_SLASH)}a(PTe,"escapeRawValue");function LTe(e){if(ns(e))return e;let t=String(e);return t===Vt.UNICODE_PERIOD?".":t===Vt.UNICODE_PERIOD+Vt.UNICODE_PERIOD?"..":String(e).replace(Vt.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(LTe,"unescapeValue");function MTe(e,t){if(ns(e))return In.info("Properties object is null"),"";let r="";return e.each(function(n,s){try{if(t&&t[n]){let i=t[n];for(let o of i)r+=";"+o+QT.EOL}!Wi(n)&&n[0]===";"?r+=" "+n+s+QT.EOL:Wi(n)||(r+=n+"="+s+QT.EOL)}catch{In.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(MTe,"stringifyProps");function KW(){let e;try{e=QT.homedir()}catch{e=process.env.HOME}return e}a(KW,"getHomeDir");function UTe(){let e=xa.join(KW(),Vt.HDB_HOME_DIR_NAME,Vt.BOOT_PROPS_FILE_NAME);return FW.existsSync(e)||(e=xa.join(__dirname,"../","hdb_boot_properties.file")),e}a(UTe,"getPropsFilePath");function vTe(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(vTe,"timeoutPromise");async function BTe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=cTe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(BTe,"isPortTaken");function HTe(e){try{return Vt.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){In.error(`Error checking operation against cluster ops ${t}`)}return!1}a(HTe,"isClusterOperation");function xTe(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(xTe,"checkGlobalSchemaTable");function kTe(e,t){if(ns(t)){In.warn("No CLUSTERING_USER defined, clustering disabled");return}if(ns(e)||Wi(e)){In.warn("No users to search.");return}let r;try{let n=e.get(t);n&&n.role.permission.cluster_user===!0&&n.active===!0&&(r=n)}catch(n){In.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){In.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(kTe,"getClusterUser");function FTe(){HW.parsePromise=function(e,t,r){return new Promise(function(n,s){HW.parse(e,{header:!0,transformHeader:YW,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(FTe,"promisifyPapaParse");function YW(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(YW,"removeBOM");function GTe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;In.info(`Got cluster status event response: ${dTe(s)}`);try{i.cancel()}catch{In.error("Error trying to cancel timeout.")}n(s)})})}a(GTe,"createEventPromise");async function qTe(e){let t=!0,r=0;do await GW(pTe*r++),(await uTe.findPs(e)).length>0&&(t=!1);while(t&&r<mTe);if(t)throw new Error(`process ${e} was not started`)}a(qTe,"checkProcessRunning");function $Te(e,t){let r=WW(e);if(r)return r;let n=jW(e,t);if(n)return n}a($Te,"checkSchemaTableExist");function WW(e){let{getDatabases:t}=(Pe(),oe(lt));if(!t()[e])return XT.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(WW,"checkSchemaExists");function jW(e,t){let{getDatabases:r}=(Pe(),oe(lt));if(!r()[e][t])return XT.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(jW,"checkTableExists");function VTe(){let e=JT().utc().add(1,Vt.MOMENT_DAYS_TAG).startOf(Vt.MOMENT_DAYS_TAG).unix(),t=JT().utc().unix();return e-t}a(VTe,"getStartOfTomorrowInSeconds");function KTe(){return JT().utc().format("DD-MM-YYYY")}a(KTe,"getLimitKey");function YTe(e){try{let t=new lTe(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(YTe,"backtickASTSchemaItems");function WTe(e){return[e]}a(WTe,"createForkArgs");function jTe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(jTe,"autoCastBoolean");function zTe(e,t){let{getDatabases:r}=(Pe(),oe(lt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(zTe,"getTableHashAttribute");function QTe(e){let{getDatabases:t}=(Pe(),oe(lt));return t()[e]!==void 0}a(QTe,"doesSchemaExist");function JTe(e,t){let{getDatabases:r}=(Pe(),oe(lt));return r()[e]?.[t]!==void 0}a(JTe,"doesTableExist");function XTe(e){try{return JSON.stringify(e)}catch{return e}}a(XTe,"stringifyObj");function ZTe(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(ZTe,"ms_to_time");function ege(e,t){let r=xa.basename(e,xa.extname(e));return xa.join(xa.dirname(e),r+t)}a(ege,"changeExtension");function Mw(){if(process.env[Vt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[Vt.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=_Te(process.argv);if(e[Vt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[Vt.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(Mw,"getEnvCliRootPath");var Pw;function tge(){if(Pw)return Pw;let e=Mw();if(Mw()&&FW.pathExistsSync(xa.join(e,Vt.HDB_CONFIG_FILE)))return Pw=!0,!0}a(tge,"noBootFile");function rge(e,t){let r;return e.protocol==="http:"?r=ETe:r=fTe,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(rge,"httpRequest");function nge(e){if(!e.schema&&!e.database){e.schema=Vt.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(nge,"transformReq");function sge(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(sge,"convertToMS")});var JW=N((iUe,QW)=>{"use strict";var Uw=M(),ige=te(),oge=Di(),ui=W(),age=Sm(),cge=pf(),sUe=Hu(),lge=ls(),uge=Rf(),dge=require("semver/functions/gte"),_ge=3e4,fge=7;QW.exports=Ege;async function Ege(){try{ui.notify("Starting update nodes. This process will attempt to update any node connections the need to be reestablished after a 4.0.0 upgrade"),await lge.setSchemaDataToGlobalAsync();let e=await oge.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(hge(s))}await Promise.allSettled(t),ui.notify("Shutting down 4.0.0 clustering upgrade process")}catch(e){throw ui.error(e),e}}a(Ege,"updateAllNodes");async function hge(e){try{let{name:t,subscriptions:r}=e;ui.notify("Running 4.0.0 update on node:",t);let n=!1,s=0;for(;s<fge;){let i=[];if(await age.buildNodeStatus(e,i),ui.trace("Received status:",i[0].status,"from node:",t),i[0].status==="open"&&dge(i[0].system_info.hdb_version,"4.0.0")){ui.notify("Received open status from node:",t,"calling add node");let o={operation:Uw.OPERATIONS_ENUM.ADD_NODE,node_name:t,subscriptions:r};await cge(o,!0),ui.notify("Successfully added node",t),n=!0;break}s=(Date.now()-e.__updatedtime__)/(1e3*60*60*24),ui.trace("Update node has been running for",s,"days. Calling node status again for node:",t),await ige.async_set_timeout(_ge)}n||(ui.error("4.0.0 node update was unable to update connection to node:",t),ui.error("Removing following node record from hdb_nodes",e),await uge({operation:Uw.OPERATIONS_ENUM.REMOVE_NODE,node_name:t}))}catch(t){throw ui.error(t),t}}a(hge,"updateNode")});var pge=JW();(async()=>{try{await pge()}catch(e){console.error("Error launching 4.0.0 node update"),console.error(e),process.exit(1)}})();
|