harperdb 4.5.0 → 4.5.1

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/bin/harperdb.js CHANGED
@@ -1,11 +1,11 @@
1
1
  #!/usr/bin/env node
2
- "use strict";var T2=Object.create;var yf=Object.defineProperty;var A2=Object.getOwnPropertyDescriptor;var R2=Object.getOwnPropertyNames;var y2=Object.getPrototypeOf,b2=Object.prototype.hasOwnProperty;var a=(e,t)=>yf(e,"name",{value:t,configurable:!0});var be=(e,t)=>()=>(e&&(t=e(e=0)),t);var w=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),ve=(e,t)=>{for(var r in t)yf(e,r,{get:t[r],enumerable:!0})},oD=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of R2(t))!b2.call(e,s)&&s!==r&&yf(e,s,{get:()=>t[s],enumerable:!(n=A2(t,s))||n.enumerable});return e};var M=(e,t,r)=>(r=e!=null?T2(y2(e)):{},oD(t||!e||!e.__esModule?yf(r,"default",{value:e,enumerable:!0}):r,e)),C=e=>oD(yf({},"__esModule",{value:!0}),e);var st=w((Bye,lD)=>{var{join:O2,dirname:aD}=require("node:path"),{existsSync:N2,readFileSync:w2}=require("node:fs");function I2(){let t=__dirname,r,n=0;for(;!N2(r=O2(t,"package.json"));)if(t===(t=aD(t))||n++>10)throw new Error("Could not find package root");return r}a(I2,"findPackageJson");var cD=I2(),C2=JSON.parse(w2(cD,"utf8")),P2=aD(cD);lD.exports={packageJson:C2,PACKAGE_ROOT:P2}});var rm=w((kye,uD)=>{if(__filename.endsWith("dev.js")){let e=require("fast-glob"),{tmpdir:t}=require("node:os"),{relative:r,join:n}=require("node:path"),{existsSync:s,statSync:i,readFileSync:o,writeFileSync:c}=require("node:fs"),{isMainThread:l}=require("node:worker_threads"),{spawnSync:u,spawn:f}=require("node:child_process"),{PACKAGE_ROOT:d}=st(),p=["bin","components","dataLayer","resources","server","sqlTranslator","upgrade","utility","validation"],_="ts-build";if(l){let g=!1,R=!1;if((R=s(n(d,_)))?g=e.sync(p.map(E=>`${E}/**/*.ts`),{cwd:d}).some(E=>{let T=0,b=0;try{T=i(n(d,E)).mtimeMs-5e3,b=i(n(d,_,E.replace(/.ts$/,".js"))).mtimeMs}catch{}return T>b}):g=!0,g){console.log("Compiling TypeScript...");let E=u("npx",["tsc"],{cwd:d});if(E.stdout?.length&&console.log(E.stdout.toString()),E.stderr?.length&&console.log(E.stderr.toString()),R){let T=n(t(),"harperdb-tsc.pid"),b=!1;if(s(T))try{process.kill(+o(T,"utf8"),0),b=!0}catch{}if(!b){console.log("Starting background TypeScript compilation...");let v=f("npx",["tsc","--watch"],{detached:!0,cwd:d,stdio:"ignore"});c(T,v.pid.toString()),v.unref()}}}}let h=uD.constructor,S=h._findPath;h._findPath=function(g,R,E){if(g.startsWith(".")&&!E&&R.length===1&&R[0].startsWith(d)&&!R[0].includes("node_modules")){let T=r(d,R[0]),b;T.startsWith(_)?b=n(d,r(_,T)):b=n(d,_,T);let v=n(b,g),F=v+".js";if(s(F))return F;if(v.includes(".")&&s(v))return v}return S(g,R,E)}}});var G={};ve(G,{AUTH_AUDIT_STATUS:()=>Ys,AUTH_AUDIT_TYPES:()=>la,BOOT_PROPS_FILE_NAME:()=>tQ,BOOT_PROP_PARAMS:()=>_D,CLUSTERING_FLAG:()=>wQ,CLUSTERING_PROCESSES:()=>F2,CLUSTER_MESSAGE_TYPE_ENUM:()=>jA,CLUSTER_OPERATIONS:()=>EQ,CONFIG_PARAMS:()=>B,CONFIG_PARAM_MAP:()=>pD,DATABASES_DIR_NAME:()=>Rc,DATABASES_PARAM_CONFIG:()=>AQ,DEFAULT_DATABASE_NAME:()=>q2,ESCAPED_FORWARD_SLASH_REGEX:()=>X2,FORWARD_SLASH_REGEX:()=>J2,FUNC_VAL:()=>MQ,GEO_CONVERSION_ENUM:()=>SQ,HDB_COMPONENT_CONFIG_FILE:()=>M2,HDB_CONFIG_FILE:()=>D2,HDB_DEFAULT_CONFIG_FILE:()=>L2,HDB_FILE_PERMISSIONS:()=>nQ,HDB_HOME_DIR_NAME:()=>eQ,HDB_PID_FILE:()=>G2,HDB_PROCESS_SERVICES:()=>k2,HDB_PROC_NAME:()=>v2,HDB_RESTART_SCRIPT:()=>U2,HDB_ROOT_DIR_NAME:()=>VA,HDB_SETTINGS_NAMES:()=>zA,HDB_SUPPORT_ADDRESS:()=>fD,INFO_TABLE_HASH_ATTRIBUTE:()=>lQ,INSERT_MAX_CHARACTER_SIZE:()=>aQ,INSTALL_PROMPTS:()=>oQ,ITC_EVENT_TYPES:()=>QA,JOB_STATUS_ENUM:()=>_Q,JOB_TYPE_ENUM:()=>RQ,JWT_ENUM:()=>Of,LAUNCH_SERVICE_SCRIPTS:()=>K2,LEGACY_CONFIG_PARAMS:()=>TQ,LEGACY_DATABASES_DIR_NAME:()=>im,LICENSE_FILE_NAME:()=>fQ,LICENSE_KEY_DIR_NAME:()=>WA,LICENSE_VALUES:()=>yQ,LOG_LEVELS:()=>V2,LOG_NAMES:()=>$2,MEM_SETTING_KEY:()=>Z2,METADATA_PROPERTY:()=>NQ,NODE_ERROR_CODES:()=>OQ,OPERATIONS_ENUM:()=>Kt,PERMS_CRUD_ENUM:()=>DQ,PERMS_UPDATE_RELEASE_TIMESTAMP:()=>PQ,PRE_4_0_0_VERSION:()=>vQ,PROCESS_DESCRIPTORS:()=>H2,PROCESS_NAME_ENV_PROP:()=>iQ,RAM_ALLOCATION_ENUM:()=>bQ,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:()=>am,REG_KEY_FILE_NAME:()=>dQ,RESTART_TIMEOUT_MS:()=>rQ,ROLE_TYPES_ENUM:()=>Y2,S3_BUCKET_AUTH_KEYS:()=>hQ,SEARCH_NOT_FOUND_MESSAGE:()=>z2,SEARCH_WILDCARDS:()=>LQ,SERVICE_ACTIONS_ENUM:()=>gQ,SUPPORT_HELP_MSG:()=>W2,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:()=>uQ,SYSTEM_SCHEMA_NAME:()=>bf,SYSTEM_TABLE_NAMES:()=>du,THREAD_TYPES:()=>XA,TIME_STAMP_NAMES:()=>CQ,TIME_STAMP_NAMES_ENUM:()=>IQ,TRANSACTIONS_DIR_NAME:()=>sQ,UNICODE_FORWARD_SLASH:()=>Q2,UNICODE_PERIOD:()=>j2,UPGRADE_JSON_FIELD_NAMES_ENUM:()=>cQ,VALID_S3_FILE_TYPES:()=>pQ,VALID_SQL_OPS_ENUM:()=>mQ,VALUE_SEARCH_COMPARATORS:()=>om,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:()=>JA});var nm,sm,D2,L2,VA,M2,v2,U2,dD,$A,KA,YA,x2,B2,H2,k2,F2,G2,q2,$2,V2,K2,Y2,fD,W2,z2,j2,J2,Q2,X2,Z2,bf,eQ,WA,tQ,rQ,nQ,Rc,im,sQ,iQ,_D,oQ,aQ,cQ,du,lQ,uQ,dQ,fQ,_Q,Kt,pQ,hQ,mQ,EQ,gQ,SQ,zA,TQ,B,pD,AQ,RQ,jA,yQ,bQ,OQ,NQ,wQ,hD,mD,IQ,CQ,PQ,om,JA,DQ,LQ,MQ,am,Of,QA,XA,vQ,Ys,la,H=be(()=>{nm=require("node:path"),sm=M(st()),D2="harperdb-config.yaml",L2="defaultConfig.yaml",VA="hdb",M2="config.yaml",v2="harperdb.js",U2="restartHdb.js",dD="HarperDB",$A="Custom Functions",KA="Clustering Hub",YA="Clustering Leaf",x2="Clustering Ingest Service",B2="Clustering Reply Service",H2={HDB:dD,CLUSTERING_HUB:KA,CLUSTERING_LEAF:YA,CLUSTERING_INGEST_SERVICE:x2,CLUSTERING_REPLY_SERVICE:B2,CUSTOM_FUNCTIONS:$A,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"},k2={harperdb:dD,"clustering hub":KA,"clustering leaf":YA,"custom functions":$A,custom_functions:$A,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers",http:"http"},F2={CLUSTERING_HUB_PROC_DESCRIPTOR:KA,CLUSTERING_LEAF_PROC_DESCRIPTOR:YA},G2="hdb.pid",q2="data",$2={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},V2={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},K2={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:(0,nm.join)(sm.PACKAGE_ROOT,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:(0,nm.join)(sm.PACKAGE_ROOT,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:(0,nm.join)(sm.PACKAGE_ROOT,"launchServiceScripts/launchUpdateNodes4-0-0.js")},Y2={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},fD="support@harperdb.io",W2=`For support, please submit a request at https://harperdbhelp.zendesk.com/hc/en-us/requests/new or contact ${fD}`,z2="None of the specified records were found.",j2="U+002E",J2=/\//g,Q2="U+002F",X2=/U\+002F/g,Z2="--max-old-space-size=",bf="system",eQ=".harperdb",WA="keys",tQ="hdb_boot_properties.file",rQ=6e4,nQ=448,Rc="database",im="schema",sQ="transactions",iQ="PROCESS_NAME",_D={SETTINGS_PATH_KEY:"settings_path"},oQ={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"},aQ=250,cQ={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},du={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"},lQ="info_id",uQ={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"},dQ="060493.ks",fQ=".license",_Q={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},Kt={INSERT:"insert",UPDATE:"update",UPSERT:"upsert",SEARCH_BY_CONDITIONS:"search_by_conditions",SEARCH_BY_HASH:"search_by_hash",SEARCH_BY_ID:"search_by_id",SEARCH_BY_VALUE:"search_by_value",SEARCH:"search",SQL:"sql",CSV_DATA_LOAD:"csv_data_load",CSV_FILE_LOAD:"csv_file_load",CSV_URL_LOAD:"csv_url_load",CREATE_SCHEMA:"create_schema",CREATE_DATABASE:"create_database",CREATE_TABLE:"create_table",CREATE_ATTRIBUTE:"create_attribute",DROP_SCHEMA:"drop_schema",DROP_DATABASE:"drop_database",DROP_TABLE:"drop_table",DESCRIBE_SCHEMA:"describe_schema",DESCRIBE_DATABASE:"describe_database",DESCRIBE_TABLE:"describe_table",DESCRIBE_ALL:"describe_all",DELETE:"delete",ADD_USER:"add_user",ALTER_USER:"alter_user",DROP_USER:"drop_user",LIST_USERS:"list_users",LIST_ROLES:"list_roles",ADD_ROLE:"add_role",ALTER_ROLE:"alter_role",DROP_ROLE:"drop_role",USER_INFO:"user_info",READ_LOG:"read_log",ADD_NODE:"add_node",UPDATE_NODE:"update_node",SET_NODE_REPLICATION:"set_node_replication",EXPORT_TO_S3:"export_to_s3",IMPORT_FROM_S3:"import_from_s3",DELETE_FILES_BEFORE:"delete_files_before",DELETE_RECORDS_BEFORE:"delete_records_before",EXPORT_LOCAL:"export_local",SEARCH_JOBS_BY_START_DATE:"search_jobs_by_start_date",GET_JOB:"get_job",DELETE_JOB:"delete_job",UPDATE_JOB:"update_job",GET_FINGERPRINT:"get_fingerprint",SET_LICENSE:"set_license",GET_REGISTRATION_INFO:"registration_info",CONFIGURE_CLUSTER:"configure_cluster",SET_CONFIGURATION:"set_configuration",CLUSTER_STATUS:"cluster_status",CLUSTER_NETWORK:"cluster_network",DROP_ATTRIBUTE:"drop_attribute",REMOVE_NODE:"remove_node",RESTART:"restart",RESTART_SERVICE:"restart_service",CATCHUP:"catchup",SYSTEM_INFORMATION:"system_information",DELETE_AUDIT_LOGS_BEFORE:"delete_audit_logs_before",READ_AUDIT_LOG:"read_audit_log",CREATE_AUTHENTICATION_TOKENS:"create_authentication_tokens",LOGIN:"login",LOGOUT:"logout",REFRESH_OPERATION_TOKEN:"refresh_operation_token",GET_CONFIGURATION:"get_configuration",CUSTOM_FUNCTIONS_STATUS:"custom_functions_status",GET_CUSTOM_FUNCTIONS:"get_custom_functions",GET_CUSTOM_FUNCTION:"get_custom_function",SET_CUSTOM_FUNCTION:"set_custom_function",GET_COMPONENTS:"get_components",GET_COMPONENT_FILE:"get_component_file",SET_COMPONENT_FILE:"set_component_file",DROP_COMPONENT:"drop_component",DROP_CUSTOM_FUNCTION:"drop_custom_function",ADD_CUSTOM_FUNCTION_PROJECT:"add_custom_function_project",ADD_COMPONENT:"add_component",DROP_CUSTOM_FUNCTION_PROJECT:"drop_custom_function_project",PACKAGE_CUSTOM_FUNCTION_PROJECT:"package_custom_function_project",DEPLOY_CUSTOM_FUNCTION_PROJECT:"deploy_custom_function_project",PACKAGE_COMPONENT:"package_component",DEPLOY_COMPONENT:"deploy_component",CLUSTER_SET_ROUTES:"cluster_set_routes",CLUSTER_DELETE_ROUTES:"cluster_delete_routes",CLUSTER_GET_ROUTES:"cluster_get_routes",READ_TRANSACTION_LOG:"read_transaction_log",DELETE_TRANSACTION_LOGS_BEFORE:"delete_transaction_logs_before",INSTALL_NODE_MODULES:"install_node_modules",AUDIT_NODE_MODULES:"audit_node_modules",PURGE_STREAM:"purge_stream",GET_BACKUP:"get_backup",SIGN_CERTIFICATE:"sign_certificate",CREATE_CSR:"create_csr",LIST_CERTIFICATES:"list_certificates",ADD_CERTIFICATES:"add_certificate",REMOVE_CERTIFICATE:"remove_certificate",ADD_NODE_BACK:"add_node_back",REMOVE_NODE_BACK:"remove_node_back",ADD_SSH_KEY:"add_ssh_key",UPDATE_SSH_KEY:"update_ssh_key",DELETE_SSH_KEY:"delete_ssh_key",LIST_SSH_KEYS:"list_ssh_keys",SET_SSH_KNOWN_HOSTS:"set_ssh_known_hosts",GET_SSH_KNOWN_HOSTS:"get_ssh_known_hosts",GET_KEY:"get_key"},pQ={CSV:".csv",JSON:".json"},hQ={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},mQ={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},EQ={[Kt.INSERT]:Kt.INSERT,[Kt.UPDATE]:Kt.UPDATE,[Kt.UPSERT]:Kt.UPSERT,[Kt.DELETE]:Kt.DELETE},gQ={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"},SQ={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},zA={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"},TQ={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"},B={ANALYTICS_AGGREGATEPERIOD:"analytics_aggregatePeriod",AUTHENTICATION_AUTHORIZELOCAL:"authentication_authorizeLocal",AUTHENTICATION_CACHETTL:"authentication_cacheTTL",AUTHENTICATION_ENABLESESSIONS:"authentication_enableSessions",AUTHENTICATION_OPERATIONTOKENTIMEOUT:"authentication_operationTokenTimeout",AUTHENTICATION_REFRESHTOKENTIMEOUT:"authentication_refreshTokenTimeout",AUTHENTICATION_HASHFUNCTION:"authentication_hashFunction",CLUSTERING_USER:"clustering_user",CLUSTERING_ENABLED:"clustering_enabled",CLUSTERING_HUBSERVER_CLUSTER_NAME:"clustering_hubServer_cluster_name",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT:"clustering_hubServer_cluster_network_port",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES:"clustering_hubServer_cluster_network_routes",CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT:"clustering_hubServer_leafNodes_network_port",CLUSTERING_HUBSERVER_NETWORK_PORT:"clustering_hubServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_PORT:"clustering_leafServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_ROUTES:"clustering_leafServer_network_routes",CLUSTERING_LEAFSERVER_STREAMS_MAXAGE:"clustering_leafServer_streams_maxAge",CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES:"clustering_leafServer_streams_maxBytes",CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS:"clustering_leafServer_streams_maxMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS:"clustering_leafServer_streams_maxConsumeMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS:"clustering_leafServer_streams_maxIngestThreads",CLUSTERING_LEAFSERVER_STREAMS_PATH:"clustering_leafServer_streams_path",CLUSTERING_NODENAME:"clustering_nodeName",CLUSTERING_TLS_CERTIFICATE:"clustering_tls_certificate",CLUSTERING_TLS_PRIVATEKEY:"clustering_tls_privateKey",CLUSTERING_TLS_CERT_AUTH:"clustering_tls_certificateAuthority",CLUSTERING_TLS_INSECURE:"clustering_tls_insecure",CLUSTERING_TLS_VERIFY:"clustering_tls_verify",CLUSTERING_LOGLEVEL:"clustering_logLevel",CLUSTERING_REPUBLISHMESSAGES:"clustering_republishMessages",CLUSTERING_DATABASELEVEL:"clustering_databaseLevel",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",THREADS:"threads",THREADS_COUNT:"threads_count",THREADS_DEBUG:"threads_debug",THREADS_DEBUG_STARTINGPORT:"threads_debug_startingPort",THREADS_DEBUG_PORT:"threads_debug_port",THREADS_DEBUG_HOST:"threads_debug_host",THREADS_DEBUG_WAITFORDEBUGGER:"threads_debug_waitForDebugger",THREADS_MAXHEAPMEMORY:"threads_maxHeapMemory",HTTP_SESSIONAFFINITY:"http_sessionAffinity",HTTP_COMPRESSIONTHRESHOLD:"http_compressionThreshold",HTTP_CORS:"http_cors",HTTP_CORSACCESSLIST:"http_corsAccessList",HTTP_CORSACCESSCONTROLALLOWHEADERS:"http_corsAccessControlAllowHeaders",HTTP_HEADERSTIMEOUT:"http_headersTimeout",HTTP_KEEPALIVETIMEOUT:"http_keepAliveTimeout",HTTP_MAXPARAMLENGTH:"http_maxParamLength",HTTP_TIMEOUT:"http_timeout",HTTP_PORT:"http_port",HTTP_SECUREPORT:"http_securePort",HTTP_MTLS:"http_mtls",HTTP_MTLS_REQUIRED:"http_mtls_required",HTTP_MTLS_USER:"http_mtls_user",HTTP_MAXHEADERSIZE:"http_maxHeaderSize",HTTP_THREADRANGE:"http_threadRange",HTTP_HTTP2:"http_http2",LOCALSTUDIO_ENABLED:"localStudio_enabled",LOGGING_CONSOLE:"logging_console",LOGGING_FILE:"logging_file",LOGGING_LEVEL:"logging_level",LOGGING_ROOT:"logging_root",LOGGING_ROTATION_ENABLED:"logging_rotation_enabled",LOGGING_ROTATION_COMPRESS:"logging_rotation_compress",LOGGING_ROTATION_INTERVAL:"logging_rotation_interval",LOGGING_ROTATION_MAXSIZE:"logging_rotation_maxSize",LOGGING_ROTATION_PATH:"logging_rotation_path",LOGGING_ROTATION_RETENTION:"logging_rotation_retention",LOGGING_STDSTREAMS:"logging_stdStreams",LOGGING_AUDITLOG:"logging_auditLog",LOGGING_AUDITRETENTION:"logging_auditRetention",LOGGING_AUDITAUTHEVENTS_LOGFAILED:"logging_auditAuthEvents_logFailed",LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL:"logging_auditAuthEvents_logSuccessful",OPERATIONSAPI_NETWORK_CORS:"operationsApi_network_cors",OPERATIONSAPI_NETWORK_CORSACCESSLIST:"operationsApi_network_corsAccessList",OPERATIONSAPI_NETWORK_HEADERSTIMEOUT:"operationsApi_network_headersTimeout",OPERATIONSAPI_NETWORK_HTTPS:"operationsApi_network_https",OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT:"operationsApi_network_keepAliveTimeout",OPERATIONSAPI_NETWORK_PORT:"operationsApi_network_port",OPERATIONSAPI_NETWORK_DOMAINSOCKET:"operationsApi_network_domainSocket",OPERATIONSAPI_NETWORK_SECUREPORT:"operationsApi_network_securePort",OPERATIONSAPI_NETWORK_HTTP2:"operationsApi_network_http2",OPERATIONSAPI_TLS:"operationsApi_tls",OPERATIONSAPI_TLS_CERTIFICATE:"operationsApi_tls_certificate",OPERATIONSAPI_TLS_PRIVATEKEY:"operationsApi_tls_privateKey",OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY:"operationsApi_tls_certificateAuthority",OPERATIONSAPI_NETWORK_TIMEOUT:"operationsApi_network_timeout",OPERATIONSAPI_SYSINFO_NETWORK:"operationsApi_sysInfo_network",OPERATIONSAPI_SYSINFO_DISK:"operationsApi_sysInfo_disk",REPLICATION:"replication",REPLICATION_HOSTNAME:"replication_hostname",REPLICATION_URL:"replication_url",REPLICATION_PORT:"replication_port",REPLICATION_SECUREPORT:"replication_securePort",REPLICATION_ROUTES:"replication_routes",REPLICATION_DATABASES:"replication_databases",REPLICATION_ENABLEROOTCAS:"replication_enableRootCAs",REPLICATION_COPYTABLESTOCATCHUP:"replication_copyTablesToCatchUp",ROOTPATH:"rootPath",SERIALIZATION_BIGINT:"serialization_bigInt",STORAGE_WRITEASYNC:"storage_writeAsync",STORAGE_OVERLAPPINGSYNC:"storage_overlappingSync",STORAGE_CACHING:"storage_caching",STORAGE_COMPRESSION:"storage_compression",STORAGE_NOREADAHEAD:"storage_noReadAhead",STORAGE_PREFETCHWRITES:"storage_prefetchWrites",STORAGE_ENCRYPTION:"storage_encryption",STORAGE_MAXTRANSACTIONQUEUETIME:"storage_maxTransactionQueueTime",STORAGE_PATH:"storage_path",STORAGE_BLOBPATHS:"storage_blobPaths",STORAGE_AUDIT_PATH:"storage_audit_path",STORAGE_MAXFREESPACETOLOAD:"storage_maxFreeSpaceToLoad",STORAGE_MAXFREESPACETORETAIN:"storage_maxFreeSpaceToRetain",STORAGE_PAGESIZE:"storage_pageSize",STORAGE_COMPRESSION_DICTIONARY:"storage_compression_dictionary",STORAGE_COMPRESSION_THRESHOLD:"storage_compression_threshold",STORAGE_COMPACTONSTART:"storage_compactOnStart",STORAGE_COMPACTONSTARTKEEPBACKUP:"storage_compactOnStartKeepBackup",STORAGE_RECLAMATION_THRESHOLD:"storage_reclamation_threshold",STORAGE_RECLAMATION_INTERVAL:"storage_reclamation_interval",STORAGE_RECLAMATION_EVICTIONFACTOR:"storage_reclamation_evictionFactor",DATABASES:"databases",IGNORE_SCRIPTS:"ignoreScripts",MQTT_NETWORK_PORT:"mqtt_network_port",MQTT_WEBSOCKET:"mqtt_webSocket",MQTT_NETWORK_SECUREPORT:"mqtt_network_securePort",MQTT_NETWORK_MTLS:"mqtt_network_mtls",MQTT_NETWORK_MTLS_REQUIRED:"mqtt_network_mtls_required",MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY:"mqtt_network_mtls_certificateAuthority",MQTT_NETWORK_MTLS_USER:"mqtt_network_mtls_user",MQTT_REQUIREAUTHENTICATION:"mqtt_requireAuthentication",COMPONENTSROOT:"componentsRoot",TLS_CERTIFICATE:"tls_certificate",TLS_PRIVATEKEY:"tls_privateKey",TLS_CERTIFICATEAUTHORITY:"tls_certificateAuthority",TLS_CIPHERS:"tls_ciphers",TLS:"tls",CLONED:"cloned"},pD={settings_path:_D.SETTINGS_PATH_KEY,hdb_root_key:B.ROOTPATH,hdb_root:B.ROOTPATH,rootpath:B.ROOTPATH,server_port_key:B.OPERATIONSAPI_NETWORK_PORT,server_port:B.OPERATIONSAPI_NETWORK_PORT,cert_key:B.TLS_CERTIFICATE,certificate:B.TLS_CERTIFICATE,private_key_key:B.TLS_PRIVATEKEY,private_key:B.TLS_PRIVATEKEY,http_secure_enabled_key:B.OPERATIONSAPI_NETWORK_HTTPS,https_on:B.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:B.OPERATIONSAPI_NETWORK_CORS,cors_on:B.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:B.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:B.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:B.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:B.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:B.LOGGING_LEVEL,log_level:B.LOGGING_LEVEL,log_path_key:B.LOGGING_ROOT,log_path:B.LOGGING_ROOT,clustering_node_name_key:B.CLUSTERING_NODENAME,node_name:B.CLUSTERING_NODENAME,clustering_enabled_key:B.CLUSTERING_ENABLED,clustering:B.CLUSTERING_ENABLED,max_http_threads:B.THREADS_COUNT,max_hdb_processes:B.THREADS_COUNT,server_timeout_key:B.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:B.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:B.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:B.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:B.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:B.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:B.LOGGING_AUDITLOG,disable_transaction_log:B.LOGGING_AUDITLOG,operation_token_timeout_key:B.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:B.AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:B.AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:B.AUTHENTICATION_REFRESHTOKENTIMEOUT,custom_functions_port_key:B.HTTP_PORT,custom_functions_port:B.HTTP_PORT,custom_functions_directory_key:B.COMPONENTSROOT,custom_functions_directory:B.COMPONENTSROOT,max_custom_function_processes:B.THREADS_COUNT,logging_console:B.LOGGING_CONSOLE,log_to_file:B.LOGGING_FILE,log_to_stdstreams:B.LOGGING_STDSTREAMS,local_studio_on:B.LOCALSTUDIO_ENABLED,clustering_port:B.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:B.CLUSTERING_USER,customfunctions_network_port:B.HTTP_PORT,customfunctions_tls_certificate:B.TLS_CERTIFICATE,customfunctions_network_cors:B.HTTP_CORS,customfunctions_network_corsaccesslist:B.HTTP_CORSACCESSLIST,customfunctions_network_headerstimeout:B.HTTP_HEADERSTIMEOUT,customfunctions_network_https:B.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:B.HTTP_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:B.TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:B.TLS_CERTIFICATEAUTHORITY,customfunctions_network_timeout:B.HTTP_TIMEOUT,customfunctions_tls:B.TLS,http_threads:B.THREADS_COUNT,threads:B.THREADS_COUNT,threads_count:B.THREADS_COUNT,customfunctions_processes:B.THREADS_COUNT,customfunctions_root:B.COMPONENTSROOT,operationsapi_root:B.ROOTPATH};for(let e in B){let t=B[e];pD[t.toLowerCase()]=t}AQ={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},RQ={csv_file_load:"csv_file_load",csv_data_load:Kt.CSV_DATA_LOAD,csv_url_load:Kt.CSV_URL_LOAD,delete_files_before:"delete_files_before",delete_records_before:"delete_records_before",delete_audit_logs_before:"delete_audit_logs_before",delete_transaction_logs_before:"delete_transaction_logs_before",empty_trash:"empty_trash",export_local:"export_local",export_to_s3:"export_to_s3",import_from_s3:"import_from_s3",restart_service:"restart_service"},jA={CLUSTERING_PAYLOAD:"clustering_payload",DELEGATE_THREAD_RESPONSE:"delegate_thread_response",CLUSTERING:"clustering",SCHEMA:"schema",CLUSTER_STATUS:"cluster_status",JOB:"job",CHILD_STARTED:"child_started",CHILD_STOPPED:"child_stopped",USER:"user",RESTART:"restart"},yQ={VERSION_DEFAULT:"2.2.0"},bQ={DEVELOPMENT:8192,DEFAULT:512},OQ={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},NQ=Symbol("metadata"),wQ="__clustering__",hD="__createdtime__",mD="__updatedtime__",IQ={CREATED_TIME:hD,UPDATED_TIME:mD},CQ=[hD,mD],PQ=15984864e5,om={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},JA={"<":"LESS","<=":"LESS_OR_EQ",">":"GREATER",">=":"GREATER_OR_EQ","...":"BETWEEN"},DQ={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},LQ=["*","%"],MQ="func_val",am={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},Of={JWT_PRIVATE_KEY_NAME:".jwtPrivate.key",JWT_PUBLIC_KEY_NAME:".jwtPublic.key",JWT_PASSPHRASE_NAME:".jwtPass"},QA={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"},XA={HTTP:"http"},vQ="3.x.x",Ys={SUCCESS:"success",FAILURE:"failure"},la={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"}});var ua=w((Fye,SD)=>{"use strict";var ED=require("minimist");SD.exports=UQ;function UQ(e=[],t=!1){if(!Array.isArray(e))return{};let r,n;t?(r=gD(process.env),n=gD(ED(process.argv))):(r=process.env,n=ED(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(UQ,"assignCMDENVVariables");function gD(e){let t,r=Object.keys(e),n=r.length,s={};for(;n--;)t=r[n],s[t.toLowerCase()]=e[t];return s}a(gD,"objKeysToLowerCase")});var Ti=w(Ws=>{"use strict";global.Resource=Ws.Resource=void 0;global.tables=Ws.tables={};global.databases=Ws.databases={};global.getUser=Ws.getUser=void 0;global.authenticateUser=Ws.authenticateUser=void 0;global.server=Ws.server={};global.contentTypes=Ws.contentTypes=null;global.threads=Ws.threads=[];global.logger={};Ws._assignPackageExport=(e,t)=>{global[e]=Ws[e]=t}});var z=w((vD,UD)=>{"use strict";var no=require("fs-extra"),{workerData:xQ,threadId:BQ,isMainThread:HQ}=require("worker_threads"),Ri=require("path"),yD=require("yaml"),bD=require("properties-reader"),Yt=(H(),C(G)),TD=ua(),kQ=require("os"),{PACKAGE_ROOT:rR}=st(),{_assignPackageExport:FQ}=Ti(),AD=process.stdout.nativeWrite||(process.stdout.nativeWrite=process.stdout.write),mr={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},OD={STDOUT:"stdOut",STDERR:"stdErr"},GQ=Ri.join(rR,"logs"),qQ=Ri.join(rR,"config/yaml/",Yt.HDB_DEFAULT_CONFIG_FILE),$Q=1e4,ZA,Ai,ms,Cr,cm,Nf,lm,da,wf;wf===void 0&&ND();Object.assign(vD,{notify:DD,fatal:LD,error:um,warn:MD,info:ID,debug:PD,trace:CD,setLogLevel:QQ,log_level:Cr,loggerWithTag:YQ,suppressLogging:WQ,initLogSettings:ND,logCustomLevel:jQ,closeLogFile:nR,logsAtLevel:VQ,getLogFilePath:a(()=>lm,"getLogFilePath"),OUTPUTS:OD,AuthAuditLog:e4});FQ("logger",UD.exports);var eR;function VQ(e){return mr[Cr]<=mr[e]}a(VQ,"logsAtLevel");function ND(e=!1){try{if(wf===void 0||e){nR();let t=JQ(),r=TD(["ROOTPATH"]);try{wf=bD(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!no.pathExistsSync(Ri.join(r.ROOTPATH,Yt.HDB_CONFIG_FILE)))throw n}if({level:Cr,config_log_path:Nf,to_file:Ai,to_stream:ms}=XQ(r.ROOTPATH?Ri.join(r.ROOTPATH,Yt.HDB_CONFIG_FILE):wf.get("settings_path")),cm=Yt.LOG_NAMES.HDB,lm=Ri.join(Nf,cm),HQ)try{require("segfault-handler").registerHandler(Ri.join(Nf,"crash.log"))}catch{}}}catch(t){if(wf=void 0,t.code===Yt.NODE_ERROR_CODES.ENOENT||t.code===Yt.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=TD(Object.keys(Yt.CONFIG_PARAM_MAP),!0);for(let o in r){let c=Yt.CONFIG_PARAM_MAP[o];c&&c.toLowerCase();let l=r[o];if(c===Yt.CONFIG_PARAMS.LOGGING_LEVEL){Cr=l;continue}if(c===Yt.CONFIG_PARAMS.LOGGING_STDSTREAMS){ms=l;continue}c===Yt.CONFIG_PARAMS.LOGGING_FILE&&(Ai=c),c===Yt.CONFIG_PARAMS.LOGGING_CONSOLE&&(ZA=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=ZQ();Ai=Ai===void 0?s:Ai,Ai=RD(Ai),ms=ms===void 0?i:ms,ms=RD(ms),Cr=Cr===void 0?n:Cr,Nf=GQ,cm=Yt.LOG_NAMES.INSTALL,lm=Ri.join(Nf,cm);return}throw um("Error initializing log settings"),um(t),t}process.env.DEV_MODE&&(ms=!0),KQ()}a(ND,"initLogSettings");var fa=!0;function KQ(){Ai&&(process.stdout.write=function(e){return typeof e=="string"&&fa&&ZA!==!1&&(tR(),e=e.toString(),e[e.length-1]===`
3
- `&&(e=e.slice(0,-1)),no.appendFileSync(da,zs("stdout",[e]))),AD.apply(process.stdout,arguments)},process.stderr.write=function(e){return typeof e=="string"&&fa&&ZA!==!1&&(tR(),e[e.length-1]===`
4
- `&&(e=e.slice(0,-1)),no.appendFileSync(da,zs("stderr",[e]))),AD.apply(process.stderr,arguments)})}a(KQ,"stdioLogging");function YQ(e,t){let r={tagName:e.replace(/ /g,"-")};return{notify:n(DD,"notify"),fatal:n(LD,"fatal"),error:n(um,"error"),warn:n(MD,"warn"),info:n(ID,"info"),debug:n(PD,"debug"),trace:n(CD,"trace")};function n(s,i){return!t||mr[Cr]<=mr[i]?function(...o){return s(r,...o)}:null}}a(YQ,"loggerWithTag");function WQ(e){try{fa=!1,e()}finally{fa=!0}}a(WQ,"suppressLogging");var zQ=xQ?.name?.replace(/ /g,"-")||"main";function zs(e,t){let r=new Date(Date.now()).toISOString(),n="",s=t.length,i=s-1,o=[e],c=0,l;for(typeof t[0]=="object"&&(t[0]?.tagName?(o.push(t[0]?.tagName),c++):t[0]?.serviceName&&(l=t[0]?.serviceName,c++)),o.unshift(l||zQ+"/"+BQ);c<s;c++){let u=t[c];if(u instanceof Error&&u.stack)n+=u.stack,Object.keys(u).length>0&&(n+=`
2
+ "use strict";var S2=Object.create;var yf=Object.defineProperty;var T2=Object.getOwnPropertyDescriptor;var A2=Object.getOwnPropertyNames;var R2=Object.getPrototypeOf,y2=Object.prototype.hasOwnProperty;var a=(e,t)=>yf(e,"name",{value:t,configurable:!0});var be=(e,t)=>()=>(e&&(t=e(e=0)),t);var w=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),ve=(e,t)=>{for(var r in t)yf(e,r,{get:t[r],enumerable:!0})},aD=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of A2(t))!y2.call(e,s)&&s!==r&&yf(e,s,{get:()=>t[s],enumerable:!(n=T2(t,s))||n.enumerable});return e};var M=(e,t,r)=>(r=e!=null?S2(R2(e)):{},aD(t||!e||!e.__esModule?yf(r,"default",{value:e,enumerable:!0}):r,e)),C=e=>aD(yf({},"__esModule",{value:!0}),e);var it=w((Fye,uD)=>{var{join:b2,dirname:cD}=require("node:path"),{existsSync:O2,readFileSync:N2}=require("node:fs");function w2(){let t=__dirname,r,n=0;for(;!O2(r=b2(t,"package.json"));)if(t===(t=cD(t))||n++>10)throw new Error("Could not find package root");return r}a(w2,"findPackageJson");var lD=w2(),I2=JSON.parse(N2(lD,"utf8")),C2=cD(lD);uD.exports={packageJson:I2,PACKAGE_ROOT:C2}});var nm=w((qye,dD)=>{if(__filename.endsWith("dev.js")){let e=require("fast-glob"),{tmpdir:t}=require("node:os"),{relative:r,join:n}=require("node:path"),{existsSync:s,statSync:i,readFileSync:o,writeFileSync:c}=require("node:fs"),{isMainThread:l}=require("node:worker_threads"),{spawnSync:u,spawn:f}=require("node:child_process");process.setSourceMapsEnabled(!0);let{PACKAGE_ROOT:d}=it(),p=["bin","components","dataLayer","resources","server","sqlTranslator","upgrade","utility","validation"],_="ts-build";if(l){let g=!1,R=!1;if((R=s(n(d,_)))?g=e.sync(p.map(E=>`${E}/**/*.ts`),{cwd:d}).some(E=>{let T=0,b=0;try{T=i(n(d,E)).mtimeMs-5e3,b=i(n(d,_,E.replace(/.ts$/,".js"))).mtimeMs}catch{}return T>b}):g=!0,g){console.log("Compiling TypeScript...");let E=u("npx",["tsc"],{cwd:d});if(E.stdout?.length&&console.log(E.stdout.toString()),E.stderr?.length&&console.log(E.stderr.toString()),R){let T=n(t(),"harperdb-tsc.pid"),b=!1;if(s(T))try{process.kill(+o(T,"utf8"),0),b=!0}catch{}if(!b){console.log("Starting background TypeScript compilation...");let v=f("npx",["tsc","--watch"],{detached:!0,cwd:d,stdio:"ignore"});c(T,v.pid.toString()),v.unref()}}}}let h=dD.constructor,S=h._findPath;h._findPath=function(g,R,E){if(g.startsWith(".")&&!E&&R.length===1&&R[0].startsWith(d)&&!R[0].includes("node_modules")){let T=r(d,R[0]),b;T.startsWith(_)?b=n(d,r(_,T)):b=n(d,_,T);let v=n(b,g),F=v+".js";if(s(F))return F;if(v.includes(".")&&s(v))return v}return S(g,R,E)}}});var G={};ve(G,{AUTH_AUDIT_STATUS:()=>Ys,AUTH_AUDIT_TYPES:()=>la,BOOT_PROPS_FILE_NAME:()=>eQ,BOOT_PROP_PARAMS:()=>pD,CLUSTERING_FLAG:()=>NQ,CLUSTERING_PROCESSES:()=>k2,CLUSTER_MESSAGE_TYPE_ENUM:()=>JA,CLUSTER_OPERATIONS:()=>mQ,CONFIG_PARAMS:()=>x,CONFIG_PARAM_MAP:()=>hD,DATABASES_DIR_NAME:()=>Nc,DATABASES_PARAM_CONFIG:()=>TQ,DEFAULT_DATABASE_NAME:()=>G2,ESCAPED_FORWARD_SLASH_REGEX:()=>Q2,FORWARD_SLASH_REGEX:()=>j2,FUNC_VAL:()=>LQ,GEO_CONVERSION_ENUM:()=>gQ,HDB_COMPONENT_CONFIG_FILE:()=>L2,HDB_CONFIG_FILE:()=>P2,HDB_DEFAULT_CONFIG_FILE:()=>D2,HDB_FILE_PERMISSIONS:()=>rQ,HDB_HOME_DIR_NAME:()=>Z2,HDB_PID_FILE:()=>F2,HDB_PROCESS_SERVICES:()=>H2,HDB_PROC_NAME:()=>M2,HDB_RESTART_SCRIPT:()=>v2,HDB_ROOT_DIR_NAME:()=>KA,HDB_SETTINGS_NAMES:()=>jA,HDB_SUPPORT_ADDRESS:()=>_D,INFO_TABLE_HASH_ATTRIBUTE:()=>cQ,INSERT_MAX_CHARACTER_SIZE:()=>oQ,INSTALL_PROMPTS:()=>iQ,ITC_EVENT_TYPES:()=>XA,JOB_STATUS_ENUM:()=>fQ,JOB_TYPE_ENUM:()=>AQ,JWT_ENUM:()=>Of,LAUNCH_SERVICE_SCRIPTS:()=>V2,LEGACY_CONFIG_PARAMS:()=>SQ,LEGACY_DATABASES_DIR_NAME:()=>om,LICENSE_FILE_NAME:()=>dQ,LICENSE_KEY_DIR_NAME:()=>zA,LICENSE_VALUES:()=>RQ,LOG_LEVELS:()=>$2,LOG_NAMES:()=>q2,MEM_SETTING_KEY:()=>X2,METADATA_PROPERTY:()=>OQ,NODE_ERROR_CODES:()=>bQ,OPERATIONS_ENUM:()=>Yt,PERMS_CRUD_ENUM:()=>PQ,PERMS_UPDATE_RELEASE_TIMESTAMP:()=>CQ,PRE_4_0_0_VERSION:()=>MQ,PROCESS_DESCRIPTORS:()=>B2,PROCESS_NAME_ENV_PROP:()=>sQ,RAM_ALLOCATION_ENUM:()=>yQ,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:()=>cm,REG_KEY_FILE_NAME:()=>uQ,RESTART_TIMEOUT_MS:()=>tQ,ROLE_TYPES_ENUM:()=>K2,S3_BUCKET_AUTH_KEYS:()=>pQ,SEARCH_NOT_FOUND_MESSAGE:()=>W2,SEARCH_WILDCARDS:()=>DQ,SERVICE_ACTIONS_ENUM:()=>EQ,SUPPORT_HELP_MSG:()=>Y2,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:()=>lQ,SYSTEM_SCHEMA_NAME:()=>bf,SYSTEM_TABLE_NAMES:()=>fu,THREAD_TYPES:()=>ZA,TIME_STAMP_NAMES:()=>IQ,TIME_STAMP_NAMES_ENUM:()=>wQ,TRANSACTIONS_DIR_NAME:()=>nQ,UNICODE_FORWARD_SLASH:()=>J2,UNICODE_PERIOD:()=>z2,UPGRADE_JSON_FIELD_NAMES_ENUM:()=>aQ,VALID_S3_FILE_TYPES:()=>_Q,VALID_SQL_OPS_ENUM:()=>hQ,VALUE_SEARCH_COMPARATORS:()=>am,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:()=>QA});var sm,im,P2,D2,KA,L2,M2,v2,fD,VA,YA,WA,U2,x2,B2,H2,k2,F2,G2,q2,$2,V2,K2,_D,Y2,W2,z2,j2,J2,Q2,X2,bf,Z2,zA,eQ,tQ,rQ,Nc,om,nQ,sQ,pD,iQ,oQ,aQ,fu,cQ,lQ,uQ,dQ,fQ,Yt,_Q,pQ,hQ,mQ,EQ,gQ,jA,SQ,x,hD,TQ,AQ,JA,RQ,yQ,bQ,OQ,NQ,mD,ED,wQ,IQ,CQ,am,QA,PQ,DQ,LQ,cm,Of,XA,ZA,MQ,Ys,la,H=be(()=>{sm=require("node:path"),im=M(it()),P2="harperdb-config.yaml",D2="defaultConfig.yaml",KA="hdb",L2="config.yaml",M2="harperdb.js",v2="restartHdb.js",fD="HarperDB",VA="Custom Functions",YA="Clustering Hub",WA="Clustering Leaf",U2="Clustering Ingest Service",x2="Clustering Reply Service",B2={HDB:fD,CLUSTERING_HUB:YA,CLUSTERING_LEAF:WA,CLUSTERING_INGEST_SERVICE:U2,CLUSTERING_REPLY_SERVICE:x2,CUSTOM_FUNCTIONS:VA,RESTART_HDB:"Restart HDB",INSTALL:"Install",RUN:"Run",STOP:"Stop",UPGRADE:"Upgrade",REGISTER:"Register",JOB:"Job",CLUSTERING_UPGRADE_4_0_0:"Upgrade-4-0-0"},H2={harperdb:fD,"clustering hub":YA,"clustering leaf":WA,"custom functions":VA,custom_functions:VA,clustering:"clustering","clustering config":"clustering config",clustering_config:"clustering_config",http_workers:"http_workers",http:"http"},k2={CLUSTERING_HUB_PROC_DESCRIPTOR:YA,CLUSTERING_LEAF_PROC_DESCRIPTOR:WA},F2="hdb.pid",G2="data",q2={HDB:"hdb.log",INSTALL:"install.log",CLUSTERING_HUB:"clustering_hub.log",CLUSTERING_LEAF:"clustering_leaf.log"},$2={NOTIFY:"notify",FATAL:"fatal",ERROR:"error",WARN:"warn",INFO:"info",DEBUG:"debug",TRACE:"trace"},V2={MAIN:"bin/harperdb.js",NATS_INGEST_SERVICE:(0,sm.join)(im.PACKAGE_ROOT,"launchServiceScripts/launchNatsIngestService.js"),NATS_REPLY_SERVICE:(0,sm.join)(im.PACKAGE_ROOT,"launchServiceScripts/launchNatsReplyService.js"),NODES_UPGRADE_4_0_0:(0,sm.join)(im.PACKAGE_ROOT,"launchServiceScripts/launchUpdateNodes4-0-0.js")},K2={SUPER_USER:"super_user",CLUSTER_USER:"cluster_user"},_D="support@harperdb.io",Y2=`For support, please submit a request at https://harperdbhelp.zendesk.com/hc/en-us/requests/new or contact ${_D}`,W2="None of the specified records were found.",z2="U+002E",j2=/\//g,J2="U+002F",Q2=/U\+002F/g,X2="--max-old-space-size=",bf="system",Z2=".harperdb",zA="keys",eQ="hdb_boot_properties.file",tQ=6e4,rQ=448,Nc="database",om="schema",nQ="transactions",sQ="PROCESS_NAME",pD={SETTINGS_PATH_KEY:"settings_path"},iQ={TC_AGREEMENT:"TC_AGREEMENT",CLUSTERING_USER:"CLUSTERING_USER",CLUSTERING_PASSWORD:"CLUSTERING_PASSWORD",HDB_ADMIN_USERNAME:"HDB_ADMIN_USERNAME",HDB_ADMIN_PASSWORD:"HDB_ADMIN_PASSWORD",OPERATIONSAPI_ROOT:"OPERATIONSAPI_ROOT",ROOTPATH:"ROOTPATH",CLUSTERING_NODENAME:"CLUSTERING_NODENAME",CLUSTERING_ENABLED:"CLUSTERING_ENABLED",HDB_CONFIG:"HDB_CONFIG",DEFAULTS_MODE:"DEFAULTS_MODE",REPLICATION_HOSTNAME:"REPLICATION_HOSTNAME",CLUSTERING_PORT:"CLUSTERING_PORT",HDB_ROOT:"HDB_ROOT",SERVER_PORT:"SERVER_PORT",NODE_NAME:"NODE_NAME",CLUSTERING:"CLUSTERING"},oQ=250,aQ={DATA_VERSION:"data_version",UPGRADE_VERSION:"upgrade_version"},fu={JOB_TABLE_NAME:"hdb_job",NODE_TABLE_NAME:"hdb_nodes",ATTRIBUTE_TABLE_NAME:"hdb_attribute",LICENSE_TABLE_NAME:"hdb_license",ROLE_TABLE_NAME:"hdb_role",SCHEMA_TABLE_NAME:"hdb_schema",TABLE_TABLE_NAME:"hdb_table",USER_TABLE_NAME:"hdb_user",INFO_TABLE_NAME:"hdb_info"},cQ="info_id",lQ={ATTR_ATTRIBUTE_KEY:"attribute",ATTR_CREATEDDATE_KEY:"createddate",ATTR_HASH_ATTRIBUTE_KEY:"hash_attribute",ATTR_ID_KEY:"id",ATTR_NAME_KEY:"name",ATTR_PASSWORD_KEY:"password",ATTR_RESIDENCE_KEY:"residence",ATTR_ROLE_KEY:"role",ATTR_SCHEMA_KEY:"schema",ATTR_SCHEMA_TABLE_KEY:"schema_table",ATTR_TABLE_KEY:"table",ATTR_USERNAME_KEY:"username"},uQ="060493.ks",dQ=".license",fQ={CREATED:"CREATED",IN_PROGRESS:"IN_PROGRESS",COMPLETE:"COMPLETE",ERROR:"ERROR"},Yt={INSERT:"insert",UPDATE:"update",UPSERT:"upsert",SEARCH_BY_CONDITIONS:"search_by_conditions",SEARCH_BY_HASH:"search_by_hash",SEARCH_BY_ID:"search_by_id",SEARCH_BY_VALUE:"search_by_value",SEARCH:"search",SQL:"sql",CSV_DATA_LOAD:"csv_data_load",CSV_FILE_LOAD:"csv_file_load",CSV_URL_LOAD:"csv_url_load",CREATE_SCHEMA:"create_schema",CREATE_DATABASE:"create_database",CREATE_TABLE:"create_table",CREATE_ATTRIBUTE:"create_attribute",DROP_SCHEMA:"drop_schema",DROP_DATABASE:"drop_database",DROP_TABLE:"drop_table",DESCRIBE_SCHEMA:"describe_schema",DESCRIBE_DATABASE:"describe_database",DESCRIBE_TABLE:"describe_table",DESCRIBE_ALL:"describe_all",DELETE:"delete",ADD_USER:"add_user",ALTER_USER:"alter_user",DROP_USER:"drop_user",LIST_USERS:"list_users",LIST_ROLES:"list_roles",ADD_ROLE:"add_role",ALTER_ROLE:"alter_role",DROP_ROLE:"drop_role",USER_INFO:"user_info",READ_LOG:"read_log",ADD_NODE:"add_node",UPDATE_NODE:"update_node",SET_NODE_REPLICATION:"set_node_replication",EXPORT_TO_S3:"export_to_s3",IMPORT_FROM_S3:"import_from_s3",DELETE_FILES_BEFORE:"delete_files_before",DELETE_RECORDS_BEFORE:"delete_records_before",EXPORT_LOCAL:"export_local",SEARCH_JOBS_BY_START_DATE:"search_jobs_by_start_date",GET_JOB:"get_job",DELETE_JOB:"delete_job",UPDATE_JOB:"update_job",GET_FINGERPRINT:"get_fingerprint",SET_LICENSE:"set_license",GET_REGISTRATION_INFO:"registration_info",CONFIGURE_CLUSTER:"configure_cluster",SET_CONFIGURATION:"set_configuration",CLUSTER_STATUS:"cluster_status",CLUSTER_NETWORK:"cluster_network",DROP_ATTRIBUTE:"drop_attribute",REMOVE_NODE:"remove_node",RESTART:"restart",RESTART_SERVICE:"restart_service",CATCHUP:"catchup",SYSTEM_INFORMATION:"system_information",DELETE_AUDIT_LOGS_BEFORE:"delete_audit_logs_before",READ_AUDIT_LOG:"read_audit_log",CREATE_AUTHENTICATION_TOKENS:"create_authentication_tokens",LOGIN:"login",LOGOUT:"logout",REFRESH_OPERATION_TOKEN:"refresh_operation_token",GET_CONFIGURATION:"get_configuration",CUSTOM_FUNCTIONS_STATUS:"custom_functions_status",GET_CUSTOM_FUNCTIONS:"get_custom_functions",GET_CUSTOM_FUNCTION:"get_custom_function",SET_CUSTOM_FUNCTION:"set_custom_function",GET_COMPONENTS:"get_components",GET_COMPONENT_FILE:"get_component_file",SET_COMPONENT_FILE:"set_component_file",DROP_COMPONENT:"drop_component",DROP_CUSTOM_FUNCTION:"drop_custom_function",ADD_CUSTOM_FUNCTION_PROJECT:"add_custom_function_project",ADD_COMPONENT:"add_component",DROP_CUSTOM_FUNCTION_PROJECT:"drop_custom_function_project",PACKAGE_CUSTOM_FUNCTION_PROJECT:"package_custom_function_project",DEPLOY_CUSTOM_FUNCTION_PROJECT:"deploy_custom_function_project",PACKAGE_COMPONENT:"package_component",DEPLOY_COMPONENT:"deploy_component",CLUSTER_SET_ROUTES:"cluster_set_routes",CLUSTER_DELETE_ROUTES:"cluster_delete_routes",CLUSTER_GET_ROUTES:"cluster_get_routes",READ_TRANSACTION_LOG:"read_transaction_log",DELETE_TRANSACTION_LOGS_BEFORE:"delete_transaction_logs_before",INSTALL_NODE_MODULES:"install_node_modules",AUDIT_NODE_MODULES:"audit_node_modules",PURGE_STREAM:"purge_stream",GET_BACKUP:"get_backup",SIGN_CERTIFICATE:"sign_certificate",CREATE_CSR:"create_csr",LIST_CERTIFICATES:"list_certificates",ADD_CERTIFICATES:"add_certificate",REMOVE_CERTIFICATE:"remove_certificate",ADD_NODE_BACK:"add_node_back",REMOVE_NODE_BACK:"remove_node_back",ADD_SSH_KEY:"add_ssh_key",UPDATE_SSH_KEY:"update_ssh_key",DELETE_SSH_KEY:"delete_ssh_key",LIST_SSH_KEYS:"list_ssh_keys",SET_SSH_KNOWN_HOSTS:"set_ssh_known_hosts",GET_SSH_KNOWN_HOSTS:"get_ssh_known_hosts",GET_KEY:"get_key"},_Q={CSV:".csv",JSON:".json"},pQ={AWS_ACCESS_KEY:"aws_access_key_id",AWS_SECRET:"aws_secret_access_key",AWS_BUCKET:"bucket",AWS_FILE_KEY:"key",REGION:"region"},hQ={SELECT:"select",INSERT:"insert",UPDATE:"update",DELETE:"delete"},mQ={[Yt.INSERT]:Yt.INSERT,[Yt.UPDATE]:Yt.UPDATE,[Yt.UPSERT]:Yt.UPSERT,[Yt.DELETE]:Yt.DELETE},EQ={DEV:"dev",RUN:"run",START:"start",INSTALL:"install",REGISTER:"register",STOP:"stop",RESTART:"restart",VERSION:"version",UPGRADE:"upgrade",HELP:"help",STATUS:"status",OPERATION:"operation",RENEWCERTS:"renew-certs",COPYDB:"copy-db"},gQ={point:"point",lineString:"lineString",multiLineString:"multiLineString",multiPoint:"multiPoint",multiPolygon:"multiPolygon",polygon:"polygon"},jA={HDB_ROOT_KEY:"HDB_ROOT",SERVER_PORT_KEY:"SERVER_PORT",CERT_KEY:"CERTIFICATE",PRIVATE_KEY_KEY:"PRIVATE_KEY",HTTP_SECURE_ENABLED_KEY:"HTTPS_ON",CORS_ENABLED_KEY:"CORS_ON",CORS_WHITELIST_KEY:"CORS_WHITELIST",LOG_LEVEL_KEY:"LOG_LEVEL",LOGGER_KEY:"LOGGER",LOG_PATH_KEY:"LOG_PATH",LOG_ROTATE:"LOG_ROTATE",LOG_ROTATE_MAX_SIZE:"LOG_ROTATE_MAX_SIZE",LOG_ROTATE_RETAIN:"LOG_ROTATE_RETAIN",LOG_ROTATE_COMPRESS:"LOG_ROTATE_COMPRESS",LOG_ROTATE_DATE_FORMAT:"LOG_ROTATE_DATE_FORMAT",LOG_ROTATE_ROTATE_MODULE:"LOG_ROTATE_ROTATE_MODULE",LOG_ROTATE_WORKER_INTERVAL:"LOG_ROTATE_WORKER_INTERVAL",LOG_ROTATE_ROTATE_INTERVAL:"LOG_ROTATE_ROTATE_INTERVAL",LOG_ROTATE_TIMEZONE:"LOG_ROTATE_TIMEZONE",LOG_DAILY_ROTATE_KEY:"LOG_DAILY_ROTATE",LOG_MAX_DAILY_FILES_KEY:"LOG_MAX_DAILY_FILES",PROPS_ENV_KEY:"NODE_ENV",SETTINGS_PATH_KEY:"settings_path",CLUSTERING_PORT_KEY:"CLUSTERING_PORT",CLUSTERING_NODE_NAME_KEY:"NODE_NAME",CLUSTERING_ENABLED_KEY:"CLUSTERING",ALLOW_SELF_SIGNED_SSL_CERTS:"ALLOW_SELF_SIGNED_SSL_CERTS",MAX_HDB_PROCESSES:"MAX_HDB_PROCESSES",INSTALL_USER:"install_user",CLUSTERING_USER_KEY:"CLUSTERING_USER",MAX_CLUSTERING_PROCESSES:"MAX_CLUSTERING_PROCESSES",SERVER_TIMEOUT_KEY:"SERVER_TIMEOUT_MS",SERVER_KEEP_ALIVE_TIMEOUT_KEY:"SERVER_KEEP_ALIVE_TIMEOUT",SERVER_HEADERS_TIMEOUT_KEY:"SERVER_HEADERS_TIMEOUT",DISABLE_TRANSACTION_LOG_KEY:"DISABLE_TRANSACTION_LOG",OPERATION_TOKEN_TIMEOUT_KEY:"OPERATION_TOKEN_TIMEOUT",REFRESH_TOKEN_TIMEOUT_KEY:"REFRESH_TOKEN_TIMEOUT",CUSTOM_FUNCTIONS_ENABLED_KEY:"CUSTOM_FUNCTIONS",CUSTOM_FUNCTIONS_PORT_KEY:"CUSTOM_FUNCTIONS_PORT",CUSTOM_FUNCTIONS_DIRECTORY_KEY:"CUSTOM_FUNCTIONS_DIRECTORY",MAX_CUSTOM_FUNCTION_PROCESSES:"MAX_CUSTOM_FUNCTION_PROCESSES",LOG_TO_FILE:"LOG_TO_FILE",LOG_TO_STDSTREAMS:"LOG_TO_STDSTREAMS",RUN_IN_FOREGROUND:"RUN_IN_FOREGROUND",LOCAL_STUDIO_ON:"LOCAL_STUDIO_ON",STORAGE_WRITE_ASYNC:"STORAGE_WRITE_ASYNC"},SQ={CUSTOMFUNCTIONS_ENABLED:"customFunctions_enabled",CUSTOMFUNCTIONS_NETWORK_PORT:"customFunctions_network_port",CUSTOMFUNCTIONS_TLS_CERTIFICATE:"customFunctions_tls_certificate",CUSTOMFUNCTIONS_NETWORK_CORS:"customFunctions_network_cors",CUSTOMFUNCTIONS_NETWORK_CORSACCESSLIST:"customFunctions_network_corsAccessList",CUSTOMFUNCTIONS_NETWORK_HEADERSTIMEOUT:"customFunctions_network_headersTimeout",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",CUSTOMFUNCTIONS_NETWORK_KEEPALIVETIMEOUT:"customFunctions_network_keepAliveTimeout",CUSTOMFUNCTIONS_TLS_PRIVATEKEY:"customFunctions_tls_privateKey",CUSTOMFUNCTIONS_TLS_CERT_AUTH:"customFunctions_tls_certificateAuthority",CUSTOMFUNCTIONS_NETWORK_TIMEOUT:"customFunctions_network_timeout",CUSTOMFUNCTIONS_NODEENV:"customFunctions_nodeEnv",CUSTOMFUNCTIONS_ROOT:"customFunctions_root"},x={ANALYTICS_AGGREGATEPERIOD:"analytics_aggregatePeriod",AUTHENTICATION_AUTHORIZELOCAL:"authentication_authorizeLocal",AUTHENTICATION_CACHETTL:"authentication_cacheTTL",AUTHENTICATION_ENABLESESSIONS:"authentication_enableSessions",AUTHENTICATION_OPERATIONTOKENTIMEOUT:"authentication_operationTokenTimeout",AUTHENTICATION_REFRESHTOKENTIMEOUT:"authentication_refreshTokenTimeout",AUTHENTICATION_HASHFUNCTION:"authentication_hashFunction",CLUSTERING_USER:"clustering_user",CLUSTERING_ENABLED:"clustering_enabled",CLUSTERING_HUBSERVER_CLUSTER_NAME:"clustering_hubServer_cluster_name",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT:"clustering_hubServer_cluster_network_port",CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES:"clustering_hubServer_cluster_network_routes",CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT:"clustering_hubServer_leafNodes_network_port",CLUSTERING_HUBSERVER_NETWORK_PORT:"clustering_hubServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_PORT:"clustering_leafServer_network_port",CLUSTERING_LEAFSERVER_NETWORK_ROUTES:"clustering_leafServer_network_routes",CLUSTERING_LEAFSERVER_STREAMS_MAXAGE:"clustering_leafServer_streams_maxAge",CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES:"clustering_leafServer_streams_maxBytes",CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS:"clustering_leafServer_streams_maxMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS:"clustering_leafServer_streams_maxConsumeMsgs",CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS:"clustering_leafServer_streams_maxIngestThreads",CLUSTERING_LEAFSERVER_STREAMS_PATH:"clustering_leafServer_streams_path",CLUSTERING_NODENAME:"clustering_nodeName",CLUSTERING_TLS_CERTIFICATE:"clustering_tls_certificate",CLUSTERING_TLS_PRIVATEKEY:"clustering_tls_privateKey",CLUSTERING_TLS_CERT_AUTH:"clustering_tls_certificateAuthority",CLUSTERING_TLS_INSECURE:"clustering_tls_insecure",CLUSTERING_TLS_VERIFY:"clustering_tls_verify",CLUSTERING_LOGLEVEL:"clustering_logLevel",CLUSTERING_REPUBLISHMESSAGES:"clustering_republishMessages",CLUSTERING_DATABASELEVEL:"clustering_databaseLevel",CUSTOMFUNCTIONS_NETWORK_HTTPS:"customFunctions_network_https",THREADS:"threads",THREADS_COUNT:"threads_count",THREADS_DEBUG:"threads_debug",THREADS_DEBUG_STARTINGPORT:"threads_debug_startingPort",THREADS_DEBUG_PORT:"threads_debug_port",THREADS_DEBUG_HOST:"threads_debug_host",THREADS_DEBUG_WAITFORDEBUGGER:"threads_debug_waitForDebugger",THREADS_MAXHEAPMEMORY:"threads_maxHeapMemory",HTTP_SESSIONAFFINITY:"http_sessionAffinity",HTTP_COMPRESSIONTHRESHOLD:"http_compressionThreshold",HTTP_CORS:"http_cors",HTTP_CORSACCESSLIST:"http_corsAccessList",HTTP_CORSACCESSCONTROLALLOWHEADERS:"http_corsAccessControlAllowHeaders",HTTP_HEADERSTIMEOUT:"http_headersTimeout",HTTP_KEEPALIVETIMEOUT:"http_keepAliveTimeout",HTTP_MAXPARAMLENGTH:"http_maxParamLength",HTTP_TIMEOUT:"http_timeout",HTTP_PORT:"http_port",HTTP_SECUREPORT:"http_securePort",HTTP_MTLS:"http_mtls",HTTP_MTLS_REQUIRED:"http_mtls_required",HTTP_MTLS_USER:"http_mtls_user",HTTP_MAXHEADERSIZE:"http_maxHeaderSize",HTTP_THREADRANGE:"http_threadRange",HTTP_HTTP2:"http_http2",LOCALSTUDIO_ENABLED:"localStudio_enabled",LOGGING_CONSOLE:"logging_console",LOGGING_FILE:"logging_file",LOGGING_LEVEL:"logging_level",LOGGING_ROOT:"logging_root",LOGGING_ROTATION_ENABLED:"logging_rotation_enabled",LOGGING_ROTATION_COMPRESS:"logging_rotation_compress",LOGGING_ROTATION_INTERVAL:"logging_rotation_interval",LOGGING_ROTATION_MAXSIZE:"logging_rotation_maxSize",LOGGING_ROTATION_PATH:"logging_rotation_path",LOGGING_ROTATION_RETENTION:"logging_rotation_retention",LOGGING_STDSTREAMS:"logging_stdStreams",LOGGING_AUDITLOG:"logging_auditLog",LOGGING_AUDITRETENTION:"logging_auditRetention",LOGGING_AUDITAUTHEVENTS_LOGFAILED:"logging_auditAuthEvents_logFailed",LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL:"logging_auditAuthEvents_logSuccessful",OPERATIONSAPI_NETWORK_CORS:"operationsApi_network_cors",OPERATIONSAPI_NETWORK_CORSACCESSLIST:"operationsApi_network_corsAccessList",OPERATIONSAPI_NETWORK_HEADERSTIMEOUT:"operationsApi_network_headersTimeout",OPERATIONSAPI_NETWORK_HTTPS:"operationsApi_network_https",OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT:"operationsApi_network_keepAliveTimeout",OPERATIONSAPI_NETWORK_PORT:"operationsApi_network_port",OPERATIONSAPI_NETWORK_DOMAINSOCKET:"operationsApi_network_domainSocket",OPERATIONSAPI_NETWORK_SECUREPORT:"operationsApi_network_securePort",OPERATIONSAPI_NETWORK_HTTP2:"operationsApi_network_http2",OPERATIONSAPI_TLS:"operationsApi_tls",OPERATIONSAPI_TLS_CERTIFICATE:"operationsApi_tls_certificate",OPERATIONSAPI_TLS_PRIVATEKEY:"operationsApi_tls_privateKey",OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY:"operationsApi_tls_certificateAuthority",OPERATIONSAPI_NETWORK_TIMEOUT:"operationsApi_network_timeout",OPERATIONSAPI_SYSINFO_NETWORK:"operationsApi_sysInfo_network",OPERATIONSAPI_SYSINFO_DISK:"operationsApi_sysInfo_disk",REPLICATION:"replication",REPLICATION_HOSTNAME:"replication_hostname",REPLICATION_URL:"replication_url",REPLICATION_PORT:"replication_port",REPLICATION_SECUREPORT:"replication_securePort",REPLICATION_ROUTES:"replication_routes",REPLICATION_DATABASES:"replication_databases",REPLICATION_ENABLEROOTCAS:"replication_enableRootCAs",REPLICATION_SHARD:"replication_shard",REPLICATION_COPYTABLESTOCATCHUP:"replication_copyTablesToCatchUp",ROOTPATH:"rootPath",SERIALIZATION_BIGINT:"serialization_bigInt",STORAGE_WRITEASYNC:"storage_writeAsync",STORAGE_OVERLAPPINGSYNC:"storage_overlappingSync",STORAGE_CACHING:"storage_caching",STORAGE_COMPRESSION:"storage_compression",STORAGE_NOREADAHEAD:"storage_noReadAhead",STORAGE_PREFETCHWRITES:"storage_prefetchWrites",STORAGE_ENCRYPTION:"storage_encryption",STORAGE_MAXTRANSACTIONQUEUETIME:"storage_maxTransactionQueueTime",STORAGE_PATH:"storage_path",STORAGE_BLOBPATHS:"storage_blobPaths",STORAGE_AUDIT_PATH:"storage_audit_path",STORAGE_MAXFREESPACETOLOAD:"storage_maxFreeSpaceToLoad",STORAGE_MAXFREESPACETORETAIN:"storage_maxFreeSpaceToRetain",STORAGE_PAGESIZE:"storage_pageSize",STORAGE_COMPRESSION_DICTIONARY:"storage_compression_dictionary",STORAGE_COMPRESSION_THRESHOLD:"storage_compression_threshold",STORAGE_COMPACTONSTART:"storage_compactOnStart",STORAGE_COMPACTONSTARTKEEPBACKUP:"storage_compactOnStartKeepBackup",STORAGE_RECLAMATION_THRESHOLD:"storage_reclamation_threshold",STORAGE_RECLAMATION_INTERVAL:"storage_reclamation_interval",STORAGE_RECLAMATION_EVICTIONFACTOR:"storage_reclamation_evictionFactor",DATABASES:"databases",IGNORE_SCRIPTS:"ignoreScripts",MQTT_NETWORK_PORT:"mqtt_network_port",MQTT_WEBSOCKET:"mqtt_webSocket",MQTT_NETWORK_SECUREPORT:"mqtt_network_securePort",MQTT_NETWORK_MTLS:"mqtt_network_mtls",MQTT_NETWORK_MTLS_REQUIRED:"mqtt_network_mtls_required",MQTT_NETWORK_MTLS_CERTIFICATEAUTHORITY:"mqtt_network_mtls_certificateAuthority",MQTT_NETWORK_MTLS_USER:"mqtt_network_mtls_user",MQTT_REQUIREAUTHENTICATION:"mqtt_requireAuthentication",COMPONENTSROOT:"componentsRoot",TLS_CERTIFICATE:"tls_certificate",TLS_PRIVATEKEY:"tls_privateKey",TLS_CERTIFICATEAUTHORITY:"tls_certificateAuthority",TLS_CIPHERS:"tls_ciphers",TLS:"tls",CLONED:"cloned"},hD={settings_path:pD.SETTINGS_PATH_KEY,hdb_root_key:x.ROOTPATH,hdb_root:x.ROOTPATH,rootpath:x.ROOTPATH,server_port_key:x.OPERATIONSAPI_NETWORK_PORT,server_port:x.OPERATIONSAPI_NETWORK_PORT,cert_key:x.TLS_CERTIFICATE,certificate:x.TLS_CERTIFICATE,private_key_key:x.TLS_PRIVATEKEY,private_key:x.TLS_PRIVATEKEY,http_secure_enabled_key:x.OPERATIONSAPI_NETWORK_HTTPS,https_on:x.OPERATIONSAPI_NETWORK_HTTPS,cors_enabled_key:x.OPERATIONSAPI_NETWORK_CORS,cors_on:x.OPERATIONSAPI_NETWORK_CORS,cors_whitelist_key:x.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_whitelist:x.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist_key:x.OPERATIONSAPI_NETWORK_CORSACCESSLIST,cors_accesslist:x.OPERATIONSAPI_NETWORK_CORSACCESSLIST,log_level_key:x.LOGGING_LEVEL,log_level:x.LOGGING_LEVEL,log_path_key:x.LOGGING_ROOT,log_path:x.LOGGING_ROOT,clustering_node_name_key:x.CLUSTERING_NODENAME,node_name:x.CLUSTERING_NODENAME,clustering_enabled_key:x.CLUSTERING_ENABLED,clustering:x.CLUSTERING_ENABLED,max_http_threads:x.THREADS_COUNT,max_hdb_processes:x.THREADS_COUNT,server_timeout_key:x.OPERATIONSAPI_NETWORK_TIMEOUT,server_timeout_ms:x.OPERATIONSAPI_NETWORK_TIMEOUT,server_keep_alive_timeout_key:x.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_keep_alive_timeout:x.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT,server_headers_timeout_key:x.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,server_headers_timeout:x.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT,disable_transaction_log_key:x.LOGGING_AUDITLOG,disable_transaction_log:x.LOGGING_AUDITLOG,operation_token_timeout_key:x.AUTHENTICATION_OPERATIONTOKENTIMEOUT,operation_token_timeout:x.AUTHENTICATION_OPERATIONTOKENTIMEOUT,refresh_token_timeout_key:x.AUTHENTICATION_REFRESHTOKENTIMEOUT,refresh_token_timeout:x.AUTHENTICATION_REFRESHTOKENTIMEOUT,custom_functions_port_key:x.HTTP_PORT,custom_functions_port:x.HTTP_PORT,custom_functions_directory_key:x.COMPONENTSROOT,custom_functions_directory:x.COMPONENTSROOT,max_custom_function_processes:x.THREADS_COUNT,logging_console:x.LOGGING_CONSOLE,log_to_file:x.LOGGING_FILE,log_to_stdstreams:x.LOGGING_STDSTREAMS,local_studio_on:x.LOCALSTUDIO_ENABLED,clustering_port:x.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT,clustering_user:x.CLUSTERING_USER,customfunctions_network_port:x.HTTP_PORT,customfunctions_tls_certificate:x.TLS_CERTIFICATE,customfunctions_network_cors:x.HTTP_CORS,customfunctions_network_corsaccesslist:x.HTTP_CORSACCESSLIST,customfunctions_network_headerstimeout:x.HTTP_HEADERSTIMEOUT,customfunctions_network_https:x.CUSTOMFUNCTIONS_NETWORK_HTTPS,customfunctions_network_keepalivetimeout:x.HTTP_KEEPALIVETIMEOUT,customfunctions_tls_privatekey:x.TLS_PRIVATEKEY,customfunctions_tls_certificateauthority:x.TLS_CERTIFICATEAUTHORITY,customfunctions_network_timeout:x.HTTP_TIMEOUT,customfunctions_tls:x.TLS,http_threads:x.THREADS_COUNT,threads:x.THREADS_COUNT,threads_count:x.THREADS_COUNT,customfunctions_processes:x.THREADS_COUNT,customfunctions_root:x.COMPONENTSROOT,operationsapi_root:x.ROOTPATH};for(let e in x){let t=x[e];hD[t.toLowerCase()]=t}TQ={TABLES:"tables",PATH:"path",AUDIT_PATH:"auditPath"},AQ={csv_file_load:"csv_file_load",csv_data_load:Yt.CSV_DATA_LOAD,csv_url_load:Yt.CSV_URL_LOAD,delete_files_before:"delete_files_before",delete_records_before:"delete_records_before",delete_audit_logs_before:"delete_audit_logs_before",delete_transaction_logs_before:"delete_transaction_logs_before",empty_trash:"empty_trash",export_local:"export_local",export_to_s3:"export_to_s3",import_from_s3:"import_from_s3",restart_service:"restart_service"},JA={CLUSTERING_PAYLOAD:"clustering_payload",DELEGATE_THREAD_RESPONSE:"delegate_thread_response",CLUSTERING:"clustering",SCHEMA:"schema",CLUSTER_STATUS:"cluster_status",JOB:"job",CHILD_STARTED:"child_started",CHILD_STOPPED:"child_stopped",USER:"user",RESTART:"restart"},RQ={VERSION_DEFAULT:"2.2.0"},yQ={DEVELOPMENT:8192,DEFAULT:512},bQ={ENOENT:"ENOENT",EACCES:"EACCES",EEXIST:"EEXIST",ERR_INVALID_ARG_TYPE:"ERR_INVALID_ARG_TYPE"},OQ=Symbol("metadata"),NQ="__clustering__",mD="__createdtime__",ED="__updatedtime__",wQ={CREATED_TIME:mD,UPDATED_TIME:ED},IQ=[mD,ED],CQ=15984864e5,am={LESS:"<",LESS_OR_EQ:"<=",GREATER:">",GREATER_OR_EQ:">=",BETWEEN:"..."},QA={"<":"LESS","<=":"LESS_OR_EQ",">":"GREATER",">=":"GREATER_OR_EQ","...":"BETWEEN"},PQ={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},DQ=["*","%"],LQ="func_val",cm={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},Of={JWT_PRIVATE_KEY_NAME:".jwtPrivate.key",JWT_PUBLIC_KEY_NAME:".jwtPublic.key",JWT_PASSPHRASE_NAME:".jwtPass"},XA={SHUTDOWN:"shutdown",CHILD_STARTED:"child_started",CHILD_STOPPED:"child_stopped",SCHEMA:"schema",USER:"user",CLUSTER_STATUS_RESPONSE:"cluster_status_response",CLUSTER_STATUS_REQUEST:"cluster_status_request",METRICS:"metrics",GET_METRICS:"get_metrics",RESTART:"restart",START_JOB:"start_job",NATS_CONSUMER_UPDATE:"nats_consumer_update"},ZA={HTTP:"http"},MQ="3.x.x",Ys={SUCCESS:"success",FAILURE:"failure"},la={AUTHENTICATION:"authentication",AUTHORIZATION:"authorization"}});var ua=w(($ye,TD)=>{"use strict";var gD=require("minimist");TD.exports=vQ;function vQ(e=[],t=!1){if(!Array.isArray(e))return{};let r,n;t?(r=SD(process.env),n=SD(gD(process.argv))):(r=process.env,n=gD(process.argv));let s={};for(let i=0,o=e.length;i<o;i++){let c=e[i];n[c]!==void 0?s[c]=n[c].toString().trim():r[c]!==void 0&&(s[c]=r[c].toString().trim())}return s}a(vQ,"assignCMDENVVariables");function SD(e){let t,r=Object.keys(e),n=r.length,s={};for(;n--;)t=r[n],s[t.toLowerCase()]=e[t];return s}a(SD,"objKeysToLowerCase")});var Ti=w(Ws=>{"use strict";global.Resource=Ws.Resource=void 0;global.tables=Ws.tables={};global.databases=Ws.databases={};global.getUser=Ws.getUser=void 0;global.authenticateUser=Ws.authenticateUser=void 0;global.server=Ws.server={};global.contentTypes=Ws.contentTypes=null;global.threads=Ws.threads=[];global.logger={};Ws._assignPackageExport=(e,t)=>{global[e]=Ws[e]=t}});var z=w((UD,xD)=>{"use strict";var no=require("fs-extra"),{workerData:UQ,threadId:xQ,isMainThread:BQ}=require("worker_threads"),Ri=require("path"),bD=require("yaml"),OD=require("properties-reader"),Wt=(H(),C(G)),AD=ua(),HQ=require("os"),{PACKAGE_ROOT:nR}=it(),{_assignPackageExport:kQ}=Ti(),RD=process.stdout.nativeWrite||(process.stdout.nativeWrite=process.stdout.write),Er={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},ND={STDOUT:"stdOut",STDERR:"stdErr"},FQ=Ri.join(nR,"logs"),GQ=Ri.join(nR,"config/yaml/",Wt.HDB_DEFAULT_CONFIG_FILE),qQ=1e4,eR,Ai,ms,Pr,lm,Nf,um,da,wf;wf===void 0&&wD();Object.assign(UD,{notify:LD,fatal:MD,error:dm,warn:vD,info:CD,debug:DD,trace:PD,setLogLevel:JQ,log_level:Pr,loggerWithTag:KQ,suppressLogging:YQ,initLogSettings:wD,logCustomLevel:zQ,closeLogFile:sR,logsAtLevel:$Q,getLogFilePath:a(()=>um,"getLogFilePath"),OUTPUTS:ND,AuthAuditLog:ZQ});kQ("logger",xD.exports);var tR;function $Q(e){return Er[Pr]<=Er[e]}a($Q,"logsAtLevel");function wD(e=!1){try{if(wf===void 0||e){sR();let t=jQ(),r=AD(["ROOTPATH"]);try{wf=OD(t)}catch(n){if(!r.ROOTPATH||r.ROOTPATH&&!no.pathExistsSync(Ri.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE)))throw n}if({level:Pr,config_log_path:Nf,to_file:Ai,to_stream:ms}=QQ(r.ROOTPATH?Ri.join(r.ROOTPATH,Wt.HDB_CONFIG_FILE):wf.get("settings_path")),lm=Wt.LOG_NAMES.HDB,um=Ri.join(Nf,lm),BQ)try{require("segfault-handler").registerHandler(Ri.join(Nf,"crash.log"))}catch{}}}catch(t){if(wf=void 0,t.code===Wt.NODE_ERROR_CODES.ENOENT||t.code===Wt.NODE_ERROR_CODES.ERR_INVALID_ARG_TYPE){let r=AD(Object.keys(Wt.CONFIG_PARAM_MAP),!0);for(let o in r){let c=Wt.CONFIG_PARAM_MAP[o];c&&c.toLowerCase();let l=r[o];if(c===Wt.CONFIG_PARAMS.LOGGING_LEVEL){Pr=l;continue}if(c===Wt.CONFIG_PARAMS.LOGGING_STDSTREAMS){ms=l;continue}c===Wt.CONFIG_PARAMS.LOGGING_FILE&&(Ai=c),c===Wt.CONFIG_PARAMS.LOGGING_CONSOLE&&(eR=c)}let{default_level:n,default_to_file:s,default_to_stream:i}=XQ();Ai=Ai===void 0?s:Ai,Ai=yD(Ai),ms=ms===void 0?i:ms,ms=yD(ms),Pr=Pr===void 0?n:Pr,Nf=FQ,lm=Wt.LOG_NAMES.INSTALL,um=Ri.join(Nf,lm);return}throw dm("Error initializing log settings"),dm(t),t}process.env.DEV_MODE&&(ms=!0),VQ()}a(wD,"initLogSettings");var fa=!0;function VQ(){Ai&&(process.stdout.write=function(e){return typeof e=="string"&&fa&&eR!==!1&&(rR(),e=e.toString(),e[e.length-1]===`
3
+ `&&(e=e.slice(0,-1)),no.appendFileSync(da,zs("stdout",[e]))),RD.apply(process.stdout,arguments)},process.stderr.write=function(e){return typeof e=="string"&&fa&&eR!==!1&&(rR(),e[e.length-1]===`
4
+ `&&(e=e.slice(0,-1)),no.appendFileSync(da,zs("stderr",[e]))),RD.apply(process.stderr,arguments)})}a(VQ,"stdioLogging");function KQ(e,t){let r={tagName:e.replace(/ /g,"-")};return{notify:n(LD,"notify"),fatal:n(MD,"fatal"),error:n(dm,"error"),warn:n(vD,"warn"),info:n(CD,"info"),debug:n(DD,"debug"),trace:n(PD,"trace")};function n(s,i){return!t||Er[Pr]<=Er[i]?function(...o){return s(r,...o)}:null}}a(KQ,"loggerWithTag");function YQ(e){try{fa=!1,e()}finally{fa=!0}}a(YQ,"suppressLogging");var WQ=UQ?.name?.replace(/ /g,"-")||"main";function zs(e,t){let r=new Date(Date.now()).toISOString(),n="",s=t.length,i=s-1,o=[e],c=0,l;for(typeof t[0]=="object"&&(t[0]?.tagName?(o.push(t[0]?.tagName),c++):t[0]?.serviceName&&(l=t[0]?.serviceName,c++)),o.unshift(l||WQ+"/"+xQ);c<s;c++){let u=t[c];if(u instanceof Error&&u.stack)n+=u.stack,Object.keys(u).length>0&&(n+=`
5
5
  `+JSON.stringify(u)),u.cause&&(t[c--]=u.cause,u&&(n+=`
6
6
  Caused by:`));else if(typeof u=="object")try{n+=JSON.stringify(u)}catch{n+="Object ["+Object.keys(u)+"]"}else n+=u;c<i&&(n+=" ")}return`${r} [${o.join("] [")}]: ${n}
7
- `}a(zs,"createLogRecord");function If(e){if(Ai){if(wD(e),ms){fa=!1;try{process.stdout.write(e)}finally{fa=!0}}}else ms&&process.stdout.write(e)}a(If,"logStdOut");function dm(e){if(Ai){if(wD(e),ms){fa=!1;try{process.stderr.write(e)}finally{fa=!0}}}else ms&&process.stderr.write(e)}a(dm,"logStdErr");function wD(e){tR(),da?no.appendFileSync(da,e):eR||console.log(e)}a(wD,"logToFile");function nR(){try{no.closeSync(da)}catch{}da=null}a(nR,"closeLogFile");function tR(){if(!da){try{da=no.openSync(lm,"a")}catch(e){eR||(eR=!0,console.error(e))}setTimeout(()=>{nR()},$Q).unref()}}a(tR,"openLogFile");function ID(...e){mr[Cr]<=mr.info&&If(zs("info",e))}a(ID,"info");function CD(...e){mr[Cr]<=mr.trace&&If(zs("trace",e))}a(CD,"trace");function um(...e){mr[Cr]<=mr.error&&dm(zs("error",e))}a(um,"error");function PD(...e){mr[Cr]<=mr.debug&&If(zs("debug",e))}a(PD,"debug");function DD(...e){mr[Cr]<=mr.notify&&If(zs("notify",e))}a(DD,"notify");function LD(...e){mr[Cr]<=mr.fatal&&dm(zs("fatal",e))}a(LD,"fatal");function MD(...e){mr[Cr]<=mr.warn&&dm(zs("warn",e))}a(MD,"warn");function jQ(e,t,...r){t===OD.STDERR?dm(zs(e,r)):If(zs(e,r))}a(jQ,"logCustomLevel");function JQ(){let e;try{e=kQ.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=Ri.join(e,Yt.HDB_HOME_DIR_NAME,Yt.BOOT_PROPS_FILE_NAME);return no.existsSync(t)||(t=Ri.join(rR,"utility/hdb_boot_properties.file")),t}a(JQ,"getPropsFilePath");function QQ(e){Cr=e}a(QQ,"setLogLevel");function RD(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(RD,"autoCastBoolean");function XQ(e){try{if(e.includes("config/settings.js")){let o=bD(e);return{level:o.get(Yt.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY),config_log_path:Ri.dirname(o.get(Yt.HDB_SETTINGS_NAMES.LOG_PATH_KEY)),to_file:o.get(Yt.HDB_SETTINGS_NAMES.LOG_TO_FILE),to_stream:o.get(Yt.HDB_SETTINGS_NAMES.LOG_TO_STDSTREAMS)}}let t=yD.parseDocument(no.readFileSync(e,"utf8")),r=t.getIn(["logging","level"]),n=t.getIn(["logging","root"]),s=t.getIn(["logging","file"]),i=t.getIn(["logging","stdStreams"]);return{level:r,config_log_path:n,to_file:s,to_stream:i}}catch(t){if(t.code===Yt.NODE_ERROR_CODES.ENOENT)throw t;console.error("Error accessing config file for logging"),console.error(t)}}a(XQ,"getLogConfig");function ZQ(){try{let e=yD.parseDocument(no.readFileSync(qQ,"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(ZQ,"getDefaultConfig");function e4(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(e4,"AuthAuditLog")});var sR=w((Vye,xD)=>{"use strict";var t4=require("util"),r4=require("path"),n4=require("child_process"),s4=t4.promisify(n4.execFile),i4=1e3*1e3*10;xD.exports={findPs:o4};async function o4(e){let t={};try{await Promise.all(["comm","args","ppid","uid","%cpu","%mem"].map(async r=>{let{stdout:n}=await s4("ps",["wwxo",`pid,${r}`],{maxBuffer:i4});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:r4.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(o4,"findPs")});var Ut=w((Yye,HD)=>{"use strict";var a4="__dbis__",c4="__txns__",l4="__environment_name__",u4="__dbi_defintion__",d4={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"},f4=["__createdtime__","__updatedtime__"],_4="\uFFFF",BD={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},p4=Object.values(BD);HD.exports={AUDIT_STORE_NAME:c4,INTERNAL_DBIS_NAME:a4,DBI_DEFINITION_NAME:u4,SEARCH_TYPES:d4,TIMESTAMP_NAMES:f4,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:l4,TRANSACTIONS_DBI_NAMES_ENUM:BD,TRANSACTIONS_DBIS:p4,OVERFLOW_MARKER:_4}});var Un=w((Wye,WD)=>{"use strict";var kD=(H(),C(G)),FD=Ut(),GD={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},qD=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),$D={500:qD("There was an error processing your request."),400:"Invalid request"},h4=$D[GD.INTERNAL_SERVER_ERROR],m4={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")},E4={CONFIG_VALIDATION:a(e=>`HarperDB config file validation error: ${e}`,"CONFIG_VALIDATION")},g4={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"},S4={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 ${FD.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${FD.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"},T4={ATTR_NAME_LENGTH_ERR:a(e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${kD.INSERT_MAX_CHARACTER_SIZE} bytes.`,"ATTR_NAME_LENGTH_ERR"),ATTR_NAME_NULLISH_ERR:"transaction aborted due to record(s) with an attribute name that is null, undefined or empty string",HASH_VAL_LENGTH_ERR:`transaction aborted due to record(s) with a hash value that exceeds ${kD.INSERT_MAX_CHARACTER_SIZE} bytes, check log for more info`,INVALID_FORWARD_SLASH_IN_HASH_ERR:"transaction aborted due to record(s) with a hash value that contains a forward slash, check log for more info",RECORD_MISSING_HASH_ERR:"transaction aborted due to record(s) with no hash value, check log for more info"},VD={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"},A4={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."},R4={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")},y4={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"},b4={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},O4={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")},KD={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")},YD={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")},N4={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"},w4={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},I4={...VD,...g4,...m4,...A4,...R4,...y4,...b4,...O4,...T4,...KD,...YD,...N4,...w4,...E4};WD.exports={CHECK_LOGS_WRAPPER:qD,HDB_ERROR_MSGS:I4,DEFAULT_ERROR_MSGS:$D,DEFAULT_ERROR_RESP:h4,HTTP_STATUS_CODES:GD,LMDB_ERRORS_ENUM:S4,AUTHENTICATION_ERROR_MSGS:VD,VALIDATION_ERROR_MSGS:KD,ITC_ERRORS:YD}});var pe=w((jye,JD)=>{"use strict";var fu=Un(),C4=z(),P4=(H(),C(G)),fm=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,zD),this.statusCode=n||fu.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(fu.DEFAULT_ERROR_MSGS[n]?fu.DEFAULT_ERROR_MSGS[n]:fu.DEFAULT_ERROR_MSGS[fu.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&&C4[s](i)}},iR=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}},oR=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function zD(e,t,r,n=P4.LOG_LEVELS.ERROR,s=null,i=!1){if(jD(e))return e;let o=new fm(e,t,r,n,s);return i&&delete o.stack,o}a(zD,"handleHDBError");function jD(e){return e.__proto__.constructor.name===fm.name}a(jD,"isHDBError");JD.exports={isHDBError:jD,handleHDBError:zD,ClientError:iR,ServerError:oR,hdb_errors:fu}});var gt=w((Qye,nL)=>{"use strict";var Mf=(H(),C(G)),D4=ie(),fn=ae(),vf=require("path"),L4=require("minimist"),QD=require("fs-extra"),XD=require("lodash");fn.initSync();var{CONFIG_PARAMS:_a,DATABASES_PARAM_CONFIG:Cf,SYSTEM_SCHEMA_NAME:_m}=Mf,Pf,Df,Lf;function ZD(){if(Pf!==void 0)return Pf;if(fn.getHdbBasePath()!==void 0)return Pf=fn.get(_a.STORAGE_PATH)||vf.join(fn.getHdbBasePath(),Mf.DATABASES_DIR_NAME),Pf}a(ZD,"getBaseSchemaPath");function eL(){if(Df!==void 0)return Df;if(fn.getHdbBasePath()!==void 0)return Df=rL(_m),Df}a(eL,"getSystemSchemaPath");function tL(){if(Lf!==void 0)return Lf;if(fn.getHdbBasePath()!==void 0)return Lf=fn.get(Mf.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||vf.join(fn.getHdbBasePath(),Mf.TRANSACTIONS_DIR_NAME),Lf}a(tL,"getTransactionAuditStoreBasePath");function M4(e,t){let r=fn.get(_a.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||vf.join(tL(),e.toString())}a(M4,"getTransactionAuditStorePath");function rL(e,t){e=e.toString(),t=t&&t.toString();let r=fn.get(Mf.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||vf.join(ZD(),e)}a(rL,"getSchemaPath");function v4(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,L4(process.argv));let n=r[_a.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!D4.isObject(n))throw o;i=n}for(let o of i){let c=o[_m];if(!c)continue;let l=fn.get(_a.DATABASES);l=l??{};let u=c?.tables?.[t]?.[Cf.PATH];if(u)return XD.set(l,[_m,Cf.TABLES,t,Cf.PATH],u),fn.setProperty(_a.DATABASES,l),u;let f=c?.[Cf.PATH];if(f)return XD.set(l,[_m,Cf.PATH],f),fn.setProperty(_a.DATABASES,l),f}}let s=r[_a.STORAGE_PATH.toUpperCase()];if(s){if(!QD.pathExistsSync(s))throw new Error(s+" does not exist");let i=vf.join(s,e);return QD.mkdirsSync(i),fn.setProperty(_a.STORAGE_PATH,s),i}return eL()}a(v4,"initSystemSchemaPaths");function U4(){Pf=void 0,Df=void 0,Lf=void 0}a(U4,"resetPaths");nL.exports={getBaseSchemaPath:ZD,getSystemSchemaPath:eL,getTransactionAuditStorePath:M4,getTransactionAuditStoreBasePath:tL,getSchemaPath:rL,initSystemSchemaPaths:v4,resetPaths:U4}});var _n=w((tbe,cL)=>{"use strict";var x4=Un().LMDB_ERRORS_ENUM,Zye=require("lmdb"),B4=Ut(),ebe=require("buffer").Buffer,{OVERFLOW_MARKER:sL,MAX_SEARCH_KEY_LENGTH:pm}=B4,iL=["number","string","symbol","boolean","bigint"];function H4(e){if(e=e?.primaryStore||e,!e)throw new Error(x4.ENV_REQUIRED)}a(H4,"validateEnv");function k4(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(k4,"stringifyData");function F4(e){return e instanceof Date?e.valueOf():e}a(F4,"convertKeyValueToWrite");function G4(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(iL.includes(typeof e))return e.length>pm?[e.slice(0,pm)+sL]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(iL.includes(typeof i))i.length>pm?r.push(i.slice(0,pm)+sL):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(G4,"getIndexedValues");var hm=0,oL=0;function aL(){oL=Date.now()-performance.now()}a(aL,"adjustStartTime");aL();var q4=6e4;setInterval(aL,q4).unref();function $4(){let e=performance.now()+oL;return e>hm?(hm=e,e):(hm+=488e-6,hm)}a($4,"getNextMonotonicTime");cL.exports={validateEnv:H4,stringifyData:k4,convertKeyValueToWrite:F4,getNextMonotonicTime:$4,getIndexedValues:G4}});var Uf=w((nbe,lL)=>{"use strict";var V4=(H(),C(G)).OPERATIONS_ENUM,aR=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=V4.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};lL.exports=aR});var xf=w((obe,_L)=>{"use strict";var ibe=Uf(),mm=(H(),C(G)),cR=ie(),uL=z(),K4=require("uuid"),{handleHDBError:Em,hdb_errors:Y4}=pe(),{HDB_ERROR_MSGS:gm,HTTP_STATUS_CODES:Sm}=Y4;_L.exports=dL;function dL(e,t,r){for(let s=0;s<t.length;s++)fL(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];W4(i,r,e.operation)}}a(dL,"processRows");dL.validateAttribute=fL;function fL(e){if(Buffer.byteLength(String(e))>mm.INSERT_MAX_CHARACTER_SIZE)throw Em(new Error,gm.ATTR_NAME_LENGTH_ERR(e),Sm.BAD_REQUEST,void 0,void 0,!0);if(cR.isEmptyOrZeroLength(e)||cR.isEmpty(e.trim()))throw Em(new Error,gm.ATTR_NAME_NULLISH_ERR,Sm.BAD_REQUEST,void 0,void 0,!0)}a(fL,"validateAttribute");function W4(e,t,r){if(!e.hasOwnProperty(t)||cR.isEmptyOrZeroLength(e[t])){if(r===mm.OPERATIONS_ENUM.INSERT||r===mm.OPERATIONS_ENUM.UPSERT){e[t]=K4.v4();return}throw uL.error("Update transaction aborted due to record with no hash value:",e),Em(new Error,gm.RECORD_MISSING_HASH_ERR,Sm.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>mm.INSERT_MAX_CHARACTER_SIZE)throw uL.error(e),Em(new Error,gm.HASH_VAL_LENGTH_ERR,Sm.BAD_REQUEST,void 0,void 0,!0)}a(W4,"validateHash")});var pL,xn,lR,_u=be(()=>{pL=require("events"),xn=class extends pL.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new lR;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)}},lR=class{static{a(this,"EventQueueIterator")}queue;push(t){this.queue.send(t)}next(){let t=this.queue.getNextMessage();return t?{value:t}:new Promise(r=>this.queue.resolveNext=r)}return(t){return this.queue.emit("close"),{value:t,done:!0}}throw(t){return this.queue.emit("close",t),{done:!0}}}});function AL(e){dR=e}function Q4(){J4=setInterval(function(){for(let e of uR)if(e.stale){let t=e.getContext()?.url;gL.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},j4).unref()}var fR,EL,gL,SL,TL,hL,uR,z4,Bf,mL,dR,yc,Tm,j4,J4,Am=be(()=>{fR=M(_n()),EL=M(pe()),gL=M(z()),SL=M(ae());H();TL=M(ie()),hL=100,uR=new Set,z4=(0,TL.convertToMS)(SL.get(B.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(AL,"replicationConfirmation");yc=class e{static{a(this,"DatabaseTransaction")}#e;writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxnsUsed=1,this.readTxn.openTimer&&(this.readTxn.openTimer=0),uR.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn?.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(uR.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(Bf&&!this.overloadChecked&&performance.now()-mL>z4)throw new EL.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,fR.getNextMonotonicTime)()),t.timestamp||(t.timestamp=r);let n=t.retries||0;if(this.validated<this.writes.length)try{let d=this.validated;this.validated=this.writes.length;for(let _=d;_<this.validated;_++)this.writes[_]?.validate?.(this.timestamp);let p;for(let _=d;_<this.validated;_++){let h=this.writes[_];h&&(h.before||h.beforeIntermediate)&&(p=!0)}if(p)return(async()=>{try{for(let _=0;_<2;_++){let h;for(let S=d;S<this.validated;S++){let g=this.writes[S];if(!g)continue;let R=g[_===0?"before":"beforeIntermediate"];if(R){let E=R();h?h.push?h.push(E):h=[h,E]:h=E}}h&&await(h.push?Promise.all(h):h)}}catch(_){throw this.abort(),_}return this.commit(t)})()}catch(d){throw this.abort(),d}n||this.doneReadTxn(),this.open=t?.doneWriting?2:1;let s,i=[],o=0;this.writes=this.writes.filter(d=>d);let c=a(d=>{d.commit(r,d.entry,n)},"doWrite"),l=a(()=>{let d=this.writes[o++];if(d)if(d.key){n>0&&(d.entry=d.store.getEntry(d.key));let p=d.store.ifVersion(d.key,d.entry?.version??null,l);s=s||p}else l();else for(let p of this.writes)c(p)},"nextCondition"),u=this.lmdbDb;if(this.writes.length>0&&(u?.retryRisk&&(u.retryRisk*=.99),this.writes.length+(u?.retryRisk||0)<hL>>n?l():s=this.writes[0].store.transaction(()=>{for(let d of this.writes)d.entry=d.store.getEntry(d.key),c(d);return!0})),s)return Bf||(Bf=s,mL=performance.now(),Bf.then(()=>{Bf=null})),s.then(d=>{if(d){if(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.replicatedConfirmation){let p=this.writes[0].store.rootStore.databaseName,_=this.writes[this.writes.length-1];dR&&_&&i.push(dR(p,_.store.getEntry(_.key).localTime,this.replicatedConfirmation))}return this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))}else return u&&(u.retryRisk=(u.retryRisk||0)+hL/2),t?t.retries=n+1:t={retries:1},this.commit(t)});let f={txnTime:r};if(this.next){let d=this.next?.commit(t);if(d?.then)return d?.then(p=>({txnTime:r,next:p}));f.next=d}return f}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}getContext(){return this.#e}setContext(t){this.#e=t}},Tm=class extends yc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,fR.getNextMonotonicTime)())}getReadTxn(){}},j4=3e4;a(Q4,"startMonitoringTxns");Q4()});function Nt(e,t,r){if(!t)t=e,e={};else if(!e)e={};else if(e?.transaction?.open===1&&typeof t=="function")return t(e.transaction);if(typeof t!="function")throw new Error("Callback function must be provided to transaction");let n=e.transaction=new yc;e.timestamp&&(n.timestamp=e.timestamp),e.replicatedConfirmation&&(n.replicatedConfirmation=e.replicatedConfirmation),n.setContext(e),e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({doneWriting:!0});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var RL,bc=be(()=>{RL=M(Ti());Am();a(Nt,"transaction");(0,RL._assignPackageExport)("transaction",Nt);Nt.commit=function(e){let t=(e.getContext?.()||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Nt.abort=function(e){let t=(e.getContext?.()||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});function pR(e,t,r,n,s,i,o,c){let l=e[0];if(t==="or"){let d=u(l);for(let _=1;_<e.length;_++){let h=e[_],S=u(h);d=d.concat(S)}let p=new Set;return d.filter(_=>{let h=_.key??_;return p.has(h)?!1:(p.add(h),!0)})}else{let d=u(l),p=f(e.slice(1),!0,l.estimated_count);return p.length>0?o(d,p):d}function u(d){return d.conditions?pR(d.conditions,d.operator,r,n,s,i,o,c):mu(d,n,d.descending||s.reverse===!0,r,s.allowFullScan,c)}a(u,"executeCondition");function f(d,p,_){return d.map((h,S)=>{if(h.conditions){let E=h.operator==="or",T=f(h.conditions,!E,_);return E?(b,v)=>T.some(F=>F(b,v)):(b,v)=>T.every(F=>F(b,v))}let g=(h.attribute||h[0])===r.primaryKey,R=Ff(h,r,i,c,g,_);return p&&S<d.length-1&&_&&(_=o3(r.primaryStore,h.estimated_count,_)),R}).filter(Boolean)}a(f,"mapConditionsToFilters")}function mu(e,t,r,n,s,i){let o=e[0]??e.attribute,c=e[1]??e.value,l=e.comparator;if(c===void 0&&l!=="sort")throw new hn.ClientError(`Search condition for ${o} must have a value`);if(Array.isArray(o)){let E=o[0],T=bi(n.attributes,E);if(T.relationship){if(o.length<2)throw new hn.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let b=T.definition?.tableClass||T.elements?.definition?.tableClass,v=new Map,F=mu({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,b,s,v);if(T.relationship.to){i[o[0]]=v;let q=!!bi(b.attributes,T.relationship.to)?.elements;F=r3(F,T,b.primaryStore,q,v)}if(T.relationship.from){let q=a(Y=>(Y?.key!==void 0&&(Y=Y.key),mu({attribute:T.relationship.from,value:Y},t,r,n,s,v)),"searchEntry");T.elements?(i[o[0]]=v,F=n3(F,T,b.primaryStore,v,q)):F=F.flatMap(q)}return F}else if(o.length===1)o=o[0];else throw new hn.ClientError("Unable to query by attribute "+JSON.stringify(o))}let u,f,d,p;c instanceof Date&&(c=c.getTime());let _;switch(hR[l]||l){case"lt":u=!0,f=c;break;case"le":u=!0,f=c,d=!0;break;case"gt":u=c,p=!0;break;case"ge":u=c;break;case"prefix":Array.isArray(c)?c[c.length-1]!=null&&(c=c.concat(null)):c=[c,null],u=c,f=c.slice(0),f[f.length-1]=yi.MAXIMUM_KEY;break;case"starts_with":u=c.toString(),f=c+"\uFFFF";break;case"between":case"gele":case"gelt":case"gtlt":case"gtle":u=c[0],u instanceof Date&&(u=u.getTime()),f=c[1],f instanceof Date&&(f=f.getTime()),d=l==="gele"||l==="gtle"||l==="between",p=l==="gtlt"||l==="gtle";break;case"equals":case void 0:u=c,f=c,d=!0;break;case"ne":if(c===null){u=c,p=!0;break}case"sort":case"contains":case"ends_with":u=!0,_=!0;break;default:throw new hn.ClientError(`Unknown query comparator "${l}"`)}let h,S=o===n.primaryKey||o==null;if(typeof u=="string"&&u.length>Es.MAX_SEARCH_KEY_LENGTH&&(u=u.slice(0,Es.MAX_SEARCH_KEY_LENGTH)+Es.OVERFLOW_MARKER,p=!1,h=Ff(e,n,null,i,S)),typeof f=="string"&&f.length>Es.MAX_SEARCH_KEY_LENGTH&&(f=f.slice(0,Es.MAX_SEARCH_KEY_LENGTH)+Es.OVERFLOW_MARKER,d=!0,h=h??Ff(e,n,null,i,S)),r){let E=u;u=f,f=E,E=!p,p=!d,d=E}let g=S?n.primaryStore:n.indices[o];if(!g||g.isIndexing||_||c===null&&!g.indexNulls){if(s===!1&&!g)throw new hn.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&_)throw new hn.ClientError(`Can not use ${l||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(g?.isIndexing)throw new hn.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&g&&!g.indexNulls)throw new hn.ClientError(`"${o}" is not indexed for nulls, index needs to be rebuilt to search for nulls, can not search for this attribute`,400);if(h=h??Ff(e,n,null,i,S),!h)throw new hn.ClientError(`Unknown search operator ${e.comparator}`)}let R={start:u,end:f,inclusiveEnd:d,exclusiveStart:p,values:!0,versions:S,transaction:t,reverse:r};if(S){let E=g.getRange(R).map(h?function({key:T,value:b}){return this?.isSync?b&&h(b)?T:pa.SKIP:new Promise((v,F)=>setImmediate(()=>{try{v(b&&h(b)?T:pa.SKIP)}catch(q){F(q)}}))}:T=>T.value==null&&!(T.metadataFlags&(Bn|ma))?pa.SKIP:T);return E.hasEntries=!0,E}else return g?g.getRange(R).map(h?function({key:E,value:T}){let b;return typeof E=="string"&&E.length>Es.MAX_SEARCH_KEY_LENGTH?b=n.primaryStore.get(T):b={[o]:E},this.isSync?h(b)?T:pa.SKIP:new Promise((v,F)=>setImmediate(()=>{try{v(h(b)?T:pa.SKIP)}catch(q){F(q)}}))}:({value:E})=>E):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:E,value:T}){return this.isSync?T&&h(T)?E:pa.SKIP:new Promise((b,v)=>setImmediate(()=>{try{b(T&&h(T)?E:pa.SKIP)}catch(F){v(F)}}))})}function bi(e,t){if(Array.isArray(t))if(t.length>1){let r=bi(e,t[0]),n=(r?.definition?.tableClass||r?.elements?.definition?.tableClass)?.attributes??r?.properties;return n?bi(n,t.slice(1)):void 0}else t=t.toString();else typeof t!="string"&&(t=t.toString());return e.find(r=>r.name===t)}function r3(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i;return s.hasMappings=!0,{next(){if(!i){let c=t.relationship.to,l=a((u,f)=>{let d=s.get(u);d?d.push(f):s.set(u,d=[f])},"add_entry");for(let u of e){let f=u.value??r.get(u.key??u),d=f?.[c];if(d!=null&&!s.filters?.some(p=>!p(f)))if(n)for(let p=0;p<d.length;p++)l(d[p],u);else l(d,u)}return i=s.keys()[Symbol.iterator](),this.next()}let o=i.next();return o.done?o:{value:o.value}},return(){if(i?.return)return i.return()}}}})}function n3(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i,o,c=new Set;return{next(){let l;if(o)for(;l=o.next(),!l.done;){let u=l.value;if(!c.has(u))return c.add(u),l}if(!i){let u=new Set;n.fromRecord=f=>f[t.relationship.from]?.filter?.(d=>u.has(d));for(let f of e){if(n.filters){let d=r.get(f);if(n.filters.some(p=>!p(d)))continue}u.add(f)}return i=u[Symbol.iterator](),this.next()}do{let u=i.next();return u.done?u:(o=s(u.value)[Symbol.iterator](),this.next())}while(!0)},return(){return o?.return?.()},throw(){return o?.throw?.()}}}})}function Ff(e,t,r,n,s,i){let o=e.comparator,c=e[0]??e.attribute,l=e[1]??e.value;if(Array.isArray(c)){if(c.length===0)return()=>!0;if(c.length===1)c=c[0];else if(c.length>1){let f=c[0],d=bi(t.attributes,f),p=d.definition?.tableClass||d.elements.definition?.tableClass,_=n?.[f],h=Ff({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:o},p,r,_?.[f]?.joined,c[1]===p.primaryKey,i);if(!h)return;if(_){_.filters||(_.filters=[]),_.filters.push(h);return}let S=t.propertyResolvers?.[f],g,R=a((E,T)=>{let b,v;if(S){if(S.from&&h.idFilter){if(!g)if(h.idFilter.idSet?.size===1){for(let q of h.idFilter.idSet)e={attribute:S.from,value:q};g=u(S.from,h.idFilter,!0,!0)}else g=u(S.from,h.idFilter,!1,!0);let F=g(E);return g.idFilter&&(R.idFilter=g.idFilter),F}v=S(E,r,T),b=v?.value}else b=E[f];return b?Array.isArray(b)?b.some(h):h(b,v):!1},"recordFilter");return R}}switch(l instanceof Date&&(l=l.getTime()),hR[o]||o){case Es.SEARCH_TYPES.EQUALS:case void 0:return u(c,f=>f===l,!0);case"contains":return u(c,f=>f?.toString().includes(l));case"ends_with":return u(c,f=>f?.toString().endsWith(l));case"starts_with":return u(c,f=>typeof f=="string"&&f.startsWith(l),!0);case"prefix":return Array.isArray(l)?l[l.length-1]==null&&(l=l.slice(0,-1)):l=[l],u(c,f=>{if(!Array.isArray(f))return!1;for(let d=0,p=l.length;d<p;d++)if(f[d]!==l[d])return!1;return!0},!0);case"between":return l[0]instanceof Date&&(l[0]=l[0].getTime()),l[1]instanceof Date&&(l[1]=l[1].getTime()),u(c,f=>(0,yi.compareKeys)(f,l[0])>=0&&(0,yi.compareKeys)(f,l[1])<=0,!0);case"gt":return u(c,f=>(0,yi.compareKeys)(f,l)>0);case"ge":return u(c,f=>(0,yi.compareKeys)(f,l)>=0);case"lt":return u(c,f=>(0,yi.compareKeys)(f,l)<0);case"le":return u(c,f=>(0,yi.compareKeys)(f,l)<=0);case"ne":return u(c,f=>(0,yi.compareKeys)(f,l)!==0,!1,!0);case"sort":return()=>!0;default:throw new hn.ClientError(`Unknown query comparator "${o}"`)}function u(f,d,p,_){let h;p=p&&!s&&t?.indices[f]&&i>3,p&&(e.estimated_count==null&&ym(t)(e),h=e.estimated_count>>4,(isNaN(h)||h>=i)&&(p=!1));let S=0,g=3;function R(E){let T=E[f],b;if(typeof T!="object"||!T||_?b=d(T):Array.isArray(T)?b=T.some(d):T instanceof Date&&(b=d(T.getTime())),p&&(g++,!b&&!R.idFilter&&++S/g*(i-g)>h)){let v=mu(e,r.transaction.getReadTxn(),!1,t).map(Eu),F=new Set(v);R.idFilter=q=>F.has(Eu(q)),R.idFilter.idSet=F}return b}return a(R,"recordFilter"),s&&(R.idFilter=d),R}a(u,"attributeComparator")}function ym(e){function t(r){if(r.estimated_count===void 0){if(r.conditions){let s;if(r.operator==="or"){s=0;for(let i of r.conditions)t(i),s+=i.estimated_count}else{s=1/0;for(let i of r.conditions)t(i),s=isFinite(s)?s*i.estimated_count/so(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=hR[n]||n,n===Es.SEARCH_TYPES.EQUALS||!n){let s=r[0]??r.attribute;if(s==null||s===e.primaryKey)r.estimated_count=1;else if(Array.isArray(s)&&s.length>1){let i=bi(e.attributes,s[0]),o=i.definition?.tableClass||i.elements.definition?.tableClass,c=ym(o)({value:r.value,attribute:s.length>2?s.slice(1):s[1],comparator:"equals"}),l=e.indices[i.relationship.from];r.estimated_count=c+(l?c*so(e.indices[i.relationship.from])/(so(o.primaryStore)||1):c)}else{let i=e.indices[s];r.estimated_count=i?i.getValuesCount(r[1]??r.value):1/0}}else if(n==="contains"||n==="ends_with"||n==="ne"){let s=r[0]??r.attribute,i=e.indices[s];r.value===null&&n==="ne"?r.estimated_count=so(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=e3*so(e.primaryStore)+1:n==="between"?r.estimated_count=Z4*so(e.primaryStore)+1:n==="sort"?r.estimated_count=so(e.primaryStore)+1:r.estimated_count=X4*so(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function bm(e){if(e)if(ha=e,pu.lastIndex=0,s3.test(e))try{let t=Hf(new hu,"");if(pn!==ha.length)throw new SyntaxError("Unable to parse query, unexpected end of query");return t}catch(t){throw t.statusCode=400,t.message=`Unable to parse query, ${t.message} at position ${pn} in '${ha}'`,t}else return new URLSearchParams(e)}function Hf(e,t){let r=pu,n,s,i,o,c,l=decodeURIComponent,u;for(;n=r.exec(ha);){pn=r.lastIndex;let[,f,d]=n;if(o){if(f)throw new SyntaxError(`expected operator, but encountered '${f}'`);o=!1,c=!1}else c=!0;let p;switch(d){case"=":if(s!=null){if(f.length<=2)i=f;else throw new SyntaxError(`invalid FIQL operator ${f}`);l=yL}else{if(l=decodeURIComponent,i="equals",!f)throw new SyntaxError("attribute must be specified before equality comparator");s=kf(f)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=t3[d],l=_R[i]?yL:decodeURIComponent,!f)throw new SyntaxError(`attribute must be specified before comparator ${d}`);s=kf(f);break;case"&=":case"|=":case"|":case"&":case"":case void 0:if(s==null){if(s===void 0)throw t?new SyntaxError(`expected '${t}', but encountered ${d[0]?"'"+d[0]+"'":"end of string"}}`):new SyntaxError(`no comparison specified before ${d?"'"+d+"'":"end of string"}`)}else{if(!e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");let h={comparator:i,attribute:s||null,value:l(f)};if(i==="eq"&&bL(h,f),s===""){let S=e.conditions[e.conditions.length-1];S.chainedConditions=S.chainedConditions||[],S.chainedConditions.push(h),S.operator=u}else Rm(e,u),e.conditions.push(h)}d==="&"?(u="and",s=void 0):d==="|"?(u="or",s=void 0):d==="&="?(u="and",s=""):d==="|="&&(u="or",s="");break;case",":if(e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");e.push(kf(f)),s=void 0;break;case"(":pu.lastIndex=pn;let _=Hf(f?[]:new hu,")");switch(f){case"":Rm(e,u),e.conditions.push(_);break;case"limit":switch(_.length){case 1:e.limit=+_[0];break;case 2:e.offset=+_[0],e.limit=_[1]-e.offset;break;default:throw new SyntaxError("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(_[0])&&_.length===1&&!_[0].name?(e.select=_[0],e.select.asArray=!0):_.length===1?e.select=_[0]:_.length===2&&_[1]===""?e.select=_.slice(0,1):e.select=_;break;case"group-by":throw new SyntaxError("group by is not implemented yet");case"sort":e.sort=OL(_);break;default:throw new SyntaxError(`unknown query function call ${f}`)}ha[pn]===","?r.lastIndex=++pn:o=!0,s=null;break;case"{":if(e.conditions)throw new SyntaxError("property sets are not allowed in a queries");if(!f)throw new SyntaxError("property sets must have a defined parent property name");pu.lastIndex=pn,p=Hf([],"}"),p.name=f,e.push(p),ha[pn]===","?r.lastIndex=++pn:o=!0;break;case"[":pu.lastIndex=pn,f?(p=Hf(new hu,"]"),p.name=f):p=Hf(e.conditions?new hu:[],"]"),e.conditions?(Rm(e,u),e.conditions.push(p),s=null):e.push(p),ha[pn]===","?r.lastIndex=++pn:o=!0;break;case")":case"]":case"}":if(t===d[0]){if(e.conditions){if(s){let h={comparator:i||"equals",attribute:s,value:l(f)};i==="eq"&&bL(h,f),Rm(e,u),e.conditions.push(h)}else if(f)throw new SyntaxError("no attribute or comparison specified")}else(f||e.length>0&&c)&&e.push(kf(f));return e}else throw t?new SyntaxError(`expected '${t}', but encountered '${d[0]}'`):new SyntaxError(`unexpected token '${d[0]}'`);default:throw new SyntaxError(`unexpected operator '${d}'`)}if(t!==")"&&(r=s?i3:pu,r.lastIndex=pn),pn===ha.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function Rm(e,t){if(e.conditions.length>0)if(e.operator){if(e.operator!==t)throw new SyntaxError("Can not mix operators within a condition grouping")}else e.operator=t}function kf(e){return e.indexOf(".")>-1?e.split(".").map(kf):decodeURIComponent(e)}function yL(e){if(e==="null")return null;if(e.indexOf(":")>-1){let[t,r]=e.split(":");if(t==="number")return r[0]==="$"?parseInt(r.slice(1),36):+r;if(t==="boolean")return r==="true";if(t==="date")return new Date(isNaN(r)?decodeURIComponent(r):+r);if(t==="string")return decodeURIComponent(r);throw new hn.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function bL(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new hn.ClientError("wildcard can only be used at the end of a string")}function OL(e){let t=NL(e[0]);return e.length>1&&(t.next=OL(e.slice(1))),t}function NL(e){if(Array.isArray(e)){let t=NL(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 Eu(e){return Array.isArray(e)?e.join("\0"):e}function so(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function o3(e,t,r){return t*r/so(e)}var hn,Es,yi,pa,X4,Z4,e3,t3,_R,hR,s3,pu,i3,pn,ha,hu,Oc,Gf=be(()=>{hn=M(pe()),Es=M(Ut()),yi=require("ordered-binary"),pa=require("lmdb");qf();X4=.3,Z4=.1,e3=.05,t3={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},_R={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(pR,"executeConditions");a(mu,"searchByIndex");a(bi,"findAttribute");a(r3,"joinTo");a(n3,"joinFrom");hR={eq:"equals",greater_than:"gt",greaterThan:"gt",greater_than_equal:"ge",greaterThanEqual:"ge",less_than:"lt",lessThan:"lt",less_than_equal:"le",lessThanEqual:"le",not_equal:"ne",notEqual:"ne",equal:"equals",sw:"starts_with",startsWith:"starts_with",ew:"ends_with",endsWith:"ends_with",ct:"contains",">":"gt",">=":"ge","<":"lt","<=":"le","...":"between"};a(Ff,"filterByType");a(ym,"estimateCondition");s3=/[()[\]|!<>.]|(=\w*=)/,pu=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,i3=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(bm,"parseQuery");a(Hf,"parseBlock");a(Rm,"assignOperator");a(kf,"decodeProperty");a(yL,"typedDecoding");a(bL,"wildcardDecoding");a(OL,"toSortObject");a(NL,"toSortEntry");hu=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(Eu,"flattenKey");a(so,"estimatedEntryCount");a(o3,"intersectionEstimate");Oc=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});var ER={};ve(ER,{MultiPartId:()=>Nm,Resource:()=>$r,snake_case:()=>c3,transformForSelect:()=>wm});function c3(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function wL(e,t){if(Nc=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(Nc=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new Nm;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Nc=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return Nc=!0,null;e[e.length-1]==="/"&&(Nc=!0)}return t.coerceId(decodeURIComponent(e))}function Hn(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,l,u,f;if(r?(o?(f=i,o=o.getContext?.()||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(f=s,c=f[this.primaryKey]??null,o=i.getContext?.()||i):f=i:(f=s,s=void 0,c=f.getId?.()??f[this.primaryKey]),c===null&&(u=!0)):i?o=i.getContext?.()||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="object"&&s){if(l=s,typeof(c=s.url)=="string")if(this.directURLMapping)c=c.slice(1);else{let _=c.indexOf("?");if(_>-1){let S=this.parseQuery(c.slice(_+1));l?S&&(l=Object.assign(S,l)):l=S,c=c.slice(0,_)}let h=this.parsePath(c,o,l);h?.id!==void 0?(h.query&&(l?l=Object.assign(h.query,l):l=h.query),u=h.isCollection,c=h.id):c=h}else if(s[Symbol.iterator]){c=[],u=!0;for(let _ of s){if(typeof _=="object"&&_)break;c.push(_)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=null,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new Oc(c),c==null&&(u=!0);o||(o={});let d;if(l?.ensureLoaded!=null||l?.async||u?(d={...t},l?.ensureLoaded!=null&&(d.ensureLoaded=l.ensureLoaded),l?.async&&(d.async=l.async),u&&(d.isCollection=!0)):d=t,o.transaction){let _=this.getResource(c,o,d);return _.then?_.then(p):p(_)}else return Nt(o,()=>{let _=this.getResource(c,o,d);return _.then?_.then(p):p(_)},d);function p(_){if(o.authorize){o.authorize=!1;let h=t.type==="read"?_.allowRead(o.user,l,o):t.type==="update"?_.doesExist?.()===!1?_.allowCreate(o.user,f,o):_.allowUpdate(o.user,f,o):t.type==="create"?_.allowCreate(o.user,f,o):_.allowDelete(o.user,l,o);if(h?.then)return h.then(S=>{if(!S)throw new Om(o.user);return typeof f?.then=="function"?f.then(g=>e(_,l,o,g)):e(_,l,o,f)});if(!h)throw new Om(o.user)}return typeof f?.then=="function"?f.then(h=>e(_,l,o,h)):e(_,l,o,f)}a(p,"authorizeActionOnResource")}}function kn(e,t){let r=new PL.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 mR(e,t,r){let n=e.getRecord?.();if(n){let s=e.getChanges?.();return i=>{let o,c;return e.hasOwnProperty(i)&&typeof(o=e[i])!="function"?o:s&&i in s?s[i]:(c=t?.[i])?c(e,r):n[i]}}else return t?s=>{let i=t[s];return i?i(e,r):e[s]}:s=>e[s]}function wm(e,t){let r=t.propertyResolvers,n=t.getContext?.(),s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):mR(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(c);let u=[],f=i(mR(l,r,n));for(let d of e)u.push(f(d));return u},"transform");let o=e.forceNulls;return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(p=>p&&typeof p=="object"?c(p):p);let u={},f=i(mR(l,r,n)),d;for(let p of e){let _=f(p);_===void 0&&o&&(_=null),_?.then?(d||(d=[]),d.push(_.then(h=>u[p.name||p]=h))):u[p.name||p]=_}return d?Promise.all(d).then(()=>u):u},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(o){return c=>{if(typeof c=="string")return o(c);if(typeof c=="object")if(c.name){s||(s={});let l=s[c.name];if(!l){let f=r[c.name]?.definition?.tableClass;l=s[c.name]=wm(c.select||c,f)}let u=o(c.name);return l(u)}else return o(c);else return c}}a(i,"handleProperty")}var IL,CL,PL,a3,$r,Om,Nc,Nm,Ea=be(()=>{IL=require("crypto");_u();CL=M(Ti()),PL=M(pe());bc();Gf();a3={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},$r=class{static{a(this,"Resource")}#e;#t;#n;static transactions;static directURLMapping=!1;constructor(t,r){this.#e=t;let n=r?.getContext?r.getContext()??null:void 0;this.#t=n!==void 0?n:r||null}static get=Hn(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let l;if((l=r?.select)&&c!=null&&!c.selectApplied){let u=wm(l,t.constructor);return typeof c?.map=="function"?c.map(u):u(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=Hn(function(t,r,n,s){if(Array.isArray(s)&&t.#n){let i=[],o=n.authorize;for(let c of s){let l=t.constructor,u=l.getResource(c[l.primaryKey],n,{async:!0});u.then?i.push(u.then(f=>f.put(c,n))):i.push(u.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):kn(t,"put")},{hasContent:!0,type:"update"});static patch=Hn(function(t,r,n,s){return t.patch?t.patch(s,r):kn(t,"patch")},{hasContent:!0,type:"update"});static delete=Hn(function(t,r,n,s){return t.delete?t.delete(r):kn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,IL.randomUUID)()}static create(t,r,n){let s;return t==null?s=r?.[this.primaryKey]??this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=r?.[this.primaryKey]??[...t,this.getNewId()]:typeof t!="object"?s=r?.[this.primaryKey]??[t,this.getNewId()]:(s=t?.[this.primaryKey]??this.getNewId(),n=r||{},r=t),n||(n={}),Nt(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):kn(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=Hn(function(t,r,n,s){return t.invalidate?t.invalidate(r):kn(t,"delete")},{hasContent:!1,type:"update"});static post=Hn(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=Hn(function(t,r,n,s){return t.connect?t.connect(s,r):kn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=Hn(function(t,r,n,s){return t.subscribe?t.subscribe(r):kn(t,"subscribe")},{type:"read"});static publish=Hn(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.publish?t.publish(s,r):kn(t,"publish")},{hasContent:!0,type:"create"});static search=Hn(function(t,r,n,s){let i=t.search?t.search(r):kn(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=wm(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=Hn(function(t,r,n,s){return t.search?t.search(s,r):kn(t,"search")},{hasContent:!0,type:"read"});static copy=Hn(function(t,r,n,s){return t.copy?t.copy(s,r):kn(t,"copy")},{hasContent:!0,type:"create"});static move=Hn(function(t,r,n,s){return t.move?t.move(s,r):kn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this.#n)return(await this.constructor.create(this.#e,t,this.#t)).#e;kn(this,"post")}static isCollection(t){return t&&t.#n}get isCollection(){return this.#n}static coerceId(t){return t}static parseQuery(t){return bm(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1),c=r?.headers&&a3[o];if(c)r.requestedContentType=c,t=t.slice(0,s);else if(this.attributes?.find(l=>l.name===o))if(t=t.slice(0,s),n)n.property=o;else return{query:{property:o},id:wL(t,this),isCollection:Nc}}let i=wL(t,this);return Nc?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r.getContext?.(),o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let u=l.asMap.get(t);if(s=u?.find(f=>f.constructor===c),s)return s;u||l.asMap.set(t,u=[]),u.push(s=new c(t,i))}else{if(s=l.find(u=>u.#e===t&&u.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let u=new Map;for(let f of l){let d=f.#e,p=u.get(d);p?p.push(f):u.set(d,[f])}i.resourceCache.length=0,i.resourceCache.asMap=u}}}else s=new c(t,i);return o&&(s.#n=!0),s}subscribe(t){return new xn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new xn}allowRead(t){return t?.role.permission.super_user}allowUpdate(t){return t?.role.permission.super_user}allowCreate(t){return t?.role.permission.super_user}allowDelete(t){return t?.role.permission.super_user}getId(){return this.#e}getContext(){return this.#t}};(0,CL._assignPackageExport)("Resource",$r);a(c3,"snake_case");Om=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(wL,"pathToId");Nm=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(Hn,"transactional");a(kn,"missingMethod");a(mR,"selectFromObject");a(wm,"transformForSelect")});var ga,gR=be(()=>{ga=class{constructor(t){this.error=t}static{a(this,"ErrorResource")}isError=!0;allowRead(){throw this.error}allowUpdate(){throw this.error}allowCreate(){throw this.error}allowDelete(){throw this.error}getId(){throw this.error}getContext(){throw this.error}get(){throw this.error}post(){throw this.error}put(){throw this.error}delete(){throw this.error}connect(){throw this.error}getResource(){return this}publish(){throw this.error}subscribe(){throw this.error}}});var ML={};ve(ML,{Resources:()=>Im,keyArrayToString:()=>gu,resetResources:()=>l3,resources:()=>Oi});function l3(){return Oi=new Im}function gu(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var DL,LL,Im,Oi,Su=be(()=>{bc();gR();DL=M(z()),LL=M(pe()),Im=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 LL.ServerError(`Conflicting paths for ${t}`);DL.default.error(c),i.Resource=new ga(c)}super.set(t,i);for(let[c,l]of this){let u=2;for(;(u=c.indexOf("/",u))>-1;){let f=this.get(c.slice(0,u));f&&(f.hasSubPaths=!0),u+=2}}}getMatch(t,r){let n=2,s=0,i,o=t.length;for(;n<o;){s=n,n=t.indexOf("/",n),n===-1&&(n=o);let u=n===o?t:t.slice(0,n),f=this.get(u),d=-1;if(!f&&n===o&&(d=u.indexOf("?",s),d!==-1)){let p=u.slice(0,d);f=this.get(p)}if(f&&(!r||f.exportTypes?.[r]!==!1)){if(f.relativeURL=t.slice(d!==-1?d:n),!f.hasSubPaths)return f;i=f}n+=2}if(i)return i;let c=t.indexOf("?"),l=c>-1?t.slice(0,c):t;return i=this.get(l),!i&&l.indexOf(".")>-1&&(i=this.get(l.split(".")[0])),i&&(!r||i.exportTypes?.[r]!==!1)?i.relativeURL=c>-1?t.slice(c):"":i||(i=this.get(""),i&&(!r||i.exportTypes?.[r]!==!1)&&(t.charAt(0)!=="/"&&(t="/"+t),i.relativeURL=t)),i}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return Nt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(l3,"resetResources");a(gu,"keyArrayToString")});var Tu={};ve(Tu,{server:()=>Ye});var vL,Ye,Vr=be(()=>{vL=M(Ti()),Ye={};(0,vL._assignPackageExport)("server",Ye)});var AR={};ve(AR,{loadGQLSchema:()=>f3,start:()=>TR,startOnMainThread:()=>d3});function TR({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:u,StringValueNode:f}=await import("graphql"),d=o(new c(r.toString(),s)),p=new Map,_=[],h;for(let R of d.definitions)switch(R.kind){case l.OBJECT_TYPE_DEFINITION:let F=function(Y){if(Y.kind==="NonNullType"){let Q=F(Y.type);return Q.nullable=!1,Q}if(Y.kind==="ListType")return{type:"array",elements:F(Y.type)};let se={type:Y.name?.value};return Object.defineProperty(se,"location",{value:Y.loc.startToken}),se};a(F,"getProperty");let E=R.name.value,T=[],b={table:null,database:null,properties:T};p.set(E,b);for(let Y of R.directives){if(Y.name.value==="table"){for(let se of Y.arguments)b[se.name.value]=se.value.value;b.schema&&(b.database=b.schema),b.table||(b.table=E),b.audit&&(b.audit=b.audit!=="false"),b.attributes=b.properties,_.push(b)}if(Y.name.value==="sealed"&&(b.sealed=!0),Y.name.value==="splitSegments"&&(b.splitSegments=!0),Y.name.value==="replicate"&&(b.replicate=!0),Y.name.value==="export"){b.export=!0;for(let se of Y.arguments)typeof b.export!="object"&&(b.export={}),b.export[se.name.value]=se.value.value}}let v=!1,q={};for(let Y of R.fields){let Z=F(Y.type);Z.name=Y.name.value,T.push(Z),q[Z.name]=void 0;for(let se of Y.directives){let Q=se.name.value;if(Q==="primaryKey")v?console.warn("Can not define two attributes as a primary key at",se.loc):(Z.isPrimaryKey=!0,v=!0);else if(Q==="indexed")Z.indexed=!0;else if(Q==="computed"){for(let ne of se.arguments||[])if(ne.name.value==="from"){let J=ne.value.value;Z.computed={from:g(J,ne,q)},Z.version==null&&(Z.version=J)}else ne.name.value==="version"&&(Z.version=ne.value.value);Z.computed=Z.computed||!0}else if(Q==="relationship"){let ne={};for(let J of se.arguments)ne[J.name.value]=J.value.value;Z.relationship=ne}else if(Q==="createdTime")Z.assignCreatedTime=!0;else if(Q==="updatedTime")Z.assignUpdatedTime=!0;else if(Q==="expiresAt")Z.expiresAt=!0;else if(Q==="allow"){let ne=Z.authorizedRoles=[];for(let J of se.arguments)J.name.value==="role"&&ne.push(J.value.value)}else server.knownGraphQLDirectives.includes(Q)&&console.warn(`@${Q} is an unknown directive, at`,se.loc)}}b.type=E,E==="Query"&&(h=b)}function S(R){let E=p.get(R.type);E?(Object.defineProperty(R,"properties",{value:E.properties}),Object.defineProperty(R,"definition",{value:E})):R.type==="array"?S(R.elements):u3.includes(R.type)||(0,xL.getWorkerIndex)()===0&&console.error(`The type ${R.type} is unknown at line ${R.location.line}, column ${R.location.column}, in ${s}`)}a(S,"connectPropertyType");for(let R of p.values())for(let E of R.properties)S(E);for(let R of _)R.tableClass=e(R),R.export&&(R.export.name===""?i.set((0,SR.dirname)(n),R.tableClass):i.set((0,SR.dirname)(n)+"/"+(R.export.name||R.type),R.tableClass,R.export));function g(R,E,T){return new UL.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${R}; } } } } computed;`,{filename:s,lineOffset:E.loc.startToken.line-1,columnOffset:E.loc.startToken.column}).runInThisContext()(T)}a(g,"createComputedFrom")}}var SR,UL,xL,u3,d3,f3,BL=be(()=>{SR=require("path"),UL=require("node:vm");Pe();xL=M(et()),u3=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt","Blob"];server.knownGraphQLDirectives&&(server.knownGraphQLDirectives=["table","sealed","export","primaryKey","indexed","computed","relationship","createdTime","updatedTime","expiresAt","allow"]);a(TR,"start");d3=TR,f3=TR({ensureTable:ft}).handleFile});var VL={};ve(VL,{parse:()=>yR,streamAsJSON:()=>$f,stringify:()=>wc});function $f(e){return new RR({value:e})}function HL(e){return console.error(e),JSON.stringify(e.toString())}function kL(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function wc(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===qL)return $L(e);if(t.resolution)return t.resolution.then(()=>wc(e));throw t}}function $L(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+=$L(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+wc(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function yR(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),h3.test(e)?_3.parse(e):JSON.parse(e)):null}var FL,GL,_3,p3,qL,RR,h3,bR=be(()=>{FL=require("stream"),GL=M(require("json-bigint-fixes")),_3=(0,GL.default)({useNativeBigInt:!0}),p3=1e4,qL={message:"Cannot serialize BigInt to JSON"};BigInt.prototype.toJSON=function(){throw qL};a($f,"streamAsJSON");RR=class extends FL.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),HL)}catch(s){yield HL(s)}else yield wc(t)}else yield wc(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);kL(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>p3?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 kL(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(HL,"handleError");a(kL,"when");a(wc,"stringify");a($L,"jsStringify");h3=/[[,:]\s*-?\d{16,}/;a(yR,"parse")});var Ni=w(Pm=>{var Cm=z();for(let e of["trace","debug","info","warn","error","fatal","notify"])Cm.logsAtLevel(e)&&(Pm[e]=Cm[e]);Pm.loggerWithTag=e=>Cm.loggerWithTag(e,!0);Pm.setLogLevel=Cm.setLogLevel});var Fm={};ve(Fm,{Blob:()=>wi,blobsWereEncoded:()=>Cc,databasePaths:()=>Mm,decodeBlobsWithWrites:()=>IR,decodeFromDatabase:()=>Pc,decodeWithBlobCallback:()=>CR,deleteBlob:()=>ZL,deleteBlobsInObject:()=>Ta,deleteRootBlobPathsForDB:()=>wR,encodeBlobsAsBuffers:()=>O3,encodeBlobsWithFilePath:()=>km,findBlobsInObject:()=>Ru,getFileId:()=>Bm,getFilePathForBlob:()=>tM,getRootBlobPathsForDB:()=>Hm,setDeletionDelay:()=>S3});function QL(){}function ZL(e){let t=tM(e);t&&setTimeout(()=>{(0,je.unlink)(t,r=>{r&&Sa.default.debug?.("Error trying to remove blob file",r)})},XL)}function S3(e){XL=e}function eM(e){let t=mn.get(e);if(!t)t={storageIndex:0,fileId:null,store:js},mn.set(e,t);else{if(t.saving)return t;t.store=js}return A3(t),t.source?OR(e,t.source,t):t.contentBuffer?T3(e,t):OR(e,Kf.Readable.from(e.stream()),t),t}function OR(e,t,r){let{filePath:n,fileId:s,store:i,compress:o,flush:c}=r;return r.saving=new Promise((l,u)=>{let f=s+":blob";if(!i.attemptLock(f,0))throw new Error(`Unable to get lock for blob file ${s}`);let d=(0,je.createWriteStream)(n,{autoClose:!1,flags:"w"});if(t.errored){let g=Buffer.from(t.errored.toString());d.end(Buffer.concat([h(BigInt(g.length)+0xff000000000000n),g]));return}let p=!1;e.size!==void 0&&(d.write(h(e.size)),p=!0);let _;o?(p||d.write(E3),_=(0,Um.createDeflate)(),t.pipe(_).pipe(d)):(p||d.write(m3),t.pipe(d)),t.on("error",S);function h(g){let R=BigInt(g),E=new Uint8Array(Er),T=new DataView(E.buffer);return R|=BigInt(o?NR:JL)<<48n,T.setBigInt64(0,R),E}a(h,"createHeader");function S(g){i.unlock(f,0);let R=d.fd;g?(R&&(0,je.close)(R),u(g)):c?(0,je.fdatasync)(R,E=>{E&&u(E),l(),(0,je.close)(R)}):(l(),(0,je.close)(R))}a(S,"finished"),d.on("error",S).on("finish",()=>{if(p)S();else{let g=_?_.bytesWritten:d.bytesWritten-Er;e.size=g,(0,je.write)(d.fd,h(g),0,Er,0,S)}})}),e}function Bm(e){return mn.get(e)?.fileId}function tM(e){let t=mn.get(e);return t?.fileId&&Yf(t)}function Hm(e){if(!e)throw new Error("No store specified, can not determine blob storage path");let t=Mm.get(e);if(!t){if(!e.databaseName)throw new Error("No database name specified, can not determine blob storage path");let r=(0,xm.get)(B.STORAGE_BLOBPATHS);r?t=r.map(n=>(0,oo.join)(n,e.databaseName)):t=[(0,oo.join)((0,xm.getHdbBasePath)(),"blobs",e.databaseName)],Mm.set(e,t)}return t}async function wR(e){let t=Mm.get(e);t&&await Promise.all(t.map(r=>rM(r)))}async function rM(e){for(let t of await(0,Js.readdir)(e,{withFileTypes:!0}))if(t.isDirectory())await rM((0,oo.join)(e,t.name));else try{await(0,Js.unlink)((0,oo.join)(e,t.name))}catch(r){Sa.default.warn?.("Error deleting file",r)}try{await(0,Js.rmdir)(e)}catch(t){Sa.default.warn?.("Error deleting directory",t)}}function Yf({storageIndex:e,fileId:t,store:r}){let n=Hm(r);return(0,oo.join)(n[e],t.slice(-9,-6)||"0",t.slice(-6,-3)||"0",t.length<=9?t.slice(-3):t.slice(0,-9)+t.slice(-3))}function T3(e,t){let r=t.contentBuffer,n=r.length;if(!(n<jL))return e.size=n,OR(e,Kf.Readable.from([r]),t)}function A3(e){let t=Hm(e.store),r=R3(),n=t?.length>1?y3(t,r):0,s=r.toString(16);e.storageIndex=n,e.fileId=s;let i=Yf(e),o=(0,oo.dirname)(i);(0,je.existsSync)(o)||(0,zL.ensureDirSync)(o),e.filePath=i}function R3(){let e=WL.get(js);if(!e){let t=0,r=Hm(js);for(let n of r){let s=0;for(let i=0;i<3;i++){s=s*4096;let o=0;if((0,je.existsSync)(n))for(let c of(0,je.readdirSync)(n)){let l=parseInt(c,16);i===2&&c.length>3&&(l=parseInt(c.slice(-3),16),l+=parseInt(c.slice(0,-3),16)*68719476736),l>o&&(o=l)}s+=o,n=(0,oo.join)(n,o.toString(16))}t=Math.max(t,s)}e=new BigInt64Array([BigInt(t)+1n]),e=new BigInt64Array(js.getUserSharedBuffer("blob-file-id",e.buffer)),WL.set(js,e)}return Number(Atomics.add(e,0,1n))}function y3(e,t){let r=Date.now();if(!e.frequencyTable){e.lastUpdated=0;let s=new Array(vm);for(let i=0;i<s.length;i++)s[i]=i%e.length;e.frequencyTable=s}return(e.lastUpdated??0)+6e4<r&&(e.lastUpdated=r,b3(e)),e.frequencyTable[t%vm]}async function b3(e){if(!Js.statfs)return;let t=await Promise.all(e.map(async(s,i)=>{let o=await(0,Js.statfs)(s),c=o.bavail*o.bsize;return Math.pow(c,.8)})),r=new Array(vm),n=t.map(s=>1/s);for(let s=0;s<vm;s++){let i=1/0,o=0;for(let c=0;c<n.length;c++)n[c]<i&&(o=c,i=n[c]);n[o]+=1/t[o],r[s]=o}e.frequencyTable=r}function km(e,t,r){Au=t,js=r,Cc=!1;try{return e()}finally{Au=void 0,js=void 0}}function O3(e){Pr=[];let t;try{t=e()}catch(n){throw Pr=void 0,n}let r=Pr.length<2?Pr[0]:Promise.all(Pr);return Pr=void 0,r?r.then(()=>e()):t}function IR(e,t){try{Pr=[],Ic=t,e()}catch(n){throw Ic=void 0,Pr=void 0,n}Ic=void 0;let r=Pr.length<2?Pr[0]:Promise.all(Pr);return Pr=void 0,r}function CR(e,t){try{return Ic=t,e()}finally{Ic=void 0}}function Pc(e,t){return js=t,e()}function Ta(e){Ru(e,t=>{ZL(t)})}function Ru(e,t){if(e instanceof wi)t(e);else if(Array.isArray(e))for(let r of e)typeof r=="object"&&r&&Ru(r,t);else if(e.constructor===Object)for(let r in e){let n=e[r];typeof n=="object"&&n&&Ru(e[r],t)}}function N3(){return class{static{a(this,"Blob")}content;constructor(t){this.content=t[0]}stream(){return new ReadableStream({start(t){t.enqueue(this.content),t.close()}})}text(){return Promise.resolve(this.content.toString())}arrayBuffer(){return Promise.resolve(this.content.buffer)}get size(){return this.content.length}slice(){throw new Error("Not implemented")}bytes(){return Promise.resolve(this.content)}get type(){return""}}}var io,Js,je,Um,Kf,zL,xm,oo,Sa,jL,Er,JL,NR,KL,m3,E3,YL,mn,Ic,wi,Au,Pr,js,Cc,Vf,Dm,g3,Lm,XL,Mm,WL,vm,gs=be(()=>{io=require("msgpackr"),Js=require("node:fs/promises"),je=require("node:fs"),Um=require("node:zlib"),Kf=require("node:stream"),zL=require("fs-extra"),xm=M(ae());H();oo=require("path"),Sa=M(Ni());ao();jL=8192,Er=8,JL=0,NR=1,KL=255,m3=new Uint8Array([0,JL,255,255,255,255,255,255]),E3=new Uint8Array([0,NR,255,255,255,255,255,255]),YL=0xffffffffffff,mn=new WeakMap,wi=global.Blob||N3(),Cc=!1,Vf=new Uint8Array(8),Dm=new DataView(Vf.buffer),g3=6e4;a(QL,"InstanceOfBlobWithNoConstructor");QL.prototype=wi.prototype;Lm=class e extends QL{static{a(this,"FileBackedBlob")}type="";size;#e;#t;constructor(t){super(),t?.type&&(this.type=t.type),t?.size!=null&&(this.size=t.size)}on(t,r){if(t==="error")this.#e??=[],this.#e.push(r);else if(t==="size")this.#t??=[],this.#t.push(r);else throw new Error("Only 'error' and 'size' events are supported")}toJSON(){if(this.type?.startsWith("text")){let t=mn.get(this),{start:r,end:n,contentBuffer:s,asString:i}=t;return i||(s&&(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),s?(t.asString=s.toString(),t.asString):(DR()&&PR(this.bytes().then(o=>t.contentBuffer=o)),`[blob: ${this.type}, ${this.size} bytes]`))}return{description:"Blobs that are not of type text/* can not be directly serialized as JSON, use as the body of a response or convert to another type"}}async text(){return(await this.bytes()).toString()}bytes(){let t=mn.get(this),{start:r,end:n,contentBuffer:s}=t;if(s)return(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),Promise.resolve(s);let i=Yf(t),o,c=a(async()=>{let l,u=Er;try{if(l=await(0,Js.readFile)(i),l.length>=Er){l.copy(Vf,0,0,Er);let d=Dm.getBigUint64(0);if(Number(d>>48n)===KL)throw new Error("Error in blob: "+buffer.subarray(Er));if(u=Number(d&0xffffffffffffn),u<n&&(u=n),u<YL&&(this.size=u,this.#t))for(let p of this.#t)p(u)}}catch(d){if(d.code!=="ENOENT")throw d;l=Buffer.alloc(0)}function f(d){if(u>d.length){let p=t.store,_=t.fileId+":blob";if(o)throw new Error("Incomplete blob");return new Promise((h,S)=>{if(p.attemptLock(_,0,()=>(o=!0,p.unlock(_,0),h(c()))))return o=!0,p.unlock(_,0),h(c())})}return(n!=null||r!=null)&&(d=d.subarray(r??0,n??d.length)),d}return a(f,"checkCompletion"),l[1]===NR?new Promise((d,p)=>{(0,Um.deflate)(l.subarray(Er),(_,h)=>{_?p(_):d(f(h))})}):f(l.subarray(Er))},"readContents");return c()}async arrayBuffer(){let t=await this.bytes(),r=new ArrayBuffer(t.length);return new Uint8Array(r).set(t),r}stream(){let t=mn.get(this),{contentBuffer:r,start:n,end:s}=t;if(r)return(s!=null||n!=null)&&(r=r.subarray(n??0,s??t.contentBuffer.length)),new ReadableStream({pull(S){S.enqueue(r),S.close()}});let i=Yf(t),o,c=0,l=0,u,f,d,p=!1,_=this;return new ReadableStream({start(){let S=1e3,g=a((R,E)=>{(0,je.open)(i,"r",(T,b)=>{if(T){if(T.code==="ENOENT"&&d!==!1&&(Sa.default.debug?.("File does not exist yet, waiting for it to be created",i,S),S-- >0))return setTimeout(()=>{h(),g(R,E)},20).unref();E(T),_.#e?.forEach(v=>v(T))}else o=b,R(b)})},"openFile");return new Promise(g)},pull:a(S=>{let g=0,R=100;return new Promise(a(function E(T,b){function v(q){(0,je.close)(o),clearTimeout(f),u&&u.close(),b(q),_.#e?.forEach(Y=>Y(q))}a(v,"onError");let F=Buffer.allocUnsafe(262144);(0,je.read)(o,F,0,F.length,c,(q,Y,Z)=>{if(l+=Y,q)return v(q);if(c===0){if(Y<Er){R-- >0&&d!==!1?(h(),Sa.default.debug?.("File was empty, waiting for data to be written",i,R),setTimeout(()=>E(T,b),20).unref()):(Sa.default.debug?.("File was empty, throwing error",i,R),b(new Error(`Blob ${t.fileId} was empty`)));return}Z.copy(Vf,0,0,Er);let se=Dm.getBigUint64(0);if(Number(se>>48n)===KL)return v(new Error("Error in blob: "+Z.subarray(Er)));if(g=Number(se&0xffffffffffffn),g<YL&&_.size!==g&&(_.size=g,_.#t))for(let Q of _.#t)Q(g);Z=Z.subarray(Er,Y),l-=Er}else if(Y===0){let se=Buffer.allocUnsafe(8);return(0,je.read)(o,se,0,Er,0,Q=>{if(Q)return v(Q);if(Vf.set(se),g=Number(Dm.getBigUint64(0)&0xffffffffffffn),g>l){h()?u?f=setTimeout(()=>{v(new Error("File read timed out"))},g3).unref():(u=(0,je.watch)(i,{persistent:!1},()=>{u.close(),u=null,f&&(clearTimeout(f),f=null,E(T,b))}),E(T,b)):p?v(new Error("Blob is incomplete")):(p=!0,E(T,b));return}(0,je.close)(o),S.close(),T()})}else Z=Z.subarray(0,Y);if(n!==void 0||s!==void 0){if(n&&l<n)return c+=Y,E(T,b);s&&l>=s&&(l>s&&(Z=Z.subarray(0,s-c)),l=g=s),n&&n>c&&(Z=Z.subarray(n-c))}c+=Y;try{S.enqueue(Z)}catch(se){return Sa.default.debug?.("Error enqueuing chunk",se),T()}l===g&&((0,je.close)(o),S.close()),T()})},"readMore"))},"pull"),cancel(){(0,je.close)(o),clearTimeout(f),u&&u.close()}});function h(){if(d===void 0){let S=t.store,g=t.fileId+":blob";d=!S.attemptLock(g,0,()=>{d=!1,S.unlock(g,0)}),d||S.unlock(g,0)}return d}}slice(t,r,n){let s=mn.get(this),i=new e(n&&{type:n});if(s?.fileId){let o={...s,start:t,end:r};mn.set(i,o),this.size!=null&&(i.size=(r==null?this.size:Math.min(r,this.size))-(t??0))}else if(s?.contentBuffer&&!s.storageBuffer){let o={...s,contentBuffer:s.contentBuffer.subarray(t,r)};mn.set(i,o),i.size=(r??this.size)-t}else throw new Error("Can not slice a streaming blob that is not backed by a file");return i}save(t){if(!t?.primaryStore?.rootStore)throw new Error("No target table specified");return eM(this).saving??Promise.resolve()}},XL=500;a(ZL,"deleteBlob");a(S3,"setDeletionDelay");global.createBlob=function(e,t){let r=new Lm(t),n={storageIndex:0,fileId:null,flush:t?.flush,compress:t?.compress};if(mn.set(r,n),e instanceof Uint8Array)r.size=e.length,n.contentBuffer=e;else if(e instanceof Kf.Readable)n.source=e;else if(typeof e=="string")n.contentBuffer=Buffer.from(e);else if(e?.[Symbol.asyncIterator]||e?.[Symbol.iterator])n.source=Kf.Readable.from(e);else throw new Error("Invalid source type");return r};a(eM,"saveBlob");a(OR,"writeBlobWithStream");a(Bm,"getFileId");a(tM,"getFilePathForBlob");Mm=new Map;a(Hm,"getRootBlobPathsForDB");a(wR,"deleteRootBlobPathsForDB");a(rM,"rimrafSteadily");a(Yf,"getFilePath");a(T3,"writeBlobWithBuffer");a(A3,"generateFilePath");WL=new Map;a(R3,"getNextFileId");vm=128;a(y3,"getNextStorageIndex");a(b3,"createFrequencyTableForStoragePaths");a(km,"encodeBlobsWithFilePath");a(O3,"encodeBlobsAsBuffers");a(IR,"decodeBlobsWithWrites");a(CR,"decodeWithBlobCallback");a(Pc,"decodeFromDatabase");a(Ta,"deleteBlobsInObject");a(Ru,"findBlobsInObject");(0,io.addExtension)({Class:wi,type:11,unpack:a(function(e){let t=(0,io.unpack)(e),r=new Lm;if(Object.assign(r,t[0]),typeof t[1]!="object"){if(!js)throw new Error("No store specified, can not load blob from storage");if(mn.set(r,{storageIndex:t[1],fileId:t[2],store:js}),Ic)return Ic(r)??r}else mn.set(r,{storageIndex:0,fileId:null,storageBuffer:e,contentBuffer:t[1]}),r.size=t[1]?.length;return r},"unpack"),pack:a(function(e){let t=mn.get(e);if(Au!==void 0&&(Cc=!0,t?.recordId!==void 0&&t.recordId!==Au))throw new Error("Cannot use the same blob in two different records");let r={...e};if(e.type&&(r.type=e.type),e.size!==void 0&&(r.size=e.size),t){if(t.storageBuffer)return t.storageBuffer;if(t.contentBuffer?.length<jL)return r.size=t.contentBuffer.length,(0,io.pack)([r,t.contentBuffer])}if(Au!==void 0){if(t=eM(e),!t.fileId)throw new Error("Unable to save blob without file id");return t.recordId=Au,(0,io.pack)([r,t.storageIndex,t.fileId])}if(t)try{let n=(0,je.readFileSync)(Yf(t));if(n.length>=Er&&(n.copy(Vf,0,0,Er),Number(Dm.getBigUint64(0)&0xffffffffffffn)===n.length-Er))return Buffer.concat([(0,io.pack)([r]),n]);if(Pr)Pr.push(e.bytes());else throw new Error("Incomplete blob");return Buffer.alloc(0)}catch(n){if(n.code==="ENOENT"&&Pr)return Pr.push(e.bytes()),Buffer.alloc(0);throw n}else throw new Error("Blob has no storage info or buffer attached to it")},"pack")});(0,io.addExtension)({Class:Promise,type:12,pack(){throw new Error("Cannot encode a promise")}});a(N3,"polyfillBlob")});var uM={};ve(uM,{asyncSerialization:()=>PR,contentTypes:()=>UR,findBestSerializer:()=>qm,getDeserializer:()=>uo,hasAsyncSerialization:()=>DR,registerContentHandlers:()=>jf,serialize:()=>Jf,serializeMessage:()=>Aa,toCsvStream:()=>Gm});function I3(e){try{return e?.[0]===123?vR(e):e}catch{return e}}function jf(e){e.register(P3,{serializers:[{regex:/^application\/json$/,serializer:$f},{regex:/^application\/cbor$/,serializer:a(function(t){return new Dc.EncoderStream(zf).end(t)},"serializer")},{regex:/^application\/(x-)?msgpack$/,serializer:a(function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?Lc.Readable.from((0,Ii.encodeIter)(t,zf)):(0,Ii.pack)(t)},"serializer")},{regex:/^text\/csv$/,serializer:a(function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),Gm(t)},"serializer")}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Ii.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Dc.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function qm(e){let t=e.headers.asObject||e.headers,r=e.requestedContentType??t.accept,n,s=0,i,o,c=r?r.toLowerCase().split(/\s*,\s*/):[];for(let l of c){let[u,...f]=l.split(/\s*;\s*/),d=1,p={q:1};for(let h of f){let S=h.indexOf("=");p[h.substring(0,S)]=h.substring(S+1)}d=+p.q;let _=Kr.get(u);if(_){let h=(_.q||1)*d;h>s&&(n=_,i=_.type||u,s=h,o=p)}}if(!n){if(r)throw new iM.ClientError("No supported content types found in Accept header, supported types include: "+Array.from(Kr.keys()).join(", "),406);n=Kr.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function Jf(e,t,r){let n=sM&&t.headers.asObject?.["accept-encoding"]?.includes("br"),s;if(e?.contentType!=null&&e.data!=null)r.headers.set("Content-Type",e.contentType),r.headers.set("Vary","Accept-Encoding"),s=e.data;else if(e instanceof Uint8Array||e instanceof wi)r.headers.set("Content-Type","application/octet-stream"),r.headers.set("Vary","Accept-Encoding"),s=e;else{let i=qm(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}),MR.default.warn?.(`Error serializing error ${t?.url||t}: ${l}`),l)),e.getColumns=c}let o=i.serializer.serializeStream(e,r);return n&&(r.headers.set("Content-Encoding","br"),o=o.pipe((0,lo.createBrotliCompress)({params:{[lo.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?lo.constants.BROTLI_MODE_TEXT:lo.constants.BROTLI_MODE_GENERIC,[lo.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>sM?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,lo.brotliCompress)(s,(c,l)=>{c?o(c):i(l)}))):s}function Aa(e,t,r){if(e?.contentType!=null&&e.data!=null)return e.data;co=r?void 0:[];try{let n;if(t){let s=t.serialize;if(s)n=s(e);else{let i=qm(t);s=t.serialize=i.serializer.serialize,n=s(e)}}else n=Wf(e);return co?.length>0?(co.length===1?co[0]:Promise.all(co)).then(()=>Aa(e,t,!0)):n}finally{co=void 0}}function PR(e){if(co)co.push(e);else throw new Error("Unable to serialize asynchronously")}function DR(){return!!co}function D3(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 M3(e){return L3.includes(e)}function v3(e){let t=e.indexOf(";"),r;if(t>-1){r={};let n=e.slice(t+1).split(";");for(let s of n){let[i,o]=s.split("=");r[i.trim()]=o.trim()}e=e.slice(0,t)}return{type:e,parameters:r}}function uo(e="",t=!1){let r=v3(e),n=r.type&&Kr.get(r.type)?.deserialize||U3(r);return t?s=>D3(s).then(n):n}function U3(e){return e.type.startsWith("text/")?(e.parameters?.charset&&!M3(e.parameters.charset)&&MR.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 vR(t)}catch{}return{contentType:e.type||"application/octet-stream",data:t}}}function x3(e,t){return{[Symbol.asyncIterator](){let r=e[Symbol.asyncIterator]?e[Symbol.asyncIterator]():e[Symbol.iterator]();return{next(){let n=r.next();return n.then?n.then(s=>({value:t(s.value),done:s.done})):{value:t(n.value),done:n.done}},return(n){return r.return(n)},throw(n){return r.throw(n)}}}}}function Gm(e,t){let r=Lc.default.Readable.from(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator]?e:[e]),n={};t&&(n.fields=t.map(o=>({label:o,value:o})));let s={objectMode:!0},i=new w3(n,s);return r.pipe(i)}var Ii,Dc,lo,iM,Lc,oM,LR,aM,MR,w3,cM,Wf,vR,zf,Kr,UR,nM,lM,C3,P3,sM,co,L3,ao=be(()=>{bR();Ii=require("msgpackr"),Dc=require("cbor-x"),lo=require("zlib"),iM=M(pe()),Lc=M(require("stream"));Vr();oM=M(Ti()),LR=M(ae());H();aM=M(require("yaml")),MR=M(Ni());gs();({Transform:w3}=require("json2csv")),cM=LR.default.get(B.SERIALIZATION_BIGINT)!==!1,Wf=cM?wc:JSON.stringify,vR=cM?yR:JSON.parse,zf={useRecords:!1,useToJSON:!0},Kr=new Map,UR=Kr;Ye.contentTypes=UR;(0,oM._assignPackageExport)("contentTypes",UR);Kr.set("application/json",{serializeStream:$f,serialize:Wf,deserialize(e){return vR(e)},q:.8});nM=new Dc.Encoder(zf);Kr.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new Dc.EncoderStream(zf).end(e)},serialize:nM.encode,deserialize:nM.decode,q:1});Kr.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?Lc.Readable.from((0,Ii.encodeIter)(e,zf)):(0,Ii.pack)(e)},serialize:Ii.pack,deserialize:Ii.unpack,q:.9});Kr.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),Gm(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]),Gm(e,e?.getColumns?.())},q:.1});Kr.set("text/plain",{serialize(e){return e.toString()},serializeStream(e){return Lc.Readable.from(e.map?e.map(t=>t.toString()):e)},deserialize(e){return e.toString()},q:.2});Kr.set("text/yaml",{serialize(e){return aM.stringify(e,{aliasDuplicateObjects:!1})},q:.7});Kr.set("text/event-stream",{serializeStream:a(function(e){return Lc.Readable.from(x3(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+`
7
+ `}a(zs,"createLogRecord");function If(e){if(Ai){if(ID(e),ms){fa=!1;try{process.stdout.write(e)}finally{fa=!0}}}else ms&&process.stdout.write(e)}a(If,"logStdOut");function fm(e){if(Ai){if(ID(e),ms){fa=!1;try{process.stderr.write(e)}finally{fa=!0}}}else ms&&process.stderr.write(e)}a(fm,"logStdErr");function ID(e){rR(),da?no.appendFileSync(da,e):tR||console.log(e)}a(ID,"logToFile");function sR(){try{no.closeSync(da)}catch{}da=null}a(sR,"closeLogFile");function rR(){if(!da){try{da=no.openSync(um,"a")}catch(e){tR||(tR=!0,console.error(e))}setTimeout(()=>{sR()},qQ).unref()}}a(rR,"openLogFile");function CD(...e){Er[Pr]<=Er.info&&If(zs("info",e))}a(CD,"info");function PD(...e){Er[Pr]<=Er.trace&&If(zs("trace",e))}a(PD,"trace");function dm(...e){Er[Pr]<=Er.error&&fm(zs("error",e))}a(dm,"error");function DD(...e){Er[Pr]<=Er.debug&&If(zs("debug",e))}a(DD,"debug");function LD(...e){Er[Pr]<=Er.notify&&If(zs("notify",e))}a(LD,"notify");function MD(...e){Er[Pr]<=Er.fatal&&fm(zs("fatal",e))}a(MD,"fatal");function vD(...e){Er[Pr]<=Er.warn&&fm(zs("warn",e))}a(vD,"warn");function zQ(e,t,...r){t===ND.STDERR?fm(zs(e,r)):If(zs(e,r))}a(zQ,"logCustomLevel");function jQ(){let e;try{e=HQ.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=Ri.join(e,Wt.HDB_HOME_DIR_NAME,Wt.BOOT_PROPS_FILE_NAME);return no.existsSync(t)||(t=Ri.join(nR,"utility/hdb_boot_properties.file")),t}a(jQ,"getPropsFilePath");function JQ(e){Pr=e}a(JQ,"setLogLevel");function yD(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(yD,"autoCastBoolean");function QQ(e){try{if(e.includes("config/settings.js")){let o=OD(e);return{level:o.get(Wt.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY),config_log_path:Ri.dirname(o.get(Wt.HDB_SETTINGS_NAMES.LOG_PATH_KEY)),to_file:o.get(Wt.HDB_SETTINGS_NAMES.LOG_TO_FILE),to_stream:o.get(Wt.HDB_SETTINGS_NAMES.LOG_TO_STDSTREAMS)}}let t=bD.parseDocument(no.readFileSync(e,"utf8")),r=t.getIn(["logging","level"]),n=t.getIn(["logging","root"]),s=t.getIn(["logging","file"]),i=t.getIn(["logging","stdStreams"]);return{level:r,config_log_path:n,to_file:s,to_stream:i}}catch(t){if(t.code===Wt.NODE_ERROR_CODES.ENOENT)throw t;console.error("Error accessing config file for logging"),console.error(t)}}a(QQ,"getLogConfig");function XQ(){try{let e=bD.parseDocument(no.readFileSync(GQ,"utf8")),t=e.getIn(["logging","level"]),r=e.getIn(["logging","file"]),n=e.getIn(["logging","stdStreams"]);return{default_level:t,default_to_file:r,default_to_stream:n}}catch(e){console.error("Error accessing default config file for logging"),console.error(e)}}a(XQ,"getDefaultConfig");function ZQ(e,t,r,n,s,i){this.username=e,this.status=t,this.type=r,this.originating_ip=n,this.request_method=s,this.path=i}a(ZQ,"AuthAuditLog")});var iR=w((Wye,BD)=>{"use strict";var e4=require("util"),t4=require("path"),r4=require("child_process"),n4=e4.promisify(r4.execFile),s4=1e3*1e3*10;BD.exports={findPs:i4};async function i4(e){let t={};try{await Promise.all(["comm","args","ppid","uid","%cpu","%mem"].map(async r=>{let{stdout:n}=await n4("ps",["wwxo",`pid,${r}`],{maxBuffer:s4});for(let s of n.trim().split(`
8
+ `).slice(1)){s=s.trim();let[i]=s.split(" ",1),o=s.slice(i.length+1).trim();t[i]===void 0&&(t[i]={}),t[i][r]=o}}))}catch(r){throw r}return Object.entries(t).filter(([,r])=>r.comm&&r.args&&r.ppid&&r.uid&&r["%cpu"]&&r["%mem"]&&r.args.includes(e)).map(([r,n])=>({pid:Number.parseInt(r,10),name:t4.basename(n.comm),cmd:n.args,ppid:Number.parseInt(n.ppid,10),uid:Number.parseInt(n.uid,10),cpu:Number.parseFloat(n["%cpu"]),memory:Number.parseFloat(n["%mem"])}))}a(i4,"findPs")});var xt=w((jye,kD)=>{"use strict";var o4="__dbis__",a4="__txns__",c4="__environment_name__",l4="__dbi_defintion__",u4={EQUALS:"equals",STARTS_WITH:"startsWith",_STARTS_WITH:"starts_with",ENDS_WITH:"endsWith",_ENDS_WITH:"ends_with",CONTAINS:"contains",SEARCH_ALL:"searchAll",SEARCH_ALL_TO_MAP:"searchAllToMap",BATCH_SEARCH_BY_HASH:"batchSearchByHash",BATCH_SEARCH_BY_HASH_TO_MAP:"batchSearchByHashToMap",GREATER_THAN:"greaterThan",_GREATER_THAN:"greater_than",GREATER_THAN_EQUAL:"greaterThanEqual",_GREATER_THAN_EQUAL:"greater_than_equal",LESS_THAN:"lessThan",_LESS_THAN:"less_than",LESS_THAN_EQUAL:"lessThanEqual",_LESS_THAN_EQUAL:"less_than_equal",BETWEEN:"between"},d4=["__createdtime__","__updatedtime__"],f4="\uFFFF",HD={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},_4=Object.values(HD);kD.exports={AUDIT_STORE_NAME:a4,INTERNAL_DBIS_NAME:o4,DBI_DEFINITION_NAME:l4,SEARCH_TYPES:u4,TIMESTAMP_NAMES:d4,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:c4,TRANSACTIONS_DBI_NAMES_ENUM:HD,TRANSACTIONS_DBIS:_4,OVERFLOW_MARKER:f4}});var xn=w((Jye,zD)=>{"use strict";var FD=(H(),C(G)),GD=xt(),qD={CONTINUE:100,OK:200,CREATED:201,BAD_REQUEST:400,UNAUTHORIZED:401,FORBIDDEN:403,NOT_FOUND:404,METHOD_NOT_ALLOWED:405,REQUEST_TIMEOUT:408,CONFLICT:409,TOO_MANY_REQUESTS:429,INTERNAL_SERVER_ERROR:500,NOT_IMPLEMENTED:501,BAD_GATEWAY:502,SERVICE_UNAVAILABLE:503,GATEWAY_TIMEOUT:504,HTTP_VERSION_NOT_SUPPORTED:505,INSUFFICIENT_STORAGE:507,NETWORK_AUTHENTICATION_REQUIRED:511},$D=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),VD={500:$D("There was an error processing your request."),400:"Invalid request"},p4=VD[qD.INTERNAL_SERVER_ERROR],h4={OP_NOT_SUPPORTED_FOR_FS:a(e=>`${e} is not available for this instance because it uses the File System data store.`,"OP_NOT_SUPPORTED_FOR_FS"),MISSING_VALUE:a(e=>`${e} is missing.`,"MISSING_VALUE"),INVALID_VALUE:a(e=>`${e} is invalid.`,"INVALID_VALUE"),NOT_FOUND:a(e=>`${e} not found.`,"NOT_FOUND")},m4={CONFIG_VALIDATION:a(e=>`HarperDB config file validation error: ${e}`,"CONFIG_VALIDATION")},E4={DEFAULT_BULK_LOAD_ERR:"There was an error during your bulk load into HarperDB.",DOWNLOAD_FILE_ERR:a(e=>`There was an error downloading '${e}'.`,"DOWNLOAD_FILE_ERR"),INSERT_JSON_ERR:"There was an error inserting the downloaded JSON data.",INSERT_CSV_ERR:"There was an error inserting the downloaded CSV data.",INVALID_ACTION_PARAM_ERR:a(e=>`Bulk load operation failed - ${e} is not a valid 'action' parameter`,"INVALID_ACTION_PARAM_ERR"),INVALID_FILE_EXT_ERR:a(e=>`Error selecting correct parser - valid file type not found in json - ${e}`,"INVALID_FILE_EXT_ERR"),MAX_FILE_SIZE_ERR:a((e,t)=>`File size is ${e} bytes, which exceeded the maximum size allowed of: ${t} bytes`,"MAX_FILE_SIZE_ERR"),PAPA_PARSE_ERR:"There was an error parsing the downloaded CSV data.",S3_DOWNLOAD_ERR:a(e=>`There was an error downloading '${e}' from AWS.`,"S3_DOWNLOAD_ERR"),WRITE_TEMP_FILE_ERR:"Error writing temporary file to storage"},g4={BASE_PATH_REQUIRED:"base_path is required",DESTINATION_PATH_REQUIRED:"destination_path is required",ENV_NAME_REQUIRED:"env_name is required",INVALID_BASE_PATH:"invalid base_path",INVALID_DESTINATION_PATH:"invalid destination_path",INVALID_ENVIRONMENT:"invalid environment",ENV_REQUIRED:"env is required",DBI_NAME_REQUIRED:"dbi_name is required",DBI_DOES_NOT_EXIST:"dbi does not exist",HASH_ATTRIBUTE_REQUIRED:"hash_attribute is required",ID_REQUIRED:"id is required",IDS_REQUIRED:"ids is required",IDS_MUST_BE_ITERABLE:"ids must be iterable",FETCH_ATTRIBUTES_REQUIRED:"fetch_attributes is required",FETCH_ATTRIBUTES_MUST_BE_ARRAY:"fetch_attributes must be an array",ATTRIBUTE_REQUIRED:"attribute is required",SEARCH_VALUE_REQUIRED:"search_value is required",SEARCH_VALUE_TOO_LARGE:"search_value is too long",WRITE_ATTRIBUTES_REQUIRED:"write_attributes is required",WRITE_ATTRIBUTES_MUST_BE_ARRAY:"write_attributes must be an array",RECORDS_REQUIRED:"records is required",RECORDS_MUST_BE_ARRAY:"records must be an array",CANNOT_CREATE_INTERNAL_DBIS_NAME:`cannot create a dbi named ${GD.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${GD.INTERNAL_DBIS_NAME}`,START_VALUE_REQUIRED:"start_value is required",END_VALUE_REQUIRED:"end_value is required",CANNOT_COMPARE_STRING_TO_NUMERIC_KEYS:"cannot compare a string to numeric keys",END_VALUE_MUST_BE_GREATER_THAN_START_VALUE:"end_value must be greater than or equal to start_value",UNKNOWN_SEARCH_TYPE:"unknown search type",CANNOT_DROP_TABLE_HASH_ATTRIBUTE:"cannot drop a table's hash attribute"},S4={ATTR_NAME_LENGTH_ERR:a(e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${FD.INSERT_MAX_CHARACTER_SIZE} bytes.`,"ATTR_NAME_LENGTH_ERR"),ATTR_NAME_NULLISH_ERR:"transaction aborted due to record(s) with an attribute name that is null, undefined or empty string",HASH_VAL_LENGTH_ERR:`transaction aborted due to record(s) with a hash value that exceeds ${FD.INSERT_MAX_CHARACTER_SIZE} bytes, check log for more info`,INVALID_FORWARD_SLASH_IN_HASH_ERR:"transaction aborted due to record(s) with a hash value that contains a forward slash, check log for more info",RECORD_MISSING_HASH_ERR:"transaction aborted due to record(s) with no hash value, check log for more info"},KD={GENERIC_AUTH_FAIL:"Login failed",USER_INACTIVE:"Cannot complete request: User is inactive",INVALID_TOKEN:"invalid token",NO_ENCRYPTION_KEYS:"unable to generate JWT as there are no encryption keys. please contact your administrator",INVALID_CREDENTIALS:"invalid credentials",PASSWORD_REQUIRED:"password is required",USERNAME_REQUIRED:"username is required",REFRESH_TOKEN_REQUIRED:"refresh_token is required",INVALID_AUTH_OBJECT:"invalid auth_object",INVALID_BODY:"invalid body",TOKEN_EXPIRED:"token expired",REFRESH_TOKEN_SAVE_FAILED:"unable to store refresh_token"},T4={DEFAULT_INVALID_REQUEST:"Invalid request",OP_AUTH_PERMS_ERROR:"This operation is not authorized due to role restrictions and/or invalid database items",OP_IS_SU_ONLY:a(e=>`Operation '${e}' is restricted to 'super_user' roles`,"OP_IS_SU_ONLY"),OP_NOT_FOUND:a(e=>`Operation '${e}' not found`,"OP_NOT_FOUND"),SYSTEM_TIMESTAMP_PERMS_ERR:"Internal timestamp attributes - '__createdtime_' and '__updatedtime__' - cannot be inserted to or updated by HDB users.",UNKNOWN_OP_AUTH_ERROR:a((e,t,r)=>`There was an error authorizing ${e} op on table '${t}.${r}'`,"UNKNOWN_OP_AUTH_ERROR"),USER_HAS_NO_PERMS:a(e=>`User ${e} has no role or permissions. Please assign the user a valid role.`,"USER_HAS_NO_PERMS"),DROP_SYSTEM:"The 'system' database, tables and records are used internally by HarperDB and cannot be updated or removed."},A4={ATTR_PERM_MISSING:a((e,t)=>`${e.toUpperCase()} attribute permission missing for '${t}'`,"ATTR_PERM_MISSING"),ATTR_PERM_MISSING_NAME:"Permission object in 'attribute_permission' missing an 'attribute_name'",ATTR_PERM_NOT_BOOLEAN:a((e,t)=>`${e.toUpperCase()} attribute permission for '${t}' must be a boolean`,"ATTR_PERM_NOT_BOOLEAN"),ATTR_PERMS_ARRAY_MISSING:"Missing 'attribute_permissions' array",ATTR_PERMS_NOT_ARRAY:"Value for 'attribute_permissions' must be an array",INVALID_ATTRIBUTE_IN_PERMS:a(e=>`Invalid attribute '${e}' in 'attribute_permissions'`,"INVALID_ATTRIBUTE_IN_PERMS"),INVALID_PERM_KEY:a(e=>`Invalid table permission key value '${e}'`,"INVALID_PERM_KEY"),INVALID_ATTR_PERM_KEY:a(e=>`Invalid attribute permission key value '${e}'`,"INVALID_ATTR_PERM_KEY"),INVALID_ROLE_JSON_KEYS:a(e=>`Invalid ${e.length>1?"keys":"key"} in JSON body - '${e.join("', '")}'`,"INVALID_ROLE_JSON_KEYS"),MISMATCHED_TABLE_ATTR_PERMS:a(e=>`You have a conflict with TABLE permissions for '${e}' being false and ATTRIBUTE permissions being true`,"MISMATCHED_TABLE_ATTR_PERMS"),OUTDATED_PERMS_TRANSLATION_ERROR:"This instance was recently upgraded and uses our new role permissions structure. Please login to this instance in HarperDB Studio, go to 'Roles', and click 'Update Role Permission' for all standard roles to migrate them to the new structure.",ROLE_ALREADY_EXISTS:a(e=>`A role with name '${e}' already exists`,"ROLE_ALREADY_EXISTS"),ROLE_NOT_FOUND:"Role not found",ROLE_PERMS_ERROR:"Errors in the role permissions JSON provided",SCHEMA_PERM_ERROR:a(e=>`Your role does not have permission to view database metadata for '${e}'`,"SCHEMA_PERM_ERROR"),SCHEMA_TABLE_PERM_ERROR:a((e,t)=>`Your role does not have permission to view database.table metadata for '${e}.${t}'`,"SCHEMA_TABLE_PERM_ERROR"),SU_ROLE_MISSING_ERROR:"Missing 'super_user' key/value in permission set",SU_CU_ROLE_BOOLEAN_ERROR:a(e=>`Value for '${e}' permission must be a boolean`,"SU_CU_ROLE_BOOLEAN_ERROR"),STRUCTURE_USER_ROLE_TYPE_ERROR:a(e=>`Value for '${e}' permission must be a boolean or Array`,"STRUCTURE_USER_ROLE_TYPE_ERROR"),SU_CU_ROLE_NO_PERMS_ALLOWED:a(e=>`Roles with '${e}' set to true cannot have other permissions set.`,"SU_CU_ROLE_NO_PERMS_ALLOWED"),SU_CU_ROLE_COMBINED_ERROR:"Roles cannot have both 'super_user' and 'cluster_user' values included in their permissions set.",TABLE_PERM_MISSING:a(e=>`Missing table ${e.toUpperCase()} permission`,"TABLE_PERM_MISSING"),TABLE_PERM_NOT_BOOLEAN:a(e=>`Table ${e.toUpperCase()} permission must be a boolean`,"TABLE_PERM_NOT_BOOLEAN")},R4={ATTR_NOT_FOUND:a((e,t,r)=>`Attribute '${r}' does not exist on '${e}.${t}'`,"ATTR_NOT_FOUND"),ATTR_EXISTS_ERR:a((e,t,r)=>`Attribute '${r}' already exists in ${e}.${t}'`,"ATTR_EXISTS_ERR"),DESCRIBE_ALL_ERR:"There was an error during describeAll. Please check the logs and try again.",INVALID_TABLE_ERR:a(e=>`Invalid table ${JSON.stringify(e)}`,"INVALID_TABLE_ERR"),SCHEMA_NOT_FOUND:a(e=>`database '${e}' does not exist`,"SCHEMA_NOT_FOUND"),SCHEMA_EXISTS_ERR:a(e=>`database '${e}' already exists`,"SCHEMA_EXISTS_ERR"),TABLE_EXISTS_ERR:a((e,t)=>`Table '${t}' already exists in '${e}'`,"TABLE_EXISTS_ERR"),SCHEMA_REQUIRED_ERR:"database is required",TABLE_NOT_FOUND:a((e,t)=>`Table '${e}.${t}' does not exist`,"TABLE_NOT_FOUND"),TABLE_REQUIRED_ERR:"table is required"},y4={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},b4={ALTER_USER_DUP_ROLES:a(e=>`Update failed. There are duplicates for the '${e}' role which is not allowed. Update your roles and try again.`,"ALTER_USER_DUP_ROLES"),ALTER_USER_ROLE_NOT_FOUND:a(e=>`Update failed. Requested '${e}' role not found.`,"ALTER_USER_ROLE_NOT_FOUND"),DUP_ROLES_FOUND:a(e=>`Multiple ${e} roles found. Roles must have unique 'role' value. Please update and try again.`,"DUP_ROLES_FOUND"),ROLE_NAME_NOT_FOUND:a(e=>`${e} role not found`,"ROLE_NAME_NOT_FOUND"),USER_ALREADY_EXISTS:a(e=>`User ${e} already exists`,"USER_ALREADY_EXISTS"),USER_NOT_EXIST:a(e=>`User ${e} does not exist`,"USER_NOT_EXIST")},YD={INVALID_DATE:"Invalid date, must be in ISO-8601 format (YYYY-MM-DD).",SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE:a(e=>`invalid sort attribute '${e}', the attribute must either be the table's hash attribute or an attribute used in conditions.`,"SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE")},WD={INVALID_ITC_DATA_TYPE:"Invalid ITC event data type, must be an object",MISSING_TYPE:"ITC event missing 'type'",MISSING_MSG:"ITC event missing 'message'",MISSING_ORIGIN:"ITC event message missing 'originator' property",INVALID_EVENT:a(e=>`ITC server received invalid event type: ${e}`,"INVALID_EVENT")},O4={FUNCTION_STATUS:"Error getting custom function status, check the log for more details",GET_FUNCTIONS:"Error getting custom functions, check the log for more details",GET_FUNCTION:"Error getting custom function, check the log for more details",SET_FUNCTION:"Error setting custom function, check the log for more details",NO_PROJECT:"Project does not exist. Create one using 'add_custom_function_project'",PROJECT_EXISTS:"Project already exists",VALIDATION_ERR:"Error validating request, check the log for more details",NO_FILE:"File does not exist",BAD_FILE_NAME:"File name can only contain alphanumeric, dash and underscore characters",BAD_PROJECT_NAME:"Project name can only contain alphanumeric, dash and underscores characters",BAD_PACKAGE:"Packaged project must be base64-encoded tar file of project directory",DROP_FUNCTION:"Error dropping custom function, check the log for more details",ADD_FUNCTION:"Error adding custom function project, check the log for more details",DROP_FUNCTION_PROJECT:"Error dropping custom function project, check the log for more details",BAD_FILE_PATH:"Filepath must be valid, and contain the name of the tarball you wish to write",NOT_ENABLED:"Custom functions is not enabled, to enable set fastifyRoutes enabled to true in hdb/harperdb-config.yaml file.",BAD_SSH_KEY_NAME:"SSH key name can only contain alphanumeric, dash and underscore characters"},N4={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},w4={...KD,...E4,...h4,...T4,...A4,...R4,...y4,...b4,...S4,...YD,...WD,...O4,...N4,...m4};zD.exports={CHECK_LOGS_WRAPPER:$D,HDB_ERROR_MSGS:w4,DEFAULT_ERROR_MSGS:VD,DEFAULT_ERROR_RESP:p4,HTTP_STATUS_CODES:qD,LMDB_ERRORS_ENUM:g4,AUTHENTICATION_ERROR_MSGS:KD,VALIDATION_ERROR_MSGS:YD,ITC_ERRORS:WD}});var pe=w((Xye,QD)=>{"use strict";var _u=xn(),I4=z(),C4=(H(),C(G)),_m=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,jD),this.statusCode=n||_u.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(_u.DEFAULT_ERROR_MSGS[n]?_u.DEFAULT_ERROR_MSGS[n]:_u.DEFAULT_ERROR_MSGS[_u.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR]),this.message=t.message?t.message:this.http_resp_msg,this.type=t.name,s&&(this.logLevel=s),typeof this.message!="string"&&(this.stack=t.stack),i&&I4[s](i)}},oR=class extends Error{static{a(this,"ClientError")}constructor(t,r){if(t instanceof Error)return t.statusCode=r||400,t;super(t),this.statusCode=r||400}},aR=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function jD(e,t,r,n=C4.LOG_LEVELS.ERROR,s=null,i=!1){if(JD(e))return e;let o=new _m(e,t,r,n,s);return i&&delete o.stack,o}a(jD,"handleHDBError");function JD(e){return e.__proto__.constructor.name===_m.name}a(JD,"isHDBError");QD.exports={isHDBError:JD,handleHDBError:jD,ClientError:oR,ServerError:aR,hdb_errors:_u}});var gt=w((ebe,sL)=>{"use strict";var Mf=(H(),C(G)),P4=ie(),fn=ae(),vf=require("path"),D4=require("minimist"),XD=require("fs-extra"),ZD=require("lodash");fn.initSync();var{CONFIG_PARAMS:_a,DATABASES_PARAM_CONFIG:Cf,SYSTEM_SCHEMA_NAME:pm}=Mf,Pf,Df,Lf;function eL(){if(Pf!==void 0)return Pf;if(fn.getHdbBasePath()!==void 0)return Pf=fn.get(_a.STORAGE_PATH)||vf.join(fn.getHdbBasePath(),Mf.DATABASES_DIR_NAME),Pf}a(eL,"getBaseSchemaPath");function tL(){if(Df!==void 0)return Df;if(fn.getHdbBasePath()!==void 0)return Df=nL(pm),Df}a(tL,"getSystemSchemaPath");function rL(){if(Lf!==void 0)return Lf;if(fn.getHdbBasePath()!==void 0)return Lf=fn.get(Mf.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||vf.join(fn.getHdbBasePath(),Mf.TRANSACTIONS_DIR_NAME),Lf}a(rL,"getTransactionAuditStoreBasePath");function L4(e,t){let r=fn.get(_a.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||vf.join(rL(),e.toString())}a(L4,"getTransactionAuditStorePath");function nL(e,t){e=e.toString(),t=t&&t.toString();let r=fn.get(Mf.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||vf.join(eL(),e)}a(nL,"getSchemaPath");function M4(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,D4(process.argv));let n=r[_a.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!P4.isObject(n))throw o;i=n}for(let o of i){let c=o[pm];if(!c)continue;let l=fn.get(_a.DATABASES);l=l??{};let u=c?.tables?.[t]?.[Cf.PATH];if(u)return ZD.set(l,[pm,Cf.TABLES,t,Cf.PATH],u),fn.setProperty(_a.DATABASES,l),u;let f=c?.[Cf.PATH];if(f)return ZD.set(l,[pm,Cf.PATH],f),fn.setProperty(_a.DATABASES,l),f}}let s=r[_a.STORAGE_PATH.toUpperCase()];if(s){if(!XD.pathExistsSync(s))throw new Error(s+" does not exist");let i=vf.join(s,e);return XD.mkdirsSync(i),fn.setProperty(_a.STORAGE_PATH,s),i}return tL()}a(M4,"initSystemSchemaPaths");function v4(){Pf=void 0,Df=void 0,Lf=void 0}a(v4,"resetPaths");sL.exports={getBaseSchemaPath:eL,getSystemSchemaPath:tL,getTransactionAuditStorePath:L4,getTransactionAuditStoreBasePath:rL,getSchemaPath:nL,initSystemSchemaPaths:M4,resetPaths:v4}});var _n=w((sbe,lL)=>{"use strict";var U4=xn().LMDB_ERRORS_ENUM,rbe=require("lmdb"),x4=xt(),nbe=require("buffer").Buffer,{OVERFLOW_MARKER:iL,MAX_SEARCH_KEY_LENGTH:hm}=x4,oL=["number","string","symbol","boolean","bigint"];function B4(e){if(e=e?.primaryStore||e,!e)throw new Error(U4.ENV_REQUIRED)}a(B4,"validateEnv");function H4(e){if(e==null)return null;let t;try{t=typeof e=="object"?JSON.stringify(e):e.toString()}catch{t=e.toString()}return t}a(H4,"stringifyData");function k4(e){return e instanceof Date?e.valueOf():e}a(k4,"convertKeyValueToWrite");function F4(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(oL.includes(typeof e))return e.length>hm?[e.slice(0,hm)+iL]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(oL.includes(typeof i))i.length>hm?r.push(i.slice(0,hm)+iL):r.push(i);else{if(i===null&&t)return r.push(null);if(i instanceof Date)return r.push(i.getTime())}}}else if(e instanceof Date)return[e.getTime()];return r}a(F4,"getIndexedValues");var mm=0,aL=0;function cL(){aL=Date.now()-performance.now()}a(cL,"adjustStartTime");cL();var G4=6e4;setInterval(cL,G4).unref();function q4(){let e=performance.now()+aL;return e>mm?(mm=e,e):(mm+=488e-6,mm)}a(q4,"getNextMonotonicTime");lL.exports={validateEnv:B4,stringifyData:H4,convertKeyValueToWrite:k4,getNextMonotonicTime:q4,getIndexedValues:F4}});var Uf=w((obe,uL)=>{"use strict";var $4=(H(),C(G)).OPERATIONS_ENUM,cR=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=$4.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};uL.exports=cR});var xf=w((lbe,pL)=>{"use strict";var cbe=Uf(),Em=(H(),C(G)),lR=ie(),dL=z(),V4=require("uuid"),{handleHDBError:gm,hdb_errors:K4}=pe(),{HDB_ERROR_MSGS:Sm,HTTP_STATUS_CODES:Tm}=K4;pL.exports=fL;function fL(e,t,r){for(let s=0;s<t.length;s++)_L(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];Y4(i,r,e.operation)}}a(fL,"processRows");fL.validateAttribute=_L;function _L(e){if(Buffer.byteLength(String(e))>Em.INSERT_MAX_CHARACTER_SIZE)throw gm(new Error,Sm.ATTR_NAME_LENGTH_ERR(e),Tm.BAD_REQUEST,void 0,void 0,!0);if(lR.isEmptyOrZeroLength(e)||lR.isEmpty(e.trim()))throw gm(new Error,Sm.ATTR_NAME_NULLISH_ERR,Tm.BAD_REQUEST,void 0,void 0,!0)}a(_L,"validateAttribute");function Y4(e,t,r){if(!e.hasOwnProperty(t)||lR.isEmptyOrZeroLength(e[t])){if(r===Em.OPERATIONS_ENUM.INSERT||r===Em.OPERATIONS_ENUM.UPSERT){e[t]=V4.v4();return}throw dL.error("Update transaction aborted due to record with no hash value:",e),gm(new Error,Sm.RECORD_MISSING_HASH_ERR,Tm.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>Em.INSERT_MAX_CHARACTER_SIZE)throw dL.error(e),gm(new Error,Sm.HASH_VAL_LENGTH_ERR,Tm.BAD_REQUEST,void 0,void 0,!0)}a(Y4,"validateHash")});var hL,Bn,uR,pu=be(()=>{hL=require("events"),Bn=class extends hL.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new uR;return t.queue=this,t}push(t){this.send(t)}send(t){this.resolveNext?(this.resolveNext({value:t}),this.resolveNext=null):this.hasDataListeners?this.emit("data",t):(this.queue||(this.queue=[]),this.queue.push(t))}getNextMessage(){let t=this.queue?.shift();return t||this.emit("drained"),t}waitForDrain(){return new Promise(t=>{!this.queue||this.queue.length===0?t(!0):(this.once("drained",()=>t(!0)),this.currentDrainResolver=t,this.drainCloseListener||(this.drainCloseListener=!0,this.on("close",()=>{this.currentDrainResolver?.(!1)})))})}on(t,r){if(t==="data"&&!this.hasDataListeners)for(this.hasDataListeners=!0;this.queue?.length>0;)r(this.queue.shift());return super.on(t,r)}},uR=class{static{a(this,"EventQueueIterator")}queue;push(t){this.queue.send(t)}next(){let t=this.queue.getNextMessage();return t?{value:t}:new Promise(r=>this.queue.resolveNext=r)}return(t){return this.queue.emit("close"),{value:t,done:!0}}throw(t){return this.queue.emit("close",t),{done:!0}}}});function RL(e){fR=e}function J4(){j4=setInterval(function(){for(let e of dR)if(e.stale){let t=e.getContext()?.url;SL.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},z4).unref()}var _R,gL,SL,TL,AL,mL,dR,W4,Bf,EL,fR,wc,Am,z4,j4,Rm=be(()=>{_R=M(_n()),gL=M(pe()),SL=M(z()),TL=M(ae());H();AL=M(ie()),mL=100,dR=new Set,W4=(0,AL.convertToMS)(TL.get(x.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(RL,"replicationConfirmation");wc=class e{static{a(this,"DatabaseTransaction")}#e;writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxnsUsed=1,this.readTxn.openTimer&&(this.readTxn.openTimer=0),dR.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn?.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(dR.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(Bf&&!this.overloadChecked&&performance.now()-EL>W4)throw new gL.ServerError("Outstanding write transactions have too long of queue, please try again later",503);this.overloadChecked=!0}addWrite(t){if(this.open===0)throw new Error("Can not use a transaction that is no longer open");if(this.open===2){let r=new e;return r.addWrite(t),r.commit({})}else this.writes.push(t)}removeWrite(t){let r=this.writes.indexOf(t);r>-1&&(this.writes[r]=null)}commit(t={}){let r=this.timestamp;r||(r=this.timestamp=t.timestamp||(0,_R.getNextMonotonicTime)()),t.timestamp||(t.timestamp=r);let n=t.retries||0;if(this.validated<this.writes.length)try{let d=this.validated;this.validated=this.writes.length;for(let _=d;_<this.validated;_++)this.writes[_]?.validate?.(this.timestamp);let p;for(let _=d;_<this.validated;_++){let h=this.writes[_];h&&(h.before||h.beforeIntermediate)&&(p=!0)}if(p)return(async()=>{try{for(let _=0;_<2;_++){let h;for(let S=d;S<this.validated;S++){let g=this.writes[S];if(!g)continue;let R=g[_===0?"before":"beforeIntermediate"];if(R){let E=R();h?h.push?h.push(E):h=[h,E]:h=E}}h&&await(h.push?Promise.all(h):h)}}catch(_){throw this.abort(),_}return this.commit(t)})()}catch(d){throw this.abort(),d}n||this.doneReadTxn(),this.open=t?.doneWriting?2:1;let s,i=[],o=0;this.writes=this.writes.filter(d=>d);let c=a(d=>{d.commit(r,d.entry,n)},"doWrite"),l=a(()=>{let d=this.writes[o++];if(d)if(d.key){n>0&&(d.entry=d.store.getEntry(d.key));let p=d.store.ifVersion(d.key,d.entry?.version??null,l);s=s||p}else l();else for(let p of this.writes)c(p)},"nextCondition"),u=this.lmdbDb;if(this.writes.length>0&&(u?.retryRisk&&(u.retryRisk*=.99),this.writes.length+(u?.retryRisk||0)<mL>>n?l():s=this.writes[0].store.transaction(()=>{for(let d of this.writes)d.entry=d.store.getEntry(d.key),c(d);return!0})),s)return Bf||(Bf=s,EL=performance.now(),Bf.then(()=>{Bf=null})),s.then(d=>{if(d){if(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.replicatedConfirmation){let p=this.writes[0].store.rootStore.databaseName,_=this.writes[this.writes.length-1];fR&&_&&i.push(fR(p,_.store.getEntry(_.key).localTime,this.replicatedConfirmation))}return this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))}else return u&&(u.retryRisk=(u.retryRisk||0)+mL/2),t?t.retries=n+1:t={retries:1},this.commit(t)});let f={txnTime:r};if(this.next){let d=this.next?.commit(t);if(d?.then)return d?.then(p=>({txnTime:r,next:p}));f.next=d}return f}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}getContext(){return this.#e}setContext(t){this.#e=t}},Am=class extends wc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,_R.getNextMonotonicTime)())}getReadTxn(){}},z4=3e4;a(J4,"startMonitoringTxns");J4()});function wt(e,t,r){if(!t)t=e,e={};else if(!e)e={};else if(e?.transaction?.open===1&&typeof t=="function")return t(e.transaction);if(typeof t!="function")throw new Error("Callback function must be provided to transaction");let n=e.transaction=new wc;e.timestamp&&(n.timestamp=e.timestamp),e.replicatedConfirmation&&(n.replicatedConfirmation=e.replicatedConfirmation),n.setContext(e),e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({doneWriting:!0});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var yL,Ic=be(()=>{yL=M(Ti());Rm();a(wt,"transaction");(0,yL._assignPackageExport)("transaction",wt);wt.commit=function(e){let t=(e.getContext?.()||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};wt.abort=function(e){let t=(e.getContext?.()||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});function hR(e,t,r,n,s,i,o,c){let l=e[0];if(t==="or"){let d=u(l);for(let _=1;_<e.length;_++){let h=e[_],S=u(h);d=d.concat(S)}let p=new Set;return d.filter(_=>{let h=_.key??_;return p.has(h)?!1:(p.add(h),!0)})}else{let d=u(l),p=f(e.slice(1),!0,l.estimated_count);return p.length>0?o(d,p):d}function u(d){return d.conditions?hR(d.conditions,d.operator,r,n,s,i,o,c):Eu(d,n,d.descending||s.reverse===!0,r,s.allowFullScan,c)}a(u,"executeCondition");function f(d,p,_){return d.map((h,S)=>{if(h.conditions){let E=h.operator==="or",T=f(h.conditions,!E,_);return E?(b,v)=>T.some(F=>F(b,v)):(b,v)=>T.every(F=>F(b,v))}let g=(h.attribute||h[0])===r.primaryKey,R=Ff(h,r,i,c,g,_);return p&&S<d.length-1&&_&&(_=i3(r.primaryStore,h.estimated_count,_)),R}).filter(Boolean)}a(f,"mapConditionsToFilters")}function Eu(e,t,r,n,s,i){let o=e[0]??e.attribute,c=e[1]??e.value,l=e.comparator;if(c===void 0&&l!=="sort")throw new hn.ClientError(`Search condition for ${o} must have a value`);if(Array.isArray(o)){let E=o[0],T=bi(n.attributes,E);if(T.relationship){if(o.length<2)throw new hn.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let b=T.definition?.tableClass||T.elements?.definition?.tableClass,v=new Map,F=Eu({attribute:o.length>2?o.slice(1):o[1],value:c,comparator:l},t,r,b,s,v);if(T.relationship.to){i[o[0]]=v;let q=!!bi(b.attributes,T.relationship.to)?.elements;F=t3(F,T,b.primaryStore,q,v)}if(T.relationship.from){let q=a(Y=>(Y?.key!==void 0&&(Y=Y.key),Eu({attribute:T.relationship.from,value:Y},t,r,n,s,v)),"searchEntry");T.elements?(i[o[0]]=v,F=r3(F,T,b.primaryStore,v,q)):F=F.flatMap(q)}return F}else if(o.length===1)o=o[0];else throw new hn.ClientError("Unable to query by attribute "+JSON.stringify(o))}let u,f,d,p;c instanceof Date&&(c=c.getTime());let _;switch(mR[l]||l){case"lt":u=!0,f=c;break;case"le":u=!0,f=c,d=!0;break;case"gt":u=c,p=!0;break;case"ge":u=c;break;case"prefix":Array.isArray(c)?c[c.length-1]!=null&&(c=c.concat(null)):c=[c,null],u=c,f=c.slice(0),f[f.length-1]=yi.MAXIMUM_KEY;break;case"starts_with":u=c.toString(),f=c+"\uFFFF";break;case"between":case"gele":case"gelt":case"gtlt":case"gtle":u=c[0],u instanceof Date&&(u=u.getTime()),f=c[1],f instanceof Date&&(f=f.getTime()),d=l==="gele"||l==="gtle"||l==="between",p=l==="gtlt"||l==="gtle";break;case"equals":case void 0:u=c,f=c,d=!0;break;case"ne":if(c===null){u=c,p=!0;break}case"sort":case"contains":case"ends_with":u=!0,_=!0;break;default:throw new hn.ClientError(`Unknown query comparator "${l}"`)}let h,S=o===n.primaryKey||o==null;if(typeof u=="string"&&u.length>Es.MAX_SEARCH_KEY_LENGTH&&(u=u.slice(0,Es.MAX_SEARCH_KEY_LENGTH)+Es.OVERFLOW_MARKER,p=!1,h=Ff(e,n,null,i,S)),typeof f=="string"&&f.length>Es.MAX_SEARCH_KEY_LENGTH&&(f=f.slice(0,Es.MAX_SEARCH_KEY_LENGTH)+Es.OVERFLOW_MARKER,d=!0,h=h??Ff(e,n,null,i,S)),r){let E=u;u=f,f=E,E=!p,p=!d,d=E}let g=S?n.primaryStore:n.indices[o];if(!g||g.isIndexing||_||c===null&&!g.indexNulls){if(s===!1&&!g)throw new hn.ClientError(`"${o}" is not indexed, can not search for this attribute`,404);if(s===!1&&_)throw new hn.ClientError(`Can not use ${l||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${o}`,403);if(g?.isIndexing)throw new hn.ServerError(`"${o}" is not indexed yet, can not search for this attribute`,503);if(c===null&&g&&!g.indexNulls)throw new hn.ClientError(`"${o}" is not indexed for nulls, index needs to be rebuilt to search for nulls, can not search for this attribute`,400);if(h=h??Ff(e,n,null,i,S),!h)throw new hn.ClientError(`Unknown search operator ${e.comparator}`)}let R={start:u,end:f,inclusiveEnd:d,exclusiveStart:p,values:!0,versions:S,transaction:t,reverse:r};if(S){let E=g.getRange(R).map(h?function({key:T,value:b}){return this?.isSync?b&&h(b)?T:pa.SKIP:new Promise((v,F)=>setImmediate(()=>{try{v(b&&h(b)?T:pa.SKIP)}catch(q){F(q)}}))}:T=>T.value==null&&!(T.metadataFlags&(mn|ma))?pa.SKIP:T);return E.hasEntries=!0,E}else return g?g.getRange(R).map(h?function({key:E,value:T}){let b;return typeof E=="string"&&E.length>Es.MAX_SEARCH_KEY_LENGTH?b=n.primaryStore.get(T):b={[o]:E},this.isSync?h(b)?T:pa.SKIP:new Promise((v,F)=>setImmediate(()=>{try{v(h(b)?T:pa.SKIP)}catch(q){F(q)}}))}:({value:E})=>E):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:E,value:T}){return this.isSync?T&&h(T)?E:pa.SKIP:new Promise((b,v)=>setImmediate(()=>{try{b(T&&h(T)?E:pa.SKIP)}catch(F){v(F)}}))})}function bi(e,t){if(Array.isArray(t))if(t.length>1){let r=bi(e,t[0]),n=(r?.definition?.tableClass||r?.elements?.definition?.tableClass)?.attributes??r?.properties;return n?bi(n,t.slice(1)):void 0}else t=t.toString();else typeof t!="string"&&(t=t.toString());return e.find(r=>r.name===t)}function t3(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i;return s.hasMappings=!0,{next(){if(!i){let c=t.relationship.to,l=a((u,f)=>{let d=s.get(u);d?d.push(f):s.set(u,d=[f])},"add_entry");for(let u of e){let f=u.value??r.get(u.key??u),d=f?.[c];if(d!=null&&!s.filters?.some(p=>!p(f)))if(n)for(let p=0;p<d.length;p++)l(d[p],u);else l(d,u)}return i=s.keys()[Symbol.iterator](),this.next()}let o=i.next();return o.done?o:{value:o.value}},return(){if(i?.return)return i.return()}}}})}function r3(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i,o,c=new Set;return{next(){let l;if(o)for(;l=o.next(),!l.done;){let u=l.value;if(!c.has(u))return c.add(u),l}if(!i){let u=new Set;n.fromRecord=f=>f[t.relationship.from]?.filter?.(d=>u.has(d));for(let f of e){if(n.filters){let d=r.get(f);if(n.filters.some(p=>!p(d)))continue}u.add(f)}return i=u[Symbol.iterator](),this.next()}do{let u=i.next();return u.done?u:(o=s(u.value)[Symbol.iterator](),this.next())}while(!0)},return(){return o?.return?.()},throw(){return o?.throw?.()}}}})}function Ff(e,t,r,n,s,i){let o=e.comparator,c=e[0]??e.attribute,l=e[1]??e.value;if(Array.isArray(c)){if(c.length===0)return()=>!0;if(c.length===1)c=c[0];else if(c.length>1){let f=c[0],d=bi(t.attributes,f),p=d.definition?.tableClass||d.elements.definition?.tableClass,_=n?.[f],h=Ff({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:o},p,r,_?.[f]?.joined,c[1]===p.primaryKey,i);if(!h)return;if(_){_.filters||(_.filters=[]),_.filters.push(h);return}let S=t.propertyResolvers?.[f],g,R=a((E,T)=>{let b,v;if(S){if(S.from&&h.idFilter){if(!g)if(h.idFilter.idSet?.size===1){for(let q of h.idFilter.idSet)e={attribute:S.from,value:q};g=u(S.from,h.idFilter,!0,!0)}else g=u(S.from,h.idFilter,!1,!0);let F=g(E);return g.idFilter&&(R.idFilter=g.idFilter),F}v=S(E,r,T),b=v?.value}else b=E[f];return b?Array.isArray(b)?b.some(h):h(b,v):!1},"recordFilter");return R}}switch(l instanceof Date&&(l=l.getTime()),mR[o]||o){case Es.SEARCH_TYPES.EQUALS:case void 0:return u(c,f=>f===l,!0);case"contains":return u(c,f=>f?.toString().includes(l));case"ends_with":return u(c,f=>f?.toString().endsWith(l));case"starts_with":return u(c,f=>typeof f=="string"&&f.startsWith(l),!0);case"prefix":return Array.isArray(l)?l[l.length-1]==null&&(l=l.slice(0,-1)):l=[l],u(c,f=>{if(!Array.isArray(f))return!1;for(let d=0,p=l.length;d<p;d++)if(f[d]!==l[d])return!1;return!0},!0);case"between":return l[0]instanceof Date&&(l[0]=l[0].getTime()),l[1]instanceof Date&&(l[1]=l[1].getTime()),u(c,f=>(0,yi.compareKeys)(f,l[0])>=0&&(0,yi.compareKeys)(f,l[1])<=0,!0);case"gt":return u(c,f=>(0,yi.compareKeys)(f,l)>0);case"ge":return u(c,f=>(0,yi.compareKeys)(f,l)>=0);case"lt":return u(c,f=>(0,yi.compareKeys)(f,l)<0);case"le":return u(c,f=>(0,yi.compareKeys)(f,l)<=0);case"ne":return u(c,f=>(0,yi.compareKeys)(f,l)!==0,!1,!0);case"sort":return()=>!0;default:throw new hn.ClientError(`Unknown query comparator "${o}"`)}function u(f,d,p,_){let h;p=p&&!s&&t?.indices[f]&&i>3,p&&(e.estimated_count==null&&bm(t)(e),h=e.estimated_count>>4,(isNaN(h)||h>=i)&&(p=!1));let S=0,g=3;function R(E){let T=E[f],b;if(typeof T!="object"||!T||_?b=d(T):Array.isArray(T)?b=T.some(d):T instanceof Date&&(b=d(T.getTime())),p&&(g++,!b&&!R.idFilter&&++S/g*(i-g)>h)){let v=Eu(e,r.transaction.getReadTxn(),!1,t).map(gu),F=new Set(v);R.idFilter=q=>F.has(gu(q)),R.idFilter.idSet=F}return b}return a(R,"recordFilter"),s&&(R.idFilter=d),R}a(u,"attributeComparator")}function bm(e){function t(r){if(r.estimated_count===void 0){if(r.conditions){let s;if(r.operator==="or"){s=0;for(let i of r.conditions)t(i),s+=i.estimated_count}else{s=1/0;for(let i of r.conditions)t(i),s=isFinite(s)?s*i.estimated_count/so(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=mR[n]||n,n===Es.SEARCH_TYPES.EQUALS||!n){let s=r[0]??r.attribute;if(s==null||s===e.primaryKey)r.estimated_count=1;else if(Array.isArray(s)&&s.length>1){let i=bi(e.attributes,s[0]),o=i.definition?.tableClass||i.elements.definition?.tableClass,c=bm(o)({value:r.value,attribute:s.length>2?s.slice(1):s[1],comparator:"equals"}),l=e.indices[i.relationship.from];r.estimated_count=c+(l?c*so(e.indices[i.relationship.from])/(so(o.primaryStore)||1):c)}else{let i=e.indices[s];r.estimated_count=i?i.getValuesCount(r[1]??r.value):1/0}}else if(n==="contains"||n==="ends_with"||n==="ne"){let s=r[0]??r.attribute,i=e.indices[s];r.value===null&&n==="ne"?r.estimated_count=so(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else n==="starts_with"||n==="prefix"?r.estimated_count=Z4*so(e.primaryStore)+1:n==="between"?r.estimated_count=X4*so(e.primaryStore)+1:n==="sort"?r.estimated_count=so(e.primaryStore)+1:r.estimated_count=Q4*so(e.primaryStore)+1;typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return a(t,"estimateConditionForTable"),t}function Om(e){if(e)if(ha=e,hu.lastIndex=0,n3.test(e))try{let t=Hf(new mu,"");if(pn!==ha.length)throw new SyntaxError("Unable to parse query, unexpected end of query");return t}catch(t){throw t.statusCode=400,t.message=`Unable to parse query, ${t.message} at position ${pn} in '${ha}'`,t}else return new URLSearchParams(e)}function Hf(e,t){let r=hu,n,s,i,o,c,l=decodeURIComponent,u;for(;n=r.exec(ha);){pn=r.lastIndex;let[,f,d]=n;if(o){if(f)throw new SyntaxError(`expected operator, but encountered '${f}'`);o=!1,c=!1}else c=!0;let p;switch(d){case"=":if(s!=null){if(f.length<=2)i=f;else throw new SyntaxError(`invalid FIQL operator ${f}`);l=bL}else{if(l=decodeURIComponent,i="equals",!f)throw new SyntaxError("attribute must be specified before equality comparator");s=kf(f)}break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":if(i=e3[d],l=pR[i]?bL:decodeURIComponent,!f)throw new SyntaxError(`attribute must be specified before comparator ${d}`);s=kf(f);break;case"&=":case"|=":case"|":case"&":case"":case void 0:if(s==null){if(s===void 0)throw t?new SyntaxError(`expected '${t}', but encountered ${d[0]?"'"+d[0]+"'":"end of string"}}`):new SyntaxError(`no comparison specified before ${d?"'"+d+"'":"end of string"}`)}else{if(!e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");let h={comparator:i,attribute:s||null,value:l(f)};if(i==="eq"&&OL(h,f),s===""){let S=e.conditions[e.conditions.length-1];S.chainedConditions=S.chainedConditions||[],S.chainedConditions.push(h),S.operator=u}else ym(e,u),e.conditions.push(h)}d==="&"?(u="and",s=void 0):d==="|"?(u="or",s=void 0):d==="&="?(u="and",s=""):d==="|="&&(u="or",s="");break;case",":if(e.conditions)throw new SyntaxError("conditions/comparisons are not allowed in a property list");e.push(kf(f)),s=void 0;break;case"(":hu.lastIndex=pn;let _=Hf(f?[]:new mu,")");switch(f){case"":ym(e,u),e.conditions.push(_);break;case"limit":switch(_.length){case 1:e.limit=+_[0];break;case 2:e.offset=+_[0],e.limit=_[1]-e.offset;break;default:throw new SyntaxError("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(_[0])&&_.length===1&&!_[0].name?(e.select=_[0],e.select.asArray=!0):_.length===1?e.select=_[0]:_.length===2&&_[1]===""?e.select=_.slice(0,1):e.select=_;break;case"group-by":throw new SyntaxError("group by is not implemented yet");case"sort":e.sort=NL(_);break;default:throw new SyntaxError(`unknown query function call ${f}`)}ha[pn]===","?r.lastIndex=++pn:o=!0,s=null;break;case"{":if(e.conditions)throw new SyntaxError("property sets are not allowed in a queries");if(!f)throw new SyntaxError("property sets must have a defined parent property name");hu.lastIndex=pn,p=Hf([],"}"),p.name=f,e.push(p),ha[pn]===","?r.lastIndex=++pn:o=!0;break;case"[":hu.lastIndex=pn,f?(p=Hf(new mu,"]"),p.name=f):p=Hf(e.conditions?new mu:[],"]"),e.conditions?(ym(e,u),e.conditions.push(p),s=null):e.push(p),ha[pn]===","?r.lastIndex=++pn:o=!0;break;case")":case"]":case"}":if(t===d[0]){if(e.conditions){if(s){let h={comparator:i||"equals",attribute:s,value:l(f)};i==="eq"&&OL(h,f),ym(e,u),e.conditions.push(h)}else if(f)throw new SyntaxError("no attribute or comparison specified")}else(f||e.length>0&&c)&&e.push(kf(f));return e}else throw t?new SyntaxError(`expected '${t}', but encountered '${d[0]}'`):new SyntaxError(`unexpected token '${d[0]}'`);default:throw new SyntaxError(`unexpected operator '${d}'`)}if(t!==")"&&(r=s?s3:hu,r.lastIndex=pn),pn===ha.length)return e}if(t)throw new SyntaxError(`expected '${t}', but encountered end of string`)}function ym(e,t){if(e.conditions.length>0)if(e.operator){if(e.operator!==t)throw new SyntaxError("Can not mix operators within a condition grouping")}else e.operator=t}function kf(e){return e.indexOf(".")>-1?e.split(".").map(kf):decodeURIComponent(e)}function bL(e){if(e==="null")return null;if(e.indexOf(":")>-1){let[t,r]=e.split(":");if(t==="number")return r[0]==="$"?parseInt(r.slice(1),36):+r;if(t==="boolean")return r==="true";if(t==="date")return new Date(isNaN(r)?decodeURIComponent(r):+r);if(t==="string")return decodeURIComponent(r);throw new hn.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function OL(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new hn.ClientError("wildcard can only be used at the end of a string")}function NL(e){let t=wL(e[0]);return e.length>1&&(t.next=NL(e.slice(1))),t}function wL(e){if(Array.isArray(e)){let t=wL(e[0]);return e[0]=t.attribute,t.attribute=e,t}if(typeof e=="string")switch(e[0]){case"-":return{attribute:e.slice(1),descending:!0};case"+":return{attribute:e.slice(1),descending:!1};default:return{attribute:e,descending:!1}}throw new SyntaxError(`Unknown sort type ${e}`)}function gu(e){return Array.isArray(e)?e.join("\0"):e}function so(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function i3(e,t,r){return t*r/so(e)}var hn,Es,yi,pa,Q4,X4,Z4,e3,pR,mR,n3,hu,s3,pn,ha,mu,Cc,Gf=be(()=>{hn=M(pe()),Es=M(xt()),yi=require("ordered-binary"),pa=require("lmdb");qf();Q4=.3,X4=.1,Z4=.05,e3={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},pR={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};a(hR,"executeConditions");a(Eu,"searchByIndex");a(bi,"findAttribute");a(t3,"joinTo");a(r3,"joinFrom");mR={eq:"equals",greater_than:"gt",greaterThan:"gt",greater_than_equal:"ge",greaterThanEqual:"ge",less_than:"lt",lessThan:"lt",less_than_equal:"le",lessThanEqual:"le",not_equal:"ne",notEqual:"ne",equal:"equals",sw:"starts_with",startsWith:"starts_with",ew:"ends_with",endsWith:"ends_with",ct:"contains",">":"gt",">=":"ge","<":"lt","<=":"le","...":"between"};a(Ff,"filterByType");a(bm,"estimateCondition");n3=/[()[\]|!<>.]|(=\w*=)/,hu=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,s3=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;a(Om,"parseQuery");a(Hf,"parseBlock");a(ym,"assignOperator");a(kf,"decodeProperty");a(bL,"typedDecoding");a(OL,"wildcardDecoding");a(NL,"toSortObject");a(wL,"toSortEntry");mu=class{static{a(this,"Query")}constructor(){this.conditions=[]}[Symbol.iterator](){return this.conditions[Symbol.iterator]()}get(t){for(let r=0;r<this.conditions.length;r++){let n=this.conditions[r];if(n.attribute===t)return n.value}}};a(gu,"flattenKey");a(so,"estimatedEntryCount");a(i3,"intersectionEstimate");Cc=class{constructor(t){this.url=t}static{a(this,"SimpleURLQuery")}get(){}[Symbol.iterator](){return[][Symbol.iterator]()}}});var gR={};ve(gR,{MultiPartId:()=>wm,Resource:()=>$r,snake_case:()=>a3,transformForSelect:()=>Im});function a3(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function IL(e,t){if(Pc=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(Pc=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new wm;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Pc=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return Pc=!0,null;e[e.length-1]==="/"&&(Pc=!0)}return t.coerceId(decodeURIComponent(e))}function Hn(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,l,u,f;if(r?(o?(f=i,o=o.getContext?.()||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(f=s,c=f[this.primaryKey]??null,o=i.getContext?.()||i):f=i:(f=s,s=void 0,c=f.getId?.()??f[this.primaryKey]),c===null&&(u=!0)):i?o=i.getContext?.()||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="object"&&s){if(l=s,typeof(c=s.url)=="string")if(this.directURLMapping)c=c.slice(1);else{let _=c.indexOf("?");if(_>-1){let S=this.parseQuery(c.slice(_+1));l?S&&(l=Object.assign(S,l)):l=S,c=c.slice(0,_)}let h=this.parsePath(c,o,l);h?.id!==void 0?(h.query&&(l?l=Object.assign(h.query,l):l=h.query),u=h.isCollection,c=h.id):c=h}else if(s[Symbol.iterator]){c=[],u=!0;for(let _ of s){if(typeof _=="object"&&_)break;c.push(_)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=null,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new Cc(c),c==null&&(u=!0);o||(o={});let d;if(l?.ensureLoaded!=null||l?.async||u?(d={...t},l?.ensureLoaded!=null&&(d.ensureLoaded=l.ensureLoaded),l?.async&&(d.async=l.async),u&&(d.isCollection=!0)):d=t,o.transaction){let _=this.getResource(c,o,d);return _.then?_.then(p):p(_)}else return wt(o,()=>{let _=this.getResource(c,o,d);return _.then?_.then(p):p(_)},d);function p(_){if(o.authorize){o.authorize=!1;let h=t.type==="read"?_.allowRead(o.user,l,o):t.type==="update"?_.doesExist?.()===!1?_.allowCreate(o.user,f,o):_.allowUpdate(o.user,f,o):t.type==="create"?_.allowCreate(o.user,f,o):_.allowDelete(o.user,l,o);if(h?.then)return h.then(S=>{if(!S)throw new Nm(o.user);return typeof f?.then=="function"?f.then(g=>e(_,l,o,g)):e(_,l,o,f)});if(!h)throw new Nm(o.user)}return typeof f?.then=="function"?f.then(h=>e(_,l,o,h)):e(_,l,o,f)}a(p,"authorizeActionOnResource")}}function kn(e,t){let r=new DL.ClientError(`The ${e.constructor.name} does not have a ${t} method implemented`,405);r.allow=[],r.method=t;for(let n of["get","put","post","delete","query","move","copy"])typeof e[n]=="function"&&r.allow.push(n);throw r}function ER(e,t,r){let n=e.getRecord?.();if(n){let s=e.getChanges?.();return i=>{let o,c;return e.hasOwnProperty(i)&&typeof(o=e[i])!="function"?o:s&&i in s?s[i]:(c=t?.[i])?c(e,r):n[i]}}else return t?s=>{let i=t[s];return i?i(e,r):e[s]}:s=>e[s]}function Im(e,t){let r=t.propertyResolvers,n=t.getContext?.(),s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):ER(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(c);let u=[],f=i(ER(l,r,n));for(let d of e)u.push(f(d));return u},"transform");let o=e.forceNulls;return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(p=>p&&typeof p=="object"?c(p):p);let u={},f=i(ER(l,r,n)),d;for(let p of e){let _=f(p);_===void 0&&o&&(_=null),_?.then?(d||(d=[]),d.push(_.then(h=>u[p.name||p]=h))):u[p.name||p]=_}return d?Promise.all(d).then(()=>u):u},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(o){return c=>{if(typeof c=="string")return o(c);if(typeof c=="object")if(c.name){s||(s={});let l=s[c.name];if(!l){let f=r[c.name]?.definition?.tableClass;l=s[c.name]=Im(c.select||c,f)}let u=o(c.name);return l(u)}else return o(c);else return c}}a(i,"handleProperty")}var CL,PL,DL,o3,$r,Nm,Pc,wm,Ea=be(()=>{CL=require("crypto");pu();PL=M(Ti()),DL=M(pe());Ic();Gf();o3={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},$r=class{static{a(this,"Resource")}#e;#t;#n;static transactions;static directURLMapping=!1;constructor(t,r){this.#e=t;let n=r?.getContext?r.getContext()??null:void 0;this.#t=n!==void 0?n:r||null}static get=Hn(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let l;if((l=r?.select)&&c!=null&&!c.selectApplied){let u=Im(l,t.constructor);return typeof c?.map=="function"?c.map(u):u(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=Hn(function(t,r,n,s){if(Array.isArray(s)&&t.#n){let i=[],o=n.authorize;for(let c of s){let l=t.constructor,u=l.getResource(c[l.primaryKey],n,{async:!0});u.then?i.push(u.then(f=>f.put(c,n))):i.push(u.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):kn(t,"put")},{hasContent:!0,type:"update"});static patch=Hn(function(t,r,n,s){return t.patch?t.patch(s,r):kn(t,"patch")},{hasContent:!0,type:"update"});static delete=Hn(function(t,r,n,s){return t.delete?t.delete(r):kn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,CL.randomUUID)()}static create(t,r,n){let s;return t==null?s=r?.[this.primaryKey]??this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=r?.[this.primaryKey]??[...t,this.getNewId()]:typeof t!="object"?s=r?.[this.primaryKey]??[t,this.getNewId()]:(s=t?.[this.primaryKey]??this.getNewId(),n=r||{},r=t),n||(n={}),wt(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):kn(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=Hn(function(t,r,n,s){return t.invalidate?t.invalidate(r):kn(t,"delete")},{hasContent:!1,type:"update"});static post=Hn(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=Hn(function(t,r,n,s){return t.connect?t.connect(s,r):kn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=Hn(function(t,r,n,s){return t.subscribe?t.subscribe(r):kn(t,"subscribe")},{type:"read"});static publish=Hn(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.publish?t.publish(s,r):kn(t,"publish")},{hasContent:!0,type:"create"});static search=Hn(function(t,r,n,s){let i=t.search?t.search(r):kn(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=Im(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=Hn(function(t,r,n,s){return t.search?t.search(s,r):kn(t,"search")},{hasContent:!0,type:"read"});static copy=Hn(function(t,r,n,s){return t.copy?t.copy(s,r):kn(t,"copy")},{hasContent:!0,type:"create"});static move=Hn(function(t,r,n,s){return t.move?t.move(s,r):kn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this.#n)return(await this.constructor.create(this.#e,t,this.#t)).#e;kn(this,"post")}static isCollection(t){return t&&t.#n}get isCollection(){return this.#n}static coerceId(t){return t}static parseQuery(t){return Om(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1),c=r?.headers&&o3[o];if(c)r.requestedContentType=c,t=t.slice(0,s);else if(this.attributes?.find(l=>l.name===o))if(t=t.slice(0,s),n)n.property=o;else return{query:{property:o},id:IL(t,this),isCollection:Pc}}let i=IL(t,this);return Pc?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r.getContext?.(),o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let u=l.asMap.get(t);if(s=u?.find(f=>f.constructor===c),s)return s;u||l.asMap.set(t,u=[]),u.push(s=new c(t,i))}else{if(s=l.find(u=>u.#e===t&&u.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let u=new Map;for(let f of l){let d=f.#e,p=u.get(d);p?p.push(f):u.set(d,[f])}i.resourceCache.length=0,i.resourceCache.asMap=u}}}else s=new c(t,i);return o&&(s.#n=!0),s}subscribe(t){return new Bn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new Bn}allowRead(t){return t?.role.permission.super_user}allowUpdate(t){return t?.role.permission.super_user}allowCreate(t){return t?.role.permission.super_user}allowDelete(t){return t?.role.permission.super_user}getId(){return this.#e}getContext(){return this.#t}};(0,PL._assignPackageExport)("Resource",$r);a(a3,"snake_case");Nm=class extends Error{static{a(this,"AccessError")}constructor(t){t?(super("Unauthorized access to resource"),this.statusCode=403):(super("Must login"),this.statusCode=401)}};a(IL,"pathToId");wm=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(Hn,"transactional");a(kn,"missingMethod");a(ER,"selectFromObject");a(Im,"transformForSelect")});var ga,SR=be(()=>{ga=class{constructor(t){this.error=t}static{a(this,"ErrorResource")}isError=!0;allowRead(){throw this.error}allowUpdate(){throw this.error}allowCreate(){throw this.error}allowDelete(){throw this.error}getId(){throw this.error}getContext(){throw this.error}get(){throw this.error}post(){throw this.error}put(){throw this.error}delete(){throw this.error}connect(){throw this.error}getResource(){return this}publish(){throw this.error}subscribe(){throw this.error}}});var vL={};ve(vL,{Resources:()=>Cm,keyArrayToString:()=>Su,resetResources:()=>c3,resources:()=>Oi});function c3(){return Oi=new Cm}function Su(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var LL,ML,Cm,Oi,Tu=be(()=>{Ic();SR();LL=M(z()),ML=M(pe()),Cm=class extends Map{static{a(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,exportTypes:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s){let c=new ML.ServerError(`Conflicting paths for ${t}`);LL.default.error(c),i.Resource=new ga(c)}super.set(t,i);for(let[c,l]of this){let u=2;for(;(u=c.indexOf("/",u))>-1;){let f=this.get(c.slice(0,u));f&&(f.hasSubPaths=!0),u+=2}}}getMatch(t,r){let n=2,s=0,i,o=t.length;for(;n<o;){s=n,n=t.indexOf("/",n),n===-1&&(n=o);let u=n===o?t:t.slice(0,n),f=this.get(u),d=-1;if(!f&&n===o&&(d=u.indexOf("?",s),d!==-1)){let p=u.slice(0,d);f=this.get(p)}if(f&&(!r||f.exportTypes?.[r]!==!1)){if(f.relativeURL=t.slice(d!==-1?d:n),!f.hasSubPaths)return f;i=f}n+=2}if(i)return i;let c=t.indexOf("?"),l=c>-1?t.slice(0,c):t;return i=this.get(l),!i&&l.indexOf(".")>-1&&(i=this.get(l.split(".")[0])),i&&(!r||i.exportTypes?.[r]!==!1)?i.relativeURL=c>-1?t.slice(c):"":i||(i=this.get(""),i&&(!r||i.exportTypes?.[r]!==!1)&&(t.charAt(0)!=="/"&&(t="/"+t),i.relativeURL=t)),i}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return wt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(c3,"resetResources");a(Su,"keyArrayToString")});var Au={};ve(Au,{server:()=>We});var UL,We,Vr=be(()=>{UL=M(Ti()),We={};(0,UL._assignPackageExport)("server",We)});var RR={};ve(RR,{loadGQLSchema:()=>d3,start:()=>AR,startOnMainThread:()=>u3});function AR({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:u,StringValueNode:f}=await import("graphql"),d=o(new c(r.toString(),s)),p=new Map,_=[],h;for(let R of d.definitions)switch(R.kind){case l.OBJECT_TYPE_DEFINITION:let F=function(Y){if(Y.kind==="NonNullType"){let Q=F(Y.type);return Q.nullable=!1,Q}if(Y.kind==="ListType")return{type:"array",elements:F(Y.type)};let se={type:Y.name?.value};return Object.defineProperty(se,"location",{value:Y.loc.startToken}),se};a(F,"getProperty");let E=R.name.value,T=[],b={table:null,database:null,properties:T};p.set(E,b);for(let Y of R.directives){if(Y.name.value==="table"){for(let se of Y.arguments)b[se.name.value]=se.value.value;b.schema&&(b.database=b.schema),b.table||(b.table=E),b.audit&&(b.audit=b.audit!=="false"),b.attributes=b.properties,_.push(b)}if(Y.name.value==="sealed"&&(b.sealed=!0),Y.name.value==="splitSegments"&&(b.splitSegments=!0),Y.name.value==="replicate"&&(b.replicate=!0),Y.name.value==="export"){b.export=!0;for(let se of Y.arguments)typeof b.export!="object"&&(b.export={}),b.export[se.name.value]=se.value.value}}let v=!1,q={};for(let Y of R.fields){let Z=F(Y.type);Z.name=Y.name.value,T.push(Z),q[Z.name]=void 0;for(let se of Y.directives){let Q=se.name.value;if(Q==="primaryKey")v?console.warn("Can not define two attributes as a primary key at",se.loc):(Z.isPrimaryKey=!0,v=!0);else if(Q==="indexed")Z.indexed=!0;else if(Q==="computed"){for(let ne of se.arguments||[])if(ne.name.value==="from"){let J=ne.value.value;Z.computed={from:g(J,ne,q)},Z.version==null&&(Z.version=J)}else ne.name.value==="version"&&(Z.version=ne.value.value);Z.computed=Z.computed||!0}else if(Q==="relationship"){let ne={};for(let J of se.arguments)ne[J.name.value]=J.value.value;Z.relationship=ne}else if(Q==="createdTime")Z.assignCreatedTime=!0;else if(Q==="updatedTime")Z.assignUpdatedTime=!0;else if(Q==="expiresAt")Z.expiresAt=!0;else if(Q==="allow"){let ne=Z.authorizedRoles=[];for(let J of se.arguments)J.name.value==="role"&&ne.push(J.value.value)}else server.knownGraphQLDirectives.includes(Q)&&console.warn(`@${Q} is an unknown directive, at`,se.loc)}}b.type=E,E==="Query"&&(h=b)}function S(R){let E=p.get(R.type);E?(Object.defineProperty(R,"properties",{value:E.properties}),Object.defineProperty(R,"definition",{value:E})):R.type==="array"?S(R.elements):l3.includes(R.type)||(0,BL.getWorkerIndex)()===0&&console.error(`The type ${R.type} is unknown at line ${R.location.line}, column ${R.location.column}, in ${s}`)}a(S,"connectPropertyType");for(let R of p.values())for(let E of R.properties)S(E);for(let R of _)R.tableClass=e(R),R.export&&(R.export.name===""?i.set((0,TR.dirname)(n),R.tableClass):i.set((0,TR.dirname)(n)+"/"+(R.export.name||R.type),R.tableClass,R.export));function g(R,E,T){return new xL.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${R}; } } } } computed;`,{filename:s,lineOffset:E.loc.startToken.line-1,columnOffset:E.loc.startToken.column}).runInThisContext()(T)}a(g,"createComputedFrom")}}var TR,xL,BL,l3,u3,d3,HL=be(()=>{TR=require("path"),xL=require("node:vm");De();BL=M(rt()),l3=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt","Blob"];server.knownGraphQLDirectives&&(server.knownGraphQLDirectives=["table","sealed","export","primaryKey","indexed","computed","relationship","createdTime","updatedTime","expiresAt","allow"]);a(AR,"start");u3=AR,d3=AR({ensureTable:ft}).handleFile});var KL={};ve(KL,{parse:()=>bR,streamAsJSON:()=>$f,stringify:()=>Dc});function $f(e){return new yR({value:e})}function kL(e){return console.error(e),JSON.stringify(e.toString())}function FL(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Dc(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===$L)return VL(e);if(t.resolution)return t.resolution.then(()=>Dc(e));throw t}}function VL(e){let t=typeof e;if(t==="object"){if(e===null)return"null";e.toJSON&&(e=e.toJSON());let r;if(Array.isArray(e)){r="[";for(let n=0;n<e.length;n++)n>0&&(r+=","),r+=VL(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Dc(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function bR(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),p3.test(e)?f3.parse(e):JSON.parse(e)):null}var GL,qL,f3,_3,$L,yR,p3,OR=be(()=>{GL=require("stream"),qL=M(require("json-bigint-fixes")),f3=(0,qL.default)({useNativeBigInt:!0}),_3=1e4,$L={message:"Cannot serialize BigInt to JSON"};BigInt.prototype.toJSON=function(){throw $L};a($f,"streamAsJSON");yR=class extends GL.Readable{static{a(this,"JSONStream")}constructor(t){super(t),this.buffer=[],this.bufferSize=0,this.iterator=this.serialize(t.value,!0),this.activeIterators=[]}*serialize(t){if(t&&typeof t=="object"){let r=t[Symbol.asyncIterator],n=t[Symbol.iterator];if((n||r)&&!t.then){yield"[";let s=!0;if((r||n)&&!(t instanceof Array)){let i=r?t[Symbol.asyncIterator]():t[Symbol.iterator]();this.activeIterators.push(i);let o;for(;;){try{o=i.next(),o.then&&(yield o.then(c=>(o=c,""),c=>(o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")},"")))}catch(c){o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")}}if(o.done){this.activeIterators.splice(this.activeIterators.indexOf(i),1),yield"]";return}else s?s=!1:yield",",yield*this.serialize(o.value)}}for(let i of t)s?s=!1:yield",",yield*this.serialize(i);yield"]";return}if(t.then)try{yield t.then(s=>this.serialize(s),kL)}catch(s){yield kL(s)}else yield Dc(t)}else yield Dc(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);FL(this.readIterator(this.iterator),t=>{t?(this.done=!0,this.push(null)):this._amReading=!1},t=>{console.error(t),this.done=!0,this.push(t.toString()),this.push(null)})}}push(t){return t===null||t instanceof Buffer?(this.bufferSize>0&&this.flush(),super.push(t)):(this.bufferSize+=t.length||t.toString().length,this.buffer.push(t),this.bufferSize>_3?this.flush():!0)}flush(){let t=super.push(this.buffer.join(""));return this.buffer=[],this.bufferSize=0,t}readIterator(t){try{let r;if(t.childIterator)return FL(this.readIterator(t.childIterator),n=>{if(n)return t.childIterator=null,this.readIterator(t)});do{let n=t.next();if(n.done)return!0;if(r=n.value,r==null)r="null";else{if(r.then)return this.flush(),Promise.resolve(r).then(s=>{if(s&&typeof s.return=="function")return t.childIterator=s,this.readIterator(t);if(this.push(s+""))return this.readIterator(t)});if(typeof r.return=="function")return t.childIterator=r,this.readIterator(t)}}while(this.push(r))}catch(r){return console.error(r),this.push(r.toString()),this.push(null),!0}}_destroy(t,r){for(let n of this.activeIterators)t?n.throw(t):n.return();r()}};a(kL,"handleError");a(FL,"when");a(Dc,"stringify");a(VL,"jsStringify");p3=/[[,:]\s*-?\d{16,}/;a(bR,"parse")});var Ni=w(Dm=>{var Pm=z();for(let e of["trace","debug","info","warn","error","fatal","notify"])Pm.logsAtLevel(e)&&(Dm[e]=Pm[e]);Dm.loggerWithTag=e=>Pm.loggerWithTag(e,!0);Dm.setLogLevel=Pm.setLogLevel});var Gm={};ve(Gm,{Blob:()=>wi,blobsWereEncoded:()=>Mc,databasePaths:()=>vm,decodeBlobsWithWrites:()=>CR,decodeFromDatabase:()=>vc,decodeWithBlobCallback:()=>PR,deleteBlob:()=>eM,deleteBlobsInObject:()=>Ta,deleteRootBlobPathsForDB:()=>IR,encodeBlobsAsBuffers:()=>b3,encodeBlobsWithFilePath:()=>Fm,findBlobsInObject:()=>yu,getFileId:()=>Hm,getFilePathForBlob:()=>rM,getRootBlobPathsForDB:()=>km,setDeletionDelay:()=>g3});function XL(){}function eM(e){let t=rM(e);t&&setTimeout(()=>{(0,Je.unlink)(t,r=>{r&&Sa.default.debug?.("Error trying to remove blob file",r)})},ZL)}function g3(e){ZL=e}function tM(e){let t=En.get(e);if(!t)t={storageIndex:0,fileId:null,store:js},En.set(e,t);else{if(t.saving)return t;t.store=js}return T3(t),t.source?NR(e,t.source,t):t.contentBuffer?S3(e,t):NR(e,Kf.Readable.from(e.stream()),t),t}function NR(e,t,r){let{filePath:n,fileId:s,store:i,compress:o,flush:c}=r;return r.saving=new Promise((l,u)=>{let f=s+":blob";if(!i.attemptLock(f,0))throw new Error(`Unable to get lock for blob file ${s}`);let d=(0,Je.createWriteStream)(n,{autoClose:!1,flags:"w"});if(t.errored){let g=Buffer.from(t.errored.toString());d.end(Buffer.concat([h(BigInt(g.length)+0xff000000000000n),g]));return}let p=!1;e.size!==void 0&&(d.write(h(e.size)),p=!0);let _;o?(p||d.write(m3),_=(0,xm.createDeflate)(),t.pipe(_).pipe(d)):(p||d.write(h3),t.pipe(d)),t.on("error",S);function h(g){let R=BigInt(g),E=new Uint8Array(gr),T=new DataView(E.buffer);return R|=BigInt(o?wR:QL)<<48n,T.setBigInt64(0,R),E}a(h,"createHeader");function S(g){i.unlock(f,0);let R=d.fd;g?(R&&(0,Je.close)(R),u(g)):c?(0,Je.fdatasync)(R,E=>{E&&u(E),l(),(0,Je.close)(R)}):(l(),(0,Je.close)(R))}a(S,"finished"),d.on("error",S).on("finish",()=>{if(p)S();else{let g=_?_.bytesWritten:d.bytesWritten-gr;e.size=g,(0,Je.write)(d.fd,h(g),0,gr,0,S)}})}),e}function Hm(e){return En.get(e)?.fileId}function rM(e){let t=En.get(e);return t?.fileId&&Yf(t)}function km(e){if(!e)throw new Error("No store specified, can not determine blob storage path");let t=vm.get(e);if(!t){if(!e.databaseName)throw new Error("No database name specified, can not determine blob storage path");let r=(0,Bm.get)(x.STORAGE_BLOBPATHS);r?t=r.map(n=>(0,oo.join)(n,e.databaseName)):t=[(0,oo.join)((0,Bm.getHdbBasePath)(),"blobs",e.databaseName)],vm.set(e,t)}return t}async function IR(e){let t=vm.get(e);t&&await Promise.all(t.map(r=>nM(r)))}async function nM(e){for(let t of await(0,Js.readdir)(e,{withFileTypes:!0}))if(t.isDirectory())await nM((0,oo.join)(e,t.name));else try{await(0,Js.unlink)((0,oo.join)(e,t.name))}catch(r){Sa.default.warn?.("Error deleting file",r)}try{await(0,Js.rmdir)(e)}catch(t){Sa.default.warn?.("Error deleting directory",t)}}function Yf({storageIndex:e,fileId:t,store:r}){let n=km(r);return(0,oo.join)(n[e],t.slice(-9,-6)||"0",t.slice(-6,-3)||"0",t.length<=9?t.slice(-3):t.slice(0,-9)+t.slice(-3))}function S3(e,t){let r=t.contentBuffer,n=r.length;if(!(n<JL))return e.size=n,NR(e,Kf.Readable.from([r]),t)}function T3(e){let t=km(e.store),r=A3(),n=t?.length>1?R3(t,r):0,s=r.toString(16);e.storageIndex=n,e.fileId=s;let i=Yf(e),o=(0,oo.dirname)(i);(0,Je.existsSync)(o)||(0,jL.ensureDirSync)(o),e.filePath=i}function A3(){let e=zL.get(js);if(!e){let t=0,r=km(js);for(let n of r){let s=0;for(let i=0;i<3;i++){s=s*4096;let o=0;if((0,Je.existsSync)(n))for(let c of(0,Je.readdirSync)(n)){let l=parseInt(c,16);i===2&&c.length>3&&(l=parseInt(c.slice(-3),16),l+=parseInt(c.slice(0,-3),16)*68719476736),l>o&&(o=l)}s+=o,n=(0,oo.join)(n,o.toString(16))}t=Math.max(t,s)}e=new BigInt64Array([BigInt(t)+1n]),e=new BigInt64Array(js.getUserSharedBuffer("blob-file-id",e.buffer)),zL.set(js,e)}return Number(Atomics.add(e,0,1n))}function R3(e,t){let r=Date.now();if(!e.frequencyTable){e.lastUpdated=0;let s=new Array(Um);for(let i=0;i<s.length;i++)s[i]=i%e.length;e.frequencyTable=s}return(e.lastUpdated??0)+6e4<r&&(e.lastUpdated=r,y3(e)),e.frequencyTable[t%Um]}async function y3(e){if(!Js.statfs)return;let t=await Promise.all(e.map(async(s,i)=>{let o=await(0,Js.statfs)(s),c=o.bavail*o.bsize;return Math.pow(c,.8)})),r=new Array(Um),n=t.map(s=>1/s);for(let s=0;s<Um;s++){let i=1/0,o=0;for(let c=0;c<n.length;c++)n[c]<i&&(o=c,i=n[c]);n[o]+=1/t[o],r[s]=o}e.frequencyTable=r}function Fm(e,t,r){Ru=t,js=r,Mc=!1;try{return e()}finally{Ru=void 0,js=void 0}}function b3(e){Dr=[];let t;try{t=e()}catch(n){throw Dr=void 0,n}let r=Dr.length<2?Dr[0]:Promise.all(Dr);return Dr=void 0,r?r.then(()=>e()):t}function CR(e,t){try{Dr=[],Lc=t,e()}catch(n){throw Lc=void 0,Dr=void 0,n}Lc=void 0;let r=Dr.length<2?Dr[0]:Promise.all(Dr);return Dr=void 0,r}function PR(e,t){try{return Lc=t,e()}finally{Lc=void 0}}function vc(e,t){return js=t,e()}function Ta(e){yu(e,t=>{eM(t)})}function yu(e,t){if(e instanceof wi)t(e);else if(Array.isArray(e))for(let r of e)typeof r=="object"&&r&&yu(r,t);else if(e.constructor===Object)for(let r in e){let n=e[r];typeof n=="object"&&n&&yu(e[r],t)}}function O3(){return class{static{a(this,"Blob")}content;constructor(t){this.content=t[0]}stream(){return new ReadableStream({start(t){t.enqueue(this.content),t.close()}})}text(){return Promise.resolve(this.content.toString())}arrayBuffer(){return Promise.resolve(this.content.buffer)}get size(){return this.content.length}slice(){throw new Error("Not implemented")}bytes(){return Promise.resolve(this.content)}get type(){return""}}}var io,Js,Je,xm,Kf,jL,Bm,oo,Sa,JL,gr,QL,wR,YL,h3,m3,WL,En,Lc,wi,Ru,Dr,js,Mc,Vf,Lm,E3,Mm,ZL,vm,zL,Um,gs=be(()=>{io=require("msgpackr"),Js=require("node:fs/promises"),Je=require("node:fs"),xm=require("node:zlib"),Kf=require("node:stream"),jL=require("fs-extra"),Bm=M(ae());H();oo=require("path"),Sa=M(Ni());ao();JL=8192,gr=8,QL=0,wR=1,YL=255,h3=new Uint8Array([0,QL,255,255,255,255,255,255]),m3=new Uint8Array([0,wR,255,255,255,255,255,255]),WL=0xffffffffffff,En=new WeakMap,wi=global.Blob||O3(),Mc=!1,Vf=new Uint8Array(8),Lm=new DataView(Vf.buffer),E3=6e4;a(XL,"InstanceOfBlobWithNoConstructor");XL.prototype=wi.prototype;Mm=class e extends XL{static{a(this,"FileBackedBlob")}type="";size;#e;#t;constructor(t){super(),t?.type&&(this.type=t.type),t?.size!=null&&(this.size=t.size)}on(t,r){if(t==="error")this.#e??=[],this.#e.push(r);else if(t==="size")this.#t??=[],this.#t.push(r);else throw new Error("Only 'error' and 'size' events are supported")}toJSON(){if(this.type?.startsWith("text")){let t=En.get(this),{start:r,end:n,contentBuffer:s,asString:i}=t;return i||(s&&(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),s?(t.asString=s.toString(),t.asString):(LR()&&DR(this.bytes().then(o=>t.contentBuffer=o)),`[blob: ${this.type}, ${this.size} bytes]`))}return{description:"Blobs that are not of type text/* can not be directly serialized as JSON, use as the body of a response or convert to another type"}}async text(){return(await this.bytes()).toString()}bytes(){let t=En.get(this),{start:r,end:n,contentBuffer:s}=t;if(s)return(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),Promise.resolve(s);let i=Yf(t),o,c=a(async()=>{let l,u=gr;try{if(l=await(0,Js.readFile)(i),l.length>=gr){l.copy(Vf,0,0,gr);let d=Lm.getBigUint64(0);if(Number(d>>48n)===YL)throw new Error("Error in blob: "+buffer.subarray(gr));if(u=Number(d&0xffffffffffffn),u<n&&(u=n),u<WL&&(this.size=u,this.#t))for(let p of this.#t)p(u)}}catch(d){if(d.code!=="ENOENT")throw d;l=Buffer.alloc(0)}function f(d){if(u>d.length){let p=t.store,_=t.fileId+":blob";if(o)throw new Error("Incomplete blob");return new Promise((h,S)=>{if(p.attemptLock(_,0,()=>(o=!0,p.unlock(_,0),h(c()))))return o=!0,p.unlock(_,0),h(c())})}return(n!=null||r!=null)&&(d=d.subarray(r??0,n??d.length)),d}return a(f,"checkCompletion"),l[1]===wR?new Promise((d,p)=>{(0,xm.deflate)(l.subarray(gr),(_,h)=>{_?p(_):d(f(h))})}):f(l.subarray(gr))},"readContents");return c()}async arrayBuffer(){let t=await this.bytes(),r=new ArrayBuffer(t.length);return new Uint8Array(r).set(t),r}stream(){let t=En.get(this),{contentBuffer:r,start:n,end:s}=t;if(r)return(s!=null||n!=null)&&(r=r.subarray(n??0,s??t.contentBuffer.length)),new ReadableStream({pull(S){S.enqueue(r),S.close()}});let i=Yf(t),o,c=0,l=0,u,f,d,p=!1,_=this;return new ReadableStream({start(){let S=1e3,g=a((R,E)=>{(0,Je.open)(i,"r",(T,b)=>{if(T){if(T.code==="ENOENT"&&d!==!1&&(Sa.default.debug?.("File does not exist yet, waiting for it to be created",i,S),S-- >0))return setTimeout(()=>{h(),g(R,E)},20).unref();E(T),_.#e?.forEach(v=>v(T))}else o=b,R(b)})},"openFile");return new Promise(g)},pull:a(S=>{let g=0,R=100;return new Promise(a(function E(T,b){function v(q){(0,Je.close)(o),clearTimeout(f),u&&u.close(),b(q),_.#e?.forEach(Y=>Y(q))}a(v,"onError");let F=Buffer.allocUnsafe(262144);(0,Je.read)(o,F,0,F.length,c,(q,Y,Z)=>{if(l+=Y,q)return v(q);if(c===0){if(Y<gr){R-- >0&&d!==!1?(h(),Sa.default.debug?.("File was empty, waiting for data to be written",i,R),setTimeout(()=>E(T,b),20).unref()):(Sa.default.debug?.("File was empty, throwing error",i,R),b(new Error(`Blob ${t.fileId} was empty`)));return}Z.copy(Vf,0,0,gr);let se=Lm.getBigUint64(0);if(Number(se>>48n)===YL)return v(new Error("Error in blob: "+Z.subarray(gr)));if(g=Number(se&0xffffffffffffn),g<WL&&_.size!==g&&(_.size=g,_.#t))for(let Q of _.#t)Q(g);Z=Z.subarray(gr,Y),l-=gr}else if(Y===0){let se=Buffer.allocUnsafe(8);return(0,Je.read)(o,se,0,gr,0,Q=>{if(Q)return v(Q);if(Vf.set(se),g=Number(Lm.getBigUint64(0)&0xffffffffffffn),g>l){h()?u?f=setTimeout(()=>{v(new Error("File read timed out"))},E3).unref():(u=(0,Je.watch)(i,{persistent:!1},()=>{u.close(),u=null,f&&(clearTimeout(f),f=null,E(T,b))}),E(T,b)):p?v(new Error("Blob is incomplete")):(p=!0,E(T,b));return}(0,Je.close)(o),S.close(),T()})}else Z=Z.subarray(0,Y);if(n!==void 0||s!==void 0){if(n&&l<n)return c+=Y,E(T,b);s&&l>=s&&(l>s&&(Z=Z.subarray(0,s-c)),l=g=s),n&&n>c&&(Z=Z.subarray(n-c))}c+=Y;try{S.enqueue(Z)}catch(se){return Sa.default.debug?.("Error enqueuing chunk",se),T()}l===g&&((0,Je.close)(o),S.close()),T()})},"readMore"))},"pull"),cancel(){(0,Je.close)(o),clearTimeout(f),u&&u.close()}});function h(){if(d===void 0){let S=t.store,g=t.fileId+":blob";d=!S.attemptLock(g,0,()=>{d=!1,S.unlock(g,0)}),d||S.unlock(g,0)}return d}}slice(t,r,n){let s=En.get(this),i=new e(n&&{type:n});if(s?.fileId){let o={...s,start:t,end:r};En.set(i,o),this.size!=null&&(i.size=(r==null?this.size:Math.min(r,this.size))-(t??0))}else if(s?.contentBuffer&&!s.storageBuffer){let o={...s,contentBuffer:s.contentBuffer.subarray(t,r)};En.set(i,o),i.size=(r??this.size)-t}else throw new Error("Can not slice a streaming blob that is not backed by a file");return i}save(t){if(!t?.primaryStore?.rootStore)throw new Error("No target table specified");return tM(this).saving??Promise.resolve()}},ZL=500;a(eM,"deleteBlob");a(g3,"setDeletionDelay");global.createBlob=function(e,t){let r=new Mm(t),n={storageIndex:0,fileId:null,flush:t?.flush,compress:t?.compress};if(En.set(r,n),e instanceof Uint8Array)r.size=e.length,n.contentBuffer=e;else if(e instanceof Kf.Readable)n.source=e;else if(typeof e=="string")n.contentBuffer=Buffer.from(e);else if(e?.[Symbol.asyncIterator]||e?.[Symbol.iterator])n.source=Kf.Readable.from(e);else throw new Error("Invalid source type");return r};a(tM,"saveBlob");a(NR,"writeBlobWithStream");a(Hm,"getFileId");a(rM,"getFilePathForBlob");vm=new Map;a(km,"getRootBlobPathsForDB");a(IR,"deleteRootBlobPathsForDB");a(nM,"rimrafSteadily");a(Yf,"getFilePath");a(S3,"writeBlobWithBuffer");a(T3,"generateFilePath");zL=new Map;a(A3,"getNextFileId");Um=128;a(R3,"getNextStorageIndex");a(y3,"createFrequencyTableForStoragePaths");a(Fm,"encodeBlobsWithFilePath");a(b3,"encodeBlobsAsBuffers");a(CR,"decodeBlobsWithWrites");a(PR,"decodeWithBlobCallback");a(vc,"decodeFromDatabase");a(Ta,"deleteBlobsInObject");a(yu,"findBlobsInObject");(0,io.addExtension)({Class:wi,type:11,unpack:a(function(e){let t=(0,io.unpack)(e),r=new Mm;if(Object.assign(r,t[0]),typeof t[1]!="object"){if(!js)throw new Error("No store specified, can not load blob from storage");if(En.set(r,{storageIndex:t[1],fileId:t[2],store:js}),Lc)return Lc(r)??r}else En.set(r,{storageIndex:0,fileId:null,storageBuffer:e,contentBuffer:t[1]}),r.size=t[1]?.length;return r},"unpack"),pack:a(function(e){let t=En.get(e);if(Ru!==void 0&&(Mc=!0,t?.recordId!==void 0&&t.recordId!==Ru))throw new Error("Cannot use the same blob in two different records");let r={...e};if(e.type&&(r.type=e.type),e.size!==void 0&&(r.size=e.size),t){if(t.storageBuffer)return t.storageBuffer;if(t.contentBuffer?.length<JL)return r.size=t.contentBuffer.length,(0,io.pack)([r,t.contentBuffer])}if(Ru!==void 0){if(t=tM(e),!t.fileId)throw new Error("Unable to save blob without file id");return t.recordId=Ru,(0,io.pack)([r,t.storageIndex,t.fileId])}if(t)try{let n=(0,Je.readFileSync)(Yf(t));if(n.length>=gr&&(n.copy(Vf,0,0,gr),Number(Lm.getBigUint64(0)&0xffffffffffffn)===n.length-gr))return Buffer.concat([(0,io.pack)([r]),n]);if(Dr)Dr.push(e.bytes());else throw new Error("Incomplete blob");return Buffer.alloc(0)}catch(n){if(n.code==="ENOENT"&&Dr)return Dr.push(e.bytes()),Buffer.alloc(0);throw n}else throw new Error("Blob has no storage info or buffer attached to it")},"pack")});(0,io.addExtension)({Class:Promise,type:12,pack(){throw new Error("Cannot encode a promise")}});a(O3,"polyfillBlob")});var dM={};ve(dM,{asyncSerialization:()=>DR,contentTypes:()=>xR,findBestSerializer:()=>$m,getDeserializer:()=>uo,hasAsyncSerialization:()=>LR,registerContentHandlers:()=>jf,serialize:()=>Jf,serializeMessage:()=>Aa,toCsvStream:()=>qm});function w3(e){try{return e?.[0]===123?UR(e):e}catch{return e}}function jf(e){e.register(C3,{serializers:[{regex:/^application\/json$/,serializer:$f},{regex:/^application\/cbor$/,serializer:a(function(t){return new Uc.EncoderStream(zf).end(t)},"serializer")},{regex:/^application\/(x-)?msgpack$/,serializer:a(function(t){return(t?.[Symbol.iterator]||t?.[Symbol.asyncIterator])&&!Array.isArray(t)?xc.Readable.from((0,Ii.encodeIter)(t,zf)):(0,Ii.pack)(t)},"serializer")},{regex:/^text\/csv$/,serializer:a(function(t){return this.header("Content-Disposition",'attachment; filename="data.csv"'),qm(t)},"serializer")}]}),e.addContentTypeParser("application/x-msgpack",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Ii.unpack)(r))}catch(s){s.statusCode=400,n(s)}}),e.addContentTypeParser("application/cbor",{parseAs:"buffer"},(t,r,n)=>{try{n(null,(0,Uc.decode)(r))}catch(s){s.statusCode=400,n(s)}})}function $m(e){let t=e.headers.asObject||e.headers,r=e.requestedContentType??t.accept,n,s=0,i,o,c=r?r.toLowerCase().split(/\s*,\s*/):[];for(let l of c){let[u,...f]=l.split(/\s*;\s*/),d=1,p={q:1};for(let h of f){let S=h.indexOf("=");p[h.substring(0,S)]=h.substring(S+1)}d=+p.q;let _=Kr.get(u);if(_){let h=(_.q||1)*d;h>s&&(n=_,i=_.type||u,s=h,o=p)}}if(!n){if(r)throw new oM.ClientError("No supported content types found in Accept header, supported types include: "+Array.from(Kr.keys()).join(", "),406);n=Kr.get("application/json"),i="application/json"}return{serializer:n,type:i,parameters:o}}function Jf(e,t,r){let n=iM&&t.headers.asObject?.["accept-encoding"]?.includes("br"),s;if(e?.contentType!=null&&e.data!=null)r.headers.set("Content-Type",e.contentType),r.headers.set("Vary","Accept-Encoding"),s=e.data;else if(e instanceof Uint8Array||e instanceof wi)r.headers.set("Content-Type","application/octet-stream"),r.headers.set("Vary","Accept-Encoding"),s=e;else{let i=$m(t);if(i.serializer.compressible===!1&&(n=!1),r.headers.set("Vary","Accept, Accept-Encoding"),r.headers.set("Content-Type",i.type),typeof e=="object"&&e&&(e[Symbol.iterator]||e[Symbol.asyncIterator])&&i.serializer.serializeStream){if(e.mapError){let c=e.getColumns;e=e.mapError(l=>(l.toJSON=()=>({error:l.name,message:l.message,...l.partialObject}),vR.default.warn?.(`Error serializing error ${t?.url||t}: ${l}`),l)),e.getColumns=c}let o=i.serializer.serializeStream(e,r);return n&&(r.headers.set("Content-Encoding","br"),o=o.pipe((0,lo.createBrotliCompress)({params:{[lo.constants.BROTLI_PARAM_MODE]:i.type.includes("json")||i.type.includes("text")?lo.constants.BROTLI_MODE_TEXT:lo.constants.BROTLI_MODE_GENERIC,[lo.constants.BROTLI_PARAM_QUALITY]:2}}))),o}s=i.serializer.serialize(e,r)}return n&&s?.length>iM?(r.headers.set("Content-Encoding","br"),new Promise((i,o)=>(0,lo.brotliCompress)(s,(c,l)=>{c?o(c):i(l)}))):s}function Aa(e,t,r){if(e?.contentType!=null&&e.data!=null)return e.data;co=r?void 0:[];try{let n;if(t){let s=t.serialize;if(s)n=s(e);else{let i=$m(t);s=t.serialize=i.serializer.serialize,n=s(e)}}else n=Wf(e);return co?.length>0?(co.length===1?co[0]:Promise.all(co)).then(()=>Aa(e,t,!0)):n}finally{co=void 0}}function DR(e){if(co)co.push(e);else throw new Error("Unable to serialize asynchronously")}function LR(){return!!co}function P3(e){return new Promise((t,r)=>{let n=[];e.on("data",s=>n.push(s)),e.on("end",()=>t(Buffer.concat(n))),e.on("error",r)})}function L3(e){return D3.includes(e)}function M3(e){let t=e.indexOf(";"),r;if(t>-1){r={};let n=e.slice(t+1).split(";");for(let s of n){let[i,o]=s.split("=");r[i.trim()]=o.trim()}e=e.slice(0,t)}return{type:e,parameters:r}}function uo(e="",t=!1){let r=M3(e),n=r.type&&Kr.get(r.type)?.deserialize||v3(r);return t?s=>P3(s).then(n):n}function v3(e){return e.type.startsWith("text/")?(e.parameters?.charset&&!L3(e.parameters.charset)&&vR.default.info(`Unknown Buffer encoding ${e.parameters.charset} in content-type. Proceeding anyways.`),t=>({contentType:e.type,data:t.toString(e.parameters?.charset||"utf-8")})):e.type==="application/octet-stream"?t=>t:t=>{if(e.type==="")try{if(t?.[0]===123)return UR(t)}catch{}return{contentType:e.type||"application/octet-stream",data:t}}}function U3(e,t){return{[Symbol.asyncIterator](){let r=e[Symbol.asyncIterator]?e[Symbol.asyncIterator]():e[Symbol.iterator]();return{next(){let n=r.next();return n.then?n.then(s=>({value:t(s.value),done:s.done})):{value:t(n.value),done:n.done}},return(n){return r.return(n)},throw(n){return r.throw(n)}}}}}function qm(e,t){let r=xc.default.Readable.from(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator]?e:[e]),n={};t&&(n.fields=t.map(o=>({label:o,value:o})));let s={objectMode:!0},i=new N3(n,s);return r.pipe(i)}var Ii,Uc,lo,oM,xc,aM,MR,cM,vR,N3,lM,Wf,UR,zf,Kr,xR,sM,uM,I3,C3,iM,co,D3,ao=be(()=>{OR();Ii=require("msgpackr"),Uc=require("cbor-x"),lo=require("zlib"),oM=M(pe()),xc=M(require("stream"));Vr();aM=M(Ti()),MR=M(ae());H();cM=M(require("yaml")),vR=M(Ni());gs();({Transform:N3}=require("json2csv")),lM=MR.default.get(x.SERIALIZATION_BIGINT)!==!1,Wf=lM?Dc:JSON.stringify,UR=lM?bR:JSON.parse,zf={useRecords:!1,useToJSON:!0},Kr=new Map,xR=Kr;We.contentTypes=xR;(0,aM._assignPackageExport)("contentTypes",xR);Kr.set("application/json",{serializeStream:$f,serialize:Wf,deserialize(e){return UR(e)},q:.8});sM=new Uc.Encoder(zf);Kr.set("application/cbor",{serializeStream(e){return e[Symbol.asyncIterator]&&(e[Symbol.iterator]=null),new Uc.EncoderStream(zf).end(e)},serialize:sM.encode,deserialize:sM.decode,q:1});Kr.set("application/x-msgpack",{serializeStream(e){return(e?.[Symbol.iterator]||e?.[Symbol.asyncIterator])&&!Array.isArray(e)?xc.Readable.from((0,Ii.encodeIter)(e,zf)):(0,Ii.pack)(e)},serialize:Ii.pack,deserialize:Ii.unpack,q:.9});Kr.set("text/csv",{serializeStream(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),qm(e,e?.getColumns?.())},serialize(e,t){return t.headers.set("Content-Disposition",'attachment; filename="data.csv"'),e&&!e[Symbol.iterator]&&(e=[e.toJSON?e.toJSON():e]),qm(e,e?.getColumns?.())},q:.1});Kr.set("text/plain",{serialize(e){return e.toString()},serializeStream(e){return xc.Readable.from(e.map?e.map(t=>t.toString()):e)},deserialize(e){return e.toString()},q:.2});Kr.set("text/yaml",{serialize(e){return cM.stringify(e,{aliasDuplicateObjects:!1})},q:.7});Kr.set("text/event-stream",{serializeStream:a(function(e){return xc.Readable.from(U3(e,this.serialize))},"serializeStream"),serialize:a(function(e){if(e.acknowledge&&e.acknowledge(),typeof e=="object"&&"value"in e&&e.timestamp&&(e={data:e.value,event:e.type,id:e.timestamp}),e.data||e.event){let t="";if(e.event&&(t+="event: "+e.event+`
9
9
  `),e.data){let r=e.data;typeof r=="object"&&(r=Wf(r)),t+="data: "+r+`
10
10
  `}return e.id&&(t+="id: "+e.id+`
11
11
  `),e.retry&&(t+="retry: "+e.retry+`
@@ -14,125 +14,124 @@ Caused by:`));else if(typeof u=="object")try{n+=JSON.stringify(u)}catch{n+="Obje
14
14
 
15
15
  `:`data: ${e}
16
16
 
17
- `},"serialize"),compressible:!1,q:.8});Kr.set("application/x-www-form-urlencoded",{deserialize(e){let t=Buffer.isBuffer(e)?e.toString("utf8"):e,r={};for(let[n,s]of new URLSearchParams(t))if(r.hasOwnProperty(n)){let i=r[n];Array.isArray(i)?i.push(s):r.key=[i,s]}else r[n]=s;return r},serialize(e){let t=new URLSearchParams;for(let r in e)t.set(r,e);return t.toString()}});lM={type:"application/json",serializeStream:$f,serialize:Wf,deserialize:I3,q:.5};Kr.set("*/*",lM);Kr.set("",lM);a(I3,"tryJSONParse");a(jf,"registerContentHandlers");C3=require("fastify-plugin"),P3=C3(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=qm(n.raw);s.type(c),s.serializer(function(l){let u;if(typeof l=="object"&&l&&(l[Symbol.iterator]||l[Symbol.asyncIterator])&&o.serializeStream){if(l.mapError){let f=l.getColumns;l=l.mapError(d=>(d.toJSON=()=>({error:d.name,message:d.message,...d.partialObject}),d)),l.getColumns=f}u=o.serializeStream}else u=o.serialize;return u(l,{headers:{set:a((f,d)=>{s.header(f,d)},"set")}})})}),r()},{name:"content-type-negotiation"});a(qm,"findBestSerializer");sM=LR.default.get(B.HTTP_COMPRESSIONTHRESHOLD);a(Jf,"serialize");a(Aa,"serializeMessage");a(PR,"asyncSerialization");a(DR,"hasAsyncSerialization");a(D3,"streamToBuffer");L3=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(M3,"isBufferEncoding");a(v3,"parseContentType");a(uo,"getDeserializer");a(U3,"deserializerUnknownType");a(x3,"transformIterable");a(Gm,"toCsvStream")});var BR={};ve(BR,{start:()=>K3});function B3(e){if(e.kind!==Le.Kind.OPERATION_DEFINITION&&e.kind!==Le.Kind.FRAGMENT_DEFINITION)throw new br(`Unexpected non-executable definition type ${e.kind}.`)}function dM(e){if(typeof e!="object"||e===null)throw new Ci("Request body must be an object.");if(!("query"in e))throw new Ci("Request body must contain a `query` field.");if(typeof e.query!="string")throw new Ci("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new Ci("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new Ci("Request body `operationName` field must be a string.")}function xR(e){return parseInt(e.value,10)}function _M(e){return parseFloat(e.value)}function pM(e,t,r){let n=r.get(e.name.value);return hM(n)?mM(n,t):{attribute:t,value:n}}function hM(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function mM(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],hM(n)?mM(n,t):{attribute:t,value:n}))}function H3(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:xR(e.value)};case Le.Kind.FLOAT:return{attribute:t,value:_M(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:t,value:e.value.value};case Le.Kind.VARIABLE:return pM(e.value,t,r);case Le.Kind.OBJECT:return EM(e.value,t,r);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new br(`Value type, ${e.value.kind}, is not supported.`)}}function EM(e,t,r){return e.fields.flatMap(n=>H3(n,t,r))}function k3(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:xR(e.value)};case Le.Kind.FLOAT:return{attribute:e.name.value,value:_M(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Le.Kind.VARIABLE:return pM(e.value,e.name.value,t);case Le.Kind.OBJECT:return EM(e.value,[e.name.value],t);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new br(`Argument type, ${e.value.kind}, is not supported.`)}}function F3(e,t){return e.flatMap(r=>k3(r,t))}function $m(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 br(`Fragment \`${n}\` not found.`);return $m(s.selectionSet,t)}case Le.Kind.INLINE_FRAGMENT:return $m(r.selectionSet,t)}})}function gM(e,t){return $m(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:gM(r.selectionSet,t)}:r.name.value)}async function G3(e,t,r,n){let s=Oi.getMatch(e.name.value,"graphql");if(s===void 0)throw new br(`Resource \`${e.name.value}\` not found.`);let i=s.Resource,o={select:gM(e.selectionSet,r),conditions:F3(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 SM(e){switch(e.kind){case Le.Kind.NULL:return null;case Le.Kind.INT:return xR(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]:SM(r.value),...t}),{});case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new br(`Value type, ${e.kind}, is not supported.`)}}function q3(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=SM(n.defaultValue)),n.type.kind===Le.Kind.NON_NULL_TYPE&&!(s in t)&&i===void 0)throw new br(`Variable $${s} is required, but not provided.`);r.set(n.variable.name.value,i??null)}return r}async function $3(e,t,r,n){if(e.operation===Le.OperationTypeNode.SUBSCRIPTION)throw new br("Subscriptions are not supported.");if(e.operation===Le.OperationTypeNode.MUTATION)throw new br("Mutations are not supported yet.");let s=q3(e.variableDefinitions,t),i=await Promise.all($m(e.selectionSet,r).map(c=>G3(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function fM({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(B3(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 br("Unnamed operations are only allowed when there is a single operation in the document.");let f=u.name?.value??"Unnamed Query";if(i.has(f))throw new br(`Duplicate operation definition: ${f}`);i.set(f,u)}let c;if(r==null)if(i.size===1)c=i.entries().next().value[1];else throw new br("Operation name is required when there are multiple operations in the document.");else if(c=i.get(r),c==null)throw new br(`Operation \`${r}\` not found.`);let l=await $3(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function V3(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 dM(r),fM(r,e)}case"POST":{let r=await uo(e.headers.get("content-type"),!0)(e._nodeRequest);return dM(r),fM(r,e)}default:throw new Ci("Method Not Allowed",405,{Allow:"GET, POST"})}}function K3(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await V3(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof Ci)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json",...n.headers}};if(n instanceof Le.GraphQLError)return{status:200,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/json"}};if(n instanceof br)return{status:200,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};break}default:logger.info(`Unsupported accept header, ${s}, defaulting to application/graphql-response+json`);case"application/graphql-response+json":{if(n instanceof Ci)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json",...n.headers}};if(n instanceof Le.GraphQLError)return{status:400,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof br)return{status:400,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};break}}throw n}},{port:e.port,securePort:e.securePort})}var Le,br,Ci,TM=be(()=>{Le=M(require("graphql"));ao();Su();a(B3,"assertExecutableDefinitionNode");a(dM,"assertRequestParams");a(xR,"processIntValueNode");a(_M,"processFloatValueNode");a(pM,"processVariableNode");a(hM,"isObject");a(mM,"transformObjectIntoQueryCondition");a(H3,"processObjectFieldNode");a(EM,"processObjectValueNode");a(k3,"processArgumentNode");a(F3,"buildConditionsQuery");a($m,"fillInFragments");a(gM,"buildSelectQuery");a(G3,"processFieldNode");a(SM,"processConstValueNode");a(q3,"resolveVariables");a($3,"executeOperation");a(fM,"resolver");br=class extends Error{static{a(this,"GraphQLQueryingError")}},Ci=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a(V3,"graphqlQueryingHandler");a(K3,"start")});var Di=w((Ybe,yM)=>{"use strict";var RM=ie(),AM=(H(),C(G)),yu=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Pi=require("joi"),Ra={schema_format:{pattern:yu,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},Y3=Pi.alternatives(Pi.string().min(1).max(Ra.schema_length.maximum).pattern(yu).messages({"string.pattern.base":"{:#label} "+Ra.schema_format.message}),Pi.number(),Pi.array()).required(),W3=Pi.alternatives(Pi.string().min(1).max(Ra.schema_length.maximum).pattern(yu).messages({"string.pattern.base":"{:#label} "+Ra.schema_format.message}),Pi.number()),z3=Pi.alternatives(Pi.string().min(1).max(Ra.schema_length.maximum).pattern(yu).messages({"string.pattern.base":"{:#label} "+Ra.schema_format.message}),Pi.number()).required();function j3(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>Ra.schema_length.maximum?`'${e}' maximum of 250 characters`:yu.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(j3,"checkValidTable");function J3(e,t){return RM.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(J3,"validateSchemaExists");function Q3(e,t){let r=t.state.ancestors[0].schema;return RM.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(Q3,"validateTableExists");function X3(e,t){return e.toLowerCase()===AM.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${AM.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(X3,"validateSchemaName");yM.exports={common_validators:Ra,schema_regex:yu,hdb_schema_table:Y3,validateSchemaExists:J3,validateTableExists:Q3,validateSchemaName:X3,checkValidTable:j3,hdb_database:W3,hdb_table:z3}});var it=w((zbe,bM)=>{"use strict";var En=require("validate.js");En.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||En.validators.type.checks[t](e)?null:` must be a '${t}' value`};En.validators.type.checks={Object:a(function(e){return En.isObject(e)&&!En.isArray(e)},"Object"),Array:En.isArray,Integer:En.isInteger,Number:En.isNumber,String:En.isString,Date:En.isDate,Boolean:a(function(e){return typeof e=="boolean"},"Boolean")};En.validators.hasValidFileExt=function(e,t){return En.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};bM.exports={validateObject:Z3,validateObjectAsync:eX,validateBySchema:tX};function Z3(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=En(e,t,{format:"flat"});return r?new Error(r):null}a(Z3,"validateObject");async function eX(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await En.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(eX,"validateObjectAsync");function tX(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(tX,"validateBySchema")});var kR=w((Jbe,NM)=>{var{hdb_table:rX,hdb_database:OM}=Di(),nX=it(),HR=require("joi"),sX={undefined:"undefined",null:"null"},iX=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||sX[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"),oX=HR.object({database:OM,schema:OM,table:rX,records:HR.array().items(HR.object().custom(iX)).required()});NM.exports=function(e){return nX.validateBySchema(e,oX)}});var IM=w((Xbe,wM)=>{"use strict";var FR=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")}};wM.exports=FR});var PM=w((eOe,CM)=>{"use strict";var GR=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};CM.exports=GR});var UM={};ve(UM,{HAS_EXPIRATION:()=>Ym,HAS_RESIDENCY_ID:()=>zR,HAS_STRUCTURE_UPDATE:()=>zm,LAST_TIMESTAMP_PLACEHOLDER:()=>t_,LOCAL_TIMESTAMP:()=>aX,METADATA:()=>Qf,NEW_TIMESTAMP_PLACEHOLDER:()=>LM,NO_TIMESTAMP:()=>qR,PENDING_LOCAL_TIME:()=>jR,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>WR,RecordEncoder:()=>YR,TIMESTAMP_ASSIGN_LAST:()=>lX,TIMESTAMP_ASSIGN_NEW:()=>MM,TIMESTAMP_ASSIGN_PREVIOUS:()=>vM,TIMESTAMP_PLACEHOLDER:()=>Vm,TIMESTAMP_RECORD_PREVIOUS:()=>$R,handleLocalTimeForGets:()=>jm,recordUpdater:()=>JR,removeEntry:()=>vc});function dX(){return e_[0]=e_[0]^64,cX.getFloat64(0)}function jm(e,t){let r=e.getEntry;e.readCount=0,e.cachePuts=!1,e.rootStore=t,e.encoder.rootStore=t,e.getEntry=function(o,c){e.readCount++;let l=r.call(this,o,c),u=l?.value,f=u?.[Qf];return f>=0&&(l.metadataFlags=f,l.localTime=u.localTime,l.value=u.value,l.residencyId=u.residencyId,u.expiresAt>=0&&(l.expiresAt=u.expiresAt)),l&&(l.key=o),l};let n=e.get;e.get=function(o,c){let l=n.call(this,o,c);return l?.[Qf]>=0?l.value:l};let s=e.getRange;e.getRange=function(o){let c=s.call(this,o);return o.valuesForKey?c.map(l=>l?.value):o.values===!1||o.onlyCount?c:c.map(l=>{let u=l.value,f=u[Qf];return f>=0&&(l.metadataFlags=f,l.localTime=u.localTime,l.value=u.value,l.residencyId=u.residencyId,u.expiresAt>=0&&(l.expiresAt=u.expiresAt)),l})};let i=e.useReadTransaction();if(i.done(),!i.done.isTracked){let o=i.constructor,c=i.use,l=i.done;o.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,Mc.push(new WeakRef(this))),c.call(this)},o.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<Mc.length;u++){let f=Mc[u].deref();(!f||f.isDone||f.isCommitted)&&Mc.splice(u--,1)}},o.prototype.done.isTracked=!0}return e}function JR(e,t,r){return function(n,s,i,o,c=-1,l,u,f="put",d,p){d||l==null?bu=i?.localTime?$R|vM:qR:bu=l?i?.localTime?$R|16384:MM|16384:qR;let _=u?.expiresAt;if(_>=0&&(c|=Ym),Zf=c,VR=_,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:bu>0},S,g=0;try{let R=i?.residencyId,E=u?.residencyId;E&&(KR=E,Zf|=zR,g|=Uc),R!==E&&(g|=xc,R||(R=0)),c&Ym&&(g|=n_),u?.originatingOperation&&(g|=r_),d&&(h.ifVersion=S=i?.version??null),i&&i.value&&i.metadataFlags&Fn&&(r.getBinaryFast(i.localTime)||Ta(i.value));let T;if(s!==void 0&&(T=km(()=>e.put(n,s,h),n,e.rootStore),Cc&&(g|=Fn)),l){let b=u?.user?.username;if(p&&(km(()=>e.encoder.encode(p),n,e.rootStore),Cc&&(g|=Fn)),e.encoder.hasStructureUpdate&&(g|=zm,e.encoder.hasStructureUpdate=!1),d&&i?.localTime){let v=i?.localTime,F=r.get(v);if(F){let q=wt(F).previousLocalTime;return T=r.put(v,Ou(o,t,n,q,u?.nodeId??server.replication.getThisNodeId(r)??0,b,f,Xf,g,E,R,_),{ifVersion:S}),T}}T=r.put(s===void 0?LM:t_,Ou(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,b,f,Xf,g,E,R,_,u?.originatingOperation),{append:f!=="invalidate",instructedWrite:!0,ifVersion:S})}return T}catch(R){throw R.message+=" id: "+n+" options: "+h,R}}}function vc(e,t,r){if(t)return t.value&&t.metadataFlags&Fn&&!e.auditStore.getBinaryFast(t.localTime)&&Ta(t.value),e.remove(t.key,r)}var DM,Km,Vm,t_,WR,LM,aX,Qf,e_,cX,qR,MM,lX,vM,$R,Ym,zR,jR,zm,uX,Xf,bu,Zf,VR,KR,YR,Mc,Nu=be(()=>{DM=require("msgpackr");fo();Km=M(z());gs();gs();Vm=new Uint8Array([1,1,1,1,4,64,0,0]),t_=new Uint8Array([1,1,1,1,1,0,0,0]),WR=new Uint8Array([1,1,1,1,3,64,0,0]),LM=new Uint8Array([1,1,1,1,0,64,0,0]),aX=Symbol("local-timestamp"),Qf=Symbol("metadata"),e_=new Uint8Array(8),cX=new DataView(e_.buffer,0,8),qR=0,MM=0,lX=1,vM=3,$R=4,Ym=16,zR=32,jR=1,zm=256,bu=0,Zf=-1,VR=-1,KR=0,YR=class extends DM.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(bu||Zf>=0){let o=0,c=bu;c&&(o+=8,bu=0);let l=Zf,u=VR,f=KR;l>=0&&(o+=4,Zf=-1,u>=0&&(o+=8,VR=-1),f&&(o+=4,KR=0));let d=uX=r.call(this,s,i|2048|o);Xf=d.subarray((d.start||0)+o,d.end);let p=d.start||0;return c&&(Vm[4]=c,Vm[5]=c>>8,d.set(Vm,p),p+=8),Cc&&(l|=Fn),l>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(p,l|Wm<<24),p+=4,u>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setFloat64(p,u),p+=8),f&&(d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(p,f)),d}else return Xf=r.call(this,s,i),Xf};let n=this.saveStructures;this.saveStructures=function(s,i){let o=n.call(this,s,i);return this.hasStructureUpdate=!0,o}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(e_,0,c),c+=8;else for(let p=0;p<8;p++)e_[p]=t[c++];l=dX(),i=t[c]}let u,f;i<32&&(i===Wm?(o=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4):(o=i|t[c+1]<<5,c+=2),o&Ym&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&zR&&(f=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let d=Pc(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return{localTime:l,value:d,[Qf]:o,expiresAt:u,residencyId:f}}return r?.valueAsBuffer?t:Pc(()=>super.decode(t,r),this.rootStore)}catch(c){return Km.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};a(dX,"getTimestamp");a(jm,"handleLocalTimeForGets");Mc=[];setInterval(()=>{for(let e=0;e<Mc.length;e++){let t=Mc[e].deref();!t||t.isDone||t.isCommitted?Mc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(Km.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):Km.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(JR,"recordUpdater");a(vc,"removeEntry")});var s_=w((oOe,BM)=>{"use strict";var xM=ae(),fX=(H(),C(G)),{RecordEncoder:_X}=(Nu(),C(UM));xM.initSync();var pX=xM.get(fX.CONFIG_PARAMS.STORAGE_CACHING)!==!1,QR=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=pX&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:_X})}};BM.exports=QR});var i_=w((cOe,HM)=>{"use strict";var Gn=ae(),Ss=(H(),C(G));Gn.initSync();var Jm=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Gn.get(Ss.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Gn.get(Ss.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Gn.get(Ss.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Gn.get(Ss.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Gn.get(Ss.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Gn.get(Ss.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Gn.get(Ss.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Gn.get(Ss.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Gn.get(Ss.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Gn.get(Ss.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Gn.get(Ss.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Gn.get(Ss.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};HM.exports=Jm;Jm.MAX_DBS=1e4});var _t=w((uOe,zM)=>{"use strict";var ZR=require("lmdb"),Qs=require("fs-extra"),qn=require("path"),Qm=_n(),GM=z(),gn=Un().LMDB_ERRORS_ENUM,Xm=PM(),ey=s_(),qM=i_(),ya=Ut(),kM=(H(),C(G)),{table:hX,resetDatabases:mX}=(Pe(),C(tt)),FM=ae(),Xs=ya.INTERNAL_DBIS_NAME,$M=ya.DBI_DEFINITION_NAME,EX="data.mdb",gX="lock.mdb",o_=".mdb",SX="-lock",XR=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=Ts(t,r),this.key_type=this.dbi[ya.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[ya.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new ZR.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function Zm(e,t){if(e===void 0)throw new Error(gn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(gn.ENV_NAME_REQUIRED)}a(Zm,"pathEnvNameValidation");async function ty(e,t,r=!0){try{await Qs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(gn.INVALID_BASE_PATH):n}try{let n=qn.join(e,t+o_);return await Qs.access(n,Qs.constants.R_OK|Qs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Qs.access(qn.join(e,t,EX),Qs.constants.R_OK|Qs.constants.F_OK),qn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(gn.INVALID_ENVIRONMENT)}else throw new Error(gn.INVALID_ENVIRONMENT);throw n}}a(ty,"validateEnvironmentPath");function eE(e,t){if(Qm.validateEnv(e),t===void 0)throw new Error(gn.DBI_NAME_REQUIRED)}a(eE,"validateEnvDBIName");async function TX(e,t,r=!1,n=!1){Zm(e,t);let s=qn.basename(e);t=t.toString();let i=FM.get(kM.CONFIG_PARAMS.DATABASES);i||FM.setProperty(kM.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await ty(e,t,n),VM(e,t,r)}catch(o){if(o.message===gn.INVALID_ENVIRONMENT){let c=qn.join(e,t);await Qs.mkdirp(n?c:e);let l=new qM(n?c:c+o_,!1),u=ZR.open(l);u.dbis=Object.create(null);let f=new ey(!1);u.openDB(Xs,f),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=ry(e,t,r);return u[ya.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=u,u}throw o}}a(TX,"createEnvironment");async function AX(e,t,r,n=!0){Zm(e,t),t=t.toString();let s=qn.join(e,t);return hX({table:t,database:qn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(AX,"copyEnvironment");async function VM(e,t,r=!1){Zm(e,t),t=t.toString();let n=ry(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 ty(e,t),i=qn.join(e,t+o_),o=s!=i,c=new qM(s,o),l=ZR.open(c);l.dbis=Object.create(null);let u=YM(l);for(let f=0;f<u.length;f++)Ts(l,u[f]);return l[ya.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(VM,"openEnvironment");async function RX(e,t,r=!1){Zm(e,t),t=t.toString();let n=qn.join(e,t+o_),s=await ty(e,t);if(global.lmdb_map!==void 0){let i=ry(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await KM(o),delete global.lmdb_map[i]}}await Qs.remove(s),await Qs.remove(s===n?s+SX:qn.join(qn.dirname(s),gX))}a(RX,"deleteEnvironment");async function KM(e){Qm.validateEnv(e);let t=e[ya.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(KM,"closeEnvironment");function ry(e,t,r=!1){let s=`${qn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(ry,"getCachedEnvironmentName");function yX(e){Qm.validateEnv(e);let t=Object.create(null),r=Ts(e,Xs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Xs)try{t[n]=Object.assign(new Xm,s)}catch{GM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(yX,"listDBIDefinitions");function YM(e){Qm.validateEnv(e);let t=[],r=Ts(e,Xs);for(let{key:n}of r.getRange({start:!1}))n!==Xs&&t.push(n);return t}a(YM,"listDBIs");function bX(e,t){let n=Ts(e,Xs).getEntry(t),s=new Xm;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{GM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(bX,"getDBIDefinition");function WM(e,t,r,n=!r){if(eE(e,t),t=t.toString(),t===Xs)throw new Error(gn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return Ts(e,t)}catch(s){if(s.message===gn.DBI_DOES_NOT_EXIST){let i=new ey(r,n===!0),o=e.openDB(t,i),c=new Xm(r===!0,n);return o[$M]=c,Ts(e,Xs).putSync(t,c),e.dbis[t]=o,o}throw s}}a(WM,"createDBI");function Ts(e,t){if(eE(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Xs?r=bX(e,t):r=new Xm,r===void 0)throw new Error(gn.DBI_DOES_NOT_EXIST);let n;try{let s=new ey(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(gn.DBI_DOES_NOT_EXIST):s}return n[$M]=r,e.dbis[t]=n,n}a(Ts,"openDBI");function OX(e,t){eE(e,t),t=t.toString();let r=Ts(e,t),n=r.getStats();return r[ya.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(OX,"statDBI");async function NX(e,t){try{let r=qn.join(e,t+o_);return(await Qs.stat(r)).size}catch{throw new Error(gn.INVALID_ENVIRONMENT)}}a(NX,"environmentDataSize");function wX(e,t){if(eE(e,t),t=t.toString(),t===Xs)throw new Error(gn.CANNOT_DROP_INTERNAL_DBIS_NAME);Ts(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],Ts(e,Xs).removeSync(t)}a(wX,"dropDBI");function IX(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{Ts(e,i)}catch(o){if(o.message===gn.DBI_DOES_NOT_EXIST)WM(e,i,i!==t,i===t),n=!0;else throw o}}n&&mX()}a(IX,"initializeDBIs");zM.exports={openDBI:Ts,openEnvironment:VM,createEnvironment:TX,listDBIs:YM,listDBIDefinitions:yX,createDBI:WM,dropDBI:wX,statDBI:OX,deleteEnvironment:RX,initializeDBIs:IX,TransactionCursor:XR,environmentDataSize:NX,copyEnvironment:AX,closeEnvironment:KM}});var JM=w((fOe,jM)=>{"use strict";var ny=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};jM.exports=ny});var XM=w((pOe,QM)=>{"use strict";var sy=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}};QM.exports=sy});var ev=w((mOe,ZM)=>{"use strict";var iy=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};ZM.exports=iy});var Hc=w((AOe,nv)=>{"use strict";var CX=_t(),PX=JM(),DX=XM(),LX=ev(),Li=_n(),a_=Un().LMDB_ERRORS_ENUM,MX=Ut(),_o=(H(),C(G)),vX=ie(),UX=require("uuid"),gOe=require("lmdb"),{handleHDBError:xX,hdb_errors:BX}=pe(),{OVERFLOW_MARKER:SOe,MAX_SEARCH_KEY_LENGTH:TOe}=MX,tv=ae();tv.initSync();var tE=tv.get(_o.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),oy=_o.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Bc=_o.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function HX(e,t,r,n,s=Li.getNextMonotonicTime()){uy(e,t,r,n),ay(e,t,r);let i=new PX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];rv(u,!0,s);let f=kX(e,t,r,u),d=u[t];o.push(f),c.push(d)}return cy(o,c,n,i,s)}a(HX,"insertRecords");function kX(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let f=c([[{}]]);Array.isArray(f)&&(c=f[0][_o.FUNC_VAL],n[o]=c)}let l=Li.getIndexedValues(c),u=e.dbis[o];if(l){tE&&u.prefetch(l.map(f=>({key:f,value:s})),rE);for(let f=0,d=l.length;f<d;f++)u.put(l[f],s)}}tE&&e.dbis[t].prefetch([s],rE),e.dbis[t].put(s,n,n[Bc])})}a(kX,"insertRecord");function FX(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(FX,"removeSkippedRecords");function rv(e,t,r){let n=r>0;(n||!Number.isInteger(e[Bc]))&&(e[Bc]=r||(r=Li.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[oy]))&&(e[oy]=r||Li.getNextMonotonicTime()):delete e[oy]}a(rv,"setTimestamps");function ay(e,t,r){r.indexOf(_o.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(_o.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(_o.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(_o.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),CX.initializeDBIs(e,t,r)}a(ay,"initializeTransaction");async function GX(e,t,r,n,s=Li.getNextMonotonicTime()){uy(e,t,r,n),ay(e,t,r);let i=new DX,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let f=n[u],d=f[t],p;try{p=ly(e,t,f,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(u);continue}c.push(p),l.push(d)}return cy(c,l,n,i,s,o)}a(GX,"updateRecords");async function qX(e,t,r,n,s=Li.getNextMonotonicTime()){try{uy(e,t,r,n)}catch(l){throw xX(l,l.message,BX.HTTP_STATUS_CODES.BAD_REQUEST)}ay(e,t,r);let i=new LX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],f;vX.isEmpty(u[t])?(f=UX.v4(),u[t]=f):f=u[t];let d=ly(e,t,u,f,i,!1,s);o.push(d),c.push(f)}return cy(o,c,n,i,s)}a(qX,"upsertRecords");async function cy(e,t,r,n,s,i=[]){let o=await Promise.all(e);for(let c=0,l=o.length;c<l;c++)o[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||Li.getNextMonotonicTime(),FX(r,i),n}a(cy,"finalizeWrite");function ly(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),u=l?.value,f=u;if(!u){if(i)return!1;u={}}if(rv(r,!f,o),Number.isInteger(r[Bc])&&u[Bc]>r[Bc])return!1;f&&s.original_records.push(u);let d,p=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let S=r[h],g=e.dbis[h];if(g===void 0)continue;let R=u[h];if(typeof S=="function"){let T=S([[u]]);Array.isArray(T)&&(S=T[0][_o.FUNC_VAL],r[h]=S)}if(S===R)continue;let E=Li.getIndexedValues(R);if(E){tE&&g.prefetch(E.map(T=>({key:T,value:n})),rE);for(let T=0,b=E.length;T<b;T++)g.remove(E[T],n)}if(E=Li.getIndexedValues(S),E){tE&&g.prefetch(E.map(T=>({key:T,value:n})),rE);for(let T=0,b=E.length;T<b;T++)g.put(E[T],n)}}let _={...u,...r};c.put(n,_,_[Bc])},"do_put");return l?d=c.ifVersion(n,l.version,p):d=c.ifNoExists(n,p),d.then(_=>_?!0:ly(e,t,r,n,s,i,o))}a(ly,"updateUpsertRecord");function $X(e,t,r){if(Li.validateEnv(e),t===void 0)throw new Error(a_.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(a_.WRITE_ATTRIBUTES_REQUIRED):new Error(a_.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a($X,"validateBasic");function uy(e,t,r,n){if($X(e,t,r),!Array.isArray(n))throw n===void 0?new Error(a_.RECORDS_REQUIRED):new Error(a_.RECORDS_MUST_BE_ARRAY)}a(uy,"validateWrite");function rE(){}a(rE,"noop");nv.exports={insertRecords:HX,updateRecords:GX,upsertRecords:qX}});var po=w((yOe,VX)=>{VX.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"hash_function"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"revoked_certificates"},{attribute:"shard"}]},hdb_certificate:{hash_attribute:"name",name:"hdb_certificate",schema:"system",attributes:[{attribute:"name"},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var iv=w((bOe,sv)=>{"use strict";var KX=require("uuid"),dy=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||KX.v4(),this.schema_table=`${this.schema}.${this.table}`}};sv.exports=dy});var nE=w((NOe,ov)=>{"use strict";var YX=iv(),fy=class extends YX{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}};ov.exports=fy});var cv=w((IOe,av)=>{"use strict";av.exports=zX;var WX="inserted";function zX(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===WX?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(zX,"returnObject")});var sE=w((DOe,uv)=>{"use strict";var jX=(H(),C(G)),_y=_t(),JX=Hc(),{getSystemSchemaPath:QX,getSchemaPath:XX}=gt(),POe=po(),{validateBySchema:ZX}=it(),c_=require("joi"),e6=nE(),t6=cv(),{handleHDBError:r6,hdb_errors:n6,ClientError:s6}=pe(),lv=ie(),{HTTP_STATUS_CODES:i6}=n6,o6="inserted";uv.exports=a6;async function a6(e){let t=ZX(e,c_.object({database:c_.string(),schema:c_.string(),table:c_.string().required(),attribute:c_.string().required()}));if(t)throw new s6(t.message);let r=!e.skip_table_check&&lv.checkGlobalSchemaTable(e.schema,e.table);if(r)throw r6(new Error,r,i6.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=lv.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 e6(e.schema,e.table,e.attribute,e.id);try{let i=await _y.openEnvironment(XX(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}`);_y.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await _y.openEnvironment(QX(),jX.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await JX.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return t6(o6,c,{records:[s]},l)}catch(i){throw i}}a(a6,"lmdbCreateAttribute")});var l_=w((vOe,fv)=>{"use strict";var ho=ie(),dv=z(),MOe=kR(),{getDatabases:c6}=(Pe(),C(tt)),{ClientError:kc}=pe();fv.exports=l6;function l6(e){if(ho.isEmpty(e))throw new kc("invalid update parameters defined.");if(ho.isEmptyOrZeroLength(e.schema))throw new kc("invalid schema specified.");if(ho.isEmptyOrZeroLength(e.table))throw new kc("invalid table specified.");if(!Array.isArray(e.records))throw new kc("records must be an array");let t=c6()[e.schema]?.[e.table];if(ho.isEmpty(t))throw new kc(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&ho.isEmptyOrZeroLength(o[r]))throw dv.error("a valid hash attribute must be provided with update record:",o),new kc("a valid hash attribute must be provided with update record, check log for more info");if(!ho.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw dv.error(`a valid hash value must be provided with ${e.operation} record:`,o),new kc(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!ho.isEmpty(o[r])&&o[r]!==""&&n.has(ho.autoCast(o[r]))&&(o.skip=!0),n.add(ho.autoCast(o[r]));for(let c in o)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}a(l6,"insertUpdateValidate")});var pv=w((xOe,_v)=>{"use strict";var py=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};_v.exports=py});var Ev=w((HOe,mv)=>{"use strict";var hy=_t(),u6=z(),hv=Un().LMDB_ERRORS_ENUM;mv.exports=d6;async function d6(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 hy.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==hv.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await hy.closeEnvironment(global.lmdb_map[n]),await hy.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==hv.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){u6.error(t)}}a(d6,"cleanLMDBMap")});var Pv=w((GOe,Cv)=>{"use strict";var my=require("recursive-iterator"),f6=require("alasql"),Ey=require("clone"),gv=ie(),{handleHDBError:Sv,hdb_errors:_6}=pe(),{HDB_ERROR_MSGS:Tv,HTTP_STATUS_CODES:Av}=_6,{getDatabases:p6}=(Pe(),C(tt)),h6=["DISTINCT_ARRAY"],Rv=Symbol("validateTables"),gy=Symbol("validateTable"),FOe=Symbol("getAllColumns"),yv=Symbol("validateAllColumns"),iE=Symbol("findColumn"),bv=Symbol("validateOrderBy"),u_=Symbol("validateSegment"),Sy=Symbol("validateColumn"),Ov=Symbol("setColumnsForTable"),Nv=Symbol("checkColumnsForAsterisk"),wv=Symbol("validateGroupBy"),Iv=Symbol("hasColumns"),Ty=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[Rv](),this[Nv](),this[yv]()}[Rv](){if(this[Iv]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[gy](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[gy](t.table)})}}[Iv](){let t=!1,r=new my(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[gy](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=p6();if(!r[t.databaseid])throw Sv(new Error,Tv.SCHEMA_NOT_FOUND(t.databaseid),Av.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw Sv(new Error,Tv.TABLE_NOT_FOUND(t.databaseid,t.tableid),Av.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=Ey(s);i.table=Ey(t),this.attributes.push(i)})}[iE](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)}[Nv](){let t=new my(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[Ov](r.tableid)}[Ov](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new f6.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[yv](){this[u_](this.statement.columns,!1),this[u_](this.statement.joins,!1),this[u_](this.statement.where,!1),this[wv](this.statement.group,!1),this[u_](this.statement.order,!0)}[u_](t,r){if(!t)return;let n=new my(t),s=[];for(let{node:i,path:o}of n)!gv.isEmpty(i)&&!gv.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[bv](i):s.push(this[Sy](i)));return s}[wv](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&h6.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=Ey(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[iE](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[iE](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`}[bv](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[Sy](t)}[Sy](t){let r=this[iE](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]}};Cv.exports=Ty});var vv=w(($Oe,Mv)=>{"use strict";var Dv=require("lodash"),d_=require("mathjs"),m6=require("jsonata"),Lv=ie();Mv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?Dv.uniqWith(e,Dv.isEqual):e,"distinct_array"),searchJSON:E6,mad:f_.bind(null,d_.mad),mean:f_.bind(null,d_.mean),mode:f_.bind(null,d_.mode),prod:f_.bind(null,d_.prod),median:f_.bind(null,d_.median)};function f_(e,t,r,n){return n===1?t==null?[]:[t]:n===2?(t!=null&&r.push(t),r):r!=null&&r.length>0?e(r):null}a(f_,"aggregateFunction");function E6(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(Lv.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),Lv.isEmpty(this.__ala__.res[r])){let n=m6(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(E6,"searchJSON")});var xv=w((KOe,Uv)=>{"use strict";var er=require("moment"),Ay="YYYY-MM-DDTHH:mm:ss.SSSZZ";er.suppressDeprecationWarnings=!0;Uv.exports={current_date:a(()=>er().utc().format("YYYY-MM-DD"),"current_date"),current_time:a(()=>er().utc().format("HH:mm:ss.SSS"),"current_time"),extract:a((e,t)=>{switch(t.toLowerCase()){case"year":return er(e).utc().format("YYYY");case"month":return er(e).utc().format("MM");case"day":return er(e).utc().format("DD");case"hour":return er(e).utc().format("HH");case"minute":return er(e).utc().format("mm");case"second":return er(e).utc().format("ss");case"millisecond":return er(e).utc().format("SSS");default:break}},"extract"),date:a(e=>er(e).utc().format(Ay),"date"),date_format:a((e,t)=>er(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>er(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>er(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=er(e).utc(),s=er(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>er().utc().valueOf(),"now"),get_server_time:a(()=>er().format(Ay),"get_server_time"),offset_utc:a((e,t)=>er(e).utc().utcOffset(t).format(Ay),"offset_utc")}});var Fv=w((WOe,kv)=>{"use strict";var g6=require("@turf/area"),S6=require("@turf/length"),T6=require("@turf/circle"),A6=require("@turf/difference"),R6=require("@turf/distance"),y6=require("@turf/boolean-contains"),b6=require("@turf/boolean-equal"),O6=require("@turf/boolean-disjoint"),N6=require("@turf/helpers"),Bv=(H(),C(G)),Ge=ie(),mo=z();kv.exports={geoArea:w6,geoLength:I6,geoCircle:C6,geoDifference:P6,geoDistance:Hv,geoNear:D6,geoContains:L6,geoEqual:M6,geoCrosses:v6,geoConvert:U6};function w6(e){if(Ge.isEmpty(e))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return g6.default(e)}catch(t){return mo.trace(t,e),NaN}}a(w6,"geoArea");function I6(e,t){if(Ge.isEmpty(e))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return S6.default(e,{units:t||"kilometers"})}catch(r){return mo.trace(r,e),NaN}}a(I6,"geoLength");function C6(e,t,r){if(Ge.isEmpty(e))return NaN;if(Ge.isEmpty(t))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return T6.default(e,t,{units:r||"kilometers"})}catch(n){return mo.trace(n,e,t),NaN}}a(C6,"geoCircle");function P6(e,t){if(Ge.isEmpty(e))return NaN;if(Ge.isEmpty(t))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return A6(e,t)}catch(r){return mo.trace(r,e,t),NaN}}a(P6,"geoDifference");function Hv(e,t,r){if(Ge.isEmpty(e))return NaN;if(Ge.isEmpty(t))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return R6.default(e,t,{units:r||"kilometers"})}catch(n){return mo.trace(n,e,t),NaN}}a(Hv,"geoDistance");function D6(e,t,r,n){if(Ge.isEmpty(e)||Ge.isEmpty(t))return!1;if(Ge.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return Hv(e,t,n)<=r}catch(s){return mo.trace(s,e,t),!1}}a(D6,"geoNear");function L6(e,t){if(Ge.isEmpty(e)||Ge.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return y6.default(e,t)}catch(r){return mo.trace(r,e,t),!1}}a(L6,"geoContains");function M6(e,t){if(Ge.isEmpty(e)||Ge.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return b6.default(e,t)}catch(r){return mo.trace(r,e,t),!1}}a(M6,"geoEqual");function v6(e,t){if(Ge.isEmpty(e)||Ge.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return!O6.default(e,t)}catch(r){return mo.trace(r,e,t),!1}}a(v6,"geoCrosses");function U6(e,t,r){if(Ge.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(Ge.isEmpty(t))throw new Error("geo_type is required");if(Ge.isEmpty(Bv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(Bv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ge.autoCastJSON(e)),N6[t](e,r)}a(U6,"geoConvert")});var oE=w((jOe,Gv)=>{var Fc=vv(),$n=xv(),Mi=Fv();Gv.exports=e=>{e.aggr.mad=e.aggr.MAD=Fc.mad,e.aggr.mean=e.aggr.MEAN=Fc.mean,e.aggr.mode=e.aggr.MODE=Fc.mode,e.aggr.prod=e.aggr.PROD=Fc.prod,e.aggr.median=e.aggr.MEDIAN=Fc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Fc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Fc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=$n.current_date,e.fn.current_time=e.fn.CURRENT_TIME=$n.current_time,e.fn.extract=e.fn.EXTRACT=$n.extract,e.fn.date=e.fn.DATE=$n.date,e.fn.date_format=e.fn.DATE_FORMAT=$n.date_format,e.fn.date_add=e.fn.DATE_ADD=$n.date_add,e.fn.date_sub=e.fn.DATE_SUB=$n.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=$n.date_diff,e.fn.now=e.fn.NOW=$n.now,e.fn.offset_utc=e.fn.OFFSET_UTC=$n.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=$n.get_server_time,e.fn.getdate=e.fn.GETDATE=$n.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=$n.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Mi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Mi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Mi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Mi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Mi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Mi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Mi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Mi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Mi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Mi.geoNear}});var Kv=w((JOe,Vv)=>{"use strict";var __=require("lodash"),Sn=require("alasql");Sn.options.cache=!1;var x6=oE(),qv=require("clone"),aE=require("recursive-iterator"),Ue=z(),We=ie(),wu=Vn(),B6=(H(),C(G)),{hdb_errors:H6}=pe(),{getDatabases:$v}=(Pe(),C(tt)),k6="IS NULL",Zs="There was a problem performing this search. Please check the logs and try again.";x6(Sn);var Ry=class{static{a(this,"SQLSearch")}constructor(t,r){if(We.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(),We.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!We.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(Zs)}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(Zs)}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(Zs)}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(Zs)}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(Zs)}}_getColumns(){let t=new aE(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(qv(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=__.uniqBy(t,r=>[r.databaseid,r.tableid,r.as].join()),this.tables.forEach(r=>{let n=`${r.databaseid}_${r.as?r.as:r.tableid}`;this.data[n]={},this.data[n].__hash_name=$v()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(We.isEmpty(this.statement.where)){Ue.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new aE(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!We.isEmpty(r)&&r.right)if(We.isNotEmptyAndHasValue(r.right.value)){let n=We.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new Sn.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=We.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new Sn.yy.LogicValue({value:i}):n instanceof Sn.yy.StringValue&&We.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Sn.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 aE(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(!We.isEmpty(B6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(We.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(We.isEmptyOrZeroLength(r.left.columnid)||We.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(We.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"=":!We.isEmpty(r.right.value)||!We.isEmpty(r.left.value)?n.add(We.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(We.isEmptyOrZeroLength(this.all_table_attributes)&&We.isEmptyOrZeroLength(this.statement.from)&&We.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((n,s)=>{if(n.columnid==="*"){t.push(s);return}if(n.aggregatorid&&(this.has_aggregator=!0),!n.aggregatorid&&!n.funcid)if(n.as_orig=n.as?n.as:n.columnid,this.statement.joins)if(r[n.as_orig]>=0){let i=r[n.as_orig]+1;n.as=`[${n.as_orig+i}]`,r[n.as_orig]=i}else n.as=`[${n.as_orig}]`,r[n.as_orig]=0;else n.as=`[${n.as_orig}]`;!n.aggregatorid&&n.funcid&&n.args&&(n.as_orig=n.as?n.as:n.toString().replace(/'/g,'"'),n.as=`[${n.as_orig}]`),n.aggregatorid&&n.expression.columnid!=="*"&&(n.as_orig=n.as?n.as:n.expression.tableid?`${n.aggregatorid}(${n.expression.tableid}.${n.expression.columnid})`:`${n.aggregatorid}(${n.expression.columnid})`,n.as=`[${n.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&__.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(We.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);We.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(We.isEmptyOrZeroLength(this.all_table_attributes)&&!We.isEmptyOrZeroLength(this.columns.columns))return t;if(We.isEmptyOrZeroLength(this.all_table_attributes)&&We.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await Sn.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(qv(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(We.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(k6)>-1&&this.tables.forEach(s=>{let i={columnid:$v()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=__.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,u=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!We.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!We.isEmptyOrZeroLength(this.exact_search_values[u].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[u].values);let f=await wu.getDataByHash(c);for(let d of c.hash_values)f.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(f){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(f),new Error(Zs)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async f=>{let d={...c};d.search_value=f;let p=await wu.getDataByValue(d);for(let[_,h]of p)this.data[i].__merged_data[_]?this._updateMergedAttribute(i,_,s.attribute,h[s.attribute]):(this.data[i].__merged_data[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,_))}))}catch(f){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(f),new Error(Zs)}else if(!We.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!We.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let f=this.comparator_search_values[u].comparators;for(let d=0,p=f.length;d<p;d++){let _=f[d];c.search_attribute=_.attribute,c.search_value=_.search_value;let h=await wu.getDataByValue(c,_.operation);if(l)for(let[S]of h)this.data[i].__merged_data[S]||(this.data[i].__merged_data[S]=[...n[i]],this._setMergedHashAttribute(i,S));else for(let[S,g]of h)this.data[i].__merged_data[S]?this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]):(this.data[i].__merged_data[S]=[...n[i]],this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]),this._setMergedHashAttribute(i,S))}}catch(f){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),Ue.error(f),new Error(Zs)}else try{c.search_attribute=s.attribute,c.search_value="*";let f=await wu.getDataByValue(c);if(l)for(let[d]of f)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,p]of f)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,p[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,p[s.attribute]),this._setMergedHashAttribute(i,d))}catch(f){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),Ue.error(f),new Error(Zs)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof Sn.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 Sn.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new Sn.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 Sn.yy.FuncValue:new Sn.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(_=>{_.joinmode&&_.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(_.table);let h=_.joinmode+" JOIN ? AS "+(_.as?_.as:_.table.tableid);_.on&&(h+=" ON "+_.on.toString()),i.push(h),t.push(Object.values(this.data[`${_.table.databaseid_orig}_${_.table.as?_.table.as_orig:_.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(_=>{let h=this.data[`${_.databaseid_orig}_${_.as?_.as_orig:_.tableid_orig}`].__hash_name,S=_.as?_.as_orig:_.tableid_orig;o.push({key:`'${S}.${h}'`,schema:_.databaseid_orig,table:_.as?_.as_orig:_.tableid_orig,keys:new Set}),r.push(`${_.as?_.as:_.tableid}.\`${h}\` AS "${S}.${h}"`),c[_.as?_.as_orig:_.tableid_orig]=this.data[`${_.databaseid_orig}_${_.as?_.as_orig:_.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let u="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(u="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(_=>{_.is_func?r.push(_.initial_select_column.toString()):_.initial_select_column.tableid?r.push(`${_.initial_select_column.tableid}.${_.initial_select_column.columnid} AS ${_.expression.columnid}`):r.push(`${_.initial_select_column.columnid} AS ${_.expression.columnid}`)}));let f="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(f=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let p=[];try{let _=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${u} ${f} ${d}`,h=this._convertColumnsToIndexes(_,s);p=await Sn.promise(h,t),t=null}catch(_){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),Ue.error(_),new Error("There was a problem processing the data.")}if(p&&p.length>0){for(let _=0,h=p.length;_<h;_++){let S=p[_];o.forEach(g=>{S[g.key]!==null&&S[g.key]!==void 0&&g.keys.add(S[g.key])})}o.forEach(_=>{let h=Object.keys(this.data[`${_.schema}_${_.table}`].__merged_data),S=__.difference(h,[..._.keys].map(g=>g.toString()));for(let g=0,R=S.length;g<R;g++){let E=S[g];delete this.data[`${_.schema}_${_.table}`].__merged_data[E]}})}return{existing_attributes:c,joined_length:p?p.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new aE(this.columns);for(let{node:i}of s)if(i&&i.columnid){let o=this._findColumn(i);if(o){let c=o.table.as?o.table.as:o.table.tableid;(!t[c]||t[c].indexOf(o.attribute)<0)&&n.push(o)}}n=__.uniqBy(n,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(n)}catch(i){throw Ue.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),Ue.error(i),new Error(Zs)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__merged_data,o=[];for(let f in i)o.push(i[f][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await wu.getDataByHash(c),u=s.columns.length;for(let f=0,d=o.length;f<d;f++){let p=o[f],_=l.get(p);for(let h=0;h<u;h++){let S=s.columns[h],g=_[S]===void 0?null:_[S];this.data[n].__merged_data[p].push(g)}}}}catch(r){throw 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 Sn.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(H6.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"),f=`${l}.[${c}]`;n=n.replace(u,f)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),u=`[${c}]`;n=n.replace(l,u)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await wu.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(Zs)}}return Object.values(Object.values(this.data)[0].__merged_data)}};Vv.exports=Ry});var Yr=w((XOe,Yv)=>{"use strict";var F6=Pv();Yv.exports={searchByConditions:q6,searchByHash:$6,searchByValue:V6,search:K6};var yy=Vn(),{transformReq:by}=ie(),G6=Kv();async function q6(e){return by(e),yy.searchByConditions(e)}a(q6,"searchByConditions");async function $6(e){by(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of yy.searchByHash(e))r&&t.push(r);return t}a($6,"searchByHash");async function V6(e){by(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of yy.searchByValue(e))t.push(r);return t}a(V6,"searchByValue");function K6(e,t){try{let r=new F6(e);r.validate(),new G6(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(K6,"search")});var Eo=w((eNe,Jv)=>{"use strict";var p_=require("crypto"),Y6=ae(),{CONFIG_PARAMS:W6}=(H(),C(G)),zv="aes-256-cbc",z6=32,j6=16,Oy=64,jv=32,J6=Oy+jv,Wv=new Map;Jv.exports={encrypt:Q6,decrypt:X6,createNatsTableStreamName:Z6};function Q6(e){let t=p_.randomBytes(z6),r=p_.randomBytes(j6),n=p_.createCipheriv(zv,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(Q6,"encrypt");function X6(e){let t=e.substr(0,Oy),r=e.substr(Oy,jv),n=e.substr(J6,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=p_.createDecipheriv(zv,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(X6,"decrypt");function Z6(e,t){let r=Y6.get(W6.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=Wv.get(r);return n||(n=p_.createHash("md5").update(r).digest("hex"),Wv.set(r,n)),n}a(Z6,"createNatsTableStreamName")});var go=w((nNe,eU)=>{"use strict";var rNe=Yr(),h_=z(),{validateBySchema:Qv}=it(),Gc=require("joi"),eZ=Eo(),cE=ie(),{handleHDBError:lE,hdb_errors:tZ,ClientError:Xv}=pe(),{HDB_ERROR_MSGS:uE,HTTP_STATUS_CODES:Ny}=tZ,Zv=ae();Zv.initSync();var{getDatabases:wy}=(Pe(),C(tt)),rZ=require("fs-extra"),nZ=(H(),C(G));eU.exports={describeAll:sZ,describeTable:dE,describeSchema:iZ};async function sZ(e={}){try{let t=cE.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=wy(),o={},c={},l=[],u=e?.exact_count;for(let d in i){o[d]=!0,!t&&!s&&!r&&(c[d]=e.hdb_user?.role?.permission[d]?.describe);let p=i[d];for(let _ in p)try{let h;if(t||s||r)h=await dE({schema:d,table:_,exact_count:u});else if(n&&n[d].describe&&n[d].tables[_].describe){let S=n[d].tables[_].attribute_permissions;h=await dE({schema:d,table:_,exact_count:u},S)}h&&l.push(h)}catch(h){h_.error(h)}}let f={};for(let d in l)t||s||r?(f[l[d].schema]==null&&(f[l[d].schema]={}),f[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]):c[l[d].schema]&&(f[l[d].schema]==null&&(f[l[d].schema]={}),f[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]);for(let d in o)t||s||r?f[d]={}:c[d]&&(f[d]={});return f}catch(t){return h_.error("Got an error in describeAll"),h_.error(t),lE(new Error,uE.DESCRIBE_ALL_ERR)}}a(sZ,"describeAll");async function dE(e,t){cE.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=Qv(e,Gc.object({database:Gc.string(),table:Gc.string().required(),exact_count:Gc.boolean().strict()}));if(i)throw new Xv(i.message);let c=wy()[r];if(!c)throw lE(new Error,uE.SCHEMA_NOT_FOUND(e.schema),Ny.NOT_FOUND);let l=c[n];if(!l)throw lE(new Error,uE.TABLE_NOT_FOUND(e.schema,e.table),Ny.NOT_FOUND);function u(_){f.push({attribute:_.attribute,type:_.type,elements:_.elements?.type,indexed:_.indexed,is_primary_key:_.isPrimaryKey,assigned_created_time:_.assignCreatedTime,assigned_updated_time:_.assignUpdatedTime,nullable:_.nullable,properties:_.properties?_.properties.map(h=>({type:h.type,name:h.name})):void 0})}a(u,"pushAtt");let f=[];if(s){let _={};s.forEach(h=>{h.describe&&(_[h.attribute_name]=!0)}),l.attributes.forEach(h=>{_[h.name]&&u(h)})}else l.attributes?.forEach(_=>u(_));let d;try{d=(await rZ.stat(l.primaryStore.env.path)).size}catch(_){h_.warn("unable to get database size",_)}let p={schema:r,name:l.tableName,hash_attribute:l.attributes.find(_=>_.isPrimaryKey||_.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:f,db_size:d};l.replicate!==void 0&&(p.replicate=l.replicate),l.expirationMS!==void 0&&(p.expiration=l.expirationMS/1e3+"s"),l.sealed!==void 0&&(p.sealed=l.sealed),l.sources?.length>0&&(p.sources=l.sources.map(_=>_.name).filter(_=>_&&_!=="NATSReplicator"&&_!=="Replicator")),Zv.get(nZ.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(p.clustering_stream_name=eZ.createNatsTableStreamName(p.schema,p.name));try{let _=await l.getRecordCount({exactCount:!!e.exact_count});p.record_count=_.recordCount,p.table_size=l.getSize(),p.db_audit_size=l.getAuditSize(),p.estimated_record_range=_.estimatedRange;let h=l.auditStore;if(h)for(let S of h.getKeys({reverse:!0,limit:1}))p.last_updated_record=S[0];if(!p.last_updated_record&&l.indices.__updatedtime__)for(let S of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))p.last_updated_record=S}catch(_){h_.warn(`unable to stat table dbi due to ${_}`)}return p}a(dE,"descTable");async function iZ(e){cE.transformReq(e);let t=Qv(e,Gc.object({database:Gc.string(),exact_count:Gc.boolean().strict()}));if(t)throw new Xv(t.message);let r;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(r=e.hdb_user?.role?.permission[e.schema]);let n=e.schema.toString(),i=wy()[n];if(!i)throw lE(new Error,uE.SCHEMA_NOT_FOUND(e.schema),Ny.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),cE.isEmpty(l)||l.describe){let u=await dE({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(iZ,"describeSchema")});var As=w((aNe,iU)=>{var oZ=po(),{callbackify:rU,promisify:aZ}=require("util"),{getDatabases:nU}=(Pe(),C(tt));iU.exports={setSchemaDataToGlobal:tU,getTableSchema:cZ,getSystemSchema:lZ,setSchemaDataToGlobalAsync:aZ(tU)};var sU=go(),iNe=rU(sU.describeAll),oNe=rU(sU.describeTable);function tU(e){global.hdb_schema=nU(),e&&e()}a(tU,"setSchemaDataToGlobal");function cZ(e,t,r){let n=nU()[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(cZ,"getTableSchema");function lZ(){return oZ}a(lZ,"getSystemSchema")});var Cy=w((lNe,cU)=>{var uZ=it(),Iy=require("joi"),{hdb_table:dZ,hdb_database:oU}=Di(),aU={schema:oU,database:oU,table:dZ},fZ={date:Iy.date().iso().required()},_Z={timestamp:Iy.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};cU.exports=function(e,t){let r=t==="timestamp"?{...aU,..._Z}:{...aU,...fZ},n=Iy.object(r);return uZ.validateBySchema(e,n)}});var dU=w((uNe,uU)=>{var pZ=it(),Py=require("joi"),{hdb_table:hZ,hdb_database:lU}=Di(),mZ=Py.object({schema:lU,database:lU,table:hZ,hash_values:Py.array().required(),ids:Py.array()});uU.exports=function(e){return pZ.validateBySchema(e,mZ)}});var vy=w((dNe,fU)=>{"use strict";var Dy=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}},Ly=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}},My=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};fU.exports={InsertObject:Dy,NoSQLSeachObject:Ly,DeleteResponseObject:My}});var Vc=w((_Ne,EU)=>{"use strict";var pU=Cy(),EZ=dU(),qc=ie(),_U=require("moment"),hU=z(),{promisify:gZ,callbackify:SZ}=require("util"),$c=(H(),C(G)),TZ=As(),Uy=gZ(TZ.getTableSchema),xy=Vn(),{DeleteResponseObject:AZ}=vy(),{handleHDBError:ba,hdb_errors:RZ}=pe(),{HDB_ERROR_MSGS:fE,HTTP_STATUS_CODES:Oa}=RZ,yZ="records successfully deleted",bZ=SZ(mU);EU.exports={delete:bZ,deleteRecord:mU,deleteFilesBefore:OZ,deleteAuditLogsBefore:NZ};async function OZ(e){let t=pU(e,"date");if(t)throw ba(t,t.message,Oa.BAD_REQUEST,void 0,void 0,!0);if(qc.transformReq(e),!_U(e.date,_U.ISO_8601).isValid())throw ba(new Error,fE.INVALID_DATE,Oa.BAD_REQUEST,$c.LOG_LEVELS.ERROR,fE.INVALID_DATE,!0);let n=qc.checkSchemaTableExist(e.schema,e.table);if(n)throw ba(new Error,n,Oa.NOT_FOUND,$c.LOG_LEVELS.ERROR,n,!0);let s=await xy.deleteRecordsBefore(e);if(await Uy(e.schema,e.table),hU.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(OZ,"deleteFilesBefore");async function NZ(e){let t=pU(e,"timestamp");if(t)throw ba(t,t.message,Oa.BAD_REQUEST,void 0,void 0,!0);if(qc.transformReq(e),isNaN(e.timestamp))throw ba(new Error,fE.INVALID_VALUE("Timestamp"),Oa.BAD_REQUEST,$c.LOG_LEVELS.ERROR,fE.INVALID_VALUE("Timestamp"),!0);let r=qc.checkSchemaTableExist(e.schema,e.table);if(r)throw ba(new Error,r,Oa.NOT_FOUND,$c.LOG_LEVELS.ERROR,r,!0);let n=await xy.deleteAuditLogsBefore(e);return await Uy(e.schema,e.table),hU.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(NZ,"deleteAuditLogsBefore");async function mU(e){e.ids&&(e.hash_values=e.ids);let t=EZ(e);if(t)throw ba(t,t.message,Oa.BAD_REQUEST,void 0,void 0,!0);qc.transformReq(e);let r=qc.checkSchemaTableExist(e.schema,e.table);if(r)throw ba(new Error,r,Oa.NOT_FOUND,$c.LOG_LEVELS.ERROR,r,!0);try{await Uy(e.schema,e.table);let n=await xy.deleteRecords(e);return qc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${yZ}`),n}catch(n){if(n.message===$c.SEARCH_NOT_FOUND_MESSAGE){let s=new AZ;return s.message=$c.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(mU,"deleteRecord")});var _E={};ve(_E,{HASH_FUNCTION:()=>g_,hash:()=>ky,validate:()=>Fy});function By(e=E_){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(m_.randomBytes(e)).map(r=>t[r%t.length]).join("")}function ky(e,t=g_[SU?.toUpperCase()]??"sha256"){return Hy[t](e)}function Fy(e,t,r=g_[SU?.toUpperCase()]??"sha256"){return e?wZ[r](e,t):!1}var m_,Iu,gU,SU,E_,TU,g_,Hy,wZ,pE=be(()=>{m_=M(require("node:crypto")),Iu=M(require("argon2")),gU=M(ae());H();SU=(0,gU.get)(B.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),E_=16,TU=9,g_=(n=>(n.MD5="md5",n.SHA256="sha256",n.ARGON2ID="argon2id",n))(g_||{});a(By,"generateSalt");Hy={md5:a((e,t=void 0)=>{t=t??By(TU);let r=m_.createHash("md5").update(e+t).digest("hex");return t+r},"md5"),sha256:a((e,t=void 0)=>{t=t??By(E_);let r=m_.createHash("sha256").update(e+t).digest("hex");return t+r},"sha256"),argon2id:a(async e=>{let t=By(E_),r=await Iu.hash(e,{type:Iu.argon2id,salt:Buffer.from(t)});return t+r},"argon2id")},wZ={md5:a((e,t)=>{let r=e.slice(0,TU);return e===Hy.md5(t,r)},"md5"),sha256:a((e,t)=>{let r=e.slice(0,E_);return e===Hy.sha256(t,r)},"sha256"),argon2id:a(async(e,t)=>await Iu.verify(e.slice(E_),t),"argon2id")};a(ky,"hash");a(Fy,"validate")});var RU=w((ENe,AU)=>{var Gy=it(),Wr={username:{presence:!0,exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function IZ(e){return Wr.password.presence=!0,Wr.username.presence=!0,Wr.role.presence=!0,Wr.active.presence=!0,Gy.validateObject(e,Wr)}a(IZ,"addUserValidation");function CZ(e){return Wr.password.presence=!1,Wr.username.presence=!0,Wr.role.presence=!1,Wr.active.presence=!1,Gy.validateObject(e,Wr)}a(CZ,"alterUserValidation");function PZ(e){return Wr.password.presence=!1,Wr.username.presence=!0,Wr.role.presence=!1,Wr.active.presence=!1,Gy.validateObject(e,Wr)}a(PZ,"dropUserValidation");AU.exports={addUserValidation:IZ,alterUserValidation:CZ,dropUserValidation:PZ}});var Tt=w((TNe,bU)=>{"use strict";var{platform:SNe}=require("os"),DZ="nats-server.zip",qy="nats-server",LZ=process.platform==="win32"?`${qy}.exe`:qy,MZ=/^[^\s.,*>]+$/,yU="__request__",vZ=a(e=>`${e}.${yU}`,"REQUEST_SUBJECT"),UZ={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},xZ={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},BZ={HUB:"hub.pid",LEAF:"leaf.pid"},HZ={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},kZ={SUCCESS:"success",ERROR:"error"},FZ={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},GZ={TXN:"txn",MSGID:"msgid"},Cu={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},qZ={[Cu.ERR]:1,[Cu.WRN]:2,[Cu.INF]:3,[Cu.DBG]:4,[Cu.TRC]:5},$Z={debug:"-D",trace:"-DVV"};bU.exports={NATS_SERVER_ZIP:DZ,NATS_SERVER_NAME:qy,NATS_BINARY_NAME:LZ,PID_FILES:BZ,NATS_CONFIG_FILES:xZ,SERVER_SUFFIX:HZ,NATS_TERM_CONSTRAINTS_RX:MZ,REQUEST_SUFFIX:yU,UPDATE_REMOTE_RESPONSE_STATUSES:kZ,CLUSTER_STATUS_STATUSES:FZ,REQUEST_SUBJECT:vZ,SUBJECT_PREFIXES:GZ,MSG_HEADERS:UZ,LOG_LEVELS:Cu,LOG_LEVEL_FLAGS:$Z,LOG_LEVEL_HIERARCHY:qZ}});var $y=w(OU=>{"use strict";var VZ={cert:"-----BEGIN CERTIFICATE-----\rMIIDXDCCAkSgAwIBAgIFNTE4MzQwDQYJKoZIhvcNAQELBQAwXTEXMBUGA1UEAxMO\rSGFycGVyREIsIEluYy4xCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDTzEPMA0GA1UE\rBxMGRGVudmVyMRcwFQYDVQQKEw5IYXJwZXJEQiwgSW5jLjAeFw0yMjAzMTEyMzAz\rNDlaFw0yNzAzMTAyMzAzNDlaMF0xFzAVBgNVBAMTDkhhcnBlckRCLCBJbmMuMQsw\rCQYDVQQGEwJVUzELMAkGA1UECBMCQ08xDzANBgNVBAcTBkRlbnZlcjEXMBUGA1UE\rChMOSGFycGVyREIsIEluYy4wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB\rAQCsEUlBF8WImS78rCFXVKyntxfrW++4qZ3hGnoD2MHZAuDHyeP/5eGnaE9GQhKc\r4DwG4DGvh0wP2zIYnBfiQ3L2ZtnlDR9ZkKIQYGlVxTUn6T43krhK5nZKqDF43Yg3\rZEvO3cbJBjiKZx0eA2/toehdSsTAHHQx5gTDcggNe2tgoJHYPwi9YF/AxSBZrbgb\ryWlYgtYDmF32ytHP03GUCIdKOFuBPsHTGu4SkdEIdLIqO9oglW1YFH5qZ6NiwApW\rsP+GCuqOwDXXbdjr75iq9Tq/CDrjGFLaTPmvd2Q0qG/BtaCll0ghpG+yIHvt/iQs\rajS+LxEWAnVlGMaDdFErbDUtAgMBAAGjIzAhMA8GA1UdEwEB/wQFMAMBAf8wDgYD\rVR0PAQH/BAQDAgIEMA0GCSqGSIb3DQEBCwUAA4IBAQASR4YW/rPK7PNArHVe9zzM\rb0rKNX/2T9/0nybRhmE/+hdlSgliTAeebmwkUS2APckmekYt/q2ZY2NS65Fo/jjp\rG8TJrtcF4h+ylVqUp0ZXQLFtIsr7r2JZA7hJ6njW6G4DHSZ0gxtECLi4CBlTjzm5\rNmnmIDObvGRTuqmcdAZmXeObbta/He2XIzietukPAYX062pNM+G5XT5UM1eG/Vlp\rN86vjhpyI+ffKy+C60SJqxmKM3ydgN7oLscE7+2wLPN25XqN4W99OwGsp5dTdu/f\r5lPtFayXdJ55e/sNQKmGN+UGLrL05c2MWgjb8U/LFilnupUianceoeSERZmVjzKX\r-----END CERTIFICATE-----\r".replace(/\r/g,`\r
17
+ `},"serialize"),compressible:!1,q:.8});Kr.set("application/x-www-form-urlencoded",{deserialize(e){let t=Buffer.isBuffer(e)?e.toString("utf8"):e,r={};for(let[n,s]of new URLSearchParams(t))if(r.hasOwnProperty(n)){let i=r[n];Array.isArray(i)?i.push(s):r.key=[i,s]}else r[n]=s;return r},serialize(e){let t=new URLSearchParams;for(let r in e)t.set(r,e);return t.toString()}});uM={type:"application/json",serializeStream:$f,serialize:Wf,deserialize:w3,q:.5};Kr.set("*/*",uM);Kr.set("",uM);a(w3,"tryJSONParse");a(jf,"registerContentHandlers");I3=require("fastify-plugin"),C3=I3(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=$m(n.raw);s.type(c),s.serializer(function(l){let u;if(typeof l=="object"&&l&&(l[Symbol.iterator]||l[Symbol.asyncIterator])&&o.serializeStream){if(l.mapError){let f=l.getColumns;l=l.mapError(d=>(d.toJSON=()=>({error:d.name,message:d.message,...d.partialObject}),d)),l.getColumns=f}u=o.serializeStream}else u=o.serialize;return u(l,{headers:{set:a((f,d)=>{s.header(f,d)},"set")}})})}),r()},{name:"content-type-negotiation"});a($m,"findBestSerializer");iM=MR.default.get(x.HTTP_COMPRESSIONTHRESHOLD);a(Jf,"serialize");a(Aa,"serializeMessage");a(DR,"asyncSerialization");a(LR,"hasAsyncSerialization");a(P3,"streamToBuffer");D3=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(L3,"isBufferEncoding");a(M3,"parseContentType");a(uo,"getDeserializer");a(v3,"deserializerUnknownType");a(U3,"transformIterable");a(qm,"toCsvStream")});var HR={};ve(HR,{start:()=>V3});function x3(e){if(e.kind!==Le.Kind.OPERATION_DEFINITION&&e.kind!==Le.Kind.FRAGMENT_DEFINITION)throw new Or(`Unexpected non-executable definition type ${e.kind}.`)}function fM(e){if(typeof e!="object"||e===null)throw new Ci("Request body must be an object.");if(!("query"in e))throw new Ci("Request body must contain a `query` field.");if(typeof e.query!="string")throw new Ci("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new Ci("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new Ci("Request body `operationName` field must be a string.")}function BR(e){return parseInt(e.value,10)}function pM(e){return parseFloat(e.value)}function hM(e,t,r){let n=r.get(e.name.value);return mM(n)?EM(n,t):{attribute:t,value:n}}function mM(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function EM(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],mM(n)?EM(n,t):{attribute:t,value:n}))}function B3(e,t,r){switch(t=[...t,e.name.value],e.value.kind){case Le.Kind.NULL:return{attribute:t,value:null};case Le.Kind.INT:return{attribute:t,value:BR(e.value)};case Le.Kind.FLOAT:return{attribute:t,value:pM(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:t,value:e.value.value};case Le.Kind.VARIABLE:return hM(e.value,t,r);case Le.Kind.OBJECT:return gM(e.value,t,r);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Or(`Value type, ${e.value.kind}, is not supported.`)}}function gM(e,t,r){return e.fields.flatMap(n=>B3(n,t,r))}function H3(e,t){switch(e.value.kind){case Le.Kind.NULL:return{attribute:e.name.value,value:null};case Le.Kind.INT:return{attribute:e.name.value,value:BR(e.value)};case Le.Kind.FLOAT:return{attribute:e.name.value,value:pM(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Le.Kind.VARIABLE:return hM(e.value,e.name.value,t);case Le.Kind.OBJECT:return gM(e.value,[e.name.value],t);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Or(`Argument type, ${e.value.kind}, is not supported.`)}}function k3(e,t){return e.flatMap(r=>H3(r,t))}function Vm(e,t){return e.selections.flatMap(r=>{switch(r.kind){case Le.Kind.FIELD:return r;case Le.Kind.FRAGMENT_SPREAD:{let n=r.name.value,s=t.get(n);if(s==null)throw new Or(`Fragment \`${n}\` not found.`);return Vm(s.selectionSet,t)}case Le.Kind.INLINE_FRAGMENT:return Vm(r.selectionSet,t)}})}function SM(e,t){return Vm(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:SM(r.selectionSet,t)}:r.name.value)}async function F3(e,t,r,n){let s=Oi.getMatch(e.name.value,"graphql");if(s===void 0)throw new Or(`Resource \`${e.name.value}\` not found.`);let i=s.Resource,o={select:SM(e.selectionSet,r),conditions:k3(e.arguments,t)},c=[];n.authorize=!0;for await(let l of i.search(o,n))c.push(l);return[e.name.value,c]}function TM(e){switch(e.kind){case Le.Kind.NULL:return null;case Le.Kind.INT:return BR(e);case Le.Kind.FLOAT:return parseFloat(e.value);case Le.Kind.STRING:case Le.Kind.BOOLEAN:return e.value;case Le.Kind.OBJECT:return e.fields.reduce((t,r)=>({[r.name.value]:TM(r.value),...t}),{});case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Or(`Value type, ${e.kind}, is not supported.`)}}function G3(e,t){let r=new Map;for(let n of e){let s=n.variable.name.value,i=t?.[s];if(i===void 0&&n.defaultValue!==void 0&&(i=TM(n.defaultValue)),n.type.kind===Le.Kind.NON_NULL_TYPE&&!(s in t)&&i===void 0)throw new Or(`Variable $${s} is required, but not provided.`);r.set(n.variable.name.value,i??null)}return r}async function q3(e,t,r,n){if(e.operation===Le.OperationTypeNode.SUBSCRIPTION)throw new Or("Subscriptions are not supported.");if(e.operation===Le.OperationTypeNode.MUTATION)throw new Or("Mutations are not supported yet.");let s=G3(e.variableDefinitions,t),i=await Promise.all(Vm(e.selectionSet,r).map(c=>F3(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function _M({query:e,variables:t={},operationName:r},n){let s=Le.parse(e),i=new Map,o=new Map;for(let u of s.definitions)if(x3(u),u.kind===Le.Kind.FRAGMENT_DEFINITION)o.set(u.name.value,u);else{if(u.name===void 0&&s.definitions.length>1)throw new Or("Unnamed operations are only allowed when there is a single operation in the document.");let f=u.name?.value??"Unnamed Query";if(i.has(f))throw new Or(`Duplicate operation definition: ${f}`);i.set(f,u)}let c;if(r==null)if(i.size===1)c=i.entries().next().value[1];else throw new Or("Operation name is required when there are multiple operations in the document.");else if(c=i.get(r),c==null)throw new Or(`Operation \`${r}\` not found.`);let l=await q3(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function $3(e){switch(e.method){case"GET":{let t=new URLSearchParams(e.url.split("?")[1]),r={};for(let[n,s]of t)r[n]=n==="variables"||n==="extensions"?JSON.parse(s):s;return fM(r),_M(r,e)}case"POST":{let r=await uo(e.headers.get("content-type"),!0)(e._nodeRequest);return fM(r),_M(r,e)}default:throw new Ci("Method Not Allowed",405,{Allow:"GET, POST"})}}function V3(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await $3(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof Ci)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json",...n.headers}};if(n instanceof Le.GraphQLError)return{status:200,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/json"}};if(n instanceof Or)return{status:200,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};break}default:logger.info(`Unsupported accept header, ${s}, defaulting to application/graphql-response+json`);case"application/graphql-response+json":{if(n instanceof Ci)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json",...n.headers}};if(n instanceof Le.GraphQLError)return{status:400,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Or)return{status:400,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};break}}throw n}},{port:e.port,securePort:e.securePort})}var Le,Or,Ci,AM=be(()=>{Le=M(require("graphql"));ao();Tu();a(x3,"assertExecutableDefinitionNode");a(fM,"assertRequestParams");a(BR,"processIntValueNode");a(pM,"processFloatValueNode");a(hM,"processVariableNode");a(mM,"isObject");a(EM,"transformObjectIntoQueryCondition");a(B3,"processObjectFieldNode");a(gM,"processObjectValueNode");a(H3,"processArgumentNode");a(k3,"buildConditionsQuery");a(Vm,"fillInFragments");a(SM,"buildSelectQuery");a(F3,"processFieldNode");a(TM,"processConstValueNode");a(G3,"resolveVariables");a(q3,"executeOperation");a(_M,"resolver");Or=class extends Error{static{a(this,"GraphQLQueryingError")}},Ci=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a($3,"graphqlQueryingHandler");a(V3,"start")});var Di=w((jbe,bM)=>{"use strict";var yM=ie(),RM=(H(),C(G)),bu=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Pi=require("joi"),Ra={schema_format:{pattern:bu,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},K3=Pi.alternatives(Pi.string().min(1).max(Ra.schema_length.maximum).pattern(bu).messages({"string.pattern.base":"{:#label} "+Ra.schema_format.message}),Pi.number(),Pi.array()).required(),Y3=Pi.alternatives(Pi.string().min(1).max(Ra.schema_length.maximum).pattern(bu).messages({"string.pattern.base":"{:#label} "+Ra.schema_format.message}),Pi.number()),W3=Pi.alternatives(Pi.string().min(1).max(Ra.schema_length.maximum).pattern(bu).messages({"string.pattern.base":"{:#label} "+Ra.schema_format.message}),Pi.number()).required();function z3(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>Ra.schema_length.maximum?`'${e}' maximum of 250 characters`:bu.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(z3,"checkValidTable");function j3(e,t){return yM.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(j3,"validateSchemaExists");function J3(e,t){let r=t.state.ancestors[0].schema;return yM.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(J3,"validateTableExists");function Q3(e,t){return e.toLowerCase()===RM.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${RM.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(Q3,"validateSchemaName");bM.exports={common_validators:Ra,schema_regex:bu,hdb_schema_table:K3,validateSchemaExists:j3,validateTableExists:J3,validateSchemaName:Q3,checkValidTable:z3,hdb_database:Y3,hdb_table:W3}});var ot=w((Qbe,OM)=>{"use strict";var gn=require("validate.js");gn.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||gn.validators.type.checks[t](e)?null:` must be a '${t}' value`};gn.validators.type.checks={Object:a(function(e){return gn.isObject(e)&&!gn.isArray(e)},"Object"),Array:gn.isArray,Integer:gn.isInteger,Number:gn.isNumber,String:gn.isString,Date:gn.isDate,Boolean:a(function(e){return typeof e=="boolean"},"Boolean")};gn.validators.hasValidFileExt=function(e,t){return gn.isString(e)?e===""?"can't be blank":t.filter(r=>e.endsWith(r)).length>0?null:`must include one of the following valid file extensions - '${t.join("', '")}'`:null};OM.exports={validateObject:X3,validateObjectAsync:Z3,validateBySchema:eX};function X3(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=gn(e,t,{format:"flat"});return r?new Error(r):null}a(X3,"validateObject");async function Z3(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await gn.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(Z3,"validateObjectAsync");function eX(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(eX,"validateBySchema")});var FR=w((Zbe,wM)=>{var{hdb_table:tX,hdb_database:NM}=Di(),rX=ot(),kR=require("joi"),nX={undefined:"undefined",null:"null"},sX=a((e,t)=>{let r=Object.keys(e),n=r.length,s;for(let i=0;i<n;i++){let o=r[i];(!o||o.length===0||nX[o]!==void 0)&&(s===void 0?s=`Invalid attribute name: '${o}'`:s+=`. Invalid attribute name: '${o}'`)}return s?t.message(s):e},"custom_records_val"),iX=kR.object({database:NM,schema:NM,table:tX,records:kR.array().items(kR.object().custom(sX)).required()});wM.exports=function(e){return rX.validateBySchema(e,iX)}});var CM=w((tOe,IM)=>{"use strict";var GR=class{static{a(this,"BridgeMethods")}createSchema(){throw new Error("createSchema bridge method is not defined")}dropSchema(){throw new Error("dropSchema bridge method is not defined")}createTable(){throw new Error("createTable bridge method is not defined")}dropTable(){throw new Error("dropTable bridge method is not defined")}createRecords(){throw new Error("createRecords bridge method is not defined")}updateRecords(){throw new Error("updateRecords bridge method is not defined")}async upsertRecords(){throw new Error("upsertRecords bridge method is not defined")}deleteRecords(){throw new Error("deleteRecords bridge method is not defined")}createAttribute(){throw new Error("createAttribute bridge method is not defined")}dropAttribute(){throw new Error("dropAttribute bridge method is not defined")}searchByConditions(){throw new Error("searchByConditions bridge method is not defined")}searchByHash(){throw new Error("searchByHash bridge method is not defined")}searchByValue(){throw new Error("searchByValue bridge method is not defined")}getDataByHash(){throw new Error("getDataByHash bridge method is not defined")}getDataByValue(){throw new Error("getDataByValue bridge method is not defined")}deleteRecordsBefore(){throw new Error("deleteRecordsBefore bridge method is not defined")}deleteAuditLogsBefore(){throw new Error("deleteAuditLogsBefore bridge method is not defined")}async readAuditLog(){throw new Error("readAuditLog bridge method is not defined")}};IM.exports=GR});var DM=w((nOe,PM)=>{"use strict";var qR=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};PM.exports=qR});var xM={};ve(xM,{HAS_EXPIRATION:()=>Wm,HAS_RESIDENCY_ID:()=>jR,HAS_STRUCTURE_UPDATE:()=>jm,LAST_TIMESTAMP_PLACEHOLDER:()=>t_,LOCAL_TIMESTAMP:()=>oX,METADATA:()=>Qf,NEW_TIMESTAMP_PLACEHOLDER:()=>MM,NO_TIMESTAMP:()=>$R,PENDING_LOCAL_TIME:()=>JR,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>zR,RecordEncoder:()=>WR,TIMESTAMP_ASSIGN_LAST:()=>cX,TIMESTAMP_ASSIGN_NEW:()=>vM,TIMESTAMP_ASSIGN_PREVIOUS:()=>UM,TIMESTAMP_PLACEHOLDER:()=>Km,TIMESTAMP_RECORD_PREVIOUS:()=>VR,handleLocalTimeForGets:()=>Jm,recordUpdater:()=>QR,removeEntry:()=>Hc});function uX(){return e_[0]=e_[0]^64,aX.getFloat64(0)}function Jm(e,t){let r=e.getEntry;e.readCount=0,e.cachePuts=!1,e.rootStore=t,e.encoder.rootStore=t,e.getEntry=function(o,c){e.readCount++;let l=r.call(this,o,c),u=l?.value,f=u?.[Qf];return f>=0&&(l.metadataFlags=f,l.localTime=u.localTime,l.value=u.value,l.residencyId=u.residencyId,u.expiresAt>=0&&(l.expiresAt=u.expiresAt)),l&&(l.key=o),l};let n=e.get;e.get=function(o,c){let l=n.call(this,o,c);return l?.[Qf]>=0?l.value:l};let s=e.getRange;e.getRange=function(o){let c=s.call(this,o);return o.valuesForKey?c.map(l=>l?.value):o.values===!1||o.onlyCount?c:c.map(l=>{let u=l.value,f=u[Qf];return f>=0&&(l.metadataFlags=f,l.localTime=u.localTime,l.value=u.value,l.residencyId=u.residencyId,u.expiresAt>=0&&(l.expiresAt=u.expiresAt)),l})};let i=e.useReadTransaction();if(i.done(),!i.done.isTracked){let o=i.constructor,c=i.use,l=i.done;o.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,Bc.push(new WeakRef(this))),c.call(this)},o.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<Bc.length;u++){let f=Bc[u].deref();(!f||f.isDone||f.isCommitted)&&Bc.splice(u--,1)}},o.prototype.done.isTracked=!0}return e}function QR(e,t,r){return function(n,s,i,o,c=-1,l,u,f="put",d,p){d||l==null?Ou=i?.localTime?VR|UM:$R:Ou=l?i?.localTime?VR|16384:vM|16384:$R;let _=u?.expiresAt;if(_>=0&&(c|=Wm),Zf=c,KR=_,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:Ou>0},S,g=0;try{let R=i?.residencyId,E=u?.residencyId;E&&(YR=E,Zf|=jR,g|=kc),R!==E&&(g|=Fc,R||(R=0)),c&Wm&&(g|=n_),u?.originatingOperation&&(g|=r_),d&&(h.ifVersion=S=i?.version??null),i&&i.value&&i.metadataFlags&Fn&&(r.getBinaryFast(i.localTime)||Ta(i.value));let T;if(s!==void 0&&(T=Fm(()=>e.put(n,s,h),n,e.rootStore),Mc&&(g|=Fn)),l){let b=u?.user?.username;if(p&&(Fm(()=>e.encoder.encode(p),n,e.rootStore),Mc&&(g|=Fn)),e.encoder.hasStructureUpdate&&(g|=jm,e.encoder.hasStructureUpdate=!1),d&&i?.localTime){let v=i?.localTime,F=r.get(v);if(F){let q=It(F).previousLocalTime;return T=r.put(v,Nu(o,t,n,q,u?.nodeId??server.replication.getThisNodeId(r)??0,b,f,Xf,g,E,R,_),{ifVersion:S}),T}}T=r.put(s===void 0?MM:t_,Nu(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,b,f,Xf,g,E,R,_,u?.originatingOperation),{append:f!=="invalidate",instructedWrite:!0,ifVersion:S})}return T}catch(R){throw R.message+=" id: "+n+" options: "+h,R}}}function Hc(e,t,r){if(t)return t.value&&t.metadataFlags&Fn&&!e.auditStore.getBinaryFast(t.localTime)&&Ta(t.value),e.remove(t.key,r)}var LM,Ym,Km,t_,zR,MM,oX,Qf,e_,aX,$R,vM,cX,UM,VR,Wm,jR,JR,jm,lX,Xf,Ou,Zf,KR,YR,WR,Bc,wu=be(()=>{LM=require("msgpackr");fo();Ym=M(z());gs();gs();Km=new Uint8Array([1,1,1,1,4,64,0,0]),t_=new Uint8Array([1,1,1,1,1,0,0,0]),zR=new Uint8Array([1,1,1,1,3,64,0,0]),MM=new Uint8Array([1,1,1,1,0,64,0,0]),oX=Symbol("local-timestamp"),Qf=Symbol("metadata"),e_=new Uint8Array(8),aX=new DataView(e_.buffer,0,8),$R=0,vM=0,cX=1,UM=3,VR=4,Wm=16,jR=32,JR=1,jm=256,Ou=0,Zf=-1,KR=-1,YR=0,WR=class extends LM.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(Ou||Zf>=0){let o=0,c=Ou;c&&(o+=8,Ou=0);let l=Zf,u=KR,f=YR;l>=0&&(o+=4,Zf=-1,u>=0&&(o+=8,KR=-1),f&&(o+=4,YR=0));let d=lX=r.call(this,s,i|2048|o);Xf=d.subarray((d.start||0)+o,d.end);let p=d.start||0;return c&&(Km[4]=c,Km[5]=c>>8,d.set(Km,p),p+=8),Mc&&(l|=Fn),l>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(p,l|zm<<24),p+=4,u>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setFloat64(p,u),p+=8),f&&(d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(p,f)),d}else return Xf=r.call(this,s,i),Xf};let n=this.saveStructures;this.saveStructures=function(s,i){let o=n.call(this,s,i);return this.hasStructureUpdate=!0,o}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(e_,0,c),c+=8;else for(let p=0;p<8;p++)e_[p]=t[c++];l=uX(),i=t[c]}let u,f;i<32&&(i===zm?(o=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4):(o=i|t[c+1]<<5,c+=2),o&Wm&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&jR&&(f=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let d=vc(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return{localTime:l,value:d,[Qf]:o,expiresAt:u,residencyId:f}}return r?.valueAsBuffer?t:vc(()=>super.decode(t,r),this.rootStore)}catch(c){return Ym.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};a(uX,"getTimestamp");a(Jm,"handleLocalTimeForGets");Bc=[];setInterval(()=>{for(let e=0;e<Bc.length;e++){let t=Bc[e].deref();!t||t.isDone||t.isCommitted?Bc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(Ym.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):Ym.error("Read transaction detected that has been open too long (over one minute), make sure read transactions are quickly closed",t)),t.openTimer++):t.openTimer=1)}},15e3).unref();a(QR,"recordUpdater");a(Hc,"removeEntry")});var s_=w((lOe,HM)=>{"use strict";var BM=ae(),dX=(H(),C(G)),{RecordEncoder:fX}=(wu(),C(xM));BM.initSync();var _X=BM.get(dX.CONFIG_PARAMS.STORAGE_CACHING)!==!1,XR=class{static{a(this,"OpenDBIObject")}constructor(t,r=!1){this.dupSort=t===!0,this.encoding=t?"ordered-binary":"msgpack",this.useVersions=r,this.sharedStructuresKey=Symbol.for("structures"),r&&(this.cache=_X&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:fX})}};HM.exports=XR});var i_=w((dOe,kM)=>{"use strict";var Gn=ae(),Ss=(H(),C(G));Gn.initSync();var Qm=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Gn.get(Ss.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Gn.get(Ss.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Gn.get(Ss.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Gn.get(Ss.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Gn.get(Ss.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Gn.get(Ss.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Gn.get(Ss.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Gn.get(Ss.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Gn.get(Ss.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Gn.get(Ss.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Gn.get(Ss.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Gn.get(Ss.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};kM.exports=Qm;Qm.MAX_DBS=1e4});var _t=w((_Oe,jM)=>{"use strict";var ey=require("lmdb"),Qs=require("fs-extra"),qn=require("path"),Xm=_n(),qM=z(),Sn=xn().LMDB_ERRORS_ENUM,Zm=DM(),ty=s_(),$M=i_(),ya=xt(),FM=(H(),C(G)),{table:pX,resetDatabases:hX}=(De(),C(nt)),GM=ae(),Xs=ya.INTERNAL_DBIS_NAME,VM=ya.DBI_DEFINITION_NAME,mX="data.mdb",EX="lock.mdb",o_=".mdb",gX="-lock",ZR=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=Ts(t,r),this.key_type=this.dbi[ya.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[ya.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new ey.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function eE(e,t){if(e===void 0)throw new Error(Sn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(Sn.ENV_NAME_REQUIRED)}a(eE,"pathEnvNameValidation");async function ry(e,t,r=!0){try{await Qs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Sn.INVALID_BASE_PATH):n}try{let n=qn.join(e,t+o_);return await Qs.access(n,Qs.constants.R_OK|Qs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Qs.access(qn.join(e,t,mX),Qs.constants.R_OK|Qs.constants.F_OK),qn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(Sn.INVALID_ENVIRONMENT)}else throw new Error(Sn.INVALID_ENVIRONMENT);throw n}}a(ry,"validateEnvironmentPath");function tE(e,t){if(Xm.validateEnv(e),t===void 0)throw new Error(Sn.DBI_NAME_REQUIRED)}a(tE,"validateEnvDBIName");async function SX(e,t,r=!1,n=!1){eE(e,t);let s=qn.basename(e);t=t.toString();let i=GM.get(FM.CONFIG_PARAMS.DATABASES);i||GM.setProperty(FM.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await ry(e,t,n),KM(e,t,r)}catch(o){if(o.message===Sn.INVALID_ENVIRONMENT){let c=qn.join(e,t);await Qs.mkdirp(n?c:e);let l=new $M(n?c:c+o_,!1),u=ey.open(l);u.dbis=Object.create(null);let f=new ty(!1);u.openDB(Xs,f),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=ny(e,t,r);return u[ya.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=u,u}throw o}}a(SX,"createEnvironment");async function TX(e,t,r,n=!0){eE(e,t),t=t.toString();let s=qn.join(e,t);return pX({table:t,database:qn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(TX,"copyEnvironment");async function KM(e,t,r=!1){eE(e,t),t=t.toString();let n=ny(e,t,r);if(global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null)),global.lmdb_map[n]!==void 0)return global.lmdb_map[n];let s=await ry(e,t),i=qn.join(e,t+o_),o=s!=i,c=new $M(s,o),l=ey.open(c);l.dbis=Object.create(null);let u=WM(l);for(let f=0;f<u.length;f++)Ts(l,u[f]);return l[ya.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(KM,"openEnvironment");async function AX(e,t,r=!1){eE(e,t),t=t.toString();let n=qn.join(e,t+o_),s=await ry(e,t);if(global.lmdb_map!==void 0){let i=ny(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await YM(o),delete global.lmdb_map[i]}}await Qs.remove(s),await Qs.remove(s===n?s+gX:qn.join(qn.dirname(s),EX))}a(AX,"deleteEnvironment");async function YM(e){Xm.validateEnv(e);let t=e[ya.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(YM,"closeEnvironment");function ny(e,t,r=!1){let s=`${qn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(ny,"getCachedEnvironmentName");function RX(e){Xm.validateEnv(e);let t=Object.create(null),r=Ts(e,Xs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Xs)try{t[n]=Object.assign(new Zm,s)}catch{qM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(RX,"listDBIDefinitions");function WM(e){Xm.validateEnv(e);let t=[],r=Ts(e,Xs);for(let{key:n}of r.getRange({start:!1}))n!==Xs&&t.push(n);return t}a(WM,"listDBIs");function yX(e,t){let n=Ts(e,Xs).getEntry(t),s=new Zm;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{qM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(yX,"getDBIDefinition");function zM(e,t,r,n=!r){if(tE(e,t),t=t.toString(),t===Xs)throw new Error(Sn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return Ts(e,t)}catch(s){if(s.message===Sn.DBI_DOES_NOT_EXIST){let i=new ty(r,n===!0),o=e.openDB(t,i),c=new Zm(r===!0,n);return o[VM]=c,Ts(e,Xs).putSync(t,c),e.dbis[t]=o,o}throw s}}a(zM,"createDBI");function Ts(e,t){if(tE(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Xs?r=yX(e,t):r=new Zm,r===void 0)throw new Error(Sn.DBI_DOES_NOT_EXIST);let n;try{let s=new ty(r.dup_sort,r.useVersions);if(n=e.openDB(t,s),n.db===void 0)throw new Error("MDB_NOTFOUND")}catch(s){throw s.message.includes("MDB_NOTFOUND")===!0?new Error(Sn.DBI_DOES_NOT_EXIST):s}return n[VM]=r,e.dbis[t]=n,n}a(Ts,"openDBI");function bX(e,t){tE(e,t),t=t.toString();let r=Ts(e,t),n=r.getStats();return r[ya.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(bX,"statDBI");async function OX(e,t){try{let r=qn.join(e,t+o_);return(await Qs.stat(r)).size}catch{throw new Error(Sn.INVALID_ENVIRONMENT)}}a(OX,"environmentDataSize");function NX(e,t){if(tE(e,t),t=t.toString(),t===Xs)throw new Error(Sn.CANNOT_DROP_INTERNAL_DBIS_NAME);Ts(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],Ts(e,Xs).removeSync(t)}a(NX,"dropDBI");function wX(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{Ts(e,i)}catch(o){if(o.message===Sn.DBI_DOES_NOT_EXIST)zM(e,i,i!==t,i===t),n=!0;else throw o}}n&&hX()}a(wX,"initializeDBIs");jM.exports={openDBI:Ts,openEnvironment:KM,createEnvironment:SX,listDBIs:WM,listDBIDefinitions:RX,createDBI:zM,dropDBI:NX,statDBI:bX,deleteEnvironment:AX,initializeDBIs:wX,TransactionCursor:ZR,environmentDataSize:OX,copyEnvironment:TX,closeEnvironment:YM}});var QM=w((hOe,JM)=>{"use strict";var sy=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};JM.exports=sy});var ZM=w((EOe,XM)=>{"use strict";var iy=class{static{a(this,"UpdateRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n,this.original_records=s}};XM.exports=iy});var tv=w((SOe,ev)=>{"use strict";var oy=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};ev.exports=oy});var qc=w((bOe,sv)=>{"use strict";var IX=_t(),CX=QM(),PX=ZM(),DX=tv(),Li=_n(),a_=xn().LMDB_ERRORS_ENUM,LX=xt(),_o=(H(),C(G)),MX=ie(),vX=require("uuid"),AOe=require("lmdb"),{handleHDBError:UX,hdb_errors:xX}=pe(),{OVERFLOW_MARKER:ROe,MAX_SEARCH_KEY_LENGTH:yOe}=LX,rv=ae();rv.initSync();var rE=rv.get(_o.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),ay=_o.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Gc=_o.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function BX(e,t,r,n,s=Li.getNextMonotonicTime()){dy(e,t,r,n),cy(e,t,r);let i=new CX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];nv(u,!0,s);let f=HX(e,t,r,u),d=u[t];o.push(f),c.push(d)}return ly(o,c,n,i,s)}a(BX,"insertRecords");function HX(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let f=c([[{}]]);Array.isArray(f)&&(c=f[0][_o.FUNC_VAL],n[o]=c)}let l=Li.getIndexedValues(c),u=e.dbis[o];if(l){rE&&u.prefetch(l.map(f=>({key:f,value:s})),nE);for(let f=0,d=l.length;f<d;f++)u.put(l[f],s)}}rE&&e.dbis[t].prefetch([s],nE),e.dbis[t].put(s,n,n[Gc])})}a(HX,"insertRecord");function kX(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(kX,"removeSkippedRecords");function nv(e,t,r){let n=r>0;(n||!Number.isInteger(e[Gc]))&&(e[Gc]=r||(r=Li.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[ay]))&&(e[ay]=r||Li.getNextMonotonicTime()):delete e[ay]}a(nv,"setTimestamps");function cy(e,t,r){r.indexOf(_o.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(_o.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(_o.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(_o.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),IX.initializeDBIs(e,t,r)}a(cy,"initializeTransaction");async function FX(e,t,r,n,s=Li.getNextMonotonicTime()){dy(e,t,r,n),cy(e,t,r);let i=new PX,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let f=n[u],d=f[t],p;try{p=uy(e,t,f,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(u);continue}c.push(p),l.push(d)}return ly(c,l,n,i,s,o)}a(FX,"updateRecords");async function GX(e,t,r,n,s=Li.getNextMonotonicTime()){try{dy(e,t,r,n)}catch(l){throw UX(l,l.message,xX.HTTP_STATUS_CODES.BAD_REQUEST)}cy(e,t,r);let i=new DX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],f;MX.isEmpty(u[t])?(f=vX.v4(),u[t]=f):f=u[t];let d=uy(e,t,u,f,i,!1,s);o.push(d),c.push(f)}return ly(o,c,n,i,s)}a(GX,"upsertRecords");async function ly(e,t,r,n,s,i=[]){let o=await Promise.all(e);for(let c=0,l=o.length;c<l;c++)o[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||Li.getNextMonotonicTime(),kX(r,i),n}a(ly,"finalizeWrite");function uy(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),u=l?.value,f=u;if(!u){if(i)return!1;u={}}if(nv(r,!f,o),Number.isInteger(r[Gc])&&u[Gc]>r[Gc])return!1;f&&s.original_records.push(u);let d,p=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let S=r[h],g=e.dbis[h];if(g===void 0)continue;let R=u[h];if(typeof S=="function"){let T=S([[u]]);Array.isArray(T)&&(S=T[0][_o.FUNC_VAL],r[h]=S)}if(S===R)continue;let E=Li.getIndexedValues(R);if(E){rE&&g.prefetch(E.map(T=>({key:T,value:n})),nE);for(let T=0,b=E.length;T<b;T++)g.remove(E[T],n)}if(E=Li.getIndexedValues(S),E){rE&&g.prefetch(E.map(T=>({key:T,value:n})),nE);for(let T=0,b=E.length;T<b;T++)g.put(E[T],n)}}let _={...u,...r};c.put(n,_,_[Gc])},"do_put");return l?d=c.ifVersion(n,l.version,p):d=c.ifNoExists(n,p),d.then(_=>_?!0:uy(e,t,r,n,s,i,o))}a(uy,"updateUpsertRecord");function qX(e,t,r){if(Li.validateEnv(e),t===void 0)throw new Error(a_.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(a_.WRITE_ATTRIBUTES_REQUIRED):new Error(a_.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(qX,"validateBasic");function dy(e,t,r,n){if(qX(e,t,r),!Array.isArray(n))throw n===void 0?new Error(a_.RECORDS_REQUIRED):new Error(a_.RECORDS_MUST_BE_ARRAY)}a(dy,"validateWrite");function nE(){}a(nE,"noop");sv.exports={insertRecords:BX,updateRecords:FX,upsertRecords:GX}});var po=w((NOe,$X)=>{$X.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"hash_function"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"revoked_certificates"},{attribute:"shard"}]},hdb_certificate:{hash_attribute:"name",name:"hdb_certificate",schema:"system",attributes:[{attribute:"name"},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var ov=w((wOe,iv)=>{"use strict";var VX=require("uuid"),fy=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||VX.v4(),this.schema_table=`${this.schema}.${this.table}`}};iv.exports=fy});var sE=w((COe,av)=>{"use strict";var KX=ov(),_y=class extends KX{static{a(this,"LMDBCreateAttributeObject")}constructor(t,r,n,s,i=!0,o=!1){super(t,r,n,s),this.dup_sort=i,this.is_hash_attribute=o}};av.exports=_y});var lv=w((DOe,cv)=>{"use strict";cv.exports=WX;var YX="inserted";function WX(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===YX?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(WX,"returnObject")});var iE=w((vOe,dv)=>{"use strict";var zX=(H(),C(G)),py=_t(),jX=qc(),{getSystemSchemaPath:JX,getSchemaPath:QX}=gt(),MOe=po(),{validateBySchema:XX}=ot(),c_=require("joi"),ZX=sE(),e6=lv(),{handleHDBError:t6,hdb_errors:r6,ClientError:n6}=pe(),uv=ie(),{HTTP_STATUS_CODES:s6}=r6,i6="inserted";dv.exports=o6;async function o6(e){let t=XX(e,c_.object({database:c_.string(),schema:c_.string(),table:c_.string().required(),attribute:c_.string().required()}));if(t)throw new n6(t.message);let r=!e.skip_table_check&&uv.checkGlobalSchemaTable(e.schema,e.table);if(r)throw t6(new Error,r,s6.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=uv.isEmpty(e.dup_sort)||e.dup_sort=="true";let n=[];if(global.hdb_schema[e.schema]&&global.hdb_schema[e.schema][e.table]&&(n=global.hdb_schema[e.schema][e.table].attributes),Array.isArray(n)&&n.length>0){for(let i of n)if(i.attribute===e.attribute)throw new Error(`attribute '${i.attribute}' already exists in ${e.schema}.${e.table}`)}let s=new ZX(e.schema,e.table,e.attribute,e.id);try{let i=await py.openEnvironment(QX(e.schema,e.table),e.table);if(i.dbis[e.attribute]!==void 0)throw new Error(`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`);py.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await py.openEnvironment(JX(),zX.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await jX.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return e6(i6,c,{records:[s]},l)}catch(i){throw i}}a(o6,"lmdbCreateAttribute")});var l_=w((BOe,_v)=>{"use strict";var ho=ie(),fv=z(),xOe=FR(),{getDatabases:a6}=(De(),C(nt)),{ClientError:$c}=pe();_v.exports=c6;function c6(e){if(ho.isEmpty(e))throw new $c("invalid update parameters defined.");if(ho.isEmptyOrZeroLength(e.schema))throw new $c("invalid schema specified.");if(ho.isEmptyOrZeroLength(e.table))throw new $c("invalid table specified.");if(!Array.isArray(e.records))throw new $c("records must be an array");let t=a6()[e.schema]?.[e.table];if(ho.isEmpty(t))throw new $c(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&ho.isEmptyOrZeroLength(o[r]))throw fv.error("a valid hash attribute must be provided with update record:",o),new $c("a valid hash attribute must be provided with update record, check log for more info");if(!ho.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw fv.error(`a valid hash value must be provided with ${e.operation} record:`,o),new $c(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!ho.isEmpty(o[r])&&o[r]!==""&&n.has(ho.autoCast(o[r]))&&(o.skip=!0),n.add(ho.autoCast(o[r]));for(let c in o)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}a(c6,"insertUpdateValidate")});var hv=w((kOe,pv)=>{"use strict";var hy=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};pv.exports=hy});var gv=w((GOe,Ev)=>{"use strict";var my=_t(),l6=z(),mv=xn().LMDB_ERRORS_ENUM;Ev.exports=u6;async function u6(e){try{if(global.lmdb_map!==void 0&&e.operation!==void 0){let t=Object.keys(global.lmdb_map),r;switch(e.operation){case"drop_schema":for(let i=0;i<t.length;i++){let o=t[i];if(o.startsWith(`${e.schema}.`)||o.startsWith(`txn.${e.schema}.`))try{await my.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==mv.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await my.closeEnvironment(global.lmdb_map[n]),await my.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==mv.ENV_REQUIRED)throw i}break;case"drop_attribute":r=global.lmdb_map[`${e.schema}.${e.table}`],r!==void 0&&typeof r.dbis=="object"&&r.dbis[`${e.attribute}`]!==void 0&&delete r.dbis[`${e.attribute}`];break;default:break}}}catch(t){l6.error(t)}}a(u6,"cleanLMDBMap")});var Dv=w((VOe,Pv)=>{"use strict";var Ey=require("recursive-iterator"),d6=require("alasql"),gy=require("clone"),Sv=ie(),{handleHDBError:Tv,hdb_errors:f6}=pe(),{HDB_ERROR_MSGS:Av,HTTP_STATUS_CODES:Rv}=f6,{getDatabases:_6}=(De(),C(nt)),p6=["DISTINCT_ARRAY"],yv=Symbol("validateTables"),Sy=Symbol("validateTable"),$Oe=Symbol("getAllColumns"),bv=Symbol("validateAllColumns"),oE=Symbol("findColumn"),Ov=Symbol("validateOrderBy"),u_=Symbol("validateSegment"),Ty=Symbol("validateColumn"),Nv=Symbol("setColumnsForTable"),wv=Symbol("checkColumnsForAsterisk"),Iv=Symbol("validateGroupBy"),Cv=Symbol("hasColumns"),Ay=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[yv](),this[wv](),this[bv]()}[yv](){if(this[Cv]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[Sy](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[Sy](t.table)})}}[Cv](){let t=!1,r=new Ey(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[Sy](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=_6();if(!r[t.databaseid])throw Tv(new Error,Av.SCHEMA_NOT_FOUND(t.databaseid),Rv.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw Tv(new Error,Av.TABLE_NOT_FOUND(t.databaseid,t.tableid),Rv.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=gy(s);i.table=gy(t),this.attributes.push(i)})}[oE](t){return this.attributes.filter(r=>t.tableid?(r.table.as===t.tableid||r.table.tableid===t.tableid)&&r.attribute===t.columnid:r.attribute===t.columnid)}[wv](){let t=new Ey(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[Nv](r.tableid)}[Nv](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new d6.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[bv](){this[u_](this.statement.columns,!1),this[u_](this.statement.joins,!1),this[u_](this.statement.where,!1),this[Iv](this.statement.group,!1),this[u_](this.statement.order,!0)}[u_](t,r){if(!t)return;let n=new Ey(t),s=[];for(let{node:i,path:o}of n)!Sv.isEmpty(i)&&!Sv.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[Ov](i):s.push(this[Ty](i)));return s}[Iv](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&p6.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=gy(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[oE](n)[0];s&&r.push(s)}}}),this.statement.group.forEach(n=>{let s=null;if(!n.columnid)r.forEach((i,o)=>{if(i.toString()===n.toString()){s=i,r.splice(o,1);return}});else{let i=this[oE](n);if(!i||i.length===0)throw`unknown column '${n.toString()}' in group by`;if(i.length>1)throw`ambiguously defined column '${n.toString()}' in group by`;r.forEach((o,c)=>{if(o.attribute===i[0].attribute&&o.table.tableid===i[0].table.tableid){s=o,r.splice(c,1);return}})}if(!s)throw`group by column '${n.toString()}' must be in select`}),r.length>0)throw`select column '${r[0].attribute?r[0].attribute:r[0].toString()}' must be in group by`}[Ov](t){let r=this.statement.columns.filter(n=>n.as===t.columnid);if(r.length>1)throw`ambiguous column reference ${(t.tableid?t.tableid+".":"")+t.columnid} in order by`;r.length===0&&this[Ty](t)}[Ty](t){let r=this[oE](t),n=(t.tableid?t.tableid+".":"")+t.columnid;if(r.length===0)throw`unknown column ${n}`;if(r.length>1)throw`ambiguous column reference ${n}`;return r[0]}};Pv.exports=Ay});var Uv=w((YOe,vv)=>{"use strict";var Lv=require("lodash"),d_=require("mathjs"),h6=require("jsonata"),Mv=ie();vv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?Lv.uniqWith(e,Lv.isEqual):e,"distinct_array"),searchJSON:m6,mad:f_.bind(null,d_.mad),mean:f_.bind(null,d_.mean),mode:f_.bind(null,d_.mode),prod:f_.bind(null,d_.prod),median:f_.bind(null,d_.median)};function f_(e,t,r,n){return n===1?t==null?[]:[t]:n===2?(t!=null&&r.push(t),r):r!=null&&r.length>0?e(r):null}a(f_,"aggregateFunction");function m6(e,t){if(typeof e!="string"||e.length===0)throw new Error("search json expression must be a non-empty string");let r="__"+e+"__";if(Mv.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),Mv.isEmpty(this.__ala__.res[r])){let n=h6(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(m6,"searchJSON")});var Bv=w((zOe,xv)=>{"use strict";var er=require("moment"),Ry="YYYY-MM-DDTHH:mm:ss.SSSZZ";er.suppressDeprecationWarnings=!0;xv.exports={current_date:a(()=>er().utc().format("YYYY-MM-DD"),"current_date"),current_time:a(()=>er().utc().format("HH:mm:ss.SSS"),"current_time"),extract:a((e,t)=>{switch(t.toLowerCase()){case"year":return er(e).utc().format("YYYY");case"month":return er(e).utc().format("MM");case"day":return er(e).utc().format("DD");case"hour":return er(e).utc().format("HH");case"minute":return er(e).utc().format("mm");case"second":return er(e).utc().format("ss");case"millisecond":return er(e).utc().format("SSS");default:break}},"extract"),date:a(e=>er(e).utc().format(Ry),"date"),date_format:a((e,t)=>er(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>er(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>er(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=er(e).utc(),s=er(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>er().utc().valueOf(),"now"),get_server_time:a(()=>er().format(Ry),"get_server_time"),offset_utc:a((e,t)=>er(e).utc().utcOffset(t).format(Ry),"offset_utc")}});var Gv=w((JOe,Fv)=>{"use strict";var E6=require("@turf/area"),g6=require("@turf/length"),S6=require("@turf/circle"),T6=require("@turf/difference"),A6=require("@turf/distance"),R6=require("@turf/boolean-contains"),y6=require("@turf/boolean-equal"),b6=require("@turf/boolean-disjoint"),O6=require("@turf/helpers"),Hv=(H(),C(G)),Ge=ie(),mo=z();Fv.exports={geoArea:N6,geoLength:w6,geoCircle:I6,geoDifference:C6,geoDistance:kv,geoNear:P6,geoContains:D6,geoEqual:L6,geoCrosses:M6,geoConvert:v6};function N6(e){if(Ge.isEmpty(e))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return E6.default(e)}catch(t){return mo.trace(t,e),NaN}}a(N6,"geoArea");function w6(e,t){if(Ge.isEmpty(e))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return g6.default(e,{units:t||"kilometers"})}catch(r){return mo.trace(r,e),NaN}}a(w6,"geoLength");function I6(e,t,r){if(Ge.isEmpty(e))return NaN;if(Ge.isEmpty(t))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e));try{return S6.default(e,t,{units:r||"kilometers"})}catch(n){return mo.trace(n,e,t),NaN}}a(I6,"geoCircle");function C6(e,t){if(Ge.isEmpty(e))return NaN;if(Ge.isEmpty(t))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return T6(e,t)}catch(r){return mo.trace(r,e,t),NaN}}a(C6,"geoDifference");function kv(e,t,r){if(Ge.isEmpty(e))return NaN;if(Ge.isEmpty(t))return NaN;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return A6.default(e,t,{units:r||"kilometers"})}catch(n){return mo.trace(n,e,t),NaN}}a(kv,"geoDistance");function P6(e,t,r,n){if(Ge.isEmpty(e)||Ge.isEmpty(t))return!1;if(Ge.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return kv(e,t,n)<=r}catch(s){return mo.trace(s,e,t),!1}}a(P6,"geoNear");function D6(e,t){if(Ge.isEmpty(e)||Ge.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return R6.default(e,t)}catch(r){return mo.trace(r,e,t),!1}}a(D6,"geoContains");function L6(e,t){if(Ge.isEmpty(e)||Ge.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return y6.default(e,t)}catch(r){return mo.trace(r,e,t),!1}}a(L6,"geoEqual");function M6(e,t){if(Ge.isEmpty(e)||Ge.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ge.autoCastJSON(e)),typeof t=="string"&&(t=Ge.autoCastJSON(t));try{return!b6.default(e,t)}catch(r){return mo.trace(r,e,t),!1}}a(M6,"geoCrosses");function v6(e,t,r){if(Ge.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(Ge.isEmpty(t))throw new Error("geo_type is required");if(Ge.isEmpty(Hv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(Hv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ge.autoCastJSON(e)),O6[t](e,r)}a(v6,"geoConvert")});var aE=w((XOe,qv)=>{var Vc=Uv(),$n=Bv(),Mi=Gv();qv.exports=e=>{e.aggr.mad=e.aggr.MAD=Vc.mad,e.aggr.mean=e.aggr.MEAN=Vc.mean,e.aggr.mode=e.aggr.MODE=Vc.mode,e.aggr.prod=e.aggr.PROD=Vc.prod,e.aggr.median=e.aggr.MEDIAN=Vc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Vc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Vc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=$n.current_date,e.fn.current_time=e.fn.CURRENT_TIME=$n.current_time,e.fn.extract=e.fn.EXTRACT=$n.extract,e.fn.date=e.fn.DATE=$n.date,e.fn.date_format=e.fn.DATE_FORMAT=$n.date_format,e.fn.date_add=e.fn.DATE_ADD=$n.date_add,e.fn.date_sub=e.fn.DATE_SUB=$n.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=$n.date_diff,e.fn.now=e.fn.NOW=$n.now,e.fn.offset_utc=e.fn.OFFSET_UTC=$n.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=$n.get_server_time,e.fn.getdate=e.fn.GETDATE=$n.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=$n.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Mi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Mi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Mi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Mi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Mi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Mi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Mi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Mi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Mi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Mi.geoNear}});var Yv=w((ZOe,Kv)=>{"use strict";var __=require("lodash"),Tn=require("alasql");Tn.options.cache=!1;var U6=aE(),$v=require("clone"),cE=require("recursive-iterator"),xe=z(),ze=ie(),Iu=Vn(),x6=(H(),C(G)),{hdb_errors:B6}=pe(),{getDatabases:Vv}=(De(),C(nt)),H6="IS NULL",Zs="There was a problem performing this search. Please check the logs and try again.";U6(Tn);var yy=class{static{a(this,"SQLSearch")}constructor(t,r){if(ze.isEmpty(t))throw xe.error("AST statement for SQL select process cannot be empty"),"statement cannot be null";this.statement=t,this.columns={},this.all_table_attributes=r,this.fetch_attributes=[],this.exact_search_values={},this.comparator_search_values={},this.tables=[],this.data={},this.has_aggregator=!1,this.has_ordinal=!1,this.has_outer_join=!1,this._getColumns(),this._getTables(),this._conditionsToFetchAttributeValues(),this._setAliasesForColumns(),ze.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!ze.isEmptyOrZeroLength(n))return xe.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw xe.error("Error thrown from checkEmptySQL in SQLSearch class method search."),xe.error(n),new Error(Zs)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw xe.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),xe.error(n),new Error(Zs)}if(Object.keys(this.data).length===0)return xe.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw xe.error("Error thrown from processJoins in SQLSearch class method search."),xe.error(n),new Error(Zs)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw xe.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),xe.error(n),new Error(Zs)}try{return t=await this._finalSQL(),t}catch(n){throw xe.error("Error thrown from finalSQL in SQLSearch class method search."),xe.error(n),new Error(Zs)}}_getColumns(){let t=new cE(this.statement);for(let{node:r,path:n}of t)r&&r.columnid&&(this.columns[n[0]]||(this.columns[n[0]]=[]),this.columns[n[0]].push($v(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=__.uniqBy(t,r=>[r.databaseid,r.tableid,r.as].join()),this.tables.forEach(r=>{let n=`${r.databaseid}_${r.as?r.as:r.tableid}`;this.data[n]={},this.data[n].__hash_name=Vv()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(ze.isEmpty(this.statement.where)){xe.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new cE(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!ze.isEmpty(r)&&r.right)if(ze.isNotEmptyAndHasValue(r.right.value)){let n=ze.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new Tn.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=ze.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new Tn.yy.LogicValue({value:i}):n instanceof Tn.yy.StringValue&&ze.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Tn.yy.NumValue({value:i}))});if(t){xe.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new cE(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let n=new Set,s=r.left.columnid?r.left:r.right,i=this._findColumn(s);if(!i)continue;let o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!ze.isEmpty(x6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(ze.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(ze.isEmptyOrZeroLength(r.left.columnid)||ze.isEmptyOrZeroLength(r.right.value)){this.comparator_search_values[o].ignore=!0,this.comparator_search_values[o].comparators=[];continue}this.comparator_search_values[o].comparators.push({attribute:r.left.columnid,operation:r.op,search_value:r.right.value})}continue}if(ze.isEmpty(this.exact_search_values[o])&&(this.exact_search_values[o]={ignore:!1,values:new Set}),!this.exact_search_values[o].ignore){let c=!1;switch(r.op){case"=":!ze.isEmpty(r.right.value)||!ze.isEmpty(r.left.value)?n.add(ze.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let l=Array.isArray(r.right)?r.right:r.left;for(let u=0;u<l.length;u++)if(l[u].value)n.add(l[u].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(ze.isEmptyOrZeroLength(this.all_table_attributes)&&ze.isEmptyOrZeroLength(this.statement.from)&&ze.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((n,s)=>{if(n.columnid==="*"){t.push(s);return}if(n.aggregatorid&&(this.has_aggregator=!0),!n.aggregatorid&&!n.funcid)if(n.as_orig=n.as?n.as:n.columnid,this.statement.joins)if(r[n.as_orig]>=0){let i=r[n.as_orig]+1;n.as=`[${n.as_orig+i}]`,r[n.as_orig]=i}else n.as=`[${n.as_orig}]`,r[n.as_orig]=0;else n.as=`[${n.as_orig}]`;!n.aggregatorid&&n.funcid&&n.args&&(n.as_orig=n.as?n.as:n.toString().replace(/'/g,'"'),n.as=`[${n.as_orig}]`),n.aggregatorid&&n.expression.columnid!=="*"&&(n.as_orig=n.as?n.as:n.expression.tableid?`${n.aggregatorid}(${n.expression.tableid}.${n.expression.columnid})`:`${n.aggregatorid}(${n.expression.columnid})`,n.as=`[${n.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&__.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(ze.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);ze.isEmptyOrZeroLength(n)||(r=this.all_table_attributes.filter(s=>s.attribute===n[0].columnid&&n[0].tableid&&n[0].tableid===(s.table.as?s.table.as:s.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(ze.isEmptyOrZeroLength(this.all_table_attributes)&&!ze.isEmptyOrZeroLength(this.columns.columns))return t;if(ze.isEmptyOrZeroLength(this.all_table_attributes)&&ze.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await Tn.promise(r)}catch(r){throw xe.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),xe.error(r),new Error("There was a problem with the SQL statement")}return t}_addFetchColumns(t){t&&t.length>0&&t.forEach(r=>{let n=this._findColumn(r);n&&this.fetch_attributes.push($v(n))})}_addColumnToMergedAttributes(t,r){this.data[t].__merged_attributes.push(r),this.data[t].__merged_attr_map[r]=this.data[t].__merged_attributes.length-1}_setMergedHashAttribute(t,r){this.data[t].__merged_data[r].splice(0,1,r)}_updateMergedAttribute(t,r,n,s){let i=this.data[t].__merged_attr_map[n];this.data[t].__merged_data[r].splice(i,1,s)}async _getFetchAttributeValues(){if(ze.isEmptyOrZeroLength(Object.keys(this.columns)))return[];this._addFetchColumns(this.columns.joins);let t=null;try{t=this.statement.where?this.statement.where.toString():""}catch{throw new Error("Could not generate proper where clause")}this.columns.where&&this._addFetchColumns(this.columns.where);let r=this._isSimpleSelect();if(r?this._addFetchColumns(this.columns.columns):(!this.columns.where&&this.fetch_attributes.length===0)|t.indexOf(H6)>-1&&this.tables.forEach(s=>{let i={columnid:Vv()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=__.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,u=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!ze.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!ze.isEmptyOrZeroLength(this.exact_search_values[u].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[u].values);let f=await Iu.getDataByHash(c);for(let d of c.hash_values)f.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(f){throw xe.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),xe.error(f),new Error(Zs)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async f=>{let d={...c};d.search_value=f;let p=await Iu.getDataByValue(d);for(let[_,h]of p)this.data[i].__merged_data[_]?this._updateMergedAttribute(i,_,s.attribute,h[s.attribute]):(this.data[i].__merged_data[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,_))}))}catch(f){throw xe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),xe.error(f),new Error(Zs)}else if(!ze.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!ze.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let f=this.comparator_search_values[u].comparators;for(let d=0,p=f.length;d<p;d++){let _=f[d];c.search_attribute=_.attribute,c.search_value=_.search_value;let h=await Iu.getDataByValue(c,_.operation);if(l)for(let[S]of h)this.data[i].__merged_data[S]||(this.data[i].__merged_data[S]=[...n[i]],this._setMergedHashAttribute(i,S));else for(let[S,g]of h)this.data[i].__merged_data[S]?this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]):(this.data[i].__merged_data[S]=[...n[i]],this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]),this._setMergedHashAttribute(i,S))}}catch(f){throw xe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),xe.error(f),new Error(Zs)}else try{c.search_attribute=s.attribute,c.search_value="*";let f=await Iu.getDataByValue(c);if(l)for(let[d]of f)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,p]of f)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,p[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,p[s.attribute]),this._setMergedHashAttribute(i,d))}catch(f){throw xe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),xe.error(f),new Error(Zs)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof Tn.yy.Column||(t=!1)}),t)}_updateOrderByToAliases(){this.statement.order.forEach(t=>{if(t.expression.aggregatorid){t.is_aggregator=!0;return}if(t.expression.value){t.is_ordinal=!0,this.has_ordinal=!0;return}else t.is_ordinal=!1;let r=this.statement.columns.filter(s=>{let i=s.aggregatorid?s.expression:s,o=s.aggregatorid?s.as_orig:i.as_orig;return t.expression.tableid?i.columnid_orig===t.expression.columnid_orig&&i.tableid_orig===t.expression.tableid_orig:i.columnid_orig===t.expression.columnid_orig||t.expression.columnid_orig===o});r[0]||r.push(this._findColumn(t.expression));let n=r[0];if(t.is_func=!!n.funcid,t.is_aggregator=!!n.aggregatorid,n.as)if(n.as&&!t.expression.tableid)t.expression.columnid=n.as,t.expression.columnid_orig=n.as_orig;else{let s=new Tn.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new Tn.yy.Column,t.expression),t.initial_select_column.as=`[${t.expression.columnid_orig}]`,t.expression.columnid=t.initial_select_column.as;return}if(!t.is_aggregator){let s=t.is_func?new Tn.yy.FuncValue:new Tn.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(_=>{_.joinmode&&_.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(_.table);let h=_.joinmode+" JOIN ? AS "+(_.as?_.as:_.table.tableid);_.on&&(h+=" ON "+_.on.toString()),i.push(h),t.push(Object.values(this.data[`${_.table.databaseid_orig}_${_.table.as?_.table.as_orig:_.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(_=>{let h=this.data[`${_.databaseid_orig}_${_.as?_.as_orig:_.tableid_orig}`].__hash_name,S=_.as?_.as_orig:_.tableid_orig;o.push({key:`'${S}.${h}'`,schema:_.databaseid_orig,table:_.as?_.as_orig:_.tableid_orig,keys:new Set}),r.push(`${_.as?_.as:_.tableid}.\`${h}\` AS "${S}.${h}"`),c[_.as?_.as_orig:_.tableid_orig]=this.data[`${_.databaseid_orig}_${_.as?_.as_orig:_.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let u="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(u="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(_=>{_.is_func?r.push(_.initial_select_column.toString()):_.initial_select_column.tableid?r.push(`${_.initial_select_column.tableid}.${_.initial_select_column.columnid} AS ${_.expression.columnid}`):r.push(`${_.initial_select_column.columnid} AS ${_.expression.columnid}`)}));let f="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(f=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let p=[];try{let _=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${u} ${f} ${d}`,h=this._convertColumnsToIndexes(_,s);p=await Tn.promise(h,t),t=null}catch(_){throw xe.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),xe.error(_),new Error("There was a problem processing the data.")}if(p&&p.length>0){for(let _=0,h=p.length;_<h;_++){let S=p[_];o.forEach(g=>{S[g.key]!==null&&S[g.key]!==void 0&&g.keys.add(S[g.key])})}o.forEach(_=>{let h=Object.keys(this.data[`${_.schema}_${_.table}`].__merged_data),S=__.difference(h,[..._.keys].map(g=>g.toString()));for(let g=0,R=S.length;g<R;g++){let E=S[g];delete this.data[`${_.schema}_${_.table}`].__merged_data[E]}})}return{existing_attributes:c,joined_length:p?p.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new cE(this.columns);for(let{node:i}of s)if(i&&i.columnid){let o=this._findColumn(i);if(o){let c=o.table.as?o.table.as:o.table.tableid;(!t[c]||t[c].indexOf(o.attribute)<0)&&n.push(o)}}n=__.uniqBy(n,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(n)}catch(i){throw xe.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),xe.error(i),new Error(Zs)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__merged_data,o=[];for(let f in i)o.push(i[f][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await Iu.getDataByHash(c),u=s.columns.length;for(let f=0,d=o.length;f<d;f++){let p=o[f],_=l.get(p);for(let h=0;h<u;h++){let S=s.columns[h],g=_[S]===void 0?null:_[S];this.data[n].__merged_data[p].push(g)}}}}catch(r){throw xe.error("Error thrown from getDataByHash function in SQLSearch class method getData."),xe.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__merged_data)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,l=o.aggregatorid?o.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===l}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();xe.trace(`Final SQL: ${s}`),n=await Tn.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),xe.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw xe.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),xe.error(s),new Error("There was a problem running the generated sql.")}return n}_translateUndefinedValues(t){try{let r=[];for(let n of t){let s=Object.create(null);Object.keys(n).forEach(i=>{n[i]===void 0?s[i]=null:s[i]=n[i]}),r.push(s)}return r}catch(r){return xe.error(B6.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),xe.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],u=new RegExp(`${l}.\`${o}\``,"g"),f=`${l}.[${c}]`;n=n.replace(u,f)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),u=`[${c}]`;n=n.replace(l,u)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await Iu.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]={...r[s]}),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw xe.error("There was an error when processing this SQL operation. Check your logs"),xe.error(o),new Error(Zs)}}return Object.values(Object.values(this.data)[0].__merged_data)}};Kv.exports=yy});var Yr=w((tNe,Wv)=>{"use strict";var k6=Dv();Wv.exports={searchByConditions:G6,searchByHash:q6,searchByValue:$6,search:V6};var by=Vn(),{transformReq:Oy}=ie(),F6=Yv();async function G6(e){return Oy(e),by.searchByConditions(e)}a(G6,"searchByConditions");async function q6(e){Oy(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of by.searchByHash(e))r&&t.push(r);return t}a(q6,"searchByHash");async function $6(e){Oy(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of by.searchByValue(e))t.push(r);return t}a($6,"searchByValue");function V6(e,t){try{let r=new k6(e);r.validate(),new F6(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(V6,"search")});var Eo=w((nNe,Qv)=>{"use strict";var p_=require("crypto"),K6=ae(),{CONFIG_PARAMS:Y6}=(H(),C(G)),jv="aes-256-cbc",W6=32,z6=16,Ny=64,Jv=32,j6=Ny+Jv,zv=new Map;Qv.exports={encrypt:J6,decrypt:Q6,createNatsTableStreamName:X6};function J6(e){let t=p_.randomBytes(W6),r=p_.randomBytes(z6),n=p_.createCipheriv(jv,Buffer.from(t),r),s=n.update(e);s=Buffer.concat([s,n.final()]);let i=t.toString("hex"),o=r.toString("hex"),c=s.toString("hex");return i+o+c}a(J6,"encrypt");function Q6(e){let t=e.substr(0,Ny),r=e.substr(Ny,Jv),n=e.substr(j6,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=p_.createDecipheriv(jv,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(Q6,"decrypt");function X6(e,t){let r=K6.get(Y6.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=zv.get(r);return n||(n=p_.createHash("md5").update(r).digest("hex"),zv.set(r,n)),n}a(X6,"createNatsTableStreamName")});var go=w((oNe,tU)=>{"use strict";var iNe=Yr(),h_=z(),{validateBySchema:Xv}=ot(),Kc=require("joi"),Z6=Eo(),lE=ie(),{handleHDBError:uE,hdb_errors:eZ,ClientError:Zv}=pe(),{HDB_ERROR_MSGS:dE,HTTP_STATUS_CODES:wy}=eZ,eU=ae();eU.initSync();var{getDatabases:Iy}=(De(),C(nt)),tZ=require("fs-extra"),rZ=(H(),C(G));tU.exports={describeAll:nZ,describeTable:fE,describeSchema:sZ};async function nZ(e={}){try{let t=lE.isEmptyOrZeroLength(e),r=!!e.bypass_auth,n,s;!t&&!r&&(n=e.hdb_user?.role?.permission,s=n?.super_user||n?.cluster_user);let i=Iy(),o={},c={},l=[],u=e?.exact_count;for(let d in i){o[d]=!0,!t&&!s&&!r&&(c[d]=e.hdb_user?.role?.permission[d]?.describe);let p=i[d];for(let _ in p)try{let h;if(t||s||r)h=await fE({schema:d,table:_,exact_count:u});else if(n&&n[d].describe&&n[d].tables[_].describe){let S=n[d].tables[_].attribute_permissions;h=await fE({schema:d,table:_,exact_count:u},S)}h&&l.push(h)}catch(h){h_.error(h)}}let f={};for(let d in l)t||s||r?(f[l[d].schema]==null&&(f[l[d].schema]={}),f[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]):c[l[d].schema]&&(f[l[d].schema]==null&&(f[l[d].schema]={}),f[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]);for(let d in o)t||s||r?f[d]={}:c[d]&&(f[d]={});return f}catch(t){return h_.error("Got an error in describeAll"),h_.error(t),uE(new Error,dE.DESCRIBE_ALL_ERR)}}a(nZ,"describeAll");async function fE(e,t){lE.transformReq(e);let{schema:r,table:n}=e;r=r?.toString(),n=n?.toString();let s=t;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(s=e.hdb_user?.role?.permission[r]?.tables[n]?.attribute_permissions);let i=Xv(e,Kc.object({database:Kc.string(),table:Kc.string().required(),exact_count:Kc.boolean().strict()}));if(i)throw new Zv(i.message);let c=Iy()[r];if(!c)throw uE(new Error,dE.SCHEMA_NOT_FOUND(e.schema),wy.NOT_FOUND);let l=c[n];if(!l)throw uE(new Error,dE.TABLE_NOT_FOUND(e.schema,e.table),wy.NOT_FOUND);function u(_){f.push({attribute:_.attribute,type:_.type,elements:_.elements?.type,indexed:_.indexed,is_primary_key:_.isPrimaryKey,assigned_created_time:_.assignCreatedTime,assigned_updated_time:_.assignUpdatedTime,nullable:_.nullable,properties:_.properties?_.properties.map(h=>({type:h.type,name:h.name})):void 0})}a(u,"pushAtt");let f=[];if(s){let _={};s.forEach(h=>{h.describe&&(_[h.attribute_name]=!0)}),l.attributes.forEach(h=>{_[h.name]&&u(h)})}else l.attributes?.forEach(_=>u(_));let d;try{d=(await tZ.stat(l.primaryStore.env.path)).size}catch(_){h_.warn("unable to get database size",_)}let p={schema:r,name:l.tableName,hash_attribute:l.attributes.find(_=>_.isPrimaryKey||_.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:f,db_size:d};l.replicate!==void 0&&(p.replicate=l.replicate),l.expirationMS!==void 0&&(p.expiration=l.expirationMS/1e3+"s"),l.sealed!==void 0&&(p.sealed=l.sealed),l.sources?.length>0&&(p.sources=l.sources.map(_=>_.name).filter(_=>_&&_!=="NATSReplicator"&&_!=="Replicator")),eU.get(rZ.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(p.clustering_stream_name=Z6.createNatsTableStreamName(p.schema,p.name));try{let _=await l.getRecordCount({exactCount:!!e.exact_count});p.record_count=_.recordCount,p.table_size=l.getSize(),p.db_audit_size=l.getAuditSize(),p.estimated_record_range=_.estimatedRange;let h=l.auditStore;if(h)for(let S of h.getKeys({reverse:!0,limit:1}))p.last_updated_record=S[0];if(!p.last_updated_record&&l.indices.__updatedtime__)for(let S of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))p.last_updated_record=S}catch(_){h_.warn(`unable to stat table dbi due to ${_}`)}return p}a(fE,"descTable");async function sZ(e){lE.transformReq(e);let t=Xv(e,Kc.object({database:Kc.string(),exact_count:Kc.boolean().strict()}));if(t)throw new Zv(t.message);let r;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(r=e.hdb_user?.role?.permission[e.schema]);let n=e.schema.toString(),i=Iy()[n];if(!i)throw uE(new Error,dE.SCHEMA_NOT_FOUND(e.schema),wy.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),lE.isEmpty(l)||l.describe){let u=await fE({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(sZ,"describeSchema")});var As=w((uNe,oU)=>{var iZ=po(),{callbackify:nU,promisify:oZ}=require("util"),{getDatabases:sU}=(De(),C(nt));oU.exports={setSchemaDataToGlobal:rU,getTableSchema:aZ,getSystemSchema:cZ,setSchemaDataToGlobalAsync:oZ(rU)};var iU=go(),cNe=nU(iU.describeAll),lNe=nU(iU.describeTable);function rU(e){global.hdb_schema=sU(),e&&e()}a(rU,"setSchemaDataToGlobal");function aZ(e,t,r){let n=sU()[e];if(!n)return r(`schema ${e} does not exist`);let s=n[t];return s?r(null,{schema:e,name:t,hash_attribute:s.primaryKey}):r(`table ${e}.${t} does not exist`)}a(aZ,"getTableSchema");function cZ(){return iZ}a(cZ,"getSystemSchema")});var Py=w((fNe,lU)=>{var lZ=ot(),Cy=require("joi"),{hdb_table:uZ,hdb_database:aU}=Di(),cU={schema:aU,database:aU,table:uZ},dZ={date:Cy.date().iso().required()},fZ={timestamp:Cy.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};lU.exports=function(e,t){let r=t==="timestamp"?{...cU,...fZ}:{...cU,...dZ},n=Cy.object(r);return lZ.validateBySchema(e,n)}});var fU=w((_Ne,dU)=>{var _Z=ot(),Dy=require("joi"),{hdb_table:pZ,hdb_database:uU}=Di(),hZ=Dy.object({schema:uU,database:uU,table:pZ,hash_values:Dy.array().required(),ids:Dy.array()});dU.exports=function(e){return _Z.validateBySchema(e,hZ)}});var Uy=w((pNe,_U)=>{"use strict";var Ly=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i){this.operation=t,this.schema=r,this.table=n,this.hash_attribute=s,this.records=i}},My=class{static{a(this,"NoSQLSeachObject")}constructor(t,r,n,s,i,o){this.schema=t,this.table=r,this.search_attribute=n,this.hash_attribute=s,this.get_attributes=i,this.search_value=o}},vy=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};_U.exports={InsertObject:Ly,NoSQLSeachObject:My,DeleteResponseObject:vy}});var zc=w((mNe,gU)=>{"use strict";var hU=Py(),mZ=fU(),Yc=ie(),pU=require("moment"),mU=z(),{promisify:EZ,callbackify:gZ}=require("util"),Wc=(H(),C(G)),SZ=As(),xy=EZ(SZ.getTableSchema),By=Vn(),{DeleteResponseObject:TZ}=Uy(),{handleHDBError:ba,hdb_errors:AZ}=pe(),{HDB_ERROR_MSGS:_E,HTTP_STATUS_CODES:Oa}=AZ,RZ="records successfully deleted",yZ=gZ(EU);gU.exports={delete:yZ,deleteRecord:EU,deleteFilesBefore:bZ,deleteAuditLogsBefore:OZ};async function bZ(e){let t=hU(e,"date");if(t)throw ba(t,t.message,Oa.BAD_REQUEST,void 0,void 0,!0);if(Yc.transformReq(e),!pU(e.date,pU.ISO_8601).isValid())throw ba(new Error,_E.INVALID_DATE,Oa.BAD_REQUEST,Wc.LOG_LEVELS.ERROR,_E.INVALID_DATE,!0);let n=Yc.checkSchemaTableExist(e.schema,e.table);if(n)throw ba(new Error,n,Oa.NOT_FOUND,Wc.LOG_LEVELS.ERROR,n,!0);let s=await By.deleteRecordsBefore(e);if(await xy(e.schema,e.table),mU.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(bZ,"deleteFilesBefore");async function OZ(e){let t=hU(e,"timestamp");if(t)throw ba(t,t.message,Oa.BAD_REQUEST,void 0,void 0,!0);if(Yc.transformReq(e),isNaN(e.timestamp))throw ba(new Error,_E.INVALID_VALUE("Timestamp"),Oa.BAD_REQUEST,Wc.LOG_LEVELS.ERROR,_E.INVALID_VALUE("Timestamp"),!0);let r=Yc.checkSchemaTableExist(e.schema,e.table);if(r)throw ba(new Error,r,Oa.NOT_FOUND,Wc.LOG_LEVELS.ERROR,r,!0);let n=await By.deleteAuditLogsBefore(e);return await xy(e.schema,e.table),mU.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(OZ,"deleteAuditLogsBefore");async function EU(e){e.ids&&(e.hash_values=e.ids);let t=mZ(e);if(t)throw ba(t,t.message,Oa.BAD_REQUEST,void 0,void 0,!0);Yc.transformReq(e);let r=Yc.checkSchemaTableExist(e.schema,e.table);if(r)throw ba(new Error,r,Oa.NOT_FOUND,Wc.LOG_LEVELS.ERROR,r,!0);try{await xy(e.schema,e.table);let n=await By.deleteRecords(e);return Yc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${RZ}`),n}catch(n){if(n.message===Wc.SEARCH_NOT_FOUND_MESSAGE){let s=new TZ;return s.message=Wc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(EU,"deleteRecord")});var pE={};ve(pE,{HASH_FUNCTION:()=>g_,hash:()=>Fy,validate:()=>Gy});function Hy(e=E_){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(m_.randomBytes(e)).map(r=>t[r%t.length]).join("")}function Fy(e,t=g_[TU?.toUpperCase()]??"sha256"){return ky[t](e)}function Gy(e,t,r=g_[TU?.toUpperCase()]??"sha256"){return e?NZ[r](e,t):!1}var m_,Cu,SU,TU,E_,AU,g_,ky,NZ,hE=be(()=>{m_=M(require("node:crypto")),Cu=M(require("argon2")),SU=M(ae());H();TU=(0,SU.get)(x.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),E_=16,AU=9,g_=(n=>(n.MD5="md5",n.SHA256="sha256",n.ARGON2ID="argon2id",n))(g_||{});a(Hy,"generateSalt");ky={md5:a((e,t=void 0)=>{t=t??Hy(AU);let r=m_.createHash("md5").update(e+t).digest("hex");return t+r},"md5"),sha256:a((e,t=void 0)=>{t=t??Hy(E_);let r=m_.createHash("sha256").update(e+t).digest("hex");return t+r},"sha256"),argon2id:a(async e=>{let t=Hy(E_),r=await Cu.hash(e,{type:Cu.argon2id,salt:Buffer.from(t)});return t+r},"argon2id")},NZ={md5:a((e,t)=>{let r=e.slice(0,AU);return e===ky.md5(t,r)},"md5"),sha256:a((e,t)=>{let r=e.slice(0,E_);return e===ky.sha256(t,r)},"sha256"),argon2id:a(async(e,t)=>await Cu.verify(e.slice(E_),t),"argon2id")};a(Fy,"hash");a(Gy,"validate")});var yU=w((TNe,RU)=>{var qy=ot(),Wr={username:{presence:!0,exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function wZ(e){return Wr.password.presence=!0,Wr.username.presence=!0,Wr.role.presence=!0,Wr.active.presence=!0,qy.validateObject(e,Wr)}a(wZ,"addUserValidation");function IZ(e){return Wr.password.presence=!1,Wr.username.presence=!0,Wr.role.presence=!1,Wr.active.presence=!1,qy.validateObject(e,Wr)}a(IZ,"alterUserValidation");function CZ(e){return Wr.password.presence=!1,Wr.username.presence=!0,Wr.role.presence=!1,Wr.active.presence=!1,qy.validateObject(e,Wr)}a(CZ,"dropUserValidation");RU.exports={addUserValidation:wZ,alterUserValidation:IZ,dropUserValidation:CZ}});var Tt=w((yNe,OU)=>{"use strict";var{platform:RNe}=require("os"),PZ="nats-server.zip",$y="nats-server",DZ=process.platform==="win32"?`${$y}.exe`:$y,LZ=/^[^\s.,*>]+$/,bU="__request__",MZ=a(e=>`${e}.${bU}`,"REQUEST_SUBJECT"),vZ={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},UZ={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},xZ={HUB:"hub.pid",LEAF:"leaf.pid"},BZ={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},HZ={SUCCESS:"success",ERROR:"error"},kZ={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},FZ={TXN:"txn",MSGID:"msgid"},Pu={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},GZ={[Pu.ERR]:1,[Pu.WRN]:2,[Pu.INF]:3,[Pu.DBG]:4,[Pu.TRC]:5},qZ={debug:"-D",trace:"-DVV"};OU.exports={NATS_SERVER_ZIP:PZ,NATS_SERVER_NAME:$y,NATS_BINARY_NAME:DZ,PID_FILES:xZ,NATS_CONFIG_FILES:UZ,SERVER_SUFFIX:BZ,NATS_TERM_CONSTRAINTS_RX:LZ,REQUEST_SUFFIX:bU,UPDATE_REMOTE_RESPONSE_STATUSES:HZ,CLUSTER_STATUS_STATUSES:kZ,REQUEST_SUBJECT:MZ,SUBJECT_PREFIXES:FZ,MSG_HEADERS:vZ,LOG_LEVELS:Pu,LOG_LEVEL_FLAGS:qZ,LOG_LEVEL_HIERARCHY:GZ}});var Vy=w(NU=>{"use strict";var $Z={cert:"-----BEGIN CERTIFICATE-----\rMIIDXDCCAkSgAwIBAgIFNTE4MzQwDQYJKoZIhvcNAQELBQAwXTEXMBUGA1UEAxMO\rSGFycGVyREIsIEluYy4xCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDTzEPMA0GA1UE\rBxMGRGVudmVyMRcwFQYDVQQKEw5IYXJwZXJEQiwgSW5jLjAeFw0yMjAzMTEyMzAz\rNDlaFw0yNzAzMTAyMzAzNDlaMF0xFzAVBgNVBAMTDkhhcnBlckRCLCBJbmMuMQsw\rCQYDVQQGEwJVUzELMAkGA1UECBMCQ08xDzANBgNVBAcTBkRlbnZlcjEXMBUGA1UE\rChMOSGFycGVyREIsIEluYy4wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB\rAQCsEUlBF8WImS78rCFXVKyntxfrW++4qZ3hGnoD2MHZAuDHyeP/5eGnaE9GQhKc\r4DwG4DGvh0wP2zIYnBfiQ3L2ZtnlDR9ZkKIQYGlVxTUn6T43krhK5nZKqDF43Yg3\rZEvO3cbJBjiKZx0eA2/toehdSsTAHHQx5gTDcggNe2tgoJHYPwi9YF/AxSBZrbgb\ryWlYgtYDmF32ytHP03GUCIdKOFuBPsHTGu4SkdEIdLIqO9oglW1YFH5qZ6NiwApW\rsP+GCuqOwDXXbdjr75iq9Tq/CDrjGFLaTPmvd2Q0qG/BtaCll0ghpG+yIHvt/iQs\rajS+LxEWAnVlGMaDdFErbDUtAgMBAAGjIzAhMA8GA1UdEwEB/wQFMAMBAf8wDgYD\rVR0PAQH/BAQDAgIEMA0GCSqGSIb3DQEBCwUAA4IBAQASR4YW/rPK7PNArHVe9zzM\rb0rKNX/2T9/0nybRhmE/+hdlSgliTAeebmwkUS2APckmekYt/q2ZY2NS65Fo/jjp\rG8TJrtcF4h+ylVqUp0ZXQLFtIsr7r2JZA7hJ6njW6G4DHSZ0gxtECLi4CBlTjzm5\rNmnmIDObvGRTuqmcdAZmXeObbta/He2XIzietukPAYX062pNM+G5XT5UM1eG/Vlp\rN86vjhpyI+ffKy+C60SJqxmKM3ydgN7oLscE7+2wLPN25XqN4W99OwGsp5dTdu/f\r5lPtFayXdJ55e/sNQKmGN+UGLrL05c2MWgjb8U/LFilnupUianceoeSERZmVjzKX\r-----END CERTIFICATE-----\r".replace(/\r/g,`\r
18
18
  `),key:"-----BEGIN RSA PRIVATE KEY-----\rMIIEowIBAAKCAQEArBFJQRfFiJku/KwhV1Ssp7cX61vvuKmd4Rp6A9jB2QLgx8nj\r/+Xhp2hPRkISnOA8BuAxr4dMD9syGJwX4kNy9mbZ5Q0fWZCiEGBpVcU1J+k+N5K4\rSuZ2SqgxeN2IN2RLzt3GyQY4imcdHgNv7aHoXUrEwBx0MeYEw3IIDXtrYKCR2D8I\rvWBfwMUgWa24G8lpWILWA5hd9srRz9NxlAiHSjhbgT7B0xruEpHRCHSyKjvaIJVt\rWBR+amejYsAKVrD/hgrqjsA1123Y6++YqvU6vwg64xhS2kz5r3dkNKhvwbWgpZdI\rIaRvsiB77f4kLGo0vi8RFgJ1ZRjGg3RRK2w1LQIDAQABAoIBAQCEOmh78EOpnGZC\rYBjjHrvrysVD5gvLcfVUtl8Ls7gMB60re1eOIF+PoZZCHKZnDd6zPfiQtj1adg0C\rYnnsM/8VoaZS4gm0b3RLd3ubIQifWhuo40RissY2yxfxlPSH9LhZCY8ojnJG0cTL\resK579E8WCfopjUY33XLqEbN7Ylv39J+DSqInjqV3efJZUa+HqUJ98VxxzodcKMD\rP3bwUU4gHoSSp4pAsOFH5sQhaIWH1IcNjrAwpee2cJQuh4G157RRIuuUpagtaEG/\rXJIiAyBguJyu3JQFnIBQF01N5+omJgXYJ1L0m54543/iIRThmF3zDCDgCyUzmOk+\rH6As9fv1AoGBANOpOtOZLSAScjGsgJamT3ceJ2wCa86g2j8Oxu8lJUmUp5s3tA0v\rBFW5O3S4KR1EXwkLMBUMrfFM8YvzHWxsXBI6XV8azGLvyqPHxr65OhmpGYkGZMXu\rn9okgjkqlewnY2I073gvyK7ppX51UL5y9fF1vlsk+UlW+Rgx/vMHbdcjAoGBANAc\rxRUsxs4QJpbS4zD3JOkHjr24a97TrS3kCybAHUMpR2NrEHPZw9zex0/aphOJUHfL\rIMkOZdpfDqMfxWy4FAEmqBEMkO2SB+h0Wp4P+qp81ax4vGFiB0cD3wtixr11U1tt\rlZ/ZTdv4VDpDFNK1KaplhTDeyuCjeYfS3/GJia9vAoGAcOsAgjBevZR5rXx84WH6\rVO8WUu37u7FenXNxt9VWTinrPMh72uixZFY8nOk+rely1e1NCn3IMko9Ns9NbDFm\r8SaH95vhXArXTYbfxZIlp9jp0YtCqcHDL+p4Oq04bFMbFyJseu7rHj1x18QYfnHw\rOY/6LL/N6k1m+Hx7qgXVmIcCgYB/w0nTCBw84XlvWqSTqQaF8VfWbWP79mP5KmkW\rLxdH5g2noVEGbohqDnK6OXd/wusdwByukiJBf94Skyy25AOT+VFwthA7aU1ljhkb\rtJ+lDuJ28eBkwLPLCzthWBC+u0qjdJFJAzVjd/7tjcU43nNn4s90AzL12iaAFhvZ\rwyA+DQKBgGc/4cdyGJ3YkcA8150gQBawgJZ7q8V1JND87ggWA8wnK3cHn7rMZQl2\r3emDp9HEFXFex5dbGDDqZFAoesZCDxjknIn9oNfW4PvaWS8q7b6ZKLZG1p03Pu7/\rtYaD0kPbo0kysfFT/co+NgHbdykvIyboomfGdNLTUjYuy6lpwpvs\r-----END RSA PRIVATE KEY-----\r".replace(/\r/g,`\r
19
- `)},KZ="certificate.pem",YZ="privateKey.pem",WZ="caCertificate.pem",zZ="natsCertificate.pem",jZ="natsCaCertificate.pem",At={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},JZ={tls_certificate:At.SERVER,tls_certificateAuthority:At.CA,customFunctions_tls_certificate:At.SERVER,customFunctions_tls_certificateAuthority:At.CA,operationsApi_tls_certificate:At["OPERATIONS-API"],operationsApi_tls_certificateAuthority:At["OPERATIONS-CA"]},QZ={[At.SERVER]:2,[At.DEFAULT]:1},XZ={[At["OPERATIONS-API"]]:3,[At.SERVER]:2,[At.DEFAULT]:1},ZZ={[At["OPERATIONS-API"]]:3,[At.SERVER]:2,[At.DEFAULT]:1},e8={[At["OPERATIONS-CA"]]:3,[At.CA]:2,[At["DEFAULT-CA"]]:1},t8={[At["OPERATIONS-CA"]]:3,[At.CA]:2,[At["DEFAULT-CA"]]:1},r8={[At.CA]:2,[At["DEFAULT-CA"]]:1};Object.assign(OU,{CERTIFICATE_PEM_NAME:KZ,PRIVATEKEY_PEM_NAME:YZ,CA_PEM_NAME:WZ,CERT_NAME:At,CERT_CONFIG_NAME_MAP:JZ,CERT_PREFERENCE_APP:QZ,CERT_PREFERENCE_OPS:XZ,CERT_PREFERENCE_REP:ZZ,CA_CERT_PREFERENCE_REP:e8,CA_CERT_PREFERENCE_OPS:t8,CA_CERT_PREFERENCE_APP:r8,CERTIFICATE_VALUES:VZ,NATS_CERTIFICATE_PEM_NAME:zZ,NATS_CA_PEM_NAME:jZ})});var Ky=w((bNe,DU)=>{"use strict";var CU=require("fs-extra"),Te=require("joi"),n8=require("os"),{boolean:Be,string:Rt,number:tr,array:Yc}=Te.types(),{totalmem:NU}=require("os"),Kc=require("path"),s8=z(),Vy=ie(),yNe=$y(),wU=(H(),C(G)),i8=it(),IU="log",o8="components",a8="Invalid logging.rotation.maxSize unit. Available units are G, M or K",c8="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",l8="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",u8="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",d8="rootPath config parameter is undefined",Tn=Te.alternatives([tr.min(0),Rt]).optional().empty(null),hE=Te.alternatives([Yc.items(Rt,{host:Rt.required(),port:Tn},{hostname:Rt.required(),port:Tn}).empty(null),Yc.items(Rt)]),vi,PU=!1;DU.exports={configValidator:f8,routesValidator:g8,route_constraints:hE};function f8(e,t=!1){if(PU=t,vi=e.rootPath,Vy.isEmpty(vi))throw d8;let r=Be.optional(),n=tr.min(0).max(1e3).empty(null).default(E8),s=Rt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(S_),i=Rt.optional().empty(null),o=Rt.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=Te.string().empty(null).default(S_),l=Te.custom(p8).empty(null).default(S_),u=e.clustering?.enabled,f=Te.object({certificate:i,certificateAuthority:i,privateKey:i}),d;return u===!0?d=Te.object({enabled:r,hubServer:Te.object({cluster:Te.object({name:Te.required().empty(null),network:Te.object({port:Tn,routes:hE}).required()}).required(),leafNodes:Te.object({network:Te.object({port:Tn}).required()}).required(),network:Te.object({port:Tn}).required()}).required(),leafServer:Te.object({network:Te.object({port:Tn,routes:hE}).required(),streams:Te.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:Te.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:Be.optional(),databaseLevel:Be.optional(),tls:Te.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:Be.required(),verify:Be.optional()}),user:Rt.optional().empty(null)}).optional():d=Te.object({enabled:r,tls:Te.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:Be.optional()})}).optional(),Te.object({authentication:Te.alternatives(Te.object({authorizeLocal:Be,cacheTTL:tr.required(),enableSessions:Be,hashFunction:Rt.valid("md5","sha256","argon2id").optional().empty(null)}),Be).optional(),analytics:Te.object({aggregatePeriod:tr}),replication:Te.object({hostname:Te.alternatives(Rt,tr).optional().empty(null),url:Rt.optional().empty(null),port:Tn,securePort:Tn,routes:Yc.optional().empty(null),databases:Te.alternatives(Rt,Yc),enableRootCAs:Be.optional(),copyTablesToCatchUp:Be.optional()}).optional(),componentsRoot:s.optional(),clustering:d,localStudio:Te.object({enabled:r}).required(),logging:Te.object({auditAuthEvents:Te.object({logFailed:Be,logSuccessful:Be}),file:Be.required(),level:Te.valid("notify","fatal","error","warn","info","debug","trace"),rotation:Te.object({enabled:Be.optional(),compress:Be.optional(),interval:Rt.custom(m8).optional().empty(null),maxSize:Rt.custom(h8).optional().empty(null),path:Rt.optional().empty(null).default(S_)}).required(),root:s,stdStreams:Be.required(),auditLog:Be.required()}).required(),operationsApi:Te.object({network:Te.object({cors:Be.optional(),corsAccessList:Yc.optional(),headersTimeout:tr.min(1).optional(),keepAliveTimeout:tr.min(1).optional(),port:Tn,domainSocket:Te.optional().empty("hdb/operations-server").default(S_),securePort:Tn,timeout:tr.min(1).optional()}).optional(),tls:Te.alternatives([Te.array().items(f),f])}).required(),rootPath:Rt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:Te.object({network:Te.object({port:Tn,securePort:Tn,mtls:Te.alternatives([Be.optional(),Te.object({user:Rt.optional(),certificateAuthority:i,required:Be.optional()})])}).required(),webSocket:Be.optional(),requireAuthentication:Be.optional()}),http:Te.object({compressionThreshold:tr.optional(),cors:Be.optional(),corsAccessList:Yc.optional(),headersTimeout:tr.min(1).optional(),port:Tn,securePort:Tn,maxHeaderSize:tr.optional(),mtls:Te.alternatives([Be.optional(),Te.object({user:Rt.optional(),certificateAuthority:i,required:Be.optional()})]),threadRange:Te.alternatives([Yc.optional(),Rt.optional()])}).required(),threads:Te.alternatives(n.optional(),Te.object({count:n.optional(),debug:Te.alternatives(Be.optional(),Te.object({startingPort:tr.min(1).optional(),host:Rt.optional(),waitForDebugger:Be.optional()})),maxHeapMemory:tr.min(0).optional()})),storage:Te.object({writeAsync:Be.required(),overlappingSync:Be.optional(),caching:Be.optional(),compression:Te.alternatives([Be.optional(),Te.object({dictionary:Rt.optional(),threshold:tr.optional()})]),compactOnStart:Be.optional(),compactOnStartKeepBackup:Be.optional(),noReadAhead:Be.optional(),path:l,prefetchWrites:Be.optional(),maxFreeSpaceToLoad:tr.optional(),maxFreeSpaceToRetain:tr.optional()}).required(),ignoreScripts:Be.optional(),tls:Te.alternatives([Te.array().items(f),f])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(f8,"configValidator");function _8(e){return PU||CU.existsSync(e)?null:`Specified path ${e} does not exist.`}a(_8,"doesPathExist");function p8(e,t){Te.assert(e,Rt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=_8(e);if(r)return t.message(r)}a(p8,"validatePath");function h8(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(a8);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(l8):e}a(h8,"validateRotationMaxSize");function m8(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(c8);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(u8):e}a(m8,"validateRotationInterval");function E8(e,t){let r=t.state.path.join("."),n=n8.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||NU();return i=Math.round(Math.min(i,NU())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),s8.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(E8,"setDefaultThreads");function S_(e,t){let r=t.state.path.join(".");if(!Vy.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(Vy.isEmpty(vi))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return Kc.join(vi,o8);case"logging.root":return Kc.join(vi,IU);case"clustering.leafServer.streams.path":return Kc.join(vi,"clustering","leaf");case"storage.path":let n=Kc.join(vi,wU.LEGACY_DATABASES_DIR_NAME);return CU.existsSync(n)?n:Kc.join(vi,wU.DATABASES_DIR_NAME);case"logging.rotation.path":return Kc.join(vi,IU);case"operationsApi.network.domainSocket":return r==null?null:Kc.join(vi,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(S_,"setDefaultRoot");function g8(e){let t=Te.object({routes:hE});return i8.validateBySchema({routes:e},t)}a(g8,"routesValidator")});var yt=w(qU=>{"use strict";var Rs=(H(),C(G)),gr=ie(),rr=z(),{configValidator:S8,routesValidator:LU}=Ky(),zr=require("fs-extra"),vU=require("yaml"),Yn=require("path"),T8=require("is-number"),UU=require("properties-reader"),A8=require("lodash"),{handleHDBError:R8}=pe(),{HTTP_STATUS_CODES:y8,HDB_ERROR_MSGS:Pu}=Un(),{server:b8}=(Vr(),C(Tu)),{PACKAGE_ROOT:xU}=st(),{DATABASES_PARAM_CONFIG:T_,CONFIG_PARAMS:Kn,CONFIG_PARAM_MAP:ei}=Rs,O8="Unable to get config value because config is uninitialized",N8="Config successfully initialized",w8="Error backing up config file",I8="Empty parameter sent to getConfigValue",BU=Yn.join(xU,"config","yaml",Rs.HDB_DEFAULT_CONFIG_FILE),C8=Yn.join(xU,"config","yaml","defaultNatsConfig.yaml"),P8="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",MU={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"},mE,It,EE;Object.assign(qU,{createConfigFile:D8,getDefaultConfig:L8,getConfigValue:kU,initConfig:gE,flattenConfig:Du,updateConfigValue:FU,updateConfigObject:v8,getConfiguration:B8,setConfiguration:H8,readConfigFile:jy,getClusteringRoutes:k8,initOldConfig:GU,getConfigFromFile:F8,getConfigFilePath:Wc,addConfig:G8,deleteConfigFromFile:q8,getConfigObj:$8,resolvePath:Yy,getFlatConfigObj:V8});function Yy(e){if(e?.startsWith("~/"))return Yn.join(gr.getHomeDir(),e.slice(1));let t=ae();return Yn.resolve(t.getHdbBasePath(),e)}a(Yy,"resolvePath");function D8(e,t=!1){let r=Na(BU);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=vU.parseDocument(zr.readFileSync(C8,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}mE=Du(r.toJSON());let n;for(let c in e){let l=ei[c.toLowerCase()];if(l===Kn.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(u=>({[u]:e[c][u]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let u=l.split("_"),f=Wy(l,e[c]);l==="rootPath"&&f?.endsWith("/")&&(f=f.slice(0,-1));try{r.setIn([...u],f)}catch(d){rr.error(d)}}}n&&HU(r,n),zy(r,t);let s=r.toJSON();It=Du(s);let i=r.getIn(["rootPath"]),o=Yn.join(i,Rs.HDB_CONFIG_FILE);if(zr.createFileSync(o),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);zr.writeFileSync(o,String(r)),rr.trace(`Config file written to ${o}`)}a(D8,"createConfigFile");function HU(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!gr.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(T_.TABLES))for(let i in n[s][T_.TABLES])for(let o in n[s][T_.TABLES][i]){let c=n[s][T_.TABLES][i][o],l=[Kn.DATABASES,s,T_.TABLES,i,o];e.hasIn(l)?e.setIn(l,c):e.addIn(l,c)}else for(let i in n[s]){let o=n[s][i],c=[Kn.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){rr.error("Error parsing schemas CLI/env config arguments",n)}}a(HU,"setSchemasConfig");function L8(e){if(mE===void 0){let r=Na(BU);mE=Du(r.toJSON())}let t=ei[e.toLowerCase()];if(t!==void 0)return mE[t.toLowerCase()]}a(L8,"getDefaultConfig");function kU(e){if(e==null){rr.info(I8);return}if(It===void 0){rr.trace(O8);return}let t=ei[e.toLowerCase()];if(t!==void 0)return It[t.toLowerCase()]}a(kU,"getConfigValue");function Wc(e=gr.getPropsFilePath()){let t=gr.getEnvCliRootPath();if(t)return Yy(Yn.join(t,Rs.HDB_CONFIG_FILE));let r=UU(e);return Yy(r.get(Rs.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(Wc,"getConfigFilePath");function gE(e=!1){if(It===void 0||e){let t;if(!gr.noBootFile()){t=gr.getPropsFilePath();try{zr.accessSync(t,zr.constants.F_OK|zr.constants.R_OK)}catch(i){throw rr.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Wc(t),n;if(r.includes("config/settings.js"))try{GU(r);return}catch(i){if(i.code!==Rs.NODE_ERROR_CODES.ENOENT)throw i}try{n=Na(r)}catch(i){if(i.code===Rs.NODE_ERROR_CODES.ENOENT){rr.trace(`HarperDB config file not found at ${r}.
20
- This can occur during early stages of install where the config file has not yet been created`);return}else throw rr.error(i),new Error(`Error reading HarperDB config file at ${r}`)}M8(n,r),zy(n);let s=n.toJSON();if(b8.config=s,It=Du(s),It.logging_rotation_rotate)for(let i in MU)It[i]&&rr.error(`Config ${MU[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);rr.trace(N8)}}a(gE,"initConfig");function M8(e,t){let r=e.getIn(["rootPath"]),n=!1;if(e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Yn.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Yn.join(r,"log")),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n){if(rr.trace("Updating config file with missing config params"),e.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${e.errors}`);zr.writeFileSync(t,String(e))}}a(M8,"checkForUpdatedConfig");function zy(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 Pu.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 Pu.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=S8(r,t);if(n.error)throw Pu.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(zy,"validateConfig");function v8(e,t){It===void 0&&(It={});let r=ei[e.toLowerCase()];if(r===void 0){rr.trace(`Unable to update config object because config param '${e}' does not exist`);return}It[r.toLowerCase()]=t}a(v8,"updateConfigObject");function FU(e,t,r=void 0,n=!1,s=!1,i=!1){It===void 0&&gE();let o=kU(ei.hdb_root),c=Yn.join(o,Rs.HDB_CONFIG_FILE),l=Na(c),u;if(r&&It){let p=!1;for(let _ in r)if(r[_]!=It[_.toLowerCase()]){p=!0;break}if(!p){rr.trace("No changes detected in config parameters, skipping update");return}}if(r===void 0&&e.toLowerCase()===Kn.DATABASES)u=t;else if(r===void 0){let p;if(i)p=e;else if(p=ei[e.toLowerCase()],p===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let _=p.split("_"),h=Wy(p,t);l.setIn([..._],h)}else for(let p in r){let _=ei[p.toLowerCase()];if(_===Kn.HTTP_SECUREPORT&&r[p]===It[Kn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),_===Kn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[p]===It[Kn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),_===Kn.DATABASES){u=r[p];continue}if(_?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!_&&(p.endsWith("_package")||p.endsWith("_port"))&&(_=p),_!==void 0){let h=_.split("_"),S=Rs.LEGACY_CONFIG_PARAMS[p.toUpperCase()];S&&S.startsWith("customFunctions")&&l.hasIn(S.split("_"))&&(_=S,h=S.split("_"));let g=Wy(_,r[p]);_==="rootPath"&&g?.endsWith("/")&&(g=g.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],g)}catch(R){rr.error(R)}}}u&&HU(l,u),zy(l);let f=l.getIn(["rootPath"]),d=Yn.join(f,Rs.HDB_CONFIG_FILE);if(n===!0&&U8(c,f),l.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${l.errors}`);zr.writeFileSync(d,String(l)),s&&(It=Du(l.toJSON())),rr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(FU,"updateConfigValue");function U8(e,t){try{let r=Yn.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${Rs.HDB_CONFIG_FILE}.bak`);zr.copySync(e,r),rr.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){rr.error(w8),rr.error(r)}}a(U8,"backupConfigFile");var x8=["databases"];function Du(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}),EE=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])&&!x8.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!Kn[l.toUpperCase()]&&ei[l]&&(s[ei[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Du,"flattenConfig");function Wy(e,t){if(e===Kn.CLUSTERING_NODENAME||e===Kn.CLUSTERING_USER){if(t==null)return t;if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if(T8(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||gr.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 gr.autoCast(t)}a(Wy,"castConfigValue");function B8(){let e=gr.getPropsFilePath(),t=Wc(e);return Na(t).toJSON()}a(B8,"getConfiguration");async function H8(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return FU(void 0,void 0,s,!0),P8}catch(i){throw typeof i=="string"||i instanceof String?R8(i,i,y8.BAD_REQUEST,void 0,void 0,!0):i}}a(H8,"setConfiguration");function jy(){let e=gr.getPropsFilePath();try{zr.accessSync(e,zr.constants.F_OK|zr.constants.R_OK)}catch(n){if(!gr.noBootFile())throw rr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Wc(e);return Na(t).toJSON()}a(jy,"readConfigFile");function Na(e){return vU.parseDocument(zr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Na,"parseYamlDoc");function k8(){let e=jy(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=gr.isEmptyOrZeroLength(t)?[]:t;let r=LU(t);if(r)throw Pu.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=gr.isEmptyOrZeroLength(n)?[]:n;let s=LU(n);if(s)throw Pu.CONFIG_VALIDATION(s.message);if(!gr.isEmptyOrZeroLength(n)&&!gr.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!gr.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw Pu.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(k8,"getClusteringRoutes");function GU(e){let t=UU(e);It={};for(let r in ei){let n=t.get(r.toUpperCase());if(gr.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=ei[r].toLowerCase();s===Kn.LOGGING_ROOT?It[s]=Yn.dirname(n):It[s]=n}return It}a(GU,"initOldConfig");function F8(e){let t=jy();return A8.get(t,e.replaceAll("_","."))}a(F8,"getConfigFromFile");async function G8(e,t){let r=Na(Wc());if(r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);await zr.writeFile(Wc(),String(r))}a(G8,"addConfig");function q8(e){let t=Wc(gr.getPropsFilePath()),r=Na(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Yn.join(n,Rs.HDB_CONFIG_FILE);zr.writeFileSync(s,String(r))}a(q8,"deleteConfigFromFile");function $8(){return EE||(gE(),EE)}a($8,"getConfigObj");function V8(){return It||gE(),It}a(V8,"getFlatConfigObj")});var An=w((INe,Or)=>{"use strict";var KU="username is required",YU="nothing to update, must supply active, role or password to update",WU="password cannot be an empty string",zU="If role is specified, it cannot be empty.",jU="active must be true or false";Or.exports.addUser=Z8;Or.exports.alterUser=e5;Or.exports.dropUser=r5;Or.exports.getSuperUser=a5;Or.exports.userInfo=n5;Or.exports.listUsers=TE;Or.exports.listUsersExternal=s5;Or.exports.setUsersWithRolesCache=zc;Or.exports.findAndValidateUser=sb;Or.exports.getClusterUser=c5;Or.exports.getUsersWithRolesCache=o5;Or.exports.USERNAME_REQUIRED=KU;Or.exports.ALTERUSER_NOTHING_TO_UPDATE=YU;Or.exports.EMPTY_PASSWORD=WU;Or.exports.EMPTY_ROLE=zU;Or.exports.ACTIVE_BOOLEAN=jU;var JU=Rn(),K8=Vc(),A_=(pE(),C(_E)),QU=RU(),R_=Yr(),eb=To(),Ui=ie(),XU=require("validate.js"),tb=z(),{promisify:Y8}=require("util"),rb=Eo(),Qy=(H(),C(G)),$U=Tt(),W8=yt(),z8=ae(),j8=po(),{hdb_errors:J8,ClientError:ti}=pe(),{HTTP_STATUS_CODES:So,AUTHENTICATION_ERROR_MSGS:Jy,HDB_ERROR_MSGS:Lu}=J8,{UserEventMsg:nb}=ri(),Xy=require("lodash"),{server:SE}=(Vr(),C(Tu)),Q8=z();SE.getUser=(e,t)=>sb(e,t,t!=null);SE.authenticateUser=(e,t)=>sb(e,t);var ZU={username:!0,active:!0,role:!0,password:!0},VU=new Map,X8=Y8(K8.delete),Zy=z8.get(Qy.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??A_.HASH_FUNCTION.SHA256,xi;async function Z8(e){let t=XU.cleanAttributes(e,ZU),r=QU.addUserValidation(t);if(r)throw new ti(r.message);let n=await R_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]});if(!n||n.length<1)throw new ti(Lu.ROLE_NAME_NOT_FOUND(t.role),So.NOT_FOUND);if(n.length>1)throw new ti(Lu.DUP_ROLES_FOUND(t.role),So.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=rb.encrypt(t.password)),t.password=await A_.hash(t.password,Zy),t.hash_function=Zy,t.role=n[0].id;let s=await JU.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(tb.debug(s),await zc(),s.skipped_hashes.length===1)throw new ti(Lu.USER_ALREADY_EXISTS(t.username),So.CONFLICT);return eb.signalUserChange(new nb(process.pid)),`${t.username} successfully added`}a(Z8,"addUser");async function e5(e){let t=XU.cleanAttributes(e,ZU);if(Ui.isEmptyOrZeroLength(t.username))throw new Error(KU);if(Ui.isEmptyOrZeroLength(t.password)&&Ui.isEmptyOrZeroLength(t.role)&&Ui.isEmptyOrZeroLength(t.active))throw new Error(YU);if(!Ui.isEmpty(t.password)&&Ui.isEmptyOrZeroLength(t.password.trim()))throw new Error(WU);if(!Ui.isEmpty(t.active)&&!Ui.isBoolean(t.active))throw new Error(jU);if(!Ui.isEmpty(t.password)&&!Ui.isEmptyOrZeroLength(t.password.trim())&&(t5(t.username)&&(t.hash=rb.encrypt(t.password)),t.password=await A_.hash(t.password,Zy)),t.role==="")throw new Error(zU);if(t.role){let n=await R_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]});if(!n||n.length===0)throw new ti(Lu.ALTER_USER_ROLE_NOT_FOUND(t.role),So.NOT_FOUND);if(n.length>1)throw new ti(Lu.DUP_ROLES_FOUND(t.role),So.CONFLICT);t.role=n[0].id}let r=await JU.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await zc(),eb.signalUserChange(new nb(process.pid)),r}a(e5,"alterUser");function t5(e){let t=!1,r=xi.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(t5,"isClusterUser");async function r5(e){let t=QU.dropUserValidation(e);if(t)throw new ti(t.message);if(xi.get(e.username)===void 0)throw new ti(Lu.USER_NOT_EXIST(e.username),So.NOT_FOUND);let r=await X8({table:"hdb_user",schema:"system",hash_values:[e.username]});return tb.debug(r),await zc(),eb.signalUserChange(new nb(process.pid)),`${e.username} successfully deleted`}a(r5,"dropUser");async function n5(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=Xy.cloneDeep(e.hdb_user);let r=await R_.searchByHash({schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]});return t.role=r[0],delete t.password,delete t.refresh_token,delete t.hash,delete t.hash_function,t}a(n5,"userInfo");async function s5(){let e=await TE();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}a(s5,"listUsersExternal");async function TE(){let e=await R_.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=Xy.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await R_.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=Xy.cloneDeep(s),s.role=t[s.role],i5(s.role),n.set(s.username,s);return n}a(TE,"listUsers");function i5(e){if(!e){tb.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(j8)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}a(i5,"appendSystemTablesToRole");async function zc(e=void 0){e?xi=e:xi=await TE()}a(zc,"setUsersWithRolesCache");async function o5(){return xi||await zc(),xi}a(o5,"getUsersWithRolesCache");async function sb(e,t,r=!0){xi||await zc();let n=xi.get(e);if(!n){if(!r)return{username:e};throw new ti(Jy.GENERIC_AUTH_FAIL,So.UNAUTHORIZED)}if(n&&!n.active)throw new ti(Jy.USER_INACTIVE,So.UNAUTHORIZED);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(VU.get(t)===n.password)return s;{let i=A_.validate(n.password,t,n.hash_function||A_.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)VU.set(t,n.password);else throw new ti(Jy.GENERIC_AUTH_FAIL,So.UNAUTHORIZED)}}return s}a(sb,"findAndValidateUser");async function a5(){xi||await zc();for(let[,e]of xi)if(e.role.role==="super_user")return e}a(a5,"getSuperUser");async function c5(){let e=await TE(),t=W8.getConfigFromFile(Qy.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==Qy.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=rb.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+$U.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+$U.SERVER_SUFFIX.ADMIN,r}a(c5,"getClusterUser");var e0=[];SE.invalidateUser=function(e){for(let t of e0)try{t(e)}catch(r){Q8.error("Error invalidating user",r)}};SE.onInvalidatedUser=function(e){e0.push(e)}});var b_=w((LNe,s0)=>{"use strict";var jc=z(),Wn=(H(),C(G)),l5=Ev(),PNe=As(),DNe=go(),u5=An(),{validateEvent:t0}=ri(),y_=Vn(),d5=require("process"),{resetDatabases:f5}=(Pe(),C(tt)),_5={[Wn.ITC_EVENT_TYPES.SCHEMA]:p5,[Wn.ITC_EVENT_TYPES.USER]:n0};async function p5(e){let t=t0(e);if(t){jc.error(t);return}jc.trace("ITC schemaHandler received schema event:",e),await l5(e.message),await h5(e.message)}a(p5,"schemaHandler");async function h5(e){try{y_.resetReadTxn(Wn.SYSTEM_SCHEMA_NAME,Wn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),y_.resetReadTxn(Wn.SYSTEM_SCHEMA_NAME,Wn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),y_.resetReadTxn(Wn.SYSTEM_SCHEMA_NAME,Wn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=f5();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){jc.error(t)}}a(h5,"syncSchemaMetadata");var r0=[];async function n0(e){try{try{y_.resetReadTxn(Wn.SYSTEM_SCHEMA_NAME,Wn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),y_.resetReadTxn(Wn.SYSTEM_SCHEMA_NAME,Wn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){jc.warn(r)}let t=t0(e);if(t){jc.error(t);return}jc.trace(`ITC userHandler ${Wn.HDB_ITC_CLIENT_PREFIX}${d5.pid} received user event:`,e),await u5.setUsersWithRolesCache();for(let r of r0)r()}catch(t){jc.error(t)}}a(n0,"userHandler");n0.addListener=function(e){r0.push(e)};s0.exports=_5});var ri=w((HNe,o0)=>{"use strict";var vNe=z(),ib=ie(),m5=(H(),C(G)),{ITC_ERRORS:O_}=Un(),{parentPort:UNe,threadId:E5,isMainThread:g5,workerData:xNe}=require("worker_threads"),{onMessageFromWorkers:S5,broadcast:BNe,broadcastWithAcknowledgement:T5}=et();o0.exports={sendItcEvent:A5,validateEvent:i0,SchemaEventMsg:R5,UserEventMsg:y5};var AE;S5(async(e,t)=>{AE=AE||b_(),i0(e),AE[e.type]&&await AE[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function A5(e){return!g5&&e.message&&(e.message.originator=E5),T5(e)}a(A5,"sendItcEvent");function i0(e){if(typeof e!="object")return O_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||ib.isEmpty(e.type))return O_.MISSING_TYPE;if(!e.hasOwnProperty("message")||ib.isEmpty(e.message))return O_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||ib.isEmpty(e.message.originator))return O_.MISSING_ORIGIN;if(m5.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return O_.INVALID_EVENT(e.type)}a(i0,"validateEvent");function R5(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(R5,"SchemaEventMsg");function y5(e){this.originator=e}a(y5,"UserEventMsg")});var To=w((GNe,u0)=>{"use strict";var a0=(H(),C(G)),FNe=ie(),RE=z(),c0=pv(),Mu,{sendItcEvent:l0}=ri();function b5(e){try{RE.info("signalSchemaChange called with message:",e),Mu=Mu||b_();let t=new c0(a0.ITC_EVENT_TYPES.SCHEMA,e);return Mu.schema(t),l0(t)}catch(t){RE.error(t)}}a(b5,"signalSchemaChange");function O5(e){try{RE.trace("signalUserChange called with message:",e),Mu=Mu||b_();let t=new c0(a0.ITC_EVENT_TYPES.USER,e);return Mu.user(t),l0(t)}catch(t){RE.error(t)}}a(O5,"signalUserChange");u0.exports={signalSchemaChange:b5,signalUserChange:O5}});var yE=w(($Ne,f0)=>{"use strict";var d0=ie(),N5=(H(),C(G)),w5=z(),I5=sE(),C5=nE(),P5=To(),{SchemaEventMsg:D5}=ri(),L5="already exists in";f0.exports=M5;async function M5(e,t,r){if(d0.isEmptyOrZeroLength(r))return r;let n=[];d0.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 v5(e,t.schema,t.name,i)})),s}a(M5,"lmdbCheckForNewAttributes");async function v5(e,t,r,n){let s=new C5(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await U5(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(L5))w5.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(v5,"createNewAttribute");async function U5(e){let t;return t=await I5(e),P5.signalSchemaChange(new D5(process.pid,N5.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(U5,"createAttribute")});var vu=w((KNe,_0)=>{"use strict";var ob=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}};_0.exports=ob});var h0=w((WNe,p0)=>{"use strict";var x5=vu(),B5=(H(),C(G)).OPERATIONS_ENUM,ab=class extends x5{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(B5.INSERT,r,n,s,i),this.records=t}};p0.exports=ab});var E0=w((jNe,m0)=>{"use strict";var H5=vu(),k5=(H(),C(G)).OPERATIONS_ENUM,cb=class extends H5{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(k5.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};m0.exports=cb});var S0=w((QNe,g0)=>{"use strict";var F5=vu(),G5=(H(),C(G)).OPERATIONS_ENUM,lb=class extends F5{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(G5.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};g0.exports=lb});var A0=w((ZNe,T0)=>{"use strict";var q5=vu(),$5=(H(),C(G)).OPERATIONS_ENUM,ub=class extends q5{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super($5.DELETE,n,s,t,i),this.original_records=r}};T0.exports=ub});var N_=w((rwe,O0)=>{"use strict";var twe=require("path"),R0=_t(),V5=h0(),K5=E0(),Y5=S0(),W5=A0(),Uu=Ut(),y0=ie(),{CONFIG_PARAMS:z5}=(H(),C(G)),b0=ae();b0.initSync();var bE=(H(),C(G)).OPERATIONS_ENUM,{getTransactionAuditStorePath:j5}=gt();O0.exports=J5;async function J5(e,t){if(b0.get(z5.LOGGING_AUDITLOG)===!1)return;let r=j5(e.schema,e.table),n=await R0.openEnvironment(r,e.table,!0),s=Q5(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){R0.initializeDBIs(n,Uu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Uu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Uu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Uu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),y0.isEmpty(s.user_name)||n.dbis[Uu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Uu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(J5,"writeTransaction");function Q5(e,t){let r=y0.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===bE.INSERT)return new V5(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===bE.UPDATE)return new K5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===bE.UPSERT)return new Y5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===bE.DELETE)return new W5(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(Q5,"createTransactionObject")});var db=w((iwe,N0)=>{"use strict";var X5=l_(),swe=Uf(),w_=(H(),C(G)),Z5=xf(),e9=Hc().insertRecords,t9=_t(),r9=z(),n9=yE(),{getSchemaPath:s9}=gt(),i9=N_();N0.exports=o9;async function o9(e){try{let{schema_table:t,attributes:r}=X5(e);Z5(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 n9(e.hdb_auth_header,t,r),s=s9(e.schema,e.table),i=await t9.openEnvironment(s,e.table),o=await e9(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await i9(e,o)}catch(c){r9.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(o9,"lmdbCreateRecords")});var C0=w((awe,I0)=>{"use strict";var w0=(H(),C(G)),a9=db(),c9=Uf(),l9=require("fs-extra"),{getSchemaPath:u9}=gt();I0.exports=d9;async function d9(e){let t=[{name:e.schema,createddate:Date.now()}],r=new c9(w0.SYSTEM_SCHEMA_NAME,w0.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await a9(r),await l9.mkdirp(u9(e.schema))}a(d9,"lmdbCreateSchema")});var D0=w((lwe,P0)=>{"use strict";var fb=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}};P0.exports=fb});var U0=w((pwe,v0)=>{"use strict";var L0=_t(),_b=_n(),pb=Un().LMDB_ERRORS_ENUM,f9=Ut(),M0=z(),dwe=ie(),_9=require("lmdb"),p9=D0(),h9=(H(),C(G)),{OVERFLOW_MARKER:fwe,MAX_SEARCH_KEY_LENGTH:_we}=f9,m9=h9.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function E9(e,t,r,n){if(_b.validateEnv(e),t===void 0)throw new Error(pb.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(pb.IDS_REQUIRED):new Error(pb.IDS_MUST_BE_ITERABLE);try{let s=L0.listDBIs(e);L0.initializeDBIs(e,t,s);let i=new p9,o,c=[],l=[];for(let p=0,_=r.length;p<_;p++)try{o=r[p];let h=e.dbis[t].get(o);if(!h||n&&h[m9]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,_9.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let g=0;g<s.length;g++){let R=s[g];if(!h.hasOwnProperty(R)||R===t)continue;let E=e.dbis[R],T=h[R];if(T!=null)try{let b=_b.getIndexedValues(T);if(b)for(let v=0,F=b.length;v<F;v++)E.remove(b[v],o)}catch{M0.warn(`cannot delete from attribute: ${R}, ${T}:${o}`)}}});c.push(S),l.push(o),i.original_records.push(h)}catch(h){M0.warn(h),i.skipped.push(o)}let u=[],f=await Promise.all(c);for(let p=0,_=f.length;p<_;p++)f[p]===!0?i.deleted.push(l[p]):(i.skipped.push(l[p]),u.push(p));let d=0;for(let p=0;p<u.length;p++){let _=u[p];i.original_records.splice(_-d,1),d++}return i.txn_time=_b.getNextMonotonicTime(),i}catch(s){throw s}}a(E9,"deleteRecords");v0.exports={deleteRecords:E9}});var I_=w((mwe,B0)=>{"use strict";var xu=ie(),g9=U0(),S9=_t(),{getSchemaPath:T9}=gt(),A9=N_(),R9=z();B0.exports=y9;async function y9(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(xu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(xu.isEmptyOrZeroLength(e.hash_values)&&!xu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];xu.isEmpty(l)||e.hash_values.push(l)}}if(xu.isEmptyOrZeroLength(e.hash_values))return x0([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(xu.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=T9(e.schema,e.table),i=await S9.openEnvironment(s,e.table),o=await g9.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await A9(e,o)}catch(c){R9.error(`unable to write transaction due to ${c.message}`)}return x0(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(y9,"lmdbDeleteRecords");function x0(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(x0,"createDeleteResponse")});var mb=w((Swe,H0)=>{"use strict";var b9=(H(),C(G)),gwe=_n();function hb(e,t){let r=Object.create(null);if(t.length===1&&b9.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(hb,"parseRow");function O9(e,t,r,n){let s=hb(r,e);n.push(s)}a(O9,"searchAll");function N9(e,t,r,n){let s=hb(r,e);n[t]=s}a(N9,"searchAllToMap");function w9(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(w9,"iterateDBI");function Jc(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(Jc,"pushResults");function I9(e,t,r,n,s,i){t.toString().endsWith(e)&&Jc(t,r,n,s,i)}a(I9,"endsWith");function C9(e,t,r,n,s,i){t.toString().includes(e)&&Jc(t,r,n,s,i)}a(C9,"contains");function P9(e,t,r,n,s,i){t>e&&Jc(t,r,n,s,i)}a(P9,"greaterThanCompare");function D9(e,t,r,n,s,i){t>=e&&Jc(t,r,n,s,i)}a(D9,"greaterThanEqualCompare");function L9(e,t,r,n,s,i){t<e&&Jc(t,r,n,s,i)}a(L9,"lessThanCompare");function M9(e,t,r,n,s,i){t<=e&&Jc(t,r,n,s,i)}a(M9,"lessThanEqualCompare");H0.exports={parseRow:hb,searchAll:O9,searchAllToMap:N9,iterateDBI:w9,endsWith:I9,contains:C9,greaterThanCompare:P9,greaterThanEqualCompare:D9,lessThanCompare:L9,lessThanEqualCompare:M9,pushResults:Jc}});var Bu=w((bwe,K0)=>{"use strict";var wa=_t(),Awe=z(),zn=_n(),OE=Ut(),Wt=Un().LMDB_ERRORS_ENUM,Rwe=ie(),v9=(H(),C(G)),NE=mb(),{parseRow:U9}=NE,ywe=require("lmdb"),{OVERFLOW_MARKER:k0,MAX_SEARCH_KEY_LENGTH:x9}=OE;function F0(e,t,r,n=!1,s=void 0,i=void 0){return Qc(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(F0,"iterateFullIndex");function C_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return Qc(e,t,r,(f,d,p,_)=>{let E={transaction:f,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return _===r?(E.values=!1,d.getRange(E).map(T=>({value:T}))):d.getRange(E)})}a(C_,"iterateRangeBetween");function Qc(e,t,r,n){let s=e.database||e,i=wa.openDBI(s,r);i[OE.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&wa.openDBI(s,t);let o;e.database?o=e:(o=e.useReadTransaction(),o.database=e);let c=n(o,i,s,t);return c.transaction=o,e.database||(c.onDone=()=>{o.done()}),c}a(Qc,"setupTransaction");function G0(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(k0)){if(!s)if(r)s=wa.openDBI(e,r);else{let l=wa.listDBIs(e);for(let u=0,f=l.length;u<f&&(s=wa.openDBI(e,l[u]),!s[OE.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(G0,"getOverflowCheck");function B9(e,t,r,n=!1,s=void 0,i=void 0){if(zn.validateEnv(e),t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);return Qc(e,t,t,(o,c,l)=>(wE(r),r=P_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>U9(u.value,r))))}a(B9,"searchAll");function H9(e,t,r,n=!1,s=void 0,i=void 0){if(zn.validateEnv(e),t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);wE(r),r=P_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of F0(e,t,t,n,s,i))o.set(c,NE.parseRow(l,r));return o}a(H9,"searchAllToMap");function k9(e,t,r=!1,n=void 0,s=void 0){if(zn.validateEnv(e),t===void 0)throw new Error(Wt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=F0(e,void 0,t,r,n,s),c=o.transaction,l=G0(c.database,c,void 0,t);for(let{key:u,value:f}of o){let d=l(u,f);i[d]===void 0&&(i[d]=[]),i[d].push(f)}return i}a(k9,"iterateDBI");function F9(e,t){if(zn.validateEnv(e),t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);return wa.statDBI(e,t).entryCount}a(F9,"countAll");function G9(e,t,r,n,s=!1,i=void 0,o=void 0){return Ia(e,r,n),Qc(e,t,r,(c,l,u,f)=>(n=zn.convertKeyValueToWrite(n),f===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(d=>({key:n,value:d}))))}a(G9,"equals");function q9(e,t,r){return Ia(e,t,r),wa.openDBI(e,t).getValuesCount(r)}a(q9,"count");function $9(e,t,r,n,s=!1,i=void 0,o=void 0){return Ia(e,r,n),Qc(e,null,r,(c,l)=>{n=zn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let f;if(s===!0){let d;for(let p of l.getKeys({transaction:c,start:n}))if(!p.startsWith(n)){d=p;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),f=l.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(p=>{let{key:_}=p;if(_!==d){if(_.toString().startsWith(n))return p;if(u===!0)return f.DONE}}),f.filter(p=>p)}else return f=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(u===!0)return f.DONE}),u?f:f.filter(d=>d)})}a($9,"startsWith");function V9(e,t,r,n,s=!1,i=void 0,o=void 0){return q0(e,t,r,n,s,i,o,!0)}a(V9,"endsWith");function q0(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Ia(e,r,n),Qc(e,null,r,(l,u,f,d)=>{let p=G0(f,l,d,r);return o=Number.isInteger(o)?o:0,u.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(_=>{let h=_.toString();return h.endsWith(k0)?u.getValues(_,{transaction:l}).map(S=>{let g=p(_,S);if(c?g.endsWith(n):g.includes(n))return{key:g,value:S}}).filter(S=>S):(c?h.endsWith(n):h.includes(n))?u[OE.DBI_DEFINITION_NAME].is_hash_attribute?{key:_,value:_}:u.getValues(_,{transaction:l}).map(S=>({key:_,value:S})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(q0,"contains");function K9(e,t,r,n,s=!1,i=void 0,o=void 0){Ia(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),C_(e,t,r,n,l,s,i,o,!0,!1)}a(K9,"greaterThan");function Y9(e,t,r,n,s=!1,i=void 0,o=void 0){Ia(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),C_(e,t,r,n,l,s,i,o,!1,!1)}a(Y9,"greaterThanEqual");function W9(e,t,r,n,s=!1,i=void 0,o=void 0){Ia(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),C_(e,t,r,l,n,s,i,o,!1,!0)}a(W9,"lessThan");function z9(e,t,r,n,s=!1,i=void 0,o=void 0){Ia(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),C_(e,t,r,l,n,s,i,o,!1,!1)}a(z9,"lessThanEqual");function j9(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(zn.validateEnv(e),r===void 0)throw new Error(Wt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Wt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Wt.END_VALUE_REQUIRED);if(n=zn.convertKeyValueToWrite(n),s=zn.convertKeyValueToWrite(s),n>s)throw new Error(Wt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return C_(e,t,r,n,s,i,o,c)}a(j9,"between");function J9(e,t,r,n){zn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);if(wE(r),r=P_(s,r),n===void 0)throw new Error(Wt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=NE.parseRow(c,r)),o}a(J9,"searchByHash");function Q9(e,t,r){zn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Wt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(Q9,"checkHashExists");function X9(e,t,r,n,s=[]){return V0(e,t,r,n,s),$0(e,t,r,n,s).map(i=>i[1])}a(X9,"batchSearchByHash");function Z9(e,t,r,n,s=[]){V0(e,t,r,n,s);let i=new Map;for(let[o,c]of $0(e,t,r,n,s))i.set(o,c);return i}a(Z9,"batchSearchByHashToMap");function $0(e,t,r,n,s=[]){return Qc(e,t,t,(i,o,c)=>{r=P_(c,r);let l=r.length<3;return n.map(u=>{let f=c.dbis[t].get(u,{transaction:i,lazy:l});if(f)return[u,NE.parseRow(f,r)];s.push(u)}).filter(u=>u)})}a($0,"batchHashSearch");function V0(e,t,r,n,s){if(zn.validateEnv(e),t===void 0)throw new Error(Wt.HASH_ATTRIBUTE_REQUIRED);if(wE(r),n==null)throw new Error(Wt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Wt.IDS_MUST_BE_ITERABLE)}a(V0,"initializeBatchSearchByHash");function wE(e){if(!Array.isArray(e))throw e===void 0?new Error(Wt.FETCH_ATTRIBUTES_REQUIRED):new Error(Wt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(wE,"validateFetchAttributes");function Ia(e,t,r){if(zn.validateEnv(e),t===void 0)throw new Error(Wt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Wt.SEARCH_VALUE_REQUIRED);if(r?.length>x9)throw new Error(Wt.SEARCH_VALUE_TOO_LARGE)}a(Ia,"validateComparisonFunctions");function P_(e,t){return t.length===1&&v9.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=wa.listDBIs(e)),t}a(P_,"setGetWholeRowAttributes");K0.exports={searchAll:B9,searchAllToMap:H9,count:q9,countAll:F9,equals:G9,startsWith:$9,endsWith:V9,contains:q0,searchByHash:J9,setGetWholeRowAttributes:P_,batchSearchByHash:X9,batchSearchByHashToMap:Z9,checkHashExists:Q9,iterateDBI:k9,greaterThan:K9,greaterThanEqual:Y9,lessThan:W9,lessThanEqual:z9,between:j9}});var Hu=w((Nwe,J0)=>{var Y0=require("lodash"),W0=it(),He=require("joi"),e7=ie(),{hdb_schema_table:D_,checkValidTable:z0,hdb_table:j0,hdb_database:IE}=Di(),{handleHDBError:t7,hdb_errors:r7}=pe(),{getDatabases:n7}=(Pe(),C(tt)),{HTTP_STATUS_CODES:s7}=r7,i7=He.object({database:IE,schema:IE,table:j0,search_attribute:D_,search_value:He.any().required(),get_attributes:He.array().min(1).items(He.alternatives(D_,He.object())).optional(),desc:He.bool(),limit:He.number().integer().min(1),offset:He.number().integer().min(0)}),o7=He.object({database:IE,schema:IE,table:j0,operator:He.string().valid("and","or").default("and").lowercase(),offset:He.number().integer().min(0),limit:He.number().integer().min(1),get_attributes:He.array().min(1).items(He.alternatives(D_,He.object())).optional(),sort:He.object({attribute:He.alternatives(D_,He.array().min(1)),descending:He.bool().optional()}).optional(),conditions:He.array().min(1).items(He.alternatives(He.object({operator:He.string().valid("and","or").default("and").lowercase(),conditions:He.array()}),He.object({search_attribute:He.alternatives(D_,He.array().min(1)),search_type:He.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:He.when("search_type",{switch:[{is:"equals",then:He.any()},{is:"between",then:He.array().items(He.alternatives([He.string(),He.number()])).length(2)}],otherwise:He.alternatives(He.string(),He.number())}).required()}))).required()});J0.exports=function(e,t){let r=null;switch(t){case"value":r=W0.validateBySchema(e,i7);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(z0("database",e.schema)),i(z0("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=W0.validateBySchema(e,o7);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=e7.checkGlobalSchemaTable(e.schema,e.table);if(s)return t7(new Error,s,s7.NOT_FOUND);let o=n7()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(f=>{for(let d=0,p=f.conditions.length;d<p;d++){let _=f.conditions[d];_.conditions?l(_):c.push(_.search_attribute)}},"addConditions");t==="conditions"&&l(e);let u=Y0.filter(c,f=>f!=="*"&&!f.startsWith?.("$")&&f.attribute!=="*"&&!Array.isArray(f)&&!f.name&&!Y0.some(o,d=>d===f||d.attribute===f||d.attribute===f.attribute));if(u&&u.length>0){let f=u.join(", ");return f=f.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${f}'`)}}return r}});var Eb=w((Iwe,Q0)=>{"use strict";var a7=_t(),c7=Hu(),{getSchemaPath:l7}=gt();Q0.exports=u7;function u7(e){let t=c7(e,"hashes");if(t)throw t;let r=l7(e.schema,e.table);return a7.openEnvironment(r,e.table)}a(u7,"initialize")});var gb=w((Pwe,X0)=>{"use strict";var d7=Bu(),f7=Eb();X0.exports=_7;async function _7(e){let t=await f7(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return d7.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(_7,"lmdbGetDataByHash")});var ku=w((Lwe,Z0)=>{"use strict";var Sb=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};Z0.exports=Sb});var tx=w((Uwe,ex)=>{"use strict";var vwe=ku(),p7=Bu(),h7=Eb();ex.exports=m7;async function m7(e){let t=await h7(e),r=global.hdb_schema[e.schema][e.table];return p7.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(m7,"lmdbSearchByHash")});var ni=w((Bwe,rx)=>{"use strict";var Tb=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,u=void 0,f=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=u,this.offset=f}};rx.exports=Tb});var CE=w((kwe,cx)=>{"use strict";var jr=Bu(),E7=_t(),g7=ie(),ke=Ut(),Xc=(H(),C(G)),S7=po(),nx=Un().LMDB_ERRORS_ENUM,{getSchemaPath:T7}=gt(),Ao=Xc.SEARCH_WILDCARDS;async function A7(e,t,r){let n;e.schema===Xc.SYSTEM_SCHEMA_NAME?n=S7[e.table]:n=global.hdb_schema[e.schema][e.table];let s=ax(e,n.hash_attribute,r,t);return ix(e,s,n.hash_attribute,r)}a(A7,"prepSearch");async function ix(e,t,r,n){let s=T7(e.schema,e.table),i=await E7.openEnvironment(s,e.table),o=ox(i,e,t,r),c=o.transaction||i;if([ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,ke.SEARCH_TYPES.SEARCH_ALL,ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(R7(e,r)===!1){let f=e.search_attribute;if(f===r)return n?sx(o,()=>!0):o.map(p=>({[r]:p.key}));let d=a(p=>({[r]:p.value,[f]:p.key}),"toObject");return n?sx(o,d):o.map(d)}let u=e.search_attribute===r?o.map(f=>f.key):o.map(f=>f.value);return n===!0?jr.batchSearchByHashToMap(c,r,e.get_attributes,u):jr.batchSearchByHash(c,r,e.get_attributes,u)}a(ix,"executeSearch");function ox(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case ke.SEARCH_TYPES.EQUALS:s=jr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.CONTAINS:s=jr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.ENDS_WITH:case ke.SEARCH_TYPES._ENDS_WITH:s=jr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.STARTS_WITH:case ke.SEARCH_TYPES._STARTS_WITH:s=jr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return jr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return jr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case ke.SEARCH_TYPES.SEARCH_ALL:return jr.searchAll(e,n,t.get_attributes,o,c,l);case ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return jr.searchAllToMap(e,n,t.get_attributes,o,c,l);case ke.SEARCH_TYPES.BETWEEN:s=jr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case ke.SEARCH_TYPES.GREATER_THAN:case ke.SEARCH_TYPES._GREATER_THAN:s=jr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.GREATER_THAN_EQUAL:case ke.SEARCH_TYPES._GREATER_THAN_EQUAL:s=jr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.LESS_THAN:case ke.SEARCH_TYPES._LESS_THAN:s=jr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.LESS_THAN_EQUAL:case ke.SEARCH_TYPES._LESS_THAN_EQUAL:s=jr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(ox,"searchByType");function sx(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(sx,"createMapFromIterable");function R7(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(R7,"checkToFetchMore");function ax(e,t,r,n){if(g7.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),o=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),Ao.indexOf(s)>-1)return r===!0?ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP:ke.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(Ao[0])<0&&s.indexOf(Ao[1])<0)return c===!0?r===!0?ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:ke.SEARCH_TYPES.EQUALS;if(Ao.indexOf(i)>=0&&Ao.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),ke.SEARCH_TYPES.CONTAINS;if(Ao.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),ke.SEARCH_TYPES.ENDS_WITH;if(Ao.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),ke.SEARCH_TYPES.STARTS_WITH;if(s.includes(Ao[0])||s.includes(Ao[1]))return ke.SEARCH_TYPES.EQUALS;throw new Error(nx.UNKNOWN_SEARCH_TYPE)}else switch(n){case Xc.VALUE_SEARCH_COMPARATORS.BETWEEN:return ke.SEARCH_TYPES.BETWEEN;case Xc.VALUE_SEARCH_COMPARATORS.GREATER:return ke.SEARCH_TYPES.GREATER_THAN;case Xc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return ke.SEARCH_TYPES.GREATER_THAN_EQUAL;case Xc.VALUE_SEARCH_COMPARATORS.LESS:return ke.SEARCH_TYPES.LESS_THAN;case Xc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return ke.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(nx.UNKNOWN_SEARCH_TYPE)}}a(ax,"createSearchTypeFromSearchObject");cx.exports={executeSearch:ix,createSearchTypeFromSearchObject:ax,prepSearch:A7,searchByType:ox}});var ux=w((qwe,lx)=>{"use strict";var Gwe=ni(),y7=Hu(),b7=ie(),O7=(H(),C(G)),N7=CE();lx.exports=w7;function w7(e,t){if(!b7.isEmpty(t)&&O7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=y7(e,"value");if(n)throw n;return N7.prepSearch(e,t,!0)}a(w7,"lmdbGetDataByValue")});var L_=w((Kwe,dx)=>{"use strict";var Vwe=ni(),I7=Hu(),C7=ie(),P7=(H(),C(G)),D7=CE();dx.exports=L7;async function L7(e,t){if(!C7.isEmpty(t)&&P7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=I7(e,"value");if(n)throw n;return D7.prepSearch(e,t,!1)}a(L7,"lmdbSearchByValue")});var _x=w((zwe,fx)=>{"use strict";var Wwe=Ut(),Ab=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}},Rb=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},yb=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};fx.exports={SearchByConditionsObject:Ab,SearchCondition:Rb,SortAttribute:yb}});var gx=w((Xwe,Ex)=>{"use strict";var Jwe=_x().SearchByConditionsObject,M7=ni(),v7=Hu(),bb=Bu(),PE=Ut(),{Resource:Qwe}=(Ea(),C(ER)),mx=CE(),U7=mb(),x7=require("lodash"),{getSchemaPath:B7}=gt(),px=_t(),{handleHDBError:H7,hdb_errors:k7}=pe(),{HTTP_STATUS_CODES:F7}=k7,G7=1e8;Ex.exports=q7;async function q7(e){let t=v7(e,"conditions");if(t)throw H7(t,t.message,F7.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=B7(e.schema,e.table),n=await px.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)px.openDBI(n,u.search_attribute);let i=x7.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let f=u.search_type;f===PE.SEARCH_TYPES.EQUALS?u.estimated_count=bb.count(n,u.search_attribute,u.search_value):f===PE.SEARCH_TYPES.CONTAINS||f===PE.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=G7}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await hx(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let u=n.dbis[s.hash_attribute],f=i.slice(1).map(mx.filterByType),d=f.length,p=bb.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(_=>u.get(_,{transaction:o,lazy:!0})),d>0&&(l=l.filter(_=>{for(let h=0;h<d;h++)if(!f[h](_))return!1;return!0})),(e.offset||e.limit!==void 0)&&(l=l.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),l=l.map(_=>U7.parseRow(_,p))}else{for(let d=1;d<i.length;d++){let p=i[d],_=await hx(o,e,p,s.hash_attribute);c=c.concat(_)}let u=new Set,f=e.offset||0;c=c.filter(d=>u.has(d)?!1:(u.add(d),!0)).slice(f,e.limit&&e.limit+f),l=bb.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(q7,"lmdbSearchByConditions");async function hx(e,t,r,n){let s=new M7(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===PE.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,mx.searchByType(e,s,i,n).map(o=>o.value)}a(hx,"executeConditionSearch")});var M_=w((eIe,Sx)=>{"use strict";var $7=(H(),C(G)).OPERATIONS_ENUM,Ob=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=$7.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};Sx.exports=Ob});var Nb=w((rIe,wx)=>{"use strict";var yx=ni(),bx=M_(),Ox=L_(),Nx=I_(),yn=(H(),C(G)),Tx=ie(),Ax=_t(),{getTransactionAuditStorePath:V7,getSchemaPath:K7}=gt(),Rx=z();wx.exports=Y7;async function Y7(e){try{if(Tx.isEmpty(global.hdb_schema[e.schema])||Tx.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await W7(e),await z7(e);let t=K7(e.schema,e.table);try{await Ax.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")Rx.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=V7(e.schema,e.table);await Ax.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")Rx.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(Y7,"lmdbDropTable");async function W7(e){let t=new yx(yn.SYSTEM_SCHEMA_NAME,yn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await Ox(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 bx(yn.SYSTEM_SCHEMA_NAME,yn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await Nx(s)}a(W7,"deleteAttributesFromSystem");async function z7(e){let t=new yx(yn.SYSTEM_SCHEMA_NAME,yn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await Ox(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 bx(yn.SYSTEM_SCHEMA_NAME,yn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await Nx(s)}catch(i){throw i}}a(z7,"dropTableFromSystem")});var Cx=w((sIe,Ix)=>{"use strict";var j7=require("fs-extra"),J7=ni(),Q7=ku(),X7=M_(),Z7=Nb(),eee=I_(),tee=gb(),ree=L_(),Ro=(H(),C(G)),{getSchemaPath:nee}=gt(),{handleHDBError:see,hdb_errors:iee}=pe(),{HDB_ERROR_MSGS:oee,HTTP_STATUS_CODES:aee}=iee;Ix.exports=cee;async function cee(e){let t;try{t=await lee(e.schema);let r=new J7(Ro.SYSTEM_SCHEMA_NAME,Ro.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Ro.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Ro.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await ree(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await Z7(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new X7(Ro.SYSTEM_SCHEMA_NAME,Ro.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await eee(s);let i=nee(t);await j7.remove(i)}catch(r){throw r}}a(cee,"lmdbDropSchema");async function lee(e){let t=new Q7(Ro.SYSTEM_SCHEMA_NAME,Ro.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Ro.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await tee(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw see(new Error,oee.SCHEMA_NOT_FOUND(e),aee.NOT_FOUND,void 0,void 0,!0);return n}a(lee,"validateDropSchema")});var v_=w((oIe,Px)=>{"use strict";var wb=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Px.exports=wb});var Cb=w((lIe,Dx)=>{"use strict";var uee=require("fs-extra"),DE=_t(),{getTransactionAuditStorePath:dee}=gt(),Ib=Ut(),cIe=v_();Dx.exports=fee;async function fee(e){let t;try{let r=dee(e.schema,e.table);await uee.mkdirp(r),t=await DE.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{DE.createDBI(t,Ib.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),DE.createDBI(t,Ib.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),DE.createDBI(t,Ib.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(fee,"createTransactionsAuditEnvironment")});var vx=w((fIe,Mx)=>{"use strict";var Pb=(H(),C(G)),Lx=_t(),_ee=Hc(),{getSystemSchemaPath:pee,getSchemaPath:hee}=gt(),dIe=po(),mee=sE(),Db=nE(),Eee=z(),gee=Cb();Mx.exports=See;async function See(e,t){let r=hee(t.schema,t.table),n=new Db(t.schema,t.table,Pb.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Db(t.schema,t.table,Pb.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Db(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await Lx.createEnvironment(r,t.table),e!==void 0){let o=await Lx.openEnvironment(pee(),Pb.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await _ee.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 Lb(n),await Lb(s),await Lb(i)}await gee(t)}catch(o){throw o}}a(See,"lmdbCreateTable");async function Lb(e){try{await mee(e)}catch(t){Eee.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(Lb,"createAttribute")});var xx=w((pIe,Ux)=>{"use strict";var Tee=l_(),Aee=xf(),Ree=yE(),U_=(H(),C(G)),yee=Hc().updateRecords,bee=_t(),{getSchemaPath:Oee}=gt(),Nee=N_(),wee=z();Ux.exports=Iee;async function Iee(e){try{let{schema_table:t,attributes:r}=Tee(e);Aee(e,r,t.hash_attribute),e.schema!==U_.SYSTEM_SCHEMA_NAME&&(r.includes(U_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(U_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(U_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(U_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await Ree(e.hdb_auth_header,t,r),s=Oee(e.schema,e.table),i=await bee.openEnvironment(s,e.table),o=await yee(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await Nee(e,o)}catch(c){wee.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(Iee,"lmdbUpdateRecords")});var Hx=w((mIe,Bx)=>{"use strict";var Cee=(H(),C(G)).OPERATIONS_ENUM,Mb=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Cee.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Bx.exports=Mb});var Fx=w((SIe,kx)=>{"use strict";var gIe=Hx(),Pee=l_(),Dee=xf(),Lee=yE(),x_=(H(),C(G)),Mee=Hc().upsertRecords,vee=_t(),{getSchemaPath:Uee}=gt(),xee=N_(),Bee=z(),{handleHDBError:Hee,hdb_errors:kee}=pe();kx.exports=Fee;async function Fee(e){let t;try{t=Pee(e)}catch(l){throw Hee(l,l.message,kee.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;Dee(e,n,r.hash_attribute),e.schema!==x_.SYSTEM_SCHEMA_NAME&&(n.includes(x_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(x_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(x_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(x_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await Lee(e.hdb_auth_header,r,n),i=Uee(e.schema,e.table),o=await vee.openEnvironment(i,e.table),c=await Mee(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await xee(e,c)}catch(l){Bee.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(Fee,"lmdbUpsertRecords")});var qx=w((AIe,Gx)=>{"use strict";var vb=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};Gx.exports=vb});var Vx=w((yIe,$x)=>{"use strict";var Ub=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}};$x.exports=Ub});var Wx=w((NIe,Yx)=>{"use strict";var xb=_t(),{getTransactionAuditStorePath:Gee}=gt(),OIe=qx(),B_=Ut(),qee=ie(),Kx=Vx(),$ee=require("util").promisify,Vee=$ee(setTimeout),Kee=1e4,Yee=100;Yx.exports=Wee;async function Wee(e){let t=Gee(e.schema,e.table),r=await xb.openEnvironment(t,e.table,!0),n=xb.listDBIs(r);xb.initializeDBIs(r,B_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new Kx;do s=await zee(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 Vee(Yee);while(s.transactions_deleted>0);return i}a(Wee,"deleteAuditLogsBefore");async function zee(e,t){let r=new Kx;try{let n=e.dbis[B_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],s;for(let{key:i,value:o}of n.getRange({start:!1})){if(i>=t)break;r.start_timestamp===void 0&&(r.start_timestamp=i),s=n.remove(i);let c=o[B_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];qee.isEmpty(c)||(s=e.dbis[B_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[B_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>Kee)break}return await s,r}catch(n){throw n}}a(zee,"deleteTransactions")});var jx=w((IIe,zx)=>{"use strict";var Bb=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};zx.exports=Bb});var Qx=w((DIe,Jx)=>{"use strict";var jee=ni(),Jee=M_(),PIe=jx(),Bi=(H(),C(G)),Qee=ie(),Hb=_t(),Xee=po(),Zee=L_(),ete=I_(),{getSchemaPath:tte}=gt();Jx.exports=rte;async function rte(e,t=!0){let r;e.schema===Bi.SYSTEM_SCHEMA_NAME?r=Xee[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await ste(e),s=tte(e.schema,e.table),i=await Hb.openEnvironment(s,e.table);return t===!0&&await nte(e,i,r.hash_attribute),Hb.dropDBI(i,e.attribute),n}a(rte,"lmdbDropAttribute");async function nte(e,t,r){let n=Hb.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let u={};for(let f in c)f!==i&&(u[f]=c[f]);s=t.dbis[r].put(o,u,l)}await s}a(nte,"removeAttributeFromAllObjects");async function ste(e){let t=new jee(Bi.SYSTEM_SCHEMA_NAME,Bi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await Zee(t)).filter(o=>o[Bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(Qee.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[Bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new Jee(Bi.SYSTEM_SCHEMA_NAME,Bi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return ete(i)}a(ste,"dropAttributeFromSystem")});var nB=w((vIe,rB)=>{"use strict";var kb=_t(),Fu=Ut(),MIe=_n(),Fb=(H(),C(G)),Xx=ie(),{getTransactionAuditStorePath:ite}=gt(),ote=Bu(),LE=vu(),ate=z();rB.exports=cte;async function cte(e){let t=ite(e.schema,e.table),r=await kb.openEnvironment(t,e.table,!0),n=kb.listDBIs(r);kb.initializeDBIs(r,Fu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case Fb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return Zx(r,e.search_values);case Fb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,ute(r,e.search_values,s);case Fb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return lte(r,e.search_values);default:return Zx(r)}}a(cte,"readAuditLog");function Zx(e,t=[0,Date.now()]){Xx.isEmpty(t[0])&&(t[0]=0),Xx.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[Fu.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 LE,s))}a(Zx,"searchTransactionsByTimestamp");function lte(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[Fu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,tB(e,i))}return Object.fromEntries(r)}a(lte,"searchTransactionsByUsername");function ute(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],f=ote.equals(e,Fu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Fu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:d}of f){let p=Number(d);n.has(p)?n.get(p).push(u.toString()):n.set(p,[u.toString()])}}let s=Array.from(n.keys()),i=tB(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,f=n.get(u);eB(l,"records",r,f,o),eB(l,"original_records",r,f,o)}return Object.fromEntries(o)}a(ute,"searchTransactionsByHashValues");function eB(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let u=s.get(l),f=u[u.length-1];if(f.timestamp===i)f[t]=[c];else{let d=new LE(e.operation,e.user_name,i,void 0);d[t]=[c],u.push(d)}}else{let u=new LE(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}a(eB,"loopRecords");function tB(e,t){let r=[];try{let n=e.dbis[Fu.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 LE,i);r.push(o)}}catch(i){ate.warn(i)}return r}catch(n){throw n}}a(tB,"batchSearchTransactions")});var iB=w((HIe,sB)=>{"use strict";var{getSchemaPath:xIe}=gt(),BIe=_t(),{database:dte}=(Pe(),C(tt));sB.exports={writeTransaction:fte};async function fte(e,t,r){return dte({database:e,table:t}).transaction(r)}a(fte,"writeTransaction")});var lB=w((FIe,cB)=>{"use strict";var{getSchemaPath:oB}=gt(),aB=_t();cB.exports={flush:_te,resetReadTxn:pte};async function _te(e,t){return(await aB.openEnvironment(oB(e,t),t.toString())).flushed}a(_te,"flush");async function pte(e,t){try{(await aB.openEnvironment(oB(e,t),t.toString())).resetReadTxn()}catch{}}a(pte,"resetReadTxn")});var _B=w((qIe,fB)=>{"use strict";var{Readable:hte}=require("stream"),{getDatabases:mte}=(Pe(),C(tt)),{readSync:Ete,openSync:gte,createReadStream:uB}=require("fs"),{open:Ste}=require("lmdb"),dB=s_(),Tte=i_(),{AUDIT_STORE_OPTIONS:Ate}=(fo(),C(pB)),{INTERNAL_DBIS_NAME:Rte,AUDIT_STORE_NAME:yte}=Ut();fB.exports=Ote;var Gb=32768,bte=100;async function Ote(e){let t=e.database||e.schema||"data",r=mte()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let u=r[s[0]];if(!u)throw new Error(`Can not find table ${s[0]}`);let f=u.dbisDB,d=Ste({noSync:!0,maxDbs:Tte.MAX_DBS}),p,_=d.openDB(Rte,new dB(!1)),h=f.useReadTransaction(),S=0,g=a(async function(E,T){T.encoding="binary",T.encoder=void 0;let b=d.openDB(E,T),v=f.openDB(E,T);for(let{key:F,version:q,value:Y}of v.getRange({start:null,transaction:h,versions:v.useVersions}))p=b.put(F,Y,q),S++%bte===0&&(await new Promise(Z=>setTimeout(Z,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:E,value:T}of f.getRange({transaction:h,start:!1}))if(s.some(b=>E.startsWith?.(b+"/"))){_.put(E,T);let[,b]=E.split("/"),v=!b,F=new dB(!v,v);await g(E,F)}e.include_audit&&await g(yte,{...Ate}),await p;let R=uB(d.path);return R.headers=l(),R.on("close",()=>{h.done(),d.close()}),R}let o=r[Object.keys(r)[0]].primaryStore,c=gte(o.path);return o.transaction(()=>{let u=Buffer.alloc(Gb);Ete(c,u,0,Gb),o.resetReadTxn();let f=o.useReadTransaction();f.renew();let d=uB(null,{fd:c,start:Gb}),p=new hte.from(async function*(){yield u;for await(let _ of d)f.openTimer&&(f.openTimer=0),yield _;f.done()}());return p.headers=l(),p});function l(){let u=new Map;return u.set("content-type","application/octet-stream"),u.set("content-disposition",`attachment; filename="${t}"`),u.set("date",n),u}}a(Ote,"getBackup")});var EB=w((VIe,mB)=>{"use strict";var Nte=z(),{handleHDBError:wte}=pe(),Ite=IM(),Cte=sE(),Pte=db(),Dte=C0(),Lte=I_(),Mte=gb(),vte=tx(),Ute=ux(),xte=L_(),Bte=gx(),Hte=Cx(),kte=vx(),Fte=xx(),Gte=Fx(),qte=Wx(),$te=Nb(),Vte=Qx(),Kte=nB(),Yte=iB(),hB=lB(),Wte=_B(),qb=class extends Ite{static{a(this,"LMDBBridge")}async searchByConditions(t){return Bte(t)}async getDataByHash(t){return await Mte(t)}async searchByHash(t){return await vte(t)}async getDataByValue(t,r){return await Ute(t,r)}async searchByValue(t){return await xte(t)}async createSchema(t){return await Dte(t)}async dropSchema(t){return await Hte(t)}async createTable(t,r){return await kte(t,r)}async dropTable(t){return await $te(t)}async createAttribute(t){return await Cte(t)}async createRecords(t){return await Pte(t)}async updateRecords(t){return await Fte(t)}async upsertRecords(t){try{return await Gte(t)}catch(r){throw wte(r,null,null,Nte.ERR,r)}}async deleteRecords(t){return await Lte(t)}async dropAttribute(t){return await Vte(t)}async deleteAuditLogsBefore(t){return await qte(t)}async readAuditLog(t){return await Kte(t)}writeTransaction(t,r,n){return Yte.writeTransaction(t,r,n)}flush(t,r){return hB.flush(t,r)}resetReadTxn(t,r){return hB.resetReadTxn(t,r)}getBackup(t){return Wte(t)}};mB.exports=qb});var Vb={};ve(Vb,{add:()=>ME,applyReverse:()=>gB,getRecordAtTime:()=>$b,rebuildUpdateBefore:()=>vE});function ME(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 vE(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,ME(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function gB(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=zte[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=SB}}function $b(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),u=wt(l);switch(u.type){case"put":s=u.getValue(r);break;case"patch":gB(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===SB&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),u=wt(l),f;switch(u.type){case"put":f=u.getValue(r);break;case"patch":f=u.getValue(r);break}for(let d in f)o[d]&&(s[d]=f[d],o[d]=!1,c--);i=u.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var zte,SB,UE=be(()=>{fo();a(ME,"add");ME.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)};zte={add:ME};a(vE,"rebuildUpdateBefore");a(gB,"applyReverse");SB={};a($b,"getRecordAtTime")});function bn(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function kE(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let c of s){let l=c.name,u,f;if(c.resolve)f={get(){return c.resolve(this,this.getContext?.())},set(d){return c.set(this,d)},configurable:!0};else{switch(c.type){case"String":u=a(function(d){if(!(typeof d=="string"||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a string, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"ID":u=a(function(d){if(!(typeof d=="string"||d?.length>0&&d.every?.(p=>typeof p=="string")||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a string, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Float":case"Number":u=a(function(d){let p=d?.__op__?d.value:d;if(!(typeof p=="number"||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a number, attempt to assign ${p}`);bn(this)[l]=d},"set");break;case"Int":u=a(function(d){let p=d?.__op__?d.value:d;if(!(p>>0===p||d==null&&c.nullable!==!1))if(typeof p=="number"&&Math.abs((p>>0)-p)<=1)p=Math.round(p),d?.__op__?d.value=p:d=p;else throw new jn.ClientError(`${l} must be an integer between -2147483648 and 2147483647, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Long":u=a(function(d){let p=d?.__op__?d.value:d;if(!(Math.round(p)===d&&Math.abs(p)<=9007199254740992||d==null&&c.nullable!==!1))if(typeof p=="number"&&Math.abs(p)<=9007199254740992)p=Math.round(p),d?.__op__?d.value=p:d=p;else throw new jn.ClientError(`${l} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"BigInt":u=a(function(d){let p=d?.__op__?d.value:d;if(!(typeof p=="bigint"||d==null&&c.nullable!==!1))if(typeof p=="string"||typeof p=="number")p=BigInt(p),d?.__op__?d.value=p:d=p;else throw new jn.ClientError(`${l} must be a number, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Boolean":u=a(function(d){if(!(typeof d=="boolean"||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a boolean, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Date":u=a(function(d){if(!(d instanceof Date||d==null&&c.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=new Date(d);else throw new jn.ClientError(`${l} must be a Date, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Bytes":u=a(function(d){if(!(d instanceof Uint8Array||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a Buffer or Uint8Array, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Blob":u=a(function(d){if(!(d instanceof wi||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a Blob, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Any":case void 0:u=a(function(d){bn(this)[l]=d},"set");break;default:u=a(function(d){if(!(typeof d=="object"||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be an object, attempt to assign ${d}`);bn(this)[l]=d},"set")}f={get(){let d=this.getChanges?.();if(d&&l in d){let _=d[l];if(_?.__op__){let h=this.getRecord()?.[l];return _.update(h)}return _}let p=this.getRecord()?.[l];if(p&&typeof p=="object"){let _=Kb(p,c);if(_)return d||this._setChanges(d=Object.create(null)),d[l]=_}return p},set:u,enumerable:!0,configurable:!0}}f.get.isAttribute=!0,n[l]=f,(!(l in r)||Object.getOwnPropertyDescriptor(r,l)?.get?.isAttribute)&&Object.defineProperty(r,l,f)}i("getProperty",function(c){let l=n[c];if(l)return l.get.call(this);let u=this.getChanges();return u?.[c]!==void 0?u[c]:this.getRecord()?.[c]}),i("set",function(c,l){let u=n[c];if(u)return u.set.call(this,l);if(t.sealed)throw new jn.ClientError("Can not add a property to a sealed table schema");bn(this)[c]=l}),i("deleteProperty",function(c){bn(this)[c]=void 0}),i("toJSON",function(){let c=this.getChanges?.(),l;for(let f in c){l||(l={...this.getRecord()});let d=c[f];if(d?.__op__){let p=l[f];d=d.update(p)}l[f]=d}return Object.keys(this).length>0&&(l||(l={...this.getRecord()}),Object.assign(l,this)),l||this.getRecord()}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty),r.then||i("then",null);function i(c,l){Object.defineProperty(r,c,{value:l,configurable:!0})}a(i,"setMethod");let o=r;do{let c=Object.getPrototypeOf(o);if(c===Object.prototype){Object.setPrototypeOf(o,AB);break}o=c}while(o&&o!==AB)}function Kb(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends H_{static{a(this,"TrackedObject")}},kE(r,t)),new r(e)):new H_(e);case Array:let n=new BE(e.length,e);for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=Kb(o,t?.elements)),n[s]=o}return n;default:return e}}function FE(e){let t=e.getChanges?.(),r;for(let s in t){r||(r=e.getRecord?{...e.getRecord()}:{});let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=FE(i);r[s]=i}return Object.keys(e).length>0&&(r||(r=e.getRecord?{...e.getRecord()}:{}),Object.assign(r,e)),r||e.getRecord?.()||e}function el(e,t=e.getChanges?.()){let r;if(e.getRecord&&e.constructor===Array&&!Object.isFrozen(e)){r=e;for(let n=0,s=e.length;n<s;n++){let i=e[n];if(i&&typeof i=="object"){let o=el(i);o!==i&&r===e&&(r=e.slice(0)),i=o}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r={...e.getRecord?.()});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=Vb[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=el(s);r[n]=s}if(!Array.isArray(e))for(let n in e)jte.call(e,n)&&(r||(r={...e.getRecord?.()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?.()??e}function xE(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[Zc]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.getRecord?.()===s){if(xE(i))return!0}else return!0}}else{let r=e.getChanges?.();if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s.getRecord?.()===i){if(xE(s))return!0}else return!0}else return!0}}return!1}var jn,TB,AB,H_,jte,Zc,BE,HE,Yb=be(()=>{jn=M(pe());UE();gs();a(bn,"getChanges");a(kE,"assignTrackedAccessors");TB=Object.prototype,AB=new Proxy({},{get(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(TB[t])return TB[t];let n=r.getChanges?.();if(n&&t in n)return n[t];let s=r.getRecord?.()[t];if(s&&typeof s=="object"){let i=Kb(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}});a(Kb,"trackObject");H_=class{static{a(this,"GenericTrackedObject")}#e;#t;constructor(t){if(t?.getRecord)throw new Error("Can not track an already tracked object, check for circular references");this.#e=t}getRecord(){return this.#e}setRecord(t){this.#e=t}getChanges(){return this.#t}_setChanges(t){this.#t=t}};kE(H_,{});a(FE,"collapseData");jte=Object.prototype.hasOwnProperty;a(el,"updateAndFreeze");a(xE,"hasChanges");Zc=Symbol.for("has-array-changes"),BE=class extends Array{static{a(this,"TrackedArray")}#e;[Zc];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[Zc]=!0,super.splice(...t)}push(...t){return this[Zc]=!0,super.push(...t)}pop(){return this[Zc]=!0,super.pop()}unshift(...t){return this[Zc]=!0,super.unshift(...t)}shift(){return this[Zc]=!0,super.shift()}};BE.prototype.constructor=Array;HE=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var CB={};ve(CB,{ResourceBridge:()=>jb});function Jb({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 yB(e,t){let r=Hi(e),n=Jb(e,r);if(!r)throw new si.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache,replicateFrom:e.replicateFrom},o;Nt(i,()=>new Promise(u=>o=u));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let u=c[l++],f;try{f=await r.get({id:u,lazy:s,select:n},i),f=f&&FE(f)}catch(d){f={message:d.toString()}}return t?{value:{key:u,value:f}}:{value:f}}else return o(),{done:!0}},return(u){return o(),{value:u,done:!0}},throw(u){return o(),{done:!0}}}}}}function Hi(e){let t=e.database||e.schema||Qte,r=Qe()[t];if(!r)throw(0,si.handleHDBError)(new Error,Jte.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function bB(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*OB(e,t,r,n){let s,i=0;for await(let o of e.getHistory(t,r)){let c=o.operation??o.type;c==="put"&&(c="upsert");let{id:l,version:u,value:f}=o;if(s?.timestamp===u)s.hash_values.push(l),s.records.push(f);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:u,hash_values:[l],records:[f]}}}s&&(yield s)}var NB,GE,si,wB,Wb,zb,IB,Jte,Qte,Xte,Zte,RB,jb,PB=be(()=>{"use strict";NB=M(EB()),GE=M(Hu()),si=M(pe());Pe();wB=M(l_());H();Wb=M(To()),zb=M(ri()),IB=M(ie());bc();Yb();({HDB_ERROR_MSGS:Jte}=si.hdb_errors),Qte="data",Xte=1e4,Zte=10,jb=class extends NB.default{static{a(this,"ResourceBridge")}constructor(t){super(t),RB=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,GE.default)(t,"conditions");if(r)throw(0,si.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Hi(t);if(!n)throw new si.ClientError(`Table ${t.table} not found`);let s=t.conditions.map(i);function i(o){return o.conditions?(o.conditions=o.conditions.map(i),o):{attribute:o.search_attribute??o.attribute,comparator:o.search_type??o.comparator,value:o.search_value!==void 0?o.search_value:o.value}}return a(i,"mapCondition"),n.search({conditions:s,operator:t.operator?t.operator.toLowerCase():void 0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:Jb(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new si.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}ft({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await Hi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Hi(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c={...c},delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(u=>{if(!u){let{value:f,version:d}=r.primaryStore.getEntry(o);return i(o,f,d)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(u=>setImmediate(u));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){Hi(t).dropTable()}createSchema(t){return Gu({database:t.schema,table:null}),Wb.signalSchemaChange(new zb.SchemaEventMsg(process.pid,Kt.CREATE_SCHEMA,t.schema))}async dropSchema(t){await Qb(t.schema),Wb.signalSchemaChange(new zb.SchemaEventMsg(process.pid,Kt.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,RB.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,wB.default)(t),s,i=Qe()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(o.replicateTo=t.replicateTo),t.replicatedConfirmation&&(o.replicatedConfirmation=t.replicatedConfirmation),Nt(o,async c=>{if(!i.schemaDefined){s=[];for(let f of n)i.attributes.find(p=>p.name==f)||s.push(f);s.length>0&&await i.addAttributes(s.map(f=>({name:f,indexed:!0})))}let l=[],u=[];for(let f of t.records){let d=f[i.primaryKey],p=d!=null&&await i.get(d,o);if(t.requires_existing&&!p||t.requires_no_existing&&p){u.push(f[i.primaryKey]);continue}p&&(p=FE(p));for(let _ in f)if(Object.prototype.hasOwnProperty.call(f,_)){let h=f[_];if(typeof h=="function")try{let S=h([[p]]);Array.isArray(S)&&(h=S[0].func_val,f[_]=h)}catch(S){throw S.message+="Trying to set key "+_+" on object"+JSON.stringify(f),S}}if(p)for(let _ in p)Object.prototype.hasOwnProperty.call(f,_)||(f[_]=p[_]);await(d==null?i.create(f,o):i.put(f,o)),l.push(f[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:u}})}async deleteRecords(t){let r=Qe()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),Nt(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),o=[],c=[];for(let l of i)await r.delete(l,n)?o.push(l):c.push(l);return bB(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Qe()[t.schema][t.table];if(!r.createdTimeProperty)throw new si.ClientError("Table must have a '__createdtime__' attribute or @createdTime timestamp defined to perform this operation");let n=await r.search({conditions:[{attribute:r.createdTimeProperty.name,value:Date.parse(t.date),comparator:om.LESS}]}),s=!1,i=[],o=[],c=0,l=[],u=a(async()=>{let f=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...f.deleted_hashes),o.push(...f.skipped_hashes),await(0,IB.async_set_timeout)(Zte),l=[],s=!0},"chunkDelete");for await(let f of n)l.push(f[r.primaryKey]),c++,c%Xte===0&&await u();return l.length>0&&await u(),s?bB(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,GE.default)(t,"hashes");if(r)throw r;return yB(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of yB(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&JA[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,GE.default)(t,"value");if(n)throw n;let s=Hi(t);if(!s)throw new si.ClientError(`Table ${t.table} not found`);let i=t.search_value;i.includes?.("*")&&(i.startsWith("*")?i.endsWith("*")?i!=="*"&&(r="contains",i=i.slice(1,-1)):(r="ends_with",i=i.slice(1)):i.endsWith("*")&&(r="starts_with",i=i.slice(0,-1))),r===om.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:Jb(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=Hi(t);t.get_attributes&&!t.get_attributes.includes(s.primaryKey)&&t.get_attributes[0]!=="*"&&t.get_attributes.push(s.primaryKey);for await(let i of this.searchByValue(t,r))n.set(i[s.primaryKey],i);return n}resetReadTxn(t,r){Hi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Hi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=Hi(t),n={};switch(t.search_type){case am.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 am.USERNAME:let s=t.search_values;for await(let i of OB(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return OB(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(Jb,"getSelect");a(yB,"getRecords");a(Hi,"getTable");a(bB,"createDeleteResponse");a(OB,"groupRecordsInHistory")});var Vn=w((nCe,DB)=>{"use strict";var{ResourceBridge:ere}=(PB(),C(CB)),tre=ae();tre.initSync();var qE;function rre(){return qE||(qE=new ere,qE)}a(rre,"getBridge");DB.exports=rre()});var Rn=w((iCe,UB)=>{"use strict";var VE=kR(),Dr=ie(),nre=require("util"),KE=Vn(),sre=As(),LB=z(),{handleHDBError:tl,hdb_errors:ire}=pe(),{HTTP_STATUS_CODES:rl}=ire,ore=nre.promisify(sre.getTableSchema),are="updated",MB="inserted",vB="upserted";UB.exports={insert:lre,update:ure,upsert:dre,validation:cre,flush:fre};async function cre(e){if(Dr.isEmpty(e))throw new Error("invalid update parameters defined.");if(Dr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Dr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await ore(e.schema,e.table),r=VE(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&&Dr.isEmptyOrZeroLength(c[n]))throw LB.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(!Dr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw LB.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Dr.isEmpty(c[n])&&c[n]!==""&&s.has(Dr.autoCast(c[n]))&&(c.skip=!0),s.add(Dr.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(cre,"validation");async function lre(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=VE(e);if(t)throw tl(new Error,t.message,rl.BAD_REQUEST);Dr.transformReq(e);let r=Dr.checkSchemaTableExist(e.schema,e.table);if(r)throw tl(new Error,r,rl.BAD_REQUEST);let n=await KE.createRecords(e);return $E(MB,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(lre,"insertData");async function ure(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=VE(e);if(t)throw tl(new Error,t.message,rl.BAD_REQUEST);Dr.transformReq(e);let r=Dr.checkSchemaTableExist(e.schema,e.table);if(r)throw tl(new Error,r,rl.BAD_REQUEST);let n=await KE.updateRecords(e);return Dr.isEmpty(n.existing_rows)?$E(are,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):$E(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(ure,"updateData");async function dre(e){if(e.operation!=="upsert")throw tl(new Error,"invalid operation, must be upsert",rl.INTERNAL_SERVER_ERROR);let t=VE(e);if(t)throw tl(new Error,t.message,rl.BAD_REQUEST);Dr.transformReq(e);let r=Dr.checkSchemaTableExist(e.schema,e.table);if(r)throw tl(new Error,r,rl.BAD_REQUEST);let n=await KE.upsertRecords(e);return $E(vB,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(dre,"upsertData");function $E(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===MB?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===vB?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a($E,"returnObject");function fre(e){return Dr.transformReq(e),KE.flush(e.schema,e.table)}a(fre,"flush")});var GB=w((aCe,FB)=>{var qu=require("validate.js"),BB=it(),$u=(H(),C(G)),{handleHDBError:_re,hdb_errors:pre}=pe(),{HDB_ERROR_MSGS:zt,HTTP_STATUS_CODES:hre}=pre,Xb=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),mre={STRUCTURE_USER:"structure_user"},xB=Object.values($u.ROLE_TYPES_ENUM),Ere="attribute_permissions",gre="attribute_name",{PERMS_CRUD_ENUM:Vu}=$u,Sre=[Ere,...Object.values(Vu)],HB=[Vu.READ,Vu.INSERT,Vu.UPDATE],Tre=[gre,...HB];function Are(e){let t=Xb();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,kB(e,t)}a(Are,"addRoleValidation");function Rre(e){let t=Xb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,kB(e,t)}a(Rre,"alterRoleValidation");function yre(e){let t=Xb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,BB.validateObject(e,t)}a(yre,"dropRoleValidation");var bre=["operation","role","id","permission","hdb_user","hdb_auth_header","access"];function kB(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)bre.includes(n[o])||s.push(n[o]);s.length>0&&nr(zt.INVALID_ROLE_JSON_KEYS(s),r);let i=BB.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{nr(o,r)}),e.permission){let o=Ore(e);o&&nr(o,r),xB.forEach(c=>{e.permission[c]&&!qu.isBoolean(e.permission[c])&&nr(zt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(xB.indexOf(o)<0){if(o===mre.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let u=0,f=l.length;u<f;u++){let d=l[u];global.hdb_schema[d]||nr(zt.SCHEMA_NOT_FOUND(d),r)}continue}nr(zt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){nr(zt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let u=c.tables[l];if(!l||!global.hdb_schema[o][l]){nr(zt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(f=>{Sre.includes(f)||nr(zt.INVALID_PERM_KEY(f),r,o,l)}),Object.values(Vu).forEach(f=>{qu.isDefined(u[f])?qu.isBoolean(u[f])||nr(zt.TABLE_PERM_NOT_BOOLEAN(f),r,o,l):nr(zt.TABLE_PERM_MISSING(f),r,o,l)}),u.attribute_permissions===void 0){nr(zt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){nr(zt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}if(u.attribute_permissions){let f=global.hdb_schema[o][l].attributes.map(({attribute:p})=>p),d={read:!1,insert:!1,update:!1};for(let p in u.attribute_permissions){let _=u.attribute_permissions[p];if(Object.keys(_).forEach(S=>{!Tre.includes(S)&&S!==Vu.DELETE&&nr(zt.INVALID_ATTR_PERM_KEY(S),r,o,l)}),!qu.isDefined(_.attribute_name)){nr(zt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=_.attribute_name;if(!f.includes(h)){nr(zt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}HB.forEach(S=>{qu.isDefined(_[S])?qu.isBoolean(_[S])||nr(zt.ATTR_PERM_NOT_BOOLEAN(S,h),r,o,l):nr(zt.ATTR_PERM_MISSING(S,h),r,o,l)}),!d.read&&_.read===!0&&(d.read=!0),!d.insert&&_.insert===!0&&(d.insert=!0),!d.update&&_.update===!0&&(d.update=!0)}if(u.read===!1&&d.read===!0||u.insert===!1&&d.insert===!0||u.update===!1&&d.update===!0){let p=`${o}.${l}`;nr(zt.MISMATCHED_TABLE_ATTR_PERMS(p),r,o,l)}}}}return Nre(r)}a(kB,"customValidate");FB.exports={addRoleValidation:Are,alterRoleValidation:Rre,dropRoleValidation:yre};function Ore(e){let{operation:t,permission:r}=e;if(t===$u.OPERATIONS_ENUM.ADD_ROLE||t===$u.OPERATIONS_ENUM.ALTER_ROLE){let n=r.super_user===!0,s=r.cluster_user===!0;if(Object.keys(r).length>1&&(n||s)){if(s&&n)return zt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?$u.ROLE_TYPES_ENUM.SUPER_USER:$u.ROLE_TYPES_ENUM.CLUSTER_USER;return zt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(Ore,"validateNoSUPerms");function Nre(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:zt.ROLE_PERMS_ERROR,...e};return _re(new Error,n,hre.BAD_REQUEST)}else return null}a(Nre,"generateRolePermResponse");function nr(e,t,r,n){if(!r)t.main_permissions.push(e);else{let s=n?r+"_"+n:r;t.schema_permissions[s]?t.schema_permissions[s].push(e):t.schema_permissions[s]=[e]}}a(nr,"addPermError")});var F_=w((uCe,KB)=>{"use strict";var qB=Rn(),$B=Yr(),wre=Vc(),eO=GB(),tO=To(),lCe=require("uuid").v4,Ire=require("util"),YE=(H(),C(G)),Cre=ie(),rO=$B.searchByValue,Pre=$B.searchByHash,Dre=Ire.promisify(wre.delete),Lre=ni(),Mre=ku(),{hdb_errors:vre,handleHDBError:nl}=pe(),{HDB_ERROR_MSGS:VB,HTTP_STATUS_CODES:k_}=vre,{UserEventMsg:nO}=ri();KB.exports={addRole:Ure,alterRole:xre,dropRole:Bre,listRoles:Hre};function Zb(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(Zb,"scrubRoleDetails");async function Ure(e){let t=eO.addRoleValidation(e);if(t)throw t;e=Zb(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 rO(r)||[])}catch(i){throw nl(i)}if(n&&n.length>0)throw nl(new Error,VB.ROLE_ALREADY_EXISTS(e.role),k_.CONFLICT,void 0,void 0,!0);e.id||(e.id=e.role);let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await qB.insert(s),tO.signalUserChange(new nO(process.pid)),e=Zb(e),e}a(Ure,"addRole");async function xre(e){let t=eO.alterRoleValidation(e);if(t)throw t;e=Zb(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await qB.update(r)}catch(s){throw nl(s)}if(n&&n?.message==="updated 0 of 1 records")throw nl(new Error,"Invalid role id",k_.BAD_REQUEST,void 0,void 0,!0);return await tO.signalUserChange(new nO(process.pid)),e}a(xre,"alterRole");async function Bre(e){let t=eO.dropRoleValidation(e);if(t)throw nl(new Error,t,k_.BAD_REQUEST,void 0,void 0,!0);let r=new Mre(YE.SYSTEM_SCHEMA_NAME,YE.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await Pre(r));if(n.length===0)throw nl(new Error,VB.ROLE_NOT_FOUND,k_.NOT_FOUND,void 0,void 0,!0);let s=new Lre(YE.SYSTEM_SCHEMA_NAME,YE.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await rO(s)),o=!1;if(Cre.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw nl(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,k_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await Dre(c),tO.signalUserChange(new nO(process.pid)),`${n[0].role} successfully deleted`}a(Bre,"dropRole");async function Hre(){return rO({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Hre,"listRoles")});var sO={};ve(sO,{start:()=>zB,startOnMainThread:()=>Gre});function zB({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,YB.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(kre.includes(o))continue;let c=i.permission[o];c.tables||(i.permission[o]=c={tables:c});for(let l in c.tables){let u=c.tables[l];if(u.read=!!u.read,u.insert=!!u.insert,u.update=!!u.update,u.delete=!!u.delete,u.attributes){let f=[];for(let d in u.attributes){let p=u.attributes[d];p.attribute_name=d,f.push(p)}u.attribute_permissions=f,delete u.attributes}if(u.attribute_permissions){if(!Array.isArray(u.attribute_permissions))throw new Error("attribute_permissions must be an array if defined");for(let f of u.attribute_permissions)f.read=!!f.read,f.insert=!!f.insert,f.update=!!f.update}else u.attribute_permissions=null}}i.role=i.id=s,await Fre(i)}}}async function Fre(e){let t=Qe().system.hdb_role;for await(let r of t.search([{attribute:"role",value:e.role}])){let{__createdtime__:n,__updatedtime__:s,...i}=r;return(0,WB.isEqual)(i,e)?void 0:(e.id=r.id,(0,WE.alterRole)(e))}return(0,WE.addRole)(e)}var WE,YB,WB,kre,Gre,jB=be(()=>{Pe();WE=M(F_()),YB=require("yaml"),WB=require("lodash"),kre=["super_user","cluster_user","structure_user"];a(zB,"start");a(Fre,"ensureRole");Gre=zB});async function zE(e){let t=(0,XB.pathToFileURL)(e).toString();return qre?(G_||(G_=$re(Kre)),(await(await G_).import(t)).namespace):import(t)}async function $re(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),G_=new Compartment({console,Math,Date,fetch:Vre,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,QB.extname)(r)||(r+=".js"),r)},importHook:a(async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:$r,tables:Jn,databases:qe})}};let n=await(0,JB.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),G_}function Vre(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 Kre(){return{Resource:$r,tables:Jn}}var JB,QB,XB,qre,G_,iO=be(()=>{Ea();Pe();JB=require("fs/promises"),QB=require("path"),XB=require("url"),qre=!1;a(zE,"secureImport");a($re,"getCompartment");a(Vre,"secureOnlyFetch");a(Kre,"getGlobalVars")});var aO={};ve(aO,{handleFile:()=>Yre});async function Yre(e,t,r,n){let s=new Map,i=await zE(r);c(i.default)&&n.set((0,oO.dirname)(t),i.default),o(i,(0,oO.dirname)(t));function o(l,u){for(let f in l){let d=l[f];c(d)?n.set(u+"/"+f,d):typeof d=="object"&&o(d,u+"/"+f)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var oO,ZB=be(()=>{iO();oO=require("path");a(Yre,"handleFile")});var lO={};ve(lO,{start:()=>Wre});function Wre({resources:e}){e.set("login",cO),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var cO,eH=be(()=>{Ea();a(Wre,"start");cO=class extends $r{static{a(this,"Login")}static async get(t,r,n){}static async post(t,r,n){let{username:s,password:i,redirect:o}=r;return{data:await n.login(s,i)}}}});var W_={};ve(W_,{addAnalyticsListener:()=>Y_,calculateCPUUtilization:()=>SH,diffResourceUsage:()=>TH,recordAction:()=>sr,recordActionBinary:()=>Qn,setAnalyticsEnabled:()=>zre});function zre(e){pH=e}function jre(e,t){if(typeof e=="number"){let r=t.values,n=r.index++;if(n>=r.length){let s=r;t.values=r=new Float32Array(n*2),r.set(s),r.index=n+1}r[n]=e,t.total+=e}else if(typeof e=="boolean")e&&t.total++,t.count++;else if(typeof e=="function")t.count++;else throw new TypeError("Invalid metric value type "+typeof e)}function Jre(e,t,r,n,s,i){let o={};if(typeof t=="number")o.total=t,o.values=new Float32Array(4),o.values.index=1,o.values[0]=t,o.total=t;else if(typeof t=="boolean")o.total=t?1:0,o.count=1;else if(typeof t=="function")o.count=1,o.callback=t;else throw new TypeError("Invalid metric value type "+typeof t);o.description={metric:r,path:n,method:s,type:i},JE.set(e,o)}function sr(e,t,r,n,s){if(!pH)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=JE.get(i);o?jre(e,o):Jre(i,e,t,r,n,s),jE||Qre()}function Qn(e,t,r,n,s){sr(!!e,t,r,n,s)}function Y_(e){EH.push(e)}function Qre(){jE=performance.now(),setTimeout(async()=>{let e=performance.now()-jE;jE=0;let t=[],r={time:Date.now(),period:e,threadId:sl.threadId,metrics:t};for(let[s,i]of JE){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,u=[],f;for(let d of gH){let p=Math.floor(c*d),_=o[p-1];if(p>l){let h=p-l;if(_===f){let S=u[u.length-1];typeof S=="number"?u[u.length-1]={value:S,count:1+h}:S.count+=h}else u.push(h>1?{value:_,count:h}:_),f=_;l=p}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:u,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await AH()}let n=process.memoryUsage();t.push({metric:"memory",threadId:sl.threadId,byThread:!0,...n});for(let s of EH)s(t);JE=new Map,sl.parentPort?sl.parentPort.postMessage({type:mH,report:r}):bH({report:r})},hH).unref()}function QE(e,t,r){let n={id:(0,V_.getNextMonotonicTime)(),metric:t,...r};e.primaryStore.put(n.id,n,{append:!0}).then(s=>{s||e.primaryStore.put(n.id,n)})}function SH(e,t){let r=e.userCPUTime+e.systemCPUTime;return Math.round(r/t*100)/100}function TH(e,t){return{userCPUTime:t.userCPUTime/1e3-(e?.userCPUTime??0),systemCPUTime:t.systemCPUTime/1e3-(e?.systemCPUTime??0),minorPageFault:t.minorPageFault-(e?.minorPageFault??0),majorPageFault:t.majorPageFault-(e?.majorPageFault??0),fsRead:t.fsRead-(e?.fsRead??0),fsWrite:t.fsWrite-(e?.fsWrite??0),voluntaryContextSwitches:t.voluntaryContextSwitches-(e?.voluntaryContextSwitches??0),involuntaryContextSwitches:t.involuntaryContextSwitches-(e?.involuntaryContextSwitches??0)}}function Xre(e,t,r){let n=0;for(let[s,i]of Object.entries(r)){let o=`${t}.${s}`,c=i.getSize(),l={database:t,table:s,size:c};QE(e,"table-size",l),il.trace?.(`table ${o} size metric: ${JSON.stringify(l)}`),n+=c}return n}function tH(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s.getAuditSize(),o=_H.default.statSync(s.primaryStore.env.path).size,c=Xre(e,r,n),l=o-c,u={database:r,size:o,used:c,free:l,audit:i};QE(e,"database-size",u),il.trace?.(`database ${r} size metric: ${JSON.stringify(u)}`)}catch(s){il.warn?.("Error getting DB size metrics",s)}}function rH(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s.getStorageStats(),o={database:r,...i};QE(e,"storage-volume",o),il.trace?.(`db ${r} storage volume metrics: ${JSON.stringify(o)}`)}catch(s){il.warn?.("Error getting DB volumne metrics",s)}}async function Zre(e,t=6e4){let r=dO(),n=RH(),s=new Promise(E=>{let T=performance.now();setImmediate(()=>{let b=performance.now();b-T>5e3&&il.warn?.("Unusually high event queue latency on the main thread of "+Math.round(b-T)+"ms"),T=performance.now()}),n.primaryStore.prefetch([1],()=>{let b=performance.now();b-T>5e3&&il.warn?.("Unusually high task queue latency on the main thread of "+Math.round(b-T)+"ms"),E(b-T)})}),i;for(let E of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(E.value?.time){i=E.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,u=[],f;for(let{key:E,value:T}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!T)continue;if(o){if(E>o+t)break}else o=E;f=E;let{metrics:b,threadId:v}=T;for(let F of b||[]){let{path:q,method:Y,type:Z,metric:se,count:Q,total:ne,distribution:J,threads:he,...Re}=F;Q||(Q=1);let Ce=se+(q?"-"+q:"");Y!==void 0&&(Ce+="-"+Y),Z!==void 0&&(Ce+="-"+Z);let me=c.get(Ce);if(me){if(me.threads){let ut=me.threads[v];if(ut)me=ut;else{me.threads[v]={...Re};continue}}me.count||(me.count=1);let Zt=me.count;for(let ut in Re){let yr=Re[ut];typeof yr=="number"&&(me[ut]=(me[ut]*Zt+yr*Q)/(Zt+Q))}me.count+=Q,ne>=0&&(me.total+=ne,me.ratio=me.total/me.count)}else me={period:t,...F},delete me.distribution,c.set(Ce,me),me.byThread&&(me.threads=[],me.threads[v]={...Re},u.push(me));if(J){J=J.map(ut=>typeof ut=="number"?{value:ut,count:1}:ut);let Zt=l.get(Ce);Zt?Zt.push(...J):l.set(Ce,J)}}await AH()}for(let E of u){let{path:T,method:b,type:v,metric:F,count:q,total:Y,distribution:Z,threads:se,...Q}=E;se=se.filter(ne=>ne);for(let ne in Q){if(typeof E[ne]!="number")continue;let J=0;for(let he of se){let Re=he[ne];typeof Re=="number"&&(J+=Re)}E[ne]=J}E.count=se.length,delete E.threads,delete E.byThread}for(let[E,T]of l){let b=c.get(E);T.sort((ut,yr)=>ut.value>yr.value?1:-1);let v=b.count-1,F=[],q=0,Y=0,Z;for(let ut of gH){let yr=v*ut;for(;q<yr;)Z=T[Y++],q+=Z.count,Y===1&&q--;let hs=T[Y>1?Y-2:0];Z||(Z=T[0]),F.push(Z.value-(Z.value-hs.value)*(q-yr)/Z.count)}let[se,Q,ne,J,he,Re,Ce,me,Zt]=F;Object.assign(b,{p1:se,p10:Q,p25:ne,median:J,p75:he,p90:Re,p95:Ce,p99:me,p999:Zt})}let d;for(let[E,T]of c)T.id=(0,V_.getNextMonotonicTime)(),T.time=f,n.primaryStore.put(T.id,T,{append:!0}).then(b=>{b||n.primaryStore.put(T.id,T)}),d=!0;let p=Date.now(),{idle:_,active:h}=performance.eventLoopUtilization();if(d||h*10>_){let E=(0,V_.getNextMonotonicTime)(),T={id:E,metric:"main-thread-utilization",idle:_-nH,active:h-sH,taskQueueLatency:await s,time:p,...process.memoryUsage()};n.primaryStore.put(E,T,{append:!0}).then(b=>{b||n.primaryStore.put(E,T)})}nH=_,sH=h;let S=process.resourceUsage(),g=TH(q_,S);g.time=p,g.period=q_.time?p-q_.time:t,g.cpuUtilization=SH(q_,g.period),QE(n,"resource-usage",g),q_=g;let R=Qe();tH(n,R),tH(n,{system:R.system}),rH(n,R),rH(n,{system:R.system})}async function iH(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function dO(){return oH||(oH=ft({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function RH(){return aH||(aH=ft({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function rne(){yH=!0;let e=(0,K_.get)(B.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await Zre(hH,e),await iH(dO(),ene),await iH(RH(),tne)},Math.min(e/2,2147483647)).unref()}function bH(e,t){let r=e.report;r.threadId=t?.threadId||sl.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(cH+=n.mean*n.count);r.totalBytesProcessed=cH,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(lH.get(t))}),lH.set(t,t.performance.eventLoopUtilization())),r.id=(0,V_.getNextMonotonicTime)(),dO().primaryStore.put(r.id,r),yH||rne(),nne&&(OH=ine(r))}async function ine(e){if(await OH,!Ca){let r=(0,$_.dirname)((0,dH.getLogFilePath)());try{Ca=await(0,uO.open)((0,$_.join)(r,"analytics.log"),"r+")}catch{Ca=await(0,uO.open)((0,$_.join)(r,"analytics.log"),"w+")}}let t=(await Ca.stat()).size;if(t>sne){let r=Buffer.alloc(t);await Ca.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Ca.write(r,{position:0}),await Ca.truncate(r.length),t=r.length}await Ca.write(JSON.stringify(e)+`
21
- `,t)}var sl,uH,dH,fH,$_,uO,V_,K_,_H,il,JE,pH,jE,hH,mH,EH,gH,nH,sH,q_,AH,ene,tne,oH,aH,yH,cH,lH,nne,OH,Ca,sne,ki=be(()=>{sl=require("worker_threads"),uH=M(et());Pe();dH=M(z()),fH=M(Ni()),$_=require("path"),uO=require("fs/promises"),V_=M(_n()),K_=M(ae());H();Vr();_H=M(require("node:fs")),il=(0,fH.loggerWithTag)("analytics");(0,K_.initSync)();JE=new Map,pH=(0,K_.get)(B.ANALYTICS_AGGREGATEPERIOD)>-1;a(zre,"setAnalyticsEnabled");a(jre,"recordExistingAction");a(Jre,"recordNewAction");a(sr,"recordAction");Ye.recordAnalytics=sr;a(Qn,"recordActionBinary");jE=0,hH=1e3,mH="analytics-report",EH=[];a(Y_,"addAnalyticsListener");gH=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(Qre,"sendAnalytics");a(QE,"storeMetric");a(SH,"calculateCPUUtilization");a(TH,"diffResourceUsage");a(Xre,"storeTableSizeMetrics");a(tH,"storeDBSizeMetrics");a(rH,"storeVolumeMetrics");a(Zre,"aggregation");nH=0,sH=0,q_={},AH=a(()=>new Promise(setImmediate),"rest");a(iH,"cleanup");ene=36e5,tne=31536e6;a(dO,"getRawAnalyticsTable");a(RH,"getAnalyticsTable");(0,uH.setChildListenerByType)(mH,bH);a(rne,"startScheduledTasks");cH=0,lH=new Map,nne=!1;a(bH,"recordAnalytics");sne=1e6;a(ine,"logAnalytics")});var NH={};ve(NH,{Headers:()=>yo,appendHeader:()=>XE,mergeHeaders:()=>fO});function XE(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 fO(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new yo(e));for(let[r,n]of t)e.has(r)?r.toLowerCase()==="set-cookie"&&e.append?.(r,n,!0):e.set(r,n);return e}var yo,z_=be(()=>{yo=class extends Map{static{a(this,"Headers")}constructor(t){if(t)if(t[Symbol.iterator])super(t);else{super();for(let r in t)this.set(r,t[r])}else super()}set(t,r){return typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r),super.set(t.toLowerCase(),[t,r])}get(t){return typeof t!="string"&&(t=""+t),super.get(t.toLowerCase())?.[1]}has(t){return typeof t!="string"&&(t=""+t),super.has(t.toLowerCase())}setIfNone(t,r){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let n=t.toLowerCase();if(!super.has(n))return super.set(n,[t,r])}append(t,r,n){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let s=t.toLowerCase(),i=super.get(s);if(i){let o=i[1];if(n)r=(typeof o=="string"?o:o.join(", "))+", "+r;else if(typeof o=="string")r=[o,r];else{o.push(r);return}}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}};a(XE,"appendHeader");a(fO,"mergeHeaders")});function DH(e){let t={openapi:one,info:{title:"HarperDB HTTP REST interface",version:PH.packageJson.version},paths:{},components:{schemas:{},securitySchemes:{basicAuth:{type:"http",scheme:"basic"},bearerAuth:{type:"http",scheme:"bearer",bearerFormat:"JWT"}}}},r=[{basicAuth:[],bearerAuth:[]}];for(let[,n]of e){if(!n.path||n.Resource.isError)continue;let{path:s}=n,i=s.split("/").slice(-1),{attributes:o,primaryKey:c,prototype:l}=n.Resource;if(c=c??"id",!c)continue;let u={},f=[];if(o)for(let{type:T,name:b,elements:v,relationship:F,definition:q}of o){if(F)T==="array"?u[b]={type:"array",items:{$ref:Pa+v.type}}:u[b]={$ref:Pa+T};else{let Y=q??v?.definition;if(Y){if(!t.components.schemas[Y.type]){let Z={};Y.properties.forEach(se=>{Z[se.name]=new mO(_O[se.type],se.type)}),t.components.schemas[Y.type]=new CH(Z)}T==="array"?u[b]={type:"array",items:{$ref:Pa+Y.type}}:u[b]={$ref:Pa+Y.type}}else T==="array"?v.type==="Any"||v.type=="ID"?u[b]={type:"array",items:{format:v.type}}:u[b]={type:"array",items:new mO(_O[v.type],v.type)}:T==="Any"||T=="ID"?u[b]={format:T}:u[b]=new mO(_O[T],T)}f.push(new EO(b,"query",u[b]))}let d=Object.keys(u),p=new EO(c,"path",{format:"ID"});p.required=!0,p.description="primary key of record";let _=new EO("property","path",{enum:d});_.required=!0,t.components.schemas[i]=new CH(u);let h=l.post!==Resource.prototype.post||l.update,S=typeof l.put=="function",g=typeof l.get=="function",R=typeof l.delete=="function",E="/"+s+"/";h&&(t.paths[E]={},t.paths[E].post=new ane(i,r,"create a new record auto-assigning a primary key")),g&&(t.paths[E]||(t.paths[E]={}),t.paths[E].get=new pO(f,r,{200:new hO({$ref:Pa+i})},"search for records by the specified property name and value pairs")),R&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new IH(f,r,"delete all the records that match the provided query",{204:new wH})),E="/"+s+"/{"+c+"}",g&&(t.paths[E]={},t.paths[E].get=new pO([p],r,{200:new hO({$ref:Pa+i})},"retrieve a record by its primary key")),S&&(t.paths[E]||(t.paths[E]={}),t.paths[E].put=new cne([p],r,i,"create or update the record with the URL path that maps to the record's primary key")),R&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new IH([p],r,"delete a record with the given primary key",{204:new wH})),g&&_.schema.enum.length>0&&(E="/"+s+"/{"+c+"}.{property}",t.paths[E]={},t.paths[E].get=new pO([p,_],r,{200:new hO({enum:d})},"used to retrieve the specified property of the specified record"))}return t}function ane(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:Pa+e}}}},this.security=t,this.responses={200:{description:gO,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function pO(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function hO(e){this.description=gO,this.content={"application/json":{schema:e}}}function wH(){this.description="successfully processed request, no content returned to client"}function cne(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:Pa+r}}}},this.responses={200:{description:gO}}}function IH(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function CH(e){this.type="object",this.properties=e}function mO(e,t){this.type=e,this.format=t}function EO(e,t,r){this.name=e,this.in=t,this.schema=r}var PH,one,_O,Pa,gO,LH=be(()=>{PH=M(st()),one="3.0.3",_O={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},Pa="#/components/schemas/",gO="successful operation";a(DH,"generateJsonApi");a(ane,"Post");a(pO,"Get");a(hO,"Response200");a(wH,"Response204");a(cne,"Put");a(IH,"Delete");a(CH,"ResourceSchema");a(mO,"Type");a(EO,"Parameter")});var eg={};ve(eg,{parseHeaderValue:()=>TO,start:()=>dne});async function une(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream",s=n?"CONNECT":e.method;e.search&&bm(e);let i=new yo;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==MH){let g=ZE.getMatch(o,n?"sse":"rest");if(!g)return t(e);e.handlerPath=g.path,c=new Oc(g.relativeURL),c.async=!0,l=g.Resource}if(l?.isCaching){let g=r["cache-control"];if(g){let R=TO(g);for(let E of R)switch(E.name){case"max-age":e.expiresAt=E.value*1e3+Date.now();break;case"only-if-cached":e.onlyIfCached=!0;break;case"no-cache":e.noCache=!0;break;case"no-store":e.noCacheStore=!0;break;case"stale-if-error":e.staleIfError=!0;break;case"must-revalidate":e.mustRevalidate=!0;break}}}let u=r["x-replicate-to"];if(u){let g=TO(u).map(R=>(R.next?.name==="confirm"&&R.next.value>=0&&(e.replicatedConfirmation=+R.next.value),R.name));e.replicateTo=g.length===1&&+g[0]>=0?+g[0]:g[0]==="*"?void 0:g}r["x-replicate-from"]==="none"&&(e.replicateFrom=!1);let d=await Nt(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=uo(r["content-type"],!0)(e.body,e.headers)}catch(g){throw new Ku.ClientError(g,400)}if(e.authorize=!0,o===MH&&s==="GET"){if(e?.user?.role?.permission?.super_user)return DH(ZE);throw new Ku.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 Ku.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Ku.ServerError(`Method ${s} is not recognized`,501)}}),p=200,_;if(d==null)p=s==="GET"||s==="HEAD"?404:204,SO.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(d.status>0&&d.headers){let g=fO(d.headers,i);return d.headers!==g&&(d.headers=g),d.data!==void 0&&(d.body=Jf(d.data,e,d)),d}else if(_=e.lastModified){lne[0]=_;let g=String.fromCharCode(34,(Lr[0]&63)+62,(Lr[0]>>6)+(Lr[1]<<2&63)+62,(Lr[1]>>4)+(Lr[2]<<4&63)+62,(Lr[2]>>2)+62,(Lr[3]&63)+62,(Lr[3]>>6)+(Lr[4]<<2&63)+62,(Lr[4]>>4)+(Lr[5]<<4&63)+62,(Lr[5]>>2)+62,(Lr[6]&63)+62,(Lr[6]>>6)+(Lr[7]<<2&63)+62,34),R=r["if-none-match"];R&&g==R?(d?.onDone&&d.onDone(),p=304,d=void 0):i.setIfNone("ETag",g),SO.lastModified&&i.setIfNone("Last-Modified",new Date(_).toUTCString())}e.createdResource&&(p=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let h={status:p,headers:i,body:void 0},S=d?.wasLoadedFromSource?.();return S!==void 0&&(h.wasCacheMiss=S,!S&&_&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||_))/1e3))),d!==void 0&&(h.body=Jf(d,e,h),s==="HEAD"&&(h.body=void 0)),h}catch(o){o.statusCode?o.statusCode===500?Fi.warn(o):Fi.info(o):Fi.error(o),o.statusCode===405&&(o.method&&(o.message+=` to handle HTTP method ${o.method.toUpperCase()||""}`),o.allow&&(o.allow.push("trace","head","options"),i.setIfNone("Allow",o.allow.map(l=>l.toUpperCase()).join(", "))));let c={status:o.statusCode||500,headers:i,body:void 0};return c.body=Jf(o.contentType?o:o.toString(),e,c),c}}function dne(e){SO=e,!vH&&(vH=!0,ZE=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return une(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{j_++;let s=new xn;UH||(UH=!0,Y_(l=>{j_>0&&l.push({metric:"ws-connections",connections:j_,byThread:!0})}));let i;t.on("error",l=>{i=!0,Fi.warn(l)});let o;t.on("message",a(function(u){o||(o=uo(r.requestedContentType??r.headers.asObject["content-type"],!1));let f=o(u);sr(u.length,"bytes-received",r.handlerPath,"message","ws"),s.push(f)},"message"));let c;t.on("close",()=>{j_--,Qn(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),u=ZE.getMatch(l,"ws");if(Qn(!!u,"connection","ws","connect"),u){r.handlerPath=u.path,sr(h=>({count:h.count,total:j_}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let f=new Oc(u.relativeURL),d=u.Resource;c=(await Nt(r,()=>d.connect(f,s,r)))[Symbol.asyncIterator]();let _;for(;!(_=await c.next()).done;){let h=await Aa(_.value,r);t.send(h),sr(h.length,"bytes-sent",r.handlerPath,"message","ws"),t._socket.writableNeedDrain&&await new Promise(S=>t._socket.once("drain",S))}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){l.statusCode?l.statusCode===500?Fi.warn(l):Fi.info(l):Fi.error(l),t.close(fne[l.statusCode]||1011,l.toString())}t.close()},e))}function TO(e){return e.trim().split(",").map(t=>{let r,n=t.trim().split(";"),s;for(;s=n.pop();)if(s.includes("=")){let[i,o]=s.trim().split("=");i=i.trim(),o&&(o=o.trim()),r={name:i.toLowerCase(),value:o,next:r}}else r={name:s.toLowerCase(),next:r};return r})}var Fi,Ku,Lr,lne,SO,MH,vH,ZE,UH,j_,fne,xH=be(()=>{ao();ki();Fi=M(z()),Ku=M(pe());Gf();_u();bc();z_();LH();Gf();Lr=new Uint8Array(8),lne=new Float64Array(Lr.buffer,0,1),SO={},MH="openapi";a(une,"http");j_=0;a(dne,"start");fne={401:3e3,403:3003};a(TO,"parseHeaderValue")});var AO=w((kCe,HH)=>{var{recordAction:tg,recordActionBinary:BH}=(ki(),C(W_)),_ne=require("fastify-plugin"),pne=200;HH.exports=_ne(function(e,t,r){e.addHook("onResponse",async(n,s)=>{let i=s.elapsedTime}),e.addHook("onSend",async(n,s,i)=>{let o=s.elapsedTime,c=performance.now(),l=s.request.routeOptions,u,f,d;l.config?.isOperation?(u=n.body?.operation,f="operation"):(u=l.url,f="fastify-route",d=l.method),tg(o,"duration",u,d,f),BH(s.raw.statusCode<400,"success",u,d,f),BH(1,"response_"+s.raw.statusCode,u,d,f);let p=pne;i?.pipe?(i.on("data",g=>{p+=g.length}),i.on("end",()=>{tg(performance.now()-c,"transfer",u,d,f),tg(p,"bytes-sent",u,d,f)})):(p+=i?.length||0,tg(p,"bytes-sent",u,d,f));let _=o.toFixed(3),h=s.getHeader("Server-Timing"),S=`db;dur=${_}`;s.header("Server-Timing",h?`${h}, ${S}`:S)}),r()},{name:"hdb-request-time"})});var FH=w((FCe,kH)=>{var hne=it(),mne={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};kH.exports=function(e){return hne.validateObject(e,mne)}});var rg=w((GCe,GH)=>{"use strict";var Ene=(H(),C(G)).OPERATIONS_ENUM,RO=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=Ene.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};GH.exports=RO});var X_={};ve(X_,{createTokens:()=>Sne,getJWTRSAKeys:()=>ag,refreshOperationToken:()=>Tne,validateOperationToken:()=>OO,validateRefreshToken:()=>cg});async function ag(){if(ng)return ng;try{let e=J_.default.join(Q_.default.getHdbBasePath(),WA),t=await sg.default.readFile(J_.default.join(e,Of.JWT_PASSPHRASE_NAME),"utf8"),r=await sg.default.readFile(J_.default.join(e,Of.JWT_PRIVATE_KEY_NAME),"utf8");return ng={publicKey:await sg.default.readFile(J_.default.join(e,Of.JWT_PUBLIC_KEY_NAME),"utf8"),privateKey:r,passphrase:t},ng}catch(e){throw og.default.error(e),new ii.ClientError(Wu.NO_ENCRYPTION_KEYS,Yu.INTERNAL_SERVER_ERROR)}}async function Sne(e){let t=(0,yO.validateBySchema)(e,Gi.default.object({username:Gi.default.string().optional(),password:Gi.default.string().optional(),role:Gi.default.string().optional(),expires_in:Gi.default.alternatives(Gi.default.string(),Gi.default.number()).optional()}));if(t)throw new ii.ClientError(t.message);let r;try{let d=e.bypass_auth!==!0;!e.username&&!e.password&&(e.username=e.hdb_user?.username,d=!1),r=await(0,bO.findAndValidateUser)(e.username,e.password,d)}catch(d){throw og.default.error(d),new ii.ClientError(Wu.INVALID_CREDENTIALS,Yu.UNAUTHORIZED)}if(!r)throw new ii.ClientError(Wu.INVALID_CREDENTIALS,Yu.UNAUTHORIZED);let n=!1,s=!1;r.role?.permission&&(n=r.role.permission.super_user===!0,s=r.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s};e.role&&(i.role=e.role);let o=await ag(),c=await zu.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:e.expires_in??YH,algorithm:ig,subject:"operation"}),l=await zu.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:gne,algorithm:ig,subject:"refresh"}),u=ky(l,"sha256");if((await(0,qH.update)(new $H.default(bf,du.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]))).skipped_hashes.length>0)throw new ii.ClientError(Wu.REFRESH_TOKEN_SAVE_FAILED,Yu.INTERNAL_SERVER_ERROR);return VH.default.signalUserChange(new KH.UserEventMsg(process.pid)),{operation_token:c,refresh_token:l}}async function Tne(e){let t=(0,yO.validateBySchema)(e,Gi.default.object({refresh_token:Gi.default.string().required()}).required());if(t)throw new ii.ClientError(t.message);let{refresh_token:r}=e;await cg(r);let n=await ag(),s=await zu.default.decode(r);return{operation_token:await zu.default.sign({username:s.username,super_user:s.super_user,cluster_user:s.cluster_user},{key:n.privateKey,passphrase:n.passphrase},{expiresIn:YH,algorithm:ig,subject:"operation"})}}async function OO(e){return WH(e,"operation")}async function cg(e){return WH(e,"refresh")}async function WH(e,t){try{let r=await ag(),n=await zu.default.verify(e,r.publicKey,{algorithms:ig,subject:t});if(n.role)throw new Error("Invalid token");let s=await(0,bO.findAndValidateUser)(n.username,void 0,!1);if(t==="refresh"&&!Fy(s.refresh_token,e))throw new Error("Invalid token");return s}catch(r){throw og.default.warn(r),r?.name==="TokenExpiredError"?new ii.ClientError(Wu.TOKEN_EXPIRED,Yu.FORBIDDEN):new ii.ClientError(Wu.INVALID_TOKEN,Yu.UNAUTHORIZED)}}var zu,sg,J_,Gi,yO,ii,og,bO,qH,$H,VH,KH,Q_,Yu,Wu,YH,gne,ig,ng,ju=be(()=>{zu=M(require("jsonwebtoken")),sg=M(require("fs-extra")),J_=M(require("node:path")),Gi=M(require("joi")),yO=M(it());H();ii=M(pe()),og=M(z());pE();bO=M(An()),qH=M(Rn()),$H=M(rg()),VH=M(To()),KH=M(ri()),Q_=M(ae()),{HTTP_STATUS_CODES:Yu,AUTHENTICATION_ERROR_MSGS:Wu}=ii.hdb_errors;Q_.default.initSync();YH=Q_.default.get(B.AUTHENTICATION_OPERATIONTOKENTIMEOUT)||"1d",gne=Q_.default.get(B.AUTHENTICATION_REFRESHTOKENTIMEOUT)||"30d",ig="RS256";a(ag,"getJWTRSAKeys");a(Sne,"createTokens");a(Tne,"refreshOperationToken");a(OO,"validateOperationToken");a(cg,"validateRefreshToken");a(WH,"validateToken")});var NO=w((YCe,JH)=>{"use strict";var Ane=FH(),Ju=require("passport"),Rne=require("passport-local").Strategy,yne=require("passport-http").BasicStrategy,bne=require("util"),One=An(),jH=bne.callbackify(One.findAndValidateUser),KCe=Un(),Nne=(H(),C(G)),zH=(ju(),C(X_));Ju.use(new Rne(function(e,t,r){jH(e,t,r)}));Ju.use(new yne(function(e,t,r){jH(e,t,r)}));Ju.serializeUser(function(e,t){t(null,e)});Ju.deserializeUser(function(e,t){t(null,e)});function wne(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":Ju.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===Nne.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?zH.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):zH.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:Ju.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(wne,"authorize");function Ine(e,t){let r=Ane(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(Ine,"checkPermissions");JH.exports={authorize:wne,checkPermissions:Ine}});var lg=w((zCe,QH)=>{"use strict";var Cne=Vn();QH.exports={writeTransaction:Pne};function Pne(e,t,r){return Cne.writeTransaction(e,t,r)}a(Pne,"writeTransaction")});var tk=w((QCe,ek)=>{"use strict";var Dne=Yr(),Lne=As(),XH=z(),Mne=Rn(),JCe=lg(),vne=require("clone"),IO=require("alasql"),Une=oE(),ZH=require("util"),xne=ZH.promisify(Lne.getTableSchema),Bne=ZH.promisify(Dne.search),Hne=(H(),C(G)),wO=ie();Une(IO);ek.exports={update:Fne};var kne="There was a problem performing this update. Please check the logs and try again.";async function Fne({statement:e,hdb_user:t}){let r=await xne(e.table.databaseid,e.table.tableid),n=Gne(e.columns);wO.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=vne(s),c=wO.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=IO.parse(l).statements[0],f=await Bne(u),d=qne(n,f);return $ne(o,d,t)}a(Fne,"update");function Gne(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=IO.compile(`SELECT ${r.expression.toString()} AS [${Hne.FUNC_VAL}] FROM ?`)}),t}catch(t){throw XH.error(t),new Error(kne)}}a(Gne,"createUpdateRecord");function qne(e,t){return wO.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(qne,"buildUpdateRecords");async function $ne(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await Mne.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){XH.error(`Error delete new_attributes from update response: ${i}`)}return s}a($ne,"updateRecords")});var nk=w((tPe,rk)=>{var Vne=require("alasql"),Kne=Yr(),Yne=z(),Wne=Vn(),PO=require("util"),CO=ie(),zne=(H(),C(G)),jne=As(),ZCe=lg(),ePe=Rn(),Jne="record",Qne="successfully deleted",Xne=PO.callbackify(rse),Zne=PO.promisify(Kne.search),ese=PO.promisify(jne.getTableSchema);rk.exports={convertDelete:Xne};function tse(e){return`${e.deleted_hashes.length} ${Jne}${e.deleted_hashes.length===1?"":"s"} ${Qne}`}a(tse,"generateReturnMessage");async function rse({statement:e,hdb_user:t}){let r=await ese(e.table.databaseid,e.table.tableid);CO.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=CO.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=Vne.parse(o).statements[0],l={operation:zne.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await Zne(c);let u=await Wne.deleteRecords(l);return CO.isEmptyOrZeroLength(u.message)&&(u.message=tse(u)),delete u.txn_time,u}catch(u){throw Yne.error(u),u.hdb_code?u.message:u}}a(rse,"convertDelete")});var ck=w((nPe,ak)=>{"use strict";var nse=go(),{hdb_errors:sk}=pe(),{getDatabases:ik}=(Pe(),C(tt));ak.exports={checkSchemaExists:ok,checkSchemaTableExists:sse,schema_describe:nse};async function ok(e){if(!ik()[e])return sk.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(ok,"checkSchemaExists");async function sse(e,t){let r=await ok(e);if(r)return r;if(!ik()[e][t])return sk.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(sse,"checkSchemaTableExists")});var UO=w((cPe,Tk)=>{"use strict";var{decode:ise}=require("msgpackr"),{isMainThread:iPe,parentPort:oPe,threadId:aPe}=require("worker_threads"),fg=ir(),Qu=Tt(),MO=(H(),C(G)),Jr=z(),LO=ae(),ose=(H(),C(G)),{onMessageByType:ase}=et(),fk=Eo(),{recordAction:lk,recordActionBinary:cse}=(ki(),C(W_)),{publishToStream:lse}=fg,{ConsumerEvents:uk}=require("nats"),use=Yr(),{promisify:dse}=require("util"),{decodeBlobsWithWrites:fse}=(gs(),C(Fm)),_k=dse(setTimeout),_g=1e4,pg,dg,_se,pse,pk,Z_=new Map,Xu=new Map;Tk.exports={initialize:hk,ingestConsumer:vO,setSubscription:hse,setIgnoreOrigin:gse,getDatabaseSubscriptions:Ese,updateConsumer:mk};async function hk(){ase(MO.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await mk(n)}),pk=!0,Jr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await fg.getNATSReferences();pg=e,dg=e.info.server_name,_se=t,pse=r}a(hk,"initialize");async function mk(e){if(e.status==="start"){let{js:t,jsm:r}=await Ek(e.node_domain_name);vO(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=Z_.get(e.stream_name+e.node_domain_name);t&&(Jr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),Z_.set(e.stream_name+e.node_domain_name,"close")),Xu.get(e.node_domain_name)==="failed"&&Xu.set(e.node_domain_name,"close")}}a(mk,"updateConsumer");var hg=new Map;function hse(e,t,r){let n=hg.get(e);n||hg.set(e,n=new Map),n.set(t,r),pk||hk().then(mse)}a(hse,"setSubscription");async function mse(){let e=await use.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+Qu.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions||[])if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await Ek(r),!n))break;let{schema:o,table:c}=i,l=fk.createNatsTableStreamName(o,c);vO(l,n,s,r)}}}a(mse,"accessConsumers");async function Ek(e){let t,r,n=1;for(;!r;)try{t=await pg.jetstream({domain:e}),r=await pg.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(Xu.get(e)==="close")break;Xu.set(e,"failed"),n%10===1&&Jr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<_g?n++*100:_g;await _k(i)}return{js:t,jsm:r}}a(Ek,"connectToRemoteJS");function Ese(){return hg}a(Ese,"getDatabaseSubscriptions");var gk;function gse(e){gk=e}a(gse,"setIgnoreOrigin");var Sk=100,dk=new Array(Sk),ug=0;async function vO(e,t,r,n){let{connection:s}=await fg.getNATSReferences();pg=s,dg=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,dg),Jr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(Xu.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 fg.createConsumer(r,e,dg,new Date(Date.now()).toISOString()));let f=o++*100<_g?o++*100:_g;await _k(f)}let c=!1,l;for(;!c;){if(Z_.get(e+n)==="close"||Xu.get(n)==="close"){Z_.delete(e+n),c=!0;continue}l=await i.consume({max_messages:LO.get(MO.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),Z_.set(e+n,l);let u=!1;(async()=>{for await(let f of await l.status())if(f.type===uk.ConsumerDeleted&&(await l.close(),c=!0),f.type===uk.HeartbeatsMissed){let d=f.data;Jr.trace(`${d} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),d===100&&(Jr.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${l.consumer.stream}`),l.stop(),u=!0)}})();try{for await(let f of l)await dk[ug],dk[ug]=Sse(f).catch(d=>{Jr.error(d)}),++ug>=Sk&&(ug=0)}catch(f){f.message==="consumer deleted"?(Jr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):Jr.error("Error consuming clustering ingest, restarting consumer",f)}}}a(vO,"ingestConsumer");async function Sse(e){let t;await fse(()=>{t=ise(e.data)}),lk(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=LO.get(MO.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(Qu.MSG_HEADERS.TRANSACTED_NODES)&&r.values(Qu.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(Qu.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!gk),cse(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(Qu.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:u,records:f,hash_values:d,__origin:p,expiresAt:_}=t;Jr.trace("processing message:",o,c,u,(f?"records: "+f.map(v=>v?.id):"")+(d?"ids: "+d:""),"with sequence:",e.seq),Jr.trace(`messageProcessor nats msg id: ${e.headers.get(Qu.MSG_HEADERS.NATS_MSG_ID)}`);let h;f||(f=d);let S=new Promise(v=>h=v),{timestamp:g,user:R,node_name:E}=p||{},T=hg.get(c)?.get(u);if(!T)throw new Error(`Missing table for replication message: ${u}`);if(o==="define_schema")t.type=o,t.onCommit=h,T.send(t);else if(f.length===1&&!l)T.send({type:DO(o),value:f[0],id:d?.[0],expiresAt:_,timestamp:g,table:u,onCommit:h,user:R,nodeName:E});else{let v=f.map((F,q)=>({type:DO(o),value:F,expiresAt:_,id:d?.[q],table:u}));for(;l;)v.push({type:DO(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;T.send({type:"transaction",writes:v,table:u,timestamp:g,onCommit:h,user:R,nodeName:E})}LO.get(ose.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&lse(e.subject.split(".").slice(0,-1).join("."),fk.createNatsTableStreamName(c,u),e.headers,e.data),await S;let b=Date.now()-g;g&&lk(b,"replication-latency",e.subject,o,"ingest")}catch(o){Jr.error(o)}e.ack()}a(Sse,"messageProcessor");function DO(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(DO,"convertOperation")});var ir=w((hPe,Bk)=>{"use strict";var Nr=ae();Nr.initSync();var Tse=require("fs-extra"),Ase=require("semver"),rp=require("path"),{monotonicFactory:Rse}=require("ulidx"),Rk=Rse(),yse=require("util"),yk=require("child_process"),bse=yse.promisify(yk.exec),Ose=yk.spawn,Mr=Tt(),$e=(H(),C(G)),{packageJson:Nse,PACKAGE_ROOT:wse}=st(),mg=ie(),oi=z(),Eg=Eo(),Ise=lg(),ep=yt(),{broadcast:Cse,onMessageByType:Pse,getWorkerIndex:Dse}=et(),{isMainThread:bk}=require("worker_threads"),{Encoder:Lse,decode:kO}=require("msgpackr"),Ok=new Lse,{isEmpty:ll}=mg,Nk=An(),uPe=48*36e11;bk&&Pse($e.ITC_EVENT_TYPES.RESTART,()=>{Qr=void 0,cl=void 0});var{connect:Mse,StorageType:vse,RetentionPolicy:Use,AckPolicy:FO,DeliverPolicy:GO,DiscardPolicy:xse,NatsConnection:dPe,JetStreamManager:fPe,JetStreamClient:_Pe,StringCodec:pPe,JSONCodec:Bse,createInbox:qO,headers:Hse,ErrorCode:Ak}=require("nats"),{recordAction:kse}=(ki(),C(W_)),{encodeBlobsAsBuffers:Fse}=(gs(),C(Fm)),wk=Bse(),Gse="clustering",qse=Nse.engines[Mr.NATS_SERVER_NAME],$se=rp.join(wse,"dependencies"),HO=rp.join($se,`${process.platform}-${process.arch}`,Mr.NATS_BINARY_NAME),xO,BO,tp,ol,al;Bk.exports={runCommand:Ik,checkNATSServerInstalled:Vse,createConnection:$O,getConnection:np,getJetStreamManager:sp,getJetStream:Pk,getNATSReferences:qi,getServerList:Yse,createLocalStream:VO,listStreams:Dk,deleteLocalStream:Wse,getServerConfig:Zu,listRemoteStreams:zse,viewStream:jse,viewStreamIterator:Jse,publishToStream:Qse,request:eie,reloadNATS:KO,reloadNATSHub:tie,reloadNATSLeaf:rie,extractServerName:Zse,requestErrorHandler:nie,createLocalTableStream:Uk,createTableStreams:oie,purgeTableStream:xk,purgeSchemaTableStreams:aie,getStreamInfo:cie,updateLocalStreams:uie,closeConnection:Kse,getJsmServerName:gg,addNatsMsgHeader:Lk,clearClientCache:Ck,updateRemoteConsumer:sie,createConsumer:Mk,updateConsumerIterator:iie};async function Ik(e,t=void 0){let{stdout:r,stderr:n}=await bse(e,{cwd:t});if(n)throw new Error(n.replace(`
19
+ `)},VZ="certificate.pem",KZ="privateKey.pem",YZ="caCertificate.pem",WZ="natsCertificate.pem",zZ="natsCaCertificate.pem",At={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},jZ={tls_certificate:At.SERVER,tls_certificateAuthority:At.CA,customFunctions_tls_certificate:At.SERVER,customFunctions_tls_certificateAuthority:At.CA,operationsApi_tls_certificate:At["OPERATIONS-API"],operationsApi_tls_certificateAuthority:At["OPERATIONS-CA"]},JZ={[At.SERVER]:2,[At.DEFAULT]:1},QZ={[At["OPERATIONS-API"]]:3,[At.SERVER]:2,[At.DEFAULT]:1},XZ={[At["OPERATIONS-API"]]:3,[At.SERVER]:2,[At.DEFAULT]:1},ZZ={[At["OPERATIONS-CA"]]:3,[At.CA]:2,[At["DEFAULT-CA"]]:1},e8={[At["OPERATIONS-CA"]]:3,[At.CA]:2,[At["DEFAULT-CA"]]:1},t8={[At.CA]:2,[At["DEFAULT-CA"]]:1};Object.assign(NU,{CERTIFICATE_PEM_NAME:VZ,PRIVATEKEY_PEM_NAME:KZ,CA_PEM_NAME:YZ,CERT_NAME:At,CERT_CONFIG_NAME_MAP:jZ,CERT_PREFERENCE_APP:JZ,CERT_PREFERENCE_OPS:QZ,CERT_PREFERENCE_REP:XZ,CA_CERT_PREFERENCE_REP:ZZ,CA_CERT_PREFERENCE_OPS:e8,CA_CERT_PREFERENCE_APP:t8,CERTIFICATE_VALUES:$Z,NATS_CERTIFICATE_PEM_NAME:WZ,NATS_CA_PEM_NAME:zZ})});var Yy=w((wNe,LU)=>{"use strict";var PU=require("fs-extra"),Re=require("joi"),r8=require("os"),{boolean:Be,string:Rt,number:tr,array:Jc}=Re.types(),{totalmem:wU}=require("os"),jc=require("path"),n8=z(),Ky=ie(),NNe=Vy(),IU=(H(),C(G)),s8=ot(),CU="log",i8="components",o8="Invalid logging.rotation.maxSize unit. Available units are G, M or K",a8="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",c8="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",l8="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",u8="rootPath config parameter is undefined",An=Re.alternatives([tr.min(0),Rt]).optional().empty(null),mE=Re.alternatives([Jc.items(Rt,{host:Rt.required(),port:An},{hostname:Rt.required(),port:An}).empty(null),Jc.items(Rt)]),vi,DU=!1;LU.exports={configValidator:d8,routesValidator:E8,route_constraints:mE};function d8(e,t=!1){if(DU=t,vi=e.rootPath,Ky.isEmpty(vi))throw u8;let r=Be.optional(),n=tr.min(0).max(1e3).empty(null).default(m8),s=Rt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(S_),i=Rt.optional().empty(null),o=Rt.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=Re.string().empty(null).default(S_),l=Re.custom(_8).empty(null).default(S_),u=e.clustering?.enabled,f=Re.object({certificate:i,certificateAuthority:i,privateKey:i}),d;return u===!0?d=Re.object({enabled:r,hubServer:Re.object({cluster:Re.object({name:Re.required().empty(null),network:Re.object({port:An,routes:mE}).required()}).required(),leafNodes:Re.object({network:Re.object({port:An}).required()}).required(),network:Re.object({port:An}).required()}).required(),leafServer:Re.object({network:Re.object({port:An,routes:mE}).required(),streams:Re.object({maxAge:tr.min(120).allow(null).optional(),maxBytes:tr.min(1).allow(null).optional(),maxMsgs:tr.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:Re.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:Be.optional(),databaseLevel:Be.optional(),tls:Re.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:Be.required(),verify:Be.optional()}),user:Rt.optional().empty(null)}).optional():d=Re.object({enabled:r,tls:Re.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:Be.optional()})}).optional(),Re.object({authentication:Re.alternatives(Re.object({authorizeLocal:Be,cacheTTL:tr.required(),enableSessions:Be,hashFunction:Rt.valid("md5","sha256","argon2id").optional().empty(null)}),Be).optional(),analytics:Re.object({aggregatePeriod:tr}),replication:Re.object({hostname:Re.alternatives(Rt,tr).optional().empty(null),url:Rt.optional().empty(null),port:An,securePort:An,routes:Jc.optional().empty(null),databases:Re.alternatives(Rt,Jc),enableRootCAs:Be.optional(),copyTablesToCatchUp:Be.optional()}).optional(),componentsRoot:s.optional(),clustering:d,localStudio:Re.object({enabled:r}).required(),logging:Re.object({auditAuthEvents:Re.object({logFailed:Be,logSuccessful:Be}),file:Be.required(),level:Re.valid("notify","fatal","error","warn","info","debug","trace"),rotation:Re.object({enabled:Be.optional(),compress:Be.optional(),interval:Rt.custom(h8).optional().empty(null),maxSize:Rt.custom(p8).optional().empty(null),path:Rt.optional().empty(null).default(S_)}).required(),root:s,stdStreams:Be.required(),auditLog:Be.required()}).required(),operationsApi:Re.object({network:Re.object({cors:Be.optional(),corsAccessList:Jc.optional(),headersTimeout:tr.min(1).optional(),keepAliveTimeout:tr.min(1).optional(),port:An,domainSocket:Re.optional().empty("hdb/operations-server").default(S_),securePort:An,timeout:tr.min(1).optional()}).optional(),tls:Re.alternatives([Re.array().items(f),f])}).required(),rootPath:Rt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:Re.object({network:Re.object({port:An,securePort:An,mtls:Re.alternatives([Be.optional(),Re.object({user:Rt.optional(),certificateAuthority:i,required:Be.optional()})])}).required(),webSocket:Be.optional(),requireAuthentication:Be.optional()}),http:Re.object({compressionThreshold:tr.optional(),cors:Be.optional(),corsAccessList:Jc.optional(),headersTimeout:tr.min(1).optional(),port:An,securePort:An,maxHeaderSize:tr.optional(),mtls:Re.alternatives([Be.optional(),Re.object({user:Rt.optional(),certificateAuthority:i,required:Be.optional()})]),threadRange:Re.alternatives([Jc.optional(),Rt.optional()])}).required(),threads:Re.alternatives(n.optional(),Re.object({count:n.optional(),debug:Re.alternatives(Be.optional(),Re.object({startingPort:tr.min(1).optional(),host:Rt.optional(),waitForDebugger:Be.optional()})),maxHeapMemory:tr.min(0).optional()})),storage:Re.object({writeAsync:Be.required(),overlappingSync:Be.optional(),caching:Be.optional(),compression:Re.alternatives([Be.optional(),Re.object({dictionary:Rt.optional(),threshold:tr.optional()})]),compactOnStart:Be.optional(),compactOnStartKeepBackup:Be.optional(),noReadAhead:Be.optional(),path:l,prefetchWrites:Be.optional(),maxFreeSpaceToLoad:tr.optional(),maxFreeSpaceToRetain:tr.optional()}).required(),ignoreScripts:Be.optional(),tls:Re.alternatives([Re.array().items(f),f])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(d8,"configValidator");function f8(e){return DU||PU.existsSync(e)?null:`Specified path ${e} does not exist.`}a(f8,"doesPathExist");function _8(e,t){Re.assert(e,Rt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=f8(e);if(r)return t.message(r)}a(_8,"validatePath");function p8(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(o8);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(c8):e}a(p8,"validateRotationMaxSize");function h8(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(a8);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(l8):e}a(h8,"validateRotationInterval");function m8(e,t){let r=t.state.path.join("."),n=r8.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||wU();return i=Math.round(Math.min(i,wU())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),n8.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(m8,"setDefaultThreads");function S_(e,t){let r=t.state.path.join(".");if(!Ky.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(Ky.isEmpty(vi))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return jc.join(vi,i8);case"logging.root":return jc.join(vi,CU);case"clustering.leafServer.streams.path":return jc.join(vi,"clustering","leaf");case"storage.path":let n=jc.join(vi,IU.LEGACY_DATABASES_DIR_NAME);return PU.existsSync(n)?n:jc.join(vi,IU.DATABASES_DIR_NAME);case"logging.rotation.path":return jc.join(vi,CU);case"operationsApi.network.domainSocket":return r==null?null:jc.join(vi,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(S_,"setDefaultRoot");function E8(e){let t=Re.object({routes:mE});return s8.validateBySchema({routes:e},t)}a(E8,"routesValidator")});var yt=w($U=>{"use strict";var Rs=(H(),C(G)),Sr=ie(),rr=z(),{configValidator:g8,routesValidator:MU}=Yy(),zr=require("fs-extra"),UU=require("yaml"),Yn=require("path"),S8=require("is-number"),xU=require("properties-reader"),T8=require("lodash"),{handleHDBError:A8}=pe(),{HTTP_STATUS_CODES:R8,HDB_ERROR_MSGS:Du}=xn(),{server:y8}=(Vr(),C(Au)),{PACKAGE_ROOT:BU}=it(),{DATABASES_PARAM_CONFIG:T_,CONFIG_PARAMS:Kn,CONFIG_PARAM_MAP:ei}=Rs,b8="Unable to get config value because config is uninitialized",O8="Config successfully initialized",N8="Error backing up config file",w8="Empty parameter sent to getConfigValue",HU=Yn.join(BU,"config","yaml",Rs.HDB_DEFAULT_CONFIG_FILE),I8=Yn.join(BU,"config","yaml","defaultNatsConfig.yaml"),C8="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",vU={logging_rotation_retain:"logging.rotation.retain",logging_rotation_rotate:"logging.rotation.rotate",logging_rotation_rotateinterval:"logging.rotation.rotateInterval",logging_rotation_rotatemodule:"logging.rotation.rotateModule",logging_rotation_timezone:"logging.rotation.timezone",logging_rotation_workerinterval:"logging.rotation.workerInterval"},EE,Ct,gE;Object.assign($U,{createConfigFile:P8,getDefaultConfig:D8,getConfigValue:FU,initConfig:SE,flattenConfig:Lu,updateConfigValue:GU,updateConfigObject:M8,getConfiguration:x8,setConfiguration:B8,readConfigFile:Jy,getClusteringRoutes:H8,initOldConfig:qU,getConfigFromFile:k8,getConfigFilePath:Qc,addConfig:F8,deleteConfigFromFile:G8,getConfigObj:q8,resolvePath:Wy,getFlatConfigObj:$8});function Wy(e){if(e?.startsWith("~/"))return Yn.join(Sr.getHomeDir(),e.slice(1));let t=ae();return Yn.resolve(t.getHdbBasePath(),e)}a(Wy,"resolvePath");function P8(e,t=!1){let r=Na(HU);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=UU.parseDocument(zr.readFileSync(I8,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}EE=Lu(r.toJSON());let n;for(let c in e){let l=ei[c.toLowerCase()];if(l===Kn.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(u=>({[u]:e[c][u]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let u=l.split("_"),f=zy(l,e[c]);l==="rootPath"&&f?.endsWith("/")&&(f=f.slice(0,-1));try{r.setIn([...u],f)}catch(d){rr.error(d)}}}n&&kU(r,n),jy(r,t);let s=r.toJSON();Ct=Lu(s);let i=r.getIn(["rootPath"]),o=Yn.join(i,Rs.HDB_CONFIG_FILE);if(zr.createFileSync(o),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);zr.writeFileSync(o,String(r)),rr.trace(`Config file written to ${o}`)}a(P8,"createConfigFile");function kU(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!Sr.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(T_.TABLES))for(let i in n[s][T_.TABLES])for(let o in n[s][T_.TABLES][i]){let c=n[s][T_.TABLES][i][o],l=[Kn.DATABASES,s,T_.TABLES,i,o];e.hasIn(l)?e.setIn(l,c):e.addIn(l,c)}else for(let i in n[s]){let o=n[s][i],c=[Kn.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){rr.error("Error parsing schemas CLI/env config arguments",n)}}a(kU,"setSchemasConfig");function D8(e){if(EE===void 0){let r=Na(HU);EE=Lu(r.toJSON())}let t=ei[e.toLowerCase()];if(t!==void 0)return EE[t.toLowerCase()]}a(D8,"getDefaultConfig");function FU(e){if(e==null){rr.info(w8);return}if(Ct===void 0){rr.trace(b8);return}let t=ei[e.toLowerCase()];if(t!==void 0)return Ct[t.toLowerCase()]}a(FU,"getConfigValue");function Qc(e=Sr.getPropsFilePath()){let t=Sr.getEnvCliRootPath();if(t)return Wy(Yn.join(t,Rs.HDB_CONFIG_FILE));let r=xU(e);return Wy(r.get(Rs.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(Qc,"getConfigFilePath");function SE(e=!1){if(Ct===void 0||e){let t;if(!Sr.noBootFile()){t=Sr.getPropsFilePath();try{zr.accessSync(t,zr.constants.F_OK|zr.constants.R_OK)}catch(i){throw rr.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Qc(t),n;if(r.includes("config/settings.js"))try{qU(r);return}catch(i){if(i.code!==Rs.NODE_ERROR_CODES.ENOENT)throw i}try{n=Na(r)}catch(i){if(i.code===Rs.NODE_ERROR_CODES.ENOENT){rr.trace(`HarperDB config file not found at ${r}.
20
+ This can occur during early stages of install where the config file has not yet been created`);return}else throw rr.error(i),new Error(`Error reading HarperDB config file at ${r}`)}L8(n,r),jy(n);let s=n.toJSON();if(y8.config=s,Ct=Lu(s),Ct.logging_rotation_rotate)for(let i in vU)Ct[i]&&rr.error(`Config ${vU[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);rr.trace(O8)}}a(SE,"initConfig");function L8(e,t){let r=e.getIn(["rootPath"]),n=!1;if(e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Yn.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Yn.join(r,"log")),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n){if(rr.trace("Updating config file with missing config params"),e.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${e.errors}`);zr.writeFileSync(t,String(e))}}a(L8,"checkForUpdatedConfig");function jy(e,t=!1){let r=e.toJSON();if(r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads),r.http?.port&&r.http?.port===r.http?.securePort)throw Du.CONFIG_VALIDATION("http.port and http.securePort cannot be the same value");if(r.operationsApi?.network?.port&&r.operationsApi?.network?.port===r.operationsApi?.network?.securePort)throw Du.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=g8(r,t);if(n.error)throw Du.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket),r?.clustering?.enabled&&e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path)}a(jy,"validateConfig");function M8(e,t){Ct===void 0&&(Ct={});let r=ei[e.toLowerCase()];if(r===void 0){rr.trace(`Unable to update config object because config param '${e}' does not exist`);return}Ct[r.toLowerCase()]=t}a(M8,"updateConfigObject");function GU(e,t,r=void 0,n=!1,s=!1,i=!1){Ct===void 0&&SE();let o=FU(ei.hdb_root),c=Yn.join(o,Rs.HDB_CONFIG_FILE),l=Na(c),u;if(r&&Ct){let p=!1;for(let _ in r)if(r[_]!=Ct[_.toLowerCase()]){p=!0;break}if(!p){rr.trace("No changes detected in config parameters, skipping update");return}}if(r===void 0&&e.toLowerCase()===Kn.DATABASES)u=t;else if(r===void 0){let p;if(i)p=e;else if(p=ei[e.toLowerCase()],p===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let _=p.split("_"),h=zy(p,t);l.setIn([..._],h)}else for(let p in r){let _=ei[p.toLowerCase()];if(_===Kn.HTTP_SECUREPORT&&r[p]===Ct[Kn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),_===Kn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[p]===Ct[Kn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),_===Kn.DATABASES){u=r[p];continue}if(_?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!_&&(p.endsWith("_package")||p.endsWith("_port"))&&(_=p),_!==void 0){let h=_.split("_"),S=Rs.LEGACY_CONFIG_PARAMS[p.toUpperCase()];S&&S.startsWith("customFunctions")&&l.hasIn(S.split("_"))&&(_=S,h=S.split("_"));let g=zy(_,r[p]);_==="rootPath"&&g?.endsWith("/")&&(g=g.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],g)}catch(R){rr.error(R)}}}u&&kU(l,u),jy(l);let f=l.getIn(["rootPath"]),d=Yn.join(f,Rs.HDB_CONFIG_FILE);if(n===!0&&v8(c,f),l.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${l.errors}`);zr.writeFileSync(d,String(l)),s&&(Ct=Lu(l.toJSON())),rr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(GU,"updateConfigValue");function v8(e,t){try{let r=Yn.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${Rs.HDB_CONFIG_FILE}.bak`);zr.copySync(e,r),rr.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){rr.error(N8),rr.error(r)}}a(v8,"backupConfigFile");var U8=["databases"];function Lu(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network={...e.http,...e.operationsApi.network}),e?.operationsApi&&(e.operationsApi.tls={...e.tls,...e.operationsApi.tls}),gE=e,r(e);function r(n){let s={};for(let i in n)if(n.hasOwnProperty(i)){if(typeof n[i]=="object"&&n[i]!==null&&!Array.isArray(n[i])&&!U8.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!Kn[l.toUpperCase()]&&ei[l]&&(s[ei[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Lu,"flattenConfig");function zy(e,t){if(e===Kn.CLUSTERING_NODENAME||e===Kn.CLUSTERING_USER){if(t==null)return t;if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if(S8(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Sr.isObject(t)||t===null)return t;if(typeof t=="string"&&t.toLowerCase()==="true")return!0;if(typeof t=="string"&&t.toLowerCase()==="false")return!1}if(t===void 0||t.toLowerCase()==="undefined")return null;if(typeof t=="string"&&(t.startsWith("{")&&t.endsWith("}")||t.startsWith("[")&&t.endsWith("]")))try{return JSON.parse(t)}catch{}return Sr.autoCast(t)}a(zy,"castConfigValue");function x8(){let e=Sr.getPropsFilePath(),t=Qc(e);return Na(t).toJSON()}a(x8,"getConfiguration");async function B8(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return GU(void 0,void 0,s,!0),C8}catch(i){throw typeof i=="string"||i instanceof String?A8(i,i,R8.BAD_REQUEST,void 0,void 0,!0):i}}a(B8,"setConfiguration");function Jy(){let e=Sr.getPropsFilePath();try{zr.accessSync(e,zr.constants.F_OK|zr.constants.R_OK)}catch(n){if(!Sr.noBootFile())throw rr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Qc(e);return Na(t).toJSON()}a(Jy,"readConfigFile");function Na(e){return UU.parseDocument(zr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Na,"parseYamlDoc");function H8(){let e=Jy(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Sr.isEmptyOrZeroLength(t)?[]:t;let r=MU(t);if(r)throw Du.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Sr.isEmptyOrZeroLength(n)?[]:n;let s=MU(n);if(s)throw Du.CONFIG_VALIDATION(s.message);if(!Sr.isEmptyOrZeroLength(n)&&!Sr.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Sr.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw Du.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(H8,"getClusteringRoutes");function qU(e){let t=xU(e);Ct={};for(let r in ei){let n=t.get(r.toUpperCase());if(Sr.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=ei[r].toLowerCase();s===Kn.LOGGING_ROOT?Ct[s]=Yn.dirname(n):Ct[s]=n}return Ct}a(qU,"initOldConfig");function k8(e){let t=Jy();return T8.get(t,e.replaceAll("_","."))}a(k8,"getConfigFromFile");async function F8(e,t){let r=Na(Qc());if(r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);await zr.writeFile(Qc(),String(r))}a(F8,"addConfig");function G8(e){let t=Qc(Sr.getPropsFilePath()),r=Na(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Yn.join(n,Rs.HDB_CONFIG_FILE);zr.writeFileSync(s,String(r))}a(G8,"deleteConfigFromFile");function q8(){return gE||(SE(),gE)}a(q8,"getConfigObj");function $8(){return Ct||SE(),Ct}a($8,"getFlatConfigObj")});var Rn=w((DNe,Nr)=>{"use strict";var YU="username is required",WU="nothing to update, must supply active, role or password to update",zU="password cannot be an empty string",jU="If role is specified, it cannot be empty.",JU="active must be true or false";Nr.exports.addUser=X8;Nr.exports.alterUser=Z8;Nr.exports.dropUser=t5;Nr.exports.getSuperUser=o5;Nr.exports.userInfo=r5;Nr.exports.listUsers=AE;Nr.exports.listUsersExternal=n5;Nr.exports.setUsersWithRolesCache=Xc;Nr.exports.findAndValidateUser=ib;Nr.exports.getClusterUser=a5;Nr.exports.getUsersWithRolesCache=i5;Nr.exports.USERNAME_REQUIRED=YU;Nr.exports.ALTERUSER_NOTHING_TO_UPDATE=WU;Nr.exports.EMPTY_PASSWORD=zU;Nr.exports.EMPTY_ROLE=jU;Nr.exports.ACTIVE_BOOLEAN=JU;var QU=yn(),V8=zc(),A_=(hE(),C(pE)),XU=yU(),R_=Yr(),tb=To(),Ui=ie(),ZU=require("validate.js"),rb=z(),{promisify:K8}=require("util"),nb=Eo(),Xy=(H(),C(G)),VU=Tt(),Y8=yt(),W8=ae(),z8=po(),{hdb_errors:j8,ClientError:ti}=pe(),{HTTP_STATUS_CODES:So,AUTHENTICATION_ERROR_MSGS:Qy,HDB_ERROR_MSGS:Mu}=j8,{UserEventMsg:sb}=ri(),Zy=require("lodash"),{server:TE}=(Vr(),C(Au)),J8=z();TE.getUser=(e,t)=>ib(e,t,t!=null);TE.authenticateUser=(e,t)=>ib(e,t);var e0={username:!0,active:!0,role:!0,password:!0},KU=new Map,Q8=K8(V8.delete),eb=W8.get(Xy.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??A_.HASH_FUNCTION.SHA256,xi;async function X8(e){let t=ZU.cleanAttributes(e,e0),r=XU.addUserValidation(t);if(r)throw new ti(r.message);let n=await R_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]});if(!n||n.length<1)throw new ti(Mu.ROLE_NAME_NOT_FOUND(t.role),So.NOT_FOUND);if(n.length>1)throw new ti(Mu.DUP_ROLES_FOUND(t.role),So.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=nb.encrypt(t.password)),t.password=await A_.hash(t.password,eb),t.hash_function=eb,t.role=n[0].id;let s=await QU.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(rb.debug(s),await Xc(),s.skipped_hashes.length===1)throw new ti(Mu.USER_ALREADY_EXISTS(t.username),So.CONFLICT);return tb.signalUserChange(new sb(process.pid)),`${t.username} successfully added`}a(X8,"addUser");async function Z8(e){let t=ZU.cleanAttributes(e,e0);if(Ui.isEmptyOrZeroLength(t.username))throw new Error(YU);if(Ui.isEmptyOrZeroLength(t.password)&&Ui.isEmptyOrZeroLength(t.role)&&Ui.isEmptyOrZeroLength(t.active))throw new Error(WU);if(!Ui.isEmpty(t.password)&&Ui.isEmptyOrZeroLength(t.password.trim()))throw new Error(zU);if(!Ui.isEmpty(t.active)&&!Ui.isBoolean(t.active))throw new Error(JU);if(!Ui.isEmpty(t.password)&&!Ui.isEmptyOrZeroLength(t.password.trim())&&(e5(t.username)&&(t.hash=nb.encrypt(t.password)),t.password=await A_.hash(t.password,eb)),t.role==="")throw new Error(jU);if(t.role){let n=await R_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]});if(!n||n.length===0)throw new ti(Mu.ALTER_USER_ROLE_NOT_FOUND(t.role),So.NOT_FOUND);if(n.length>1)throw new ti(Mu.DUP_ROLES_FOUND(t.role),So.CONFLICT);t.role=n[0].id}let r=await QU.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await Xc(),tb.signalUserChange(new sb(process.pid)),r}a(Z8,"alterUser");function e5(e){let t=!1,r=xi.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(e5,"isClusterUser");async function t5(e){let t=XU.dropUserValidation(e);if(t)throw new ti(t.message);if(xi.get(e.username)===void 0)throw new ti(Mu.USER_NOT_EXIST(e.username),So.NOT_FOUND);let r=await Q8({table:"hdb_user",schema:"system",hash_values:[e.username]});return rb.debug(r),await Xc(),tb.signalUserChange(new sb(process.pid)),`${e.username} successfully deleted`}a(t5,"dropUser");async function r5(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=Zy.cloneDeep(e.hdb_user);let r=await R_.searchByHash({schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]});return t.role=r[0],delete t.password,delete t.refresh_token,delete t.hash,delete t.hash_function,t}a(r5,"userInfo");async function n5(){let e=await AE();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}a(n5,"listUsersExternal");async function AE(){let e=await R_.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=Zy.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await R_.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=Zy.cloneDeep(s),s.role=t[s.role],s5(s.role),n.set(s.username,s);return n}a(AE,"listUsers");function s5(e){if(!e){rb.error("invalid user role found.");return}e.permission.system||(e.permission.system={}),e.permission.system.tables||(e.permission.system.tables={});for(let t of Object.keys(z8)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}a(s5,"appendSystemTablesToRole");async function Xc(e=void 0){e?xi=e:xi=await AE()}a(Xc,"setUsersWithRolesCache");async function i5(){return xi||await Xc(),xi}a(i5,"getUsersWithRolesCache");async function ib(e,t,r=!0){xi||await Xc();let n=xi.get(e);if(!n){if(!r)return{username:e};throw new ti(Qy.GENERIC_AUTH_FAIL,So.UNAUTHORIZED)}if(n&&!n.active)throw new ti(Qy.USER_INACTIVE,So.UNAUTHORIZED);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(KU.get(t)===n.password)return s;{let i=A_.validate(n.password,t,n.hash_function||A_.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)KU.set(t,n.password);else throw new ti(Qy.GENERIC_AUTH_FAIL,So.UNAUTHORIZED)}}return s}a(ib,"findAndValidateUser");async function o5(){xi||await Xc();for(let[,e]of xi)if(e.role.role==="super_user")return e}a(o5,"getSuperUser");async function a5(){let e=await AE(),t=Y8.getConfigFromFile(Xy.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==Xy.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=nb.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+VU.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+VU.SERVER_SUFFIX.ADMIN,r}a(a5,"getClusterUser");var t0=[];TE.invalidateUser=function(e){for(let t of t0)try{t(e)}catch(r){J8.error("Error invalidating user",r)}};TE.onInvalidatedUser=function(e){t0.push(e)}});var b_=w((UNe,i0)=>{"use strict";var Zc=z(),Wn=(H(),C(G)),c5=gv(),MNe=As(),vNe=go(),l5=Rn(),{validateEvent:r0}=ri(),y_=Vn(),u5=require("process"),{resetDatabases:d5}=(De(),C(nt)),f5={[Wn.ITC_EVENT_TYPES.SCHEMA]:_5,[Wn.ITC_EVENT_TYPES.USER]:s0};async function _5(e){let t=r0(e);if(t){Zc.error(t);return}Zc.trace("ITC schemaHandler received schema event:",e),await c5(e.message),await p5(e.message)}a(_5,"schemaHandler");async function p5(e){try{y_.resetReadTxn(Wn.SYSTEM_SCHEMA_NAME,Wn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),y_.resetReadTxn(Wn.SYSTEM_SCHEMA_NAME,Wn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),y_.resetReadTxn(Wn.SYSTEM_SCHEMA_NAME,Wn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=d5();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){Zc.error(t)}}a(p5,"syncSchemaMetadata");var n0=[];async function s0(e){try{try{y_.resetReadTxn(Wn.SYSTEM_SCHEMA_NAME,Wn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),y_.resetReadTxn(Wn.SYSTEM_SCHEMA_NAME,Wn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){Zc.warn(r)}let t=r0(e);if(t){Zc.error(t);return}Zc.trace(`ITC userHandler ${Wn.HDB_ITC_CLIENT_PREFIX}${u5.pid} received user event:`,e),await l5.setUsersWithRolesCache();for(let r of n0)r()}catch(t){Zc.error(t)}}a(s0,"userHandler");s0.addListener=function(e){n0.push(e)};i0.exports=f5});var ri=w((GNe,a0)=>{"use strict";var BNe=z(),ob=ie(),h5=(H(),C(G)),{ITC_ERRORS:O_}=xn(),{parentPort:HNe,threadId:m5,isMainThread:E5,workerData:kNe}=require("worker_threads"),{onMessageFromWorkers:g5,broadcast:FNe,broadcastWithAcknowledgement:S5}=rt();a0.exports={sendItcEvent:T5,validateEvent:o0,SchemaEventMsg:A5,UserEventMsg:R5};var RE;g5(async(e,t)=>{RE=RE||b_(),o0(e),RE[e.type]&&await RE[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function T5(e){return!E5&&e.message&&(e.message.originator=m5),S5(e)}a(T5,"sendItcEvent");function o0(e){if(typeof e!="object")return O_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||ob.isEmpty(e.type))return O_.MISSING_TYPE;if(!e.hasOwnProperty("message")||ob.isEmpty(e.message))return O_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||ob.isEmpty(e.message.originator))return O_.MISSING_ORIGIN;if(h5.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return O_.INVALID_EVENT(e.type)}a(o0,"validateEvent");function A5(e,t,r,n=void 0,s=void 0){this.originator=e,this.operation=t,this.schema=r,this.table=n,this.attribute=s}a(A5,"SchemaEventMsg");function R5(e){this.originator=e}a(R5,"UserEventMsg")});var To=w((VNe,d0)=>{"use strict";var c0=(H(),C(G)),$Ne=ie(),yE=z(),l0=hv(),vu,{sendItcEvent:u0}=ri();function y5(e){try{yE.info("signalSchemaChange called with message:",e),vu=vu||b_();let t=new l0(c0.ITC_EVENT_TYPES.SCHEMA,e);return vu.schema(t),u0(t)}catch(t){yE.error(t)}}a(y5,"signalSchemaChange");function b5(e){try{yE.trace("signalUserChange called with message:",e),vu=vu||b_();let t=new l0(c0.ITC_EVENT_TYPES.USER,e);return vu.user(t),u0(t)}catch(t){yE.error(t)}}a(b5,"signalUserChange");d0.exports={signalSchemaChange:y5,signalUserChange:b5}});var bE=w((YNe,_0)=>{"use strict";var f0=ie(),O5=(H(),C(G)),N5=z(),w5=iE(),I5=sE(),C5=To(),{SchemaEventMsg:P5}=ri(),D5="already exists in";_0.exports=L5;async function L5(e,t,r){if(f0.isEmptyOrZeroLength(r))return r;let n=[];f0.isEmptyOrZeroLength(t.attributes)||t.attributes.forEach(i=>{n.push(i.attribute)});let s=r.filter(i=>n.indexOf(i)<0);return s.length===0||await Promise.all(s.map(async i=>{await M5(e,t.schema,t.name,i)})),s}a(L5,"lmdbCheckForNewAttributes");async function M5(e,t,r,n){let s=new I5(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await v5(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(D5))N5.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(M5,"createNewAttribute");async function v5(e){let t;return t=await w5(e),C5.signalSchemaChange(new P5(process.pid,O5.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(v5,"createAttribute")});var Uu=w((zNe,p0)=>{"use strict";var ab=class{static{a(this,"LMDBTransactionObject")}constructor(t,r,n,s,i=void 0){this.operation=t,this.user_name=r,this.timestamp=n,this.hash_values=s,this.origin=i}};p0.exports=ab});var m0=w((JNe,h0)=>{"use strict";var U5=Uu(),x5=(H(),C(G)).OPERATIONS_ENUM,cb=class extends U5{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(x5.INSERT,r,n,s,i),this.records=t}};h0.exports=cb});var g0=w((XNe,E0)=>{"use strict";var B5=Uu(),H5=(H(),C(G)).OPERATIONS_ENUM,lb=class extends B5{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(H5.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};E0.exports=lb});var T0=w((ewe,S0)=>{"use strict";var k5=Uu(),F5=(H(),C(G)).OPERATIONS_ENUM,ub=class extends k5{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(F5.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};S0.exports=ub});var R0=w((rwe,A0)=>{"use strict";var G5=Uu(),q5=(H(),C(G)).OPERATIONS_ENUM,db=class extends G5{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(q5.DELETE,n,s,t,i),this.original_records=r}};A0.exports=db});var N_=w((iwe,N0)=>{"use strict";var swe=require("path"),y0=_t(),$5=m0(),V5=g0(),K5=T0(),Y5=R0(),xu=xt(),b0=ie(),{CONFIG_PARAMS:W5}=(H(),C(G)),O0=ae();O0.initSync();var OE=(H(),C(G)).OPERATIONS_ENUM,{getTransactionAuditStorePath:z5}=gt();N0.exports=j5;async function j5(e,t){if(O0.get(W5.LOGGING_AUDITLOG)===!1)return;let r=z5(e.schema,e.table),n=await y0.openEnvironment(r,e.table,!0),s=J5(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){y0.initializeDBIs(n,xu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,xu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[xu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[xu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),b0.isEmpty(s.user_name)||n.dbis[xu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[xu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(j5,"writeTransaction");function J5(e,t){let r=b0.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===OE.INSERT)return new $5(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===OE.UPDATE)return new V5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===OE.UPSERT)return new K5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===OE.DELETE)return new Y5(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(J5,"createTransactionObject")});var fb=w((cwe,w0)=>{"use strict";var Q5=l_(),awe=Uf(),w_=(H(),C(G)),X5=xf(),Z5=qc().insertRecords,e9=_t(),t9=z(),r9=bE(),{getSchemaPath:n9}=gt(),s9=N_();w0.exports=i9;async function i9(e){try{let{schema_table:t,attributes:r}=Q5(e);X5(e,r,t.hash_attribute),e.schema!==w_.SYSTEM_SCHEMA_NAME&&(r.includes(w_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(w_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(w_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(w_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await r9(e.hdb_auth_header,t,r),s=n9(e.schema,e.table),i=await e9.openEnvironment(s,e.table),o=await Z5(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await s9(e,o)}catch(c){t9.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(i9,"lmdbCreateRecords")});var P0=w((uwe,C0)=>{"use strict";var I0=(H(),C(G)),o9=fb(),a9=Uf(),c9=require("fs-extra"),{getSchemaPath:l9}=gt();C0.exports=u9;async function u9(e){let t=[{name:e.schema,createddate:Date.now()}],r=new a9(I0.SYSTEM_SCHEMA_NAME,I0.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await o9(r),await c9.mkdirp(l9(e.schema))}a(u9,"lmdbCreateSchema")});var L0=w((fwe,D0)=>{"use strict";var _b=class{static{a(this,"DeleteRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.deleted=t,this.skipped=r,this.txn_time=n,this.original_records=s}};D0.exports=_b});var x0=w((Ewe,U0)=>{"use strict";var M0=_t(),pb=_n(),hb=xn().LMDB_ERRORS_ENUM,d9=xt(),v0=z(),pwe=ie(),f9=require("lmdb"),_9=L0(),p9=(H(),C(G)),{OVERFLOW_MARKER:hwe,MAX_SEARCH_KEY_LENGTH:mwe}=d9,h9=p9.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function m9(e,t,r,n){if(pb.validateEnv(e),t===void 0)throw new Error(hb.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(hb.IDS_REQUIRED):new Error(hb.IDS_MUST_BE_ITERABLE);try{let s=M0.listDBIs(e);M0.initializeDBIs(e,t,s);let i=new _9,o,c=[],l=[];for(let p=0,_=r.length;p<_;p++)try{o=r[p];let h=e.dbis[t].get(o);if(!h||n&&h[h9]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,f9.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let g=0;g<s.length;g++){let R=s[g];if(!h.hasOwnProperty(R)||R===t)continue;let E=e.dbis[R],T=h[R];if(T!=null)try{let b=pb.getIndexedValues(T);if(b)for(let v=0,F=b.length;v<F;v++)E.remove(b[v],o)}catch{v0.warn(`cannot delete from attribute: ${R}, ${T}:${o}`)}}});c.push(S),l.push(o),i.original_records.push(h)}catch(h){v0.warn(h),i.skipped.push(o)}let u=[],f=await Promise.all(c);for(let p=0,_=f.length;p<_;p++)f[p]===!0?i.deleted.push(l[p]):(i.skipped.push(l[p]),u.push(p));let d=0;for(let p=0;p<u.length;p++){let _=u[p];i.original_records.splice(_-d,1),d++}return i.txn_time=pb.getNextMonotonicTime(),i}catch(s){throw s}}a(m9,"deleteRecords");U0.exports={deleteRecords:m9}});var I_=w((Swe,H0)=>{"use strict";var Bu=ie(),E9=x0(),g9=_t(),{getSchemaPath:S9}=gt(),T9=N_(),A9=z();H0.exports=R9;async function R9(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Bu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Bu.isEmptyOrZeroLength(e.hash_values)&&!Bu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Bu.isEmpty(l)||e.hash_values.push(l)}}if(Bu.isEmptyOrZeroLength(e.hash_values))return B0([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Bu.isEmptyOrZeroLength(e.records)){e.records=[];for(let c=0;c<e.hash_values.length;c++)e.records[c]={[n]:e.hash_values[c]}}let s=S9(e.schema,e.table),i=await g9.openEnvironment(s,e.table),o=await E9.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await T9(e,o)}catch(c){A9.error(`unable to write transaction due to ${c.message}`)}return B0(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(R9,"lmdbDeleteRecords");function B0(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}a(B0,"createDeleteResponse")});var Eb=w((Rwe,k0)=>{"use strict";var y9=(H(),C(G)),Awe=_n();function mb(e,t){let r=Object.create(null);if(t.length===1&&y9.SEARCH_WILDCARDS.indexOf(t[0])>=0)Object.assign(r,e);else for(let n=0;n<t.length;n++){let s=t[n],i=e[s];r[s]=i===void 0?null:i}return r}a(mb,"parseRow");function b9(e,t,r,n){let s=mb(r,e);n.push(s)}a(b9,"searchAll");function O9(e,t,r,n){let s=mb(r,e);n[t]=s}a(O9,"searchAllToMap");function N9(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(N9,"iterateDBI");function el(e,t,r,n,s){let i=Object.create(null);i[s]=e;let o;n===s?o=e:(o=t,n!==void 0&&(i[n]=o)),r[0].push(o),r[1].push(i)}a(el,"pushResults");function w9(e,t,r,n,s,i){t.toString().endsWith(e)&&el(t,r,n,s,i)}a(w9,"endsWith");function I9(e,t,r,n,s,i){t.toString().includes(e)&&el(t,r,n,s,i)}a(I9,"contains");function C9(e,t,r,n,s,i){t>e&&el(t,r,n,s,i)}a(C9,"greaterThanCompare");function P9(e,t,r,n,s,i){t>=e&&el(t,r,n,s,i)}a(P9,"greaterThanEqualCompare");function D9(e,t,r,n,s,i){t<e&&el(t,r,n,s,i)}a(D9,"lessThanCompare");function L9(e,t,r,n,s,i){t<=e&&el(t,r,n,s,i)}a(L9,"lessThanEqualCompare");k0.exports={parseRow:mb,searchAll:b9,searchAllToMap:O9,iterateDBI:N9,endsWith:w9,contains:I9,greaterThanCompare:C9,greaterThanEqualCompare:P9,lessThanCompare:D9,lessThanEqualCompare:L9,pushResults:el}});var Hu=w((wwe,Y0)=>{"use strict";var wa=_t(),bwe=z(),zn=_n(),NE=xt(),zt=xn().LMDB_ERRORS_ENUM,Owe=ie(),M9=(H(),C(G)),wE=Eb(),{parseRow:v9}=wE,Nwe=require("lmdb"),{OVERFLOW_MARKER:F0,MAX_SEARCH_KEY_LENGTH:U9}=NE;function G0(e,t,r,n=!1,s=void 0,i=void 0){return tl(e,t,r,(o,c)=>c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}))}a(G0,"iterateFullIndex");function C_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return tl(e,t,r,(f,d,p,_)=>{let E={transaction:f,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return _===r?(E.values=!1,d.getRange(E).map(T=>({value:T}))):d.getRange(E)})}a(C_,"iterateRangeBetween");function tl(e,t,r,n){let s=e.database||e,i=wa.openDBI(s,r);i[NE.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&wa.openDBI(s,t);let o;e.database?o=e:(o=e.useReadTransaction(),o.database=e);let c=n(o,i,s,t);return c.transaction=o,e.database||(c.onDone=()=>{o.done()}),c}a(tl,"setupTransaction");function q0(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(F0)){if(!s)if(r)s=wa.openDBI(e,r);else{let l=wa.listDBIs(e);for(let u=0,f=l.length;u<f&&(s=wa.openDBI(e,l[u]),!s[NE.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(q0,"getOverflowCheck");function x9(e,t,r,n=!1,s=void 0,i=void 0){if(zn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return tl(e,t,t,(o,c,l)=>(IE(r),r=P_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>v9(u.value,r))))}a(x9,"searchAll");function B9(e,t,r,n=!1,s=void 0,i=void 0){if(zn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);IE(r),r=P_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of G0(e,t,t,n,s,i))o.set(c,wE.parseRow(l,r));return o}a(B9,"searchAllToMap");function H9(e,t,r=!1,n=void 0,s=void 0){if(zn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=G0(e,void 0,t,r,n,s),c=o.transaction,l=q0(c.database,c,void 0,t);for(let{key:u,value:f}of o){let d=l(u,f);i[d]===void 0&&(i[d]=[]),i[d].push(f)}return i}a(H9,"iterateDBI");function k9(e,t){if(zn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return wa.statDBI(e,t).entryCount}a(k9,"countAll");function F9(e,t,r,n,s=!1,i=void 0,o=void 0){return Ia(e,r,n),tl(e,t,r,(c,l,u,f)=>(n=zn.convertKeyValueToWrite(n),f===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(d=>({key:n,value:d}))))}a(F9,"equals");function G9(e,t,r){return Ia(e,t,r),wa.openDBI(e,t).getValuesCount(r)}a(G9,"count");function q9(e,t,r,n,s=!1,i=void 0,o=void 0){return Ia(e,r,n),tl(e,null,r,(c,l)=>{n=zn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let f;if(s===!0){let d;for(let p of l.getKeys({transaction:c,start:n}))if(!p.startsWith(n)){d=p;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),f=l.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(p=>{let{key:_}=p;if(_!==d){if(_.toString().startsWith(n))return p;if(u===!0)return f.DONE}}),f.filter(p=>p)}else return f=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(u===!0)return f.DONE}),u?f:f.filter(d=>d)})}a(q9,"startsWith");function $9(e,t,r,n,s=!1,i=void 0,o=void 0){return $0(e,t,r,n,s,i,o,!0)}a($9,"endsWith");function $0(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Ia(e,r,n),tl(e,null,r,(l,u,f,d)=>{let p=q0(f,l,d,r);return o=Number.isInteger(o)?o:0,u.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(_=>{let h=_.toString();return h.endsWith(F0)?u.getValues(_,{transaction:l}).map(S=>{let g=p(_,S);if(c?g.endsWith(n):g.includes(n))return{key:g,value:S}}).filter(S=>S):(c?h.endsWith(n):h.includes(n))?u[NE.DBI_DEFINITION_NAME].is_hash_attribute?{key:_,value:_}:u.getValues(_,{transaction:l}).map(S=>({key:_,value:S})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a($0,"contains");function V9(e,t,r,n,s=!1,i=void 0,o=void 0){Ia(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),C_(e,t,r,n,l,s,i,o,!0,!1)}a(V9,"greaterThan");function K9(e,t,r,n,s=!1,i=void 0,o=void 0){Ia(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),C_(e,t,r,n,l,s,i,o,!1,!1)}a(K9,"greaterThanEqual");function Y9(e,t,r,n,s=!1,i=void 0,o=void 0){Ia(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),C_(e,t,r,l,n,s,i,o,!1,!0)}a(Y9,"lessThan");function W9(e,t,r,n,s=!1,i=void 0,o=void 0){Ia(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),C_(e,t,r,l,n,s,i,o,!1,!1)}a(W9,"lessThanEqual");function z9(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(zn.validateEnv(e),r===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(zt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(zt.END_VALUE_REQUIRED);if(n=zn.convertKeyValueToWrite(n),s=zn.convertKeyValueToWrite(s),n>s)throw new Error(zt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return C_(e,t,r,n,s,i,o,c)}a(z9,"between");function j9(e,t,r,n){zn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(IE(r),r=P_(s,r),n===void 0)throw new Error(zt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=wE.parseRow(c,r)),o}a(j9,"searchByHash");function J9(e,t,r){zn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(J9,"checkHashExists");function Q9(e,t,r,n,s=[]){return K0(e,t,r,n,s),V0(e,t,r,n,s).map(i=>i[1])}a(Q9,"batchSearchByHash");function X9(e,t,r,n,s=[]){K0(e,t,r,n,s);let i=new Map;for(let[o,c]of V0(e,t,r,n,s))i.set(o,c);return i}a(X9,"batchSearchByHashToMap");function V0(e,t,r,n,s=[]){return tl(e,t,t,(i,o,c)=>{r=P_(c,r);let l=r.length<3;return n.map(u=>{let f=c.dbis[t].get(u,{transaction:i,lazy:l});if(f)return[u,wE.parseRow(f,r)];s.push(u)}).filter(u=>u)})}a(V0,"batchHashSearch");function K0(e,t,r,n,s){if(zn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(IE(r),n==null)throw new Error(zt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(zt.IDS_MUST_BE_ITERABLE)}a(K0,"initializeBatchSearchByHash");function IE(e){if(!Array.isArray(e))throw e===void 0?new Error(zt.FETCH_ATTRIBUTES_REQUIRED):new Error(zt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(IE,"validateFetchAttributes");function Ia(e,t,r){if(zn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.SEARCH_VALUE_REQUIRED);if(r?.length>U9)throw new Error(zt.SEARCH_VALUE_TOO_LARGE)}a(Ia,"validateComparisonFunctions");function P_(e,t){return t.length===1&&M9.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=wa.listDBIs(e)),t}a(P_,"setGetWholeRowAttributes");Y0.exports={searchAll:x9,searchAllToMap:B9,count:G9,countAll:k9,equals:F9,startsWith:q9,endsWith:$9,contains:$0,searchByHash:j9,setGetWholeRowAttributes:P_,batchSearchByHash:Q9,batchSearchByHashToMap:X9,checkHashExists:J9,iterateDBI:H9,greaterThan:V9,greaterThanEqual:K9,lessThan:Y9,lessThanEqual:W9,between:z9}});var ku=w((Cwe,Q0)=>{var W0=require("lodash"),z0=ot(),He=require("joi"),Z9=ie(),{hdb_schema_table:D_,checkValidTable:j0,hdb_table:J0,hdb_database:CE}=Di(),{handleHDBError:e7,hdb_errors:t7}=pe(),{getDatabases:r7}=(De(),C(nt)),{HTTP_STATUS_CODES:n7}=t7,s7=He.object({database:CE,schema:CE,table:J0,search_attribute:D_,search_value:He.any().required(),get_attributes:He.array().min(1).items(He.alternatives(D_,He.object())).optional(),desc:He.bool(),limit:He.number().integer().min(1),offset:He.number().integer().min(0)}),i7=He.object({database:CE,schema:CE,table:J0,operator:He.string().valid("and","or").default("and").lowercase(),offset:He.number().integer().min(0),limit:He.number().integer().min(1),get_attributes:He.array().min(1).items(He.alternatives(D_,He.object())).optional(),sort:He.object({attribute:He.alternatives(D_,He.array().min(1)),descending:He.bool().optional()}).optional(),conditions:He.array().min(1).items(He.alternatives(He.object({operator:He.string().valid("and","or").default("and").lowercase(),conditions:He.array()}),He.object({search_attribute:He.alternatives(D_,He.array().min(1)),search_type:He.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:He.when("search_type",{switch:[{is:"equals",then:He.any()},{is:"between",then:He.array().items(He.alternatives([He.string(),He.number()])).length(2)}],otherwise:He.alternatives(He.string(),He.number())}).required()}))).required()});Q0.exports=function(e,t){let r=null;switch(t){case"value":r=z0.validateBySchema(e,s7);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(j0("database",e.schema)),i(j0("table",e.table)),e.hash_values?Array.isArray(e.hash_values)?e.hash_values.every(o=>typeof o=="string"||typeof o=="number")||i("'hash_values' must be strings or numbers"):i("'hash_values' must be an array"):i("'hash_values' is required"),e.get_attributes?Array.isArray(e.get_attributes)?e.get_attributes.length===0?i("'get_attributes' must contain at least 1 item"):e.get_attributes.every(o=>typeof o=="string"||typeof o=="number")||i("'get_attributes' must be strings or numbers"):i("'get_attributes' must be an array"):i("'get_attributes' is required"),s&&(r=new Error(s.trim()));break;case"conditions":r=z0.validateBySchema(e,i7);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=Z9.checkGlobalSchemaTable(e.schema,e.table);if(s)return e7(new Error,s,n7.NOT_FOUND);let o=r7()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(f=>{for(let d=0,p=f.conditions.length;d<p;d++){let _=f.conditions[d];_.conditions?l(_):c.push(_.search_attribute)}},"addConditions");t==="conditions"&&l(e);let u=W0.filter(c,f=>f!=="*"&&!f.startsWith?.("$")&&f.attribute!=="*"&&!Array.isArray(f)&&!f.name&&!W0.some(o,d=>d===f||d.attribute===f||d.attribute===f.attribute));if(u&&u.length>0){let f=u.join(", ");return f=f.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${f}'`)}}return r}});var gb=w((Dwe,X0)=>{"use strict";var o7=_t(),a7=ku(),{getSchemaPath:c7}=gt();X0.exports=l7;function l7(e){let t=a7(e,"hashes");if(t)throw t;let r=c7(e.schema,e.table);return o7.openEnvironment(r,e.table)}a(l7,"initialize")});var Sb=w((Mwe,Z0)=>{"use strict";var u7=Hu(),d7=gb();Z0.exports=f7;async function f7(e){let t=await d7(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return u7.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(f7,"lmdbGetDataByHash")});var Fu=w((Uwe,ex)=>{"use strict";var Tb=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};ex.exports=Tb});var rx=w((Hwe,tx)=>{"use strict";var Bwe=Fu(),_7=Hu(),p7=gb();tx.exports=h7;async function h7(e){let t=await p7(e),r=global.hdb_schema[e.schema][e.table];return _7.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(h7,"lmdbSearchByHash")});var ni=w((Fwe,nx)=>{"use strict";var Ab=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,u=void 0,f=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=u,this.offset=f}};nx.exports=Ab});var PE=w((qwe,lx)=>{"use strict";var jr=Hu(),m7=_t(),E7=ie(),ke=xt(),rl=(H(),C(G)),g7=po(),sx=xn().LMDB_ERRORS_ENUM,{getSchemaPath:S7}=gt(),Ao=rl.SEARCH_WILDCARDS;async function T7(e,t,r){let n;e.schema===rl.SYSTEM_SCHEMA_NAME?n=g7[e.table]:n=global.hdb_schema[e.schema][e.table];let s=cx(e,n.hash_attribute,r,t);return ox(e,s,n.hash_attribute,r)}a(T7,"prepSearch");async function ox(e,t,r,n){let s=S7(e.schema,e.table),i=await m7.openEnvironment(s,e.table),o=ax(i,e,t,r),c=o.transaction||i;if([ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,ke.SEARCH_TYPES.SEARCH_ALL,ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(A7(e,r)===!1){let f=e.search_attribute;if(f===r)return n?ix(o,()=>!0):o.map(p=>({[r]:p.key}));let d=a(p=>({[r]:p.value,[f]:p.key}),"toObject");return n?ix(o,d):o.map(d)}let u=e.search_attribute===r?o.map(f=>f.key):o.map(f=>f.value);return n===!0?jr.batchSearchByHashToMap(c,r,e.get_attributes,u):jr.batchSearchByHash(c,r,e.get_attributes,u)}a(ox,"executeSearch");function ax(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case ke.SEARCH_TYPES.EQUALS:s=jr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.CONTAINS:s=jr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.ENDS_WITH:case ke.SEARCH_TYPES._ENDS_WITH:s=jr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.STARTS_WITH:case ke.SEARCH_TYPES._STARTS_WITH:s=jr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return jr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return jr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case ke.SEARCH_TYPES.SEARCH_ALL:return jr.searchAll(e,n,t.get_attributes,o,c,l);case ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return jr.searchAllToMap(e,n,t.get_attributes,o,c,l);case ke.SEARCH_TYPES.BETWEEN:s=jr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case ke.SEARCH_TYPES.GREATER_THAN:case ke.SEARCH_TYPES._GREATER_THAN:s=jr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.GREATER_THAN_EQUAL:case ke.SEARCH_TYPES._GREATER_THAN_EQUAL:s=jr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.LESS_THAN:case ke.SEARCH_TYPES._LESS_THAN:s=jr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.LESS_THAN_EQUAL:case ke.SEARCH_TYPES._LESS_THAN_EQUAL:s=jr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(ax,"searchByType");function ix(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(ix,"createMapFromIterable");function A7(e,t){if(e.get_attributes.length===1&&e.get_attributes[0]==="*")return!0;let r=[e.search_attribute];e.get_attributes.indexOf(t)>=0&&r.push(t);let n=!1;for(let s=0;s<e.get_attributes.length;s++)if(r.indexOf(e.get_attributes[s])<0){n=!0;break}return n}a(A7,"checkToFetchMore");function cx(e,t,r,n){if(E7.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),o=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),Ao.indexOf(s)>-1)return r===!0?ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP:ke.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(Ao[0])<0&&s.indexOf(Ao[1])<0)return c===!0?r===!0?ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:ke.SEARCH_TYPES.EQUALS;if(Ao.indexOf(i)>=0&&Ao.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),ke.SEARCH_TYPES.CONTAINS;if(Ao.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),ke.SEARCH_TYPES.ENDS_WITH;if(Ao.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),ke.SEARCH_TYPES.STARTS_WITH;if(s.includes(Ao[0])||s.includes(Ao[1]))return ke.SEARCH_TYPES.EQUALS;throw new Error(sx.UNKNOWN_SEARCH_TYPE)}else switch(n){case rl.VALUE_SEARCH_COMPARATORS.BETWEEN:return ke.SEARCH_TYPES.BETWEEN;case rl.VALUE_SEARCH_COMPARATORS.GREATER:return ke.SEARCH_TYPES.GREATER_THAN;case rl.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return ke.SEARCH_TYPES.GREATER_THAN_EQUAL;case rl.VALUE_SEARCH_COMPARATORS.LESS:return ke.SEARCH_TYPES.LESS_THAN;case rl.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return ke.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(sx.UNKNOWN_SEARCH_TYPE)}}a(cx,"createSearchTypeFromSearchObject");lx.exports={executeSearch:ox,createSearchTypeFromSearchObject:cx,prepSearch:T7,searchByType:ax}});var dx=w((Kwe,ux)=>{"use strict";var Vwe=ni(),R7=ku(),y7=ie(),b7=(H(),C(G)),O7=PE();ux.exports=N7;function N7(e,t){if(!y7.isEmpty(t)&&b7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=R7(e,"value");if(n)throw n;return O7.prepSearch(e,t,!0)}a(N7,"lmdbGetDataByValue")});var L_=w((zwe,fx)=>{"use strict";var Wwe=ni(),w7=ku(),I7=ie(),C7=(H(),C(G)),P7=PE();fx.exports=D7;async function D7(e,t){if(!I7.isEmpty(t)&&C7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=w7(e,"value");if(n)throw n;return P7.prepSearch(e,t,!1)}a(D7,"lmdbSearchByValue")});var px=w((Qwe,_x)=>{"use strict";var Jwe=xt(),Rb=class{static{a(this,"SearchByConditionsObject")}constructor(t,r,n,s,i=void 0,o=void 0,c="and"){this.schema=t,this.table=r,this.get_attributes=n,this.limit=i,this.offset=o,this.conditions=s,this.operator=c}},yb=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},bb=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};_x.exports={SearchByConditionsObject:Rb,SearchCondition:yb,SortAttribute:bb}});var Sx=w((tIe,gx)=>{"use strict";var Zwe=px().SearchByConditionsObject,L7=ni(),M7=ku(),Ob=Hu(),DE=xt(),{Resource:eIe}=(Ea(),C(gR)),Ex=PE(),v7=Eb(),U7=require("lodash"),{getSchemaPath:x7}=gt(),hx=_t(),{handleHDBError:B7,hdb_errors:H7}=pe(),{HTTP_STATUS_CODES:k7}=H7,F7=1e8;gx.exports=G7;async function G7(e){let t=M7(e,"conditions");if(t)throw B7(t,t.message,k7.BAD_REQUEST,void 0,void 0,!0);e.operator=e.operator?e.operator.toLowerCase():void 0,e.offset=Number.isInteger(e.offset)?e.offset:0;let r=x7(e.schema,e.table),n=await hx.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)hx.openDBI(n,u.search_attribute);let i=U7.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let f=u.search_type;f===DE.SEARCH_TYPES.EQUALS?u.estimated_count=Ob.count(n,u.search_attribute,u.search_value):f===DE.SEARCH_TYPES.CONTAINS||f===DE.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=F7}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await mx(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let u=n.dbis[s.hash_attribute],f=i.slice(1).map(Ex.filterByType),d=f.length,p=Ob.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(_=>u.get(_,{transaction:o,lazy:!0})),d>0&&(l=l.filter(_=>{for(let h=0;h<d;h++)if(!f[h](_))return!1;return!0})),(e.offset||e.limit!==void 0)&&(l=l.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),l=l.map(_=>v7.parseRow(_,p))}else{for(let d=1;d<i.length;d++){let p=i[d],_=await mx(o,e,p,s.hash_attribute);c=c.concat(_)}let u=new Set,f=e.offset||0;c=c.filter(d=>u.has(d)?!1:(u.add(d),!0)).slice(f,e.limit&&e.limit+f),l=Ob.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(G7,"lmdbSearchByConditions");async function mx(e,t,r,n){let s=new L7(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===DE.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,Ex.searchByType(e,s,i,n).map(o=>o.value)}a(mx,"executeConditionSearch")});var M_=w((nIe,Tx)=>{"use strict";var q7=(H(),C(G)).OPERATIONS_ENUM,Nb=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=q7.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};Tx.exports=Nb});var wb=w((iIe,Ix)=>{"use strict";var bx=ni(),Ox=M_(),Nx=L_(),wx=I_(),bn=(H(),C(G)),Ax=ie(),Rx=_t(),{getTransactionAuditStorePath:$7,getSchemaPath:V7}=gt(),yx=z();Ix.exports=K7;async function K7(e){try{if(Ax.isEmpty(global.hdb_schema[e.schema])||Ax.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await Y7(e),await W7(e);let t=V7(e.schema,e.table);try{await Rx.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")yx.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=$7(e.schema,e.table);await Rx.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")yx.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(K7,"lmdbDropTable");async function Y7(e){let t=new bx(bn.SYSTEM_SCHEMA_NAME,bn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await Nx(t)),n=[];for(let i=0;i<r.length;i++){let o=r[i];n.push(o.id)}if(n.length===0)return;let s=new Ox(bn.SYSTEM_SCHEMA_NAME,bn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await wx(s)}a(Y7,"deleteAttributesFromSystem");async function W7(e){let t=new bx(bn.SYSTEM_SCHEMA_NAME,bn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,bn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await Nx(t))}catch(i){throw i}for(let i=0;i<r.length;i++){let o=r[i];o.name===e.table&&o.schema===e.schema&&(n=o)}if(!n)throw new Error(`${e.schema}.${e.table} was not found`);let s=new Ox(bn.SYSTEM_SCHEMA_NAME,bn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await wx(s)}catch(i){throw i}}a(W7,"dropTableFromSystem")});var Px=w((aIe,Cx)=>{"use strict";var z7=require("fs-extra"),j7=ni(),J7=Fu(),Q7=M_(),X7=wb(),Z7=I_(),eee=Sb(),tee=L_(),Ro=(H(),C(G)),{getSchemaPath:ree}=gt(),{handleHDBError:nee,hdb_errors:see}=pe(),{HDB_ERROR_MSGS:iee,HTTP_STATUS_CODES:oee}=see;Cx.exports=aee;async function aee(e){let t;try{t=await cee(e.schema);let r=new j7(Ro.SYSTEM_SCHEMA_NAME,Ro.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Ro.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Ro.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await tee(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await X7(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new Q7(Ro.SYSTEM_SCHEMA_NAME,Ro.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await Z7(s);let i=ree(t);await z7.remove(i)}catch(r){throw r}}a(aee,"lmdbDropSchema");async function cee(e){let t=new J7(Ro.SYSTEM_SCHEMA_NAME,Ro.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Ro.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await eee(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw nee(new Error,iee.SCHEMA_NOT_FOUND(e),oee.NOT_FOUND,void 0,void 0,!0);return n}a(cee,"validateDropSchema")});var v_=w((lIe,Dx)=>{"use strict";var Ib=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Dx.exports=Ib});var Pb=w((fIe,Lx)=>{"use strict";var lee=require("fs-extra"),LE=_t(),{getTransactionAuditStorePath:uee}=gt(),Cb=xt(),dIe=v_();Lx.exports=dee;async function dee(e){let t;try{let r=uee(e.schema,e.table);await lee.mkdirp(r),t=await LE.createEnvironment(r,e.table,!0)}catch(r){throw r.message=`unable to create transactions audit environment for ${e.schema}.${e.table} due to: ${r.message}`,r}try{LE.createDBI(t,Cb.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),LE.createDBI(t,Cb.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),LE.createDBI(t,Cb.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME,!0,!1)}catch(r){throw r.message=`unable to create dbi for ${e.schema}.${e.table} due to: ${r.message}`,r}return t}a(dee,"createTransactionsAuditEnvironment")});var Ux=w((hIe,vx)=>{"use strict";var Db=(H(),C(G)),Mx=_t(),fee=qc(),{getSystemSchemaPath:_ee,getSchemaPath:pee}=gt(),pIe=po(),hee=iE(),Lb=sE(),mee=z(),Eee=Pb();vx.exports=gee;async function gee(e,t){let r=pee(t.schema,t.table),n=new Lb(t.schema,t.table,Db.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Lb(t.schema,t.table,Db.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Lb(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await Mx.createEnvironment(r,t.table),e!==void 0){let o=await Mx.openEnvironment(_ee(),Db.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await fee.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_table_attributes,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await Mb(n),await Mb(s),await Mb(i)}await Eee(t)}catch(o){throw o}}a(gee,"lmdbCreateTable");async function Mb(e){try{await hee(e)}catch(t){mee.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(Mb,"createAttribute")});var Bx=w((EIe,xx)=>{"use strict";var See=l_(),Tee=xf(),Aee=bE(),U_=(H(),C(G)),Ree=qc().updateRecords,yee=_t(),{getSchemaPath:bee}=gt(),Oee=N_(),Nee=z();xx.exports=wee;async function wee(e){try{let{schema_table:t,attributes:r}=See(e);Tee(e,r,t.hash_attribute),e.schema!==U_.SYSTEM_SCHEMA_NAME&&(r.includes(U_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(U_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(U_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(U_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await Aee(e.hdb_auth_header,t,r),s=bee(e.schema,e.table),i=await yee.openEnvironment(s,e.table),o=await Ree(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await Oee(e,o)}catch(c){Nee.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(wee,"lmdbUpdateRecords")});var kx=w((SIe,Hx)=>{"use strict";var Iee=(H(),C(G)).OPERATIONS_ENUM,vb=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Iee.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Hx.exports=vb});var Gx=w((RIe,Fx)=>{"use strict";var AIe=kx(),Cee=l_(),Pee=xf(),Dee=bE(),x_=(H(),C(G)),Lee=qc().upsertRecords,Mee=_t(),{getSchemaPath:vee}=gt(),Uee=N_(),xee=z(),{handleHDBError:Bee,hdb_errors:Hee}=pe();Fx.exports=kee;async function kee(e){let t;try{t=Cee(e)}catch(l){throw Bee(l,l.message,Hee.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;Pee(e,n,r.hash_attribute),e.schema!==x_.SYSTEM_SCHEMA_NAME&&(n.includes(x_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(x_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(x_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(x_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await Dee(e.hdb_auth_header,r,n),i=vee(e.schema,e.table),o=await Mee.openEnvironment(i,e.table),c=await Lee(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await Uee(e,c)}catch(l){xee.error(`unable to write transaction due to ${l.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:s,txn_time:c.txn_time}}a(kee,"lmdbUpsertRecords")});var $x=w((bIe,qx)=>{"use strict";var Ub=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};qx.exports=Ub});var Kx=w((NIe,Vx)=>{"use strict";var xb=class{static{a(this,"DeleteAuditLogsBeforeResults")}constructor(t=void 0,r=void 0,n=0){this.start_timestamp=t,this.end_timestamp=r,this.transactions_deleted=n}};Vx.exports=xb});var zx=w((CIe,Wx)=>{"use strict";var Bb=_t(),{getTransactionAuditStorePath:Fee}=gt(),IIe=$x(),B_=xt(),Gee=ie(),Yx=Kx(),qee=require("util").promisify,$ee=qee(setTimeout),Vee=1e4,Kee=100;Wx.exports=Yee;async function Yee(e){let t=Fee(e.schema,e.table),r=await Bb.openEnvironment(t,e.table,!0),n=Bb.listDBIs(r);Bb.initializeDBIs(r,B_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new Yx;do s=await Wee(r,e.timestamp),i.start_timestamp===void 0&&(i.start_timestamp=s.start_timestamp),s.end_timestamp!==void 0&&(i.end_timestamp=s.end_timestamp),i.transactions_deleted+=s.transactions_deleted,await $ee(Kee);while(s.transactions_deleted>0);return i}a(Yee,"deleteAuditLogsBefore");async function Wee(e,t){let r=new Yx;try{let n=e.dbis[B_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],s;for(let{key:i,value:o}of n.getRange({start:!1})){if(i>=t)break;r.start_timestamp===void 0&&(r.start_timestamp=i),s=n.remove(i);let c=o[B_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];Gee.isEmpty(c)||(s=e.dbis[B_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[B_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>Vee)break}return await s,r}catch(n){throw n}}a(Wee,"deleteTransactions")});var Jx=w((DIe,jx)=>{"use strict";var Hb=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};jx.exports=Hb});var Xx=w((vIe,Qx)=>{"use strict";var zee=ni(),jee=M_(),MIe=Jx(),Bi=(H(),C(G)),Jee=ie(),kb=_t(),Qee=po(),Xee=L_(),Zee=I_(),{getSchemaPath:ete}=gt();Qx.exports=tte;async function tte(e,t=!0){let r;e.schema===Bi.SYSTEM_SCHEMA_NAME?r=Qee[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await nte(e),s=ete(e.schema,e.table),i=await kb.openEnvironment(s,e.table);return t===!0&&await rte(e,i,r.hash_attribute),kb.dropDBI(i,e.attribute),n}a(tte,"lmdbDropAttribute");async function rte(e,t,r){let n=kb.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let u={};for(let f in c)f!==i&&(u[f]=c[f]);s=t.dbis[r].put(o,u,l)}await s}a(rte,"removeAttributeFromAllObjects");async function nte(e){let t=new zee(Bi.SYSTEM_SCHEMA_NAME,Bi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await Xee(t)).filter(o=>o[Bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(Jee.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[Bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new jee(Bi.SYSTEM_SCHEMA_NAME,Bi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return Zee(i)}a(nte,"dropAttributeFromSystem")});var sB=w((BIe,nB)=>{"use strict";var Fb=_t(),Gu=xt(),xIe=_n(),Gb=(H(),C(G)),Zx=ie(),{getTransactionAuditStorePath:ste}=gt(),ite=Hu(),ME=Uu(),ote=z();nB.exports=ate;async function ate(e){let t=ste(e.schema,e.table),r=await Fb.openEnvironment(t,e.table,!0),n=Fb.listDBIs(r);Fb.initializeDBIs(r,Gu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case Gb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return eB(r,e.search_values);case Gb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,lte(r,e.search_values,s);case Gb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return cte(r,e.search_values);default:return eB(r)}}a(ate,"readAuditLog");function eB(e,t=[0,Date.now()]){Zx.isEmpty(t[0])&&(t[0]=0),Zx.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[Gu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let s of r.getKeys({start:t[1]}))if(s!==t[1]){n=s;break}return r.getRange({start:t[0],end:n}).map(({value:s})=>Object.assign(new ME,s))}a(eB,"searchTransactionsByTimestamp");function cte(e,t=[]){let r=new Map;for(let n=0;n<t.length;n++){let s=t[n],i=[];for(let o of e.dbis[Gu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,rB(e,i))}return Object.fromEntries(r)}a(cte,"searchTransactionsByUsername");function lte(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],f=ite.equals(e,Gu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Gu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:d}of f){let p=Number(d);n.has(p)?n.get(p).push(u.toString()):n.set(p,[u.toString()])}}let s=Array.from(n.keys()),i=rB(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,f=n.get(u);tB(l,"records",r,f,o),tB(l,"original_records",r,f,o)}return Object.fromEntries(o)}a(lte,"searchTransactionsByHashValues");function tB(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let u=s.get(l),f=u[u.length-1];if(f.timestamp===i)f[t]=[c];else{let d=new ME(e.operation,e.user_name,i,void 0);d[t]=[c],u.push(d)}}else{let u=new ME(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}a(tB,"loopRecords");function rB(e,t){let r=[];try{let n=e.dbis[Gu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let s=0;s<t.length;s++)try{let i=n.get(t[s]);if(i){let o=Object.assign(new ME,i);r.push(o)}}catch(i){ote.warn(i)}return r}catch(n){throw n}}a(rB,"batchSearchTransactions")});var oB=w((GIe,iB)=>{"use strict";var{getSchemaPath:kIe}=gt(),FIe=_t(),{database:ute}=(De(),C(nt));iB.exports={writeTransaction:dte};async function dte(e,t,r){return ute({database:e,table:t}).transaction(r)}a(dte,"writeTransaction")});var uB=w(($Ie,lB)=>{"use strict";var{getSchemaPath:aB}=gt(),cB=_t();lB.exports={flush:fte,resetReadTxn:_te};async function fte(e,t){return(await cB.openEnvironment(aB(e,t),t.toString())).flushed}a(fte,"flush");async function _te(e,t){try{(await cB.openEnvironment(aB(e,t),t.toString())).resetReadTxn()}catch{}}a(_te,"resetReadTxn")});var pB=w((KIe,_B)=>{"use strict";var{Readable:pte}=require("stream"),{getDatabases:hte}=(De(),C(nt)),{readSync:mte,openSync:Ete,createReadStream:dB}=require("fs"),{open:gte}=require("lmdb"),fB=s_(),Ste=i_(),{AUDIT_STORE_OPTIONS:Tte}=(fo(),C(hB)),{INTERNAL_DBIS_NAME:Ate,AUDIT_STORE_NAME:Rte}=xt();_B.exports=bte;var qb=32768,yte=100;async function bte(e){let t=e.database||e.schema||"data",r=hte()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let u=r[s[0]];if(!u)throw new Error(`Can not find table ${s[0]}`);let f=u.dbisDB,d=gte({noSync:!0,maxDbs:Ste.MAX_DBS}),p,_=d.openDB(Ate,new fB(!1)),h=f.useReadTransaction(),S=0,g=a(async function(E,T){T.encoding="binary",T.encoder=void 0;let b=d.openDB(E,T),v=f.openDB(E,T);for(let{key:F,version:q,value:Y}of v.getRange({start:null,transaction:h,versions:v.useVersions}))p=b.put(F,Y,q),S++%yte===0&&(await new Promise(Z=>setTimeout(Z,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:E,value:T}of f.getRange({transaction:h,start:!1}))if(s.some(b=>E.startsWith?.(b+"/"))){_.put(E,T);let[,b]=E.split("/"),v=!b,F=new fB(!v,v);await g(E,F)}e.include_audit&&await g(Rte,{...Tte}),await p;let R=dB(d.path);return R.headers=l(),R.on("close",()=>{h.done(),d.close()}),R}let o=r[Object.keys(r)[0]].primaryStore,c=Ete(o.path);return o.transaction(()=>{let u=Buffer.alloc(qb);mte(c,u,0,qb),o.resetReadTxn();let f=o.useReadTransaction();f.renew();let d=dB(null,{fd:c,start:qb}),p=new pte.from(async function*(){yield u;for await(let _ of d)f.openTimer&&(f.openTimer=0),yield _;f.done()}());return p.headers=l(),p});function l(){let u=new Map;return u.set("content-type","application/octet-stream"),u.set("content-disposition",`attachment; filename="${t}"`),u.set("date",n),u}}a(bte,"getBackup")});var gB=w((WIe,EB)=>{"use strict";var Ote=z(),{handleHDBError:Nte}=pe(),wte=CM(),Ite=iE(),Cte=fb(),Pte=P0(),Dte=I_(),Lte=Sb(),Mte=rx(),vte=dx(),Ute=L_(),xte=Sx(),Bte=Px(),Hte=Ux(),kte=Bx(),Fte=Gx(),Gte=zx(),qte=wb(),$te=Xx(),Vte=sB(),Kte=oB(),mB=uB(),Yte=pB(),$b=class extends wte{static{a(this,"LMDBBridge")}async searchByConditions(t){return xte(t)}async getDataByHash(t){return await Lte(t)}async searchByHash(t){return await Mte(t)}async getDataByValue(t,r){return await vte(t,r)}async searchByValue(t){return await Ute(t)}async createSchema(t){return await Pte(t)}async dropSchema(t){return await Bte(t)}async createTable(t,r){return await Hte(t,r)}async dropTable(t){return await qte(t)}async createAttribute(t){return await Ite(t)}async createRecords(t){return await Cte(t)}async updateRecords(t){return await kte(t)}async upsertRecords(t){try{return await Fte(t)}catch(r){throw Nte(r,null,null,Ote.ERR,r)}}async deleteRecords(t){return await Dte(t)}async dropAttribute(t){return await $te(t)}async deleteAuditLogsBefore(t){return await Gte(t)}async readAuditLog(t){return await Vte(t)}writeTransaction(t,r,n){return Kte.writeTransaction(t,r,n)}flush(t,r){return mB.flush(t,r)}resetReadTxn(t,r){return mB.resetReadTxn(t,r)}getBackup(t){return Yte(t)}};EB.exports=$b});var Kb={};ve(Kb,{add:()=>vE,applyReverse:()=>SB,getRecordAtTime:()=>Vb,rebuildUpdateBefore:()=>UE});function vE(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n+BigInt(r.value):isNaN(e[t])?e[t]=r.value:e[t]=n+r.value}function UE(e,t,r){let n=null;for(let s in e)if(s in t){let i=t[s];if(i?.__op__){let o=e[s];if(o?.__op__)if(o.__op__===i.__op__)n||(n={}),n[s]=o;else throw new Error("Can not merge updates with different operations");else n||(n={}),n[s]=o,vE(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function SB(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=Wte[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=TB}}function Vb(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),u=It(l);switch(u.type){case"put":s=u.getValue(r);break;case"patch":SB(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===TB&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),u=It(l),f;switch(u.type){case"put":f=u.getValue(r);break;case"patch":f=u.getValue(r);break}for(let d in f)o[d]&&(s[d]=f[d],o[d]=!1,c--);i=u.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var Wte,TB,xE=be(()=>{fo();a(vE,"add");vE.reverse=function(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n-BigInt(r.value):isNaN(e[t])||(e[t]=n-r.value)};Wte={add:vE};a(UE,"rebuildUpdateBefore");a(SB,"applyReverse");TB={};a(Vb,"getRecordAtTime")});function On(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function FE(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let c of s){let l=c.name,u,f;if(c.resolve)f={get(){return c.resolve(this,this.getContext?.())},set(d){return c.set(this,d)},configurable:!0};else{switch(c.type){case"String":u=a(function(d){if(!(typeof d=="string"||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a string, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"ID":u=a(function(d){if(!(typeof d=="string"||d?.length>0&&d.every?.(p=>typeof p=="string")||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a string, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Float":case"Number":u=a(function(d){let p=d?.__op__?d.value:d;if(!(typeof p=="number"||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a number, attempt to assign ${p}`);On(this)[l]=d},"set");break;case"Int":u=a(function(d){let p=d?.__op__?d.value:d;if(!(p>>0===p||d==null&&c.nullable!==!1))if(typeof p=="number"&&Math.abs((p>>0)-p)<=1)p=Math.round(p),d?.__op__?d.value=p:d=p;else throw new jn.ClientError(`${l} must be an integer between -2147483648 and 2147483647, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Long":u=a(function(d){let p=d?.__op__?d.value:d;if(!(Math.round(p)===d&&Math.abs(p)<=9007199254740992||d==null&&c.nullable!==!1))if(typeof p=="number"&&Math.abs(p)<=9007199254740992)p=Math.round(p),d?.__op__?d.value=p:d=p;else throw new jn.ClientError(`${l} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"BigInt":u=a(function(d){let p=d?.__op__?d.value:d;if(!(typeof p=="bigint"||d==null&&c.nullable!==!1))if(typeof p=="string"||typeof p=="number")p=BigInt(p),d?.__op__?d.value=p:d=p;else throw new jn.ClientError(`${l} must be a number, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Boolean":u=a(function(d){if(!(typeof d=="boolean"||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a boolean, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Date":u=a(function(d){if(!(d instanceof Date||d==null&&c.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=new Date(d);else throw new jn.ClientError(`${l} must be a Date, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Bytes":u=a(function(d){if(!(d instanceof Uint8Array||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a Buffer or Uint8Array, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Blob":u=a(function(d){if(!(d instanceof wi||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be a Blob, attempt to assign ${d}`);On(this)[l]=d},"set");break;case"Any":case void 0:u=a(function(d){On(this)[l]=d},"set");break;default:u=a(function(d){if(!(typeof d=="object"||d==null&&c.nullable!==!1))throw new jn.ClientError(`${l} must be an object, attempt to assign ${d}`);On(this)[l]=d},"set")}f={get(){let d=this.getChanges?.();if(d&&l in d){let _=d[l];if(_?.__op__){let h=this.getRecord()?.[l];return _.update(h)}return _}let p=this.getRecord()?.[l];if(p&&typeof p=="object"){let _=Yb(p,c);if(_)return d||this._setChanges(d=Object.create(null)),d[l]=_}return p},set:u,enumerable:!0,configurable:!0}}f.get.isAttribute=!0,n[l]=f,(!(l in r)||Object.getOwnPropertyDescriptor(r,l)?.get?.isAttribute)&&Object.defineProperty(r,l,f)}i("getProperty",function(c){let l=n[c];if(l)return l.get.call(this);let u=this.getChanges();return u?.[c]!==void 0?u[c]:this.getRecord()?.[c]}),i("set",function(c,l){let u=n[c];if(u)return u.set.call(this,l);if(t.sealed)throw new jn.ClientError("Can not add a property to a sealed table schema");On(this)[c]=l}),i("deleteProperty",function(c){On(this)[c]=void 0}),i("toJSON",function(){let c=this.getChanges?.(),l;for(let f in c){l||(l={...this.getRecord()});let d=c[f];if(d?.__op__){let p=l[f];d=d.update(p)}l[f]=d}return Object.keys(this).length>0&&(l||(l={...this.getRecord()}),Object.assign(l,this)),l||this.getRecord()}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty),r.then||i("then",null);function i(c,l){Object.defineProperty(r,c,{value:l,configurable:!0})}a(i,"setMethod");let o=r;do{let c=Object.getPrototypeOf(o);if(c===Object.prototype){Object.setPrototypeOf(o,RB);break}o=c}while(o&&o!==RB)}function Yb(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends H_{static{a(this,"TrackedObject")}},FE(r,t)),new r(e)):new H_(e);case Array:let n=new HE(e.length,e);for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=Yb(o,t?.elements)),n[s]=o}return n;default:return e}}function GE(e){let t=e.getChanges?.(),r;for(let s in t){r||(r=e.getRecord?{...e.getRecord()}:{});let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=GE(i);r[s]=i}return Object.keys(e).length>0&&(r||(r=e.getRecord?{...e.getRecord()}:{}),Object.assign(r,e)),r||e.getRecord?.()||e}function sl(e,t=e.getChanges?.()){let r;if(e.getRecord&&e.constructor===Array&&!Object.isFrozen(e)){r=e;for(let n=0,s=e.length;n<s;n++){let i=e[n];if(i&&typeof i=="object"){let o=sl(i);o!==i&&r===e&&(r=e.slice(0)),i=o}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r={...e.getRecord?.()});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=Kb[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=sl(s);r[n]=s}if(!Array.isArray(e))for(let n in e)zte.call(e,n)&&(r||(r={...e.getRecord?.()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?.()??e}function BE(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[nl]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.getRecord?.()===s){if(BE(i))return!0}else return!0}}else{let r=e.getChanges?.();if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s.getRecord?.()===i){if(BE(s))return!0}else return!0}else return!0}}return!1}var jn,AB,RB,H_,zte,nl,HE,kE,Wb=be(()=>{jn=M(pe());xE();gs();a(On,"getChanges");a(FE,"assignTrackedAccessors");AB=Object.prototype,RB=new Proxy({},{get(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(AB[t])return AB[t];let n=r.getChanges?.();if(n&&t in n)return n[t];let s=r.getRecord?.()[t];if(s&&typeof s=="object"){let i=Yb(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}});a(Yb,"trackObject");H_=class{static{a(this,"GenericTrackedObject")}#e;#t;constructor(t){if(t?.getRecord)throw new Error("Can not track an already tracked object, check for circular references");this.#e=t}getRecord(){return this.#e}setRecord(t){this.#e=t}getChanges(){return this.#t}_setChanges(t){this.#t=t}};FE(H_,{});a(GE,"collapseData");zte=Object.prototype.hasOwnProperty;a(sl,"updateAndFreeze");a(BE,"hasChanges");nl=Symbol.for("has-array-changes"),HE=class extends Array{static{a(this,"TrackedArray")}#e;[nl];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[nl]=!0,super.splice(...t)}push(...t){return this[nl]=!0,super.push(...t)}pop(){return this[nl]=!0,super.pop()}unshift(...t){return this[nl]=!0,super.unshift(...t)}shift(){return this[nl]=!0,super.shift()}};HE.prototype.constructor=Array;kE=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var PB={};ve(PB,{ResourceBridge:()=>Jb});function Qb({get_attributes:e},t){if(e){if(e[0]==="*"){if(t.schemaDefined)return;e=t.attributes.map(r=>r.name)}return e.forceNulls=!0,e}}function bB(e,t){let r=Hi(e),n=Qb(e,r);if(!r)throw new si.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache,replicateFrom:e.replicateFrom},o;wt(i,()=>new Promise(u=>o=u));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let u=c[l++],f;try{f=await r.get({id:u,lazy:s,select:n},i),f=f&&GE(f)}catch(d){f={message:d.toString()}}return t?{value:{key:u,value:f}}:{value:f}}else return o(),{done:!0}},return(u){return o(),{value:u,done:!0}},throw(u){return o(),{done:!0}}}}}}function Hi(e){let t=e.database||e.schema||Jte,r=Xe()[t];if(!r)throw(0,si.handleHDBError)(new Error,jte.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function OB(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}async function*NB(e,t,r,n){let s,i=0;for await(let o of e.getHistory(t,r)){let c=o.operation??o.type;c==="put"&&(c="upsert");let{id:l,version:u,value:f}=o;if(s?.timestamp===u)s.hash_values.push(l),s.records.push(f);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:u,hash_values:[l],records:[f]}}}s&&(yield s)}var wB,qE,si,IB,zb,jb,CB,jte,Jte,Qte,Xte,yB,Jb,DB=be(()=>{"use strict";wB=M(gB()),qE=M(ku()),si=M(pe());De();IB=M(l_());H();zb=M(To()),jb=M(ri()),CB=M(ie());Ic();Wb();({HDB_ERROR_MSGS:jte}=si.hdb_errors),Jte="data",Qte=1e4,Xte=10,Jb=class extends wB.default{static{a(this,"ResourceBridge")}constructor(t){super(t),yB=this}async searchByConditions(t){t.select!==void 0&&(t.get_attributes=t.select);for(let o of t.conditions||[])o?.attribute!==void 0&&(o.search_attribute=o.attribute),o?.comparator!==void 0&&(o.search_type=o.comparator),o?.value!==void 0&&(o.search_value=o.value);let r=(0,qE.default)(t,"conditions");if(r)throw(0,si.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Hi(t);if(!n)throw new si.ClientError(`Table ${t.table} not found`);let s=t.conditions.map(i);function i(o){return o.conditions?(o.conditions=o.conditions.map(i),o):{attribute:o.search_attribute??o.attribute,comparator:o.search_type??o.comparator,value:o.search_value!==void 0?o.search_value:o.value}}return a(i,"mapCondition"),n.search({conditions:s,operator:t.operator?t.operator.toLowerCase():void 0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:Qb(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new si.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}ft({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await Hi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Hi(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c={...c},delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(u=>{if(!u){let{value:f,version:d}=r.primaryStore.getEntry(o);return i(o,f,d)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(u=>setImmediate(u));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){Hi(t).dropTable()}createSchema(t){return qu({database:t.schema,table:null}),zb.signalSchemaChange(new jb.SchemaEventMsg(process.pid,Yt.CREATE_SCHEMA,t.schema))}async dropSchema(t){await Xb(t.schema),zb.signalSchemaChange(new jb.SchemaEventMsg(process.pid,Yt.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,yB.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,IB.default)(t),s,i=Xe()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(o.replicateTo=t.replicateTo),t.replicatedConfirmation&&(o.replicatedConfirmation=t.replicatedConfirmation),wt(o,async c=>{if(!i.schemaDefined){s=[];for(let f of n)i.attributes.find(p=>p.name==f)||s.push(f);s.length>0&&await i.addAttributes(s.map(f=>({name:f,indexed:!0})))}let l=[],u=[];for(let f of t.records){let d=f[i.primaryKey],p=d!=null&&await i.get(d,o);if(t.requires_existing&&!p||t.requires_no_existing&&p){u.push(f[i.primaryKey]);continue}p&&(p=GE(p));for(let _ in f)if(Object.prototype.hasOwnProperty.call(f,_)){let h=f[_];if(typeof h=="function")try{let S=h([[p]]);Array.isArray(S)&&(h=S[0].func_val,f[_]=h)}catch(S){throw S.message+="Trying to set key "+_+" on object"+JSON.stringify(f),S}}if(p)for(let _ in p)Object.prototype.hasOwnProperty.call(f,_)||(f[_]=p[_]);await(d==null?i.create(f,o):i.put(f,o)),l.push(f[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:u}})}async deleteRecords(t){let r=Xe()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),wt(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),o=[],c=[];for(let l of i)await r.delete(l,n)?o.push(l):c.push(l);return OB(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Xe()[t.schema][t.table];if(!r.createdTimeProperty)throw new si.ClientError("Table must have a '__createdtime__' attribute or @createdTime timestamp defined to perform this operation");let n=await r.search({conditions:[{attribute:r.createdTimeProperty.name,value:Date.parse(t.date),comparator:am.LESS}]}),s=!1,i=[],o=[],c=0,l=[],u=a(async()=>{let f=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...f.deleted_hashes),o.push(...f.skipped_hashes),await(0,CB.async_set_timeout)(Xte),l=[],s=!0},"chunkDelete");for await(let f of n)l.push(f[r.primaryKey]),c++,c%Qte===0&&await u();return l.length>0&&await u(),s?OB(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,qE.default)(t,"hashes");if(r)throw r;return bB(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of bB(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&QA[r]===void 0)throw new Error(`Value search comparator - ${r} - is not valid`);t.select!==void 0&&(t.get_attributes=t.select),t.attribute!==void 0&&(t.search_attribute=condition.attribute),t.value!==void 0&&(t.search_value=condition.value);let n=(0,qE.default)(t,"value");if(n)throw n;let s=Hi(t);if(!s)throw new si.ClientError(`Table ${t.table} not found`);let i=t.search_value;i.includes?.("*")&&(i.startsWith("*")?i.endsWith("*")?i!=="*"&&(r="contains",i=i.slice(1,-1)):(r="ends_with",i=i.slice(1)):i.endsWith("*")&&(r="starts_with",i=i.slice(0,-1))),r===am.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,sort:t.sort,select:Qb(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=Hi(t);t.get_attributes&&!t.get_attributes.includes(s.primaryKey)&&t.get_attributes[0]!=="*"&&t.get_attributes.push(s.primaryKey);for await(let i of this.searchByValue(t,r))n.set(i[s.primaryKey],i);return n}resetReadTxn(t,r){Hi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Hi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=Hi(t),n={};switch(t.search_type){case cm.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.operation??o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case cm.USERNAME:let s=t.search_values;for await(let i of NB(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return NB(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(Qb,"getSelect");a(bB,"getRecords");a(Hi,"getTable");a(OB,"createDeleteResponse");a(NB,"groupRecordsInHistory")});var Vn=w((oCe,LB)=>{"use strict";var{ResourceBridge:Zte}=(DB(),C(PB)),ere=ae();ere.initSync();var $E;function tre(){return $E||($E=new Zte,$E)}a(tre,"getBridge");LB.exports=tre()});var yn=w((cCe,xB)=>{"use strict";var KE=FR(),Lr=ie(),rre=require("util"),YE=Vn(),nre=As(),MB=z(),{handleHDBError:il,hdb_errors:sre}=pe(),{HTTP_STATUS_CODES:ol}=sre,ire=rre.promisify(nre.getTableSchema),ore="updated",vB="inserted",UB="upserted";xB.exports={insert:cre,update:lre,upsert:ure,validation:are,flush:dre};async function are(e){if(Lr.isEmpty(e))throw new Error("invalid update parameters defined.");if(Lr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Lr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await ire(e.schema,e.table),r=KE(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let n=t.hash_attribute,s=new Set,i={},o=!1;return e.operation==="update"&&(o=!0),e.records.forEach(c=>{if(o&&Lr.isEmptyOrZeroLength(c[n]))throw MB.error("a valid hash attribute must be provided with update record:",c),new Error("a valid hash attribute must be provided with update record");if(!Lr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw MB.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Lr.isEmpty(c[n])&&c[n]!==""&&s.has(Lr.autoCast(c[n]))&&(c.skip=!0),s.add(Lr.autoCast(c[n]));for(let l in c)i[l]=1}),i[n]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(i)}}a(are,"validation");async function cre(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=KE(e);if(t)throw il(new Error,t.message,ol.BAD_REQUEST);Lr.transformReq(e);let r=Lr.checkSchemaTableExist(e.schema,e.table);if(r)throw il(new Error,r,ol.BAD_REQUEST);let n=await YE.createRecords(e);return VE(vB,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(cre,"insertData");async function lre(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=KE(e);if(t)throw il(new Error,t.message,ol.BAD_REQUEST);Lr.transformReq(e);let r=Lr.checkSchemaTableExist(e.schema,e.table);if(r)throw il(new Error,r,ol.BAD_REQUEST);let n=await YE.updateRecords(e);return Lr.isEmpty(n.existing_rows)?VE(ore,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):VE(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(lre,"updateData");async function ure(e){if(e.operation!=="upsert")throw il(new Error,"invalid operation, must be upsert",ol.INTERNAL_SERVER_ERROR);let t=KE(e);if(t)throw il(new Error,t.message,ol.BAD_REQUEST);Lr.transformReq(e);let r=Lr.checkSchemaTableExist(e.schema,e.table);if(r)throw il(new Error,r,ol.BAD_REQUEST);let n=await YE.upsertRecords(e);return VE(UB,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(ure,"upsertData");function VE(e,t,r,n,s,i){let o={message:`${e} ${t.length} of ${t.length+n.length} records`,new_attributes:s,txn_time:i};return e===vB?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===UB?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(VE,"returnObject");function dre(e){return Lr.transformReq(e),YE.flush(e.schema,e.table)}a(dre,"flush")});var qB=w((uCe,GB)=>{var $u=require("validate.js"),HB=ot(),Vu=(H(),C(G)),{handleHDBError:fre,hdb_errors:_re}=pe(),{HDB_ERROR_MSGS:jt,HTTP_STATUS_CODES:pre}=_re,Zb=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),hre={STRUCTURE_USER:"structure_user"},BB=Object.values(Vu.ROLE_TYPES_ENUM),mre="attribute_permissions",Ere="attribute_name",{PERMS_CRUD_ENUM:Ku}=Vu,gre=[mre,...Object.values(Ku)],kB=[Ku.READ,Ku.INSERT,Ku.UPDATE],Sre=[Ere,...kB];function Tre(e){let t=Zb();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,FB(e,t)}a(Tre,"addRoleValidation");function Are(e){let t=Zb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,FB(e,t)}a(Are,"alterRoleValidation");function Rre(e){let t=Zb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,HB.validateObject(e,t)}a(Rre,"dropRoleValidation");var yre=["operation","role","id","permission","hdb_user","hdb_auth_header","access"];function FB(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)yre.includes(n[o])||s.push(n[o]);s.length>0&&nr(jt.INVALID_ROLE_JSON_KEYS(s),r);let i=HB.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{nr(o,r)}),e.permission){let o=bre(e);o&&nr(o,r),BB.forEach(c=>{e.permission[c]&&!$u.isBoolean(e.permission[c])&&nr(jt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(BB.indexOf(o)<0){if(o===hre.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let u=0,f=l.length;u<f;u++){let d=l[u];global.hdb_schema[d]||nr(jt.SCHEMA_NOT_FOUND(d),r)}continue}nr(jt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){nr(jt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let u=c.tables[l];if(!l||!global.hdb_schema[o][l]){nr(jt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(f=>{gre.includes(f)||nr(jt.INVALID_PERM_KEY(f),r,o,l)}),Object.values(Ku).forEach(f=>{$u.isDefined(u[f])?$u.isBoolean(u[f])||nr(jt.TABLE_PERM_NOT_BOOLEAN(f),r,o,l):nr(jt.TABLE_PERM_MISSING(f),r,o,l)}),u.attribute_permissions===void 0){nr(jt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){nr(jt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}if(u.attribute_permissions){let f=global.hdb_schema[o][l].attributes.map(({attribute:p})=>p),d={read:!1,insert:!1,update:!1};for(let p in u.attribute_permissions){let _=u.attribute_permissions[p];if(Object.keys(_).forEach(S=>{!Sre.includes(S)&&S!==Ku.DELETE&&nr(jt.INVALID_ATTR_PERM_KEY(S),r,o,l)}),!$u.isDefined(_.attribute_name)){nr(jt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=_.attribute_name;if(!f.includes(h)){nr(jt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}kB.forEach(S=>{$u.isDefined(_[S])?$u.isBoolean(_[S])||nr(jt.ATTR_PERM_NOT_BOOLEAN(S,h),r,o,l):nr(jt.ATTR_PERM_MISSING(S,h),r,o,l)}),!d.read&&_.read===!0&&(d.read=!0),!d.insert&&_.insert===!0&&(d.insert=!0),!d.update&&_.update===!0&&(d.update=!0)}if(u.read===!1&&d.read===!0||u.insert===!1&&d.insert===!0||u.update===!1&&d.update===!0){let p=`${o}.${l}`;nr(jt.MISMATCHED_TABLE_ATTR_PERMS(p),r,o,l)}}}}return Ore(r)}a(FB,"customValidate");GB.exports={addRoleValidation:Tre,alterRoleValidation:Are,dropRoleValidation:Rre};function bre(e){let{operation:t,permission:r}=e;if(t===Vu.OPERATIONS_ENUM.ADD_ROLE||t===Vu.OPERATIONS_ENUM.ALTER_ROLE){let n=r.super_user===!0,s=r.cluster_user===!0;if(Object.keys(r).length>1&&(n||s)){if(s&&n)return jt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?Vu.ROLE_TYPES_ENUM.SUPER_USER:Vu.ROLE_TYPES_ENUM.CLUSTER_USER;return jt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(bre,"validateNoSUPerms");function Ore(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:jt.ROLE_PERMS_ERROR,...e};return fre(new Error,n,pre.BAD_REQUEST)}else return null}a(Ore,"generateRolePermResponse");function nr(e,t,r,n){if(!r)t.main_permissions.push(e);else{let s=n?r+"_"+n:r;t.schema_permissions[s]?t.schema_permissions[s].push(e):t.schema_permissions[s]=[e]}}a(nr,"addPermError")});var F_=w((_Ce,YB)=>{"use strict";var $B=yn(),VB=Yr(),Nre=zc(),tO=qB(),rO=To(),fCe=require("uuid").v4,wre=require("util"),WE=(H(),C(G)),Ire=ie(),nO=VB.searchByValue,Cre=VB.searchByHash,Pre=wre.promisify(Nre.delete),Dre=ni(),Lre=Fu(),{hdb_errors:Mre,handleHDBError:al}=pe(),{HDB_ERROR_MSGS:KB,HTTP_STATUS_CODES:k_}=Mre,{UserEventMsg:sO}=ri();YB.exports={addRole:vre,alterRole:Ure,dropRole:xre,listRoles:Bre};function eO(e){try{e.hdb_auth_header&&delete e.hdb_auth_header,e.HDB_INTERNAL_PATH&&delete e.HDB_INTERNAL_PATH,e.operation&&delete e.operation,e.hdb_user&&delete e.hdb_user}catch{}return e}a(eO,"scrubRoleDetails");async function vre(e){let t=tO.addRoleValidation(e);if(t)throw t;e=eO(e);let r={schema:"system",table:"hdb_role",search_attribute:"role",search_value:e.role,hash_attribute:"id",get_attributes:["*"]},n;try{n=Array.from(await nO(r)||[])}catch(i){throw al(i)}if(n&&n.length>0)throw al(new Error,KB.ROLE_ALREADY_EXISTS(e.role),k_.CONFLICT,void 0,void 0,!0);e.id||(e.id=e.role);let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await $B.insert(s),rO.signalUserChange(new sO(process.pid)),e=eO(e),e}a(vre,"addRole");async function Ure(e){let t=tO.alterRoleValidation(e);if(t)throw t;e=eO(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await $B.update(r)}catch(s){throw al(s)}if(n&&n?.message==="updated 0 of 1 records")throw al(new Error,"Invalid role id",k_.BAD_REQUEST,void 0,void 0,!0);return await rO.signalUserChange(new sO(process.pid)),e}a(Ure,"alterRole");async function xre(e){let t=tO.dropRoleValidation(e);if(t)throw al(new Error,t,k_.BAD_REQUEST,void 0,void 0,!0);let r=new Lre(WE.SYSTEM_SCHEMA_NAME,WE.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await Cre(r));if(n.length===0)throw al(new Error,KB.ROLE_NOT_FOUND,k_.NOT_FOUND,void 0,void 0,!0);let s=new Dre(WE.SYSTEM_SCHEMA_NAME,WE.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await nO(s)),o=!1;if(Ire.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw al(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,k_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await Pre(c),rO.signalUserChange(new sO(process.pid)),`${n[0].role} successfully deleted`}a(xre,"dropRole");async function Bre(){return nO({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Bre,"listRoles")});var iO={};ve(iO,{start:()=>jB,startOnMainThread:()=>Fre});function jB({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,WB.parseDocument)(r.toString(),{simpleKeys:!0}).toJSON();for(let s in n){let i=n[s];i.permission||(i={permission:i},i.permission.access&&(i.access=i.permission.access,delete i.permission.access));for(let o in i.permission){if(Hre.includes(o))continue;let c=i.permission[o];c.tables||(i.permission[o]=c={tables:c});for(let l in c.tables){let u=c.tables[l];if(u.read=!!u.read,u.insert=!!u.insert,u.update=!!u.update,u.delete=!!u.delete,u.attributes){let f=[];for(let d in u.attributes){let p=u.attributes[d];p.attribute_name=d,f.push(p)}u.attribute_permissions=f,delete u.attributes}if(u.attribute_permissions){if(!Array.isArray(u.attribute_permissions))throw new Error("attribute_permissions must be an array if defined");for(let f of u.attribute_permissions)f.read=!!f.read,f.insert=!!f.insert,f.update=!!f.update}else u.attribute_permissions=null}}i.role=i.id=s,await kre(i)}}}async function kre(e){let t=Xe().system.hdb_role;for await(let r of t.search([{attribute:"role",value:e.role}])){let{__createdtime__:n,__updatedtime__:s,...i}=r;return(0,zB.isEqual)(i,e)?void 0:(e.id=r.id,(0,zE.alterRole)(e))}return(0,zE.addRole)(e)}var zE,WB,zB,Hre,Fre,JB=be(()=>{De();zE=M(F_()),WB=require("yaml"),zB=require("lodash"),Hre=["super_user","cluster_user","structure_user"];a(jB,"start");a(kre,"ensureRole");Fre=jB});async function jE(e){let t=(0,ZB.pathToFileURL)(e).toString();if(Gre)return G_||(G_=qre(Vre)),(await(await G_).import(t)).namespace;try{return await import(t)}catch(r){try{(await import("internal/util")).default.decorateErrorStack(r)}catch{}throw r}}async function qre(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),G_=new Compartment({console,Math,Date,fetch:$re,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,XB.extname)(r)||(r+=".js"),r)},importHook:a(async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:$r,tables:Jn,databases:qe})}};let n=await(0,QB.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),G_}function $re(e,t){let r=typeof e=="string"||e.url;if(new URL(r).protocol!="https")throw new Error("Only https is allowed in fetch");return fetch(e,t)}function Vre(){return{Resource:$r,tables:Jn}}var QB,XB,ZB,Gre,G_,oO=be(()=>{Ea();De();QB=require("fs/promises"),XB=require("path"),ZB=require("url"),Gre=!1;a(jE,"secureImport");a(qre,"getCompartment");a($re,"secureOnlyFetch");a(Vre,"getGlobalVars")});var cO={};ve(cO,{handleFile:()=>Kre});async function Kre(e,t,r,n){let s=new Map,i=await jE(r);c(i.default)&&n.set((0,aO.dirname)(t),i.default),o(i,(0,aO.dirname)(t));function o(l,u){for(let f in l){let d=l[f];c(d)?n.set(u+"/"+f,d):typeof d=="object"&&o(d,u+"/"+f)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var aO,eH=be(()=>{oO();aO=require("path");a(Kre,"handleFile")});var uO={};ve(uO,{start:()=>Yre});function Yre({resources:e}){e.set("login",lO),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var lO,tH=be(()=>{Ea();a(Yre,"start");lO=class extends $r{static{a(this,"Login")}static async get(t,r,n){}static async post(t,r,n){let{username:s,password:i,redirect:o}=r;return{data:await n.login(s,i)}}}});var W_={};ve(W_,{addAnalyticsListener:()=>Y_,calculateCPUUtilization:()=>TH,diffResourceUsage:()=>AH,recordAction:()=>sr,recordActionBinary:()=>Qn,setAnalyticsEnabled:()=>Wre});function Wre(e){hH=e}function zre(e,t){if(typeof e=="number"){let r=t.values,n=r.index++;if(n>=r.length){let s=r;t.values=r=new Float32Array(n*2),r.set(s),r.index=n+1}r[n]=e,t.total+=e}else if(typeof e=="boolean")e&&t.total++,t.count++;else if(typeof e=="function")t.count++;else throw new TypeError("Invalid metric value type "+typeof e)}function jre(e,t,r,n,s,i){let o={};if(typeof t=="number")o.total=t,o.values=new Float32Array(4),o.values.index=1,o.values[0]=t,o.total=t;else if(typeof t=="boolean")o.total=t?1:0,o.count=1;else if(typeof t=="function")o.count=1,o.callback=t;else throw new TypeError("Invalid metric value type "+typeof t);o.description={metric:r,path:n,method:s,type:i},QE.set(e,o)}function sr(e,t,r,n,s){if(!hH)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=QE.get(i);o?zre(e,o):jre(i,e,t,r,n,s),JE||Jre()}function Qn(e,t,r,n,s){sr(!!e,t,r,n,s)}function Y_(e){gH.push(e)}function Jre(){JE=performance.now(),setTimeout(async()=>{let e=performance.now()-JE;JE=0;let t=[],r={time:Date.now(),period:e,threadId:cl.threadId,metrics:t};for(let[s,i]of QE){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,u=[],f;for(let d of SH){let p=Math.floor(c*d),_=o[p-1];if(p>l){let h=p-l;if(_===f){let S=u[u.length-1];typeof S=="number"?u[u.length-1]={value:S,count:1+h}:S.count+=h}else u.push(h>1?{value:_,count:h}:_),f=_;l=p}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:u,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await RH()}let n=process.memoryUsage();t.push({metric:"memory",threadId:cl.threadId,byThread:!0,...n});for(let s of gH)s(t);QE=new Map,cl.parentPort?cl.parentPort.postMessage({type:EH,report:r}):OH({report:r})},mH).unref()}function XE(e,t,r){let n={id:(0,V_.getNextMonotonicTime)(),metric:t,...r};e.primaryStore.put(n.id,n,{append:!0}).then(s=>{s||e.primaryStore.put(n.id,n)})}function TH(e,t){let r=e.userCPUTime+e.systemCPUTime;return Math.round(r/t*100)/100}function AH(e,t){return{userCPUTime:t.userCPUTime/1e3-(e?.userCPUTime??0),systemCPUTime:t.systemCPUTime/1e3-(e?.systemCPUTime??0),minorPageFault:t.minorPageFault-(e?.minorPageFault??0),majorPageFault:t.majorPageFault-(e?.majorPageFault??0),fsRead:t.fsRead-(e?.fsRead??0),fsWrite:t.fsWrite-(e?.fsWrite??0),voluntaryContextSwitches:t.voluntaryContextSwitches-(e?.voluntaryContextSwitches??0),involuntaryContextSwitches:t.involuntaryContextSwitches-(e?.involuntaryContextSwitches??0)}}function Qre(e,t,r){let n=0;for(let[s,i]of Object.entries(r)){let o=`${t}.${s}`,c=i.getSize(),l={database:t,table:s,size:c};XE(e,"table-size",l),ll.trace?.(`table ${o} size metric: ${JSON.stringify(l)}`),n+=c}return n}function rH(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s.getAuditSize(),o=pH.default.statSync(s.primaryStore.env.path).size,c=Qre(e,r,n),l=o-c,u={database:r,size:o,used:c,free:l,audit:i};XE(e,"database-size",u),ll.trace?.(`database ${r} size metric: ${JSON.stringify(u)}`)}catch(s){ll.warn?.("Error getting DB size metrics",s)}}function nH(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s.getStorageStats(),o={database:r,...i};XE(e,"storage-volume",o),ll.trace?.(`db ${r} storage volume metrics: ${JSON.stringify(o)}`)}catch(s){ll.warn?.("Error getting DB volumne metrics",s)}}async function Xre(e,t=6e4){let r=fO(),n=yH(),s=new Promise(E=>{let T=performance.now();setImmediate(()=>{let b=performance.now();b-T>5e3&&ll.warn?.("Unusually high event queue latency on the main thread of "+Math.round(b-T)+"ms"),T=performance.now()}),n.primaryStore.prefetch([1],()=>{let b=performance.now();b-T>5e3&&ll.warn?.("Unusually high task queue latency on the main thread of "+Math.round(b-T)+"ms"),E(b-T)})}),i;for(let E of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(E.value?.time){i=E.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,u=[],f;for(let{key:E,value:T}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!T)continue;if(o){if(E>o+t)break}else o=E;f=E;let{metrics:b,threadId:v}=T;for(let F of b||[]){let{path:q,method:Y,type:Z,metric:se,count:Q,total:ne,distribution:J,threads:me,...ye}=F;Q||(Q=1);let Pe=se+(q?"-"+q:"");Y!==void 0&&(Pe+="-"+Y),Z!==void 0&&(Pe+="-"+Z);let he=c.get(Pe);if(he){if(he.threads){let dt=he.threads[v];if(dt)he=dt;else{he.threads[v]={...ye};continue}}he.count||(he.count=1);let Nt=he.count;for(let dt in ye){let br=ye[dt];typeof br=="number"&&(he[dt]=(he[dt]*Nt+br*Q)/(Nt+Q))}he.count+=Q,ne>=0&&(he.total+=ne,he.ratio=he.total/he.count)}else he={period:t,...F},delete he.distribution,c.set(Pe,he),he.byThread&&(he.threads=[],he.threads[v]={...ye},u.push(he));if(J){J=J.map(dt=>typeof dt=="number"?{value:dt,count:1}:dt);let Nt=l.get(Pe);Nt?Nt.push(...J):l.set(Pe,J)}}await RH()}for(let E of u){let{path:T,method:b,type:v,metric:F,count:q,total:Y,distribution:Z,threads:se,...Q}=E;se=se.filter(ne=>ne);for(let ne in Q){if(typeof E[ne]!="number")continue;let J=0;for(let me of se){let ye=me[ne];typeof ye=="number"&&(J+=ye)}E[ne]=J}E.count=se.length,delete E.threads,delete E.byThread}for(let[E,T]of l){let b=c.get(E);T.sort((dt,br)=>dt.value>br.value?1:-1);let v=b.count-1,F=[],q=0,Y=0,Z;for(let dt of SH){let br=v*dt;for(;q<br;)Z=T[Y++],q+=Z.count,Y===1&&q--;let hs=T[Y>1?Y-2:0];Z||(Z=T[0]),F.push(Z.value-(Z.value-hs.value)*(q-br)/Z.count)}let[se,Q,ne,J,me,ye,Pe,he,Nt]=F;Object.assign(b,{p1:se,p10:Q,p25:ne,median:J,p75:me,p90:ye,p95:Pe,p99:he,p999:Nt})}let d;for(let[E,T]of c)T.id=(0,V_.getNextMonotonicTime)(),T.time=f,n.primaryStore.put(T.id,T,{append:!0}).then(b=>{b||n.primaryStore.put(T.id,T)}),d=!0;let p=Date.now(),{idle:_,active:h}=performance.eventLoopUtilization();if(d||h*10>_){let E=(0,V_.getNextMonotonicTime)(),T={id:E,metric:"main-thread-utilization",idle:_-sH,active:h-iH,taskQueueLatency:await s,time:p,...process.memoryUsage()};n.primaryStore.put(E,T,{append:!0}).then(b=>{b||n.primaryStore.put(E,T)})}sH=_,iH=h;let S=process.resourceUsage(),g=AH(q_,S);g.time=p,g.period=q_.time?p-q_.time:t,g.cpuUtilization=TH(q_,g.period),XE(n,"resource-usage",g),q_=g;let R=Xe();rH(n,R),rH(n,{system:R.system}),nH(n,R),nH(n,{system:R.system})}async function oH(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function fO(){return aH||(aH=ft({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function yH(){return cH||(cH=ft({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function tne(){bH=!0;let e=(0,K_.get)(x.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await Xre(mH,e),await oH(fO(),Zre),await oH(yH(),ene)},Math.min(e/2,2147483647)).unref()}function OH(e,t){let r=e.report;r.threadId=t?.threadId||cl.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(lH+=n.mean*n.count);r.totalBytesProcessed=lH,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(uH.get(t))}),uH.set(t,t.performance.eventLoopUtilization())),r.id=(0,V_.getNextMonotonicTime)(),fO().primaryStore.put(r.id,r),bH||tne(),rne&&(NH=sne(r))}async function sne(e){if(await NH,!Ca){let r=(0,$_.dirname)((0,fH.getLogFilePath)());try{Ca=await(0,dO.open)((0,$_.join)(r,"analytics.log"),"r+")}catch{Ca=await(0,dO.open)((0,$_.join)(r,"analytics.log"),"w+")}}let t=(await Ca.stat()).size;if(t>nne){let r=Buffer.alloc(t);await Ca.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Ca.write(r,{position:0}),await Ca.truncate(r.length),t=r.length}await Ca.write(JSON.stringify(e)+`
21
+ `,t)}var cl,dH,fH,_H,$_,dO,V_,K_,pH,ll,QE,hH,JE,mH,EH,gH,SH,sH,iH,q_,RH,Zre,ene,aH,cH,bH,lH,uH,rne,NH,Ca,nne,ki=be(()=>{cl=require("worker_threads"),dH=M(rt());De();fH=M(z()),_H=M(Ni()),$_=require("path"),dO=require("fs/promises"),V_=M(_n()),K_=M(ae());H();Vr();pH=M(require("node:fs")),ll=(0,_H.loggerWithTag)("analytics");(0,K_.initSync)();QE=new Map,hH=(0,K_.get)(x.ANALYTICS_AGGREGATEPERIOD)>-1;a(Wre,"setAnalyticsEnabled");a(zre,"recordExistingAction");a(jre,"recordNewAction");a(sr,"recordAction");We.recordAnalytics=sr;a(Qn,"recordActionBinary");JE=0,mH=1e3,EH="analytics-report",gH=[];a(Y_,"addAnalyticsListener");SH=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(Jre,"sendAnalytics");a(XE,"storeMetric");a(TH,"calculateCPUUtilization");a(AH,"diffResourceUsage");a(Qre,"storeTableSizeMetrics");a(rH,"storeDBSizeMetrics");a(nH,"storeVolumeMetrics");a(Xre,"aggregation");sH=0,iH=0,q_={},RH=a(()=>new Promise(setImmediate),"rest");a(oH,"cleanup");Zre=36e5,ene=31536e6;a(fO,"getRawAnalyticsTable");a(yH,"getAnalyticsTable");(0,dH.setChildListenerByType)(EH,OH);a(tne,"startScheduledTasks");lH=0,uH=new Map,rne=!1;a(OH,"recordAnalytics");nne=1e6;a(sne,"logAnalytics")});var wH={};ve(wH,{Headers:()=>yo,appendHeader:()=>ZE,mergeHeaders:()=>_O});function ZE(e,t,r,n){if(e.append)e.append(t,r,n);else if(e.set){let s=e.get(t);if(s)if(n)r=(typeof s=="string"?s:s.join(", "))+", "+r;else if(typeof s=="string")r=[s,r];else{s.push(r);return}return e.set(t,r)}else e[t]=(e[t]?e[t]+", ":"")+r}function _O(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new yo(e));for(let[r,n]of t)e.has(r)?r.toLowerCase()==="set-cookie"&&e.append?.(r,n,!0):e.set(r,n);return e}var yo,z_=be(()=>{yo=class extends Map{static{a(this,"Headers")}constructor(t){if(t)if(t[Symbol.iterator])super(t);else{super();for(let r in t)this.set(r,t[r])}else super()}set(t,r){return typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r),super.set(t.toLowerCase(),[t,r])}get(t){return typeof t!="string"&&(t=""+t),super.get(t.toLowerCase())?.[1]}has(t){return typeof t!="string"&&(t=""+t),super.has(t.toLowerCase())}setIfNone(t,r){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let n=t.toLowerCase();if(!super.has(n))return super.set(n,[t,r])}append(t,r,n){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let s=t.toLowerCase(),i=super.get(s);if(i){let o=i[1];if(n)r=(typeof o=="string"?o:o.join(", "))+", "+r;else if(typeof o=="string")r=[o,r];else{o.push(r);return}}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}};a(ZE,"appendHeader");a(_O,"mergeHeaders")});function LH(e){let t={openapi:ine,info:{title:"HarperDB HTTP REST interface",version:DH.packageJson.version},paths:{},components:{schemas:{},securitySchemes:{basicAuth:{type:"http",scheme:"basic"},bearerAuth:{type:"http",scheme:"bearer",bearerFormat:"JWT"}}}},r=[{basicAuth:[],bearerAuth:[]}];for(let[,n]of e){if(!n.path||n.Resource.isError)continue;let{path:s}=n,i=s.split("/").slice(-1),{attributes:o,primaryKey:c,prototype:l}=n.Resource;if(c=c??"id",!c)continue;let u={},f=[];if(o)for(let{type:T,name:b,elements:v,relationship:F,definition:q}of o){if(F)T==="array"?u[b]={type:"array",items:{$ref:Pa+v.type}}:u[b]={$ref:Pa+T};else{let Y=q??v?.definition;if(Y){if(!t.components.schemas[Y.type]){let Z={};Y.properties.forEach(se=>{Z[se.name]=new EO(pO[se.type],se.type)}),t.components.schemas[Y.type]=new PH(Z)}T==="array"?u[b]={type:"array",items:{$ref:Pa+Y.type}}:u[b]={$ref:Pa+Y.type}}else T==="array"?v.type==="Any"||v.type=="ID"?u[b]={type:"array",items:{format:v.type}}:u[b]={type:"array",items:new EO(pO[v.type],v.type)}:T==="Any"||T=="ID"?u[b]={format:T}:u[b]=new EO(pO[T],T)}f.push(new gO(b,"query",u[b]))}let d=Object.keys(u),p=new gO(c,"path",{format:"ID"});p.required=!0,p.description="primary key of record";let _=new gO("property","path",{enum:d});_.required=!0,t.components.schemas[i]=new PH(u);let h=l.post!==Resource.prototype.post||l.update,S=typeof l.put=="function",g=typeof l.get=="function",R=typeof l.delete=="function",E="/"+s+"/";h&&(t.paths[E]={},t.paths[E].post=new one(i,r,"create a new record auto-assigning a primary key")),g&&(t.paths[E]||(t.paths[E]={}),t.paths[E].get=new hO(f,r,{200:new mO({$ref:Pa+i})},"search for records by the specified property name and value pairs")),R&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new CH(f,r,"delete all the records that match the provided query",{204:new IH})),E="/"+s+"/{"+c+"}",g&&(t.paths[E]={},t.paths[E].get=new hO([p],r,{200:new mO({$ref:Pa+i})},"retrieve a record by its primary key")),S&&(t.paths[E]||(t.paths[E]={}),t.paths[E].put=new ane([p],r,i,"create or update the record with the URL path that maps to the record's primary key")),R&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new CH([p],r,"delete a record with the given primary key",{204:new IH})),g&&_.schema.enum.length>0&&(E="/"+s+"/{"+c+"}.{property}",t.paths[E]={},t.paths[E].get=new hO([p,_],r,{200:new mO({enum:d})},"used to retrieve the specified property of the specified record"))}return t}function one(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:Pa+e}}}},this.security=t,this.responses={200:{description:SO,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function hO(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function mO(e){this.description=SO,this.content={"application/json":{schema:e}}}function IH(){this.description="successfully processed request, no content returned to client"}function ane(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:Pa+r}}}},this.responses={200:{description:SO}}}function CH(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function PH(e){this.type="object",this.properties=e}function EO(e,t){this.type=e,this.format=t}function gO(e,t,r){this.name=e,this.in=t,this.schema=r}var DH,ine,pO,Pa,SO,MH=be(()=>{DH=M(it()),ine="3.0.3",pO={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},Pa="#/components/schemas/",SO="successful operation";a(LH,"generateJsonApi");a(one,"Post");a(hO,"Get");a(mO,"Response200");a(IH,"Response204");a(ane,"Put");a(CH,"Delete");a(PH,"ResourceSchema");a(EO,"Type");a(gO,"Parameter")});var tg={};ve(tg,{parseHeaderValue:()=>AO,start:()=>une});async function lne(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream",s=n?"CONNECT":e.method;e.search&&Om(e);let i=new yo;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==vH){let g=eg.getMatch(o,n?"sse":"rest");if(!g)return t(e);e.handlerPath=g.path,c=new Cc(g.relativeURL),c.async=!0,l=g.Resource}if(l?.isCaching){let g=r["cache-control"];if(g){let R=AO(g);for(let E of R)switch(E.name){case"max-age":e.expiresAt=E.value*1e3+Date.now();break;case"only-if-cached":e.onlyIfCached=!0;break;case"no-cache":e.noCache=!0;break;case"no-store":e.noCacheStore=!0;break;case"stale-if-error":e.staleIfError=!0;break;case"must-revalidate":e.mustRevalidate=!0;break}}}let u=r["x-replicate-to"];if(u){let g=AO(u).map(R=>(R.next?.name==="confirm"&&R.next.value>=0&&(e.replicatedConfirmation=+R.next.value),R.name));e.replicateTo=g.length===1&&+g[0]>=0?+g[0]:g[0]==="*"?void 0:g}r["x-replicate-from"]==="none"&&(e.replicateFrom=!1);let d=await wt(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=uo(r["content-type"],!0)(e.body,e.headers)}catch(g){throw new Yu.ClientError(g,400)}if(e.authorize=!0,o===vH&&s==="GET"){if(e?.user?.role?.permission?.super_user)return LH(eg);throw new Yu.ServerError("Forbidden",403)}switch(s){case"GET":case"HEAD":return l.get(c,e);case"POST":return l.post(c,e.data,e);case"PUT":return l.put(c,e.data,e);case"DELETE":return l.delete(c,e);case"PATCH":return l.patch(c,e.data,e);case"OPTIONS":i.setIfNone("Allow","GET, HEAD, POST, PUT, DELETE, PATCH, OPTIONS, TRACE, QUERY, COPY, MOVE");return;case"CONNECT":return l.connect(c,null,e);case"TRACE":return"HarperDB is the terminating server";case"QUERY":return l.query(c,e.data,e);case"COPY":return l.copy(c,r.destination,e);case"MOVE":return l.move(c,r.destination,e);case"BREW":throw new Yu.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Yu.ServerError(`Method ${s} is not recognized`,501)}}),p=200,_;if(d==null)p=s==="GET"||s==="HEAD"?404:204,TO.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(d.status>0&&d.headers){let g=_O(d.headers,i);return d.headers!==g&&(d.headers=g),d.data!==void 0&&(d.body=Jf(d.data,e,d)),d}else if(_=e.lastModified){cne[0]=_;let g=String.fromCharCode(34,(Mr[0]&63)+62,(Mr[0]>>6)+(Mr[1]<<2&63)+62,(Mr[1]>>4)+(Mr[2]<<4&63)+62,(Mr[2]>>2)+62,(Mr[3]&63)+62,(Mr[3]>>6)+(Mr[4]<<2&63)+62,(Mr[4]>>4)+(Mr[5]<<4&63)+62,(Mr[5]>>2)+62,(Mr[6]&63)+62,(Mr[6]>>6)+(Mr[7]<<2&63)+62,34),R=r["if-none-match"];R&&g==R?(d?.onDone&&d.onDone(),p=304,d=void 0):i.setIfNone("ETag",g),TO.lastModified&&i.setIfNone("Last-Modified",new Date(_).toUTCString())}e.createdResource&&(p=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let h={status:p,headers:i,body:void 0},S=d?.wasLoadedFromSource?.();return S!==void 0&&(h.wasCacheMiss=S,!S&&_&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||_))/1e3))),d!==void 0&&(h.body=Jf(d,e,h),s==="HEAD"&&(h.body=void 0)),h}catch(o){o.statusCode?o.statusCode===500?Fi.warn(o):Fi.info(o):Fi.error(o),o.statusCode===405&&(o.method&&(o.message+=` to handle HTTP method ${o.method.toUpperCase()||""}`),o.allow&&(o.allow.push("trace","head","options"),i.setIfNone("Allow",o.allow.map(l=>l.toUpperCase()).join(", "))));let c={status:o.statusCode||500,headers:i,body:void 0};return c.body=Jf(o.contentType?o:o.toString(),e,c),c}}function une(e){TO=e,!UH&&(UH=!0,eg=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return lne(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{j_++;let s=new Bn;xH||(xH=!0,Y_(l=>{j_>0&&l.push({metric:"ws-connections",connections:j_,byThread:!0})}));let i;t.on("error",l=>{i=!0,Fi.warn(l)});let o;t.on("message",a(function(u){o||(o=uo(r.requestedContentType??r.headers.asObject["content-type"],!1));let f=o(u);sr(u.length,"bytes-received",r.handlerPath,"message","ws"),s.push(f)},"message"));let c;t.on("close",()=>{j_--,Qn(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),u=eg.getMatch(l,"ws");if(Qn(!!u,"connection","ws","connect"),u){r.handlerPath=u.path,sr(h=>({count:h.count,total:j_}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let f=new Cc(u.relativeURL),d=u.Resource;c=(await wt(r,()=>d.connect(f,s,r)))[Symbol.asyncIterator]();let _;for(;!(_=await c.next()).done;){let h=await Aa(_.value,r);t.send(h),sr(h.length,"bytes-sent",r.handlerPath,"message","ws"),t._socket.writableNeedDrain&&await new Promise(S=>t._socket.once("drain",S))}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){l.statusCode?l.statusCode===500?Fi.warn(l):Fi.info(l):Fi.error(l),t.close(dne[l.statusCode]||1011,l.toString())}t.close()},e))}function AO(e){return e.trim().split(",").map(t=>{let r,n=t.trim().split(";"),s;for(;s=n.pop();)if(s.includes("=")){let[i,o]=s.trim().split("=");i=i.trim(),o&&(o=o.trim()),r={name:i.toLowerCase(),value:o,next:r}}else r={name:s.toLowerCase(),next:r};return r})}var Fi,Yu,Mr,cne,TO,vH,UH,eg,xH,j_,dne,BH=be(()=>{ao();ki();Fi=M(z()),Yu=M(pe());Gf();pu();Ic();z_();MH();Gf();Mr=new Uint8Array(8),cne=new Float64Array(Mr.buffer,0,1),TO={},vH="openapi";a(lne,"http");j_=0;a(une,"start");dne={401:3e3,403:3003};a(AO,"parseHeaderValue")});var RO=w((qCe,kH)=>{var{recordAction:rg,recordActionBinary:HH}=(ki(),C(W_)),fne=require("fastify-plugin"),_ne=200;kH.exports=fne(function(e,t,r){e.addHook("onResponse",async(n,s)=>{let i=s.elapsedTime}),e.addHook("onSend",async(n,s,i)=>{let o=s.elapsedTime,c=performance.now(),l=s.request.routeOptions,u,f,d;l.config?.isOperation?(u=n.body?.operation,f="operation"):(u=l.url,f="fastify-route",d=l.method),rg(o,"duration",u,d,f),HH(s.raw.statusCode<400,"success",u,d,f),HH(1,"response_"+s.raw.statusCode,u,d,f);let p=_ne;i?.pipe?(i.on("data",g=>{p+=g.length}),i.on("end",()=>{rg(performance.now()-c,"transfer",u,d,f),rg(p,"bytes-sent",u,d,f)})):(p+=i?.length||0,rg(p,"bytes-sent",u,d,f));let _=o.toFixed(3),h=s.getHeader("Server-Timing"),S=`db;dur=${_}`;s.header("Server-Timing",h?`${h}, ${S}`:S)}),r()},{name:"hdb-request-time"})});var GH=w(($Ce,FH)=>{var pne=ot(),hne={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};FH.exports=function(e){return pne.validateObject(e,hne)}});var ng=w((VCe,qH)=>{"use strict";var mne=(H(),C(G)).OPERATIONS_ENUM,yO=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=mne.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};qH.exports=yO});var X_={};ve(X_,{createTokens:()=>gne,getJWTRSAKeys:()=>cg,refreshOperationToken:()=>Sne,validateOperationToken:()=>NO,validateRefreshToken:()=>lg});async function cg(){if(sg)return sg;try{let e=J_.default.join(Q_.default.getHdbBasePath(),zA),t=await ig.default.readFile(J_.default.join(e,Of.JWT_PASSPHRASE_NAME),"utf8"),r=await ig.default.readFile(J_.default.join(e,Of.JWT_PRIVATE_KEY_NAME),"utf8");return sg={publicKey:await ig.default.readFile(J_.default.join(e,Of.JWT_PUBLIC_KEY_NAME),"utf8"),privateKey:r,passphrase:t},sg}catch(e){throw ag.default.error(e),new ii.ClientError(zu.NO_ENCRYPTION_KEYS,Wu.INTERNAL_SERVER_ERROR)}}async function gne(e){let t=(0,bO.validateBySchema)(e,Gi.default.object({username:Gi.default.string().optional(),password:Gi.default.string().optional(),role:Gi.default.string().optional(),expires_in:Gi.default.alternatives(Gi.default.string(),Gi.default.number()).optional()}));if(t)throw new ii.ClientError(t.message);let r;try{let d=e.bypass_auth!==!0;!e.username&&!e.password&&(e.username=e.hdb_user?.username,d=!1),r=await(0,OO.findAndValidateUser)(e.username,e.password,d)}catch(d){throw ag.default.error(d),new ii.ClientError(zu.INVALID_CREDENTIALS,Wu.UNAUTHORIZED)}if(!r)throw new ii.ClientError(zu.INVALID_CREDENTIALS,Wu.UNAUTHORIZED);let n=!1,s=!1;r.role?.permission&&(n=r.role.permission.super_user===!0,s=r.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s};e.role&&(i.role=e.role);let o=await cg(),c=await ju.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:e.expires_in??WH,algorithm:og,subject:"operation"}),l=await ju.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:Ene,algorithm:og,subject:"refresh"}),u=Fy(l,"sha256");if((await(0,$H.update)(new VH.default(bf,fu.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]))).skipped_hashes.length>0)throw new ii.ClientError(zu.REFRESH_TOKEN_SAVE_FAILED,Wu.INTERNAL_SERVER_ERROR);return KH.default.signalUserChange(new YH.UserEventMsg(process.pid)),{operation_token:c,refresh_token:l}}async function Sne(e){let t=(0,bO.validateBySchema)(e,Gi.default.object({refresh_token:Gi.default.string().required()}).required());if(t)throw new ii.ClientError(t.message);let{refresh_token:r}=e;await lg(r);let n=await cg(),s=await ju.default.decode(r);return{operation_token:await ju.default.sign({username:s.username,super_user:s.super_user,cluster_user:s.cluster_user},{key:n.privateKey,passphrase:n.passphrase},{expiresIn:WH,algorithm:og,subject:"operation"})}}async function NO(e){return zH(e,"operation")}async function lg(e){return zH(e,"refresh")}async function zH(e,t){try{let r=await cg(),n=await ju.default.verify(e,r.publicKey,{algorithms:og,subject:t});if(n.role)throw new Error("Invalid token");let s=await(0,OO.findAndValidateUser)(n.username,void 0,!1);if(t==="refresh"&&!Gy(s.refresh_token,e))throw new Error("Invalid token");return s}catch(r){throw ag.default.warn(r),r?.name==="TokenExpiredError"?new ii.ClientError(zu.TOKEN_EXPIRED,Wu.FORBIDDEN):new ii.ClientError(zu.INVALID_TOKEN,Wu.UNAUTHORIZED)}}var ju,ig,J_,Gi,bO,ii,ag,OO,$H,VH,KH,YH,Q_,Wu,zu,WH,Ene,og,sg,Ju=be(()=>{ju=M(require("jsonwebtoken")),ig=M(require("fs-extra")),J_=M(require("node:path")),Gi=M(require("joi")),bO=M(ot());H();ii=M(pe()),ag=M(z());hE();OO=M(Rn()),$H=M(yn()),VH=M(ng()),KH=M(To()),YH=M(ri()),Q_=M(ae()),{HTTP_STATUS_CODES:Wu,AUTHENTICATION_ERROR_MSGS:zu}=ii.hdb_errors;Q_.default.initSync();WH=Q_.default.get(x.AUTHENTICATION_OPERATIONTOKENTIMEOUT)||"1d",Ene=Q_.default.get(x.AUTHENTICATION_REFRESHTOKENTIMEOUT)||"30d",og="RS256";a(cg,"getJWTRSAKeys");a(gne,"createTokens");a(Sne,"refreshOperationToken");a(NO,"validateOperationToken");a(lg,"validateRefreshToken");a(zH,"validateToken")});var wO=w((jCe,QH)=>{"use strict";var Tne=GH(),Qu=require("passport"),Ane=require("passport-local").Strategy,Rne=require("passport-http").BasicStrategy,yne=require("util"),bne=Rn(),JH=yne.callbackify(bne.findAndValidateUser),zCe=xn(),One=(H(),C(G)),jH=(Ju(),C(X_));Qu.use(new Ane(function(e,t,r){JH(e,t,r)}));Qu.use(new Rne(function(e,t,r){JH(e,t,r)}));Qu.serializeUser(function(e,t){t(null,e)});Qu.deserializeUser(function(e,t){t(null,e)});function Nne(e,t,r){if(e.raw?.user!==void 0)return r(null,e.raw.user);let n,s;if(e.headers?.authorization){let o=e.headers.authorization.split(" ");n=o[0],s=o[1]}function i(o,c){return o?r(o):c?r(null,c):r("Must login")}switch(a(i,"handleResponse"),n){case"Basic":Qu.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===One.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?jH.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):jH.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:Qu.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(Nne,"authorize");function wne(e,t){let r=Tne(e);if(r){t(r);return}let n={authorized:!0,messages:[]},s=e.user.role;if(!s?.permission)return t("Invalid role");let i=JSON.parse(s.permission);if(i.super_user)return t(null,n);if(!i[e.schema])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.schema} schema`),t(null,n);if(!i[e.schema].tables[e.table])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.table} table`),t(null,n);if(!i[e.schema].tables[e.table][e.operation])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.operation} on ${e.table} table`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&!e.attributes)return n.authorized=!1,n.messages.push(`${e.schema}.${e.table} has attribute permissions. Missing attributes to validate`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&e.attributes){let o=i[e.schema].tables[e.table].attribute_permissions;for(let c in o)e.attributes.indexOf(o[c].attribute_name)>-1&&!o[c][e.operation]&&(n.authorized=!1,n.messages.push(`Not authorized to ${e.operation} ${o[c].attribute_name} `))}return t(null,n)}a(wne,"checkPermissions");QH.exports={authorize:Nne,checkPermissions:wne}});var ug=w((QCe,XH)=>{"use strict";var Ine=Vn();XH.exports={writeTransaction:Cne};function Cne(e,t,r){return Ine.writeTransaction(e,t,r)}a(Cne,"writeTransaction")});var rk=w((ePe,tk)=>{"use strict";var Pne=Yr(),Dne=As(),ZH=z(),Lne=yn(),ZCe=ug(),Mne=require("clone"),CO=require("alasql"),vne=aE(),ek=require("util"),Une=ek.promisify(Dne.getTableSchema),xne=ek.promisify(Pne.search),Bne=(H(),C(G)),IO=ie();vne(CO);tk.exports={update:kne};var Hne="There was a problem performing this update. Please check the logs and try again.";async function kne({statement:e,hdb_user:t}){let r=await Une(e.table.databaseid,e.table.tableid),n=Fne(e.columns);IO.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=Mne(s),c=IO.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=CO.parse(l).statements[0],f=await xne(u),d=Gne(n,f);return qne(o,d,t)}a(kne,"update");function Fne(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=CO.compile(`SELECT ${r.expression.toString()} AS [${Bne.FUNC_VAL}] FROM ?`)}),t}catch(t){throw ZH.error(t),new Error(Hne)}}a(Fne,"createUpdateRecord");function Gne(e,t){return IO.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(Gne,"buildUpdateRecords");async function qne(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await Lne.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){ZH.error(`Error delete new_attributes from update response: ${i}`)}return s}a(qne,"updateRecords")});var sk=w((sPe,nk)=>{var $ne=require("alasql"),Vne=Yr(),Kne=z(),Yne=Vn(),DO=require("util"),PO=ie(),Wne=(H(),C(G)),zne=As(),rPe=ug(),nPe=yn(),jne="record",Jne="successfully deleted",Qne=DO.callbackify(tse),Xne=DO.promisify(Vne.search),Zne=DO.promisify(zne.getTableSchema);nk.exports={convertDelete:Qne};function ese(e){return`${e.deleted_hashes.length} ${jne}${e.deleted_hashes.length===1?"":"s"} ${Jne}`}a(ese,"generateReturnMessage");async function tse({statement:e,hdb_user:t}){let r=await Zne(e.table.databaseid,e.table.tableid);PO.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=PO.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=$ne.parse(o).statements[0],l={operation:Wne.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await Xne(c);let u=await Yne.deleteRecords(l);return PO.isEmptyOrZeroLength(u.message)&&(u.message=ese(u)),delete u.txn_time,u}catch(u){throw Kne.error(u),u.hdb_code?u.message:u}}a(tse,"convertDelete")});var lk=w((oPe,ck)=>{"use strict";var rse=go(),{hdb_errors:ik}=pe(),{getDatabases:ok}=(De(),C(nt));ck.exports={checkSchemaExists:ak,checkSchemaTableExists:nse,schema_describe:rse};async function ak(e){if(!ok()[e])return ik.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(ak,"checkSchemaExists");async function nse(e,t){let r=await ak(e);if(r)return r;if(!ok()[e][t])return ik.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(nse,"checkSchemaTableExists")});var xO=w((dPe,Ak)=>{"use strict";var{decode:sse}=require("msgpackr"),{isMainThread:cPe,parentPort:lPe,threadId:uPe}=require("worker_threads"),_g=ir(),Xu=Tt(),vO=(H(),C(G)),Jr=z(),MO=ae(),ise=(H(),C(G)),{onMessageByType:ose}=rt(),_k=Eo(),{recordAction:uk,recordActionBinary:ase}=(ki(),C(W_)),{publishToStream:cse}=_g,{ConsumerEvents:dk}=require("nats"),lse=Yr(),{promisify:use}=require("util"),{decodeBlobsWithWrites:dse}=(gs(),C(Gm)),pk=use(setTimeout),pg=1e4,hg,fg,fse,_se,hk,Z_=new Map,Zu=new Map;Ak.exports={initialize:mk,ingestConsumer:UO,setSubscription:pse,setIgnoreOrigin:Ese,getDatabaseSubscriptions:mse,updateConsumer:Ek};async function mk(){ose(vO.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await Ek(n)}),hk=!0,Jr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await _g.getNATSReferences();hg=e,fg=e.info.server_name,fse=t,_se=r}a(mk,"initialize");async function Ek(e){if(e.status==="start"){let{js:t,jsm:r}=await gk(e.node_domain_name);UO(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=Z_.get(e.stream_name+e.node_domain_name);t&&(Jr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),Z_.set(e.stream_name+e.node_domain_name,"close")),Zu.get(e.node_domain_name)==="failed"&&Zu.set(e.node_domain_name,"close")}}a(Ek,"updateConsumer");var mg=new Map;function pse(e,t,r){let n=mg.get(e);n||mg.set(e,n=new Map),n.set(t,r),hk||mk().then(hse)}a(pse,"setSubscription");async function hse(){let e=await lse.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+Xu.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions||[])if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await gk(r),!n))break;let{schema:o,table:c}=i,l=_k.createNatsTableStreamName(o,c);UO(l,n,s,r)}}}a(hse,"accessConsumers");async function gk(e){let t,r,n=1;for(;!r;)try{t=await hg.jetstream({domain:e}),r=await hg.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(Zu.get(e)==="close")break;Zu.set(e,"failed"),n%10===1&&Jr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<pg?n++*100:pg;await pk(i)}return{js:t,jsm:r}}a(gk,"connectToRemoteJS");function mse(){return mg}a(mse,"getDatabaseSubscriptions");var Sk;function Ese(e){Sk=e}a(Ese,"setIgnoreOrigin");var Tk=100,fk=new Array(Tk),dg=0;async function UO(e,t,r,n){let{connection:s}=await _g.getNATSReferences();hg=s,fg=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,fg),Jr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(Zu.get(n)==="close")break;o%10===1&&Jr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",u.message),u.code==="404"&&(Jr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await _g.createConsumer(r,e,fg,new Date(Date.now()).toISOString()));let f=o++*100<pg?o++*100:pg;await pk(f)}let c=!1,l;for(;!c;){if(Z_.get(e+n)==="close"||Zu.get(n)==="close"){Z_.delete(e+n),c=!0;continue}l=await i.consume({max_messages:MO.get(vO.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),Z_.set(e+n,l);let u=!1;(async()=>{for await(let f of await l.status())if(f.type===dk.ConsumerDeleted&&(await l.close(),c=!0),f.type===dk.HeartbeatsMissed){let d=f.data;Jr.trace(`${d} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),d===100&&(Jr.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${l.consumer.stream}`),l.stop(),u=!0)}})();try{for await(let f of l)await fk[dg],fk[dg]=gse(f).catch(d=>{Jr.error(d)}),++dg>=Tk&&(dg=0)}catch(f){f.message==="consumer deleted"?(Jr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):Jr.error("Error consuming clustering ingest, restarting consumer",f)}}}a(UO,"ingestConsumer");async function gse(e){let t;await dse(()=>{t=sse(e.data)}),uk(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),Jr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=MO.get(vO.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(Xu.MSG_HEADERS.TRANSACTED_NODES)&&r.values(Xu.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(Xu.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!Sk),ase(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(Xu.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:u,records:f,hash_values:d,__origin:p,expiresAt:_}=t;Jr.trace("processing message:",o,c,u,(f?"records: "+f.map(v=>v?.id):"")+(d?"ids: "+d:""),"with sequence:",e.seq),Jr.trace(`messageProcessor nats msg id: ${e.headers.get(Xu.MSG_HEADERS.NATS_MSG_ID)}`);let h;f||(f=d);let S=new Promise(v=>h=v),{timestamp:g,user:R,node_name:E}=p||{},T=mg.get(c)?.get(u);if(!T)throw new Error(`Missing table for replication message: ${u}`);if(o==="define_schema")t.type=o,t.onCommit=h,T.send(t);else if(f.length===1&&!l)T.send({type:LO(o),value:f[0],id:d?.[0],expiresAt:_,timestamp:g,table:u,onCommit:h,user:R,nodeName:E});else{let v=f.map((F,q)=>({type:LO(o),value:F,expiresAt:_,id:d?.[q],table:u}));for(;l;)v.push({type:LO(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;T.send({type:"transaction",writes:v,table:u,timestamp:g,onCommit:h,user:R,nodeName:E})}MO.get(ise.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&cse(e.subject.split(".").slice(0,-1).join("."),_k.createNatsTableStreamName(c,u),e.headers,e.data),await S;let b=Date.now()-g;g&&uk(b,"replication-latency",e.subject,o,"ingest")}catch(o){Jr.error(o)}e.ack()}a(gse,"messageProcessor");function LO(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(LO,"convertOperation")});var ir=w((gPe,Hk)=>{"use strict";var wr=ae();wr.initSync();var Sse=require("fs-extra"),Tse=require("semver"),rp=require("path"),{monotonicFactory:Ase}=require("ulidx"),yk=Ase(),Rse=require("util"),bk=require("child_process"),yse=Rse.promisify(bk.exec),bse=bk.spawn,vr=Tt(),$e=(H(),C(G)),{packageJson:Ose,PACKAGE_ROOT:Nse}=it(),Eg=ie(),oi=z(),gg=Eo(),wse=ug(),ep=yt(),{broadcast:Ise,onMessageByType:Cse,getWorkerIndex:Pse}=rt(),{isMainThread:Ok}=require("worker_threads"),{Encoder:Dse,decode:FO}=require("msgpackr"),Nk=new Dse,{isEmpty:_l}=Eg,wk=Rn(),_Pe=48*36e11;Ok&&Cse($e.ITC_EVENT_TYPES.RESTART,()=>{Qr=void 0,fl=void 0});var{connect:Lse,StorageType:Mse,RetentionPolicy:vse,AckPolicy:GO,DeliverPolicy:qO,DiscardPolicy:Use,NatsConnection:pPe,JetStreamManager:hPe,JetStreamClient:mPe,StringCodec:EPe,JSONCodec:xse,createInbox:$O,headers:Bse,ErrorCode:Rk}=require("nats"),{recordAction:Hse}=(ki(),C(W_)),{encodeBlobsAsBuffers:kse}=(gs(),C(Gm)),Ik=xse(),Fse="clustering",Gse=Ose.engines[vr.NATS_SERVER_NAME],qse=rp.join(Nse,"dependencies"),kO=rp.join(qse,`${process.platform}-${process.arch}`,vr.NATS_BINARY_NAME),BO,HO,tp,ul,dl;Hk.exports={runCommand:Ck,checkNATSServerInstalled:$se,createConnection:VO,getConnection:np,getJetStreamManager:sp,getJetStream:Dk,getNATSReferences:qi,getServerList:Kse,createLocalStream:KO,listStreams:Lk,deleteLocalStream:Yse,getServerConfig:ed,listRemoteStreams:Wse,viewStream:zse,viewStreamIterator:jse,publishToStream:Jse,request:Zse,reloadNATS:YO,reloadNATSHub:eie,reloadNATSLeaf:tie,extractServerName:Xse,requestErrorHandler:rie,createLocalTableStream:xk,createTableStreams:iie,purgeTableStream:Bk,purgeSchemaTableStreams:oie,getStreamInfo:aie,updateLocalStreams:lie,closeConnection:Vse,getJsmServerName:Sg,addNatsMsgHeader:Mk,clearClientCache:Pk,updateRemoteConsumer:nie,createConsumer:vk,updateConsumerIterator:sie};async function Ck(e,t=void 0){let{stdout:r,stderr:n}=await yse(e,{cwd:t});if(n)throw new Error(n.replace(`
22
22
  `,""));return r.replace(`
23
- `,"")}a(Ik,"runCommand");async function Vse(){try{await Tse.access(HO)}catch{return!1}let e=await Ik(`${HO} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return Ase.eq(t,qse)}a(Vse,"checkNATSServerInstalled");async function $O(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await Nk.getClusterUser();if(ll(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}oi.trace("create nats connection called");let i=await Mse({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:Nr.get($e.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:Nr.get($e.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:Nr.get($e.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),oi.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&oi.error("Error with Nats client connection, connection closed",o),i===Qr&&Ck()}),i}a($O,"createConnection");function Ck(){Qr=void 0,ol=void 0,al=void 0,cl=void 0}a(Ck,"clearClientCache");async function Kse(){Qr&&(await Qr.drain(),Qr=void 0,ol=void 0,al=void 0,cl=void 0)}a(Kse,"closeConnection");var Qr,cl;async function np(){return cl||(cl=$O(Nr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),Qr=await cl),Qr||cl}a(np,"getConnection");async function sp(){if(ol)return ol;ll(Qr)&&await np();let{domain:e}=Zu($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(ll(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return ol=await Qr.jetstreamManager({domain:e,timeout:6e4}),ol}a(sp,"getJetStreamManager");async function Pk(){if(al)return al;ll(Qr)&&await np();let{domain:e}=Zu($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(ll(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return al=Qr.jetstream({domain:e,timeout:6e4}),al}a(Pk,"getJetStream");async function qi(){let e=Qr||await np(),t=ol||await sp(),r=al||await Pk();return{connection:e,jsm:t,js:r}}a(qi,"getNATSReferences");async function Yse(e){let t=Nr.get($e.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await Nk.getClusterUser(),s=await $O(t,r,n),i=qO(),o=s.subscribe(i),c=[],l,u=(async()=>{for await(let f of o){let d=wk.decode(f.data);d.response_time=Date.now()-l,c.push(d)}})();return l=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await mg.async_set_timeout(e),await o.drain(),await s.close(),await u,c}a(Yse,"getServerList");async function VO(e,t){let{jsm:r}=await qi(),n=Nr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Nr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=Nr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:vse.File,retention:Use.Limits,subjects:t,discard:xse.Old,max_msgs:s,max_bytes:i,max_age:n})}a(VO,"createLocalStream");async function Dk(){let{jsm:e}=await qi(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(Dk,"listStreams");async function Wse(e){let{jsm:t}=await qi();await t.streams.delete(e)}a(Wse,"deleteLocalStream");async function zse(e){let{connection:t}=await qi(),r=[],n=qO(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(wk.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(zse,"listRemoteStreams");async function jse(e,t=void 0,r=void 0){let{jsm:n,js:s}=await qi(),i=Rk(),o={durable_name:i,ack_policy:FO.Explicit};t&&(o.deliver_policy=GO.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let u=[];for await(let f of l){let d=kO(f.data),p={nats_timestamp:f.info.timestampNanos,nats_sequence:f.info.streamSequence,entry:d};if(f.headers&&(p.origin=f.headers.get(Mr.MSG_HEADERS.ORIGIN)),u.push(p),f.ack(),f.info.pending===0)break}return await c.delete(),u}a(jse,"viewStream");async function*Jse(e,t=void 0,r=void 0){let{jsm:n,js:s}=await qi(),i=Rk(),o={durable_name:i,ack_policy:FO.Explicit};t&&(o.deliver_policy=GO.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let u of l){let f=kO(u.data);f[0]||(f=[f]);for(let d of f){let p={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:d};u.headers&&(p.origin=u.headers.get(Mr.MSG_HEADERS.ORIGIN)),yield p}if(u.ack(),u.info.pending===0)break}await c.delete()}a(Jse,"viewStreamIterator");async function Qse(e,t,r,n){oi.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=Lk(n,r);let{js:s}=await qi(),i=await gg(),o=`${e}.${i}`,c=await Fse(()=>n instanceof Uint8Array?n:Ok.encode(n));try{oi.trace(`publishToStream publishing to subject: ${o}`),kse(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 vk(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){oi.trace(`publishToStream creating stream: ${t}`);let f=o.split(".");f[2]="*",await VO(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(Qse,"publishToStream");function Lk(e,t){t===void 0&&(t=Hse());let r=Nr.get($e.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Mr.MSG_HEADERS.ORIGIN)&&r&&t.append(Mr.MSG_HEADERS.ORIGIN,r),t}a(Lk,"addNatsMsgHeader");function Zu(e){e=e.toLowerCase();let t=rp.join(Nr.get($e.CONFIG_PARAMS.ROOTPATH),Gse);if(e===$e.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return ll(BO)&&(BO={port:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+Mr.SERVER_SUFFIX.HUB,config_file:Mr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:rp.join(t,Mr.PID_FILES.HUB),hdb_nats_path:t}),BO;if(e===$e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return ll(xO)&&(xO={port:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+Mr.SERVER_SUFFIX.LEAF,config_file:Mr.NATS_CONFIG_FILES.LEAF_SERVER,domain:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+Mr.SERVER_SUFFIX.LEAF,pid_file_path:rp.join(t,Mr.PID_FILES.LEAF),hdb_nats_path:t}),xO;oi.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(Zu,"getServerConfig");async function Mk(e,t,r,n){try{await e.consumers.add(t,{ack_policy:FO.Explicit,durable_name:r,deliver_policy:GO.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(Mk,"createConsumer");async function Xse(e,t,r){await e.consumers.delete(t,r)}a(Xse,"removeConsumer");function Zse(e){return e.split(".")[1]}a(Zse,"extractServerName");async function eie(e,t,r=6e4,n=qO()){if(!mg.isObject(t))throw new Error("data param must be an object");let s=Ok.encode(t),{connection:i}=await qi(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return kO(c.data)}a(eie,"request");function KO(e){return new Promise(async(t,r)=>{let n=Ose(HO,["--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(KO,"reloadNATS");async function tie(){let{pid_file_path:e}=Zu($e.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await KO(e)}a(tie,"reloadNATSHub");async function rie(){let{pid_file_path:e}=Zu($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await KO(e)}a(rie,"reloadNATSLeaf");function nie(e,t,r){let n;switch(e.code){case Ak.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case Ak.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(nie,"requestErrorHandler");async function sie(e,t){let r=t+Mr.SERVER_SUFFIX.LEAF,{connection:n}=await qi(),{jsm:s}=await fie(r),{schema:i,table:o}=e,c=Eg.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await vk(async()=>{if(e.subscribe===!0)await Mk(s,c,n.info.server_name,l);else try{await Xse(s,c,n.info.server_name)}catch(u){oi.trace(u)}})}a(sie,"updateRemoteConsumer");async function iie(e,t,r,n){let s=Eg.createNatsTableStreamName(e,t),i=r+Mr.SERVER_SUFFIX.LEAF,o={type:$e.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!bk&&Dse()<Nr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=UO();await c(o)}await Cse(o),n==="stop"&&await mg.async_set_timeout(1e3)}a(iie,"updateConsumerIterator");function vk(e){return Ise.writeTransaction($e.SYSTEM_SCHEMA_NAME,$e.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(vk,"exclusiveLock");async function Uk(e,t){let r=Eg.createNatsTableStreamName(e,t),n=await gg(),s=lie(e,t,n);await VO(r,[s])}a(Uk,"createLocalTableStream");async function oie(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await Uk(n,s)}}a(oie,"createTableStreams");async function xk(e,t,r=void 0){if(Nr.get($e.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=Eg.createNatsTableStreamName(e,t),{domain:s}=Zu($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await np()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")oi.warn(n);else throw n}}a(xk,"purgeTableStream");async function aie(e,t){if(Nr.get($e.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await xk(e,t[r])}a(aie,"purgeSchemaTableStreams");async function cie(e){return(await sp()).streams.info(e)}a(cie,"getStreamInfo");function lie(e,t,r){return`${Mr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(lie,"createSubjectName");async function gg(){if(tp)return tp;if(tp=(await sp())?.nc?.info?.server_name,tp===void 0)throw new Error("Unable to get jetstream manager server name");return tp}a(gg,"getJsmServerName");async function uie(){let e=await sp(),t=await gg(),r=await Dk();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=die(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let u=i.split(".");u[u.length-1]=t;let f=u.join(".");oi.trace(`Updating stream subject name from: ${i} to: ${f}`),s.subjects[0]=f,await e.streams.update(s.name,s)}}a(uie,"updateLocalStreams");function die(e){let{config:t}=e,r=!1,n=Nr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Nr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=Nr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}a(die,"updateStreamLimits");async function fie(e){let t,r;try{t=await Qr.jetstream({domain:e}),r=await Qr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw oi.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(fie,"connectToRemoteJS")});function YO(e){let t=e.get(Sg),r=t?(0,ed.unpack)(t):null;r||(r={remoteNameToId:{}});let n=Xe(),s=!1;r.nodeName=Xe();let i=r.remoteNameToId;if(i[n]!==0){let o=0,c;for(let l in i){let u=i[l];u===0?c=l:u>o&&(o=u)}if(c){o++,i[c]=o;let l=[Symbol.for("seq"),o];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:op(e)??1,nodes:[]})})}i[n]=0,e.putSync(Sg,(0,ed.pack)(r))}return r}function ip(e){return YO(e).remoteNameToId}function kk(e,t){let r=YO(t),n=r.remoteNameToId,s=new Map,i=!1;for(let o in e){let c=e[o],l=n[o];if(l==null){let u=0;for(let f in n){let d=n[f];d>u&&(u=d)}l=u+1,n[o]=l,i=!0}s.set(c,l)}return i&&t.putSync(Sg,(0,ed.pack)(r)),s}function Tg(e,t){let r=YO(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(Sg,(0,ed.pack)(r))}return Hk.trace?.("The remote node name map",e,n,s),s}var Hk,ed,Sg,WO=be(()=>{Hk=M(Ni());Xn();ed=require("msgpackr"),Sg=Symbol.for("remote-ids");a(YO,"getIdMappingRecord");a(ip,"exportIdMapping");a(kk,"remoteToLocalNodeId");a(Tg,"getIdOfRemoteNode")});var zO={};ve(zO,{commits_awaiting_replication:()=>rd,getHDBNodeTable:()=>or,getReplicationSharedStatus:()=>Ag,iterateRoutes:()=>cp,shouldReplicateToNode:()=>ap,subscribeToNodeUpdates:()=>nd});function or(){return Fk||(Fk=ft({table:"hdb_nodes",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"ca"},{attribute:"ca_info"},{attribute:"replicates"},{attribute:"revoked_certificates"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function Ag(e,t,r,n){return new Float64Array(e.getUserSharedBuffer(["replicated",t,r],new ArrayBuffer(32),n&&{callback:n}))}function nd(e){or().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;Vk.debug?.("adding node",n,"on node",Xe()," on process",process.pid),server.nodes=server.nodes.filter(i=>i.name!==n),r.type==="put"&&n!==Xe()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r));let s=new Map;for await(let i of or().search({}))if(i.shard!=null){let o=s.get(i.shard);o||s.set(i.shard,o=[]),o.push(i)}server.shards=s,(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function ap(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&or().primaryStore.get(Xe())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function _ie(){nd(e=>{Da({},(t,r)=>{let n=e.name,s=Gk.get(n);if(s||Gk.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=Ag(i,r,n,()=>{let c=o[0],l=o.lastTime;for(let{txnTime:u,onConfirm:f}of rd.get(r)||[])u>l&&u<=c&&f();o.lastTime=c});o.lastTime=0,s.set(r,o)}})})}function*cp(e){for(let t of e.routes||[]){let r=t.url,n;if(typeof t=="string"?t.includes("://")?r=t:n=t:n=t.hostname??t.host,n&&!r){let s=td.default.get(B.REPLICATION_SECUREPORT)??(!td.default.get(B.REPLICATION_PORT)&&td.default.get(B.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||td.default.get(B.REPLICATION_PORT)||td.default.get(B.OPERATIONSAPI_NETWORK_PORT);let o=i?.lastIndexOf?.(":");o>0&&(i=+i.slice(o+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){qk.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{replicates:!t.subscriptions,url:r,subscription:t.subscriptions,routes:t.routes,start_time:t.startTime,revoked_certificates:t.revokedCertificates,shard:t.shard}}}var qk,$k,td,Vk,Fk,Gk,rd,ul=be(()=>{Pe();Xn();Am();qk=require("worker_threads"),$k=M(pe()),td=M(ae());H();Vk=M(Ni());server.nodes=[];a(or,"getHDBNodeTable");a(Ag,"getReplicationSharedStatus");a(nd,"subscribeToNodeUpdates");a(ap,"shouldReplicateToNode");Gk=new Map;AL((e,t,r)=>{if(r>server.nodes.length)throw new $k.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);rd||(rd=new Map,_ie());let n=rd.get(e);return n||(n=[],rd.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(_ie,"startSubscriptionToReplications");a(cp,"iterateRoutes")});var zk={};ve(zk,{connectedToNode:()=>dl,disconnectedFromNode:()=>od,ensureNode:()=>Oo,requestClusterStatus:()=>Wk,startOnMainThread:()=>JO});async function JO(e){let t=0,r=Qe();for(let i of Object.getOwnPropertyNames(r)){let o=r[i];for(let c in o){let l=o[c];if(l.auditStore){Rg.set(i,op(l.auditStore));break}}}$i.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes?.search([])||[])i.push(o);for(let o of cp(e))try{let c=!o.subscriptions;if(c){let u=Xe();or().primaryStore.get(u)===void 0&&await Oo(u,{name:u,url:e.url??La(),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)}nd(s)});let n;function s(i,o=i?.name){let c=Xe()&&o===Xe()||La()&&i?.url===La();if(c){let d=!!i?.replicates;if(n!==void 0&&n!==d)for(let p of or().search([]))p.replicates&&p.name!==o&&s(p,p.name);n=d}if(at.trace("Setting up node replication for",i),!i){for(let[d,p]of bo){let _;for(let[h,{worker:S,nodes:g}]of p){let R=g[0];if(R&&R.name==o){_=!0;for(let[E,{worker:T}]of p)p.delete(E),at.warn("Node was deleted, unsubscribing from node",o,E,d),T?.postMessage({type:"unsubscribe-from-node",node:o,database:E,url:d});break}}if(_){bo.get(d).iterator.remove(),bo.delete(d);return}}return}if(c)return;if(!i.url){at.info(`Node ${i.name} is missing url`);return}let l=bo.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(at.info(`Added node ${i.name} at ${i.url} for process ${Xe()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[d,p]of sd)if(i.url===p.url){sd.delete(d);break}sd.set(i.name,i)}let u=Qe();if(l||(l=new Map,bo.set(i.url,l)),l.iterator=Da(e,(d,p,_)=>{_?f(p,!0):f(p,!1)}),i.subscriptions)for(let d of i.subscriptions){let p=d.database||d.schema;u[p]||(at.warn(`Database ${p} not found for node ${i.name}, making a subscription anyway`),f(p,!1))}function f(d,p){at.trace("Setting up replication for database",d,"on node",i.name);let _=l.get(d),h,S=[{replicateByDefault:p,...i}];Rg.has(d)&&(S.push({replicateByDefault:p,name:Xe(),start_time:Rg.get(d),end_time:Date.now(),replicates:!0}),Rg.delete(d));let g=ap(i,d),R=$i.workers.filter(E=>E.name==="http");if(_?(h=_.worker,_.nodes=S):g&&(t=t%R.length,h=R[t++],l.set(d,{worker:h,nodes:S,url:i.url}),h?.on("exit",()=>{l.get(d)?.worker===h&&(l.delete(d),f(d,p))})),g)setTimeout(()=>{let E={type:"subscribe-to-node",database:d,nodes:S};h?h.postMessage(E):id(E)},pie);else{at.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[d],or().primaryStore.get(Xe())?.replicates),or().primaryStore.get(Xe())?.replicates||(n=!1);let E={type:"unsubscribe-from-node",database:d,url:i.url,name:i.name};h?h.postMessage(E):bg(E)}}a(f,"onDatabase")}a(s,"onNodeUpdate"),od=a(function(i){try{at.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(sd.keys()),c=o.sort(),l=c.indexOf(i.name||ai(i.url));if(l===-1){at.warn("Disconnected node not found in node map",i.name,o);return}let u=bo.get(i.url),f=u?.get(i.database);if(!f){at.warn("Disconnected node not found in replication map",i.database,u);return}if(f.connected=!1,i.finished)return;let d=f.nodes[0];if(!(d.replicates===!0||d.replicates?.sends||d.subscriptions?.length))return;let p=(l+1)%c.length;for(;l!==p;){let _=c[p],h=sd.get(_);u=bo.get(h.url);let S=u?.get(i.database);if(!S){p=(p+1)%c.length;continue}let{worker:g,nodes:R}=S,E=!1;for(let T of f.nodes){if(R.some(b=>b.name===T.name)){at.info(`Disconnected node is already failing over to ${_} for ${i.database}`);continue}R.push(T),E=!0}if(!E){at.info(`Disconnected node ${i.name} has no nodes to fail over to ${_}`);return}f.redirectingTo=S,at.info(`Failing over ${i.database} from ${i.name} to ${_}`),g?g.postMessage({type:"subscribe-to-node",database:i.database,nodes:R}):id({database:i.database,nodes:R});return}at.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){at.error("Error failing over node",o)}},"disconnectedFromNode"),dl=a(function(i){let o=bo.get(i.url),c=o?.get(i.database);if(!c){at.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,o);return}if(c.connected=!0,c.latency=i.latency,c.redirectingTo){let{worker:l,nodes:u}=c.redirectingTo,f=u.find(d=>d.name===i.name);c.redirectingTo=null,f&&(u.splice(u.indexOf(f),1),l?l.postMessage({type:"subscribe-to-node",database:i.database,nodes:u}):id({database:i.database,nodes:u}))}},"connectedToNode"),(0,$i.onMessageByType)("disconnected-from-node",od),(0,$i.onMessageByType)("connected-to-node",dl),(0,$i.onMessageByType)("request-cluster-status",Wk)}function Wk(e,t){let r=[];for(let[n,s]of sd)try{let i=bo.get(s.url);at.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let o=[];if(i){for(let[l,{worker:u,connected:f,nodes:d,latency:p}]of i)o.push({database:l,connected:f,latency:p,thread_id:u?.threadId,nodes:d.map(_=>_.name)});let c=(0,jO.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){at.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function Oo(e,t){let r=or();e=e??ai(t.url),t.name=e;try{if(t.ca){let s=new Yk.X509Certificate(t.ca);t.ca_info={issuer:s.issuer.replace(/\n/g," "),subject:s.subject.replace(/\n/g," "),subject_alt_name:s.subjectAltName,serial_number:s.serialNumber,valid_from:s.validFrom,valid_to:s.validTo}}}catch(s){at.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(at.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.put(t);else{t.replicates&&!Kk.default.get(B.CLUSTERING_ENABLED)&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],o=(0,jO.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let u of o)if((c.database??c.schema)===(u.database??u.schema)&&c.table===u.table){u.publish=c.publish,u.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...o,...i];break}if(Array.isArray(t.revoked_certificates)){let s=n.revoked_certificates||[];t.revoked_certificates=[...new Set([...s,...t.revoked_certificates])]}at.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var $i,yg,at,jO,Kk,Yk,pie,bo,od,dl,sd,Rg,lp=be(()=>{Pe();$i=M(et());Xn();yg=require("worker_threads");ul();at=M(z()),jO=require("lodash"),Kk=M(ae());H();Yk=require("crypto"),pie=200,bo=new Map,sd=new Map,Rg=new Map;a(JO,"startOnMainThread");a(Wk,"requestClusterStatus");yg.parentPort&&(od=a(e=>{yg.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),dl=a(e=>{yg.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,$i.onMessageByType)("subscribe-to-node",e=>{id(e)}),(0,$i.onMessageByType)("unsubscribe-from-node",e=>{bg(e)}));a(Oo,"ensureNode")});var Zn=w(EF=>{"use strict";var ar=require("path"),On=require("fs-extra"),ad=require("node-forge"),eF=require("net"),{generateKeyPair:XO,X509Certificate:No,createPrivateKey:tF}=require("crypto"),hie=require("util");XO=hie.promisify(XO);var bt=ad.pki,ci=require("joi"),{v4:rF}=require("uuid"),{validateBySchema:rN}=it(),pt=z(),ys=ae(),bs=(H(),C(G)),{CONFIG_PARAMS:cd}=bs,li=$y(),{ClientError:va}=pe(),Og=require("node:tls"),{relative:nF,join:mie}=require("node:path"),{CERT_PREFERENCE_APP:LPe,CERTIFICATE_VALUES:jk}=li,Eie=ua(),ZO=yt(),{table:gie,getDatabases:Sie,databases:QO}=(Pe(),C(tt)),{getJWTRSAKeys:Jk}=(ju(),C(X_));Object.assign(EF,{generateKeys:iN,updateConfigCert:dF,createCsr:wie,signCertificate:Iie,setCertTable:ld,loadCertificates:cF,reviewSelfSignedCert:aN,createTLSSelector:_F,listCertificates:hF,addCertificate:vie,removeCertificate:xie,createNatsCerts:Die,generateCertsKeys:Pie,getReplicationCert:dp,getReplicationCertAuth:Nie,renewSelfSigned:Lie,hostnamesFromCert:mF,getKey:Bie});var{urlToNodeName:sF,getThisNodeUrl:Tie,getThisNodeName:wg,clearThisNodeName:Aie}=(Xn(),C(wo)),{readFileSync:Rie,watchFile:yie,statSync:iF}=require("node:fs"),MPe=ae(),{getTicketKeys:bie,onMessageFromWorkers:Oie}=et(),Ma=z(),{isMainThread:oF}=require("worker_threads"),{TLSSocket:aF,createSecureContext:vPe}=require("node:tls"),nN=3650,up=["127.0.0.1","localhost","::1"],sN=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];Oie(async e=>{e.type===bs.ITC_EVENT_TYPES.RESTART&&(ys.initSync(!0),await aN())});var vr;function xa(){return vr||(vr=Sie().system.hdb_certificate,vr||(vr=gie({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__"}]}))),vr}a(xa,"getCertTable");async function dp(){let e=_F("operations-api"),t={secureContexts:null,setSecureContext:a(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(wg());if(!r)return;let n=new No(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(dp,"getReplicationCert");async function Nie(){xa();let e=(await dp()).options.cert,r=new No(e).issuer.match(/CN=(.*)/)?.[1];return vr.get(r)}a(Nie,"getReplicationCertAuth");var Qk,Ua=new Map;function cF(){if(Qk)return;Qk=!0;let e=[{configKey:cd.TLS},{configKey:cd.OPERATIONSAPI_TLS}];xa();let t=ar.dirname(ZO.getConfigFilePath()),r;for(let{configKey:n}of e){let s=ZO.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&nF(mie(t,"keys"),o);c&&Xk(o,l=>{Ua.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&oF){let f;Xk(u,d=>{if(jk.cert===d)return;let p=i.hostname??i.hostnames??i.host??i.hosts;p&&!Array.isArray(p)&&(p=[p]);let _=fF(u),h=new No(_),S;try{S=cN(h)}catch(T){pt.error("error extracting common name from certificate",T);return}if(S==null){pt.error("error extracting common name from certificate");return}if(h.checkIssued(new No(jk.cert)))return;let g=vr.primaryStore.get(S),R=iF(u).mtimeMs,E=!g||g.is_self_signed?1:g.file_timestamp??g.__updatedtime__;if(g&&R<=E){R<E&&pt.info(`Certificate ${S} at ${u} is older (${new Date(R)}) than the certificate in the database (${E>1?new Date(E):"only self signed certificate available"})`);return}r=vr.put({name:S,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:_,private_key_name:c,is_authority:l,hostnames:p,file_timestamp:R,details:{issuer:h.issuer.replace(/\n/g," "),subject:h.subject.replace(/\n/g," "),subject_alt_name:h.subjectAltName,serial_number:h.serialNumber,valid_from:h.validFrom,valid_to:h.validTo}})},l?"certificate authority":"certificate")}}}}}return r}a(cF,"loadCertificates");function Xk(e,t,r){let n,s=a((i,o)=>{try{let c=i.mtimeMs;c&&c!==n&&(o&&oF&&pt.warn(`Reloading ${r}:`,e),n=c,t(fF(e)))}catch(c){pt.error(`Error loading ${r}:`,e,c)}},"loadFile");On.existsSync(e)?s(iF(e)):pt.error(`${r} file not found:`,e),yie(e,{persistent:!1},s)}a(Xk,"loadAndWatch");function eN(){let e=Tie();if(e==null){let t=up[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return sF(e)}a(eN,"getHost");function Ng(){let e=wg();if(e==null){let t=up[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(Ng,"getCommonName");async function wie(){let e=await dp(),t=bt.certificateFromPem(e.options.cert),r=bt.privateKeyFromPem(e.options.key);pt.info("Creating CSR with cert named:",e.name);let n=bt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:Ng()},...sN];pt.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:lF()}];return pt.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),ad.pki.certificationRequestToPem(n)}a(wie,"createCsr");function lF(){let e=up.includes(Ng())?up:[...up,Ng()];return e.includes(eN())||e.push(eN()),[{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=>eF.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a(lF,"certExtensions");async function Iie(e){let t={},r=ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;xa();for await(let f of vr.search([]))if(f.is_authority&&!f.details.issuer.includes("HarperDB-Certificate-Authority")){if(Ua.has(f.private_key_name)){n=Ua.get(f.private_key_name),s=f;break}else if(f.private_key_name&&await On.exists(ar.join(r,f.private_key_name))){n=On.readFile(ar.join(r,f.private_key_name)),s=f;break}}if(!n){let f=await tN();s=f.ca,n=f.private_key}n=bt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=bt.certificateFromPem(s.certificate);pt.info("Signing CSR with cert named",s.name);let o=bt.certificationRequestFromPem(e.csr);try{o.verify()}catch(f){return pt.error(f),new Error("Error verifying CSR: "+f.message)}let c=ad.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()+nN),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,ad.md.sha256.create()),t.certificate=bt.certificateToPem(c)}else pt.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(Iie,"signCertificate");async function Cie(e,t){await ld({name:wg(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await ld({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:bt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(Cie,"createCertificateTable");async function ld(e){let t=new No(e.certificate);e.details={issuer:t.issuer.replace(/\n/g," "),subject:t.subject.replace(/\n/g," "),subject_alt_name:t.subjectAltName,serial_number:t.serialNumber,valid_from:t.validFrom,valid_to:t.validTo},xa(),await vr.patch(e)}a(ld,"setCertTable");async function iN(){let e=await XO("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:bt.publicKeyFromPem(e.publicKey),private_key:bt.privateKeyFromPem(e.privateKey)}}a(iN,"generateKeys");async function oN(e,t,r){let n=bt.createCertificate();if(!t){let o=await dp();t=bt.certificateFromPem(o.options.cert).publicKey}n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+nN);let i=[{name:"commonName",value:Ng()},...sN];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(lF()),n.sign(e,ad.md.sha256.create()),bt.certificateToPem(n)}a(oN,"generateCertificates");async function tN(){let e=await hF(),t;for(let r of e){if(!r.is_authority)continue;let n=await pF(r.private_key_name);if(r.private_key_name&&n&&new No(r.certificate).checkPrivateKey(tF(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(tN,"getCertAuthority");async function uF(e,t,r=!0){let n=bt.createCertificate();n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+nN);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${ys.get(cd.REPLICATION_HOSTNAME)??sF(ys.get(cd.REPLICATION_URL))??rF().split("-")[0]}`},...sN];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,ad.md.sha256.create());let o=ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME),c=ar.join(o,li.PRIVATEKEY_PEM_NAME);return r&&await On.writeFile(c,bt.privateKeyToPem(e)),n}a(uF,"generateCertAuthority");async function Pie(){let{private_key:e,public_key:t}=await iN(),r=await uF(e,t),n=await oN(e,t,r);await Cie(n,r),dF()}a(Pie,"generateCertsKeys");async function Die(){let e=await oN(bt.privateKeyFromPem(li.CERTIFICATE_VALUES.key),void 0,bt.certificateFromPem(li.CERTIFICATE_VALUES.cert)),t=ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME),r=ar.join(t,li.NATS_CERTIFICATE_PEM_NAME);await On.exists(r)||await On.writeFile(r,e);let n=ar.join(t,li.NATS_CA_PEM_NAME);await On.exists(n)||await On.writeFile(n,li.CERTIFICATE_VALUES.cert)}a(Die,"createNatsCerts");async function Lie(){xa();for await(let e of vr.search([{attribute:"is_self_signed",value:!0}]))await vr.delete(e.name);await aN()}a(Lie,"renewSelfSigned");async function aN(){Aie(),await cF(),xa();let e=await tN();if(!e){pt.notify("A matching Certificate Authority and key was not found. A new CA will be created in advance, so it's available if needed.");let r=ys.get(cd.TLS_PRIVATEKEY),n=ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME),s,i=nF(n,r);try{s=bt.privateKeyFromPem(await On.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 iN(),await On.exists(ar.join(n,li.PRIVATEKEY_PEM_NAME))&&(i=`privateKey${rF().split("-")[0]}.pem`),await On.writeFile(ar.join(n,i),bt.privateKeyToPem(s))}let o=await uF(s,bt.setRsaPublicKey(s.n,s.e),!1);await ld({name:o.subject.getField("CN").value,uses:["https"],certificate:bt.certificateToPem(o),private_key_name:i,is_authority:!0,is_self_signed:!0})}if(!await dp()){let r=wg();pt.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await tN();let n=bt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await oN(bt.privateKeyFromPem(e.private_key),s,n);await ld({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(aN,"reviewSelfSignedCert");function dF(){let e=Eie(Object.keys(bs.CONFIG_PARAM_MAP),!0),t=ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME),r=ar.join(t,li.PRIVATEKEY_PEM_NAME),n=ar.join(t,li.NATS_CERTIFICATE_PEM_NAME),s=ar.join(t,li.NATS_CA_PEM_NAME),i=bs.CONFIG_PARAMS,o={[i.TLS_PRIVATEKEY]:e[i.TLS_PRIVATEKEY.toLowerCase()]?e[i.TLS_PRIVATEKEY.toLowerCase()]:r};e[i.TLS_CERTIFICATE.toLowerCase()]&&(o[i.TLS_CERTIFICATE]=e[i.TLS_CERTIFICATE.toLowerCase()]),e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.TLS_CERTIFICATEAUTHORITY]=e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATE]=e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]),e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_PRIVATEKEY]=e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY]=e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]),(e[i.CLUSTERING_ENABLED.toLowerCase()]||e.clustering)&&(o[i.CLUSTERING_TLS_CERTIFICATE]=e[i.CLUSTERING_TLS_CERTIFICATE.toLowerCase()]??n,o[i.CLUSTERING_TLS_CERT_AUTH]=e[i.CLUSTERING_TLS_CERT_AUTH.toLowerCase()]??s,o[i.CLUSTERING_TLS_PRIVATEKEY]=e[i.CLUSTERING_TLS_PRIVATEKEY.toLowerCase()]??r),ZO.updateConfigValue(void 0,void 0,o,!1,!0)}a(dF,"updateConfigCert");function fF(e){return e.startsWith("-----BEGIN")?e:Rie(e,"utf8")}a(fF,"readPEM");var Zk=Og.createSecureContext;Og.createSecureContext=function(e){if(!e.cert||!e.key)return Zk(e);let t={...e};delete t.key,delete t.cert;let r=Zk(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var Mie=aF.prototype._init;aF.prototype._init=function(e,t){Mie.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 fl=new Map;function _F(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(),fl.clear();let f=0;for await(let d of QO.system.hdb_certificate.search([])){let p=d.certificate,_=new No(p);d.is_authority&&(_.asString=p,fl.set(_.subject,p))}for await(let d of QO.system.hdb_certificate.search([]))try{if(d.is_authority)continue;let p=e==="operations-api",_=d.is_self_signed?1:2;p&&d.uses?.includes?.("operations")&&(_+=1);let h=await pF(d.private_key_name),S=d.certificate,g=new No(S);if(fl.has(g.issuer)&&(S+=`
24
- `+fl.get(g.issuer)),!h||!S)throw new Error("Missing private key or certificate for secure server");let R={ciphers:d.ciphers,ticketKeys:bie(),availableCAs:fl,ca:t&&Array.from(fl.values()),cert:S,key:h,key_file:d.private_key_name,is_self_signed:d.is_self_signed};o&&(R.sessionIdContext=o.sessionIdContext);let E=Og.createSecureContext(R);E.name=d.name,E.options=R,E.quality=_,E.certificateAuthorities=Array.from(fl),E.certStart=S.toString().slice(0,100);let T=d.hostnames??mF(g);Array.isArray(T)||(T=[T]);let b;for(let v of T)if(v){v[0]==="*"&&(s=!0,v=v.slice(1)),v===eN()&&(_+=2),eF.isIP(v)&&(b=!0);let F=r.get(v)?.quality??0;_>F&&r.set(v,E)}else Ma.error("No hostname found for certificate at",Og.certificate);Ma.trace("Adding TLS",E.name,"for",o.ports||"client","cert named",d.name,"hostnames",T,"quality",_,"best quality",f),_>f&&(i.defaultContext=n=E,f=_,o&&(o.defaultContext=E))}catch(p){Ma.error("Error applying TLS for",d.name,p)}o?.secureContextsListeners.forEach(d=>d()),c(n)}catch(f){l(f)}}a(u,"updateTLS"),QO.system.hdb_certificate.subscribe({listener:a(()=>setTimeout(()=>u(),1500).unref(),"listener"),omitCurrent:!0}),u()})),i;function i(o,c){Ma.info("TLS requested for",o||"(no SNI)");let l=o;for(;;){let f=r.get(l);if(f)return Ma.debug("Found certificate for",o,f.certStart),f.updatedContext&&(f=f.updatedContext),c(null,f);if(s&&l){let d=l.indexOf(".",1);d<0?l="":l=l.slice(d)}else break}o?Ma.debug("No certificate found to match",o,"using the default certificate"):Ma.debug("No SNI, using the default certificate",n?.name);let u=n;u?u.updatedContext&&(u=u.updatedContext):Ma.info("No default certificate found"),c(null,u)}a(i,"SNICallback")}a(_F,"createTLSSelector");async function pF(e){let t=Ua.get(e);return!t&&e?await On.readFile(ar.join(ys.get(cd.ROOTPATH),bs.LICENSE_KEY_DIR_NAME,e),"utf8"):t}a(pF,"getPrivateKeyByName");async function hF(){xa();let e=[];for await(let t of vr.search([]))e.push(t);return e}a(hF,"listCertificates");async function vie(e){let t=rN(e,ci.object({name:ci.string().required(),certificate:ci.string().required(),is_authority:ci.boolean().required(),private_key:ci.string(),hosts:ci.array(),uses:ci.array()}));if(t)throw new va(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,o=new No(n),c=!1,l=!1,u;for(let[_,h]of Ua)!s&&!c&&o.checkPrivateKey(tF(h))&&(c=!0,u=_),s&&s===h&&(l=!0,u=_);if(!i&&!s&&!c)throw new va("A suitable private key was not found for this certificate");let f;if(!r){try{f=cN(o)}catch(_){pt.error(_)}if(f==null)throw new va("Error extracting certificate common name, please provide a name parameter")}let d=Uie(r??f);s&&!c&&!l&&(await On.writeFile(ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME,d+".pem"),s),Ua.set(d,s));let p={name:r??f,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&u||i&&s)&&(p.private_key_name=u??d+".pem"),await ld(p),"Successfully added certificate: "+d}a(vie,"addCertificate");function Uie(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(Uie,"sanitizeName");async function xie(e){let t=rN(e,ci.object({name:ci.string().required()}));if(t)throw new va(t.message);let{name:r}=e;xa();let n=await vr.get(r);if(!n)throw new va(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await vr.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(pt.info("Removing private key named",s),await On.remove(ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME,s)))}return await vr.delete(r),"Successfully removed "+r}a(xie,"removeCertificate");function cN(e){return e.subject.match(/CN=(.*)/)?.[1]}a(cN,"extractCommonName");function mF(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):[cN(e)]}a(mF,"hostnamesFromCert");async function Bie(e){if(e.bypass_auth!==!0)throw new va("Unauthorized","401");let t=rN(e,ci.object({name:ci.string().required()}));if(t)throw new va(t.message);let{name:r}=e;if(r===".jwtPrivate")return(await Jk()).privateKey;if(r===".jwtPublic")return(await Jk()).publicKey;if(Ua.get(r))return Ua.get(e.name);throw new va("Key not found")}a(Bie,"getKey")});var xF={};ve(xF,{CONFIRMATION_STATUS_POSITION:()=>UF,NodeReplicationConnection:()=>fp,OPERATION_REQUEST:()=>_N,RECEIVED_TIME_POSITION:()=>hN,RECEIVED_VERSION_POSITION:()=>pN,SENDING_TIME_POSITION:()=>Lg,createWebSocket:()=>vg,database_subscriptions:()=>Ha,replicateOverWS:()=>_p,table_update_listeners:()=>EN});async function vg(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=Xe(),i;if(e.includes("wss://")){if(!uN){let l=(0,LF.createTLSSelector)("operations-api"),u={secureContexts:null};await l.initialize(u),uN=u.secureContexts}if(i=uN.get(s),i&&le.debug?.("Creating web socket for URL",e,"with certificate named:",i.name),!i&&n!==!1)throw new Error("Unable to find a valid certificate to use for replication to connect to "+e)}let o={};r&&(o.Authorization=r);let c={headers:o,localAddress:s?.startsWith("127.0")?s:void 0,servername:(0,vF.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,rejectUnauthorized:n!==!1,secureContext:void 0};return i&&(c.secureContext=MF.createSecureContext({...i.options,ca:Array.from(pl)})),new PF.WebSocket(e,"harperdb-replication-v1",c)}function _p(e,t,r){let n=t.port||t.securePort,s=_l.pid%1e3+"-"+DF.threadId+(n?"s:"+n:"c:"+t.url?.slice(-4))+" "+Math.random().toString().slice(2,3),i=0,o=Buffer.allocUnsafeSlow(1024),c=0,l=new DataView(o.buffer,0,1024),u=t.database,f=t.databaseSubscriptions||Ha,d,p,_=!1,h=t.subscription;h?.then&&h.then(m=>h=m);let S=t.tables||u&&Qe()[u];if(!r){le.error?.("No authorization provided"),un(1008,"Unauthorized");return}let g=new Map,R=[],E=r.name;E&&t.connection&&(t.connection.nodeName=E);let T,b,v,F,q,Y,Z,se=1e3,Q,ne=0,J=0,he=0,Re=new Map,Ce=[],me=0,Zt;if(t.url){let m=a(()=>{q&&J===e._socket?.bytesRead&&he===e._socket?.bytesWritten?e.terminate():(q=performance.now(),e.ping(),J=e._socket?.bytesRead,he=e._socket?.bytesWritten)},"send_ping");v=setInterval(m,wF).unref(),m()}else ut();e._socket?.setMaxListeners(200);function ut(){clearTimeout(F),J=e._socket?.bytesRead,he=e._socket?.bytesWritten,F=setTimeout(()=>{J===e._socket?.bytesRead&&he===e._socket?.bytesWritten&&(le.warn?.(`Timeout waiting for ping from ${E}, terminating connection and reconnecting`),e.terminate())},wF*2).unref()}a(ut,"resetPingTimer");function yr(){return p||(p=Ag(d,u,E)),p}a(yr,"getSharedStatus"),u&&ia(u);let hs,vn,nu=[],su=[],BA,HA=[],Mt=[],Ef=[],jh=150,Jh=25,gf=0,Qh=0,De=!1,Sf,ln,Ir,iu;e.on("message",m=>{ne=performance.now();try{let A=m.dataView=new hl(m.buffer,m.byteOffset,m.byteLength);if(m[0]>127){let P=(0,ze.decode)(m),[N,L,k]=P;switch(N){case SF:{if(L){if(E){if(E!==L){le.error?.(s,`Node name mismatch, expecting to connect to ${E}, but peer reported name as ${L}, disconnecting`),e.send((0,ze.encode)([ud])),un(1008,"Node name mismatch");return}}else if(E=L,t.connection?.tentativeNode){let U=t.connection.tentativeNode;U.name=E,t.connection.tentativeNode=null,Oo(E,U)}if(t.connection&&(t.connection.nodeName=E),le.debug?.(s,"received node name:",E,"db:",u),!u)try{ia(u=P[2]),u==="system"&&(hs=Da(t,(U,ue)=>{au(ue)&&oa(ue)}),e.on("close",()=>{hs?.remove()}))}catch(U){le.warn?.(s,"Error setting database",U),e.send((0,ze.encode)([ud])),un(1008,U.message);return}Fr()}break}case OF:{le.debug?.(s,"Received table definitions for",L.map(U=>U.table));for(let U of L){let ue=P[2];U.database=ue;let ce;au(ue)&&(ue==="system"?qe[ue]?.[U.table]||(ce=dN(U,qe[ue]?.[U.table])):ce=dN(U,qe[ue]?.[U.table]),d||(d=ce?.auditStore),S||(S=Qe()?.[ue]))}break}case ud:un();break;case _N:try{let U=r?.replicates||r?.subscribers||r?.name;server.operation(L,{user:r},!U).then(ue=>{Array.isArray(ue)&&(ue={results:ue}),ue.requestId=L.requestId,e.send((0,ze.encode)([Cg,ue]))},ue=>{e.send((0,ze.encode)([Cg,{requestId:L.requestId,error:ue instanceof Error?ue.toString():ue}]))})}catch(U){e.send((0,ze.encode)([Cg,{requestId:L.requestId,error:U instanceof Error?U.toString():U}]))}break;case Cg:let{resolve:D,reject:x}=g.get(L.requestId);L.error?x(new Error(L.error)):D(L),g.delete(L.requestId);break;case lN:let $=P[3];S||(u?le.error?.(s,"No tables found for",u):le.error?.(s,"Database name never received"));let j=S[$];j=dN({table:$,database:u,attributes:L.attributes,schemaDefined:L.schemaDefined},j),nu[k]={name:$,decoder:new ze.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:L.typedStructs,structures:L.structures}),getEntry(U){return j.primaryStore.getEntry(U)},rootStore:j.primaryStore.rootStore};break;case TF:iu=d?kk(L,d):new Map,BA=P[2],le.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${BA}`);break;case AF:let oe=k;Ef[oe]=L;break;case bF:yr()[UF]=L,le.trace?.(s,"received and broadcasting committed update",L),yr().buffer.notify();break;case yF:T=L,h.send({type:"end_txn",localTime:T,remoteNodeIds:R});break;case Pg:{let U=P[1],{fileId:ue,size:ce,finished:fe,error:te}=U,W=Re.get(ue);le.debug?.("Received blob",ue,"has stream",!!W,"connectedToBlob",!!W?.connectedToBlob,"length",P[2].length,"finished",fe),W||(W=new fN.PassThrough,W.expectedSize=ce,Re.set(ue,W)),W.lastChunk=Date.now(),fe?(te?(W.on("error",()=>{}),W.destroy(new Error("Blob error: "+te))):W.end(P[2]),W.connectedToBlob&&Re.delete(ue)):W.write(P[2]);break}case RF:{let U=L,ue;try{let ce=P[3],fe=su[k]||(su[k]=S[P[4]]);if(!fe)return le.warn?.("Unknown table id trying to handle record request",k);let te=fe.primaryStore.getBinaryFast(Symbol.for("structures")),W=te.length;if(W!==Qh){Qh=W;let Ae=(0,ze.decode)(te);e.send((0,ze.encode)([lN,{typedStructs:Ae.typed,structures:Ae.named},k,fe.tableName]))}let _e=fe.primaryStore.getBinaryFast(ce);if(_e){let Ae=fe.primaryStore.decoder.decode(_e,{valueAsBuffer:!0});ue=(0,ze.encode)([Ig,U,{value:Ae.value,expiresAt:Ae.expiresAt,version:Ae.version,residencyId:Ae.residencyId,nodeId:Ae.nodeId,user:Ae.user}])}else ue=(0,ze.encode)([Ig,U])}catch(ce){ue=(0,ze.encode)([Ig,U,{error:ce.message}])}e.send(ue);break}case Ig:{let{resolve:U,reject:ue,tableId:ce,key:fe}=g.get(P[1]),te=P[2];if(te?.error)ue(new Error(te.error));else if(te){let W=nu[ce].decoder.decode(te.value);te.value=W,te.key=fe,U(te)}else U();g.delete(P[1]);break}case gF:{Ir=L;let U,ue,ce=!1;if(h){if(u!==h.databaseName&&!h.then){le.error?.("Subscription request for wrong database",u,h.databaseName);return}}else h=f.get(u);if(le.debug?.(s,"received subscription request for",u,"at",Ir),!h){let Ee;h=new Promise(Je=>{le.debug?.("Waiting for subscription to database "+u),Ee=Je}),h.ready=Ee,Ha.set(u,h)}if(r.name)ue=or().subscribe(r.name),ue.then(async Ee=>{U=Ee;for await(let Je of U){let nt=Je.value;if(!(nt?.replicates===!0||nt?.replicates?.receives||nt?.subscriptions?.some($t=>($t.database||$t.schema)===u&&$t.publish!==!1))){ce=!0,e.send((0,ze.encode)([ud])),un(1008,`Unauthorized database subscription to ${u}`);return}}},Ee=>{le.error?.(s,"Error subscribing to HDB nodes",Ee)});else if(!(r?.role?.permission?.super_user||r.replicates)){e.send((0,ze.encode)([ud])),un(1008,`Unauthorized database subscription to ${u}`);return}if(ln&&(le.debug?.(s,"stopping previous subscription",u),ln.emit("close")),Ir.length===0)return;let fe=Ir[0],te=a(Ee=>{if(Ee&&(fe.replicateByDefault?!fe.tables.includes(Ee.tableName):fe.tables.includes(Ee.tableName)))return{table:Ee}},"tableToTableEntry"),W={txnTime:0},_e,Ae,ye=1/0,dt,rt=a((Ee,Je)=>{if(Ee.type==="end_txn"){W.txnTime&&(o[i]!==66&&le.error?.("Invalid encoding of message"),cu(9),cu(Mg),uu(dt=Je),Gr()),i=c,W.txnTime=0;return}let nt=Ee.nodeId,$t=Ee.tableId,Vt=Ae[$t];if(!Vt&&(Vt=Ae[$t]=te(h.tableById[$t]),!Vt))return le.debug?.("Not subscribed to table",$t);let qr=Vt.table,Sc=qr.primaryStore,vt=Sc.encoder;(Ee.extendedType&zm||!vt.typedStructs)&&(vt._mergeStructures(vt.getStructures()),vt.typedStructs&&(vt.lastTypedStructuresLength=vt.typedStructs.length));let Zh=_e[nt];if(!(Zh&&Zh.startTime<Je&&(!Zh.endTime||Zh.endTime>Je)))return Dg&&le.trace?.(s,"skipping replication update",Ee.recordId,"to:",E,"from:",nt,"subscribed:",_e),iD();Dg&&le.trace?.(s,"sending replication update",Ee.recordId,"to:",E,"from:",nt,"subscribed:",_e);let kA=Ee.version;W.txnTime!==kA&&(W.txnTime&&(Dg&&le.trace?.(s,"new txn time, sending queued txn",W.txnTime),o[i]!==66&&le.error?.("Invalid encoding of message"),Gr()),W.txnTime=kA,i=c,uu(kA));let Tc=Ee.residencyId,FA=ou(Tc,qr),em;if(FA&&!FA.includes(E)){let Ac=ou(Ee.previousResidencyId,qr);if(Ac&&!Ac.includes(E)&&(Ee.type==="put"||Ee.type==="patch")||qr.getResidencyById)return iD();let Rf=Ee.recordId;le.trace?.(s,"sending invalidation",Rf,E,"from",nt);let ca=0;Tc&&(ca|=Uc),Ee.previousResidencyId&&(ca|=xc);let Ks,dn=null;for(let tm in qr.indices){if(!dn){if(Ks=Ee.getValue(Sc,!0),!Ks)break;dn={}}dn[tm]=Ks[tm]}em=Ou(Ee.version,$t,Rf,null,nt,Ee.user,Ee.type==="put"||Ee.type==="patch"?"invalidate":Ee.type,vt.encode(dn),ca,Tc,Ee.previousResidencyId,Ee.expiresAt)}function iD(){le.trace?.(s,"skipping audit record",Ee.recordId),Y||(Y=setTimeout(()=>{Y=null,(dt||0)+NF/2<ye&&(Dg&&le.trace?.(s,"sending skipped sequence update",ye),e.send((0,ze.encode)([yF,ye])))},NF).unref())}a(iD,"skipAuditRecord");let GA=vt.typedStructs,qA=vt.structures;if((GA?.length!=Vt.typed_length||qA?.length!=Vt.structure_length)&&(Vt.typed_length=GA?.length,Vt.structure_length=qA.length,le.debug?.(s,"send table struct",Vt.typed_length,Vt.structure_length),Vt.sentName||(Vt.sentName=!0),e.send((0,ze.encode)([lN,{typedStructs:GA,structures:qA,attributes:qr.attributes,schemaDefined:qr.schemaDefined},$t,Vt.table.tableName]))),Tc&&!Mt[Tc]&&(e.send((0,ze.encode)([AF,FA,Tc])),Mt[Tc]=!0),em)cu(em.length),lu(em);else{let Ac=Ee.encoded;Ee.extendedType&Fn&&CR(()=>Ee.getValue(Sc),async ca=>{let Ks=Bm(ca);try{let dn;me++;for await(let tm of ca.stream()){if(dn&&(le.debug?.("Sending blob chunk",Ks,"length",dn.length),e.send((0,ze.encode)([Pg,{fileId:Ks,size:ca.size},dn]))),dn=tm,ce)return;e._socket.writableNeedDrain&&(le.debug?.("draining",Ks),await new Promise(S2=>e._socket.once("drain",S2)),le.debug?.("drained",Ks))}le.debug?.("Sending final blob chunk",Ks,"length",dn.length),e.send((0,ze.encode)([Pg,{fileId:Ks,size:ca.size,finished:!0},dn]))}catch(dn){le.debug?.("Error sending blob",dn),e.send((0,ze.encode)([Pg,{fileId:Ks,finished:!0,error:dn.toString()},Buffer.alloc(0)]))}finally{me--,me<Jh&&Zt?.()}});let Rf=Ac[0]===66?8:0;cu(Ac.length-Rf),lu(Ac,Rf),le.trace?.("wrote record",Ee.recordId,"length:",Ac.length)}},"sendAuditRecord"),Gr=a(()=>{c-i>8?(e.send(o.subarray(i,c)),le.debug?.(s,"Sent message, size:",c-i)):le.debug?.(s,"skipping empty transaction")},"sendQueuedData");ln=new mN.EventEmitter,ln.once("close",()=>{ce=!0,U?.end()});for(let{startTime:Ee}of Ir)Ee<ye&&(ye=Ee);(ue||Promise.resolve()).then(async()=>{h=await h,d=h.auditStore,Ae=h.tableById.map(te),_e=[];for(let{name:Je,startTime:nt,endTime:$t}of Ir){let Vt=Tg(Je,d);le.debug?.("subscription to",Je,"using local id",Vt,"starting",nt),_e[Vt]={startTime:nt,endTime:$t}}oa(u),hs||(hs=ml(Je=>{Je.databaseName===u&&oa(u)}),vn=pp(Je=>{Je===u&&(e.send((0,ze.encode)([ud])),un())}),e.on("close",()=>{hs?.remove(),vn?.remove()})),e.send((0,ze.encode)([TF,ip(h.auditStore),Ir.map(({name:Je})=>Je)]));let Ee=!0;do{isFinite(ye)||(le.warn?.("Invalid sequence id "+ye),un(1008,"Invalid sequence id"+ye));let Je;if(Ee&&!ce&&(Ee=!1,!(SN(d)<=ye)&&(CF.default.get(B.REPLICATION_COPYTABLESTOCATCHUP)??Hie)&&server.nodes[0]?.name===E)){le.info?.("Replicating all tables to",E);let $t=ye,Vt=Ug(d);for(let qr in S){if(!te(qr))continue;let Sc=S[qr];for(let vt of Sc.primaryStore.getRange({snapshot:!1})){if(ce)return;vt.localTime>=ye&&(le.trace?.(s,"Copying record from",u,qr,vt.key,vt.localTime),$t=Math.max(vt.localTime,$t),Je=!0,yr()[Lg]=1,rt({recordId:vt.key,tableId:Sc.tableId,type:"put",getValue(){return vt.value},encoded:Sc.primaryStore.getBinary(vt.key),version:vt.version,residencyId:vt.residencyId,nodeId:Vt,extendedType:vt.metadataFlags},vt.localTime))}}ye=$t}for(let{key:nt,value:$t}of d.getRange({start:ye||1,exclusiveStart:!0,snapshot:!1})){if(ce)return;let Vt=wt($t);le.debug?.("sending audit record",new Date(nt)),yr()[Lg]=nt,ye=nt,rt(Vt,nt),e._socket.writableNeedDrain?await new Promise(qr=>{le.debug?.(`Waiting for remote node ${E} to allow more commits ${e._socket.writableNeedDrain?"due to network backlog":"due to requested flow directive"}`),e._socket.once("drain",qr)}):me>Jh?await new Promise(qr=>{Zt=qr}):await new Promise(setImmediate),ln.startTime=nt,Je=!0}Je&&rt({type:"end_txn"},ye),yr()[Lg]=0,await BF(d)}while(!ce)}).catch(Ee=>{le.error?.(s,"Error handling subscription to node",Ee),un(1008,"Error handling subscription to node")});break}}return}A.position=8;let I=!0,y,O;do{yr();let P=A.readInt();if(P===9&&A.getUint8(A.position)==Mg){A.position++,T=O=A.readFloat64(),p[pN]=T,p[hN]=Date.now(),le.trace?.("received remote sequence update",T,u);break}let N=A.position,L=wt(m,N,N+P),k=nu[L.tableId];k||le.error?.(`No table found with an id of ${L.tableId}`);let D;L.residencyId&&(D=Ef[L.residencyId],le.trace?.(s,"received residency list",D,L.type,L.recordId));try{IR(()=>{y={table:k.name,id:L.recordId,type:L.type,nodeId:iu.get(L.nodeId),residencyList:D,timestamp:L.version,value:L.getValue(k),user:L.user,beginTxn:I,expiresAt:L.expiresAt}},x=>{let $=Bm(x),j=Re.get($);le.debug?.("Received transaction with blob",$,"has stream",!!j,"ended",!!j?.writableEnded),j?j.writableEnded&&Re.delete($):(j=new fN.PassThrough,Re.set($,j)),j.connectedToBlob=!0,j.lastChunk=Date.now(),x.size===void 0&&j.expectedSize&&(x.size=j.expectedSize);let oe=createBlob(j,x),U=oe.save({primaryStore:h.auditStore});return U&&(U.blobId=$,Ce.push(U),U.finally(()=>{le.debug?.(`Finished receiving blob stream ${$}`),Ce.splice(Ce.indexOf(U),1)})),oe})}catch(x){throw x.message+="typed structures for current decoder"+JSON.stringify(k.decoder.typedStructs),x}I=!1,le.trace?.(s,"received replication message",L.type,"id",y.id,"version",new Date(L.version),"nodeId",y.nodeId),p[pN]=L.version,p[hN]=Date.now(),h.send(y),A.position=N+P}while(A.position<m.byteLength);gf++,sr(m.byteLength,"bytes-received",`${E}.${u}.${y?.table||"unknown_table"}`,"replication","ingest"),gf>jh&&!De&&(De=!0,e.pause(),le.debug?.(`Commit backlog causing replication back-pressure, requesting that ${E} pause replication`)),h.send({type:"end_txn",localTime:T,remoteNodeIds:R,async onCommit(){if(y){let P=Date.now()-y.timestamp;sr(P,"replication-latency",E+"."+u+"."+y.table,y.type,"ingest")}gf--,De&&(De=!1,e.resume(),le.debug?.(`Replication resuming ${E}`)),Ce.length>0&&await Promise.all(Ce),le.trace?.("All blobs finished"),!b&&O&&(le.trace?.(s,"queuing confirmation of a commit at",O),setTimeout(()=>{e.send((0,ze.encode)([bF,b])),le.trace?.(s,"sent confirmation of a commit at",b),b=null},kie)),b=O,le.debug?.("last sequence committed",new Date(O),u)}})}catch(A){le.error?.(s,"Error handling incoming replication message",A)}}),e.on("ping",ut),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-q,dl({name:E,database:u,url:t.url,latency:t.connection.latency})),q=null}),e.on("close",(m,A)=>{clearInterval(v),clearTimeout(F),clearInterval(Z),ln&&ln.emit("close"),Sf&&Sf.end();for(let[I,{reject:y}]of g)y(new Error(`Connection closed ${A?.toString()} ${m}`));le.debug?.(s,"closed",m,A?.toString())});function Tf(){}a(Tf,"recordRemoteNodeSequence");function un(m,A){e.isFinished=!0,e.close(m,A)}a(un,"close");function Fr(){if(_||(_=!0,t.connection?.on("subscriptions-updated",Fr)),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let m=new Map;try{for(let y of h?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let O of y.value.nodes||[])O.lastTxnTime>(m.get(O.id)??0)&&m.set(O.id,O.lastTxnTime)}catch(y){if(!y.message.includes("Can not re"))throw y}let A=t.connection?.nodeSubscriptions?.[0];R=[];let I=t.connection?.nodeSubscriptions.map((y,O)=>{let P=[],{replicateByDefault:N}=y;if(y.subscriptions){for(let x of y.subscriptions)if(x.subscribe&&(x.schema||x.database)===u){let $=x.table;S?.[$]?.replicate!==!1&&P.push($)}N=!1}else for(let x in S)(N?S[x].replicate===!1:S[x].replicate)&&P.push(x);let L=d&&Tg(y.name,d),k=h?.dbisDB?.get([Symbol.for("seq"),L])??1,D=Math.max(k?.seqId??1,(typeof y.start_time=="string"?new Date(y.start_time).getTime():y.start_time)??1);if(le.debug?.("Starting time recorded in db",y.name,L,u,k?.seqId,"start time:",D,new Date(D)),A!==y){let x=d&&Tg(A.name,d),$=h?.dbisDB?.get([Symbol.for("seq"),x])??1;for(let j of $?.nodes||[])j.name===y.name&&(D=j.seqId,le.debug?.("Using sequence id from proxy node",A.name,D))}return R.push(L),m.get(L)>D&&(D=m.get(L),le.debug?.("Updating start time from more recent txn recorded",A.name,D)),{name:y.name,replicateByDefault:N,tables:P,startTime:D,endTime:y.end_time}});if(I)if(le.debug?.(s,"sending subscription request",I,h?.dbisDB?.path),clearTimeout(Q),I.length>0)e.send((0,ze.encode)([gF,I]));else{let y=a(()=>{let O=performance.now();Q=setTimeout(()=>{ne<=O?un(1008,"No nodes to subscribe to"):y()},se)},"schedule_close");y()}}a(Fr,"sendSubscriptionRequestUpdate");function ou(m,A){if(!m)return;let I=HA[m];return I||(I=A.getResidencyRecord(m),HA[m]=I),I}a(ou,"getResidence");function au(m){return!(Ba&&Ba!="*"&&!Ba[m]&&!Ba.includes?.(m)&&!Ba.some?.(A=>A.name===m))}a(au,"checkDatabaseAccess");function ia(m){if(h=h||f.get(m),!au(m))throw new Error(`Access to database "${m}" is not permitted`);h||le.warn?.(`No database named "${m}" was declared and registered`),d=h?.auditStore,S||(S=Qe()?.[m]);let A=Xe();if(A===E)throw A?new Error("Should not connect to self",A):new Error("Node name not defined");return Xh(A,m),!0}a(ia,"setDatabase");function Xh(m,A){let I=Qe()?.[A],y=[];for(let O in I){let P=I[O];y.push({table:O,schemaDefined:P.schemaDefined,attributes:P.attributes.map(N=>({name:N.name,type:N.type,isPrimaryKey:N.isPrimaryKey}))})}le.trace?.("Sending database info for node",m,"database name",A),e.send((0,ze.encode)([SF,m,A,y]))}a(Xh,"sendNodeDBName");function oa(m){let A=Qe()?.[m],I=[];for(let y in A){if(Ir&&!Ir.some(P=>P.replicateByDefault?!P.tables.includes(y):P.tables.includes(y)))continue;let O=A[y];I.push({table:y,schemaDefined:O.schemaDefined,attributes:O.attributes.map(P=>({name:P.name,type:P.type,isPrimaryKey:P.isPrimaryKey}))})}e.send((0,ze.encode)([OF,I,m]))}a(oa,"sendDBSchema"),Z=setInterval(()=>{for(let[m,A]of Re)A.lastChunk+3e4<Date.now()&&(le.warn?.(`Timeout waiting for blob stream to finish ${m} from ${E}`),Re.delete(m),A.end())},3e4).unref();let aa=1,Af=[];return{end(){Sf&&Sf.end(),ln&&ln.emit("close")},getRecord(m){let A=aa++;return new Promise((I,y)=>{let O=[RF,A,m.table.tableId,m.id];Af[m.table.tableId]||(O.push(m.table.tableName),Af[m.table.tableId]=!0),e.send((0,ze.encode)(O)),g.set(A,{tableId:m.table.tableId,key:m.id,resolve(P){let{table:N,entry:L}=m;I(P),P&&N._recordRelocate(L,P)},reject:y})})},sendOperation(m){let A=aa++;return m.requestId=A,e.send((0,ze.encode)([_N,m])),new Promise((I,y)=>{g.set(A,{resolve:I,reject:y})})}};function cu(m){K(5),m<128?o[c++]=m:m<16384?(l.setUint16(c,m|32768),c+=2):m<1056964608?(l.setUint32(c,m|3221225472),c+=4):(o[c]=255,l.setUint32(c+1,m),c+=5)}function lu(m,A=0,I=m.length){let y=I-A;K(y),m.copy(o,c,A,I),c+=y}function uu(m){K(8),l.setFloat64(c,m),c+=8}function K(m){if(m+16>o.length-c){let A=Buffer.allocUnsafeSlow(c+m-i+65536>>10<<11);o.copy(A,0,i,c),c=c-i,i=0,o=A,l=new DataView(o.buffer,0,o.length)}}}function dN(e,t){let r=e.database??"data";if(r!=="data"&&!qe[r]){le.warn?.("Database not found",e.database);return}t||(t={});let n=!1,s=e.schemaDefined,i=t.attributes||[];for(let o=0;o<e.attributes?.length;o++){let c=e.attributes[o],l=i[o];(!l||l.name!==c.name||l.type!==c.type)&&(n=!0,s||(c.indexed=!0),i[o]=c)}return n?(le.debug?.("(Re)creating",e),ft({table:e.table,database:e.database,schemaDefined:e.schemaDefined,attributes:i,...t})):t}var CF,ze,PF,DF,le,mN,LF,MF,_l,vF,fN,gF,SF,TF,ud,AF,lN,RF,Ig,_N,Cg,yF,bF,OF,Pg,UF,pN,hN,Lg,Hie,EN,Ha,Dg,NF,kie,wF,uN,IF,fp,gN=be(()=>{Pe();fo();WO();TN();Xn();CF=M(ae());H();Nu();ze=require("msgpackr"),PF=require("ws"),DF=require("worker_threads"),le=M(Ni());lp();mN=require("events"),LF=M(Zn()),MF=M(require("node:tls"));ul();_l=M(require("node:process")),vF=require("node:net");ki();gs();fN=require("node:stream"),gF=129,SF=140,TF=141,ud=142,AF=130,lN=132,RF=133,Ig=134,_N=136,Cg=137,yF=143,bF=144,OF=145,Pg=146,UF=0,pN=1,hN=2,Lg=3,Hie=_l.env.HDB_LEADER_URL||_l.argv.includes("--HDB_LEADER_URL"),EN=new Map,Ha=new Map,Dg=!0,NF=300,kie=2,wF=3e4;a(vg,"createWebSocket");IF=1e3,fp=class extends mN.EventEmitter{constructor(r,n,s,i,o){super();this.url=r;this.subscription=n;this.databaseName=s;this.nodeName=i;this.authorization=o;this.nodeName=this.nodeName??ai(r)}static{a(this,"NodeReplicationConnection")}socket;startTime;retryTime=IF;retries=0;isConnected=!0;isFinished=!1;nodeSubscriptions=[];latency=0;replicateTablesByDefault;session;sessionResolve;sessionReject;async connect(){this.session||this.resetSession();let r=[];this.socket=await vg(this.url,{serverName:this.nodeName,authorization:this.authorization});let n;le.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${_l.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),le[this.isConnected?"info":"warn"]?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=IF,dl({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=_p(this.socket,{database:this.databaseName,subscription:this.subscription,url:this.url,connection:this},{replicates:!0}),this.sessionResolve(n)}),this.socket.on("error",s=>{s.code==="SELF_SIGNED_CERT_IN_CHAIN"?(le.warn?.(`Can not connect to ${this.url}, this server does not have a certificate authority for the certificate provided by ${this.url}`),s.isHandled=!0):s.code!=="ECONNREFUSED"&&(s.code==="UNABLE_TO_VERIFY_LEAF_SIGNATURE"?le.error?.(`Can not connect to ${this.url}, the certificate provided by ${this.url} is not trusted, this node needs to be added to the cluster, or a certificate authority needs to be added`):le.error?.(`Error in connection to ${this.url} due to ${s.message}`)),this.sessionReject(s)}),this.socket.on("close",(s,i)=>{if(this.isConnected&&(od({name:this.nodeName,database:this.databaseName,url:this.url,finished:this.socket.isFinished}),this.isConnected=!1),this.socket.isFinished){this.isFinished=!0,n?.end(),this.emit("finished");return}if(++this.retries%20===1){let o=i?.toString();le.warn?.(`${n?"Disconnected from":"Failed to connect to"} ${this.url} (db: "${this.databaseName}"), due to ${o?'"'+o+'" ':""}(code: ${s})`)}n=null,this.resetSession(),setTimeout(()=>{this.connect()},this.retryTime).unref(),this.retryTime+=this.retryTime>>3})}resetSession(){this.session=new Promise((r,n)=>{this.sessionResolve=r,this.sessionReject=n})}subscribe(r,n){this.nodeSubscriptions=r,this.replicateTablesByDefault=n,this.emit("subscriptions-updated",r)}unsubscribe(){this.socket.isFinished=!0,this.socket.close(1008,"No longer subscribed")}getRecord(r){return this.session.then(n=>n.getRecord(r))}};a(_p,"replicateOverWS");a(dN,"ensureTableIfChanged")});var wo={};ve(wo,{clearThisNodeName:()=>Wie,disableReplication:()=>$ie,enabled_databases:()=>Ba,forEachReplicatedDatabase:()=>Da,getThisNodeId:()=>Ug,getThisNodeName:()=>Xe,getThisNodeUrl:()=>La,hostnameToUrl:()=>kg,lastTimeInAuditStore:()=>op,monitorNodeCAs:()=>KF,replicateOperation:()=>jie,replication_certificate_authorities:()=>pl,sendOperationToNode:()=>mp,servers:()=>Gie,setReplicator:()=>WF,start:()=>qie,startOnMainThread:()=>JO,subscribeToNode:()=>id,unsubscribeFromNode:()=>bg,urlToNodeName:()=>ai});function qie(e){if(e.port||(e.port=Os.default.get(B.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=Os.default.get(B.OPERATIONSAPI_NETWORK_SECUREPORT)),!Xe())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let n of cp(e))t.set(ai(n.url),n);Vie(e),e={mtls:!0,isOperationsServer:!0,maxPayload:10*1024*1024*1024,...e};let r=Ye.ws(async(n,s,i,o)=>{if(s.headers.get("sec-websocket-protocol")!=="harperdb-replication-v1")return o(n,s,i);await i,n._socket.unref(),_p(n,e,s?.user),n.on("error",c=>{c.code!=="ECONNREFUSED"&&cr.error("Error in connection to "+this.url,c.message)})},e);e.runFirst=!0,Ye.http((n,s)=>{if(n.isWebSocket&&n.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){!n.authorized&&n._nodeRequest.socket.authorizationError&&cr.error(`Incoming client connection from ${n.ip} did not have valid certificate, you may need turn on enableRootCAs in the config if you are using a publicly signed certificate, or add the CA to the server's trusted CAs`,n._nodeRequest.socket.authorizationError);let i=or().primaryStore;if(n.authorized&&n.peerCertificate.subject){let o=n.peerCertificate.subject,c=o&&(i.get(o.CN)||t.get(o.CN));if(c)if(c?.revoked_certificates?.includes(n.peerCertificate.serialNumber)){cr.warn("Revoked certificate used in attempt to connect to node",c.name,"certificate serial number",n.peerCertificate.serialNumber);return}else n.user=c;else cr.warn(`No node found for certificate common name ${o.CN}, available nodes are ${Array.from(i.getRange({}).filter(({value:l})=>l).map(({key:l})=>l)).join(", ")} and routes ${Array.from(t.keys()).join(", ")}, connection will require credentials.`)}else{let o=i.get(n.ip)||t.get(n.ip);o?n.user=o:cr.warn(`No node found for IP address ${n.ip}, available nodes are ${Array.from(new Set([...i.getKeys(),...t.keys()])).join(", ")}, connection will require credentials.`)}}return s(n)},e);for(let n of r)if(n.secureContexts){let s=a(()=>{let i=new Set(n.secureContexts.values());n.defaultContext&&i.add(n.defaultContext);for(let o of i)try{let c=Array.from(pl);o.options.availableCAs&&c.push(...o.options.availableCAs.values());let l={...o.options,ca:c};o.updatedContext=Hg.createSecureContext(l)}catch(c){cr.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),KF(s),Os.default.get(B.REPLICATION_ENABLEROOTCAS)!==!1&&s()}}function KF(e){let t=0;nd(r=>{r?.ca&&(pl.add(r.ca),pl.size!==t&&(t=pl.size,e?.()))})}function $ie(e=!0){VF=e}function Vie(e){VF||(Qe(),Ba=e.databases,Da(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||Ha;for(let[s,i]of hp){let o=i.get(r);o&&(o.subscribe([],!1),i.delete(r))}n.delete(r);return}for(let n in t){let s=t[n];WF(r,s,e),EN.get(s)?.forEach(i=>i(s))}}))}function WF(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 YF extends $r{static{a(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||Ha,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(cr.trace("Setting up replicator subscription to database",e),!o?.auditStore)return this.subscription=o=new xn,i.set(e,o),o.tableById=c,o.auditStore=t.auditStore,o.dbisDB=t.dbisDB,o.databaseName=e,l&&l(o),o;this.subscription=o}static subscribeOnThisThread(i,o){return!0}static async load(i){if(i){let o=i.residencyId,c=i.residency||t.dbisDB.get([Symbol.for("residency_by_id"),o]);if(c){let l,u=new Set;do{let f;for(let p of c){let _=Kie(p,YF.subscription,e);_?.isConnected&&!u.has(_)&&(!f||_.latency<f.latency)&&(f=_)}if(!f)throw l||new qF.ServerError("No connection to any other nodes are available",502);let d={requestId:Fie++,table:t,entry:i,id:i.key};u.add(f);try{return await f.getRecord(d)}catch(p){if(f.isConnected)throw p;cr.warn("Error in load from node",Bg,p),l||(l=p)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function zF(e,t,r,n,s){let i=hp.get(e);i||hp.set(e,i=new Map);let o=i.get(r);if(o)return o;if(t)return i.set(r,o=new fp(e,t,r,n,s)),o.connect(),o.once("finished",()=>i.delete(r)),o}function Kie(e,t,r){let n=HF.get(e)?.get(r);if(n)return n;let s=or().primaryStore.get(e);return s?.url&&(n=zF(s.url,t,r,e,s.authorization),HF.set(e,hp.get(s.url))),n}async function mp(e,t,r){r||(r={}),r.serverName=e.name;let n=await vg(e.url,r),s=_p(n,{},{});return new Promise((i,o)=>{n.on("open",()=>{i(s.sendOperation(t))}),n.on("error",c=>{o(c)}),n.on("close",c=>{cr.info("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function id(e){try{$F.isMainThread&&cr.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=Ha.get(e.database);if(!t){let n;t=new Promise(s=>{cr.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,Ha.set(e.database,t)}let r=zF(e.nodes[0].url,t,e.database,e.nodes[0].name,e.nodes[0].authorization);e.nodes[0].name===void 0?r.tentativeNode=e.nodes[0]:r.nodeName=e.nodes[0].name,r.subscribe(e.nodes.filter(n=>ap(n,e.database)),e.replicateByDefault)}catch(t){cr.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function bg({name:e,url:t,database:r}){cr.trace("Unsubscribing from node",e,t,r,"nodes",Array.from(or().primaryStore.getRange({})));let n=hp.get(t);if(n){let s=n.get(r);s&&(s.unsubscribe(),n.delete(r))}}function Yie(){if(AN!==void 0)return AN;let e=Os.default.get(B.OPERATIONSAPI_TLS_CERTIFICATE)||Os.default.get(B.TLS_CERTIFICATE);if(e)return AN=new FF.X509Certificate((0,GF.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function Xe(){return Bg||(Bg=Os.default.get("replication_hostname")??ai(Os.default.get("replication_url"))??Yie()??kF("operationsapi_network_secureport")??kF("operationsapi_network_port")??"127.0.0.1")}function Wie(){Bg=void 0}function kF(e){let t=Os.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function xg(e){let t=Os.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function Ug(e){return ip(e)?.[Xe()]}function La(){let e=Os.default.get("replication_url");return e||kg(Xe())}function kg(e){let t=xg("replication_port");if(t)return`ws://${e}:${t}`;if(t=xg("replication_secureport"),t)return`wss://${e}:${t}`;if(t=xg("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=xg("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function ai(e){if(e)return new URL(e).hostname}function Da(e,t){for(let n of Object.getOwnPropertyNames(qe))r(n);return pp(n=>{r(n)}),ml((n,s)=>{r(n.databaseName)});function r(n){let s=qe[n];cr.trace("Checking replication status of ",n,e?.databases),e?.databases===void 0||e.databases==="*"||e.databases.includes(n)||e.databases.some?.(i=>i.name===n)||!s?t(s,n,!0):zie(n)&&t(s,n,!1)}a(r,"forDatabase")}function zie(e){let t=qe[e];for(let r in t)if(t[r].replicate)return!0}function op(e){for(let t of e.getKeys({limit:1,reverse:!0}))return t}async function jie(e){let t={message:""};if(e.replicated){e.replicated=!1,cr.trace?.("Replicating operation",e.operation,"to nodes",Ye.nodes.map(n=>n.name));let r=await Promise.allSettled(Ye.nodes.map(n=>mp(n,e)));t.replicated=r.map((n,s)=>{let i=n.status==="rejected"?{status:"failed",reason:n.reason.toString()}:n.value;return i.node=Ye.nodes[s]?.name,i})}return t}var Os,cr,FF,GF,Hg,qF,$F,VF,Fie,Gie,pl,Ba,hp,HF,AN,Bg,Xn=be(()=>{Pe();Ea();_u();gN();Vr();Os=M(ae()),cr=M(z()),FF=require("crypto"),GF=require("fs");lp();ul();H();WO();Hg=M(require("node:tls")),qF=M(pe()),$F=require("worker_threads"),Fie=1,Gie=[],pl=Os.default.get(B.REPLICATION_ENABLEROOTCAS)!==!1?new Set(Hg.rootCertificates):new Set;a(qie,"start");a(KF,"monitorNodeCAs");a($ie,"disableReplication");a(Vie,"assignReplicationSource");a(WF,"setReplicator");hp=new Map;a(zF,"getConnection");HF=new Map;a(Kie,"getConnectionByName");a(mp,"sendOperationToNode");a(id,"subscribeToNode");a(bg,"unsubscribeFromNode");a(Yie,"getCommonNameFromCert");a(Xe,"getThisNodeName");a(Wie,"clearThisNodeName");Object.defineProperty(Ye,"hostname",{get(){return Xe()}});a(kF,"getHostFromListeningPort");a(xg,"getPortFromListeningPort");a(Ug,"getThisNodeId");Ye.replication={getThisNodeId:Ug,exportIdMapping:ip};a(La,"getThisNodeUrl");a(kg,"hostnameToUrl");a(ai,"urlToNodeName");a(Da,"forEachReplicatedDatabase");a(zie,"hasExplicitlyReplicatedTable");a(op,"lastTimeInAuditStore");a(jie,"replicateOperation")});var Vg=w((oDe,ZF)=>{"use strict";var dd=ck(),{validateBySchema:Ep}=it(),{common_validators:fd,schema_regex:RN}=Di(),lr=require("joi"),Jie=z(),Qie=require("uuid").v4,qg=To(),_d=(H(),C(G)),Xie=require("util"),ka=Vn(),{handleHDBError:Io,hdb_errors:Zie,ClientError:gp}=pe(),{HDB_ERROR_MSGS:Fg,HTTP_STATUS_CODES:Co}=Zie,{SchemaEventMsg:$g}=ri(),jF=ir(),{getDatabases:eoe}=(Pe(),C(tt)),{transformReq:pd}=ie(),{replicateOperation:JF}=(Xn(),C(wo)),Gg=lr.string().min(1).max(fd.schema_length.maximum).pattern(RN).messages({"string.pattern.base":"{:#label} "+fd.schema_format.message}),toe=lr.string().min(1).max(fd.schema_length.maximum).pattern(RN).messages({"string.pattern.base":"{:#label} "+fd.schema_format.message}).required(),roe=lr.string().min(1).max(fd.schema_length.maximum).pattern(RN).messages({"string.pattern.base":"{:#label} "+fd.schema_format.message,"any.required":"'primary_key' is required","string.base":"'primary_key' must be a string"}).required();ZF.exports={createSchema:noe,createSchemaStructure:QF,createTable:soe,createTableStructure:XF,createAttribute:loe,dropSchema:ioe,dropTable:ooe,dropAttribute:aoe,getBackup:uoe};async function noe(e){let t=await QF(e);return qg.signalSchemaChange(new $g(process.pid,e.operation,e.schema)),t}a(noe,"createSchema");async function QF(e){let t=Ep(e,lr.object({database:Gg,schema:Gg}));if(t)throw new gp(t.message);if(pd(e),!await dd.checkSchemaExists(e.schema))throw Io(new Error,Fg.SCHEMA_EXISTS_ERR(e.schema),Co.BAD_REQUEST,_d.LOG_LEVELS.ERROR,Fg.SCHEMA_EXISTS_ERR(e.schema),!0);return await ka.createSchema(e),`database '${e.schema}' successfully created`}a(QF,"createSchemaStructure");async function soe(e){return pd(e),e.hash_attribute=e.primary_key??e.hash_attribute,await XF(e)}a(soe,"createTable");async function XF(e){let t=Ep(e,lr.object({database:Gg,schema:Gg,table:toe,residence:lr.array().items(lr.string().min(1)).optional(),hash_attribute:roe}));if(t)throw new gp(t.message);if(!await dd.checkSchemaTableExists(e.schema,e.table))throw Io(new Error,Fg.TABLE_EXISTS_ERR(e.schema,e.table),Co.BAD_REQUEST,_d.LOG_LEVELS.ERROR,Fg.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:Qie(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await ka.createTable(n,e);else throw Io(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Co.BAD_REQUEST);else await ka.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(XF,"createTableStructure");async function ioe(e){let t=Ep(e,lr.object({database:lr.string(),schema:lr.string()}).or("database","schema").messages({"object.missing":"'database' is required"}));if(t)throw new gp(t.message);pd(e);let r=await dd.checkSchemaExists(e.schema);if(r)throw Io(new Error,r,Co.NOT_FOUND,_d.LOG_LEVELS.ERROR,r,!0);let n=await dd.schema_describe.describeSchema({schema:e.schema}),s=Object.keys(global.hdb_schema[e.schema]);await ka.dropSchema(e),qg.signalSchemaChange(new $g(process.pid,e.operation,e.schema)),await jF.purgeSchemaTableStreams(e.schema,s);let i=await JF(e);return i.message=`successfully deleted '${e.schema}'`,i}a(ioe,"dropSchema");async function ooe(e){let t=Ep(e,lr.object({database:lr.string(),schema:lr.string(),table:lr.string().required()}));if(t)throw new gp(t.message);pd(e);let r=await dd.checkSchemaTableExists(e.schema,e.table);if(r)throw Io(new Error,r,Co.NOT_FOUND,_d.LOG_LEVELS.ERROR,r,!0);await ka.dropTable(e),await jF.purgeTableStream(e.schema,e.table);let n=await JF(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}a(ooe,"dropTable");async function aoe(e){let t=Ep(e,lr.object({database:lr.string(),schema:lr.string(),table:lr.string().required(),attribute:lr.string().required()}));if(t)throw new gp(t.message);pd(e);let r=await dd.checkSchemaTableExists(e.schema,e.table);if(r)throw Io(new Error,r,Co.NOT_FOUND,_d.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw Io(new Error,"You cannot drop a hash attribute",Co.BAD_REQUEST,void 0,void 0,!0);if(_d.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw Io(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Co.BAD_REQUEST,void 0,void 0,!0);try{return await ka.dropAttribute(e),coe(e),qg.signalSchemaChange(new $g(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw Jie.error(`Got an error deleting attribute ${Xie.inspect(e)}.`),n}}a(aoe,"dropAttribute");function coe(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(coe,"dropAttributeFromGlobal");async function loe(e){pd(e);let t=eoe()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw Io(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Co.BAD_REQUEST,void 0,void 0,!0);return await ka.createAttribute(e),qg.signalSchemaChange(new $g(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(loe,"createAttribute");function uoe(e){return ka.getBackup(e)}a(uoe,"getBackup")});var tG=w((cDe,eG)=>{"use strict";var{OPERATIONS_ENUM:doe}=(H(),C(G)),yN=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=doe.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};eG.exports=yN});var bN=w((dDe,oG)=>{"use strict";var foe=Vn(),uDe=tG(),Kg=ie(),Yg=(H(),C(G)),_oe=ae(),{handleHDBError:rG,hdb_errors:poe}=pe(),{HDB_ERROR_MSGS:nG,HTTP_STATUS_CODES:sG}=poe,hoe=Object.values(Yg.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),iG="To use this operation audit log must be enabled in harperdb-config.yaml";oG.exports=moe;async function moe(e){if(Kg.isEmpty(e.schema))throw new Error(nG.SCHEMA_REQUIRED_ERR);if(Kg.isEmpty(e.table))throw new Error(nG.TABLE_REQUIRED_ERR);if(!_oe.get(Yg.CONFIG_PARAMS.LOGGING_AUDITLOG))throw rG(new Error,iG,sG.BAD_REQUEST,Yg.LOG_LEVELS.ERROR,iG,!0);let t=Kg.checkSchemaTableExist(e.schema,e.table);if(t)throw rG(new Error,t,sG.NOT_FOUND,Yg.LOG_LEVELS.ERROR,t,!0);if(!Kg.isEmpty(e.search_type)&&hoe.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await foe.readAuditLog(e)}a(moe,"readAuditLog")});var cG=w((_De,aG)=>{"use strict";var{OPERATIONS_ENUM:Eoe}=(H(),C(G)),ON=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Eoe.GET_BACKUP,this.schema=t,this.table=r}};aG.exports=ON});var dG=w((EDe,uG)=>{"use strict";var goe=Vn(),hDe=cG(),NN=ie(),Soe=(H(),C(G)),mDe=ae(),{handleHDBError:Toe,hdb_errors:Aoe}=pe(),{HDB_ERROR_MSGS:lG,HTTP_STATUS_CODES:Roe}=Aoe;uG.exports=yoe;async function yoe(e){if(NN.isEmpty(e.schema))throw new Error(lG.SCHEMA_REQUIRED_ERR);if(NN.isEmpty(e.table))throw new Error(lG.TABLE_REQUIRED_ERR);let t=NN.checkSchemaTableExist(e.schema,e.table);if(t)throw Toe(new Error,t,Roe.NOT_FOUND,Soe.LOG_LEVELS.ERROR,t,!0);return await goe.getBackup(read_audit_log_object)}a(yoe,"getBackup")});var hG=w((SDe,pG)=>{"use strict";var boe=ae(),Fa=require("joi"),Ooe=it(),fG=require("moment"),Noe=require("fs-extra"),wN=require("path"),woe=require("lodash"),Sp=(H(),C(G)),{LOG_LEVELS:El}=(H(),C(G)),Ioe="YYYY-MM-DD hh:mm:ss",Coe=wN.resolve(__dirname,"../logs");pG.exports=function(e){return Ooe.validateBySchema(e,Poe)};var Poe=Fa.object({from:Fa.custom(_G),until:Fa.custom(_G),level:Fa.valid(El.NOTIFY,El.FATAL,El.ERROR,El.WARN,El.INFO,El.DEBUG,El.TRACE),order:Fa.valid("asc","desc"),limit:Fa.number().min(1),start:Fa.number().min(0),log_name:Fa.custom(Doe)});function _G(e,t){if(fG(e,fG.ISO_8601).format(Ioe)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(_G,"validateDatetime");function Doe(e,t){if(woe.invert(Sp.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=boe.get(Sp.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?Sp.LOG_NAMES.HDB:e,i=s===Sp.LOG_NAMES.INSTALL?wN.join(Coe,Sp.LOG_NAMES.INSTALL):wN.join(n,s);return Noe.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(Doe,"validateReadLogPath")});var CN=w((ADe,EG)=>{"use strict";var Wg=(H(),C(G)),Loe=z(),Moe=ae(),voe=hG(),IN=require("path"),mG=require("fs-extra"),{once:Uoe}=require("events"),{handleHDBError:xoe,hdb_errors:Boe}=pe(),{PACKAGE_ROOT:Hoe}=st(),koe=IN.join(Hoe,"logs"),Foe=1e3,Goe=200;EG.exports=qoe;async function qoe(e){let t=voe(e);if(t)throw xoe(t,t.message,Boe.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=Moe.get(Wg.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?Wg.LOG_NAMES.HDB:e.log_name,s=n===Wg.LOG_NAMES.INSTALL?IN.join(koe,Wg.LOG_NAMES.INSTALL):IN.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,l=c?new Date(e.from):void 0,u=e.until!==void 0,f=u?new Date(e.until):void 0,d=e.limit===void 0?Foe:e.limit,p=e.order===void 0?void 0:e.order,_=e.start===void 0?0:e.start,h=_+d,S=0;p==="desc"&&!l&&!f&&(S=Math.max(mG.statSync(s).size-(h+5)*Goe,0));let g=mG.createReadStream(s,{start:S});g.on("error",F=>{Loe.error(F)});let R=0,E=[],T="",b;g.on("data",F=>{let q=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;F=T+F;let Y=0,Z;for(;(Z=q.exec(F))&&!g.destroyed;){b&&(b.message=F.slice(Y,Z.index),v(b));let[se,Q,ne]=Z,J=ne.split("] ["),he=J[0],Re=J[1];J.splice(0,2),b={timestamp:Q,thread:he,level:Re,tags:J,message:""},Y=Z.index+se.length}T=F.slice(Y)}),g.on("end",F=>{g.destroyed||b&&(b.message=T.trim(),v(b))}),g.resume();function v(F){let q,Y,Z;switch(!0){case(i&&c&&u):q=new Date(F.timestamp),Y=new Date(l),Z=new Date(f),F.level===o&&q>=Y&&q<=Z&&R<_?R++:F.level===o&&q>=Y&&q<=Z&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case(i&&c):q=new Date(F.timestamp),Y=new Date(l),F.level===o&&q>=Y&&R<_?R++:F.level===o&&q>=Y&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case(i&&u):q=new Date(F.timestamp),Z=new Date(f),F.level===o&&q<=Z&&R<_?R++:F.level===o&&q<=Z&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case(c&&u):q=new Date(F.timestamp),Y=new Date(l),Z=new Date(f),q>=Y&&q<=Z&&R<_?R++:q>=Y&&q<=Z&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case i:F.level===o&&R<_?R++:F.level===o&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case c:q=new Date(F.timestamp),Y=new Date(l),q>=Y&&R<_?R++:q>=Y&&R>=_&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case u:q=new Date(F.timestamp),Z=new Date(f),q<=Z&&R<_?R++:q<=Z&&R>=_&&(Ga(F,p,E),R++,R===h&&g.destroy());break;default:R<_?R++:(Ga(F,p,E),R++,R===h&&g.destroy())}}return a(v,"onLogMessage"),await Uoe(g,"close"),E}a(qoe,"readLog");function Ga(e,t,r){t==="desc"?$oe(e,r):t==="asc"?Voe(e,r):r.push(e)}a(Ga,"pushLineToResult");function $oe(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)>r?n=i+1:s=i}t.splice(n,0,e)}a($oe,"insertDescending");function Voe(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(Voe,"insertAscending")});var zg=w((wDe,AG)=>{"use strict";var PN=require("joi"),{string:hd,boolean:gG,date:Koe}=PN.types(),Yoe=it(),{validateSchemaExists:yDe,validateTableExists:bDe,validateSchemaName:ODe}=Di(),Woe=(H(),C(G)),zoe=Tt(),SG=ae();SG.initSync();var NDe=hd.invalid(SG.get(Woe.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(zoe.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),TG={operation:hd.valid("add_node","update_node","set_node_replication"),node_name:hd.optional(),subscriptions:PN.array().items({table:hd.optional(),schema:hd.optional(),database:hd.optional(),subscribe:gG.required(),publish:gG.required().custom(Joe),start_time:Koe.iso()})};function joe(e){return Yoe.validateBySchema(e,PN.object(TG))}a(joe,"addUpdateNodeValidator");function Joe(e,t){if(t.state.ancestors[2].operation==="add_node"&&e===!1&&t.state.ancestors[0].subscribe===!1)return t.message(`'subscriptions[${t.state.path[1]}]' subscribe and/or publish must be set to true when adding a node`)}a(Joe,"checkForFalsy");AG.exports={addUpdateNodeValidator:joe,validation_schema:TG}});var md=w((CDe,RG)=>{"use strict";var DN=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},LN=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};RG.exports={Node:DN,NodeSubscription:LN}});var bG=w((DDe,yG)=>{"use strict";var Qoe=(H(),C(G)).OPERATIONS_ENUM,MN=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Qoe.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};yG.exports=MN});var Tp=w((MDe,OG)=>{"use strict";var vN=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},UN=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)}};OG.exports={RemotePayloadObject:vN,RemotePayloadSubscription:UN}});var wG=w((UDe,NG)=>{"use strict";var xN=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}};NG.exports=xN});var CG=w((GDe,IG)=>{"use strict";var Xoe=wG(),BDe=Ut(),HDe=_t(),Zoe=z(),{getSchemaPath:kDe,getTransactionAuditStorePath:FDe}=gt(),{getDatabases:eae}=(Pe(),C(tt));IG.exports=tae;async function tae(e){let t=new Xoe;try{let r=eae()[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){Zoe.warn(`unable to stat table dbi due to ${r}`)}return t}a(tae,"lmdbGetTableSize")});var DG=w(($De,PG)=>{"use strict";var BN=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}};PG.exports=BN});var Po=w((jDe,UG)=>{"use strict";var rae=require("fs-extra"),nae=require("path"),Xr=require("systeminformation"),qa=z(),LG=ir(),KDe=Tt(),Ed=(H(),C(G)),sae=CG(),iae=go(),{getThreadInfo:MG}=et(),Ap=ae();Ap.initSync();var oae=DG(),{openEnvironment:YDe}=_t(),{getSchemaPath:WDe}=gt(),{database:zDe,databases:HN}=(Pe(),C(tt)),jg;UG.exports={getHDBProcessInfo:qN,getNetworkInfo:VN,getDiskInfo:$N,getMemoryInfo:GN,getCPUInfo:FN,getTimeInfo:kN,getSystemInformation:KN,systemInformation:aae,getTableSize:YN,getMetrics:WN};function kN(){return Xr.time()}a(kN,"getTimeInfo");async function FN(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:u,...f}=await Xr.cpu();f.cpu_speed=await Xr.cpuCurrentSpeed();let{raw_currentload:d,raw_currentload_idle:p,raw_currentload_irq:_,raw_currentload_nice:h,raw_currentload_system:S,raw_currentload_user:g,cpus:R,...E}=await Xr.currentLoad();return E.cpus=[],R.forEach(T=>{let{raw_load:b,raw_load_idle:v,raw_load_irq:F,raw_load_nice:q,raw_load_system:Y,raw_load_user:Z,...se}=T;E.cpus.push(se)}),f.current_load=E,f}catch(e){return qa.error(`error in getCPUInfo: ${e}`),{}}}a(FN,"getCPUInfo");async function GN(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Xr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return qa.error(`error in getMemoryInfo: ${e}`),{}}}a(GN,"getMemoryInfo");async function qN(){let e={core:[],clustering:[]};try{let t=await Xr.processes(),r;try{r=Number.parseInt(await rae.readFile(nae.join(Ap.get(Ed.CONFIG_PARAMS.ROOTPATH),Ed.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Ed.NODE_ERROR_CODES.ENOENT)qa.warn("Unable to locate 'hdb.pid' file, try stopping and starting HarperDB. This could be because HarperDB is not running.");else throw n}t.list.forEach(n=>{n.pid===r?e.core.push(n):n.name==="nats-server"&&e.clustering.push(n)});for(let n of e.core)for(let s of t.list)s.pid===n.parentPid&&(s.name==="PM2"||s.command==="PM2")&&(n.parent="PM2");return e}catch(t){return qa.error(`error in getHDBProcessInfo: ${t}`),e}}a(qN,"getHDBProcessInfo");async function $N(){let e={};try{if(!Ap.get(Ed.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Xr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...u}=await Xr.fsStats();return e.read_write=u,e.size=await Xr.fsSize(),e}catch(t){return qa.error(`error in getDiskInfo: ${t}`),e}}a($N,"getDiskInfo");async function VN(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return Ap.get(Ed.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await Xr.networkInterfaceDefault(),e.latency=await Xr.inetChecksite("google.com"),(await Xr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:u,ieee8021xState:f,carrier_changes:d,...p}=n;e.interfaces.push(p)}),(await Xr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)})),e}catch(t){return qa.error(`error in getNetworkInfo: ${t}`),e}}a(VN,"getNetworkInfo");async function KN(){if(jg!==void 0)return jg;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Xr.osInfo();e=c;let l=await Xr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,jg=e,jg}catch(t){return qa.error(`error in getSystemInformation: ${t}`),e}}a(KN,"getSystemInformation");async function YN(){let e=[],t=await iae.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await sae(n));return e}a(YN,"getTableSize");async function WN(){let e={};for(let t in HN){let r=e[t]={},n=r.tables={};for(let s in HN[t])try{let i=HN[t][s];if(!r.readers&&(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[u,f,d]=l.trim().split(" ");return{pid:u,thread:f,txnid:d}}),i.auditStore)){let{treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:f,entryCount:d,overflowPages:p}=i.auditStore.getStats();r.audit={treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:f,entryCount:d,overflowPages:p}}let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){qa.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(WN,"getMetrics");async function vG(){if(Ap.get(Ed.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await LG.getNATSReferences(),t=await LG.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(vG,"getNatsStreamInfo");async function aae(e){let t=new oae;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await KN(),t.time=kN(),t.cpu=await FN(),t.memory=await GN(),t.disk=await $N(),t.network=await VN(),t.harperdb_processes=await qN(),t.table_size=await YN(),t.metrics=await WN(),t.threads=await MG(),t.replication=await vG(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await KN();break;case"time":t.time=kN();break;case"cpu":t.cpu=await FN();break;case"memory":t.memory=await GN();break;case"disk":t.disk=await $N();break;case"network":t.network=await VN();break;case"harperdb_processes":t.harperdb_processes=await qN();break;case"table_size":t.table_size=await YN();break;case"database_metrics":case"metrics":t.metrics=await WN();break;case"threads":t.threads=await MG();break;case"replication":t.replication=await vG();break;default:break}return t}a(aae,"systemInformation")});var Do=w((ZDe,kG)=>{"use strict";var cae=Rn(),zN=ie(),lae=require("util"),gl=(H(),C(G)),xG=ae();xG.initSync();var uae=NO(),BG=Yr(),{Node:QDe,NodeSubscription:XDe}=md(),dae=ku(),fae=bG(),{RemotePayloadObject:_ae,RemotePayloadSubscription:pae}=Tp(),{handleHDBError:hae,hdb_errors:mae}=pe(),{HTTP_STATUS_CODES:Eae,HDB_ERROR_MSGS:gae}=mae,Sae=ni(),Tae=Po(),{packageJson:Aae}=st(),{getDatabases:Rae}=(Pe(),C(tt)),yae=lae.promisify(uae.authorize),bae=BG.searchByHash,Oae=BG.searchByValue;kG.exports={authHeaderToUser:Nae,isEmpty:wae,getNodeRecord:Iae,upsertNodeRecord:Cae,buildNodePayloads:Pae,checkClusteringEnabled:Dae,getAllNodeRecords:Lae,getSystemInfo:Mae,reverseSubscription:HG};async function Nae(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await yae(t,null),e}a(Nae,"authHeaderToUser");function wae(e){return e==null}a(wae,"isEmpty");async function Iae(e){let t=new dae(gl.SYSTEM_SCHEMA_NAME,gl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return bae(t)}a(Iae,"getNodeRecord");async function Cae(e){let t=new fae(gl.SYSTEM_SCHEMA_NAME,gl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return cae.upsert(t)}a(Cae,"upsertNodeRecord");function HG(e){if(zN.isEmpty(e.subscribe)||zN.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(HG,"reverseSubscription");function Pae(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:u}=c,f=zN.getTableHashAttribute(l,u),{subscribe:d,publish:p}=HG(c),_=Rae()[l]?.[u],h=new pae(l,u,f,p,d,c.start_time,_.schemaDefined?_.attributes:void 0);s.push(h)}return new _ae(r,t,s,n)}a(Pae,"buildNodePayloads");function Dae(){if(!xG.get(gl.CONFIG_PARAMS.CLUSTERING_ENABLED))throw hae(new Error,gae.CLUSTERING_NOT_ENABLED,Eae.BAD_REQUEST,void 0,void 0,!0)}a(Dae,"checkClusteringEnabled");async function Lae(){let e=new Sae(gl.SYSTEM_SCHEMA_NAME,gl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await Oae(e))}a(Lae,"getAllNodeRecords");async function Mae(){let e=await Tae.getSystemInformation();return{hdb_version:Aae.version,node_version:e.node_version,platform:e.platform}}a(Mae,"getSystemInfo")});var jN=w((tLe,WG)=>{"use strict";var Jg=ir(),FG=ie(),GG=Tt(),qG=(H(),C(G)),Qg=z(),$G=Vg(),vae=v_(),{RemotePayloadObject:Uae}=Tp(),{handleHDBError:VG,hdb_errors:xae}=pe(),{HTTP_STATUS_CODES:KG}=xae,{NodeSubscription:YG}=md();WG.exports=Bae;async function Bae(e,t){let r;try{r=await Jg.request(`${t}.${GG.REQUEST_SUFFIX}`,new Uae(qG.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),Qg.trace("Response from remote describe all request:",r)}catch(o){Qg.error(`addNode received error from describe all request to remote node: ${o}`);let c=Jg.requestErrorHandler(o,"add_node",t);throw VG(new Error,c,KG.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===GG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw VG(new Error,o,KG.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===qG.SYSTEM_SCHEMA_NAME){await Jg.createLocalTableStream(l,c);let h=new YG(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let u=FG.doesSchemaExist(l),f=n[l]!==void 0,d=c?FG.doesTableExist(l,c):!0,p=c?n?.[l]?.[c]!==void 0:!0;if(!u&&!f||!d&&!p){s.push(o);continue}if(!u&&f&&(Qg.trace(`addNode creating schema: ${l}`),await $G.createSchema({operation:"create_schema",schema:l})),!d&&p){Qg.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new vae(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await $G.createTable(h)}await Jg.createLocalTableStream(l,c);let _=new YG(l,c,o.publish,o.subscribe);_.start_time=o.start_time,i.push(_)}return{added:i,skipped:s}}a(Bae,"reviewSubscriptions")});var Sl={};ve(Sl,{addNodeBack:()=>qae,removeNodeBack:()=>$ae,setNode:()=>Gae});async function Gae(e){e.node_name&&!e.hostname&&(e.hostname=e.node_name),e.verify_tls!==void 0&&(e.rejectUnauthorized=e.verify_tls);let{url:t,hostname:r}=e;t?r||(r=e.hostname=ai(t)):t=kg(r);let n=(0,jG.validateBySchema)(e,Fae);if(n)throw(0,Lo.handleHDBError)(n,n.message,kae.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new Lo.ClientError("url or hostname is required for remove_node operation");let _=r,h=or(),S=await h.get(_);if(!S)throw new Lo.ClientError(_+" does not exist");try{await mp({url:S.url},{operation:Kt.REMOVE_NODE_BACK,name:S?.subscriptions?.length>0?Xe():_},void 0)}catch(g){es.warn(`Error removing node from target node ${_}, if it is offline and we be online in the future, you may need to clean up this node manually, or retry:`,g)}return await h.delete(_),`Successfully removed '${_}' from cluster`}if(!t)throw new Lo.ClientError("url required for this operation");let s=La();if(s==null)throw new Lo.ClientError("replication url is missing from harperdb-config.yaml");let i,o,c;if(t?.startsWith("wss:")){i=await(0,Ns.getReplicationCert)();let _=await(0,Ns.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,Ns.createCsr)(),es.info("Sending CSR to target node:",t)):_&&(c=_.certificate,es.info("Sending CA named",_.name,"to target node",t))}let l={operation:Kt.ADD_NODE_BACK,hostname:(0,JG.get)(B.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(zG):l.subscriptions=null,e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let _=zG(e);l.subscribe=_.subscribe,l.publish=_.publish}e?.authorization?.username&&e?.authorization?.password&&(e.authorization="Basic "+Buffer.from(e.authorization.username+":"+e.authorization.password).toString("base64"));let u,f;try{u=await mp({url:t},l,e)}catch(_){_.message=`Error returned from ${t}: `+_.message,es.warn("Error adding node:",t,"to cluster:",_),f=_}if(o&&(!u?.certificate||!u?.certificate?.includes?.("BEGIN CERTIFICATE")))throw f?(f.message+=" and connection was required to sign certificate",f):new Error(`Unexpected certificate signature response from node ${t} response: ${JSON.stringify(u)}`);o&&(es.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,Ns.setCertTable)({name:Hae.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,Ns.setCertTable)({name:Xe(),uses:["https","operations","wss"],certificate:u.certificate,private_key_name:i?.options?.key_file,is_authority:!1,is_self_signed:!1}),c=u.signingCA);let d={url:t,ca:u?.usingCA};if(e.hostname&&(d.name=e.hostname),e.subscriptions?d.subscriptions=e.subscriptions:d.replicates=!0,e.start_time&&(d.start_time=typeof e.start_time=="string"?new Date(e.start_time).getTime():e.start_time),e.retain_authorization&&(d.authorization=e.authorization),e.revoked_certificates&&(d.revoked_certificates=e.revoked_certificates),e.shard&&(d.shard=e.shard),d.replicates){let _={url:s,ca:c,replicates:!0,subscriptions:null};e.retain_authorization&&(_.authorization=e.authorization),e.start_time&&(_.start_time=e.start_time),await Oo(Xe(),_)}await Oo(u?u.nodeName:d.name??ai(t),d);let p;return e.operation==="update_node"?p=`Successfully updated '${t}'`:p=`Successfully added '${t}' to cluster`,f&&(p+=" but there was an error updating target node: "+f.message),p}async function qae(e){es.trace("addNodeBack received request:",e);let t=await(0,Ns.signCertificate)(e),r;e.csr?(r=t.signingCA,es.info("addNodeBack received CSR from node:",e.url,"this node will use and respond with CA that was used to issue CSR")):(r=e?.cert_auth,es.info("addNodeBack received CA from node:",e.url));let n={url:e.url,ca:r};e.subscriptions?n.subscriptions=e.subscriptions:(n.replicates=!0,n.subscriptions=null),e.start_time&&(n.start_time=e.start_time),e.authorization&&(n.authorization=e.authorization);let s=await(0,Ns.getReplicationCertAuth)();if(n.replicates){let i={url:La(),ca:s?.certificate,replicates:!0,subscriptions:null};e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await Oo(Xe(),i)}return await Oo(e.hostname,n),t.nodeName=Xe(),t.usingCA=s?.certificate,es.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function $ae(e){es.trace("removeNodeBack received request:",e),await or().delete(e.name)}function zG(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var Ns,jG,$a,JG,es,Lo,Hae,kae,Fae,Tl=be(()=>{Ns=M(Zn()),jG=M(it()),$a=M(require("joi")),JG=M(ae());H();lp();ul();Xn();es=M(z()),Lo=M(pe()),{pki:Hae}=require("node-forge"),{HTTP_STATUS_CODES:kae}=Lo.hdb_errors,Fae=$a.default.object({hostname:$a.default.string(),verify_tls:$a.default.boolean(),replicates:$a.default.boolean(),subscriptions:$a.default.array(),revoked_certificates:$a.default.array(),shard:$a.default.number()});a(Gae,"setNode");a(qae,"addNodeBack");a($ae,"removeNodeBack");a(zG,"reverseSubscription")});var gd=w((uLe,XG)=>{"use strict";var{handleHDBError:Xg,hdb_errors:Vae}=pe(),{HTTP_STATUS_CODES:Zg}=Vae,{addUpdateNodeValidator:Kae}=zg(),eS=z(),tS=(H(),C(G)),QG=Tt(),Yae=ie(),Rp=ir(),yp=Do(),JN=ae(),Wae=jN(),{Node:zae,NodeSubscription:jae}=md(),{broadcast:Jae}=et(),{setNode:Qae}=(Tl(),C(Sl)),cLe=ae(),lLe=(H(),C(G)),Xae="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",Zae="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",ece=JN.get(tS.CONFIG_PARAMS.CLUSTERING_NODENAME);XG.exports=tce;async function tce(e,t=!1){if(eS.trace("addNode called with:",e),JN.get(tS.CONFIG_PARAMS.REPLICATION_URL)||JN.get(tS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Qae(e);yp.checkClusteringEnabled();let r=Kae(e);if(r)throw Xg(r,r.message,Zg.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await yp.getNodeRecord(n);if(!Yae.isEmptyOrZeroLength(d))throw Xg(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,Zg.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await Wae(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=Xae,o;let c=yp.buildNodePayloads(s,ece,tS.OPERATIONS_ENUM.ADD_NODE,await yp.getSystemInfo()),l=[];for(let d=0,p=s.length;d<p;d++){let _=s[d];s[d].start_time===void 0&&delete s[d].start_time,l.push(new jae(_.schema,_.table,_.publish,_.subscribe))}eS.trace("addNode sending remote payload:",c);let u;try{u=await Rp.request(`${n}.${QG.REQUEST_SUFFIX}`,c)}catch(d){eS.error(`addNode received error from request: ${d}`);for(let _=0,h=s.length;_<h;_++){let S=s[_];S.publish=!1,S.subscribe=!1,await Rp.updateRemoteConsumer(S,n)}let p=Rp.requestErrorHandler(d,"add_node",n);throw Xg(new Error,p,Zg.INTERNAL_SERVER_ERROR,"error",p)}if(u.status===QG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${n}: ${u.message}`;throw Xg(new Error,d,Zg.INTERNAL_SERVER_ERROR,"error",d)}eS.trace(u);for(let d=0,p=s.length;d<p;d++){let _=s[d];await Rp.updateRemoteConsumer(_,n),_.subscribe===!0&&await Rp.updateConsumerIterator(_.schema,_.table,n,"start")}let f=new zae(n,l,u.system_info);return await yp.upsertNodeRecord(f),Jae({type:"nats_update"}),i.length>0?o.message=Zae:o.message=`Successfully added '${n}' to manifest`,o}a(tce,"addNode")});var ew=w((_Le,eq)=>{"use strict";var{handleHDBError:QN,hdb_errors:rce}=pe(),{HTTP_STATUS_CODES:XN}=rce,{addUpdateNodeValidator:nce}=zg(),bp=z(),rS=(H(),C(G)),ZG=Tt(),fLe=ie(),Op=ir(),Np=Do(),ZN=ae(),{cloneDeep:sce}=require("lodash"),ice=jN(),{Node:oce,NodeSubscription:ace}=md(),{broadcast:cce}=et(),{setNode:lce}=(Tl(),C(Sl)),uce="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",dce="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",fce=ZN.get(rS.CONFIG_PARAMS.CLUSTERING_NODENAME);eq.exports=_ce;async function _ce(e){if(bp.trace("updateNode called with:",e),ZN.get(rS.CONFIG_PARAMS.REPLICATION_URL)??ZN.get(rS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return lce(e);Np.checkClusteringEnabled();let t=nce(e);if(t)throw QN(t,t.message,XN.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Np.getNodeRecord(r);s.length>0&&(n=sce(s));let{added:i,skipped:o}=await ice(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=uce,c;let l=Np.buildNodePayloads(i,fce,rS.OPERATIONS_ENUM.UPDATE_NODE,await Np.getSystemInfo());for(let f=0,d=i.length;f<d;f++){let p=i[f];bp.trace(`updateNode updating work stream for node: ${r} subscription:`,p),i[f].start_time===void 0&&delete i[f].start_time}bp.trace("updateNode sending remote payload:",l);let u;try{u=await Op.request(`${r}.${ZG.REQUEST_SUFFIX}`,l)}catch(f){bp.error(`updateNode received error from request: ${f}`);let d=Op.requestErrorHandler(f,"update_node",r);throw QN(new Error,d,XN.INTERNAL_SERVER_ERROR,"error",d)}if(u.status===ZG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let f=`Error returned from remote node ${r}: ${u.message}`;throw QN(new Error,f,XN.INTERNAL_SERVER_ERROR,"error",f)}bp.trace(u);for(let f=0,d=i.length;f<d;f++){let p=i[f];await Op.updateRemoteConsumer(p,r),p.subscribe===!0?await Op.updateConsumerIterator(p.schema,p.table,r,"start"):await Op.updateConsumerIterator(p.schema,p.table,r,"stop")}return n||(n=[new oce(r,[],u.system_info)]),await pce(n[0],i,u.system_info),o.length>0?c.message=dce:c.message=`Successfully updated '${r}'`,c}a(_ce,"updateNode");async function pce(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let l=0,u=e.subscriptions.length;l<u;l++){let f=n.subscriptions[l];if(f.schema===o.schema&&f.table===o.table){f.publish=o.publish,f.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new ace(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await Np.upsertNodeRecord(n),cce({type:"nats_update"})}a(pce,"updateNodeTable")});var iq=w((hLe,sq)=>{"use strict";var nq=require("joi"),{string:tq}=nq.types(),hce=it(),rq=(H(),C(G)),mce=ae(),Ece=Tt();sq.exports=gce;function gce(e){let t=tq.invalid(mce.get(rq.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(Ece.NATS_TERM_CONSTRAINTS_RX).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >","any.invalid":"'node_name' cannot be this nodes name"}).empty(null),r=nq.object({operation:tq.valid(rq.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return hce.validateBySchema(e,r)}a(gce,"removeNodeValidator")});var nS=w((ELe,uq)=>{"use strict";var{handleHDBError:oq,hdb_errors:Sce}=pe(),{HTTP_STATUS_CODES:aq}=Sce,Tce=iq(),wp=z(),cq=Do(),Ace=ie(),Sd=(H(),C(G)),lq=Tt(),tw=ir(),rw=ae(),{RemotePayloadObject:Rce}=Tp(),{NodeSubscription:yce}=md(),bce=M_(),Oce=Vc(),{broadcast:Nce}=et(),{setNode:wce}=(Tl(),C(Sl)),Ice=rw.get(Sd.CONFIG_PARAMS.CLUSTERING_NODENAME);uq.exports=Cce;async function Cce(e){if(wp.trace("removeNode called with:",e),rw.get(Sd.CONFIG_PARAMS.REPLICATION_URL)??rw.get(Sd.CONFIG_PARAMS.REPLICATION_HOSTNAME))return wce(e);cq.checkClusteringEnabled();let t=Tce(e);if(t)throw oq(t,t.message,aq.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await cq.getNodeRecord(r);if(Ace.isEmptyOrZeroLength(n))throw oq(new Error,`Node '${r}' was not found.`,aq.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new Rce(Sd.OPERATIONS_ENUM.REMOVE_NODE,Ice,[]),i,o=!1;for(let l=0,u=n.subscriptions.length;l<u;l++){let f=n.subscriptions[l];f.subscribe===!0&&await tw.updateConsumerIterator(f.schema,f.table,r,"stop");try{await tw.updateRemoteConsumer(new yce(f.schema,f.table,!1,!1),r)}catch(d){wp.error(d)}}try{i=await tw.request(`${r}.${lq.REQUEST_SUFFIX}`,s),wp.trace("Remove node reply from remote node:",r,i)}catch(l){wp.error("removeNode received error from request:",l),o=!0}let c=new bce(Sd.SYSTEM_SCHEMA_NAME,Sd.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Oce.deleteRecord(c),Nce({type:"nats_update"}),i?.status===lq.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(wp.error("Error returned from remote node:",r,i?.message),`Successfully removed '${r}' from local manifest, however there was an error reaching remote node. Check the logs for more details.`):`Successfully removed '${r}' from manifest`}a(Cce,"removeNode")});var _q=w((SLe,fq)=>{"use strict";var dq=require("joi"),{string:Pce,array:Dce}=dq.types(),Lce=it(),Mce=zg();fq.exports=vce;function vce(e){let t=dq.object({operation:Pce.valid("configure_cluster").required(),connections:Dce.items(Mce.validation_schema).required()});return Lce.validateBySchema(e,t)}a(vce,"configureClusterValidator")});var nw=w((ALe,gq)=>{"use strict";var pq=(H(),C(G)),sS=z(),Uce=ie(),xce=ae(),Bce=nS(),Hce=gd(),kce=Do(),Fce=_q(),{handleHDBError:hq,hdb_errors:Gce}=pe(),{HTTP_STATUS_CODES:mq}=Gce,qce="Configure cluster complete.",$ce="Failed to configure the cluster. Check the logs for more details.",Vce="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";gq.exports=Kce;async function Kce(e){sS.trace("configure cluster called with:",e);let t=Fce(e);if(t)throw hq(t,t.message,mq.BAD_REQUEST,void 0,void 0,!0);let r=await kce.getAllNodeRecords(),n=[];if(xce.get(pq.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let f=0,d=r.length;f<d;f++){let p=await Eq(Bce,{operation:pq.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[f].name},r[f].name);n.push(p)}sS.trace("All results from configure_cluster remove node:",n)}let s=[],i=e.connections.length;for(let f=0;f<i;f++){let d=e.connections[f],p=await Eq(Hce,d,d.node_name);s.push(p)}sS.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,u=n.concat(s);for(let f=0,d=u.length;f<d;f++){let p=u[f];p.status==="rejected"&&(sS.error(p.node_name,p?.error?.message,p?.error?.stack),o.includes(p.node_name)||o.push(p.node_name)),(p?.result?.message?.includes?.("Successfully")||p?.result?.includes?.("Successfully"))&&(l=!0),!(typeof p.result=="string"&&p.result.includes("Successfully removed")||p.status==="rejected")&&c.push({node_name:p?.node_name,response:p?.result})}if(Uce.isEmptyOrZeroLength(o))return{message:qce,connections:c};if(l)return{message:Vce,failed_nodes:o,connections:c};throw hq(new Error,$ce,mq.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(Kce,"configureCluster");async function Eq(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(Eq,"functionWrapper")});var Rq=w((yLe,Aq)=>{"use strict";var Ip=require("joi"),Yce=it(),{validateSchemaExists:Sq,validateTableExists:Wce,validateSchemaName:Tq}=Di(),zce=Ip.object({operation:Ip.string().valid("purge_stream"),schema:Ip.string().custom(Sq).custom(Tq).optional(),database:Ip.string().custom(Sq).custom(Tq).optional(),table:Ip.string().custom(Wce).required()});function jce(e){return Yce.validateBySchema(e,zce)}a(jce,"purgeStreamValidator");Aq.exports=jce});var sw=w((OLe,yq)=>{"use strict";var{handleHDBError:Jce,hdb_errors:Qce}=pe(),{HTTP_STATUS_CODES:Xce}=Qce,Zce=Rq(),ele=ir(),tle=Do();yq.exports=rle;async function rle(e){e.schema=e.schema??e.database;let t=Zce(e);if(t)throw Jce(t,t.message,Xce.BAD_REQUEST,void 0,void 0,!0);tle.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await ele.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(rle,"purgeStream")});var aS=w((wLe,Pq)=>{"use strict";var ow=Do(),nle=ir(),oS=ae(),Td=(H(),C(G)),Al=Tt(),sle=ie(),iw=z(),{RemotePayloadObject:ile}=Tp(),{ErrorCode:bq}=require("nats"),{parentPort:Oq}=require("worker_threads"),{onMessageByType:ole}=et(),{getThisNodeName:ale}=(Xn(),C(wo)),{requestClusterStatus:cle}=(lp(),C(zk)),{getReplicationSharedStatus:lle}=(ul(),C(zO)),{CONFIRMATION_STATUS_POSITION:ule,RECEIVED_VERSION_POSITION:dle,RECEIVED_TIME_POSITION:fle,SENDING_TIME_POSITION:_le}=(gN(),C(xF)),Nq=oS.get(Td.CONFIG_PARAMS.CLUSTERING_ENABLED),wq=oS.get(Td.CONFIG_PARAMS.CLUSTERING_NODENAME);Pq.exports={clusterStatus:ple,buildNodeStatus:Cq};var Iq;ole("cluster-status",async e=>{Iq(e)});async function ple(){if(oS.get(Td.CONFIG_PARAMS.REPLICATION_URL)||oS.get(Td.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;if(Oq){Oq.postMessage({type:"request-cluster-status"}),n=await new Promise(s=>{Iq=s});for(let s of n.connections){let i=s.name;for(let o of s.database_sockets){let c=o.database,l;for(let f of Object.values(databases[c]||{}))if(l=f.auditStore,l)break;if(!l)continue;let u=lle(l,c,i);o.lastCommitConfirmed=iS(u[ule]),o.lastReceivedRemoteTime=iS(u[dle]),o.lastReceivedLocalTime=iS(u[fle]),o.sendingMessage=iS(u[_le])}}}else n=cle();return n.node_name=ale(),n.is_enabled=!0,n}let e={node_name:wq,is_enabled:Nq,connections:[]};if(!Nq)return e;let t=await ow.getAllNodeRecords();if(sle.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(Cq(t[n],e.connections));return await Promise.allSettled(r),e}a(ple,"clusterStatus");function iS(e){return e?e===1?"Copying":new Date(e).toUTCString():void 0}a(iS,"asDate");async function Cq(e,t){let r=e.name,n=new ile(Td.OPERATIONS_ENUM.CLUSTER_STATUS,wq,void 0,await ow.getSystemInfo()),s,i,o=Al.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await nle.request(Al.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Al.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=Al.CLUSTER_STATUS_STATUSES.CLOSED,iw.error(`Error getting node status from ${r} `,s))}catch(l){iw.warn(`Error getting node status from ${r}`,l),l.code===bq.NoResponders?o=Al.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===bq.Timeout?o=Al.CLUSTER_STATUS_STATUSES.TIMEOUT:o=Al.CLUSTER_STATUS_STATUSES.CLOSED}let c=new hle(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let l={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==Td.PRE_4_0_0_VERSION&&await ow.upsertNodeRecord(l)}catch(l){iw.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(Cq,"buildNodeStatus");function hle(e,t,r,n,s,i,o,c){this.node_name=e,this.status=t,this.ports={clustering:r,operations_api:n},this.latency_ms=s,this.uptime=i,this.subscriptions=o,this.system_info=c}a(hle,"NodeStatusObject")});var lS=w((CLe,Dq)=>{"use strict";var{handleHDBError:mle,hdb_errors:Ele}=pe(),{HTTP_STATUS_CODES:gle}=Ele,Sle=ir(),Tle=Do(),aw=ie(),cS=require("joi"),Ale=it(),Rle=2e3,yle=cS.object({timeout:cS.number().min(1),connected_nodes:cS.boolean(),routes:cS.boolean()});Dq.exports=ble;async function ble(e){Tle.checkClusteringEnabled();let t=Ale.validateBySchema(e,yle);if(t)throw mle(t,t.message,gle.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||aw.autoCastBoolean(n),o=s===void 0||aw.autoCastBoolean(s),c={nodes:[]},l=await Sle.getServerList(r??Rle),u={};if(i)for(let f=0,d=l.length;f<d;f++){let p=l[f].statsz;p&&(u[l[f].server.name]=p.routes)}for(let f=0,d=l.length;f<d;f++){if(l[f].statsz)continue;let p=l[f].server,_=l[f].data;if(p.name.endsWith("-hub")){let h={name:p.name.slice(0,-4),response_time:l[f].response_time};i&&(h.connected_nodes=[],u[p.name]&&u[p.name].forEach(S=>{h.connected_nodes.includes(S.name.slice(0,-4))||h.connected_nodes.push(S.name.slice(0,-4))})),o&&(h.routes=_.cluster?.urls?_.cluster?.urls.map(S=>({host:S.split(":")[0],port:aw.autoCast(S.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(ble,"clusterNetwork")});var Uq=w((DLe,vq)=>{"use strict";var cw=require("joi"),Lq=it(),{route_constraints:Mq}=Ky();vq.exports={setRoutesValidator:Ole,deleteRoutesValidator:Nle};function Ole(e){let t=cw.object({server:cw.valid("hub","leaf"),routes:Mq.required()});return Lq.validateBySchema(e,t)}a(Ole,"setRoutesValidator");function Nle(e){let t=cw.object({routes:Mq.required()});return Lq.validateBySchema(e,t)}a(Nle,"deleteRoutesValidator")});var uS=w((MLe,qq)=>{"use strict";var Mo=yt(),lw=ie(),ws=(H(),C(G)),Ad=ae(),xq=Uq(),{handleHDBError:Bq,hdb_errors:wle}=pe(),{HTTP_STATUS_CODES:Hq}=wle,kq="cluster routes successfully set",Fq="cluster routes successfully deleted";qq.exports={setRoutes:Cle,getRoutes:Ple,deleteRoutes:Dle};function Ile(e){let t=Mo.getClusteringRoutes(),r=e.server==="hub"?t.hub_routes:t.leaf_routes,n=e.server==="hub"?t.leaf_routes:t.hub_routes,s=[],i=[];for(let o=0,c=e.routes.length;o<c;o++){let l=e.routes[o];l.port=lw.autoCast(l.port);let u=r.some(d=>d.host===l.host&&d.port===l.port),f=n.some(d=>d.host===l.host&&d.port===l.port);u||f?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?Mo.updateConfigValue(ws.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):Mo.updateConfigValue(ws.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:kq,set:i,skipped:s}}a(Ile,"setRoutesNats");function Cle(e){let t=xq.setRoutesValidator(e);if(t)throw Bq(t,t.message,Hq.BAD_REQUEST,void 0,void 0,!0);if(Ad.get(ws.CONFIG_PARAMS.CLUSTERING_ENABLED))return Ile(e);let r=[],n=[],s=Ad.get(ws.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{Gq(s,i)?n.push(i):(s.push(i),r.push(i))}),Mo.updateConfigValue(ws.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:kq,set:r,skipped:n}}a(Cle,"setRoutes");function Gq(e,t){return typeof t=="string"?e.includes(t):typeof t=="object"&&t!==null?e.some(r=>(r.host===t.host||r.hostname===t.hostname)&&r.port===t.port):!1}a(Gq,"existsInArray");function Ple(){if(Ad.get(ws.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=Mo.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return Ad.get(ws.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(Ple,"getRoutes");function Dle(e){let t=xq.deleteRoutesValidator(e);if(t)throw Bq(t,t.message,Hq.BAD_REQUEST,void 0,void 0,!0);if(Ad.get(ws.CONFIG_PARAMS.CLUSTERING_ENABLED))return Lle(e);let r=[],n=[],s=Ad.get(ws.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{Gq(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),Mo.updateConfigValue(ws.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:Fq,deleted:r,skipped:n}}a(Dle,"deleteRoutes");function Lle(e){let t=Mo.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],o=!1,c=!1;for(let l=0,u=e.routes.length;l<u;l++){let f=e.routes[l],d=!1;for(let p=0,_=r.length;p<_;p++){let h=r[p];if(f.host===h.host&&f.port===h.port){r.splice(p,1),d=!0,o=!0,s.push(f);break}}if(!d){let p=!0;for(let _=0,h=n.length;_<h;_++){let S=n[_];if(f.host===S.host&&f.port===S.port){n.splice(_,1),c=!0,p=!1,s.push(f);break}}p&&i.push(f)}}return o&&(r=lw.isEmptyOrZeroLength(r)?null:r,Mo.updateConfigValue(ws.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=lw.isEmptyOrZeroLength(n)?null:n,Mo.updateConfigValue(ws.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:Fq,deleted:s,skipped:i}}a(Lle,"deleteRoutesNats")});var Vq=w((ULe,$q)=>{"use strict";var Cp=require("alasql"),Rl=require("recursive-iterator"),ui=z(),Mle=ie(),Pp=(H(),C(G)),uw=class{static{a(this,"sql_statement_bucket")}constructor(t){this.ast=t,this.affected_attributes=new Map,this.table_lookup=new Map,this.schema_lookup=new Map,this.table_to_schema_lookup=new Map,Ule(this.ast,this.affected_attributes,this.table_lookup,this.schema_lookup,this.table_to_schema_lookup)}getAttributesBySchemaTableName(t,r){if(!t||!r||!this.affected_attributes)return[];if(this.affected_attributes.has(t))return!this.affected_attributes.get(t).has(r)&&(r=this.table_lookup.get(r),!r)?[]:this.affected_attributes.get(t).get(r)}getAllTables(){let t=[];if(!this.affected_attributes)return t;for(let r of this.affected_attributes.keys())t.push(Array.from(this.affected_attributes.get(r).keys()));return t}getTablesBySchemaName(t){return!t||!this.affected_attributes?[]:Array.from(this.affected_attributes.get(t).keys())}getSchemas(){return this.affected_attributes?Array.from(this.affected_attributes.keys()):[]}getAst(){return this.ast}updateAttributeWildcardsForRolePerms(t){let r=this.ast.columns.filter(s=>Pp.SEARCH_WILDCARDS.includes(s.columnid));if(r.length===0)return this.ast;let n=this.ast.from[0].databaseid;return this.ast.columns=this.ast.columns.filter(s=>!Pp.SEARCH_WILDCARDS.includes(s.columnid)),r.forEach(s=>{let i=this.table_to_schema_lookup.has(s.tableid)?this.table_to_schema_lookup.get(s.tableid):n,o=this.table_lookup.has(s.tableid)?this.table_lookup.get(s.tableid):this.ast.from[0].tableid;if(t[i]&&t[i].tables[o]&&t[i].tables[o][Pp.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=vle(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(u=>({attribute_name:u.attribute}));let l=this.affected_attributes.get(i).get(o).filter(u=>!Pp.SEARCH_WILDCARDS.includes(u));c.forEach(({attribute_name:u})=>{let f=new Cp.yy.Column({columnid:u});s.tableid&&(f.tableid=s.tableid),this.ast.columns.push(f),l.includes(u)||l.push(u)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function vle(e){return e.filter(t=>t[Pp.PERMS_CRUD_ENUM.READ])}a(vle,"filterReadRestrictedAttrs");function Ule(e,t,r,n,s){xle(e,t,r,n,s)}a(Ule,"interpretAST");function Dp(e,t,r,n,s){if(!(!e||!e.databaseid)&&(t.has(e.databaseid)||t.set(e.databaseid,new Map),t.get(e.databaseid).has(e.tableid)||t.get(e.databaseid).set(e.tableid,[]),e.as&&(r.has(e.as)||r.set(e.as,e.tableid),n&&!n.has(e.as)&&n.set(e.as,e.databaseid)),s)){let i=e.databaseid,o=e.tableid;e.as&&(o=e.as),s.set(o,i)}}a(Dp,"addSchemaTableToMap");function xle(e,t,r,n,s){if(!e){ui.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Cp.yy.Insert?Fle(e,t,r):e instanceof Cp.yy.Select?Ble(e,t,r,n,s):e instanceof Cp.yy.Update?Hle(e,t,r):e instanceof Cp.yy.Delete?kle(e,t,r):ui.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(xle,"getRecordAttributesAST");function Ble(e,t,r,n,s){if(!e){ui.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(Mle.isEmptyOrZeroLength(i)){ui.error("No schema specified");return}e.from.forEach(c=>{Dp(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),Dp(c.table,t,r,n,s)});let o=new Rl(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,u=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(u).has(l))if(r.has(l))l=r.get(l);else{ui.info(`table specified as ${l} not found.`);return}t.get(u).get(l).indexOf(c.columnid)<0&&t.get(u).get(l).push(c.columnid)}if(e.where){let c=new Rl(e.where),l=e.from[0].tableid;for(let{node:u}of c)if(u&&u.columnid){let f=u.tableid?u.tableid:l;if(!t.get(i).has(f))if(r.has(f))f=r.get(f);else{ui.info(`table specified as ${f} not found.`);continue}t.get(i).get(f).indexOf(u.columnid)<0&&t.get(i).get(f).push(u.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new Rl(c.on);for(let{node:u}of l)if(u&&u.columnid){let f=u.tableid,d=s.get(f);if(!t.get(d).has(f))if(r.has(f))f=r.get(f);else{ui.info(`table specified as ${f} not found.`);continue}t.get(d).get(f).indexOf(u.columnid)<0&&t.get(d).get(f).push(u.columnid)}}),e.order){let c=new Rl(e.order);for(let{node:l}of c)if(l&&l.columnid){let u=l.tableid,f=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(f).has(u))if(r.has(u))u=r.get(u);else{ui.info(`table specified as ${u} not found.`);return}t.get(f).get(u).indexOf(l.columnid)<0&&t.get(f).get(u).push(l.columnid)}}}a(Ble,"getSelectAttributes");function Hle(e,t,r){if(!e){ui.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new Rl(e.columns),s=e.table.databaseid;Dp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&dw(e.table.tableid,s,i.columnid,t,r)}a(Hle,"getUpdateAttributes");function kle(e,t,r){if(!e){ui.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new Rl(e.where),s=e.table.databaseid;Dp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&dw(e.table.tableid,s,i.columnid,t,r)}a(kle,"getDeleteAttributes");function Fle(e,t,r){if(!e){ui.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new Rl(e.columns),s=e.into.databaseid;Dp(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&dw(e.into.tableid,s,i.columnid,t,r)}a(Fle,"getInsertAttributes");function dw(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(dw,"pushAttribute");$q.exports=uw});var Yq=w((BLe,Kq)=>{"use strict";var dS=(H(),C(G)),fS=class{static{a(this,"BaseLicense")}constructor(t=0,r=dS.RAM_ALLOCATION_ENUM.DEFAULT,n=dS.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},fw=class extends fS{static{a(this,"ExtendedLicense")}constructor(t=0,r=dS.RAM_ALLOCATION_ENUM.DEFAULT,n=dS.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};Kq.exports={BaseLicense:fS,ExtendedLicense:fw}});var bd=w((kLe,Xq)=>{"use strict";var yd=require("fs-extra"),_S=(pE(),C(_E)),zq=require("crypto"),Gle=require("moment"),qle=require("uuid").v4,Zr=z(),pw=require("path"),$le=ie(),yl=(H(),C(G)),{totalmem:Wq}=require("os"),Vle=Yq().ExtendedLicense,Rd="invalid license key format",Kle="061183",Yle="mofi25",Wle="aes-256-cbc",zle=16,jle=32,jq=ae(),{resolvePath:Jq}=yt();jq.initSync();var _w;Xq.exports={validateLicense:Qq,generateFingerPrint:Qle,licenseSearch:Ew,getLicense:eue,checkMemoryLimit:tue};function hw(){return pw.join(jq.getHdbBasePath(),yl.LICENSE_KEY_DIR_NAME,yl.LICENSE_FILE_NAME)}a(hw,"getLicenseDirPath");function Jle(){let e=hw();return Jq(pw.join(e,yl.LICENSE_FILE_NAME))}a(Jle,"getLicenseFilePath");function mw(){let e=hw();return Jq(pw.join(e,yl.REG_KEY_FILE_NAME))}a(mw,"getFingerPrintFilePath");async function Qle(){let e=mw();try{return await yd.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await Xle();throw Zr.error(`Error writing fingerprint file to ${e}`),Zr.error(t),new Error("There was an error generating the fingerprint")}}a(Qle,"generateFingerPrint");async function Xle(){let e=qle(),t=_S.hash(e,_S.HASH_FUNCTION.MD5),r=mw();try{await yd.mkdirp(hw()),await yd.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw Zr.error(`Error writing fingerprint file to ${r}`),Zr.error(n),new Error("There was an error generating the fingerprint")}return t}a(Xle,"writeFingerprint");function Qq(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:yl.RAM_ALLOCATION_ENUM.DEFAULT,version:yl.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Zr.error("empty license key passed to validate."),r;let n=mw(),s=!1;try{s=yd.statSync(n)}catch(i){Zr.error(i)}if(s){let i;try{i=yd.readFileSync(n,"utf8")}catch{Zr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(Yle),c=o[1];c=Buffer.concat([Buffer.from(c)],zle);let l=Buffer.concat([Buffer.from(i)],jle),u=zq.createDecipheriv(Wle,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let f=null;try{f=u.update(o[0],"hex","utf8"),f.trim(),f+=u.final("utf8")}catch{let _=Zle(o[0],i);if(_)f=_;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Rd),Zr.error(Rd),new Error(Rd)}let d;if(isNaN(f))try{d=JSON.parse(f),r.version=d.version,r.exp_date=d.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),d.ram_allocation&&(r.ram_allocation=d.ram_allocation)}catch{throw console.error(Rd),Zr.error(Rd),new Error(Rd)}else r.exp_date=f;r.exp_date<Gle().valueOf()&&(r.valid_date=!1),_S.validate(o[1],`${Kle}${i}${t}`,_S.HASH_FUNCTION.MD5)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||Zr.error("Invalid licence"),r}a(Qq,"validateLicense");function Zle(e,t){try{let r=zq.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{Zr.warn("Check old license failed")}}a(Zle,"checkOldLicense");function Ew(){let e=new Vle,t=[];try{t=yd.readFileSync(Jle(),"utf-8").split(`\r
25
- `)}catch(r){r.code==="ENOENT"?Zr.debug("no license file found"):Zr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if($le.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=Qq(s.license_key,s.company);i.valid_machine===!0&&i.valid_date===!0&&i.valid_machine===!0&&(e.exp_date=i.exp_date>e.exp_date?i.exp_date:e.exp_date,e.ram_allocation=i.ram_allocation,e.enterprise=!0)}catch(s){Zr.error("There was an error parsing the license string."),Zr.error(s),e.ram_allocation=yl.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return _w=e,e}a(Ew,"licenseSearch");async function eue(){return _w||await Ew(),_w}a(eue,"getLicense");function tue(){let e=Ew().ram_allocation,t=process.constrainedMemory?.()||Wq();if(t=Math.round(Math.min(t,Wq())/2**20),t>e)return`This server has more memory (${t}MB) than HarperDB is licensed for (${e}MB), this should only be used for educational and development purposes.`}a(tue,"checkMemoryLimit")});var hS=w((GLe,r$)=>{var pS=bd(),Zq=require("chalk"),ts=z(),e$=require("prompt"),{promisify:rue}=require("util"),gw=(H(),C(G)),nue=require("fs-extra"),sue=require("path"),iue=ie(),{packageJson:oue}=st(),t$=ae();t$.initSync();var aue=require("moment"),cue=rue(e$.get),lue=sue.join(t$.getHdbBasePath(),gw.LICENSE_KEY_DIR_NAME,gw.LICENSE_FILE_NAME,gw.LICENSE_FILE_NAME);r$.exports={getFingerprint:due,setLicense:uue,parseLicense:Sw,register:fue,getRegistrationInfo:pue};async function uue(e){if(e&&e.key&&e.company){try{ts.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await Sw(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw ts.error(r),ts.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(uue,"setLicense");async function due(){let e={};try{e=await pS.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw ts.error(r),ts.error(t),new Error(r)}return e}a(due,"getFingerprint");async function Sw(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");ts.info("Validating license input...");let r=pS.validateLicense(e,t);if(ts.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(ts.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(ts.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{ts.info("writing license to disk"),await nue.writeFile(lue,JSON.stringify({license_key:e,company:t}))}catch(n){throw ts.error("Failed to write License"),n}return"Registration successful."}a(Sw,"parseLicense");async function fue(){let e=await _ue();return Sw(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(fue,"register");async function _ue(){let e=await pS.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:Zq.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:Zq.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{e$.start()}catch(n){ts.error(n)}let r;try{r=await cue(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(_ue,"promptForRegistration");async function pue(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await pS.getLicense()}catch(r){throw ts.error(`There was an error when searching licenses due to: ${r.message}`),r}if(iue.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=oue.version,e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=aue.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(pue,"getRegistrationInfo")});var s$=w(($Le,n$)=>{"use strict";var hue=Tt(),Tw=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,u,f,d,p,_,h){this.port=t,o===null&&(o=void 0),this.server_name=r+hue.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.reconnect_error_reports=100,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l},this.leafnodes={port:u,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:f,port:d,routes:p,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:_},HDB:{users:h}},this.system_account="SYS"}};n$.exports=Tw});var a$=w((KLe,o$)=>{"use strict";var i$=Tt(),Aw=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,u,f,d){this.port=t,d===null&&(d=void 0),this.server_name=r+i$.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+i$.SERVER_SUFFIX.LEAF},this.tls={cert_file:u,key_file:f,ca_file:d,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:d,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:d,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:l,jetstream:"enabled"}},this.system_account="SYS"}};o$.exports=Aw});var l$=w((WLe,c$)=>{"use strict";var Rw=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};c$.exports=Rw});var d$=w((jLe,u$)=>{"use strict";var mue=Tt(),yw=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+mue.SERVER_SUFFIX.ADMIN,this.password=r}};u$.exports=yw});var SS=w((QLe,p$)=>{"use strict";var bl=require("path"),Ol=require("fs-extra"),Eue=s$(),gue=a$(),Sue=l$(),Tue=d$(),bw=An(),Nd=ie(),Nn=yt(),ES=(H(),C(G)),Lp=Tt(),{CONFIG_PARAMS:jt}=ES,wd=z(),Mp=ae(),f$=Eo(),Ow=ir(),Aue=Zn(),Od="clustering",Rue=1e4,_$=50;p$.exports={generateNatsConfig:bue,removeNatsConfig:Oue,getHubConfigPath:yue};function yue(){let e=Mp.get(jt.ROOTPATH);return bl.join(e,Od,Lp.NATS_CONFIG_FILES.HUB_SERVER)}a(yue,"getHubConfigPath");async function bue(e=!1,t=void 0){let r=Mp.get(jt.ROOTPATH);Ol.ensureDirSync(bl.join(r,"clustering","leaf")),Mp.initSync();let n=Nn.getConfigFromFile(jt.CLUSTERING_TLS_CERT_AUTH),s=Nn.getConfigFromFile(jt.CLUSTERING_TLS_PRIVATEKEY),i=Nn.getConfigFromFile(jt.CLUSTERING_TLS_CERTIFICATE);!await Ol.exists(i)&&!await Ol.exists(!n)&&await Aue.createNatsCerts();let o=bl.join(r,Od,Lp.PID_FILES.HUB),c=bl.join(r,Od,Lp.PID_FILES.LEAF),l=Nn.getConfigFromFile(jt.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=bl.join(r,Od,Lp.NATS_CONFIG_FILES.HUB_SERVER),f=bl.join(r,Od,Lp.NATS_CONFIG_FILES.LEAF_SERVER),d=Nn.getConfigFromFile(jt.CLUSTERING_TLS_INSECURE),p=Nn.getConfigFromFile(jt.CLUSTERING_TLS_VERIFY),_=Nn.getConfigFromFile(jt.CLUSTERING_NODENAME),h=Nn.getConfigFromFile(jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await Ow.checkNATSServerInstalled()||gS("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let S=await bw.listUsers(),g=Nn.getConfigFromFile(jt.CLUSTERING_USER),R=await bw.getClusterUser();(Nd.isEmpty(R)||R.active!==!0)&&gS(`Invalid cluster user '${g}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await mS(jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await mS(jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await mS(jt.CLUSTERING_HUBSERVER_NETWORK_PORT),await mS(jt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let E=[],T=[];for(let[se,Q]of S.entries())Q.role?.role===ES.ROLE_TYPES_ENUM.CLUSTER_USER&&Q.active&&(E.push(new Tue(Q.username,f$.decrypt(Q.hash))),T.push(new Sue(Q.username,f$.decrypt(Q.hash))));let b=[],{hub_routes:v}=Nn.getClusteringRoutes();if(!Nd.isEmptyOrZeroLength(v))for(let se of v)b.push(`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@${se.host}:${se.port}`);let F=new Eue(Nn.getConfigFromFile(jt.CLUSTERING_HUBSERVER_NETWORK_PORT),_,o,i,s,n,d,p,h,Nn.getConfigFromFile(jt.CLUSTERING_HUBSERVER_CLUSTER_NAME),Nn.getConfigFromFile(jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),b,E,T);n==null&&(delete F.tls.ca_file,delete F.leafnodes.tls.ca_file),t=Nd.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===ES.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Ol.writeJson(u,F),wd.trace(`Hub server config written to ${u}`));let q=`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@0.0.0.0:${h}`,Y=`tls://${R.uri_encoded_name}:${R.uri_encoded_d_hash}@0.0.0.0:${h}`,Z=new gue(Nn.getConfigFromFile(jt.CLUSTERING_LEAFSERVER_NETWORK_PORT),_,c,l,[q],[Y],E,T,i,s,n,d);n==null&&delete Z.tls.ca_file,(t===void 0||t===ES.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Ol.writeJson(f,Z),wd.trace(`Leaf server config written to ${f}`))}a(bue,"generateNatsConfig");async function mS(e){let t=Mp.get(e);return Nd.isEmpty(t)&&gS(`port undefined for '${e}'`),await Nd.isPortTaken(t)&&gS(`'${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(mS,"isPortAvailable");function gS(e){let t=`Error generating clustering config: ${e}`;wd.error(t),console.error(t),process.exit(1)}a(gS,"generateNatsConfigError");async function Oue(e){let{port:t,config_file:r}=Ow.getServerConfig(e),{username:n,decrypt_hash:s}=await bw.getClusterUser(),i=0,o=2e3;for(;i<_$;){try{let f=await Ow.createConnection(t,n,s,!1);if(f.protocol.connected===!0){f.close();break}}catch(f){wd.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${f}`)}if(i++,i>=_$)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);let u=o*(i*2);u>3e4&&wd.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await Nd.async_set_timeout(u)}let c="0".repeat(Rue),l=bl.join(Mp.get(jt.ROOTPATH),Od,r);await Ol.writeFile(l,c),await Ol.remove(l),wd.notify(e,"started.")}a(Oue,"removeNatsConfig")});var T$=w((ZLe,S$)=>{"use strict";var rs=ae(),Nue=bd(),Fe=(H(),C(G)),vp=Tt(),vo=require("path"),{PACKAGE_ROOT:AS}=st(),h$=ae(),TS=ie(),Id="/dev/null",wue=vo.join(AS,"launchServiceScripts"),m$=vo.join(AS,"utility/scripts"),Iue=vo.join(m$,Fe.HDB_RESTART_SCRIPT),E$=vo.resolve(AS,"dependencies",`${process.platform}-${process.arch}`,vp.NATS_BINARY_NAME);function g$(){let t=Nue.licenseSearch().ram_allocation||Fe.RAM_ALLOCATION_ENUM.DEFAULT,r=Fe.MEM_SETTING_KEY+t,n={[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return TS.noBootFile()&&(n[Fe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=TS.getEnvCliRootPath()),{name:Fe.PROCESS_DESCRIPTORS.HDB,script:Fe.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:AS}}a(g$,"generateMainServerConfig");var Cue=9930;function Pue(){rs.initSync(!0);let e=rs.get(Fe.CONFIG_PARAMS.ROOTPATH),t=vo.join(e,"clustering",vp.NATS_CONFIG_FILES.HUB_SERVER),r=vo.join(rs.get(Fe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Fe.LOG_NAMES.HDB),n=h$.get(Fe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=vp.LOG_LEVEL_FLAGS[rs.get(Fe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==Cue?"-"+n:""),script:E$,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return rs.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Id,i.error_file=Id),i}a(Pue,"generateNatsHubServerConfig");var Due=9940;function Lue(){rs.initSync(!0);let e=rs.get(Fe.CONFIG_PARAMS.ROOTPATH),t=vo.join(e,"clustering",vp.NATS_CONFIG_FILES.LEAF_SERVER),r=vo.join(rs.get(Fe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Fe.LOG_NAMES.HDB),n=h$.get(Fe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=vp.LOG_LEVEL_FLAGS[rs.get(Fe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==Due?"-"+n:""),script:E$,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return rs.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Id,i.error_file=Id),i}a(Lue,"generateNatsLeafServerConfig");function Mue(){rs.initSync();let e=vo.join(rs.get(Fe.CONFIG_PARAMS.LOGGING_ROOT),Fe.LOG_NAMES.HDB),t={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:Fe.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:wue,autorestart:!1};return rs.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=Id,t.error_file=Id),t}a(Mue,"generateClusteringUpgradeV4ServiceConfig");function vue(){let e={[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.RESTART_HDB};return TS.noBootFile()&&(e[Fe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=TS.getEnvCliRootPath()),{...{name:Fe.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:m$},script:Iue}}a(vue,"generateRestart");function Uue(){return{apps:[g$()]}}a(Uue,"generateAllServiceConfigs");S$.exports={generateAllServiceConfigs:Uue,generateMainServerConfig:g$,generateRestart:vue,generateNatsHubServerConfig:Pue,generateNatsLeafServerConfig:Lue,generateClusteringUpgradeV4ServiceConfig:Mue}});var Cd=w((rMe,v$)=>{"use strict";var Ze=(H(),C(G)),xue=ie(),xo=SS(),RS=ir(),Uo=Tt(),Va=T$(),yS=ae(),Nl=z(),Bue=Do(),{startWorker:A$,onMessageFromWorkers:Hue}=et(),kue=Po(),tMe=require("util"),Fue=require("child_process"),Gue=require("fs"),{execFile:que}=Fue,Ve;v$.exports={enterPM2Mode:$ue,start:Ka,stop:Nw,reload:y$,restart:b$,list:ww,describe:w$,connect:Bo,kill:zue,startAllServices:jue,startService:Iw,getUniqueServicesList:I$,restartAllServices:Jue,isServiceRegistered:C$,reloadStopStart:P$,restartHdb:N$,deleteProcess:Yue,startClusteringProcesses:L$,startClusteringThreads:M$,isHdbRestartRunning:Wue,isClusteringRunning:Xue,stopClustering:Que,reloadClustering:Zue,expectedRestartOfChildren:O$};var Up=!1;Hue(e=>{e.type==="restart"&&yS.initSync(!0)});function $ue(){Up=!0}a($ue,"enterPM2Mode");function Bo(){return Ve||(Ve=require("pm2")),new Promise((e,t)=>{Ve.connect((r,n)=>{r&&t(r),e(n)})})}a(Bo,"connect");var en,Vue=10,R$;function Ka(e,t=!1){if(Up)return Kue(e);let r=que(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let o=en.indexOf(r);o>-1&&en.splice(o,1),!R$&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<Vue&&(Gue.existsSync(xo.getHubConfigPath())?Ka(e):(await xo.generateNatsConfig(!0),Ka(e),await new Promise(c=>setTimeout(c,3e3)),await xo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await xo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=yS.get(Ze.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,u=0,f;for(;l=c.exec(i);){if(l.index&&Uo.LOG_LEVEL_HIERARCHY[o]>=Uo.LOG_LEVEL_HIERARCHY[f||"info"]){let _=f===Uo.LOG_LEVELS.ERR||f===Uo.LOG_LEVELS.WRN?Nl.OUTPUTS.STDERR:Nl.OUTPUTS.STDOUT;Nl.logCustomLevel(f||"info",_,n,i.slice(u,l.index).trim())}let[d,p]=l;u=l.index+d.length,f=Uo.LOG_LEVELS[p]}if(Uo.LOG_LEVEL_HIERARCHY[o]>=Uo.LOG_LEVEL_HIERARCHY[f||"info"]){let d=f===Uo.LOG_LEVELS.ERR||f===Uo.LOG_LEVELS.WRN?Nl.OUTPUTS.STDERR:Nl.OUTPUTS.STDOUT;Nl.logCustomLevel(f||"info",d,n,i.slice(u).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!en&&(en=[],!t)){let i=a(()=>{R$=!0,en&&(en.map(o=>o.kill()),process.exit(0))},"kill_children");process.on("exit",i),process.on("SIGINT",i),process.on("SIGQUIT",i),process.on("SIGTERM",i)}en.push(r)}a(Ka,"start");function Kue(e){return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.start(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(Kue,"startWithPM2");function Nw(e){if(!Up){for(let t of en||[])t.name===e&&(en.splice(en.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.stop(e,async(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.delete(e,(i,o)=>{i&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(o)})})})}a(Nw,"stop");function y$(e){return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.reload(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(y$,"reload");function b$(e){if(!Up){O$();for(let t of en||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.restart(e,(n,s)=>{Ve.disconnect(),t(s)})})}a(b$,"restart");function O$(){for(let e of en||[])e.config&&(e.config.restarts=0)}a(O$,"expectedRestartOfChildren");function Yue(e){return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.delete(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(Yue,"deleteProcess");async function N$(){await Ka(Va.generateRestart())}a(N$,"restartHdb");async function Wue(){let e=await ww();for(let t in e)if(e[t].name===Ze.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(Wue,"isHdbRestartRunning");function ww(){return new Promise(async(e,t)=>{try{await Bo()}catch(r){t(r)}Ve.list((r,n)=>{r&&(Ve.disconnect(),t(r)),Ve.disconnect(),e(n)})})}a(ww,"list");function w$(e){return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.describe(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(w$,"describe");function zue(){if(!Up){for(let e of en||[])e.kill();en=[];return}return new Promise(async(e,t)=>{try{await Bo()}catch(r){t(r)}Ve.killDaemon((r,n)=>{r&&(Ve.disconnect(),t(r)),Ve.disconnect(),e(n)})})}a(zue,"kill");async function jue(){try{await L$(),await M$(),await Ka(Va.generateAllServiceConfigs())}catch(e){throw Ve?.disconnect(),e}}a(jue,"startAllServices");async function Iw(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case Ze.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Va.generateMainServerConfig();break;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Va.generateNatsIngestServiceConfig();break;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Va.generateNatsReplyServiceConfig();break;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Va.generateNatsHubServerConfig(),await Ka(r,t),await xo.removeNatsConfig(e);return;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Va.generateNatsLeafServerConfig(),await Ka(r,t),await xo.removeNatsConfig(e);return;case Ze.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Va.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await Ka(r)}catch(r){throw Ve?.disconnect(),r}}a(Iw,"startService");async function I$(){try{let e=await ww(),t={};for(let r=0,n=e.length;r<n;r++){let s=e[r];t[s.name]===void 0&&(t[s.name]={name:s.name,exec_mode:s.pm2_env.exec_mode})}return t}catch(e){throw Ve?.disconnect(),e}}a(I$,"getUniqueServicesList");async function Jue(e=[]){try{let t=!1,r=await I$();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===Ze.PROCESS_DESCRIPTORS.HDB?t=!0:await b$(o))}t&&await P$(Ze.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Ve?.disconnect(),t}}a(Jue,"restartAllServices");async function C$(e){if(en?.find(r=>r.name===e))return!0;let t=await kue.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(C$,"isServiceRegistered");async function P$(e){let t=yS.get(Ze.CONFIG_PARAMS.THREADS_COUNT)??yS.get(Ze.CONFIG_PARAMS.THREADS),r=await w$(e),n=xue.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await Nw(e),await Iw(e)):e===Ze.PROCESS_DESCRIPTORS.HDB?await N$():await y$(e)}a(P$,"reloadStopStart");var D$;async function L$(e=!1){for(let t in Ze.CLUSTERING_PROCESSES){let r=Ze.CLUSTERING_PROCESSES[t];await Iw(r,e)}}a(L$,"startClusteringProcesses");async function M$(){D$=A$(Ze.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:Ze.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await RS.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await RS.updateLocalStreams();let e=await Bue.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===Ze.PRE_4_0_0_VERSION){Nl.info("Starting clustering upgrade 4.0.0 process"),A$(Ze.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(M$,"startClusteringThreads");async function Que(){for(let e in Ze.CLUSTERING_PROCESSES)if(e!==Ze.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===Ze.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await D$.terminate();else{let t=Ze.CLUSTERING_PROCESSES[e];await Nw(t)}}a(Que,"stopClustering");async function Xue(){for(let e in Ze.CLUSTERING_PROCESSES){let t=Ze.CLUSTERING_PROCESSES[e];if(await C$(t)===!1)return!1}return!0}a(Xue,"isClusteringRunning");async function Zue(){await xo.generateNatsConfig(!0),await RS.reloadNATSHub(),await RS.reloadNATSLeaf(),await xo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await xo.removeNatsConfig(Ze.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(Zue,"reloadClustering")});var NS={};ve(NS,{compactOnStart:()=>ede,copyDb:()=>F$});async function ede(){Ya.notify("Running compact on start"),console.log("Running compact on start");let e=(0,Cw.get)(B.ROOTPATH),t=new Map,r=Qe();(0,Pw.updateConfigValue)(B.STORAGE_COMPACTONSTART,!1);try{for(let n in r){if(n==="system"||n.endsWith("-copy"))continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,bS.join)(e,"backup",n+".mdb"),o=(0,bS.join)(e,Rc,n+"-copy.mdb"),c=0;try{c=await U$(n),console.log("Database",n,"before compact has a total record count of",c)}catch(l){Ya.error("Error getting record count for database",n,l),console.error("Error getting record count for database",n,l)}t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await F$(n,o),console.log("Backing up",n,"to",i),await(0,wl.move)(s,i,{overwrite:!0})}try{Pd()}catch(n){Ya.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n)}for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,wl.move)(i,s,{overwrite:!0}),await(0,wl.remove)((0,bS.join)(e,Rc,`${n}-copy.mdb-lock`));try{Pd()}catch(n){Ya.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n),process.exit(0)}}catch(n){Ya.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,Pw.updateConfigValue)(B.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,wl.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw Pd(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await U$(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){o=!1;let l=`There is a discrepancy between pre and post compact record count for database ${n}.
23
+ `,"")}a(Ck,"runCommand");async function $se(){try{await Sse.access(kO)}catch{return!1}let e=await Ck(`${kO} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return Tse.eq(t,Gse)}a($se,"checkNATSServerInstalled");async function VO(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await wk.getClusterUser();if(_l(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}oi.trace("create nats connection called");let i=await Lse({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:wr.get($e.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:wr.get($e.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:wr.get($e.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),oi.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&oi.error("Error with Nats client connection, connection closed",o),i===Qr&&Pk()}),i}a(VO,"createConnection");function Pk(){Qr=void 0,ul=void 0,dl=void 0,fl=void 0}a(Pk,"clearClientCache");async function Vse(){Qr&&(await Qr.drain(),Qr=void 0,ul=void 0,dl=void 0,fl=void 0)}a(Vse,"closeConnection");var Qr,fl;async function np(){return fl||(fl=VO(wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),Qr=await fl),Qr||fl}a(np,"getConnection");async function sp(){if(ul)return ul;_l(Qr)&&await np();let{domain:e}=ed($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(_l(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return ul=await Qr.jetstreamManager({domain:e,timeout:6e4}),ul}a(sp,"getJetStreamManager");async function Dk(){if(dl)return dl;_l(Qr)&&await np();let{domain:e}=ed($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(_l(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return dl=Qr.jetstream({domain:e,timeout:6e4}),dl}a(Dk,"getJetStream");async function qi(){let e=Qr||await np(),t=ul||await sp(),r=dl||await Dk();return{connection:e,jsm:t,js:r}}a(qi,"getNATSReferences");async function Kse(e){let t=wr.get($e.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await wk.getClusterUser(),s=await VO(t,r,n),i=$O(),o=s.subscribe(i),c=[],l,u=(async()=>{for await(let f of o){let d=Ik.decode(f.data);d.response_time=Date.now()-l,c.push(d)}})();return l=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await Eg.async_set_timeout(e),await o.drain(),await s.close(),await u,c}a(Kse,"getServerList");async function KO(e,t){let{jsm:r}=await qi(),n=wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:Mse.File,retention:vse.Limits,subjects:t,discard:Use.Old,max_msgs:s,max_bytes:i,max_age:n})}a(KO,"createLocalStream");async function Lk(){let{jsm:e}=await qi(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(Lk,"listStreams");async function Yse(e){let{jsm:t}=await qi();await t.streams.delete(e)}a(Yse,"deleteLocalStream");async function Wse(e){let{connection:t}=await qi(),r=[],n=$O(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(Ik.decode(o.data))})();return await t.publish(`$JS.${e}.API.STREAM.LIST`,void 0,{reply:n}),await t.flush(),await s.drain(),await i,r}a(Wse,"listRemoteStreams");async function zse(e,t=void 0,r=void 0){let{jsm:n,js:s}=await qi(),i=yk(),o={durable_name:i,ack_policy:GO.Explicit};t&&(o.deliver_policy=qO.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let u=[];for await(let f of l){let d=FO(f.data),p={nats_timestamp:f.info.timestampNanos,nats_sequence:f.info.streamSequence,entry:d};if(f.headers&&(p.origin=f.headers.get(vr.MSG_HEADERS.ORIGIN)),u.push(p),f.ack(),f.info.pending===0)break}return await c.delete(),u}a(zse,"viewStream");async function*jse(e,t=void 0,r=void 0){let{jsm:n,js:s}=await qi(),i=yk(),o={durable_name:i,ack_policy:GO.Explicit};t&&(o.deliver_policy=qO.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let u of l){let f=FO(u.data);f[0]||(f=[f]);for(let d of f){let p={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:d};u.headers&&(p.origin=u.headers.get(vr.MSG_HEADERS.ORIGIN)),yield p}if(u.ack(),u.info.pending===0)break}await c.delete()}a(jse,"viewStreamIterator");async function Jse(e,t,r,n){oi.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=Mk(n,r);let{js:s}=await qi(),i=await Sg(),o=`${e}.${i}`,c=await kse(()=>n instanceof Uint8Array?n:Nk.encode(n));try{oi.trace(`publishToStream publishing to subject: ${o}`),Hse(c.length,"bytes-sent",e,n.operation,"replication"),await s.publish(o,c,{headers:r})}catch(l){if(l.code&&l.code.toString()==="503")return Uk(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){oi.trace(`publishToStream creating stream: ${t}`);let f=o.split(".");f[2]="*",await KO(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(Jse,"publishToStream");function Mk(e,t){t===void 0&&(t=Bse());let r=wr.get($e.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(vr.MSG_HEADERS.ORIGIN)&&r&&t.append(vr.MSG_HEADERS.ORIGIN,r),t}a(Mk,"addNatsMsgHeader");function ed(e){e=e.toLowerCase();let t=rp.join(wr.get($e.CONFIG_PARAMS.ROOTPATH),Fse);if(e===$e.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return _l(HO)&&(HO={port:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+vr.SERVER_SUFFIX.HUB,config_file:vr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:rp.join(t,vr.PID_FILES.HUB),hdb_nats_path:t}),HO;if(e===$e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return _l(BO)&&(BO={port:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+vr.SERVER_SUFFIX.LEAF,config_file:vr.NATS_CONFIG_FILES.LEAF_SERVER,domain:ep.getConfigFromFile($e.CONFIG_PARAMS.CLUSTERING_NODENAME)+vr.SERVER_SUFFIX.LEAF,pid_file_path:rp.join(t,vr.PID_FILES.LEAF),hdb_nats_path:t}),BO;oi.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(ed,"getServerConfig");async function vk(e,t,r,n){try{await e.consumers.add(t,{ack_policy:GO.Explicit,durable_name:r,deliver_policy:qO.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(vk,"createConsumer");async function Qse(e,t,r){await e.consumers.delete(t,r)}a(Qse,"removeConsumer");function Xse(e){return e.split(".")[1]}a(Xse,"extractServerName");async function Zse(e,t,r=6e4,n=$O()){if(!Eg.isObject(t))throw new Error("data param must be an object");let s=Nk.encode(t),{connection:i}=await qi(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return FO(c.data)}a(Zse,"request");function YO(e){return new Promise(async(t,r)=>{let n=bse(kO,["--signal",`reload=${e}`],{cwd:__dirname}),s,i;n.on("error",o=>{r(o)}),n.stdout.on("data",o=>{i+=o.toString()}),n.stderr.on("data",o=>{s+=o.toString()}),n.stderr.on("close",o=>{s&&r(s),t(i)})})}a(YO,"reloadNATS");async function eie(){let{pid_file_path:e}=ed($e.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await YO(e)}a(eie,"reloadNATSHub");async function tie(){let{pid_file_path:e}=ed($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await YO(e)}a(tie,"reloadNATSLeaf");function rie(e,t,r){let n;switch(e.code){case Rk.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case Rk.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(rie,"requestErrorHandler");async function nie(e,t){let r=t+vr.SERVER_SUFFIX.LEAF,{connection:n}=await qi(),{jsm:s}=await die(r),{schema:i,table:o}=e,c=gg.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await Uk(async()=>{if(e.subscribe===!0)await vk(s,c,n.info.server_name,l);else try{await Qse(s,c,n.info.server_name)}catch(u){oi.trace(u)}})}a(nie,"updateRemoteConsumer");async function sie(e,t,r,n){let s=gg.createNatsTableStreamName(e,t),i=r+vr.SERVER_SUFFIX.LEAF,o={type:$e.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!Ok&&Pse()<wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=xO();await c(o)}await Ise(o),n==="stop"&&await Eg.async_set_timeout(1e3)}a(sie,"updateConsumerIterator");function Uk(e){return wse.writeTransaction($e.SYSTEM_SCHEMA_NAME,$e.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(Uk,"exclusiveLock");async function xk(e,t){let r=gg.createNatsTableStreamName(e,t),n=await Sg(),s=cie(e,t,n);await KO(r,[s])}a(xk,"createLocalTableStream");async function iie(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await xk(n,s)}}a(iie,"createTableStreams");async function Bk(e,t,r=void 0){if(wr.get($e.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=gg.createNatsTableStreamName(e,t),{domain:s}=ed($e.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await np()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")oi.warn(n);else throw n}}a(Bk,"purgeTableStream");async function oie(e,t){if(wr.get($e.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await Bk(e,t[r])}a(oie,"purgeSchemaTableStreams");async function aie(e){return(await sp()).streams.info(e)}a(aie,"getStreamInfo");function cie(e,t,r){return`${vr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(cie,"createSubjectName");async function Sg(){if(tp)return tp;if(tp=(await sp())?.nc?.info?.server_name,tp===void 0)throw new Error("Unable to get jetstream manager server name");return tp}a(Sg,"getJsmServerName");async function lie(){let e=await sp(),t=await Sg(),r=await Lk();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=uie(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let u=i.split(".");u[u.length-1]=t;let f=u.join(".");oi.trace(`Updating stream subject name from: ${i} to: ${f}`),s.subjects[0]=f,await e.streams.update(s.name,s)}}a(lie,"updateLocalStreams");function uie(e){let{config:t}=e,r=!1,n=wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=wr.get($e.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}a(uie,"updateStreamLimits");async function die(e){let t,r;try{t=await Qr.jetstream({domain:e}),r=await Qr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw oi.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(die,"connectToRemoteJS")});function WO(e){let t=e.get(Tg),r=t?(0,td.unpack)(t):null;r||(r={remoteNameToId:{}});let n=Ze(),s=!1;r.nodeName=Ze();let i=r.remoteNameToId;if(i[n]!==0){let o=0,c;for(let l in i){let u=i[l];u===0?c=l:u>o&&(o=u)}if(c){o++,i[c]=o;let l=[Symbol.for("seq"),o];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:op(e)??1,nodes:[]})})}i[n]=0,e.putSync(Tg,(0,td.pack)(r))}return r}function ip(e){return WO(e).remoteNameToId}function Fk(e,t){let r=WO(t),n=r.remoteNameToId,s=new Map,i=!1;for(let o in e){let c=e[o],l=n[o];if(l==null){let u=0;for(let f in n){let d=n[f];d>u&&(u=d)}l=u+1,n[o]=l,i=!0}s.set(c,l)}return i&&t.putSync(Tg,(0,td.pack)(r)),s}function Ag(e,t){let r=WO(t),n=r.remoteNameToId,s=n[e];if(s==null){let i=0;for(let o in n){let c=n[o];c>i&&(i=c)}s=i+1,n[e]=s,t.putSync(Tg,(0,td.pack)(r))}return kk.trace?.("The remote node name map",e,n,s),s}var kk,td,Tg,zO=be(()=>{kk=M(Ni());Xn();td=require("msgpackr"),Tg=Symbol.for("remote-ids");a(WO,"getIdMappingRecord");a(ip,"exportIdMapping");a(Fk,"remoteToLocalNodeId");a(Ag,"getIdOfRemoteNode")});var jO={};ve(jO,{commits_awaiting_replication:()=>nd,getHDBNodeTable:()=>or,getReplicationSharedStatus:()=>Rg,iterateRoutes:()=>cp,shouldReplicateToNode:()=>ap,subscribeToNodeUpdates:()=>sd});function or(){return Gk||(Gk=ft({table:"hdb_nodes",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"ca"},{attribute:"ca_info"},{attribute:"replicates"},{attribute:"revoked_certificates"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function Rg(e,t,r,n){return new Float64Array(e.getUserSharedBuffer(["replicated",t,r],new ArrayBuffer(32),n&&{callback:n}))}function sd(e){or().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;Kk.debug?.("adding node",n,"on node",Ze()," on process",process.pid),server.nodes=server.nodes.filter(i=>i.name!==n),r.type==="put"&&n!==Ze()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r));let s=new Map;for await(let i of or().search({}))if(i.shard!=null){let o=s.get(i.shard);o||s.set(i.shard,o=[]),o.push(i)}server.shards=s,(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function ap(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&or().primaryStore.get(Ze())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function fie(){sd(e=>{Da({},(t,r)=>{let n=e.name,s=qk.get(n);if(s||qk.set(n,s=new Map),s.has(r))return;let i;for(let o in t)if(i=t[o].auditStore,i)break;if(i){let o=Rg(i,r,n,()=>{let c=o[0],l=o.lastTime;for(let{txnTime:u,onConfirm:f}of nd.get(r)||[])u>l&&u<=c&&f();o.lastTime=c});o.lastTime=0,s.set(r,o)}})})}function*cp(e){for(let t of e.routes||[]){let r=t.url,n;if(typeof t=="string"?t.includes("://")?r=t:n=t:n=t.hostname??t.host,n&&!r){let s=rd.default.get(x.REPLICATION_SECUREPORT)??(!rd.default.get(x.REPLICATION_PORT)&&rd.default.get(x.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||rd.default.get(x.REPLICATION_PORT)||rd.default.get(x.OPERATIONSAPI_NETWORK_PORT);let o=i?.lastIndexOf?.(":");o>0&&(i=+i.slice(o+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){$k.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{replicates:!t.subscriptions,url:r,subscription:t.subscriptions,routes:t.routes,start_time:t.startTime,revoked_certificates:t.revokedCertificates,shard:t.shard}}}var $k,Vk,rd,Kk,Gk,qk,nd,pl=be(()=>{De();Xn();Rm();$k=require("worker_threads"),Vk=M(pe()),rd=M(ae());H();Kk=M(Ni());server.nodes=[];a(or,"getHDBNodeTable");a(Rg,"getReplicationSharedStatus");a(sd,"subscribeToNodeUpdates");a(ap,"shouldReplicateToNode");qk=new Map;RL((e,t,r)=>{if(r>server.nodes.length)throw new Vk.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);nd||(nd=new Map,fie());let n=nd.get(e);return n||(n=[],nd.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(fie,"startSubscriptionToReplications");a(cp,"iterateRoutes")});var jk={};ve(jk,{connectedToNode:()=>hl,disconnectedFromNode:()=>ad,ensureNode:()=>Oo,requestClusterStatus:()=>zk,startOnMainThread:()=>QO});async function QO(e){let t=0,r=Xe();for(let i of Object.getOwnPropertyNames(r)){let o=r[i];for(let c in o){let l=o[c];if(l.auditStore){yg.set(i,op(l.auditStore));break}}}$i.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes?.search([])||[])i.push(o);for(let o of cp(e))try{let c=!o.subscriptions;if(c){let u=Ze(),f=or().primaryStore.get(u);if(f!==null){let d=e.url??La();(f===void 0||f.url!==d||f.shard!==e.shard)&&await Oo(u,{name:u,url:d,shard:e.shard,replicates:!0})}}let l=o.trusted!==!1;if(c&&o.replicates==null&&(o.replicates=!0),i.find(u=>u.url===o.url))continue;s(o)}catch(c){console.error(c)}sd(s)});let n;function s(i,o=i?.name){let c=Ze()&&o===Ze()||La()&&i?.url===La();if(c){let d=!!i?.replicates;if(n!==void 0&&n!==d)for(let p of or().search([]))p.replicates&&p.name!==o&&s(p,p.name);n=d}if(ct.trace("Setting up node replication for",i),!i){for(let[d,p]of bo){let _;for(let[h,{worker:S,nodes:g}]of p){let R=g[0];if(R&&R.name==o){_=!0;for(let[E,{worker:T}]of p)p.delete(E),ct.warn("Node was deleted, unsubscribing from node",o,E,d),T?.postMessage({type:"unsubscribe-from-node",node:o,database:E,url:d});break}}if(_){bo.get(d).iterator.remove(),bo.delete(d);return}}return}if(c)return;if(!i.url){ct.info(`Node ${i.name} is missing url`);return}let l=bo.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(ct.info(`Added node ${i.name} at ${i.url} for process ${Ze()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[d,p]of id)if(i.url===p.url){id.delete(d);break}id.set(i.name,i)}let u=Xe();if(l||(l=new Map,bo.set(i.url,l)),l.iterator=Da(e,(d,p,_)=>{_?f(p,!0):f(p,!1)}),i.subscriptions)for(let d of i.subscriptions){let p=d.database||d.schema;u[p]||(ct.warn(`Database ${p} not found for node ${i.name}, making a subscription anyway`),f(p,!1))}function f(d,p){ct.trace("Setting up replication for database",d,"on node",i.name);let _=l.get(d),h,S=[{replicateByDefault:p,...i}];yg.has(d)&&(S.push({replicateByDefault:p,name:Ze(),start_time:yg.get(d),end_time:Date.now(),replicates:!0}),yg.delete(d));let g=ap(i,d),R=$i.workers.filter(E=>E.name==="http");if(_?(h=_.worker,_.nodes=S):g&&(t=t%R.length,h=R[t++],l.set(d,{worker:h,nodes:S,url:i.url}),h?.on("exit",()=>{l.get(d)?.worker===h&&(l.delete(d),f(d,p))})),g)setTimeout(()=>{let E={type:"subscribe-to-node",database:d,nodes:S};h?h.postMessage(E):od(E)},_ie);else{ct.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[d],or().primaryStore.get(Ze())?.replicates),or().primaryStore.get(Ze())?.replicates||(n=!1);let E={type:"unsubscribe-from-node",database:d,url:i.url,name:i.name};h?h.postMessage(E):Og(E)}}a(f,"onDatabase")}a(s,"onNodeUpdate"),ad=a(function(i){try{ct.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(id.keys()),c=o.sort(),l=c.indexOf(i.name||ai(i.url));if(l===-1){ct.warn("Disconnected node not found in node map",i.name,o);return}let u=bo.get(i.url),f=u?.get(i.database);if(!f){ct.warn("Disconnected node not found in replication map",i.database,u);return}if(f.connected=!1,i.finished)return;let d=f.nodes[0];if(!(d.replicates===!0||d.replicates?.sends||d.subscriptions?.length))return;let p=(l+1)%c.length;for(;l!==p;){let _=c[p],h=id.get(_);u=bo.get(h.url);let S=u?.get(i.database);if(!S){p=(p+1)%c.length;continue}let{worker:g,nodes:R}=S,E=!1;for(let T of f.nodes){if(R.some(b=>b.name===T.name)){ct.info(`Disconnected node is already failing over to ${_} for ${i.database}`);continue}R.push(T),E=!0}if(!E){ct.info(`Disconnected node ${i.name} has no nodes to fail over to ${_}`);return}f.redirectingTo=S,ct.info(`Failing over ${i.database} from ${i.name} to ${_}`),g?g.postMessage({type:"subscribe-to-node",database:i.database,nodes:R}):od({database:i.database,nodes:R});return}ct.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){ct.error("Error failing over node",o)}},"disconnectedFromNode"),hl=a(function(i){let o=bo.get(i.url),c=o?.get(i.database);if(!c){ct.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,o);return}if(c.connected=!0,c.latency=i.latency,c.redirectingTo){let{worker:l,nodes:u}=c.redirectingTo,f=u.find(d=>d.name===i.name);c.redirectingTo=null,f&&(u.splice(u.indexOf(f),1),l?l.postMessage({type:"subscribe-to-node",database:i.database,nodes:u}):od({database:i.database,nodes:u}))}},"connectedToNode"),(0,$i.onMessageByType)("disconnected-from-node",ad),(0,$i.onMessageByType)("connected-to-node",hl),(0,$i.onMessageByType)("request-cluster-status",zk)}function zk(e,t){let r=[];for(let[n,s]of id)try{let i=bo.get(s.url);ct.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let o=[];if(i){for(let[l,{worker:u,connected:f,nodes:d,latency:p}]of i)o.push({database:l,connected:f,latency:p,thread_id:u?.threadId,nodes:d.map(_=>_.name)});let c=(0,JO.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){ct.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function Oo(e,t){let r=or();e=e??ai(t.url),t.name=e;try{if(t.ca){let s=new Wk.X509Certificate(t.ca);t.ca_info={issuer:s.issuer.replace(/\n/g," "),subject:s.subject.replace(/\n/g," "),subject_alt_name:s.subjectAltName,serial_number:s.serialNumber,valid_from:s.validFrom,valid_to:s.validTo}}}catch(s){ct.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(ct.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.put(t);else{t.replicates&&!Yk.default.get(x.CLUSTERING_ENABLED)&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],o=(0,JO.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let u of o)if((c.database??c.schema)===(u.database??u.schema)&&c.table===u.table){u.publish=c.publish,u.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...o,...i];break}if(Array.isArray(t.revoked_certificates)){let s=n.revoked_certificates||[];t.revoked_certificates=[...new Set([...s,...t.revoked_certificates])]}ct.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var $i,bg,ct,JO,Yk,Wk,_ie,bo,ad,hl,id,yg,lp=be(()=>{De();$i=M(rt());Xn();bg=require("worker_threads");pl();ct=M(z()),JO=require("lodash"),Yk=M(ae());H();Wk=require("crypto"),_ie=200,bo=new Map,id=new Map,yg=new Map;a(QO,"startOnMainThread");a(zk,"requestClusterStatus");bg.parentPort&&(ad=a(e=>{bg.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),hl=a(e=>{bg.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,$i.onMessageByType)("subscribe-to-node",e=>{od(e)}),(0,$i.onMessageByType)("unsubscribe-from-node",e=>{Og(e)}));a(Oo,"ensureNode")});var Zn=w(gF=>{"use strict";var ar=require("path"),Nn=require("fs-extra"),cd=require("node-forge"),tF=require("net"),{generateKeyPair:ZO,X509Certificate:No,createPrivateKey:rF}=require("crypto"),pie=require("util");ZO=pie.promisify(ZO);var bt=cd.pki,ci=require("joi"),{v4:nF}=require("uuid"),{validateBySchema:nN}=ot(),pt=z(),ys=ae(),bs=(H(),C(G)),{CONFIG_PARAMS:ld}=bs,li=Vy(),{ClientError:va}=pe(),Ng=require("node:tls"),{relative:sF,join:hie}=require("node:path"),{CERT_PREFERENCE_APP:UPe,CERTIFICATE_VALUES:Jk}=li,mie=ua(),eN=yt(),{table:Eie,getDatabases:gie,databases:XO}=(De(),C(nt)),{getJWTRSAKeys:Qk}=(Ju(),C(X_));Object.assign(gF,{generateKeys:oN,updateConfigCert:fF,createCsr:Nie,signCertificate:wie,setCertTable:ud,loadCertificates:lF,reviewSelfSignedCert:cN,createTLSSelector:pF,listCertificates:mF,addCertificate:Mie,removeCertificate:Uie,createNatsCerts:Pie,generateCertsKeys:Cie,getReplicationCert:dp,getReplicationCertAuth:Oie,renewSelfSigned:Die,hostnamesFromCert:EF,getKey:xie});var{urlToNodeName:iF,getThisNodeUrl:Sie,getThisNodeName:Ig,clearThisNodeName:Tie}=(Xn(),C(wo)),{readFileSync:Aie,watchFile:Rie,statSync:oF}=require("node:fs"),xPe=ae(),{getTicketKeys:yie,onMessageFromWorkers:bie}=rt(),Ma=z(),{isMainThread:aF}=require("worker_threads"),{TLSSocket:cF,createSecureContext:BPe}=require("node:tls"),sN=3650,up=["127.0.0.1","localhost","::1"],iN=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];bie(async e=>{e.type===bs.ITC_EVENT_TYPES.RESTART&&(ys.initSync(!0),await cN())});var Ur;function xa(){return Ur||(Ur=gie().system.hdb_certificate,Ur||(Ur=Eie({table:"hdb_certificate",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]}))),Ur}a(xa,"getCertTable");async function dp(){let e=pF("operations-api"),t={secureContexts:null,setSecureContext:a(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(Ig());if(!r)return;let n=new No(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(dp,"getReplicationCert");async function Oie(){xa();let e=(await dp()).options.cert,r=new No(e).issuer.match(/CN=(.*)/)?.[1];return Ur.get(r)}a(Oie,"getReplicationCertAuth");var Xk,Ua=new Map;function lF(){if(Xk)return;Xk=!0;let e=[{configKey:ld.TLS},{configKey:ld.OPERATIONSAPI_TLS}];xa();let t=ar.dirname(eN.getConfigFilePath()),r;for(let{configKey:n}of e){let s=eN.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&sF(hie(t,"keys"),o);c&&Zk(o,l=>{Ua.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&aF){let f;Zk(u,d=>{if(Jk.cert===d)return;let p=i.hostname??i.hostnames??i.host??i.hosts;p&&!Array.isArray(p)&&(p=[p]);let _=_F(u),h=new No(_),S;try{S=lN(h)}catch(T){pt.error("error extracting common name from certificate",T);return}if(S==null){pt.error("error extracting common name from certificate");return}if(h.checkIssued(new No(Jk.cert)))return;let g=Ur.primaryStore.get(S),R=oF(u).mtimeMs,E=!g||g.is_self_signed?1:g.file_timestamp??g.__updatedtime__;if(g&&R<=E){R<E&&pt.info(`Certificate ${S} at ${u} is older (${new Date(R)}) than the certificate in the database (${E>1?new Date(E):"only self signed certificate available"})`);return}r=Ur.put({name:S,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:_,private_key_name:c,is_authority:l,hostnames:p,file_timestamp:R,details:{issuer:h.issuer.replace(/\n/g," "),subject:h.subject.replace(/\n/g," "),subject_alt_name:h.subjectAltName,serial_number:h.serialNumber,valid_from:h.validFrom,valid_to:h.validTo}})},l?"certificate authority":"certificate")}}}}}return r}a(lF,"loadCertificates");function Zk(e,t,r){let n,s=a((i,o)=>{try{let c=i.mtimeMs;c&&c!==n&&(o&&aF&&pt.warn(`Reloading ${r}:`,e),n=c,t(_F(e)))}catch(c){pt.error(`Error loading ${r}:`,e,c)}},"loadFile");Nn.existsSync(e)?s(oF(e)):pt.error(`${r} file not found:`,e),Rie(e,{persistent:!1},s)}a(Zk,"loadAndWatch");function tN(){let e=Sie();if(e==null){let t=up[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return iF(e)}a(tN,"getHost");function wg(){let e=Ig();if(e==null){let t=up[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(wg,"getCommonName");async function Nie(){let e=await dp(),t=bt.certificateFromPem(e.options.cert),r=bt.privateKeyFromPem(e.options.key);pt.info("Creating CSR with cert named:",e.name);let n=bt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:wg()},...iN];pt.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:uF()}];return pt.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),cd.pki.certificationRequestToPem(n)}a(Nie,"createCsr");function uF(){let e=up.includes(wg())?up:[...up,wg()];return e.includes(tN())||e.push(tN()),[{name:"basicConstraints",cA:!1,critical:!0},{name:"keyUsage",digitalSignature:!0,keyEncipherment:!0,critical:!0},{name:"extKeyUsage",serverAuth:!0,clientAuth:!0},{name:"nsCertType",client:!0,server:!0},{name:"subjectAltName",altNames:e.map(t=>tF.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a(uF,"certExtensions");async function wie(e){let t={},r=ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;xa();for await(let f of Ur.search([]))if(f.is_authority&&!f.details.issuer.includes("HarperDB-Certificate-Authority")){if(Ua.has(f.private_key_name)){n=Ua.get(f.private_key_name),s=f;break}else if(f.private_key_name&&await Nn.exists(ar.join(r,f.private_key_name))){n=Nn.readFile(ar.join(r,f.private_key_name)),s=f;break}}if(!n){let f=await rN();s=f.ca,n=f.private_key}n=bt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=bt.certificateFromPem(s.certificate);pt.info("Signing CSR with cert named",s.name);let o=bt.certificationRequestFromPem(e.csr);try{o.verify()}catch(f){return pt.error(f),new Error("Error verifying CSR: "+f.message)}let c=cd.pki.createCertificate();c.serialNumber=Math.random().toString().slice(2,10),c.validity.notBefore=new Date;let l=new Date;c.validity.notAfter=l,c.validity.notAfter.setDate(l.getDate()+sN),pt.info("sign cert setting validity:",c.validity),pt.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),pt.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=o.getAttribute({name:"extensionRequest"}).extensions;pt.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=o.publicKey,c.sign(n,cd.md.sha256.create()),t.certificate=bt.certificateToPem(c)}else pt.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(wie,"signCertificate");async function Iie(e,t){await ud({name:Ig(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await ud({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:bt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(Iie,"createCertificateTable");async function ud(e){let t=new No(e.certificate);e.details={issuer:t.issuer.replace(/\n/g," "),subject:t.subject.replace(/\n/g," "),subject_alt_name:t.subjectAltName,serial_number:t.serialNumber,valid_from:t.validFrom,valid_to:t.validTo},xa(),await Ur.patch(e)}a(ud,"setCertTable");async function oN(){let e=await ZO("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:bt.publicKeyFromPem(e.publicKey),private_key:bt.privateKeyFromPem(e.privateKey)}}a(oN,"generateKeys");async function aN(e,t,r){let n=bt.createCertificate();if(!t){let o=await dp();t=bt.certificateFromPem(o.options.cert).publicKey}n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+sN);let i=[{name:"commonName",value:wg()},...iN];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(uF()),n.sign(e,cd.md.sha256.create()),bt.certificateToPem(n)}a(aN,"generateCertificates");async function rN(){let e=await mF(),t;for(let r of e){if(!r.is_authority)continue;let n=await hF(r.private_key_name);if(r.private_key_name&&n&&new No(r.certificate).checkPrivateKey(rF(n))){pt.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;pt.trace("No CA found with matching private key")}a(rN,"getCertAuthority");async function dF(e,t,r=!0){let n=bt.createCertificate();n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+sN);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${ys.get(ld.REPLICATION_HOSTNAME)??iF(ys.get(ld.REPLICATION_URL))??nF().split("-")[0]}`},...iN];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,cd.md.sha256.create());let o=ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME),c=ar.join(o,li.PRIVATEKEY_PEM_NAME);return r&&await Nn.writeFile(c,bt.privateKeyToPem(e)),n}a(dF,"generateCertAuthority");async function Cie(){let{private_key:e,public_key:t}=await oN(),r=await dF(e,t),n=await aN(e,t,r);await Iie(n,r),fF()}a(Cie,"generateCertsKeys");async function Pie(){let e=await aN(bt.privateKeyFromPem(li.CERTIFICATE_VALUES.key),void 0,bt.certificateFromPem(li.CERTIFICATE_VALUES.cert)),t=ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME),r=ar.join(t,li.NATS_CERTIFICATE_PEM_NAME);await Nn.exists(r)||await Nn.writeFile(r,e);let n=ar.join(t,li.NATS_CA_PEM_NAME);await Nn.exists(n)||await Nn.writeFile(n,li.CERTIFICATE_VALUES.cert)}a(Pie,"createNatsCerts");async function Die(){xa();for await(let e of Ur.search([{attribute:"is_self_signed",value:!0}]))await Ur.delete(e.name);await cN()}a(Die,"renewSelfSigned");async function cN(){Tie(),await lF(),xa();let e=await rN();if(!e){pt.notify("A matching Certificate Authority and key was not found. A new CA will be created in advance, so it's available if needed.");let r=ys.get(ld.TLS_PRIVATEKEY),n=ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME),s,i=sF(n,r);try{s=bt.privateKeyFromPem(await Nn.readFile(r))}catch(c){pt.warn("Unable to parse the TLS key",r,"A new key will be generated and used to create Certificate Authority",c),{private_key:s}=await oN(),await Nn.exists(ar.join(n,li.PRIVATEKEY_PEM_NAME))&&(i=`privateKey${nF().split("-")[0]}.pem`),await Nn.writeFile(ar.join(n,i),bt.privateKeyToPem(s))}let o=await dF(s,bt.setRsaPublicKey(s.n,s.e),!1);await ud({name:o.subject.getField("CN").value,uses:["https"],certificate:bt.certificateToPem(o),private_key_name:i,is_authority:!0,is_self_signed:!0})}if(!await dp()){let r=Ig();pt.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await rN();let n=bt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await aN(bt.privateKeyFromPem(e.private_key),s,n);await ud({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(cN,"reviewSelfSignedCert");function fF(){let e=mie(Object.keys(bs.CONFIG_PARAM_MAP),!0),t=ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME),r=ar.join(t,li.PRIVATEKEY_PEM_NAME),n=ar.join(t,li.NATS_CERTIFICATE_PEM_NAME),s=ar.join(t,li.NATS_CA_PEM_NAME),i=bs.CONFIG_PARAMS,o={[i.TLS_PRIVATEKEY]:e[i.TLS_PRIVATEKEY.toLowerCase()]?e[i.TLS_PRIVATEKEY.toLowerCase()]:r};e[i.TLS_CERTIFICATE.toLowerCase()]&&(o[i.TLS_CERTIFICATE]=e[i.TLS_CERTIFICATE.toLowerCase()]),e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.TLS_CERTIFICATEAUTHORITY]=e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATE]=e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]),e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_PRIVATEKEY]=e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY]=e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]),(e[i.CLUSTERING_ENABLED.toLowerCase()]||e.clustering)&&(o[i.CLUSTERING_TLS_CERTIFICATE]=e[i.CLUSTERING_TLS_CERTIFICATE.toLowerCase()]??n,o[i.CLUSTERING_TLS_CERT_AUTH]=e[i.CLUSTERING_TLS_CERT_AUTH.toLowerCase()]??s,o[i.CLUSTERING_TLS_PRIVATEKEY]=e[i.CLUSTERING_TLS_PRIVATEKEY.toLowerCase()]??r),eN.updateConfigValue(void 0,void 0,o,!1,!0)}a(fF,"updateConfigCert");function _F(e){return e.startsWith("-----BEGIN")?e:Aie(e,"utf8")}a(_F,"readPEM");var eF=Ng.createSecureContext;Ng.createSecureContext=function(e){if(!e.cert||!e.key)return eF(e);let t={...e};delete t.key,delete t.cert;let r=eF(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var Lie=cF.prototype._init;cF.prototype._init=function(e,t){Lie.call(this,e,t);let r=this;this._handle.oncertcb=function(n){let s=n.servername;r._SNICallback(s,(i,o)=>{this.sni_context=o?.context||o,this.certCbDone()})}};var ml=new Map;function pF(e,t){let r=new Map,n,s=!1;return i.initialize=o=>i.ready?i.ready:(o&&(o.secureContexts=r,o.secureContextsListeners=[]),i.ready=new Promise((c,l)=>{async function u(){try{r.clear(),ml.clear();let f=0;for await(let d of XO.system.hdb_certificate.search([])){let p=d.certificate,_=new No(p);d.is_authority&&(_.asString=p,ml.set(_.subject,p))}for await(let d of XO.system.hdb_certificate.search([]))try{if(d.is_authority)continue;let p=e==="operations-api",_=d.is_self_signed?1:2;p&&d.uses?.includes?.("operations")&&(_+=1);let h=await hF(d.private_key_name),S=d.certificate,g=new No(S);if(ml.has(g.issuer)&&(S+=`
24
+ `+ml.get(g.issuer)),!h||!S)throw new Error("Missing private key or certificate for secure server");let R={ciphers:d.ciphers,ticketKeys:yie(),availableCAs:ml,ca:t&&Array.from(ml.values()),cert:S,key:h,key_file:d.private_key_name,is_self_signed:d.is_self_signed};o&&(R.sessionIdContext=o.sessionIdContext);let E=Ng.createSecureContext(R);E.name=d.name,E.options=R,E.quality=_,E.certificateAuthorities=Array.from(ml),E.certStart=S.toString().slice(0,100);let T=d.hostnames??EF(g);Array.isArray(T)||(T=[T]);let b;for(let v of T)if(v){v[0]==="*"&&(s=!0,v=v.slice(1)),v===tN()&&(_+=2),tF.isIP(v)&&(b=!0);let F=r.get(v)?.quality??0;_>F&&r.set(v,E)}else Ma.error("No hostname found for certificate at",Ng.certificate);Ma.trace("Adding TLS",E.name,"for",o.ports||"client","cert named",d.name,"hostnames",T,"quality",_,"best quality",f),_>f&&(i.defaultContext=n=E,f=_,o&&(o.defaultContext=E))}catch(p){Ma.error("Error applying TLS for",d.name,p)}o?.secureContextsListeners.forEach(d=>d()),c(n)}catch(f){l(f)}}a(u,"updateTLS"),XO.system.hdb_certificate.subscribe({listener:a(()=>setTimeout(()=>u(),1500).unref(),"listener"),omitCurrent:!0}),u()})),i;function i(o,c){Ma.info("TLS requested for",o||"(no SNI)");let l=o;for(;;){let f=r.get(l);if(f)return Ma.debug("Found certificate for",o,f.certStart),f.updatedContext&&(f=f.updatedContext),c(null,f);if(s&&l){let d=l.indexOf(".",1);d<0?l="":l=l.slice(d)}else break}o?Ma.debug("No certificate found to match",o,"using the default certificate"):Ma.debug("No SNI, using the default certificate",n?.name);let u=n;u?u.updatedContext&&(u=u.updatedContext):Ma.info("No default certificate found"),c(null,u)}a(i,"SNICallback")}a(pF,"createTLSSelector");async function hF(e){let t=Ua.get(e);return!t&&e?await Nn.readFile(ar.join(ys.get(ld.ROOTPATH),bs.LICENSE_KEY_DIR_NAME,e),"utf8"):t}a(hF,"getPrivateKeyByName");async function mF(){xa();let e=[];for await(let t of Ur.search([]))e.push(t);return e}a(mF,"listCertificates");async function Mie(e){let t=nN(e,ci.object({name:ci.string().required(),certificate:ci.string().required(),is_authority:ci.boolean().required(),private_key:ci.string(),hosts:ci.array(),uses:ci.array()}));if(t)throw new va(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,o=new No(n),c=!1,l=!1,u;for(let[_,h]of Ua)!s&&!c&&o.checkPrivateKey(rF(h))&&(c=!0,u=_),s&&s===h&&(l=!0,u=_);if(!i&&!s&&!c)throw new va("A suitable private key was not found for this certificate");let f;if(!r){try{f=lN(o)}catch(_){pt.error(_)}if(f==null)throw new va("Error extracting certificate common name, please provide a name parameter")}let d=vie(r??f);s&&!c&&!l&&(await Nn.writeFile(ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME,d+".pem"),s),Ua.set(d,s));let p={name:r??f,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&u||i&&s)&&(p.private_key_name=u??d+".pem"),await ud(p),"Successfully added certificate: "+d}a(Mie,"addCertificate");function vie(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(vie,"sanitizeName");async function Uie(e){let t=nN(e,ci.object({name:ci.string().required()}));if(t)throw new va(t.message);let{name:r}=e;xa();let n=await Ur.get(r);if(!n)throw new va(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await Ur.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(pt.info("Removing private key named",s),await Nn.remove(ar.join(ys.getHdbBasePath(),bs.LICENSE_KEY_DIR_NAME,s)))}return await Ur.delete(r),"Successfully removed "+r}a(Uie,"removeCertificate");function lN(e){return e.subject.match(/CN=(.*)/)?.[1]}a(lN,"extractCommonName");function EF(e){return e.subjectAltName?e.subjectAltName.split(",").map(t=>{let r=t.indexOf(":");if(t=t.slice(r+1),t=t.trim(),t[0]==='"')try{t=JSON.parse(t)}catch{}return t.indexOf("=")>-1?t.match(/CN=([^,]*)/)?.[1]:t}).filter(t=>t):[lN(e)]}a(EF,"hostnamesFromCert");async function xie(e){if(e.bypass_auth!==!0)throw new va("Unauthorized","401");let t=nN(e,ci.object({name:ci.string().required()}));if(t)throw new va(t.message);let{name:r}=e;if(r===".jwtPrivate")return(await Qk()).privateKey;if(r===".jwtPublic")return(await Qk()).publicKey;if(Ua.get(r))return Ua.get(e.name);throw new va("Key not found")}a(xie,"getKey")});var BF={};ve(BF,{CONFIRMATION_STATUS_POSITION:()=>xF,NodeReplicationConnection:()=>fp,OPERATION_REQUEST:()=>pN,RECEIVED_TIME_POSITION:()=>mN,RECEIVED_VERSION_POSITION:()=>hN,SENDING_TIME_POSITION:()=>Mg,createWebSocket:()=>Ug,database_subscriptions:()=>Ha,replicateOverWS:()=>_p,table_update_listeners:()=>gN});async function Ug(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=Ze(),i;if(e.includes("wss://")){if(!dN){let l=(0,MF.createTLSSelector)("operations-api"),u={secureContexts:null};await l.initialize(u),dN=u.secureContexts}if(i=dN.get(s),i&&le.debug?.("Creating web socket for URL",e,"with certificate named:",i.name),!i&&n!==!1)throw new Error("Unable to find a valid certificate to use for replication to connect to "+e)}let o={};r&&(o.Authorization=r);let c={headers:o,localAddress:s?.startsWith("127.0")?s:void 0,servername:(0,UF.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,rejectUnauthorized:n!==!1,secureContext:void 0};return i&&(c.secureContext=vF.createSecureContext({...i.options,ca:Array.from(gl)})),new DF.WebSocket(e,"harperdb-replication-v1",c)}function _p(e,t,r){let n=t.port||t.securePort,s=El.pid%1e3+"-"+LF.threadId+(n?"s:"+n:"c:"+t.url?.slice(-4))+" "+Math.random().toString().slice(2,3),i=0,o=Buffer.allocUnsafeSlow(1024),c=0,l=new DataView(o.buffer,0,1024),u=t.database,f=t.databaseSubscriptions||Ha,d,p,_=!1,h=t.subscription;h?.then&&h.then(m=>h=m);let S=t.tables||u&&Xe()[u];if(!r){le.error?.("No authorization provided"),un(1008,"Unauthorized");return}let g=new Map,R=[],E=r.name;E&&t.connection&&(t.connection.nodeName=E);let T,b,v,F,q,Y,Z,se=1e3,Q,ne=0,J=0,me=0,ye=new Map,Pe=[],he=0,Nt;if(t.url){let m=a(()=>{q&&J===e._socket?.bytesRead&&me===e._socket?.bytesWritten?e.terminate():(q=performance.now(),e.ping(),J=e._socket?.bytesRead,me=e._socket?.bytesWritten)},"send_ping");v=setInterval(m,IF).unref(),m()}else dt();e._socket?.setMaxListeners(200);function dt(){clearTimeout(F),J=e._socket?.bytesRead,me=e._socket?.bytesWritten,F=setTimeout(()=>{J===e._socket?.bytesRead&&me===e._socket?.bytesWritten&&(le.warn?.(`Timeout waiting for ping from ${E}, terminating connection and reconnecting`),e.terminate())},IF*2).unref()}a(dt,"resetPingTimer");function br(){return p||(p=Rg(d,u,E)),p}a(br,"getSharedStatus"),u&&ia(u);let hs,Un,ou=[],au=[],HA,kA=[],vt=[],Ef=[],Jh=150,Qh=25,gf=0,Xh=0,Ie=!1,Sf,ln,Cr,cu;e.on("message",m=>{ne=performance.now();try{let A=m.dataView=new Sl(m.buffer,m.byteOffset,m.byteLength);if(m[0]>127){let P=(0,je.decode)(m),[N,L,k]=P;switch(N){case TF:{if(L){if(E){if(E!==L){le.error?.(s,`Node name mismatch, expecting to connect to ${E}, but peer reported name as ${L}, disconnecting`),e.send((0,je.encode)([dd])),un(1008,"Node name mismatch");return}}else if(E=L,t.connection?.tentativeNode){let U=t.connection.tentativeNode;U.name=E,t.connection.tentativeNode=null,Oo(E,U)}if(t.connection&&(t.connection.nodeName=E),le.debug?.(s,"received node name:",E,"db:",u),!u)try{ia(u=P[2]),u==="system"&&(hs=Da(t,(U,ue)=>{uu(ue)&&oa(ue)}),e.on("close",()=>{hs?.remove()}))}catch(U){le.warn?.(s,"Error setting database",U),e.send((0,je.encode)([dd])),un(1008,U.message);return}Gr()}break}case NF:{le.debug?.(s,"Received table definitions for",L.map(U=>U.table));for(let U of L){let ue=P[2];U.database=ue;let ce;uu(ue)&&(ue==="system"?qe[ue]?.[U.table]||(ce=fN(U,qe[ue]?.[U.table])):ce=fN(U,qe[ue]?.[U.table]),d||(d=ce?.auditStore),S||(S=Xe()?.[ue]))}break}case dd:un();break;case pN:try{let U=r?.replicates||r?.subscribers||r?.name;server.operation(L,{user:r},!U).then(ue=>{Array.isArray(ue)&&(ue={results:ue}),ue.requestId=L.requestId,e.send((0,je.encode)([Pg,ue]))},ue=>{e.send((0,je.encode)([Pg,{requestId:L.requestId,error:ue instanceof Error?ue.toString():ue}]))})}catch(U){e.send((0,je.encode)([Pg,{requestId:L.requestId,error:U instanceof Error?U.toString():U}]))}break;case Pg:let{resolve:D,reject:B}=g.get(L.requestId);L.error?B(new Error(L.error)):D(L),g.delete(L.requestId);break;case uN:let $=P[3];S||(u?le.error?.(s,"No tables found for",u):le.error?.(s,"Database name never received"));let j=S[$];j=fN({table:$,database:u,attributes:L.attributes,schemaDefined:L.schemaDefined},j),ou[k]={name:$,decoder:new je.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:L.typedStructs,structures:L.structures}),getEntry(U){return j.primaryStore.getEntry(U)},rootStore:j.primaryStore.rootStore};break;case AF:cu=d?Fk(L,d):new Map,HA=P[2],le.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${HA}`);break;case RF:let oe=k;Ef[oe]=L;break;case OF:br()[xF]=L,le.trace?.(s,"received and broadcasting committed update",L),br().buffer.notify();break;case bF:T=L,h.send({type:"end_txn",localTime:T,remoteNodeIds:R});break;case Dg:{let U=P[1],{fileId:ue,size:ce,finished:fe,error:te}=U,W=ye.get(ue);le.debug?.("Received blob",ue,"has stream",!!W,"connectedToBlob",!!W?.connectedToBlob,"length",P[2].length,"finished",fe),W||(W=new _N.PassThrough,W.expectedSize=ce,ye.set(ue,W)),W.lastChunk=Date.now(),fe?(te?(W.on("error",()=>{}),W.destroy(new Error("Blob error: "+te))):W.end(P[2]),W.connectedToBlob&&ye.delete(ue)):W.write(P[2]);break}case yF:{let U=L,ue;try{let ce=P[3],fe=au[k]||(au[k]=S[P[4]]);if(!fe)return le.warn?.("Unknown table id trying to handle record request",k);let te=fe.primaryStore.getBinaryFast(Symbol.for("structures")),W=te.length;if(W!==Xh){Xh=W;let Ee=(0,je.decode)(te);e.send((0,je.encode)([uN,{typedStructs:Ee.typed,structures:Ee.named},k,fe.tableName]))}let _e=fe.primaryStore.getBinaryFast(ce);if(_e){let Ee=fe.primaryStore.decoder.decode(_e,{valueAsBuffer:!0});ue=(0,je.encode)([Cg,U,{value:Ee.value,expiresAt:Ee.expiresAt,version:Ee.version,residencyId:Ee.residencyId,nodeId:Ee.nodeId,user:Ee.user}])}else ue=(0,je.encode)([Cg,U])}catch(ce){ue=(0,je.encode)([Cg,U,{error:ce.message}])}e.send(ue);break}case Cg:{let{resolve:U,reject:ue,tableId:ce,key:fe}=g.get(P[1]),te=P[2];if(te?.error)ue(new Error(te.error));else if(te){let W=ou[ce].decoder.decode(te.value);te.value=W,te.key=fe,U(te)}else U();g.delete(P[1]);break}case SF:{Cr=L;let U,ue,ce=!1;if(h){if(u!==h.databaseName&&!h.then){le.error?.("Subscription request for wrong database",u,h.databaseName);return}}else h=f.get(u);if(le.debug?.(s,"received subscription request for",u,"at",Cr),!h){let ge;h=new Promise(Qe=>{le.debug?.("Waiting for subscription to database "+u),ge=Qe}),h.ready=ge,Ha.set(u,h)}if(r.name)ue=or().subscribe(r.name),ue.then(async ge=>{U=ge;for await(let Qe of U){let st=Qe.value;if(!(st?.replicates===!0||st?.replicates?.receives||st?.subscriptions?.some(Vt=>(Vt.database||Vt.schema)===u&&Vt.publish!==!1))){ce=!0,e.send((0,je.encode)([dd])),un(1008,`Unauthorized database subscription to ${u}`);return}}},ge=>{le.error?.(s,"Error subscribing to HDB nodes",ge)});else if(!(r?.role?.permission?.super_user||r.replicates)){e.send((0,je.encode)([dd])),un(1008,`Unauthorized database subscription to ${u}`);return}if(ln&&(le.debug?.(s,"stopping previous subscription",u),ln.emit("close")),Cr.length===0)return;let fe=Cr[0],te=a(ge=>{if(ge&&(fe.replicateByDefault?!fe.tables.includes(ge.tableName):fe.tables.includes(ge.tableName)))return{table:ge}},"tableToTableEntry"),W={txnTime:0},_e,Ee,Se=1/0,tt,Ye=a((ge,Qe)=>{if(ge.type==="end_txn"){W.txnTime&&(o[i]!==66&&le.error?.("Invalid encoding of message"),du(9),du(vg),Rc(tt=Qe),mr()),i=c,W.txnTime=0;return}let st=ge.nodeId,Vt=ge.tableId,Kt=Ee[Vt];if(!Kt&&(Kt=Ee[Vt]=te(h.tableById[Vt]),!Kt))return le.debug?.("Not subscribed to table",Vt);let qr=Kt.table,yc=qr.primaryStore,Ut=yc.encoder;(ge.extendedType&jm||!Ut.typedStructs)&&(Ut._mergeStructures(Ut.getStructures()),Ut.typedStructs&&(Ut.lastTypedStructuresLength=Ut.typedStructs.length));let em=_e[st];if(!(em&&em.startTime<Qe&&(!em.endTime||em.endTime>Qe)))return Lg&&le.trace?.(s,"skipping replication update",ge.recordId,"to:",E,"from:",st,"subscribed:",_e),oD();Lg&&le.trace?.(s,"sending replication update",ge.recordId,"to:",E,"from:",st,"subscribed:",_e);let FA=ge.version;W.txnTime!==FA&&(W.txnTime&&(Lg&&le.trace?.(s,"new txn time, sending queued txn",W.txnTime),o[i]!==66&&le.error?.("Invalid encoding of message"),mr()),W.txnTime=FA,i=c,Rc(FA));let bc=ge.residencyId,GA=lu(bc,qr),tm;if(GA&&!GA.includes(E)){let Oc=lu(ge.previousResidencyId,qr);if(Oc&&!Oc.includes(E)&&(ge.type==="put"||ge.type==="patch")||qr.getResidencyById)return oD();let Rf=ge.recordId;le.trace?.(s,"sending invalidation",Rf,E,"from",st);let ca=0;bc&&(ca|=kc),ge.previousResidencyId&&(ca|=Fc);let Ks,dn=null;for(let rm in qr.indices){if(!dn){if(Ks=ge.getValue(yc,!0),!Ks)break;dn={}}dn[rm]=Ks[rm]}tm=Nu(ge.version,Vt,Rf,null,st,ge.user,ge.type==="put"||ge.type==="patch"?"invalidate":ge.type,Ut.encode(dn),ca,bc,ge.previousResidencyId,ge.expiresAt)}function oD(){le.trace?.(s,"skipping audit record",ge.recordId),Y||(Y=setTimeout(()=>{Y=null,(tt||0)+wF/2<Se&&(Lg&&le.trace?.(s,"sending skipped sequence update",Se),e.send((0,je.encode)([bF,Se])))},wF).unref())}a(oD,"skipAuditRecord");let qA=Ut.typedStructs,$A=Ut.structures;if((qA?.length!=Kt.typed_length||$A?.length!=Kt.structure_length)&&(Kt.typed_length=qA?.length,Kt.structure_length=$A.length,le.debug?.(s,"send table struct",Kt.typed_length,Kt.structure_length),Kt.sentName||(Kt.sentName=!0),e.send((0,je.encode)([uN,{typedStructs:qA,structures:$A,attributes:qr.attributes,schemaDefined:qr.schemaDefined},Vt,Kt.table.tableName]))),bc&&!vt[bc]&&(e.send((0,je.encode)([RF,GA,bc])),vt[bc]=!0),tm)du(tm.length),Ac(tm);else{let Oc=ge.encoded;ge.extendedType&Fn&&PR(()=>ge.getValue(yc),async ca=>{let Ks=Hm(ca);try{let dn;he++;for await(let rm of ca.stream()){if(dn&&(le.debug?.("Sending blob chunk",Ks,"length",dn.length),e.send((0,je.encode)([Dg,{fileId:Ks,size:ca.size},dn]))),dn=rm,ce)return;e._socket.writableNeedDrain&&(le.debug?.("draining",Ks),await new Promise(g2=>e._socket.once("drain",g2)),le.debug?.("drained",Ks))}le.debug?.("Sending final blob chunk",Ks,"length",dn.length),e.send((0,je.encode)([Dg,{fileId:Ks,size:ca.size,finished:!0},dn]))}catch(dn){le.debug?.("Error sending blob",dn),e.send((0,je.encode)([Dg,{fileId:Ks,finished:!0,error:dn.toString()},Buffer.alloc(0)]))}finally{he--,he<Qh&&Nt?.()}});let Rf=Oc[0]===66?8:0;du(Oc.length-Rf),Ac(Oc,Rf),le.trace?.("wrote record",ge.recordId,"length:",Oc.length)}},"sendAuditRecord"),mr=a(()=>{c-i>8?(e.send(o.subarray(i,c)),le.debug?.(s,"Sent message, size:",c-i)):le.debug?.(s,"skipping empty transaction")},"sendQueuedData");ln=new EN.EventEmitter,ln.once("close",()=>{ce=!0,U?.end()});for(let{startTime:ge}of Cr)ge<Se&&(Se=ge);(ue||Promise.resolve()).then(async()=>{h=await h,d=h.auditStore,Ee=h.tableById.map(te),_e=[];for(let{name:Qe,startTime:st,endTime:Vt}of Cr){let Kt=Ag(Qe,d);le.debug?.("subscription to",Qe,"using local id",Kt,"starting",st),_e[Kt]={startTime:st,endTime:Vt}}oa(u),hs||(hs=Tl(Qe=>{Qe.databaseName===u&&oa(u)}),Un=pp(Qe=>{Qe===u&&(e.send((0,je.encode)([dd])),un())}),e.on("close",()=>{hs?.remove(),Un?.remove()})),e.send((0,je.encode)([AF,ip(h.auditStore),Cr.map(({name:Qe})=>Qe)]));let ge=!0;do{isFinite(Se)||(le.warn?.("Invalid sequence id "+Se),un(1008,"Invalid sequence id"+Se));let Qe;if(ge&&!ce&&(ge=!1,!(TN(d)<=Se)&&(PF.default.get(x.REPLICATION_COPYTABLESTOCATCHUP)??Bie)&&server.nodes[0]?.name===E)){le.info?.("Replicating all tables to",E);let Vt=Se,Kt=xg(d);for(let qr in S){if(!te(qr))continue;let yc=S[qr];for(let Ut of yc.primaryStore.getRange({snapshot:!1})){if(ce)return;Ut.localTime>=Se&&(le.trace?.(s,"Copying record from",u,qr,Ut.key,Ut.localTime),Vt=Math.max(Ut.localTime,Vt),Qe=!0,br()[Mg]=1,Ye({recordId:Ut.key,tableId:yc.tableId,type:"put",getValue(){return Ut.value},encoded:yc.primaryStore.getBinary(Ut.key),version:Ut.version,residencyId:Ut.residencyId,nodeId:Kt,extendedType:Ut.metadataFlags},Ut.localTime))}}Se=Vt}for(let{key:st,value:Vt}of d.getRange({start:Se||1,exclusiveStart:!0,snapshot:!1})){if(ce)return;let Kt=It(Vt);le.debug?.("sending audit record",new Date(st)),br()[Mg]=st,Se=st,Ye(Kt,st),e._socket.writableNeedDrain?await new Promise(qr=>{le.debug?.(`Waiting for remote node ${E} to allow more commits ${e._socket.writableNeedDrain?"due to network backlog":"due to requested flow directive"}`),e._socket.once("drain",qr)}):he>Qh?await new Promise(qr=>{Nt=qr}):await new Promise(setImmediate),ln.startTime=st,Qe=!0}Qe&&Ye({type:"end_txn"},Se),br()[Mg]=0,await HF(d)}while(!ce)}).catch(ge=>{le.error?.(s,"Error handling subscription to node",ge),un(1008,"Error handling subscription to node")});break}}return}A.position=8;let I=!0,y,O;do{br();let P=A.readInt();if(P===9&&A.getUint8(A.position)==vg){A.position++,T=O=A.readFloat64(),p[hN]=T,p[mN]=Date.now(),le.trace?.("received remote sequence update",T,u);break}let N=A.position,L=It(m,N,N+P),k=ou[L.tableId];k||le.error?.(`No table found with an id of ${L.tableId}`);let D;L.residencyId&&(D=Ef[L.residencyId],le.trace?.(s,"received residency list",D,L.type,L.recordId));try{CR(()=>{y={table:k.name,id:L.recordId,type:L.type,nodeId:cu.get(L.nodeId),residencyList:D,timestamp:L.version,value:L.getValue(k),user:L.user,beginTxn:I,expiresAt:L.expiresAt}},B=>{let $=Hm(B),j=ye.get($);le.debug?.("Received transaction with blob",$,"has stream",!!j,"ended",!!j?.writableEnded),j?j.writableEnded&&ye.delete($):(j=new _N.PassThrough,ye.set($,j)),j.connectedToBlob=!0,j.lastChunk=Date.now(),B.size===void 0&&j.expectedSize&&(B.size=j.expectedSize);let oe=createBlob(j,B),U=oe.save({primaryStore:h.auditStore});return U&&(U.blobId=$,Pe.push(U),U.finally(()=>{le.debug?.(`Finished receiving blob stream ${$}`),Pe.splice(Pe.indexOf(U),1)})),oe})}catch(B){throw B.message+="typed structures for current decoder"+JSON.stringify(k.decoder.typedStructs),B}I=!1,le.trace?.(s,"received replication message",L.type,"id",y.id,"version",new Date(L.version),"nodeId",y.nodeId),p[hN]=L.version,p[mN]=Date.now(),h.send(y),A.position=N+P}while(A.position<m.byteLength);gf++,sr(m.byteLength,"bytes-received",`${E}.${u}.${y?.table||"unknown_table"}`,"replication","ingest"),gf>Jh&&!Ie&&(Ie=!0,e.pause(),le.debug?.(`Commit backlog causing replication back-pressure, requesting that ${E} pause replication`)),h.send({type:"end_txn",localTime:T,remoteNodeIds:R,async onCommit(){if(y){let P=Date.now()-y.timestamp;sr(P,"replication-latency",E+"."+u+"."+y.table,y.type,"ingest")}gf--,Ie&&(Ie=!1,e.resume(),le.debug?.(`Replication resuming ${E}`)),Pe.length>0&&await Promise.all(Pe),le.trace?.("All blobs finished"),!b&&O&&(le.trace?.(s,"queuing confirmation of a commit at",O),setTimeout(()=>{e.send((0,je.encode)([OF,b])),le.trace?.(s,"sent confirmation of a commit at",b),b=null},Hie)),b=O,le.debug?.("last sequence committed",new Date(O),u)}})}catch(A){le.error?.(s,"Error handling incoming replication message",A)}}),e.on("ping",dt),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-q,hl({name:E,database:u,url:t.url,latency:t.connection.latency})),q=null}),e.on("close",(m,A)=>{clearInterval(v),clearTimeout(F),clearInterval(Z),ln&&ln.emit("close"),Sf&&Sf.end();for(let[I,{reject:y}]of g)y(new Error(`Connection closed ${A?.toString()} ${m}`));le.debug?.(s,"closed",m,A?.toString())});function Tf(){}a(Tf,"recordRemoteNodeSequence");function un(m,A){e.isFinished=!0,e.close(m,A)}a(un,"close");function Gr(){if(_||(_=!0,t.connection?.on("subscriptions-updated",Gr)),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let m=new Map;try{for(let y of h?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let O of y.value.nodes||[])O.lastTxnTime>(m.get(O.id)??0)&&m.set(O.id,O.lastTxnTime)}catch(y){if(!y.message.includes("Can not re"))throw y}let A=t.connection?.nodeSubscriptions?.[0];R=[];let I=t.connection?.nodeSubscriptions.map((y,O)=>{let P=[],{replicateByDefault:N}=y;if(y.subscriptions){for(let B of y.subscriptions)if(B.subscribe&&(B.schema||B.database)===u){let $=B.table;S?.[$]?.replicate!==!1&&P.push($)}N=!1}else for(let B in S)(N?S[B].replicate===!1:S[B].replicate)&&P.push(B);let L=d&&Ag(y.name,d),k=h?.dbisDB?.get([Symbol.for("seq"),L])??1,D=Math.max(k?.seqId??1,(typeof y.start_time=="string"?new Date(y.start_time).getTime():y.start_time)??1);if(le.debug?.("Starting time recorded in db",y.name,L,u,k?.seqId,"start time:",D,new Date(D)),A!==y){let B=d&&Ag(A.name,d),$=h?.dbisDB?.get([Symbol.for("seq"),B])??1;for(let j of $?.nodes||[])j.name===y.name&&(D=j.seqId,le.debug?.("Using sequence id from proxy node",A.name,D))}return R.push(L),m.get(L)>D&&(D=m.get(L),le.debug?.("Updating start time from more recent txn recorded",A.name,D)),{name:y.name,replicateByDefault:N,tables:P,startTime:D,endTime:y.end_time}});if(I)if(le.debug?.(s,"sending subscription request",I,h?.dbisDB?.path),clearTimeout(Q),I.length>0)e.send((0,je.encode)([SF,I]));else{let y=a(()=>{let O=performance.now();Q=setTimeout(()=>{ne<=O?un(1008,"No nodes to subscribe to"):y()},se)},"schedule_close");y()}}a(Gr,"sendSubscriptionRequestUpdate");function lu(m,A){if(!m)return;let I=kA[m];return I||(I=A.getResidencyRecord(m),kA[m]=I),I}a(lu,"getResidence");function uu(m){return!(Ba&&Ba!="*"&&!Ba[m]&&!Ba.includes?.(m)&&!Ba.some?.(A=>A.name===m))}a(uu,"checkDatabaseAccess");function ia(m){if(h=h||f.get(m),!uu(m))throw new Error(`Access to database "${m}" is not permitted`);h||le.warn?.(`No database named "${m}" was declared and registered`),d=h?.auditStore,S||(S=Xe()?.[m]);let A=Ze();if(A===E)throw A?new Error("Should not connect to self",A):new Error("Node name not defined");return Zh(A,m),!0}a(ia,"setDatabase");function Zh(m,A){let I=Xe()?.[A],y=[];for(let O in I){let P=I[O];y.push({table:O,schemaDefined:P.schemaDefined,attributes:P.attributes.map(N=>({name:N.name,type:N.type,isPrimaryKey:N.isPrimaryKey}))})}le.trace?.("Sending database info for node",m,"database name",A),e.send((0,je.encode)([TF,m,A,y]))}a(Zh,"sendNodeDBName");function oa(m){let A=Xe()?.[m],I=[];for(let y in A){if(Cr&&!Cr.some(P=>P.replicateByDefault?!P.tables.includes(y):P.tables.includes(y)))continue;let O=A[y];I.push({table:y,schemaDefined:O.schemaDefined,attributes:O.attributes.map(P=>({name:P.name,type:P.type,isPrimaryKey:P.isPrimaryKey}))})}e.send((0,je.encode)([NF,I,m]))}a(oa,"sendDBSchema"),Z=setInterval(()=>{for(let[m,A]of ye)A.lastChunk+3e4<Date.now()&&(le.warn?.(`Timeout waiting for blob stream to finish ${m} from ${E}`),ye.delete(m),A.end())},3e4).unref();let aa=1,Af=[];return{end(){Sf&&Sf.end(),ln&&ln.emit("close")},getRecord(m){let A=aa++;return new Promise((I,y)=>{let O=[yF,A,m.table.tableId,m.id];Af[m.table.tableId]||(O.push(m.table.tableName),Af[m.table.tableId]=!0),e.send((0,je.encode)(O)),g.set(A,{tableId:m.table.tableId,key:m.id,resolve(P){let{table:N,entry:L}=m;I(P),P&&N._recordRelocate(L,P)},reject:y})})},sendOperation(m){let A=aa++;return m.requestId=A,e.send((0,je.encode)([pN,m])),new Promise((I,y)=>{g.set(A,{resolve:I,reject:y})})}};function du(m){V(5),m<128?o[c++]=m:m<16384?(l.setUint16(c,m|32768),c+=2):m<1056964608?(l.setUint32(c,m|3221225472),c+=4):(o[c]=255,l.setUint32(c+1,m),c+=5)}function Ac(m,A=0,I=m.length){let y=I-A;V(y),m.copy(o,c,A,I),c+=y}function Rc(m){V(8),l.setFloat64(c,m),c+=8}function V(m){if(m+16>o.length-c){let A=Buffer.allocUnsafeSlow(c+m-i+65536>>10<<11);o.copy(A,0,i,c),c=c-i,i=0,o=A,l=new DataView(o.buffer,0,o.length)}}}function fN(e,t){let r=e.database??"data";if(r!=="data"&&!qe[r]){le.warn?.("Database not found",e.database);return}t||(t={});let n=!1,s=e.schemaDefined,i=t.attributes||[];for(let o=0;o<e.attributes?.length;o++){let c=e.attributes[o],l=i[o];(!l||l.name!==c.name||l.type!==c.type)&&(n=!0,s||(c.indexed=!0),i[o]=c)}return n?(le.debug?.("(Re)creating",e),ft({table:e.table,database:e.database,schemaDefined:e.schemaDefined,attributes:i,...t})):t}var PF,je,DF,LF,le,EN,MF,vF,El,UF,_N,SF,TF,AF,dd,RF,uN,yF,Cg,pN,Pg,bF,OF,NF,Dg,xF,hN,mN,Mg,Bie,gN,Ha,Lg,wF,Hie,IF,dN,CF,fp,SN=be(()=>{De();fo();zO();AN();Xn();PF=M(ae());H();wu();je=require("msgpackr"),DF=require("ws"),LF=require("worker_threads"),le=M(Ni());lp();EN=require("events"),MF=M(Zn()),vF=M(require("node:tls"));pl();El=M(require("node:process")),UF=require("node:net");ki();gs();_N=require("node:stream"),SF=129,TF=140,AF=141,dd=142,RF=130,uN=132,yF=133,Cg=134,pN=136,Pg=137,bF=143,OF=144,NF=145,Dg=146,xF=0,hN=1,mN=2,Mg=3,Bie=El.env.HDB_LEADER_URL||El.argv.includes("--HDB_LEADER_URL"),gN=new Map,Ha=new Map,Lg=!0,wF=300,Hie=2,IF=3e4;a(Ug,"createWebSocket");CF=1e3,fp=class extends EN.EventEmitter{constructor(r,n,s,i,o){super();this.url=r;this.subscription=n;this.databaseName=s;this.nodeName=i;this.authorization=o;this.nodeName=this.nodeName??ai(r)}static{a(this,"NodeReplicationConnection")}socket;startTime;retryTime=CF;retries=0;isConnected=!0;isFinished=!1;nodeSubscriptions=[];latency=0;replicateTablesByDefault;session;sessionResolve;sessionReject;async connect(){this.session||this.resetSession();let r=[];this.socket=await Ug(this.url,{serverName:this.nodeName,authorization:this.authorization});let n;le.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${El.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),le[this.isConnected?"info":"warn"]?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=CF,hl({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=_p(this.socket,{database:this.databaseName,subscription:this.subscription,url:this.url,connection:this},{replicates:!0}),this.sessionResolve(n)}),this.socket.on("error",s=>{s.code==="SELF_SIGNED_CERT_IN_CHAIN"?(le.warn?.(`Can not connect to ${this.url}, this server does not have a certificate authority for the certificate provided by ${this.url}`),s.isHandled=!0):s.code!=="ECONNREFUSED"&&(s.code==="UNABLE_TO_VERIFY_LEAF_SIGNATURE"?le.error?.(`Can not connect to ${this.url}, the certificate provided by ${this.url} is not trusted, this node needs to be added to the cluster, or a certificate authority needs to be added`):le.error?.(`Error in connection to ${this.url} due to ${s.message}`)),this.sessionReject(s)}),this.socket.on("close",(s,i)=>{if(this.isConnected&&(ad({name:this.nodeName,database:this.databaseName,url:this.url,finished:this.socket.isFinished}),this.isConnected=!1),this.socket.isFinished){this.isFinished=!0,n?.end(),this.emit("finished");return}if(++this.retries%20===1){let o=i?.toString();le.warn?.(`${n?"Disconnected from":"Failed to connect to"} ${this.url} (db: "${this.databaseName}"), due to ${o?'"'+o+'" ':""}(code: ${s})`)}n=null,this.resetSession(),setTimeout(()=>{this.connect()},this.retryTime).unref(),this.retryTime+=this.retryTime>>3})}resetSession(){this.session=new Promise((r,n)=>{this.sessionResolve=r,this.sessionReject=n})}subscribe(r,n){this.nodeSubscriptions=r,this.replicateTablesByDefault=n,this.emit("subscriptions-updated",r)}unsubscribe(){this.socket.isFinished=!0,this.socket.close(1008,"No longer subscribed")}getRecord(r){return this.session.then(n=>n.getRecord(r))}};a(_p,"replicateOverWS");a(fN,"ensureTableIfChanged")});var wo={};ve(wo,{clearThisNodeName:()=>Yie,disableReplication:()=>qie,enabled_databases:()=>Ba,forEachReplicatedDatabase:()=>Da,getThisNodeId:()=>xg,getThisNodeName:()=>Ze,getThisNodeUrl:()=>La,hostnameToUrl:()=>Fg,lastTimeInAuditStore:()=>op,monitorNodeCAs:()=>YF,replicateOperation:()=>zie,replication_certificate_authorities:()=>gl,sendOperationToNode:()=>mp,servers:()=>Fie,setReplicator:()=>zF,start:()=>Gie,startOnMainThread:()=>QO,subscribeToNode:()=>od,unsubscribeFromNode:()=>Og,urlToNodeName:()=>ai});function Gie(e){if(e.port||(e.port=Os.default.get(x.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=Os.default.get(x.OPERATIONSAPI_NETWORK_SECUREPORT)),!Ze())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let n of cp(e))t.set(ai(n.url),n);$ie(e),e={mtls:!0,isOperationsServer:!0,maxPayload:10*1024*1024*1024,...e};let r=We.ws(async(n,s,i,o)=>{if(s.headers.get("sec-websocket-protocol")!=="harperdb-replication-v1")return o(n,s,i);await i,n._socket.unref(),_p(n,e,s?.user),n.on("error",c=>{c.code!=="ECONNREFUSED"&&cr.error("Error in connection to "+this.url,c.message)})},e);e.runFirst=!0,We.http((n,s)=>{if(n.isWebSocket&&n.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){!n.authorized&&n._nodeRequest.socket.authorizationError&&cr.error(`Incoming client connection from ${n.ip} did not have valid certificate, you may need turn on enableRootCAs in the config if you are using a publicly signed certificate, or add the CA to the server's trusted CAs`,n._nodeRequest.socket.authorizationError);let i=or().primaryStore;if(n.authorized&&n.peerCertificate.subject){let o=n.peerCertificate.subject,c=o&&(i.get(o.CN)||t.get(o.CN));if(c)if(c?.revoked_certificates?.includes(n.peerCertificate.serialNumber)){cr.warn("Revoked certificate used in attempt to connect to node",c.name,"certificate serial number",n.peerCertificate.serialNumber);return}else n.user=c;else cr.warn(`No node found for certificate common name ${o.CN}, available nodes are ${Array.from(i.getRange({}).filter(({value:l})=>l).map(({key:l})=>l)).join(", ")} and routes ${Array.from(t.keys()).join(", ")}, connection will require credentials.`)}else{let o=i.get(n.ip)||t.get(n.ip);o?n.user=o:cr.warn(`No node found for IP address ${n.ip}, available nodes are ${Array.from(new Set([...i.getKeys(),...t.keys()])).join(", ")}, connection will require credentials.`)}}return s(n)},e);for(let n of r)if(n.secureContexts){let s=a(()=>{let i=new Set(n.secureContexts.values());n.defaultContext&&i.add(n.defaultContext);for(let o of i)try{let c=Array.from(gl);o.options.availableCAs&&c.push(...o.options.availableCAs.values());let l={...o.options,ca:c};o.updatedContext=kg.createSecureContext(l)}catch(c){cr.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),YF(s),Os.default.get(x.REPLICATION_ENABLEROOTCAS)!==!1&&s()}}function YF(e){let t=0;sd(r=>{r?.ca&&(gl.add(r.ca),gl.size!==t&&(t=gl.size,e?.()))})}function qie(e=!0){KF=e}function $ie(e){KF||(Xe(),Ba=e.databases,Da(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||Ha;for(let[s,i]of hp){let o=i.get(r);o&&(o.subscribe([],!1),i.delete(r))}n.delete(r);return}for(let n in t){let s=t[n];zF(r,s,e),gN.get(s)?.forEach(i=>i(s))}}))}function zF(e,t,r){if(!t)return console.error(`Attempt to replicate non-existent table ${t.name} from database ${e}`);if(t.replicate===!1||t.sources?.some(s=>s.isReplicator))return;let n;t.sourcedFrom(class WF extends $r{static{a(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||Ha,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(cr.trace("Setting up replicator subscription to database",e),!o?.auditStore)return this.subscription=o=new Bn,i.set(e,o),o.tableById=c,o.auditStore=t.auditStore,o.dbisDB=t.dbisDB,o.databaseName=e,l&&l(o),o;this.subscription=o}static subscribeOnThisThread(i,o){return!0}static async load(i){if(i){let o=i.residencyId,c=i.residency||t.dbisDB.get([Symbol.for("residency_by_id"),o]);if(c){let l,u=new Set;do{let f;for(let p of c){let _=Vie(p,WF.subscription,e);_?.isConnected&&!u.has(_)&&(!f||_.latency<f.latency)&&(f=_)}if(!f)throw l||new $F.ServerError("No connection to any other nodes are available",502);let d={requestId:kie++,table:t,entry:i,id:i.key};u.add(f);try{return await f.getRecord(d)}catch(p){if(f.isConnected)throw p;cr.warn("Error in load from node",Hg,p),l||(l=p)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function jF(e,t,r,n,s){let i=hp.get(e);i||hp.set(e,i=new Map);let o=i.get(r);if(o)return o;if(t)return i.set(r,o=new fp(e,t,r,n,s)),o.connect(),o.once("finished",()=>i.delete(r)),o}function Vie(e,t,r){let n=kF.get(e)?.get(r);if(n)return n;let s=or().primaryStore.get(e);return s?.url&&(n=jF(s.url,t,r,e,s.authorization),kF.set(e,hp.get(s.url))),n}async function mp(e,t,r){r||(r={}),r.serverName=e.name;let n=await Ug(e.url,r),s=_p(n,{},{});return new Promise((i,o)=>{n.on("open",()=>{i(s.sendOperation(t))}),n.on("error",c=>{o(c)}),n.on("close",c=>{cr.info("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function od(e){try{VF.isMainThread&&cr.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=Ha.get(e.database);if(!t){let n;t=new Promise(s=>{cr.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,Ha.set(e.database,t)}let r=jF(e.nodes[0].url,t,e.database,e.nodes[0].name,e.nodes[0].authorization);e.nodes[0].name===void 0?r.tentativeNode=e.nodes[0]:r.nodeName=e.nodes[0].name,r.subscribe(e.nodes.filter(n=>ap(n,e.database)),e.replicateByDefault)}catch(t){cr.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function Og({name:e,url:t,database:r}){cr.trace("Unsubscribing from node",e,t,r,"nodes",Array.from(or().primaryStore.getRange({})));let n=hp.get(t);if(n){let s=n.get(r);s&&(s.unsubscribe(),n.delete(r))}}function Kie(){if(RN!==void 0)return RN;let e=Os.default.get(x.OPERATIONSAPI_TLS_CERTIFICATE)||Os.default.get(x.TLS_CERTIFICATE);if(e)return RN=new GF.X509Certificate((0,qF.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function Ze(){return Hg||(Hg=Os.default.get("replication_hostname")??ai(Os.default.get("replication_url"))??Kie()??FF("operationsapi_network_secureport")??FF("operationsapi_network_port")??"127.0.0.1")}function Yie(){Hg=void 0}function FF(e){let t=Os.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function Bg(e){let t=Os.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function xg(e){return ip(e)?.[Ze()]}function La(){let e=Os.default.get("replication_url");return e||Fg(Ze())}function Fg(e){let t=Bg("replication_port");if(t)return`ws://${e}:${t}`;if(t=Bg("replication_secureport"),t)return`wss://${e}:${t}`;if(t=Bg("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=Bg("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function ai(e){if(e)return new URL(e).hostname}function Da(e,t){for(let n of Object.getOwnPropertyNames(qe))r(n);return pp(n=>{r(n)}),Tl((n,s)=>{r(n.databaseName)});function r(n){let s=qe[n];cr.trace("Checking replication status of ",n,e?.databases),e?.databases===void 0||e.databases==="*"||e.databases.includes(n)||e.databases.some?.(i=>i.name===n)||!s?t(s,n,!0):Wie(n)&&t(s,n,!1)}a(r,"forDatabase")}function Wie(e){let t=qe[e];for(let r in t)if(t[r].replicate)return!0}function op(e){for(let t of e.getKeys({limit:1,reverse:!0}))return t}async function zie(e){let t={message:""};if(e.replicated){e.replicated=!1,cr.trace?.("Replicating operation",e.operation,"to nodes",We.nodes.map(n=>n.name));let r=await Promise.allSettled(We.nodes.map(n=>mp(n,e)));t.replicated=r.map((n,s)=>{let i=n.status==="rejected"?{status:"failed",reason:n.reason.toString()}:n.value;return i.node=We.nodes[s]?.name,i})}return t}var Os,cr,GF,qF,kg,$F,VF,KF,kie,Fie,gl,Ba,hp,kF,RN,Hg,Xn=be(()=>{De();Ea();pu();SN();Vr();Os=M(ae()),cr=M(z()),GF=require("crypto"),qF=require("fs");lp();pl();H();zO();kg=M(require("node:tls")),$F=M(pe()),VF=require("worker_threads"),kie=1,Fie=[],gl=Os.default.get(x.REPLICATION_ENABLEROOTCAS)!==!1?new Set(kg.rootCertificates):new Set;a(Gie,"start");a(YF,"monitorNodeCAs");a(qie,"disableReplication");a($ie,"assignReplicationSource");a(zF,"setReplicator");hp=new Map;a(jF,"getConnection");kF=new Map;a(Vie,"getConnectionByName");a(mp,"sendOperationToNode");a(od,"subscribeToNode");a(Og,"unsubscribeFromNode");a(Kie,"getCommonNameFromCert");a(Ze,"getThisNodeName");a(Yie,"clearThisNodeName");Object.defineProperty(We,"hostname",{get(){return Ze()}});a(FF,"getHostFromListeningPort");a(Bg,"getPortFromListeningPort");a(xg,"getThisNodeId");We.replication={getThisNodeId:xg,exportIdMapping:ip};a(La,"getThisNodeUrl");a(Fg,"hostnameToUrl");a(ai,"urlToNodeName");a(Da,"forEachReplicatedDatabase");a(Wie,"hasExplicitlyReplicatedTable");a(op,"lastTimeInAuditStore");a(zie,"replicateOperation")});var Kg=w((lDe,eG)=>{"use strict";var fd=lk(),{validateBySchema:Ep}=ot(),{common_validators:_d,schema_regex:yN}=Di(),lr=require("joi"),jie=z(),Jie=require("uuid").v4,$g=To(),pd=(H(),C(G)),Qie=require("util"),ka=Vn(),{handleHDBError:Io,hdb_errors:Xie,ClientError:gp}=pe(),{HDB_ERROR_MSGS:Gg,HTTP_STATUS_CODES:Co}=Xie,{SchemaEventMsg:Vg}=ri(),JF=ir(),{getDatabases:Zie}=(De(),C(nt)),{transformReq:hd}=ie(),{replicateOperation:QF}=(Xn(),C(wo)),qg=lr.string().min(1).max(_d.schema_length.maximum).pattern(yN).messages({"string.pattern.base":"{:#label} "+_d.schema_format.message}),eoe=lr.string().min(1).max(_d.schema_length.maximum).pattern(yN).messages({"string.pattern.base":"{:#label} "+_d.schema_format.message}).required(),toe=lr.string().min(1).max(_d.schema_length.maximum).pattern(yN).messages({"string.pattern.base":"{:#label} "+_d.schema_format.message,"any.required":"'primary_key' is required","string.base":"'primary_key' must be a string"}).required();eG.exports={createSchema:roe,createSchemaStructure:XF,createTable:noe,createTableStructure:ZF,createAttribute:coe,dropSchema:soe,dropTable:ioe,dropAttribute:ooe,getBackup:loe};async function roe(e){let t=await XF(e);return $g.signalSchemaChange(new Vg(process.pid,e.operation,e.schema)),t}a(roe,"createSchema");async function XF(e){let t=Ep(e,lr.object({database:qg,schema:qg}));if(t)throw new gp(t.message);if(hd(e),!await fd.checkSchemaExists(e.schema))throw Io(new Error,Gg.SCHEMA_EXISTS_ERR(e.schema),Co.BAD_REQUEST,pd.LOG_LEVELS.ERROR,Gg.SCHEMA_EXISTS_ERR(e.schema),!0);return await ka.createSchema(e),`database '${e.schema}' successfully created`}a(XF,"createSchemaStructure");async function noe(e){return hd(e),e.hash_attribute=e.primary_key??e.hash_attribute,await ZF(e)}a(noe,"createTable");async function ZF(e){let t=Ep(e,lr.object({database:qg,schema:qg,table:eoe,residence:lr.array().items(lr.string().min(1)).optional(),hash_attribute:toe}));if(t)throw new gp(t.message);if(!await fd.checkSchemaTableExists(e.schema,e.table))throw Io(new Error,Gg.TABLE_EXISTS_ERR(e.schema,e.table),Co.BAD_REQUEST,pd.LOG_LEVELS.ERROR,Gg.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:Jie(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await ka.createTable(n,e);else throw Io(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Co.BAD_REQUEST);else await ka.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(ZF,"createTableStructure");async function soe(e){let t=Ep(e,lr.object({database:lr.string(),schema:lr.string()}).or("database","schema").messages({"object.missing":"'database' is required"}));if(t)throw new gp(t.message);hd(e);let r=await fd.checkSchemaExists(e.schema);if(r)throw Io(new Error,r,Co.NOT_FOUND,pd.LOG_LEVELS.ERROR,r,!0);let n=await fd.schema_describe.describeSchema({schema:e.schema}),s=Object.keys(global.hdb_schema[e.schema]);await ka.dropSchema(e),$g.signalSchemaChange(new Vg(process.pid,e.operation,e.schema)),await JF.purgeSchemaTableStreams(e.schema,s);let i=await QF(e);return i.message=`successfully deleted '${e.schema}'`,i}a(soe,"dropSchema");async function ioe(e){let t=Ep(e,lr.object({database:lr.string(),schema:lr.string(),table:lr.string().required()}));if(t)throw new gp(t.message);hd(e);let r=await fd.checkSchemaTableExists(e.schema,e.table);if(r)throw Io(new Error,r,Co.NOT_FOUND,pd.LOG_LEVELS.ERROR,r,!0);await ka.dropTable(e),await JF.purgeTableStream(e.schema,e.table);let n=await QF(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}a(ioe,"dropTable");async function ooe(e){let t=Ep(e,lr.object({database:lr.string(),schema:lr.string(),table:lr.string().required(),attribute:lr.string().required()}));if(t)throw new gp(t.message);hd(e);let r=await fd.checkSchemaTableExists(e.schema,e.table);if(r)throw Io(new Error,r,Co.NOT_FOUND,pd.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw Io(new Error,"You cannot drop a hash attribute",Co.BAD_REQUEST,void 0,void 0,!0);if(pd.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw Io(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Co.BAD_REQUEST,void 0,void 0,!0);try{return await ka.dropAttribute(e),aoe(e),$g.signalSchemaChange(new Vg(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw jie.error(`Got an error deleting attribute ${Qie.inspect(e)}.`),n}}a(ooe,"dropAttribute");function aoe(e){let t=Object.values(global.hdb_schema[e.schema][e.table].attributes);for(let r=0;r<t.length;r++)t[r].attribute===e.attribute&&global.hdb_schema[e.schema][e.table].attributes.splice(r,1)}a(aoe,"dropAttributeFromGlobal");async function coe(e){hd(e);let t=Zie()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw Io(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Co.BAD_REQUEST,void 0,void 0,!0);return await ka.createAttribute(e),$g.signalSchemaChange(new Vg(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(coe,"createAttribute");function loe(e){return ka.getBackup(e)}a(loe,"getBackup")});var rG=w((dDe,tG)=>{"use strict";var{OPERATIONS_ENUM:uoe}=(H(),C(G)),bN=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=uoe.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};tG.exports=bN});var ON=w((pDe,aG)=>{"use strict";var doe=Vn(),_De=rG(),Yg=ie(),Wg=(H(),C(G)),foe=ae(),{handleHDBError:nG,hdb_errors:_oe}=pe(),{HDB_ERROR_MSGS:sG,HTTP_STATUS_CODES:iG}=_oe,poe=Object.values(Wg.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),oG="To use this operation audit log must be enabled in harperdb-config.yaml";aG.exports=hoe;async function hoe(e){if(Yg.isEmpty(e.schema))throw new Error(sG.SCHEMA_REQUIRED_ERR);if(Yg.isEmpty(e.table))throw new Error(sG.TABLE_REQUIRED_ERR);if(!foe.get(Wg.CONFIG_PARAMS.LOGGING_AUDITLOG))throw nG(new Error,oG,iG.BAD_REQUEST,Wg.LOG_LEVELS.ERROR,oG,!0);let t=Yg.checkSchemaTableExist(e.schema,e.table);if(t)throw nG(new Error,t,iG.NOT_FOUND,Wg.LOG_LEVELS.ERROR,t,!0);if(!Yg.isEmpty(e.search_type)&&poe.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await doe.readAuditLog(e)}a(hoe,"readAuditLog")});var lG=w((mDe,cG)=>{"use strict";var{OPERATIONS_ENUM:moe}=(H(),C(G)),NN=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=moe.GET_BACKUP,this.schema=t,this.table=r}};cG.exports=NN});var fG=w((TDe,dG)=>{"use strict";var Eoe=Vn(),gDe=lG(),wN=ie(),goe=(H(),C(G)),SDe=ae(),{handleHDBError:Soe,hdb_errors:Toe}=pe(),{HDB_ERROR_MSGS:uG,HTTP_STATUS_CODES:Aoe}=Toe;dG.exports=Roe;async function Roe(e){if(wN.isEmpty(e.schema))throw new Error(uG.SCHEMA_REQUIRED_ERR);if(wN.isEmpty(e.table))throw new Error(uG.TABLE_REQUIRED_ERR);let t=wN.checkSchemaTableExist(e.schema,e.table);if(t)throw Soe(new Error,t,Aoe.NOT_FOUND,goe.LOG_LEVELS.ERROR,t,!0);return await Eoe.getBackup(read_audit_log_object)}a(Roe,"getBackup")});var mG=w((RDe,hG)=>{"use strict";var yoe=ae(),Fa=require("joi"),boe=ot(),_G=require("moment"),Ooe=require("fs-extra"),IN=require("path"),Noe=require("lodash"),Sp=(H(),C(G)),{LOG_LEVELS:Al}=(H(),C(G)),woe="YYYY-MM-DD hh:mm:ss",Ioe=IN.resolve(__dirname,"../logs");hG.exports=function(e){return boe.validateBySchema(e,Coe)};var Coe=Fa.object({from:Fa.custom(pG),until:Fa.custom(pG),level:Fa.valid(Al.NOTIFY,Al.FATAL,Al.ERROR,Al.WARN,Al.INFO,Al.DEBUG,Al.TRACE),order:Fa.valid("asc","desc"),limit:Fa.number().min(1),start:Fa.number().min(0),log_name:Fa.custom(Poe)});function pG(e,t){if(_G(e,_G.ISO_8601).format(woe)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(pG,"validateDatetime");function Poe(e,t){if(Noe.invert(Sp.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=yoe.get(Sp.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?Sp.LOG_NAMES.HDB:e,i=s===Sp.LOG_NAMES.INSTALL?IN.join(Ioe,Sp.LOG_NAMES.INSTALL):IN.join(n,s);return Ooe.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(Poe,"validateReadLogPath")});var PN=w((bDe,gG)=>{"use strict";var zg=(H(),C(G)),Doe=z(),Loe=ae(),Moe=mG(),CN=require("path"),EG=require("fs-extra"),{once:voe}=require("events"),{handleHDBError:Uoe,hdb_errors:xoe}=pe(),{PACKAGE_ROOT:Boe}=it(),Hoe=CN.join(Boe,"logs"),koe=1e3,Foe=200;gG.exports=Goe;async function Goe(e){let t=Moe(e);if(t)throw Uoe(t,t.message,xoe.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=Loe.get(zg.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?zg.LOG_NAMES.HDB:e.log_name,s=n===zg.LOG_NAMES.INSTALL?CN.join(Hoe,zg.LOG_NAMES.INSTALL):CN.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,l=c?new Date(e.from):void 0,u=e.until!==void 0,f=u?new Date(e.until):void 0,d=e.limit===void 0?koe:e.limit,p=e.order===void 0?void 0:e.order,_=e.start===void 0?0:e.start,h=_+d,S=0;p==="desc"&&!l&&!f&&(S=Math.max(EG.statSync(s).size-(h+5)*Foe,0));let g=EG.createReadStream(s,{start:S});g.on("error",F=>{Doe.error(F)});let R=0,E=[],T="",b;g.on("data",F=>{let q=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;F=T+F;let Y=0,Z;for(;(Z=q.exec(F))&&!g.destroyed;){b&&(b.message=F.slice(Y,Z.index),v(b));let[se,Q,ne]=Z,J=ne.split("] ["),me=J[0],ye=J[1];J.splice(0,2),b={timestamp:Q,thread:me,level:ye,tags:J,message:""},Y=Z.index+se.length}T=F.slice(Y)}),g.on("end",F=>{g.destroyed||b&&(b.message=T.trim(),v(b))}),g.resume();function v(F){let q,Y,Z;switch(!0){case(i&&c&&u):q=new Date(F.timestamp),Y=new Date(l),Z=new Date(f),F.level===o&&q>=Y&&q<=Z&&R<_?R++:F.level===o&&q>=Y&&q<=Z&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case(i&&c):q=new Date(F.timestamp),Y=new Date(l),F.level===o&&q>=Y&&R<_?R++:F.level===o&&q>=Y&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case(i&&u):q=new Date(F.timestamp),Z=new Date(f),F.level===o&&q<=Z&&R<_?R++:F.level===o&&q<=Z&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case(c&&u):q=new Date(F.timestamp),Y=new Date(l),Z=new Date(f),q>=Y&&q<=Z&&R<_?R++:q>=Y&&q<=Z&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case i:F.level===o&&R<_?R++:F.level===o&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case c:q=new Date(F.timestamp),Y=new Date(l),q>=Y&&R<_?R++:q>=Y&&R>=_&&(Ga(F,p,E),R++,R===h&&g.destroy());break;case u:q=new Date(F.timestamp),Z=new Date(f),q<=Z&&R<_?R++:q<=Z&&R>=_&&(Ga(F,p,E),R++,R===h&&g.destroy());break;default:R<_?R++:(Ga(F,p,E),R++,R===h&&g.destroy())}}return a(v,"onLogMessage"),await voe(g,"close"),E}a(Goe,"readLog");function Ga(e,t,r){t==="desc"?qoe(e,r):t==="asc"?$oe(e,r):r.push(e)}a(Ga,"pushLineToResult");function qoe(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)>r?n=i+1:s=i}t.splice(n,0,e)}a(qoe,"insertDescending");function $oe(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)<r?n=i+1:s=i}t.splice(n,0,e)}a($oe,"insertAscending")});var jg=w((PDe,RG)=>{"use strict";var DN=require("joi"),{string:md,boolean:SG,date:Voe}=DN.types(),Koe=ot(),{validateSchemaExists:NDe,validateTableExists:wDe,validateSchemaName:IDe}=Di(),Yoe=(H(),C(G)),Woe=Tt(),TG=ae();TG.initSync();var CDe=md.invalid(TG.get(Yoe.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(Woe.NATS_TERM_CONSTRAINTS_RX).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >","any.invalid":"'node_name' cannot be this nodes name"}).empty(null),AG={operation:md.valid("add_node","update_node","set_node_replication"),node_name:md.optional(),subscriptions:DN.array().items({table:md.optional(),schema:md.optional(),database:md.optional(),subscribe:SG.required(),publish:SG.required().custom(joe),start_time:Voe.iso()})};function zoe(e){return Koe.validateBySchema(e,DN.object(AG))}a(zoe,"addUpdateNodeValidator");function joe(e,t){if(t.state.ancestors[2].operation==="add_node"&&e===!1&&t.state.ancestors[0].subscribe===!1)return t.message(`'subscriptions[${t.state.path[1]}]' subscribe and/or publish must be set to true when adding a node`)}a(joe,"checkForFalsy");RG.exports={addUpdateNodeValidator:zoe,validation_schema:AG}});var Ed=w((LDe,yG)=>{"use strict";var LN=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},MN=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};yG.exports={Node:LN,NodeSubscription:MN}});var OG=w((vDe,bG)=>{"use strict";var Joe=(H(),C(G)).OPERATIONS_ENUM,vN=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Joe.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};bG.exports=vN});var Tp=w((xDe,NG)=>{"use strict";var UN=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},xN=class{static{a(this,"RemotePayloadSubscription")}constructor(t,r,n,s,i,o,c){this.schema=t,this.table=r,this.hash_attribute=n,this.publish=s,this.subscribe=i,this.start_time=o,c!==void 0&&(this.attributes=c)}};NG.exports={RemotePayloadObject:UN,RemotePayloadSubscription:xN}});var IG=w((HDe,wG)=>{"use strict";var BN=class{static{a(this,"TableSizeObject")}constructor(t,r,n=0,s=0,i=0,o=0){this.schema=t,this.table=r,this.table_size=n,this.record_count=s,this.transaction_log_size=i,this.transaction_log_record_count=o}};wG.exports=BN});var PG=w((VDe,CG)=>{"use strict";var Qoe=IG(),FDe=xt(),GDe=_t(),Xoe=z(),{getSchemaPath:qDe,getTransactionAuditStorePath:$De}=gt(),{getDatabases:Zoe}=(De(),C(nt));CG.exports=eae;async function eae(e){let t=new Qoe;try{let r=Zoe()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats();t.schema=e.schema,t.table=e.name,t.record_count=n.entryCount,t.transaction_log_record_count=s.entryCount}catch(r){Xoe.warn(`unable to stat table dbi due to ${r}`)}return t}a(eae,"lmdbGetTableSize")});var LG=w((YDe,DG)=>{"use strict";var HN=class{static{a(this,"SystemInformationObject")}constructor(t,r,n,s,i,o,c){this.system=t,this.time=r,this.cpu=n,this.memory=s,this.disk=i,this.network=o,this.harperdb_processes=c}};DG.exports=HN});var Po=w((XDe,xG)=>{"use strict";var tae=require("fs-extra"),rae=require("path"),Xr=require("systeminformation"),qa=z(),MG=ir(),zDe=Tt(),gd=(H(),C(G)),nae=PG(),sae=go(),{getThreadInfo:vG}=rt(),Ap=ae();Ap.initSync();var iae=LG(),{openEnvironment:jDe}=_t(),{getSchemaPath:JDe}=gt(),{database:QDe,databases:kN}=(De(),C(nt)),Jg;xG.exports={getHDBProcessInfo:$N,getNetworkInfo:KN,getDiskInfo:VN,getMemoryInfo:qN,getCPUInfo:GN,getTimeInfo:FN,getSystemInformation:YN,systemInformation:oae,getTableSize:WN,getMetrics:zN};function FN(){return Xr.time()}a(FN,"getTimeInfo");async function GN(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:u,...f}=await Xr.cpu();f.cpu_speed=await Xr.cpuCurrentSpeed();let{raw_currentload:d,raw_currentload_idle:p,raw_currentload_irq:_,raw_currentload_nice:h,raw_currentload_system:S,raw_currentload_user:g,cpus:R,...E}=await Xr.currentLoad();return E.cpus=[],R.forEach(T=>{let{raw_load:b,raw_load_idle:v,raw_load_irq:F,raw_load_nice:q,raw_load_system:Y,raw_load_user:Z,...se}=T;E.cpus.push(se)}),f.current_load=E,f}catch(e){return qa.error(`error in getCPUInfo: ${e}`),{}}}a(GN,"getCPUInfo");async function qN(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Xr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return qa.error(`error in getMemoryInfo: ${e}`),{}}}a(qN,"getMemoryInfo");async function $N(){let e={core:[],clustering:[]};try{let t=await Xr.processes(),r;try{r=Number.parseInt(await tae.readFile(rae.join(Ap.get(gd.CONFIG_PARAMS.ROOTPATH),gd.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===gd.NODE_ERROR_CODES.ENOENT)qa.warn("Unable to locate 'hdb.pid' file, try stopping and starting HarperDB. This could be because HarperDB is not running.");else throw n}t.list.forEach(n=>{n.pid===r?e.core.push(n):n.name==="nats-server"&&e.clustering.push(n)});for(let n of e.core)for(let s of t.list)s.pid===n.parentPid&&(s.name==="PM2"||s.command==="PM2")&&(n.parent="PM2");return e}catch(t){return qa.error(`error in getHDBProcessInfo: ${t}`),e}}a($N,"getHDBProcessInfo");async function VN(){let e={};try{if(!Ap.get(gd.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Xr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...u}=await Xr.fsStats();return e.read_write=u,e.size=await Xr.fsSize(),e}catch(t){return qa.error(`error in getDiskInfo: ${t}`),e}}a(VN,"getDiskInfo");async function KN(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return Ap.get(gd.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await Xr.networkInterfaceDefault(),e.latency=await Xr.inetChecksite("google.com"),(await Xr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:u,ieee8021xState:f,carrier_changes:d,...p}=n;e.interfaces.push(p)}),(await Xr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)})),e}catch(t){return qa.error(`error in getNetworkInfo: ${t}`),e}}a(KN,"getNetworkInfo");async function YN(){if(Jg!==void 0)return Jg;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Xr.osInfo();e=c;let l=await Xr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,Jg=e,Jg}catch(t){return qa.error(`error in getSystemInformation: ${t}`),e}}a(YN,"getSystemInformation");async function WN(){let e=[],t=await sae.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await nae(n));return e}a(WN,"getTableSize");async function zN(){let e={};for(let t in kN){let r=e[t]={},n=r.tables={};for(let s in kN[t])try{let i=kN[t][s];if(!r.readers&&(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[u,f,d]=l.trim().split(" ");return{pid:u,thread:f,txnid:d}}),i.auditStore)){let{treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:f,entryCount:d,overflowPages:p}=i.auditStore.getStats();r.audit={treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:f,entryCount:d,overflowPages:p}}let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){qa.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(zN,"getMetrics");async function UG(){if(Ap.get(gd.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await MG.getNATSReferences(),t=await MG.listStreams(),r=[];for(let n of t){let s=[],i=await e.consumers.list(n.config.name);for await(let c of i)s.push({name:c.name,created:c.created,num_ack_pending:c.num_ack_pending,num_redelivered:c.num_redelivered,num_waiting:c.num_waiting,num_pending:c.num_pending});let o={stream_name:n.config.name,database:n.config.subjects[0].split(".")[1],table:n.config.subjects[0].split(".")[2],state:n.state,consumers:s};r.push(o)}return r}}a(UG,"getNatsStreamInfo");async function oae(e){let t=new iae;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await YN(),t.time=FN(),t.cpu=await GN(),t.memory=await qN(),t.disk=await VN(),t.network=await KN(),t.harperdb_processes=await $N(),t.table_size=await WN(),t.metrics=await zN(),t.threads=await vG(),t.replication=await UG(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await YN();break;case"time":t.time=FN();break;case"cpu":t.cpu=await GN();break;case"memory":t.memory=await qN();break;case"disk":t.disk=await VN();break;case"network":t.network=await KN();break;case"harperdb_processes":t.harperdb_processes=await $N();break;case"table_size":t.table_size=await WN();break;case"database_metrics":case"metrics":t.metrics=await zN();break;case"threads":t.threads=await vG();break;case"replication":t.replication=await UG();break;default:break}return t}a(oae,"systemInformation")});var Do=w((rLe,FG)=>{"use strict";var aae=yn(),jN=ie(),cae=require("util"),Rl=(H(),C(G)),BG=ae();BG.initSync();var lae=wO(),HG=Yr(),{Node:eLe,NodeSubscription:tLe}=Ed(),uae=Fu(),dae=OG(),{RemotePayloadObject:fae,RemotePayloadSubscription:_ae}=Tp(),{handleHDBError:pae,hdb_errors:hae}=pe(),{HTTP_STATUS_CODES:mae,HDB_ERROR_MSGS:Eae}=hae,gae=ni(),Sae=Po(),{packageJson:Tae}=it(),{getDatabases:Aae}=(De(),C(nt)),Rae=cae.promisify(lae.authorize),yae=HG.searchByHash,bae=HG.searchByValue;FG.exports={authHeaderToUser:Oae,isEmpty:Nae,getNodeRecord:wae,upsertNodeRecord:Iae,buildNodePayloads:Cae,checkClusteringEnabled:Pae,getAllNodeRecords:Dae,getSystemInfo:Lae,reverseSubscription:kG};async function Oae(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await Rae(t,null),e}a(Oae,"authHeaderToUser");function Nae(e){return e==null}a(Nae,"isEmpty");async function wae(e){let t=new uae(Rl.SYSTEM_SCHEMA_NAME,Rl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return yae(t)}a(wae,"getNodeRecord");async function Iae(e){let t=new dae(Rl.SYSTEM_SCHEMA_NAME,Rl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return aae.upsert(t)}a(Iae,"upsertNodeRecord");function kG(e){if(jN.isEmpty(e.subscribe)||jN.isEmpty(e.publish))throw new Error("Received invalid subscription object");let{schema:t,table:r,hash_attribute:n}=e,s={schema:t,table:r,hash_attribute:n};return e.subscribe===!0&&e.publish===!1?(s.subscribe=!1,s.publish=!0):e.subscribe===!1&&e.publish===!0?(s.subscribe=!0,s.publish=!1):(s.subscribe=e.subscribe,s.publish=e.publish),s}a(kG,"reverseSubscription");function Cae(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:u}=c,f=jN.getTableHashAttribute(l,u),{subscribe:d,publish:p}=kG(c),_=Aae()[l]?.[u],h=new _ae(l,u,f,p,d,c.start_time,_.schemaDefined?_.attributes:void 0);s.push(h)}return new fae(r,t,s,n)}a(Cae,"buildNodePayloads");function Pae(){if(!BG.get(Rl.CONFIG_PARAMS.CLUSTERING_ENABLED))throw pae(new Error,Eae.CLUSTERING_NOT_ENABLED,mae.BAD_REQUEST,void 0,void 0,!0)}a(Pae,"checkClusteringEnabled");async function Dae(){let e=new gae(Rl.SYSTEM_SCHEMA_NAME,Rl.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await bae(e))}a(Dae,"getAllNodeRecords");async function Lae(){let e=await Sae.getSystemInformation();return{hdb_version:Tae.version,node_version:e.node_version,platform:e.platform}}a(Lae,"getSystemInfo")});var JN=w((sLe,zG)=>{"use strict";var Qg=ir(),GG=ie(),qG=Tt(),$G=(H(),C(G)),Xg=z(),VG=Kg(),Mae=v_(),{RemotePayloadObject:vae}=Tp(),{handleHDBError:KG,hdb_errors:Uae}=pe(),{HTTP_STATUS_CODES:YG}=Uae,{NodeSubscription:WG}=Ed();zG.exports=xae;async function xae(e,t){let r;try{r=await Qg.request(`${t}.${qG.REQUEST_SUFFIX}`,new vae($G.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),Xg.trace("Response from remote describe all request:",r)}catch(o){Xg.error(`addNode received error from describe all request to remote node: ${o}`);let c=Qg.requestErrorHandler(o,"add_node",t);throw KG(new Error,c,YG.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===qG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw KG(new Error,o,YG.INTERNAL_SERVER_ERROR,"error",o)}let n=r.message,s=[],i=[];for(let o of e){let{table:c}=o,l=o.database??o.schema??"data";if(l===$G.SYSTEM_SCHEMA_NAME){await Qg.createLocalTableStream(l,c);let h=new WG(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let u=GG.doesSchemaExist(l),f=n[l]!==void 0,d=c?GG.doesTableExist(l,c):!0,p=c?n?.[l]?.[c]!==void 0:!0;if(!u&&!f||!d&&!p){s.push(o);continue}if(!u&&f&&(Xg.trace(`addNode creating schema: ${l}`),await VG.createSchema({operation:"create_schema",schema:l})),!d&&p){Xg.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new Mae(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await VG.createTable(h)}await Qg.createLocalTableStream(l,c);let _=new WG(l,c,o.publish,o.subscribe);_.start_time=o.start_time,i.push(_)}return{added:i,skipped:s}}a(xae,"reviewSubscriptions")});var yl={};ve(yl,{addNodeBack:()=>Gae,removeNodeBack:()=>qae,setNode:()=>Fae});async function Fae(e){e.node_name&&!e.hostname&&(e.hostname=e.node_name),e.verify_tls!==void 0&&(e.rejectUnauthorized=e.verify_tls);let{url:t,hostname:r}=e;t?r||(r=e.hostname=ai(t)):t=Fg(r);let n=(0,JG.validateBySchema)(e,kae);if(n)throw(0,Lo.handleHDBError)(n,n.message,Hae.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new Lo.ClientError("url or hostname is required for remove_node operation");let _=r,h=or(),S=await h.get(_);if(!S)throw new Lo.ClientError(_+" does not exist");try{await mp({url:S.url},{operation:Yt.REMOVE_NODE_BACK,name:S?.subscriptions?.length>0?Ze():_},void 0)}catch(g){es.warn(`Error removing node from target node ${_}, if it is offline and we be online in the future, you may need to clean up this node manually, or retry:`,g)}return await h.delete(_),`Successfully removed '${_}' from cluster`}if(!t)throw new Lo.ClientError("url required for this operation");let s=La();if(s==null)throw new Lo.ClientError("replication url is missing from harperdb-config.yaml");let i,o,c;if(t?.startsWith("wss:")){i=await(0,Ns.getReplicationCert)();let _=await(0,Ns.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,Ns.createCsr)(),es.info("Sending CSR to target node:",t)):_&&(c=_.certificate,es.info("Sending CA named",_.name,"to target node",t))}let l={operation:Yt.ADD_NODE_BACK,hostname:(0,Va.get)(x.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:o,cert_auth:c,authorization:e.retain_authorization?e.authorization:null};if((0,Va.get)(x.REPLICATION_SHARD)!==void 0&&(l.shard=(0,Va.get)(x.REPLICATION_SHARD)),e.subscriptions?l.subscriptions=e.subscriptions.map(jG):l.subscriptions=null,e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let _=jG(e);l.subscribe=_.subscribe,l.publish=_.publish}e?.authorization?.username&&e?.authorization?.password&&(e.authorization="Basic "+Buffer.from(e.authorization.username+":"+e.authorization.password).toString("base64"));let u,f;try{u=await mp({url:t},l,e)}catch(_){_.message=`Error returned from ${t}: `+_.message,es.warn("Error adding node:",t,"to cluster:",_),f=_}if(o&&(!u?.certificate||!u?.certificate?.includes?.("BEGIN CERTIFICATE")))throw f?(f.message+=" and connection was required to sign certificate",f):new Error(`Unexpected certificate signature response from node ${t} response: ${JSON.stringify(u)}`);o&&(es.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,Ns.setCertTable)({name:Bae.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,Ns.setCertTable)({name:Ze(),uses:["https","operations","wss"],certificate:u.certificate,private_key_name:i?.options?.key_file,is_authority:!1,is_self_signed:!1}),c=u.signingCA);let d={url:t,ca:u?.usingCA};if(e.hostname&&(d.name=e.hostname),e.subscriptions?d.subscriptions=e.subscriptions:d.replicates=!0,e.start_time&&(d.start_time=typeof e.start_time=="string"?new Date(e.start_time).getTime():e.start_time),e.retain_authorization&&(d.authorization=e.authorization),e.revoked_certificates&&(d.revoked_certificates=e.revoked_certificates),e.shard!==void 0&&(d.shard=e.shard),d.replicates){let _={url:s,ca:c,replicates:!0,subscriptions:null};(0,Va.get)(x.REPLICATION_SHARD)!==void 0&&(_.shard=(0,Va.get)(x.REPLICATION_SHARD)),e.retain_authorization&&(_.authorization=e.authorization),e.start_time&&(_.start_time=e.start_time),await Oo(Ze(),_)}await Oo(u?u.nodeName:d.name??ai(t),d);let p;return e.operation==="update_node"?p=`Successfully updated '${t}'`:p=`Successfully added '${t}' to cluster`,f&&(p+=" but there was an error updating target node: "+f.message),p}async function Gae(e){es.trace("addNodeBack received request:",e);let t=await(0,Ns.signCertificate)(e),r;e.csr?(r=t.signingCA,es.info("addNodeBack received CSR from node:",e.url,"this node will use and respond with CA that was used to issue CSR")):(r=e?.cert_auth,es.info("addNodeBack received CA from node:",e.url));let n={url:e.url,ca:r};e.subscriptions?n.subscriptions=e.subscriptions:(n.replicates=!0,n.subscriptions=null),e.start_time&&(n.start_time=e.start_time),e.authorization&&(n.authorization=e.authorization),e.shard!==void 0&&(n.shard=e.shard);let s=await(0,Ns.getReplicationCertAuth)();if(n.replicates){let i={url:La(),ca:s?.certificate,replicates:!0,subscriptions:null};(0,Va.get)(x.REPLICATION_SHARD)!==void 0&&(i.shard=(0,Va.get)(x.REPLICATION_SHARD)),e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await Oo(Ze(),i)}return await Oo(e.hostname,n),t.nodeName=Ze(),t.usingCA=s?.certificate,es.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function qae(e){es.trace("removeNodeBack received request:",e),await or().delete(e.name)}function jG(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var Ns,JG,$a,Va,es,Lo,Bae,Hae,kae,bl=be(()=>{Ns=M(Zn()),JG=M(ot()),$a=M(require("joi")),Va=M(ae());H();lp();pl();Xn();es=M(z()),Lo=M(pe()),{pki:Bae}=require("node-forge"),{HTTP_STATUS_CODES:Hae}=Lo.hdb_errors,kae=$a.default.object({hostname:$a.default.string(),verify_tls:$a.default.boolean(),replicates:$a.default.boolean(),subscriptions:$a.default.array(),revoked_certificates:$a.default.array(),shard:$a.default.number()});a(Fae,"setNode");a(Gae,"addNodeBack");a(qae,"removeNodeBack");a(jG,"reverseSubscription")});var Sd=w((_Le,XG)=>{"use strict";var{handleHDBError:Zg,hdb_errors:$ae}=pe(),{HTTP_STATUS_CODES:eS}=$ae,{addUpdateNodeValidator:Vae}=jg(),tS=z(),rS=(H(),C(G)),QG=Tt(),Kae=ie(),Rp=ir(),yp=Do(),QN=ae(),Yae=JN(),{Node:Wae,NodeSubscription:zae}=Ed(),{broadcast:jae}=rt(),{setNode:Jae}=(bl(),C(yl)),dLe=ae(),fLe=(H(),C(G)),Qae="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",Xae="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Zae=QN.get(rS.CONFIG_PARAMS.CLUSTERING_NODENAME);XG.exports=ece;async function ece(e,t=!1){if(tS.trace("addNode called with:",e),QN.get(rS.CONFIG_PARAMS.REPLICATION_URL)||QN.get(rS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Jae(e);yp.checkClusteringEnabled();let r=Vae(e);if(r)throw Zg(r,r.message,eS.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await yp.getNodeRecord(n);if(!Kae.isEmptyOrZeroLength(d))throw Zg(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,eS.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await Yae(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=Qae,o;let c=yp.buildNodePayloads(s,Zae,rS.OPERATIONS_ENUM.ADD_NODE,await yp.getSystemInfo()),l=[];for(let d=0,p=s.length;d<p;d++){let _=s[d];s[d].start_time===void 0&&delete s[d].start_time,l.push(new zae(_.schema,_.table,_.publish,_.subscribe))}tS.trace("addNode sending remote payload:",c);let u;try{u=await Rp.request(`${n}.${QG.REQUEST_SUFFIX}`,c)}catch(d){tS.error(`addNode received error from request: ${d}`);for(let _=0,h=s.length;_<h;_++){let S=s[_];S.publish=!1,S.subscribe=!1,await Rp.updateRemoteConsumer(S,n)}let p=Rp.requestErrorHandler(d,"add_node",n);throw Zg(new Error,p,eS.INTERNAL_SERVER_ERROR,"error",p)}if(u.status===QG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${n}: ${u.message}`;throw Zg(new Error,d,eS.INTERNAL_SERVER_ERROR,"error",d)}tS.trace(u);for(let d=0,p=s.length;d<p;d++){let _=s[d];await Rp.updateRemoteConsumer(_,n),_.subscribe===!0&&await Rp.updateConsumerIterator(_.schema,_.table,n,"start")}let f=new Wae(n,l,u.system_info);return await yp.upsertNodeRecord(f),jae({type:"nats_update"}),i.length>0?o.message=Xae:o.message=`Successfully added '${n}' to manifest`,o}a(ece,"addNode")});var tw=w((mLe,eq)=>{"use strict";var{handleHDBError:XN,hdb_errors:tce}=pe(),{HTTP_STATUS_CODES:ZN}=tce,{addUpdateNodeValidator:rce}=jg(),bp=z(),nS=(H(),C(G)),ZG=Tt(),hLe=ie(),Op=ir(),Np=Do(),ew=ae(),{cloneDeep:nce}=require("lodash"),sce=JN(),{Node:ice,NodeSubscription:oce}=Ed(),{broadcast:ace}=rt(),{setNode:cce}=(bl(),C(yl)),lce="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",uce="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",dce=ew.get(nS.CONFIG_PARAMS.CLUSTERING_NODENAME);eq.exports=fce;async function fce(e){if(bp.trace("updateNode called with:",e),ew.get(nS.CONFIG_PARAMS.REPLICATION_URL)??ew.get(nS.CONFIG_PARAMS.REPLICATION_HOSTNAME))return cce(e);Np.checkClusteringEnabled();let t=rce(e);if(t)throw XN(t,t.message,ZN.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Np.getNodeRecord(r);s.length>0&&(n=nce(s));let{added:i,skipped:o}=await sce(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=lce,c;let l=Np.buildNodePayloads(i,dce,nS.OPERATIONS_ENUM.UPDATE_NODE,await Np.getSystemInfo());for(let f=0,d=i.length;f<d;f++){let p=i[f];bp.trace(`updateNode updating work stream for node: ${r} subscription:`,p),i[f].start_time===void 0&&delete i[f].start_time}bp.trace("updateNode sending remote payload:",l);let u;try{u=await Op.request(`${r}.${ZG.REQUEST_SUFFIX}`,l)}catch(f){bp.error(`updateNode received error from request: ${f}`);let d=Op.requestErrorHandler(f,"update_node",r);throw XN(new Error,d,ZN.INTERNAL_SERVER_ERROR,"error",d)}if(u.status===ZG.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let f=`Error returned from remote node ${r}: ${u.message}`;throw XN(new Error,f,ZN.INTERNAL_SERVER_ERROR,"error",f)}bp.trace(u);for(let f=0,d=i.length;f<d;f++){let p=i[f];await Op.updateRemoteConsumer(p,r),p.subscribe===!0?await Op.updateConsumerIterator(p.schema,p.table,r,"start"):await Op.updateConsumerIterator(p.schema,p.table,r,"stop")}return n||(n=[new ice(r,[],u.system_info)]),await _ce(n[0],i,u.system_info),o.length>0?c.message=uce:c.message=`Successfully updated '${r}'`,c}a(fce,"updateNode");async function _ce(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let l=0,u=e.subscriptions.length;l<u;l++){let f=n.subscriptions[l];if(f.schema===o.schema&&f.table===o.table){f.publish=o.publish,f.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new oce(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await Np.upsertNodeRecord(n),ace({type:"nats_update"})}a(_ce,"updateNodeTable")});var iq=w((gLe,sq)=>{"use strict";var nq=require("joi"),{string:tq}=nq.types(),pce=ot(),rq=(H(),C(G)),hce=ae(),mce=Tt();sq.exports=Ece;function Ece(e){let t=tq.invalid(hce.get(rq.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(mce.NATS_TERM_CONSTRAINTS_RX).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >","any.invalid":"'node_name' cannot be this nodes name"}).empty(null),r=nq.object({operation:tq.valid(rq.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return pce.validateBySchema(e,r)}a(Ece,"removeNodeValidator")});var sS=w((TLe,uq)=>{"use strict";var{handleHDBError:oq,hdb_errors:gce}=pe(),{HTTP_STATUS_CODES:aq}=gce,Sce=iq(),wp=z(),cq=Do(),Tce=ie(),Td=(H(),C(G)),lq=Tt(),rw=ir(),nw=ae(),{RemotePayloadObject:Ace}=Tp(),{NodeSubscription:Rce}=Ed(),yce=M_(),bce=zc(),{broadcast:Oce}=rt(),{setNode:Nce}=(bl(),C(yl)),wce=nw.get(Td.CONFIG_PARAMS.CLUSTERING_NODENAME);uq.exports=Ice;async function Ice(e){if(wp.trace("removeNode called with:",e),nw.get(Td.CONFIG_PARAMS.REPLICATION_URL)??nw.get(Td.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Nce(e);cq.checkClusteringEnabled();let t=Sce(e);if(t)throw oq(t,t.message,aq.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await cq.getNodeRecord(r);if(Tce.isEmptyOrZeroLength(n))throw oq(new Error,`Node '${r}' was not found.`,aq.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new Ace(Td.OPERATIONS_ENUM.REMOVE_NODE,wce,[]),i,o=!1;for(let l=0,u=n.subscriptions.length;l<u;l++){let f=n.subscriptions[l];f.subscribe===!0&&await rw.updateConsumerIterator(f.schema,f.table,r,"stop");try{await rw.updateRemoteConsumer(new Rce(f.schema,f.table,!1,!1),r)}catch(d){wp.error(d)}}try{i=await rw.request(`${r}.${lq.REQUEST_SUFFIX}`,s),wp.trace("Remove node reply from remote node:",r,i)}catch(l){wp.error("removeNode received error from request:",l),o=!0}let c=new yce(Td.SYSTEM_SCHEMA_NAME,Td.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await bce.deleteRecord(c),Oce({type:"nats_update"}),i?.status===lq.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(wp.error("Error returned from remote node:",r,i?.message),`Successfully removed '${r}' from local manifest, however there was an error reaching remote node. Check the logs for more details.`):`Successfully removed '${r}' from manifest`}a(Ice,"removeNode")});var _q=w((RLe,fq)=>{"use strict";var dq=require("joi"),{string:Cce,array:Pce}=dq.types(),Dce=ot(),Lce=jg();fq.exports=Mce;function Mce(e){let t=dq.object({operation:Cce.valid("configure_cluster").required(),connections:Pce.items(Lce.validation_schema).required()});return Dce.validateBySchema(e,t)}a(Mce,"configureClusterValidator")});var sw=w((bLe,gq)=>{"use strict";var pq=(H(),C(G)),iS=z(),vce=ie(),Uce=ae(),xce=sS(),Bce=Sd(),Hce=Do(),kce=_q(),{handleHDBError:hq,hdb_errors:Fce}=pe(),{HTTP_STATUS_CODES:mq}=Fce,Gce="Configure cluster complete.",qce="Failed to configure the cluster. Check the logs for more details.",$ce="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";gq.exports=Vce;async function Vce(e){iS.trace("configure cluster called with:",e);let t=kce(e);if(t)throw hq(t,t.message,mq.BAD_REQUEST,void 0,void 0,!0);let r=await Hce.getAllNodeRecords(),n=[];if(Uce.get(pq.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let f=0,d=r.length;f<d;f++){let p=await Eq(xce,{operation:pq.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[f].name},r[f].name);n.push(p)}iS.trace("All results from configure_cluster remove node:",n)}let s=[],i=e.connections.length;for(let f=0;f<i;f++){let d=e.connections[f],p=await Eq(Bce,d,d.node_name);s.push(p)}iS.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,u=n.concat(s);for(let f=0,d=u.length;f<d;f++){let p=u[f];p.status==="rejected"&&(iS.error(p.node_name,p?.error?.message,p?.error?.stack),o.includes(p.node_name)||o.push(p.node_name)),(p?.result?.message?.includes?.("Successfully")||p?.result?.includes?.("Successfully"))&&(l=!0),!(typeof p.result=="string"&&p.result.includes("Successfully removed")||p.status==="rejected")&&c.push({node_name:p?.node_name,response:p?.result})}if(vce.isEmptyOrZeroLength(o))return{message:Gce,connections:c};if(l)return{message:$ce,failed_nodes:o,connections:c};throw hq(new Error,qce,mq.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(Vce,"configureCluster");async function Eq(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(Eq,"functionWrapper")});var Rq=w((NLe,Aq)=>{"use strict";var Ip=require("joi"),Kce=ot(),{validateSchemaExists:Sq,validateTableExists:Yce,validateSchemaName:Tq}=Di(),Wce=Ip.object({operation:Ip.string().valid("purge_stream"),schema:Ip.string().custom(Sq).custom(Tq).optional(),database:Ip.string().custom(Sq).custom(Tq).optional(),table:Ip.string().custom(Yce).required()});function zce(e){return Kce.validateBySchema(e,Wce)}a(zce,"purgeStreamValidator");Aq.exports=zce});var iw=w((ILe,yq)=>{"use strict";var{handleHDBError:jce,hdb_errors:Jce}=pe(),{HTTP_STATUS_CODES:Qce}=Jce,Xce=Rq(),Zce=ir(),ele=Do();yq.exports=tle;async function tle(e){e.schema=e.schema??e.database;let t=Xce(e);if(t)throw jce(t,t.message,Qce.BAD_REQUEST,void 0,void 0,!0);ele.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await Zce.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(tle,"purgeStream")});var cS=w((PLe,Pq)=>{"use strict";var aw=Do(),rle=ir(),aS=ae(),Ad=(H(),C(G)),Ol=Tt(),nle=ie(),ow=z(),{RemotePayloadObject:sle}=Tp(),{ErrorCode:bq}=require("nats"),{parentPort:Oq}=require("worker_threads"),{onMessageByType:ile}=rt(),{getThisNodeName:ole}=(Xn(),C(wo)),{requestClusterStatus:ale}=(lp(),C(jk)),{getReplicationSharedStatus:cle,getHDBNodeTable:lle}=(pl(),C(jO)),{CONFIRMATION_STATUS_POSITION:ule,RECEIVED_VERSION_POSITION:dle,RECEIVED_TIME_POSITION:fle,SENDING_TIME_POSITION:_le}=(SN(),C(BF)),Nq=aS.get(Ad.CONFIG_PARAMS.CLUSTERING_ENABLED),wq=aS.get(Ad.CONFIG_PARAMS.CLUSTERING_NODENAME);Pq.exports={clusterStatus:ple,buildNodeStatus:Cq};var Iq;ile("cluster-status",async e=>{Iq(e)});async function ple(){if(aS.get(Ad.CONFIG_PARAMS.REPLICATION_URL)||aS.get(Ad.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;if(Oq){Oq.postMessage({type:"request-cluster-status"}),n=await new Promise(i=>{Iq=i});for(let i of n.connections){let o=i.name;for(let c of i.database_sockets){let l=c.database,u;for(let d of Object.values(databases[l]||{}))if(u=d.auditStore,u)break;if(!u)continue;let f=cle(u,l,o);c.lastCommitConfirmed=oS(f[ule]),c.lastReceivedRemoteTime=oS(f[dle]),c.lastReceivedLocalTime=oS(f[fle]),c.sendingMessage=oS(f[_le])}}}else n=ale();n.node_name=ole();let s=lle().primaryStore.get(n.node_name);return s?.shard&&(n.shard=s.shard),s?.url&&(n.url=s.url),n.is_enabled=!0,n}let e={node_name:wq,is_enabled:Nq,connections:[]};if(!Nq)return e;let t=await aw.getAllNodeRecords();if(nle.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(Cq(t[n],e.connections));return await Promise.allSettled(r),e}a(ple,"clusterStatus");function oS(e){return e?e===1?"Copying":new Date(e).toUTCString():void 0}a(oS,"asDate");async function Cq(e,t){let r=e.name,n=new sle(Ad.OPERATIONS_ENUM.CLUSTER_STATUS,wq,void 0,await aw.getSystemInfo()),s,i,o=Ol.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await rle.request(Ol.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Ol.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=Ol.CLUSTER_STATUS_STATUSES.CLOSED,ow.error(`Error getting node status from ${r} `,s))}catch(l){ow.warn(`Error getting node status from ${r}`,l),l.code===bq.NoResponders?o=Ol.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===bq.Timeout?o=Ol.CLUSTER_STATUS_STATUSES.TIMEOUT:o=Ol.CLUSTER_STATUS_STATUSES.CLOSED}let c=new hle(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let l={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==Ad.PRE_4_0_0_VERSION&&await aw.upsertNodeRecord(l)}catch(l){ow.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(Cq,"buildNodeStatus");function hle(e,t,r,n,s,i,o,c){this.node_name=e,this.status=t,this.ports={clustering:r,operations_api:n},this.latency_ms=s,this.uptime=i,this.subscriptions=o,this.system_info=c}a(hle,"NodeStatusObject")});var uS=w((LLe,Dq)=>{"use strict";var{handleHDBError:mle,hdb_errors:Ele}=pe(),{HTTP_STATUS_CODES:gle}=Ele,Sle=ir(),Tle=Do(),cw=ie(),lS=require("joi"),Ale=ot(),Rle=2e3,yle=lS.object({timeout:lS.number().min(1),connected_nodes:lS.boolean(),routes:lS.boolean()});Dq.exports=ble;async function ble(e){Tle.checkClusteringEnabled();let t=Ale.validateBySchema(e,yle);if(t)throw mle(t,t.message,gle.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||cw.autoCastBoolean(n),o=s===void 0||cw.autoCastBoolean(s),c={nodes:[]},l=await Sle.getServerList(r??Rle),u={};if(i)for(let f=0,d=l.length;f<d;f++){let p=l[f].statsz;p&&(u[l[f].server.name]=p.routes)}for(let f=0,d=l.length;f<d;f++){if(l[f].statsz)continue;let p=l[f].server,_=l[f].data;if(p.name.endsWith("-hub")){let h={name:p.name.slice(0,-4),response_time:l[f].response_time};i&&(h.connected_nodes=[],u[p.name]&&u[p.name].forEach(S=>{h.connected_nodes.includes(S.name.slice(0,-4))||h.connected_nodes.push(S.name.slice(0,-4))})),o&&(h.routes=_.cluster?.urls?_.cluster?.urls.map(S=>({host:S.split(":")[0],port:cw.autoCast(S.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(ble,"clusterNetwork")});var Uq=w((vLe,vq)=>{"use strict";var lw=require("joi"),Lq=ot(),{route_constraints:Mq}=Yy();vq.exports={setRoutesValidator:Ole,deleteRoutesValidator:Nle};function Ole(e){let t=lw.object({server:lw.valid("hub","leaf"),routes:Mq.required()});return Lq.validateBySchema(e,t)}a(Ole,"setRoutesValidator");function Nle(e){let t=lw.object({routes:Mq.required()});return Lq.validateBySchema(e,t)}a(Nle,"deleteRoutesValidator")});var dS=w((xLe,qq)=>{"use strict";var Mo=yt(),uw=ie(),ws=(H(),C(G)),Rd=ae(),xq=Uq(),{handleHDBError:Bq,hdb_errors:wle}=pe(),{HTTP_STATUS_CODES:Hq}=wle,kq="cluster routes successfully set",Fq="cluster routes successfully deleted";qq.exports={setRoutes:Cle,getRoutes:Ple,deleteRoutes:Dle};function Ile(e){let t=Mo.getClusteringRoutes(),r=e.server==="hub"?t.hub_routes:t.leaf_routes,n=e.server==="hub"?t.leaf_routes:t.hub_routes,s=[],i=[];for(let o=0,c=e.routes.length;o<c;o++){let l=e.routes[o];l.port=uw.autoCast(l.port);let u=r.some(d=>d.host===l.host&&d.port===l.port),f=n.some(d=>d.host===l.host&&d.port===l.port);u||f?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?Mo.updateConfigValue(ws.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):Mo.updateConfigValue(ws.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:kq,set:i,skipped:s}}a(Ile,"setRoutesNats");function Cle(e){let t=xq.setRoutesValidator(e);if(t)throw Bq(t,t.message,Hq.BAD_REQUEST,void 0,void 0,!0);if(Rd.get(ws.CONFIG_PARAMS.CLUSTERING_ENABLED))return Ile(e);let r=[],n=[],s=Rd.get(ws.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{Gq(s,i)?n.push(i):(s.push(i),r.push(i))}),Mo.updateConfigValue(ws.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:kq,set:r,skipped:n}}a(Cle,"setRoutes");function Gq(e,t){return typeof t=="string"?e.includes(t):typeof t=="object"&&t!==null?e.some(r=>(r.host===t.host||r.hostname===t.hostname)&&r.port===t.port):!1}a(Gq,"existsInArray");function Ple(){if(Rd.get(ws.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=Mo.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return Rd.get(ws.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(Ple,"getRoutes");function Dle(e){let t=xq.deleteRoutesValidator(e);if(t)throw Bq(t,t.message,Hq.BAD_REQUEST,void 0,void 0,!0);if(Rd.get(ws.CONFIG_PARAMS.CLUSTERING_ENABLED))return Lle(e);let r=[],n=[],s=Rd.get(ws.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{Gq(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),Mo.updateConfigValue(ws.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:Fq,deleted:r,skipped:n}}a(Dle,"deleteRoutes");function Lle(e){let t=Mo.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],o=!1,c=!1;for(let l=0,u=e.routes.length;l<u;l++){let f=e.routes[l],d=!1;for(let p=0,_=r.length;p<_;p++){let h=r[p];if(f.host===h.host&&f.port===h.port){r.splice(p,1),d=!0,o=!0,s.push(f);break}}if(!d){let p=!0;for(let _=0,h=n.length;_<h;_++){let S=n[_];if(f.host===S.host&&f.port===S.port){n.splice(_,1),c=!0,p=!1,s.push(f);break}}p&&i.push(f)}}return o&&(r=uw.isEmptyOrZeroLength(r)?null:r,Mo.updateConfigValue(ws.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=uw.isEmptyOrZeroLength(n)?null:n,Mo.updateConfigValue(ws.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:Fq,deleted:s,skipped:i}}a(Lle,"deleteRoutesNats")});var Vq=w((HLe,$q)=>{"use strict";var Cp=require("alasql"),Nl=require("recursive-iterator"),ui=z(),Mle=ie(),Pp=(H(),C(G)),dw=class{static{a(this,"sql_statement_bucket")}constructor(t){this.ast=t,this.affected_attributes=new Map,this.table_lookup=new Map,this.schema_lookup=new Map,this.table_to_schema_lookup=new Map,Ule(this.ast,this.affected_attributes,this.table_lookup,this.schema_lookup,this.table_to_schema_lookup)}getAttributesBySchemaTableName(t,r){if(!t||!r||!this.affected_attributes)return[];if(this.affected_attributes.has(t))return!this.affected_attributes.get(t).has(r)&&(r=this.table_lookup.get(r),!r)?[]:this.affected_attributes.get(t).get(r)}getAllTables(){let t=[];if(!this.affected_attributes)return t;for(let r of this.affected_attributes.keys())t.push(Array.from(this.affected_attributes.get(r).keys()));return t}getTablesBySchemaName(t){return!t||!this.affected_attributes?[]:Array.from(this.affected_attributes.get(t).keys())}getSchemas(){return this.affected_attributes?Array.from(this.affected_attributes.keys()):[]}getAst(){return this.ast}updateAttributeWildcardsForRolePerms(t){let r=this.ast.columns.filter(s=>Pp.SEARCH_WILDCARDS.includes(s.columnid));if(r.length===0)return this.ast;let n=this.ast.from[0].databaseid;return this.ast.columns=this.ast.columns.filter(s=>!Pp.SEARCH_WILDCARDS.includes(s.columnid)),r.forEach(s=>{let i=this.table_to_schema_lookup.has(s.tableid)?this.table_to_schema_lookup.get(s.tableid):n,o=this.table_lookup.has(s.tableid)?this.table_lookup.get(s.tableid):this.ast.from[0].tableid;if(t[i]&&t[i].tables[o]&&t[i].tables[o][Pp.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=vle(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(u=>({attribute_name:u.attribute}));let l=this.affected_attributes.get(i).get(o).filter(u=>!Pp.SEARCH_WILDCARDS.includes(u));c.forEach(({attribute_name:u})=>{let f=new Cp.yy.Column({columnid:u});s.tableid&&(f.tableid=s.tableid),this.ast.columns.push(f),l.includes(u)||l.push(u)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function vle(e){return e.filter(t=>t[Pp.PERMS_CRUD_ENUM.READ])}a(vle,"filterReadRestrictedAttrs");function Ule(e,t,r,n,s){xle(e,t,r,n,s)}a(Ule,"interpretAST");function Dp(e,t,r,n,s){if(!(!e||!e.databaseid)&&(t.has(e.databaseid)||t.set(e.databaseid,new Map),t.get(e.databaseid).has(e.tableid)||t.get(e.databaseid).set(e.tableid,[]),e.as&&(r.has(e.as)||r.set(e.as,e.tableid),n&&!n.has(e.as)&&n.set(e.as,e.databaseid)),s)){let i=e.databaseid,o=e.tableid;e.as&&(o=e.as),s.set(o,i)}}a(Dp,"addSchemaTableToMap");function xle(e,t,r,n,s){if(!e){ui.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Cp.yy.Insert?Fle(e,t,r):e instanceof Cp.yy.Select?Ble(e,t,r,n,s):e instanceof Cp.yy.Update?Hle(e,t,r):e instanceof Cp.yy.Delete?kle(e,t,r):ui.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(xle,"getRecordAttributesAST");function Ble(e,t,r,n,s){if(!e){ui.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(Mle.isEmptyOrZeroLength(i)){ui.error("No schema specified");return}e.from.forEach(c=>{Dp(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),Dp(c.table,t,r,n,s)});let o=new Nl(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,u=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(u).has(l))if(r.has(l))l=r.get(l);else{ui.info(`table specified as ${l} not found.`);return}t.get(u).get(l).indexOf(c.columnid)<0&&t.get(u).get(l).push(c.columnid)}if(e.where){let c=new Nl(e.where),l=e.from[0].tableid;for(let{node:u}of c)if(u&&u.columnid){let f=u.tableid?u.tableid:l;if(!t.get(i).has(f))if(r.has(f))f=r.get(f);else{ui.info(`table specified as ${f} not found.`);continue}t.get(i).get(f).indexOf(u.columnid)<0&&t.get(i).get(f).push(u.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new Nl(c.on);for(let{node:u}of l)if(u&&u.columnid){let f=u.tableid,d=s.get(f);if(!t.get(d).has(f))if(r.has(f))f=r.get(f);else{ui.info(`table specified as ${f} not found.`);continue}t.get(d).get(f).indexOf(u.columnid)<0&&t.get(d).get(f).push(u.columnid)}}),e.order){let c=new Nl(e.order);for(let{node:l}of c)if(l&&l.columnid){let u=l.tableid,f=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(f).has(u))if(r.has(u))u=r.get(u);else{ui.info(`table specified as ${u} not found.`);return}t.get(f).get(u).indexOf(l.columnid)<0&&t.get(f).get(u).push(l.columnid)}}}a(Ble,"getSelectAttributes");function Hle(e,t,r){if(!e){ui.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new Nl(e.columns),s=e.table.databaseid;Dp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&fw(e.table.tableid,s,i.columnid,t,r)}a(Hle,"getUpdateAttributes");function kle(e,t,r){if(!e){ui.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new Nl(e.where),s=e.table.databaseid;Dp(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&fw(e.table.tableid,s,i.columnid,t,r)}a(kle,"getDeleteAttributes");function Fle(e,t,r){if(!e){ui.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new Nl(e.columns),s=e.into.databaseid;Dp(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&fw(e.into.tableid,s,i.columnid,t,r)}a(Fle,"getInsertAttributes");function fw(e,t,r,n,s){if(!n.get(t))return;let i=e;n.get(t).has(i)||(i=s.get(i)),n.get(t).get(i).push(r)}a(fw,"pushAttribute");$q.exports=dw});var Yq=w((FLe,Kq)=>{"use strict";var fS=(H(),C(G)),_S=class{static{a(this,"BaseLicense")}constructor(t=0,r=fS.RAM_ALLOCATION_ENUM.DEFAULT,n=fS.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},_w=class extends _S{static{a(this,"ExtendedLicense")}constructor(t=0,r=fS.RAM_ALLOCATION_ENUM.DEFAULT,n=fS.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};Kq.exports={BaseLicense:_S,ExtendedLicense:_w}});var Od=w((qLe,Xq)=>{"use strict";var bd=require("fs-extra"),pS=(hE(),C(pE)),zq=require("crypto"),Gle=require("moment"),qle=require("uuid").v4,Zr=z(),hw=require("path"),$le=ie(),wl=(H(),C(G)),{totalmem:Wq}=require("os"),Vle=Yq().ExtendedLicense,yd="invalid license key format",Kle="061183",Yle="mofi25",Wle="aes-256-cbc",zle=16,jle=32,jq=ae(),{resolvePath:Jq}=yt();jq.initSync();var pw;Xq.exports={validateLicense:Qq,generateFingerPrint:Qle,licenseSearch:gw,getLicense:eue,checkMemoryLimit:tue};function mw(){return hw.join(jq.getHdbBasePath(),wl.LICENSE_KEY_DIR_NAME,wl.LICENSE_FILE_NAME)}a(mw,"getLicenseDirPath");function Jle(){let e=mw();return Jq(hw.join(e,wl.LICENSE_FILE_NAME))}a(Jle,"getLicenseFilePath");function Ew(){let e=mw();return Jq(hw.join(e,wl.REG_KEY_FILE_NAME))}a(Ew,"getFingerPrintFilePath");async function Qle(){let e=Ew();try{return await bd.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await Xle();throw Zr.error(`Error writing fingerprint file to ${e}`),Zr.error(t),new Error("There was an error generating the fingerprint")}}a(Qle,"generateFingerPrint");async function Xle(){let e=qle(),t=pS.hash(e,pS.HASH_FUNCTION.MD5),r=Ew();try{await bd.mkdirp(mw()),await bd.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw Zr.error(`Error writing fingerprint file to ${r}`),Zr.error(n),new Error("There was an error generating the fingerprint")}return t}a(Xle,"writeFingerprint");function Qq(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:wl.RAM_ALLOCATION_ENUM.DEFAULT,version:wl.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Zr.error("empty license key passed to validate."),r;let n=Ew(),s=!1;try{s=bd.statSync(n)}catch(i){Zr.error(i)}if(s){let i;try{i=bd.readFileSync(n,"utf8")}catch{Zr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(Yle),c=o[1];c=Buffer.concat([Buffer.from(c)],zle);let l=Buffer.concat([Buffer.from(i)],jle),u=zq.createDecipheriv(Wle,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let f=null;try{f=u.update(o[0],"hex","utf8"),f.trim(),f+=u.final("utf8")}catch{let _=Zle(o[0],i);if(_)f=_;else throw r.valid_license=!1,r.valid_machine=!1,console.error(yd),Zr.error(yd),new Error(yd)}let d;if(isNaN(f))try{d=JSON.parse(f),r.version=d.version,r.exp_date=d.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),d.ram_allocation&&(r.ram_allocation=d.ram_allocation)}catch{throw console.error(yd),Zr.error(yd),new Error(yd)}else r.exp_date=f;r.exp_date<Gle().valueOf()&&(r.valid_date=!1),pS.validate(o[1],`${Kle}${i}${t}`,pS.HASH_FUNCTION.MD5)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||Zr.error("Invalid licence"),r}a(Qq,"validateLicense");function Zle(e,t){try{let r=zq.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{Zr.warn("Check old license failed")}}a(Zle,"checkOldLicense");function gw(){let e=new Vle,t=[];try{t=bd.readFileSync(Jle(),"utf-8").split(`\r
25
+ `)}catch(r){r.code==="ENOENT"?Zr.debug("no license file found"):Zr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if($le.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=Qq(s.license_key,s.company);i.valid_machine===!0&&i.valid_date===!0&&i.valid_machine===!0&&(e.exp_date=i.exp_date>e.exp_date?i.exp_date:e.exp_date,e.ram_allocation=i.ram_allocation,e.enterprise=!0)}catch(s){Zr.error("There was an error parsing the license string."),Zr.error(s),e.ram_allocation=wl.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return pw=e,e}a(gw,"licenseSearch");async function eue(){return pw||await gw(),pw}a(eue,"getLicense");function tue(){let e=gw().ram_allocation,t=process.constrainedMemory?.()||Wq();if(t=Math.round(Math.min(t,Wq())/2**20),t>e)return`This server has more memory (${t}MB) than HarperDB is licensed for (${e}MB), this should only be used for educational and development purposes.`}a(tue,"checkMemoryLimit")});var mS=w((VLe,r$)=>{var hS=Od(),Zq=require("chalk"),ts=z(),e$=require("prompt"),{promisify:rue}=require("util"),Sw=(H(),C(G)),nue=require("fs-extra"),sue=require("path"),iue=ie(),{packageJson:oue}=it(),t$=ae();t$.initSync();var aue=require("moment"),cue=rue(e$.get),lue=sue.join(t$.getHdbBasePath(),Sw.LICENSE_KEY_DIR_NAME,Sw.LICENSE_FILE_NAME,Sw.LICENSE_FILE_NAME);r$.exports={getFingerprint:due,setLicense:uue,parseLicense:Tw,register:fue,getRegistrationInfo:pue};async function uue(e){if(e&&e.key&&e.company){try{ts.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await Tw(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw ts.error(r),ts.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(uue,"setLicense");async function due(){let e={};try{e=await hS.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw ts.error(r),ts.error(t),new Error(r)}return e}a(due,"getFingerprint");async function Tw(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");ts.info("Validating license input...");let r=hS.validateLicense(e,t);if(ts.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(ts.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(ts.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{ts.info("writing license to disk"),await nue.writeFile(lue,JSON.stringify({license_key:e,company:t}))}catch(n){throw ts.error("Failed to write License"),n}return"Registration successful."}a(Tw,"parseLicense");async function fue(){let e=await _ue();return Tw(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(fue,"register");async function _ue(){let e=await hS.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:Zq.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:Zq.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{e$.start()}catch(n){ts.error(n)}let r;try{r=await cue(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(_ue,"promptForRegistration");async function pue(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await hS.getLicense()}catch(r){throw ts.error(`There was an error when searching licenses due to: ${r.message}`),r}if(iue.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=oue.version,e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=aue.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(pue,"getRegistrationInfo")});var s$=w((YLe,n$)=>{"use strict";var hue=Tt(),Aw=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,u,f,d,p,_,h){this.port=t,o===null&&(o=void 0),this.server_name=r+hue.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.reconnect_error_reports=100,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l},this.leafnodes={port:u,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:f,port:d,routes:p,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:_},HDB:{users:h}},this.system_account="SYS"}};n$.exports=Aw});var a$=w((zLe,o$)=>{"use strict";var i$=Tt(),Rw=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,u,f,d){this.port=t,d===null&&(d=void 0),this.server_name=r+i$.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+i$.SERVER_SUFFIX.LEAF},this.tls={cert_file:u,key_file:f,ca_file:d,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:d,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:d,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:l,jetstream:"enabled"}},this.system_account="SYS"}};o$.exports=Rw});var l$=w((JLe,c$)=>{"use strict";var yw=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};c$.exports=yw});var d$=w((XLe,u$)=>{"use strict";var mue=Tt(),bw=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+mue.SERVER_SUFFIX.ADMIN,this.password=r}};u$.exports=bw});var TS=w((eMe,p$)=>{"use strict";var Il=require("path"),Cl=require("fs-extra"),Eue=s$(),gue=a$(),Sue=l$(),Tue=d$(),Ow=Rn(),wd=ie(),wn=yt(),gS=(H(),C(G)),Lp=Tt(),{CONFIG_PARAMS:Jt}=gS,Id=z(),Mp=ae(),f$=Eo(),Nw=ir(),Aue=Zn(),Nd="clustering",Rue=1e4,_$=50;p$.exports={generateNatsConfig:bue,removeNatsConfig:Oue,getHubConfigPath:yue};function yue(){let e=Mp.get(Jt.ROOTPATH);return Il.join(e,Nd,Lp.NATS_CONFIG_FILES.HUB_SERVER)}a(yue,"getHubConfigPath");async function bue(e=!1,t=void 0){let r=Mp.get(Jt.ROOTPATH);Cl.ensureDirSync(Il.join(r,"clustering","leaf")),Mp.initSync();let n=wn.getConfigFromFile(Jt.CLUSTERING_TLS_CERT_AUTH),s=wn.getConfigFromFile(Jt.CLUSTERING_TLS_PRIVATEKEY),i=wn.getConfigFromFile(Jt.CLUSTERING_TLS_CERTIFICATE);!await Cl.exists(i)&&!await Cl.exists(!n)&&await Aue.createNatsCerts();let o=Il.join(r,Nd,Lp.PID_FILES.HUB),c=Il.join(r,Nd,Lp.PID_FILES.LEAF),l=wn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=Il.join(r,Nd,Lp.NATS_CONFIG_FILES.HUB_SERVER),f=Il.join(r,Nd,Lp.NATS_CONFIG_FILES.LEAF_SERVER),d=wn.getConfigFromFile(Jt.CLUSTERING_TLS_INSECURE),p=wn.getConfigFromFile(Jt.CLUSTERING_TLS_VERIFY),_=wn.getConfigFromFile(Jt.CLUSTERING_NODENAME),h=wn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await Nw.checkNATSServerInstalled()||SS("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let S=await Ow.listUsers(),g=wn.getConfigFromFile(Jt.CLUSTERING_USER),R=await Ow.getClusterUser();(wd.isEmpty(R)||R.active!==!0)&&SS(`Invalid cluster user '${g}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await ES(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await ES(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await ES(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),await ES(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let E=[],T=[];for(let[se,Q]of S.entries())Q.role?.role===gS.ROLE_TYPES_ENUM.CLUSTER_USER&&Q.active&&(E.push(new Tue(Q.username,f$.decrypt(Q.hash))),T.push(new Sue(Q.username,f$.decrypt(Q.hash))));let b=[],{hub_routes:v}=wn.getClusteringRoutes();if(!wd.isEmptyOrZeroLength(v))for(let se of v)b.push(`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@${se.host}:${se.port}`);let F=new Eue(wn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),_,o,i,s,n,d,p,h,wn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NAME),wn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),b,E,T);n==null&&(delete F.tls.ca_file,delete F.leafnodes.tls.ca_file),t=wd.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===gS.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await Cl.writeJson(u,F),Id.trace(`Hub server config written to ${u}`));let q=`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@0.0.0.0:${h}`,Y=`tls://${R.uri_encoded_name}:${R.uri_encoded_d_hash}@0.0.0.0:${h}`,Z=new gue(wn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT),_,c,l,[q],[Y],E,T,i,s,n,d);n==null&&delete Z.tls.ca_file,(t===void 0||t===gS.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await Cl.writeJson(f,Z),Id.trace(`Leaf server config written to ${f}`))}a(bue,"generateNatsConfig");async function ES(e){let t=Mp.get(e);return wd.isEmpty(t)&&SS(`port undefined for '${e}'`),await wd.isPortTaken(t)&&SS(`'${e}' port '${t}' is is in use by another process, check to see if HarperDB is already running or another process is using this port.`),!0}a(ES,"isPortAvailable");function SS(e){let t=`Error generating clustering config: ${e}`;Id.error(t),console.error(t),process.exit(1)}a(SS,"generateNatsConfigError");async function Oue(e){let{port:t,config_file:r}=Nw.getServerConfig(e),{username:n,decrypt_hash:s}=await Ow.getClusterUser(),i=0,o=2e3;for(;i<_$;){try{let f=await Nw.createConnection(t,n,s,!1);if(f.protocol.connected===!0){f.close();break}}catch(f){Id.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${f}`)}if(i++,i>=_$)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);let u=o*(i*2);u>3e4&&Id.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await wd.async_set_timeout(u)}let c="0".repeat(Rue),l=Il.join(Mp.get(Jt.ROOTPATH),Nd,r);await Cl.writeFile(l,c),await Cl.remove(l),Id.notify(e,"started.")}a(Oue,"removeNatsConfig")});var T$=w((rMe,S$)=>{"use strict";var rs=ae(),Nue=Od(),Fe=(H(),C(G)),vp=Tt(),vo=require("path"),{PACKAGE_ROOT:RS}=it(),h$=ae(),AS=ie(),Cd="/dev/null",wue=vo.join(RS,"launchServiceScripts"),m$=vo.join(RS,"utility/scripts"),Iue=vo.join(m$,Fe.HDB_RESTART_SCRIPT),E$=vo.resolve(RS,"dependencies",`${process.platform}-${process.arch}`,vp.NATS_BINARY_NAME);function g$(){let t=Nue.licenseSearch().ram_allocation||Fe.RAM_ALLOCATION_ENUM.DEFAULT,r=Fe.MEM_SETTING_KEY+t,n={[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return AS.noBootFile()&&(n[Fe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=AS.getEnvCliRootPath()),{name:Fe.PROCESS_DESCRIPTORS.HDB,script:Fe.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:RS}}a(g$,"generateMainServerConfig");var Cue=9930;function Pue(){rs.initSync(!0);let e=rs.get(Fe.CONFIG_PARAMS.ROOTPATH),t=vo.join(e,"clustering",vp.NATS_CONFIG_FILES.HUB_SERVER),r=vo.join(rs.get(Fe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Fe.LOG_NAMES.HDB),n=h$.get(Fe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=vp.LOG_LEVEL_FLAGS[rs.get(Fe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==Cue?"-"+n:""),script:E$,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return rs.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Cd,i.error_file=Cd),i}a(Pue,"generateNatsHubServerConfig");var Due=9940;function Lue(){rs.initSync(!0);let e=rs.get(Fe.CONFIG_PARAMS.ROOTPATH),t=vo.join(e,"clustering",vp.NATS_CONFIG_FILES.LEAF_SERVER),r=vo.join(rs.get(Fe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Fe.LOG_NAMES.HDB),n=h$.get(Fe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=vp.LOG_LEVEL_FLAGS[rs.get(Fe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==Due?"-"+n:""),script:E$,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return rs.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Cd,i.error_file=Cd),i}a(Lue,"generateNatsLeafServerConfig");function Mue(){rs.initSync();let e=vo.join(rs.get(Fe.CONFIG_PARAMS.LOGGING_ROOT),Fe.LOG_NAMES.HDB),t={name:Fe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:Fe.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:wue,autorestart:!1};return rs.get(Fe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=Cd,t.error_file=Cd),t}a(Mue,"generateClusteringUpgradeV4ServiceConfig");function vue(){let e={[Fe.PROCESS_NAME_ENV_PROP]:Fe.PROCESS_DESCRIPTORS.RESTART_HDB};return AS.noBootFile()&&(e[Fe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=AS.getEnvCliRootPath()),{...{name:Fe.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:m$},script:Iue}}a(vue,"generateRestart");function Uue(){return{apps:[g$()]}}a(Uue,"generateAllServiceConfigs");S$.exports={generateAllServiceConfigs:Uue,generateMainServerConfig:g$,generateRestart:vue,generateNatsHubServerConfig:Pue,generateNatsLeafServerConfig:Lue,generateClusteringUpgradeV4ServiceConfig:Mue}});var Pd=w((iMe,v$)=>{"use strict";var et=(H(),C(G)),xue=ie(),xo=TS(),yS=ir(),Uo=Tt(),Ka=T$(),bS=ae(),Pl=z(),Bue=Do(),{startWorker:A$,onMessageFromWorkers:Hue}=rt(),kue=Po(),sMe=require("util"),Fue=require("child_process"),Gue=require("fs"),{execFile:que}=Fue,Ve;v$.exports={enterPM2Mode:$ue,start:Ya,stop:ww,reload:y$,restart:b$,list:Iw,describe:w$,connect:Bo,kill:zue,startAllServices:jue,startService:Cw,getUniqueServicesList:I$,restartAllServices:Jue,isServiceRegistered:C$,reloadStopStart:P$,restartHdb:N$,deleteProcess:Yue,startClusteringProcesses:L$,startClusteringThreads:M$,isHdbRestartRunning:Wue,isClusteringRunning:Xue,stopClustering:Que,reloadClustering:Zue,expectedRestartOfChildren:O$};var Up=!1;Hue(e=>{e.type==="restart"&&bS.initSync(!0)});function $ue(){Up=!0}a($ue,"enterPM2Mode");function Bo(){return Ve||(Ve=require("pm2")),new Promise((e,t)=>{Ve.connect((r,n)=>{r&&t(r),e(n)})})}a(Bo,"connect");var en,Vue=10,R$;function Ya(e,t=!1){if(Up)return Kue(e);let r=que(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let o=en.indexOf(r);o>-1&&en.splice(o,1),!R$&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<Vue&&(Gue.existsSync(xo.getHubConfigPath())?Ya(e):(await xo.generateNatsConfig(!0),Ya(e),await new Promise(c=>setTimeout(c,3e3)),await xo.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await xo.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=bS.get(et.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,u=0,f;for(;l=c.exec(i);){if(l.index&&Uo.LOG_LEVEL_HIERARCHY[o]>=Uo.LOG_LEVEL_HIERARCHY[f||"info"]){let _=f===Uo.LOG_LEVELS.ERR||f===Uo.LOG_LEVELS.WRN?Pl.OUTPUTS.STDERR:Pl.OUTPUTS.STDOUT;Pl.logCustomLevel(f||"info",_,n,i.slice(u,l.index).trim())}let[d,p]=l;u=l.index+d.length,f=Uo.LOG_LEVELS[p]}if(Uo.LOG_LEVEL_HIERARCHY[o]>=Uo.LOG_LEVEL_HIERARCHY[f||"info"]){let d=f===Uo.LOG_LEVELS.ERR||f===Uo.LOG_LEVELS.WRN?Pl.OUTPUTS.STDERR:Pl.OUTPUTS.STDOUT;Pl.logCustomLevel(f||"info",d,n,i.slice(u).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!en&&(en=[],!t)){let i=a(()=>{R$=!0,en&&(en.map(o=>o.kill()),process.exit(0))},"kill_children");process.on("exit",i),process.on("SIGINT",i),process.on("SIGQUIT",i),process.on("SIGTERM",i)}en.push(r)}a(Ya,"start");function Kue(e){return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.start(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(Kue,"startWithPM2");function ww(e){if(!Up){for(let t of en||[])t.name===e&&(en.splice(en.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.stop(e,async(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.delete(e,(i,o)=>{i&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(o)})})})}a(ww,"stop");function y$(e){return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.reload(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(y$,"reload");function b$(e){if(!Up){O$();for(let t of en||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.restart(e,(n,s)=>{Ve.disconnect(),t(s)})})}a(b$,"restart");function O$(){for(let e of en||[])e.config&&(e.config.restarts=0)}a(O$,"expectedRestartOfChildren");function Yue(e){return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.delete(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(Yue,"deleteProcess");async function N$(){await Ya(Ka.generateRestart())}a(N$,"restartHdb");async function Wue(){let e=await Iw();for(let t in e)if(e[t].name===et.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(Wue,"isHdbRestartRunning");function Iw(){return new Promise(async(e,t)=>{try{await Bo()}catch(r){t(r)}Ve.list((r,n)=>{r&&(Ve.disconnect(),t(r)),Ve.disconnect(),e(n)})})}a(Iw,"list");function w$(e){return new Promise(async(t,r)=>{try{await Bo()}catch(n){r(n)}Ve.describe(e,(n,s)=>{n&&(Ve.disconnect(),r(n)),Ve.disconnect(),t(s)})})}a(w$,"describe");function zue(){if(!Up){for(let e of en||[])e.kill();en=[];return}return new Promise(async(e,t)=>{try{await Bo()}catch(r){t(r)}Ve.killDaemon((r,n)=>{r&&(Ve.disconnect(),t(r)),Ve.disconnect(),e(n)})})}a(zue,"kill");async function jue(){try{await L$(),await M$(),await Ya(Ka.generateAllServiceConfigs())}catch(e){throw Ve?.disconnect(),e}}a(jue,"startAllServices");async function Cw(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case et.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Ka.generateMainServerConfig();break;case et.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Ka.generateNatsIngestServiceConfig();break;case et.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Ka.generateNatsReplyServiceConfig();break;case et.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Ka.generateNatsHubServerConfig(),await Ya(r,t),await xo.removeNatsConfig(e);return;case et.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Ka.generateNatsLeafServerConfig(),await Ya(r,t),await xo.removeNatsConfig(e);return;case et.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Ka.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await Ya(r)}catch(r){throw Ve?.disconnect(),r}}a(Cw,"startService");async function I$(){try{let e=await Iw(),t={};for(let r=0,n=e.length;r<n;r++){let s=e[r];t[s.name]===void 0&&(t[s.name]={name:s.name,exec_mode:s.pm2_env.exec_mode})}return t}catch(e){throw Ve?.disconnect(),e}}a(I$,"getUniqueServicesList");async function Jue(e=[]){try{let t=!1,r=await I$();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===et.PROCESS_DESCRIPTORS.HDB?t=!0:await b$(o))}t&&await P$(et.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Ve?.disconnect(),t}}a(Jue,"restartAllServices");async function C$(e){if(en?.find(r=>r.name===e))return!0;let t=await kue.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(C$,"isServiceRegistered");async function P$(e){let t=bS.get(et.CONFIG_PARAMS.THREADS_COUNT)??bS.get(et.CONFIG_PARAMS.THREADS),r=await w$(e),n=xue.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await ww(e),await Cw(e)):e===et.PROCESS_DESCRIPTORS.HDB?await N$():await y$(e)}a(P$,"reloadStopStart");var D$;async function L$(e=!1){for(let t in et.CLUSTERING_PROCESSES){let r=et.CLUSTERING_PROCESSES[t];await Cw(r,e)}}a(L$,"startClusteringProcesses");async function M$(){D$=A$(et.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:et.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await yS.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await yS.updateLocalStreams();let e=await Bue.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===et.PRE_4_0_0_VERSION){Pl.info("Starting clustering upgrade 4.0.0 process"),A$(et.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(M$,"startClusteringThreads");async function Que(){for(let e in et.CLUSTERING_PROCESSES)if(e!==et.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===et.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await D$.terminate();else{let t=et.CLUSTERING_PROCESSES[e];await ww(t)}}a(Que,"stopClustering");async function Xue(){for(let e in et.CLUSTERING_PROCESSES){let t=et.CLUSTERING_PROCESSES[e];if(await C$(t)===!1)return!1}return!0}a(Xue,"isClusteringRunning");async function Zue(){await xo.generateNatsConfig(!0),await yS.reloadNATSHub(),await yS.reloadNATSLeaf(),await xo.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await xo.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(Zue,"reloadClustering")});var wS={};ve(wS,{compactOnStart:()=>ede,copyDb:()=>F$});async function ede(){Wa.notify("Running compact on start"),console.log("Running compact on start");let e=(0,Pw.get)(x.ROOTPATH),t=new Map,r=Xe();(0,Dw.updateConfigValue)(x.STORAGE_COMPACTONSTART,!1);try{for(let n in r){if(n==="system"||n.endsWith("-copy"))continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,OS.join)(e,"backup",n+".mdb"),o=(0,OS.join)(e,Nc,n+"-copy.mdb"),c=0;try{c=await U$(n),console.log("Database",n,"before compact has a total record count of",c)}catch(l){Wa.error("Error getting record count for database",n,l),console.error("Error getting record count for database",n,l)}t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await F$(n,o),console.log("Backing up",n,"to",i),await(0,Dl.move)(s,i,{overwrite:!0})}try{Dd()}catch(n){Wa.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n)}for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,Dl.move)(i,s,{overwrite:!0}),await(0,Dl.remove)((0,OS.join)(e,Nc,`${n}-copy.mdb-lock`));try{Dd()}catch(n){Wa.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n),process.exit(0)}}catch(n){Wa.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,Dw.updateConfigValue)(x.STORAGE_COMPACTONSTART,!1);for(let[s,{db_path:i,backup_dest:o}]of t){console.error("Moving backup database",o,"back to",i);try{await(0,Dl.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw Dd(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await U$(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){o=!1;let l=`There is a discrepancy between pre and post compact record count for database ${n}.
26
26
  Total record count before compaction: ${i}, total after: ${c}.
27
- Database backup has not been removed and can be found here: ${s}`;Ya.error(l),console.error(l)}(0,Cw.get)(B.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||o===!1||(console.log("Removing backup",s),await(0,wl.remove)(s))}}async function U$(e){let t=await(0,k$.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}async function F$(e,t){console.log("copyDb start");let r=Qe()[e],n;for(let d in r){n=r[d].primaryStore.rootStore;break}let s=n.dbisDb,i=n.auditStore,o=(0,x$.open)(new B$.default(t)),c=o.openDB(OS.INTERNAL_DBIS_NAME),l,u=0,f=s.useReadTransaction();try{for(let{key:p,value:_}of s.getRange({transaction:f})){let h=_.is_hash_attribute||_.isPrimaryKey,S,g;if(h&&(S=_.compression,g=IS(),g?_.compression=g:delete _.compression,S?.dictionary?.toString()===g?.dictionary?.toString()&&(S=null,g=null)),c.put(p,_),!(h||_.indexed))continue;let R=new H$.default(!h,h);R.encoding="binary",R.compression=S;let E=n.openDB(p,R);E.decoder=null,E.decoderCopies=!1,E.encoding="binary",R.compression=g;let T=o.openDB(p,R);T.encoder=null,console.log("copying",p,"from",e,"to",t),await d(E,T,h,f)}if(i){let p=n.openDB(OS.AUDIT_STORE_NAME,xp);console.log("copying audit log for",e,"to",t),d(i,p,!1,f)}async function d(p,_,h,S){let g=0,R=0,E=1e7,T=null;for(;E-- >0;)try{for(let b of p.getKeys({start:T,transaction:S}))try{T=b;let{value:v,version:F}=p.getEntry(b,{transaction:S});l=_.put(b,v,h?F:void 0),g++,S.openTimer&&(S.openTimer=0),R+=(b?.length||10)+v.length,u++>5e3&&(await l,console.log("copied",g,"entries",R,"bytes"),u=0)}catch(v){console.error("Error copying record",typeof b=="symbol"?"symbol":b,"from",e,"to",t,v)}console.log("finish copying, copied",g,"entries",R,"bytes");return}catch{if(typeof T=="string"){if(T==="z")return console.error("Reached end of dbi",T,"for",e,"to",t);T=T.slice(0,-2)+"z"}else if(typeof T=="number")T++;else return console.error("Unknown key type",T,"for",e,"to",t)}}a(d,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{f.done(),o.close()}}var x$,bS,wl,Cw,B$,H$,OS,k$,Pw,Ya,wS=be(()=>{Pe();x$=require("lmdb"),bS=require("path"),wl=require("fs-extra"),Cw=M(ae()),B$=M(i_()),H$=M(s_()),OS=M(Ut());H();fo();k$=M(go()),Pw=M(yt()),Ya=M(z());a(ede,"compactOnStart");a(U$,"getTotalDBRecordCount");a(F$,"copyDb")});var Wa=w((dMe,W$)=>{"use strict";var tde=require("minimist"),{isMainThread:Lw,parentPort:Hp,threadId:cMe}=require("worker_threads"),ot=(H(),C(G)),Vi=z(),Mw=ie(),PS=SS(),CS=ir(),lMe=Tt(),V$=yt(),di=Cd(),G$=Po(),{compactOnStart:rde}=(wS(),C(NS)),nde=ua(),{restartWorkers:DS,onMessageByType:sde}=et(),{handleHDBError:ide,hdb_errors:ode}=pe(),{HTTP_STATUS_CODES:ade}=ode,kp=ae(),{sendOperationToNode:q$,getThisNodeName:cde,monitorNodeCAs:lde}=(Xn(),C(wo)),{getHDBNodeTable:uMe}=(ul(),C(zO));kp.initSync();var Bp=`Restarting HarperDB. This may take up to ${ot.RESTART_TIMEOUT_MS/1e3} seconds.`,ude="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",$$="Clustering is not enabled so cannot be restarted",dde="Invalid service",Dd,Is;W$.exports={restart:K$,restartService:vw};Lw&&sde(ot.ITC_EVENT_TYPES.RESTART,async(e,t)=>{e.workerType?await vw({service:e.workerType}):K$({operation:"restart"}),t.postMessage({type:"restart-complete"})});async function K$(e){Is=Object.keys(e).length===0,Dd=await di.isServiceRegistered(ot.PROCESS_DESCRIPTORS.HDB);let t=tde(process.argv);if(t.service){await vw(t);return}if(Is&&!Dd){console.error(ude);return}if(Is&&console.log(Bp),Dd){di.enterPM2Mode(),Vi.notify(Bp);let r=nde(Object.keys(ot.CONFIG_PARAM_MAP),!0);return Mw.isEmptyOrZeroLength(Object.keys(r))||V$.updateConfigValue(void 0,void 0,r,!0,!0),fde(),Bp}return Lw?(Vi.notify(Bp),kp.get(ot.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await rde(),process.env.HARPER_EXIT_ON_RESTART&&process.exit(0),setTimeout(()=>{DS()},50)):Hp.postMessage({type:ot.ITC_EVENT_TYPES.RESTART}),Bp}a(K$,"restart");async function vw(e){let{service:t}=e;if(ot.HDB_PROCESS_SERVICES[t]===void 0)throw ide(new Error,dde,ade.BAD_REQUEST,void 0,void 0,!0);if(di.expectedRestartOfChildren(),Dd=await di.isServiceRegistered(ot.PROCESS_DESCRIPTORS.HDB),!Lw){e.replicated&&lde(),Hp.postMessage({type:ot.ITC_EVENT_TYPES.RESTART,workerType:t}),Hp.ref(),await new Promise(s=>{Hp.on("message",i=>{i.type==="restart-complete"&&(s(),Hp.unref())})});let n;if(e.replicated){e.replicated=!1,n=[];for(let s of server.nodes){if(s.name===cde())continue;let{job_id:i}=await q$(s,e);n.push(await new Promise((o,c)=>{let u=2400,f=setInterval(async()=>{if(u--<=0){clearInterval(f);let _=new Error("Timed out waiting for restart job to complete");_.replicated=n,c(_)}let p=(await q$(s,{operation:"get_job",id:i})).results[0];if(p.status==="COMPLETE"&&(clearInterval(f),o({node:s.name,message:p.message})),p.status==="ERROR"){clearInterval(f);let _=new Error(p.message);_.replicated=n,c(_)}},250)}))}return{replicated:n}}return}let r;switch(t){case ot.HDB_PROCESS_SERVICES.clustering:if(!kp.get(ot.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=$$;break}Is&&console.log("Restarting clustering"),Vi.notify("Restarting clustering"),await Y$();break;case ot.HDB_PROCESS_SERVICES.clustering_config:case ot.HDB_PROCESS_SERVICES["clustering config"]:if(!kp.get(ot.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=$$;break}Is&&console.log("Restarting clustering_config"),Vi.notify("Restarting clustering_config"),await di.reloadClustering();break;case"custom_functions":case"custom functions":case ot.HDB_PROCESS_SERVICES.harperdb:case ot.HDB_PROCESS_SERVICES.http_workers:case ot.HDB_PROCESS_SERVICES.http:if(Is&&!Dd){r=`Restart ${t} is not available from the CLI when running in non-pm2 mode. Either call restart ${t} from the API or stop and start HarperDB.`;break}Is&&console.log("Restarting http_workers"),Vi.notify("Restarting http_workers"),Is?await di.restart(ot.PROCESS_DESCRIPTORS.HDB):await DS("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(Vi.error(r),Is&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(vw,"restartService");async function fde(){await Y$(),await di.restart(ot.PROCESS_DESCRIPTORS.HDB),await Mw.async_set_timeout(2e3),kp.get(ot.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await Dw(),Is&&(await CS.closeConnection(),process.exit(0))}a(fde,"restartPM2Mode");async function Y$(){if(!V$.getConfigFromFile(ot.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await G$.getHDBProcessInfo()).clustering.length===0)Vi.trace("Clustering not running, restart will start clustering services"),await PS.generateNatsConfig(!0),await di.startClusteringProcesses(),await di.startClusteringThreads(),await Dw(),Is&&await CS.closeConnection();else{await PS.generateNatsConfig(!0),Dd?(Vi.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await di.restart(ot.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await di.restart(ot.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await G$.getHDBProcessInfo()).clustering.forEach(s=>{Vi.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await Mw.async_set_timeout(3e3),await Dw(),await CS.updateLocalStreams(),Is&&await CS.closeConnection(),Vi.trace("Restart clustering restarting ingest and reply service threads");let t=DS(ot.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=DS(ot.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(Y$,"restartClustering");async function Dw(){await PS.removeNatsConfig(ot.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await PS.removeNatsConfig(ot.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(Dw,"removeNatsConfig")});var sV=w((pMe,nV)=>{"use strict";var _Me=require("lodash"),wn=(H(),C(G)),{handleHDBError:z$,hdb_errors:_de}=pe(),{HDB_ERROR_MSGS:pde,HTTP_STATUS_CODES:hde}=_de,Uw=z();nV.exports={getRolePermissions:Ede};var Il=Object.create(null),mde=a(e=>({key:e,perms:{}}),"perms_template_obj"),X$=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),Z$=a((e=!1,t=!1,r=!1,n=!1)=>({[wn.PERMS_CRUD_ENUM.READ]:e,[wn.PERMS_CRUD_ENUM.INSERT]:t,[wn.PERMS_CRUD_ENUM.UPDATE]:r,[wn.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),xw=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...Z$(t,r,n,s)}),"table_perms_template"),j$=a((e,t=Z$())=>({attribute_name:e,describe:rV(t),[Fp]:t[Fp],[Bw]:t[Bw],[Hw]:t[Hw]}),"attr_perms_template"),J$=a((e,t=!1)=>({attribute_name:e,describe:t,[Fp]:t}),"timestamp_attr_perms_template"),{READ:Fp,INSERT:Bw,UPDATE:Hw}=wn.PERMS_CRUD_ENUM,eV=Object.values(wn.PERMS_CRUD_ENUM),tV=[Fp,Bw,Hw];function Ede(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r={...global.hdb_schema};delete r[wn.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(Il[t]&&Il[t].key===n)return Il[t].perms;let s=gde(e,r);return Il[t]?Il[t].key=n:Il[t]=mde(n),Il[t].perms=s,s}catch(r){if(!e[wn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[wn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<wn.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 Uw.error(n),Uw.debug(r),z$(new Error,pde.OUTDATED_PERMS_TRANSLATION_ERROR,hde.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
28
- ${r.stack}`;throw Uw.error(n),z$(new Error)}}}a(Ede,"getRolePermissions");function gde(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[wn.SYSTEM_SCHEMA_NAME]=n[wn.SYSTEM_SCHEMA_NAME],r.structure_user=n.structure_user;let s=Array.isArray(e.permission.structure_user)||e.permission.structure_user===!0?e.permission.structure_user:[];return Object.keys(t).forEach(i=>{if(s===!0||s.indexOf(i)>-1){r[i]=Sde(t[i]);return}r[i]=X$(),n[i]?(n[i].describe&&(r[i].describe=!0),Object.keys(t[i]).forEach(o=>{if(n[i].tables[o]){let c=n[i].tables[o],l=t[i][o],u=Tde(c,l);r[i].describe||eV.forEach(f=>{u[f]&&(r[i].describe=!0)}),r[i].tables[o]=u}else r[i].tables[o]=xw()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=xw()})}),r}a(gde,"translateRolePermissions");function Sde(e){let t=X$(!0);return Object.keys(e).forEach(r=>{t.tables[r]=xw(!0,!0,!0,!0,!0)}),t}a(Sde,"createStructureUserPermissions");function Tde(e,t){let{attribute_permissions:r}=e;if(r?.length>0){let s={...e};s.attribute_permissions=[];let i=r.reduce((u,f)=>{let{attribute_name:d}=f,p=f;return wn.TIME_STAMP_NAMES.includes(d)&&(p=J$(d,f[Fp])),u[d]=p,u},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=j$(o);return t.attributes.forEach(({attribute:u})=>{if(i[u]){let f=i[u];f.describe=rV(f),s.attribute_permissions.push(f),c||Ade(f,l)}else if(u!==o){let f;wn.TIME_STAMP_NAMES.includes(u)?f=J$(u):f=j$(u),s.attribute_permissions.push(f)}}),c||s.attribute_permissions.push(l),s.describe=Q$(s),s}else return e.describe=Q$(e),e}a(Tde,"getTableAttrPerms");function Q$(e){return eV.filter(t=>e[t]).length>0}a(Q$,"getSchemaTableDescribePerm");function rV(e){return tV.filter(t=>e[t]).length>0}a(rV,"getAttributeDescribePerm");function Ade(e,t){tV.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(Ade,"checkForHashPerms")});var Gp={};ve(Gp,{authentication:()=>dV,bypassAuth:()=>Ide,login:()=>Pde,logout:()=>Dde,start:()=>Cde});function Ide(){uV=!0}async function dV(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let _=e.isOperationsServer?Ode?bde:[]:yde?Rde:[];if(_.includes(i)||_.includes("*")){if(e.method==="OPTIONS"){let h=ns.get(B.HTTP_CORSACCESSCONTROLALLOWHEADERS)??"Accept, Content-Type, Authorization",S=new yo([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers",h],["Access-Control-Allow-Origin",i]]);return LS&&S.set("Access-Control-Allow-Credentials","true"),{status:200,headers:S}}o.push("Access-Control-Allow-Origin",i),LS&&o.push("Access-Control-Allow-Credentials","true")}}let l,u;if(LS){i||(i=r.host);let _=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.split(/;\s+/)||[];for(let S of h)if(S.startsWith(_)){let g=S.indexOf(";");l=S.slice(_.length,g===-1?S.length:g),u=await iV.get(l);break}e.session=u||(u={})}let f=a((_,h,S)=>{let g=new Ld.AuthAuditLog(_,h,la.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);g.auth_strategy=S,l&&(g.session_id=l),r.referer&&(g.referer=r.referer),r.origin&&(g.origin=r.origin),h===Ys.SUCCESS?kw.notify(g):kw.error(g)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&kw.error("Authorization error:",e._nodeRequest.socket.authorizationError),e.mtlsConfig&&e.authorized&&e.peerCertificate.subject){let _=e.mtlsConfig.user;_!==null?((_===void 0||_==="Common Name"||_==="CN")&&(_=e.peerCertificate.subject.CN),e.user=await Ye.getUser(_,null,e),f(_,Ys.SUCCESS,"mTLS")):(0,Ld.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let d;if(!e.user)if(n){if(d=Cl.get(n),!d){let _=n.indexOf(" "),h=n.slice(0,_),S=n.slice(_+1),g,R;try{switch(h){case"Basic":let E=atob(S),T=E.indexOf(":");g=E.slice(0,T),R=E.slice(T+1),d=g||R?await Ye.getUser(g,R,e):null;break;case"Bearer":try{d=await OO(S)}catch(b){if(b.message==="invalid token")try{return await cg(S),c({status:-1})}catch{throw b}}break}}catch(E){return wde&&(Cl.get(S)||(Cl.set(S,S),f(g,Ys.FAILURE,h))),c({status:401,body:Aa({error:E.message},e)})}Cl.set(n,d),Nde&&f(d.username,Ys.SUCCESS,h)}e.user=d}else u?.user?e.user=await Ye.getUser(u.user,null,e):(uV&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,aV.getSuperUser)());LS&&(e.session.update=function(_){if(!l){l=(0,cV.v4)();let S=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${l}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",S):p?.headers?.set&&p.headers.set("Set-Cookie",S)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):p?.headers?.set&&(i&&p.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),p.headers.set("X-Hdb-Session","Secure"))),_.id=l,iV.put(_)},e.login=async function(_,h){let S=e.user=await Ye.authenticateUser(_,h,e);e.session.update({user:S&&(S.getId?.()??S.username)})});let p=await t(e);return p&&(p.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&Oi.loginPath?(p.status=302,p.headers.set("Location",Oi.loginPath(e))):p.headers.set("WWW-Authenticate","Basic")),c(p))}catch(l){throw c(l)}function c(l){let u=o.length;if(u>0){let f=l.headers;f||(l.headers=f=new yo);for(let d=0;d<u;){let p=o[d++];f.set(p,o[d++])}}return o=null,l}a(c,"applyResponseHeaders")}function Cde({server:e,port:t,securePort:r}){e.http(dV,t||r?{port:t,securePort:r}:{port:"all"}),oV||(oV=!0,setInterval(()=>{Cl=new Map},ns.get(B.AUTHENTICATION_CACHETTL)).unref(),lV.user.addListener(()=>{Cl=new Map}))}async function Pde(e){if(!e.baseRequest?.login)throw new Error("No session for login");return e.baseResponse.headers.set=(t,r)=>{e.fastifyResponse.header(t,r)},await e.baseRequest.login(e.username,e.password??""),"Login successful"}async function Dde(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var aV,cV,ns,Ld,lV,kw,Rde,yde,bde,Ode,iV,LS,uV,Nde,wde,Cl,oV,MS=be(()=>{aV=M(An());Vr();Su();ju();Pe();cV=require("uuid"),ns=M(ae());H();Ld=M(z()),lV=M(b_());z_();ao();kw=(0,Ld.loggerWithTag)("auth-event");ns.initSync();Rde=ns.get(B.HTTP_CORSACCESSLIST),yde=ns.get(B.HTTP_CORS),bde=ns.get(B.OPERATIONSAPI_NETWORK_CORSACCESSLIST),Ode=ns.get(B.OPERATIONSAPI_NETWORK_CORS),iV=ft({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),LS=ns.get(B.AUTHENTICATION_ENABLESESSIONS)??!0,uV=process.env.AUTHENTICATION_AUTHORIZELOCAL??ns.get(B.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,Nde=ns.get(B.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,wde=ns.get(B.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,Cl=new Map;Ye.onInvalidatedUser(()=>{Cl=new Map});a(Ide,"bypassAuth");a(dV,"authentication");a(Cde,"start");a(Pde,"login");a(Dde,"logout")});var gV=w((bMe,EV)=>{"use strict";var Ne=require("joi"),fV=require("fs-extra"),_V=require("path"),ss=it(),pV=ae(),hV=(H(),C(G)),mV=z(),{hdb_errors:Lde}=pe(),{HDB_ERROR_MSGS:tn}=Lde,Ho=/^[a-zA-Z0-9-_]+$/,Mde=/^[a-zA-Z0-9-_]+$/;EV.exports={getDropCustomFunctionValidator:Ude,setCustomFunctionValidator:xde,addComponentValidator:Fde,dropCustomFunctionProjectValidator:Gde,packageComponentValidator:qde,deployComponentValidator:$de,setComponentFileValidator:Bde,getComponentFileValidator:kde,dropComponentFileValidator:Hde,addSSHKeyValidator:Vde,updateSSHKeyValidator:Kde,deleteSSHKeyValidator:Yde,setSSHKnownHostsValidator:Wde};function vS(e,t,r){try{let n=pV.get(hV.CONFIG_PARAMS.COMPONENTSROOT),s=_V.join(n,t);return fV.existsSync(s)?e?t:r.message(tn.PROJECT_EXISTS):e?r.message(tn.NO_PROJECT):t}catch(n){return mV.error(n),r.message(tn.VALIDATION_ERR)}}a(vS,"checkProjectExists");function qp(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(qp,"checkFilePath");function vde(e,t,r,n){try{let s=pV.get(hV.CONFIG_PARAMS.COMPONENTSROOT),i=_V.join(s,e,t,r+".js");return fV.existsSync(i)?r:n.message(tn.NO_FILE)}catch(s){return mV.error(s),n.message(tn.VALIDATION_ERR)}}a(vde,"checkFileExists");function Ude(e){let t=Ne.object({project:Ne.string().pattern(Ho).custom(vS.bind(null,!0)).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().pattern(Ho).custom(vde.bind(null,e.project,e.type)).custom(qp).required().messages({"string.pattern.base":tn.BAD_FILE_NAME})});return ss.validateBySchema(e,t)}a(Ude,"getDropCustomFunctionValidator");function xde(e){let t=Ne.object({project:Ne.string().pattern(Ho).custom(vS.bind(null,!0)).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().custom(qp).required(),function_content:Ne.string().required()});return ss.validateBySchema(e,t)}a(xde,"setCustomFunctionValidator");function Bde(e){let t=Ne.object({project:Ne.string().pattern(Ho).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),file:Ne.string().custom(qp).required(),payload:Ne.string().allow("").optional(),encoding:Ne.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return ss.validateBySchema(e,t)}a(Bde,"setComponentFileValidator");function Hde(e){let t=Ne.object({project:Ne.string().pattern(Ho).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),file:Ne.string().custom(qp).optional()});return ss.validateBySchema(e,t)}a(Hde,"dropComponentFileValidator");function kde(e){let t=Ne.object({project:Ne.string().required(),file:Ne.string().custom(qp).required(),encoding:Ne.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return ss.validateBySchema(e,t)}a(kde,"getComponentFileValidator");function Fde(e){let t=Ne.object({project:Ne.string().pattern(Ho).custom(vS.bind(null,!1)).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME})});return ss.validateBySchema(e,t)}a(Fde,"addComponentValidator");function Gde(e){let t=Ne.object({project:Ne.string().pattern(Ho).custom(vS.bind(null,!0)).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME})});return ss.validateBySchema(e,t)}a(Gde,"dropCustomFunctionProjectValidator");function qde(e){let t=Ne.object({project:Ne.string().pattern(Ho).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),skip_node_modules:Ne.boolean(),skip_symlinks:Ne.boolean()});return ss.validateBySchema(e,t)}a(qde,"packageComponentValidator");function $de(e){let t=Ne.object({project:Ne.string().pattern(Ho).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),package:Ne.string().optional(),restart:Ne.alternatives().try(Ne.boolean(),Ne.string().valid("rolling")).optional()});return ss.validateBySchema(e,t)}a($de,"deployComponentValidator");function Vde(e){let t=Ne.object({name:Ne.string().pattern(Mde).required().messages({"string.pattern.base":tn.BAD_SSH_KEY_NAME}),key:Ne.string().required(),host:Ne.string().required(),hostname:Ne.string().required(),known_hosts:Ne.string().optional()});return ss.validateBySchema(e,t)}a(Vde,"addSSHKeyValidator");function Kde(e){let t=Ne.object({name:Ne.string().required(),key:Ne.string().required()});return ss.validateBySchema(e,t)}a(Kde,"updateSSHKeyValidator");function Yde(e){let t=Ne.object({name:Ne.string().required()});return ss.validateBySchema(e,t)}a(Yde,"deleteSSHKeyValidator");function Wde(e){let t=Ne.object({known_hosts:Ne.string().required()});return ss.validateBySchema(e,t)}a(Wde,"setSSHKnownHostsValidator")});var Kp=w((NMe,bV)=>{"use strict";var US=require("joi"),za=require("path"),Md=require("fs-extra"),{exec:zde}=require("child_process"),jde=require("util"),SV=jde.promisify(zde),vd=(H(),C(G)),{PACKAGE_ROOT:Jde}=st(),{handleHDBError:$p,hdb_errors:Qde}=pe(),{HTTP_STATUS_CODES:Vp}=Qde,Pl=ae(),Xde=it(),Dl=z();Pl.initSync();var Fw=Pl.get(vd.CONFIG_PARAMS.COMPONENTSROOT),TV="npm install --force --omit=dev --json",Zde=`${TV} --dry-run`,efe=Pl.get(vd.CONFIG_PARAMS.ROOTPATH),xS=za.join(efe,"ssh");bV.exports={installModules:sfe,auditModules:ife,installAllRootModules:tfe,uninstallRootModule:rfe,linkHarperdb:nfe,runCommand:Ud};async function tfe(e=!1,t=Pl.get(vd.CONFIG_PARAMS.ROOTPATH)){await BS();let r=!1,n=process.env;Md.pathExistsSync(xS)&&Md.readdirSync(xS).forEach(s=>{s.includes(".key")&&!r&&(n={GIT_SSH_COMMAND:"ssh -F "+za.join(xS,"config")+" -o UserKnownHostsFile="+za.join(xS,"known_hosts"),...process.env},r=!0)});try{let s=Pl.get(vd.CONFIG_PARAMS.ROOTPATH),i=za.join(s,"node_modules","harperdb");Md.lstatSync(i).isSymbolicLink()&&Md.unlinkSync(i)}catch(s){s.code!=="ENOENT"&&Dl.error("Error removing symlink:",s)}await Ud(e?"npm install --force --ignore-scripts --no-bin-links":"npm install --force --no-bin-links",t,n)}a(tfe,"installAllRootModules");async function rfe(e){await Ud(`npm uninstall ${e}`,Pl.get(vd.CONFIG_PARAMS.ROOTPATH))}a(rfe,"uninstallRootModule");async function nfe(){await BS(),await Ud(`npm link ${Jde}`,Pl.get(vd.CONFIG_PARAMS.ROOTPATH))}a(nfe,"linkHarperdb");async function Ud(e,t=void 0,r=process.env){let n,s;try{({stdout:n,stderr:s}=await SV(e,{cwd:t,env:r}))}catch(i){throw new Error(i.stderr.replace(`
29
- `,""))}return s&&!s.includes("Debugger listening")&&!s.includes("warn using --force")&&Dl.error("Error running NPM command:",e,s),Dl.trace(n,s),n?.replace(`
30
- `,"")}a(Ud,"runCommand");async function sfe(e){let t="install_node_modules is deprecated. Dependencies are automatically installed on deploy, and install_node_modules can lead to inconsistent behavior";Dl.warn(t,e);let r=yV(e);if(r)throw $p(r,r.message,Vp.BAD_REQUEST);let{projects:n,dry_run:s}=e,i=s===!0?Zde:TV;await BS(),await RV(n);let o={};for(let c=0,l=n.length;c<l;c++){let u=n[c];o[u]={npm_output:null,npm_error:null};let f=za.join(Fw,u),d,p=null;try{let{stdout:_,stderr:h}=await SV(i,{cwd:f});d=_?_.replace(`
27
+ Database backup has not been removed and can be found here: ${s}`;Wa.error(l),console.error(l)}(0,Pw.get)(x.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||o===!1||(console.log("Removing backup",s),await(0,Dl.remove)(s))}}async function U$(e){let t=await(0,k$.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}async function F$(e,t){console.log("copyDb start");let r=Xe()[e],n;for(let d in r){n=r[d].primaryStore.rootStore;break}let s=n.dbisDb,i=n.auditStore,o=(0,x$.open)(new B$.default(t)),c=o.openDB(NS.INTERNAL_DBIS_NAME),l,u=0,f=s.useReadTransaction();try{for(let{key:p,value:_}of s.getRange({transaction:f})){let h=_.is_hash_attribute||_.isPrimaryKey,S,g;if(h&&(S=_.compression,g=CS(),g?_.compression=g:delete _.compression,S?.dictionary?.toString()===g?.dictionary?.toString()&&(S=null,g=null)),c.put(p,_),!(h||_.indexed))continue;let R=new H$.default(!h,h);R.encoding="binary",R.compression=S;let E=n.openDB(p,R);E.decoder=null,E.decoderCopies=!1,E.encoding="binary",R.compression=g;let T=o.openDB(p,R);T.encoder=null,console.log("copying",p,"from",e,"to",t),await d(E,T,h,f)}if(i){let p=n.openDB(NS.AUDIT_STORE_NAME,xp);console.log("copying audit log for",e,"to",t),d(i,p,!1,f)}async function d(p,_,h,S){let g=0,R=0,E=1e7,T=null;for(;E-- >0;)try{for(let b of p.getKeys({start:T,transaction:S}))try{T=b;let{value:v,version:F}=p.getEntry(b,{transaction:S});l=_.put(b,v,h?F:void 0),g++,S.openTimer&&(S.openTimer=0),R+=(b?.length||10)+v.length,u++>5e3&&(await l,console.log("copied",g,"entries",R,"bytes"),u=0)}catch(v){console.error("Error copying record",typeof b=="symbol"?"symbol":b,"from",e,"to",t,v)}console.log("finish copying, copied",g,"entries",R,"bytes");return}catch{if(typeof T=="string"){if(T==="z")return console.error("Reached end of dbi",T,"for",e,"to",t);T=T.slice(0,-2)+"z"}else if(typeof T=="number")T++;else return console.error("Unknown key type",T,"for",e,"to",t)}}a(d,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{f.done(),o.close()}}var x$,OS,Dl,Pw,B$,H$,NS,k$,Dw,Wa,IS=be(()=>{De();x$=require("lmdb"),OS=require("path"),Dl=require("fs-extra"),Pw=M(ae()),B$=M(i_()),H$=M(s_()),NS=M(xt());H();fo();k$=M(go()),Dw=M(yt()),Wa=M(z());a(ede,"compactOnStart");a(U$,"getTotalDBRecordCount");a(F$,"copyDb")});var za=w((pMe,W$)=>{"use strict";var tde=require("minimist"),{isMainThread:Mw,parentPort:Hp,threadId:dMe}=require("worker_threads"),at=(H(),C(G)),Vi=z(),vw=ie(),DS=TS(),PS=ir(),fMe=Tt(),V$=yt(),di=Pd(),G$=Po(),{compactOnStart:rde}=(IS(),C(wS)),nde=ua(),{restartWorkers:LS,onMessageByType:sde}=rt(),{handleHDBError:ide,hdb_errors:ode}=pe(),{HTTP_STATUS_CODES:ade}=ode,kp=ae(),{sendOperationToNode:q$,getThisNodeName:cde,monitorNodeCAs:lde}=(Xn(),C(wo)),{getHDBNodeTable:_Me}=(pl(),C(jO));kp.initSync();var Bp=`Restarting HarperDB. This may take up to ${at.RESTART_TIMEOUT_MS/1e3} seconds.`,ude="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",$$="Clustering is not enabled so cannot be restarted",dde="Invalid service",Ld,Is;W$.exports={restart:K$,restartService:Uw};Mw&&sde(at.ITC_EVENT_TYPES.RESTART,async(e,t)=>{e.workerType?await Uw({service:e.workerType}):K$({operation:"restart"}),t.postMessage({type:"restart-complete"})});async function K$(e){Is=Object.keys(e).length===0,Ld=await di.isServiceRegistered(at.PROCESS_DESCRIPTORS.HDB);let t=tde(process.argv);if(t.service){await Uw(t);return}if(Is&&!Ld){console.error(ude);return}if(Is&&console.log(Bp),Ld){di.enterPM2Mode(),Vi.notify(Bp);let r=nde(Object.keys(at.CONFIG_PARAM_MAP),!0);return vw.isEmptyOrZeroLength(Object.keys(r))||V$.updateConfigValue(void 0,void 0,r,!0,!0),fde(),Bp}return Mw?(Vi.notify(Bp),kp.get(at.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await rde(),process.env.HARPER_EXIT_ON_RESTART&&process.exit(0),setTimeout(()=>{LS()},50)):Hp.postMessage({type:at.ITC_EVENT_TYPES.RESTART}),Bp}a(K$,"restart");async function Uw(e){let{service:t}=e;if(at.HDB_PROCESS_SERVICES[t]===void 0)throw ide(new Error,dde,ade.BAD_REQUEST,void 0,void 0,!0);if(di.expectedRestartOfChildren(),Ld=await di.isServiceRegistered(at.PROCESS_DESCRIPTORS.HDB),!Mw){e.replicated&&lde(),Hp.postMessage({type:at.ITC_EVENT_TYPES.RESTART,workerType:t}),Hp.ref(),await new Promise(s=>{Hp.on("message",i=>{i.type==="restart-complete"&&(s(),Hp.unref())})});let n;if(e.replicated){e.replicated=!1,n=[];for(let s of server.nodes){if(s.name===cde())continue;let{job_id:i}=await q$(s,e);n.push(await new Promise((o,c)=>{let u=2400,f=setInterval(async()=>{if(u--<=0){clearInterval(f);let _=new Error("Timed out waiting for restart job to complete");_.replicated=n,c(_)}let p=(await q$(s,{operation:"get_job",id:i})).results[0];if(p.status==="COMPLETE"&&(clearInterval(f),o({node:s.name,message:p.message})),p.status==="ERROR"){clearInterval(f);let _=new Error(p.message);_.replicated=n,c(_)}},250)}))}return{replicated:n}}return}let r;switch(t){case at.HDB_PROCESS_SERVICES.clustering:if(!kp.get(at.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=$$;break}Is&&console.log("Restarting clustering"),Vi.notify("Restarting clustering"),await Y$();break;case at.HDB_PROCESS_SERVICES.clustering_config:case at.HDB_PROCESS_SERVICES["clustering config"]:if(!kp.get(at.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=$$;break}Is&&console.log("Restarting clustering_config"),Vi.notify("Restarting clustering_config"),await di.reloadClustering();break;case"custom_functions":case"custom functions":case at.HDB_PROCESS_SERVICES.harperdb:case at.HDB_PROCESS_SERVICES.http_workers:case at.HDB_PROCESS_SERVICES.http:if(Is&&!Ld){r=`Restart ${t} is not available from the CLI when running in non-pm2 mode. Either call restart ${t} from the API or stop and start HarperDB.`;break}Is&&console.log("Restarting http_workers"),Vi.notify("Restarting http_workers"),Is?await di.restart(at.PROCESS_DESCRIPTORS.HDB):await LS("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(Vi.error(r),Is&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(Uw,"restartService");async function fde(){await Y$(),await di.restart(at.PROCESS_DESCRIPTORS.HDB),await vw.async_set_timeout(2e3),kp.get(at.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await Lw(),Is&&(await PS.closeConnection(),process.exit(0))}a(fde,"restartPM2Mode");async function Y$(){if(!V$.getConfigFromFile(at.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await G$.getHDBProcessInfo()).clustering.length===0)Vi.trace("Clustering not running, restart will start clustering services"),await DS.generateNatsConfig(!0),await di.startClusteringProcesses(),await di.startClusteringThreads(),await Lw(),Is&&await PS.closeConnection();else{await DS.generateNatsConfig(!0),Ld?(Vi.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await di.restart(at.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await di.restart(at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await G$.getHDBProcessInfo()).clustering.forEach(s=>{Vi.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await vw.async_set_timeout(3e3),await Lw(),await PS.updateLocalStreams(),Is&&await PS.closeConnection(),Vi.trace("Restart clustering restarting ingest and reply service threads");let t=LS(at.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=LS(at.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(Y$,"restartClustering");async function Lw(){await DS.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await DS.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(Lw,"removeNatsConfig")});var sV=w((EMe,nV)=>{"use strict";var mMe=require("lodash"),In=(H(),C(G)),{handleHDBError:z$,hdb_errors:_de}=pe(),{HDB_ERROR_MSGS:pde,HTTP_STATUS_CODES:hde}=_de,xw=z();nV.exports={getRolePermissions:Ede};var Ll=Object.create(null),mde=a(e=>({key:e,perms:{}}),"perms_template_obj"),X$=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),Z$=a((e=!1,t=!1,r=!1,n=!1)=>({[In.PERMS_CRUD_ENUM.READ]:e,[In.PERMS_CRUD_ENUM.INSERT]:t,[In.PERMS_CRUD_ENUM.UPDATE]:r,[In.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),Bw=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...Z$(t,r,n,s)}),"table_perms_template"),j$=a((e,t=Z$())=>({attribute_name:e,describe:rV(t),[Fp]:t[Fp],[Hw]:t[Hw],[kw]:t[kw]}),"attr_perms_template"),J$=a((e,t=!1)=>({attribute_name:e,describe:t,[Fp]:t}),"timestamp_attr_perms_template"),{READ:Fp,INSERT:Hw,UPDATE:kw}=In.PERMS_CRUD_ENUM,eV=Object.values(In.PERMS_CRUD_ENUM),tV=[Fp,Hw,kw];function Ede(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r={...global.hdb_schema};delete r[In.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(Ll[t]&&Ll[t].key===n)return Ll[t].perms;let s=gde(e,r);return Ll[t]?Ll[t].key=n:Ll[t]=mde(n),Ll[t].perms=s,s}catch(r){if(!e[In.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[In.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<In.PERMS_UPDATE_RELEASE_TIMESTAMP){let n=`Role permissions for role '${t}' must be updated to align with new structure from the 2.2.0 release.`;throw xw.error(n),xw.debug(r),z$(new Error,pde.OUTDATED_PERMS_TRANSLATION_ERROR,hde.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
28
+ ${r.stack}`;throw xw.error(n),z$(new Error)}}}a(Ede,"getRolePermissions");function gde(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[In.SYSTEM_SCHEMA_NAME]=n[In.SYSTEM_SCHEMA_NAME],r.structure_user=n.structure_user;let s=Array.isArray(e.permission.structure_user)||e.permission.structure_user===!0?e.permission.structure_user:[];return Object.keys(t).forEach(i=>{if(s===!0||s.indexOf(i)>-1){r[i]=Sde(t[i]);return}r[i]=X$(),n[i]?(n[i].describe&&(r[i].describe=!0),Object.keys(t[i]).forEach(o=>{if(n[i].tables[o]){let c=n[i].tables[o],l=t[i][o],u=Tde(c,l);r[i].describe||eV.forEach(f=>{u[f]&&(r[i].describe=!0)}),r[i].tables[o]=u}else r[i].tables[o]=Bw()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=Bw()})}),r}a(gde,"translateRolePermissions");function Sde(e){let t=X$(!0);return Object.keys(e).forEach(r=>{t.tables[r]=Bw(!0,!0,!0,!0,!0)}),t}a(Sde,"createStructureUserPermissions");function Tde(e,t){let{attribute_permissions:r}=e;if(r?.length>0){let s={...e};s.attribute_permissions=[];let i=r.reduce((u,f)=>{let{attribute_name:d}=f,p=f;return In.TIME_STAMP_NAMES.includes(d)&&(p=J$(d,f[Fp])),u[d]=p,u},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=j$(o);return t.attributes.forEach(({attribute:u})=>{if(i[u]){let f=i[u];f.describe=rV(f),s.attribute_permissions.push(f),c||Ade(f,l)}else if(u!==o){let f;In.TIME_STAMP_NAMES.includes(u)?f=J$(u):f=j$(u),s.attribute_permissions.push(f)}}),c||s.attribute_permissions.push(l),s.describe=Q$(s),s}else return e.describe=Q$(e),e}a(Tde,"getTableAttrPerms");function Q$(e){return eV.filter(t=>e[t]).length>0}a(Q$,"getSchemaTableDescribePerm");function rV(e){return tV.filter(t=>e[t]).length>0}a(rV,"getAttributeDescribePerm");function Ade(e,t){tV.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(Ade,"checkForHashPerms")});var Gp={};ve(Gp,{authentication:()=>dV,bypassAuth:()=>Ide,login:()=>Pde,logout:()=>Dde,start:()=>Cde});function Ide(){uV=!0}async function dV(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let _=e.isOperationsServer?Ode?bde:[]:yde?Rde:[];if(_.includes(i)||_.includes("*")){if(e.method==="OPTIONS"){let h=ns.get(x.HTTP_CORSACCESSCONTROLALLOWHEADERS)??"Accept, Content-Type, Authorization",S=new yo([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers",h],["Access-Control-Allow-Origin",i]]);return MS&&S.set("Access-Control-Allow-Credentials","true"),{status:200,headers:S}}o.push("Access-Control-Allow-Origin",i),MS&&o.push("Access-Control-Allow-Credentials","true")}}let l,u;if(MS){i||(i=r.host);let _=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.split(/;\s+/)||[];for(let S of h)if(S.startsWith(_)){let g=S.indexOf(";");l=S.slice(_.length,g===-1?S.length:g),u=await iV.get(l);break}e.session=u||(u={})}let f=a((_,h,S)=>{let g=new Md.AuthAuditLog(_,h,la.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);g.auth_strategy=S,l&&(g.session_id=l),r.referer&&(g.referer=r.referer),r.origin&&(g.origin=r.origin),h===Ys.SUCCESS?Fw.notify(g):Fw.error(g)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&Fw.error("Authorization error:",e._nodeRequest.socket.authorizationError),e.mtlsConfig&&e.authorized&&e.peerCertificate.subject){let _=e.mtlsConfig.user;_!==null?((_===void 0||_==="Common Name"||_==="CN")&&(_=e.peerCertificate.subject.CN),e.user=await We.getUser(_,null,e),f(_,Ys.SUCCESS,"mTLS")):(0,Md.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let d;if(!e.user)if(n){if(d=Ml.get(n),!d){let _=n.indexOf(" "),h=n.slice(0,_),S=n.slice(_+1),g,R;try{switch(h){case"Basic":let E=atob(S),T=E.indexOf(":");g=E.slice(0,T),R=E.slice(T+1),d=g||R?await We.getUser(g,R,e):null;break;case"Bearer":try{d=await NO(S)}catch(b){if(b.message==="invalid token")try{return await lg(S),c({status:-1})}catch{throw b}}break}}catch(E){return wde&&(Ml.get(S)||(Ml.set(S,S),f(g,Ys.FAILURE,h))),c({status:401,body:Aa({error:E.message},e)})}Ml.set(n,d),Nde&&f(d.username,Ys.SUCCESS,h)}e.user=d}else u?.user?e.user=await We.getUser(u.user,null,e):(uV&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,aV.getSuperUser)());MS&&(e.session.update=function(_){if(!l){l=(0,cV.v4)();let S=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${l}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",S):p?.headers?.set&&p.headers.set("Set-Cookie",S)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):p?.headers?.set&&(i&&p.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),p.headers.set("X-Hdb-Session","Secure"))),_.id=l,iV.put(_)},e.login=async function(_,h){let S=e.user=await We.authenticateUser(_,h,e);e.session.update({user:S&&(S.getId?.()??S.username)})});let p=await t(e);return p&&(p.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&Oi.loginPath?(p.status=302,p.headers.set("Location",Oi.loginPath(e))):p.headers.set("WWW-Authenticate","Basic")),c(p))}catch(l){throw c(l)}function c(l){let u=o.length;if(u>0){let f=l.headers;f||(l.headers=f=new yo);for(let d=0;d<u;){let p=o[d++];f.set(p,o[d++])}}return o=null,l}a(c,"applyResponseHeaders")}function Cde({server:e,port:t,securePort:r}){e.http(dV,t||r?{port:t,securePort:r}:{port:"all"}),oV||(oV=!0,setInterval(()=>{Ml=new Map},ns.get(x.AUTHENTICATION_CACHETTL)).unref(),lV.user.addListener(()=>{Ml=new Map}))}async function Pde(e){if(!e.baseRequest?.login)throw new Error("No session for login");return e.baseResponse.headers.set=(t,r)=>{e.fastifyResponse.header(t,r)},await e.baseRequest.login(e.username,e.password??""),"Login successful"}async function Dde(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var aV,cV,ns,Md,lV,Fw,Rde,yde,bde,Ode,iV,MS,uV,Nde,wde,Ml,oV,vS=be(()=>{aV=M(Rn());Vr();Tu();Ju();De();cV=require("uuid"),ns=M(ae());H();Md=M(z()),lV=M(b_());z_();ao();Fw=(0,Md.loggerWithTag)("auth-event");ns.initSync();Rde=ns.get(x.HTTP_CORSACCESSLIST),yde=ns.get(x.HTTP_CORS),bde=ns.get(x.OPERATIONSAPI_NETWORK_CORSACCESSLIST),Ode=ns.get(x.OPERATIONSAPI_NETWORK_CORS),iV=ft({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),MS=ns.get(x.AUTHENTICATION_ENABLESESSIONS)??!0,uV=process.env.AUTHENTICATION_AUTHORIZELOCAL??ns.get(x.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,Nde=ns.get(x.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,wde=ns.get(x.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,Ml=new Map;We.onInvalidatedUser(()=>{Ml=new Map});a(Ide,"bypassAuth");a(dV,"authentication");a(Cde,"start");a(Pde,"login");a(Dde,"logout")});var gV=w((wMe,EV)=>{"use strict";var Ne=require("joi"),fV=require("fs-extra"),_V=require("path"),ss=ot(),pV=ae(),hV=(H(),C(G)),mV=z(),{hdb_errors:Lde}=pe(),{HDB_ERROR_MSGS:tn}=Lde,Ho=/^[a-zA-Z0-9-_]+$/,Mde=/^[a-zA-Z0-9-_]+$/;EV.exports={getDropCustomFunctionValidator:Ude,setCustomFunctionValidator:xde,addComponentValidator:Fde,dropCustomFunctionProjectValidator:Gde,packageComponentValidator:qde,deployComponentValidator:$de,setComponentFileValidator:Bde,getComponentFileValidator:kde,dropComponentFileValidator:Hde,addSSHKeyValidator:Vde,updateSSHKeyValidator:Kde,deleteSSHKeyValidator:Yde,setSSHKnownHostsValidator:Wde};function US(e,t,r){try{let n=pV.get(hV.CONFIG_PARAMS.COMPONENTSROOT),s=_V.join(n,t);return fV.existsSync(s)?e?t:r.message(tn.PROJECT_EXISTS):e?r.message(tn.NO_PROJECT):t}catch(n){return mV.error(n),r.message(tn.VALIDATION_ERR)}}a(US,"checkProjectExists");function qp(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(qp,"checkFilePath");function vde(e,t,r,n){try{let s=pV.get(hV.CONFIG_PARAMS.COMPONENTSROOT),i=_V.join(s,e,t,r+".js");return fV.existsSync(i)?r:n.message(tn.NO_FILE)}catch(s){return mV.error(s),n.message(tn.VALIDATION_ERR)}}a(vde,"checkFileExists");function Ude(e){let t=Ne.object({project:Ne.string().pattern(Ho).custom(US.bind(null,!0)).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().pattern(Ho).custom(vde.bind(null,e.project,e.type)).custom(qp).required().messages({"string.pattern.base":tn.BAD_FILE_NAME})});return ss.validateBySchema(e,t)}a(Ude,"getDropCustomFunctionValidator");function xde(e){let t=Ne.object({project:Ne.string().pattern(Ho).custom(US.bind(null,!0)).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),type:Ne.string().valid("helpers","routes").required(),file:Ne.string().custom(qp).required(),function_content:Ne.string().required()});return ss.validateBySchema(e,t)}a(xde,"setCustomFunctionValidator");function Bde(e){let t=Ne.object({project:Ne.string().pattern(Ho).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),file:Ne.string().custom(qp).required(),payload:Ne.string().allow("").optional(),encoding:Ne.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return ss.validateBySchema(e,t)}a(Bde,"setComponentFileValidator");function Hde(e){let t=Ne.object({project:Ne.string().pattern(Ho).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),file:Ne.string().custom(qp).optional()});return ss.validateBySchema(e,t)}a(Hde,"dropComponentFileValidator");function kde(e){let t=Ne.object({project:Ne.string().required(),file:Ne.string().custom(qp).required(),encoding:Ne.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return ss.validateBySchema(e,t)}a(kde,"getComponentFileValidator");function Fde(e){let t=Ne.object({project:Ne.string().pattern(Ho).custom(US.bind(null,!1)).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME})});return ss.validateBySchema(e,t)}a(Fde,"addComponentValidator");function Gde(e){let t=Ne.object({project:Ne.string().pattern(Ho).custom(US.bind(null,!0)).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME})});return ss.validateBySchema(e,t)}a(Gde,"dropCustomFunctionProjectValidator");function qde(e){let t=Ne.object({project:Ne.string().pattern(Ho).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),skip_node_modules:Ne.boolean(),skip_symlinks:Ne.boolean()});return ss.validateBySchema(e,t)}a(qde,"packageComponentValidator");function $de(e){let t=Ne.object({project:Ne.string().pattern(Ho).required().messages({"string.pattern.base":tn.BAD_PROJECT_NAME}),package:Ne.string().optional(),restart:Ne.alternatives().try(Ne.boolean(),Ne.string().valid("rolling")).optional()});return ss.validateBySchema(e,t)}a($de,"deployComponentValidator");function Vde(e){let t=Ne.object({name:Ne.string().pattern(Mde).required().messages({"string.pattern.base":tn.BAD_SSH_KEY_NAME}),key:Ne.string().required(),host:Ne.string().required(),hostname:Ne.string().required(),known_hosts:Ne.string().optional()});return ss.validateBySchema(e,t)}a(Vde,"addSSHKeyValidator");function Kde(e){let t=Ne.object({name:Ne.string().required(),key:Ne.string().required()});return ss.validateBySchema(e,t)}a(Kde,"updateSSHKeyValidator");function Yde(e){let t=Ne.object({name:Ne.string().required()});return ss.validateBySchema(e,t)}a(Yde,"deleteSSHKeyValidator");function Wde(e){let t=Ne.object({known_hosts:Ne.string().required()});return ss.validateBySchema(e,t)}a(Wde,"setSSHKnownHostsValidator")});var Kp=w((CMe,yV)=>{"use strict";var xS=require("joi"),ja=require("path"),vd=require("fs-extra"),{exec:zde,spawn:jde}=require("child_process"),Jde=require("util"),Qde=Jde.promisify(zde),Ud=(H(),C(G)),{PACKAGE_ROOT:Xde}=it(),{handleHDBError:$p,hdb_errors:Zde}=pe(),{HTTP_STATUS_CODES:Vp}=Zde,vl=ae(),efe=ot(),Ja=z(),{once:tfe}=require("events");vl.initSync();var Gw=vl.get(Ud.CONFIG_PARAMS.COMPONENTSROOT),SV="npm install --force --omit=dev --json",rfe=`${SV} --dry-run`,nfe=vl.get(Ud.CONFIG_PARAMS.ROOTPATH),BS=ja.join(nfe,"ssh");yV.exports={installModules:afe,auditModules:cfe,installAllRootModules:sfe,uninstallRootModule:ife,linkHarperdb:ofe,runCommand:xd};async function sfe(e=!1,t=vl.get(Ud.CONFIG_PARAMS.ROOTPATH)){await HS();let r=!1,n=process.env;vd.pathExistsSync(BS)&&vd.readdirSync(BS).forEach(s=>{s.includes(".key")&&!r&&(n={GIT_SSH_COMMAND:"ssh -F "+ja.join(BS,"config")+" -o UserKnownHostsFile="+ja.join(BS,"known_hosts"),...process.env},r=!0)});try{let s=vl.get(Ud.CONFIG_PARAMS.ROOTPATH),i=ja.join(s,"node_modules","harperdb");vd.lstatSync(i).isSymbolicLink()&&vd.unlinkSync(i)}catch(s){s.code!=="ENOENT"&&Ja.error("Error removing symlink:",s)}await xd(e?"npm install --force --ignore-scripts --no-bin-links":"npm install --force --no-bin-links",t,n)}a(sfe,"installAllRootModules");async function ife(e){await xd(`npm uninstall ${e}`,vl.get(Ud.CONFIG_PARAMS.ROOTPATH))}a(ife,"uninstallRootModule");async function ofe(){await HS(),await xd(`npm link ${Xde}`,vl.get(Ud.CONFIG_PARAMS.ROOTPATH))}a(ofe,"linkHarperdb");async function xd(e,t=void 0,r=process.env){Ja.debug({tagName:"npm_run_command"},`running command: \`${e}\``);let n=jde(e,{shell:!0,cwd:t,env:r,stdio:["ignore","pipe","pipe"]}),s="",i="";n.stdout.on("data",c=>{let l=c.toString();Ja.debug({tagName:"npm_run_command:stdout"},l),s+=l}),n.stderr.on("data",c=>{let l=c.toString();Ja.error({tagName:"npm_run_command:stderr"},l),i+=l});let[o]=await tfe(n,"close");if(o!==0)throw new Error(`Command \`${e}\` exited with code ${o}.${i===""?"":` Error: ${i}`}`);return s||void 0}a(xd,"runCommand");async function afe(e){let t="install_node_modules is deprecated. Dependencies are automatically installed on deploy, and install_node_modules can lead to inconsistent behavior";Ja.warn(t,e);let r=RV(e);if(r)throw $p(r,r.message,Vp.BAD_REQUEST);let{projects:n,dry_run:s}=e,i=s===!0?rfe:SV;await HS(),await AV(n);let o={};for(let c=0,l=n.length;c<l;c++){let u=n[c];o[u]={npm_output:null,npm_error:null};let f=ja.join(Gw,u),d,p=null;try{let{stdout:_,stderr:h}=await Qde(i,{cwd:f});d=_?_.replace(`
31
29
  `,""):null,p=h?h.replace(`
32
- `,""):null}catch(_){_.stderr?o[u].npm_error=AV(_.stderr):o[u].npm_error=_.message;continue}try{o[u].npm_output=JSON.parse(d)}catch{o[u].npm_output=d}try{o[u].npm_error=JSON.parse(p)}catch{o[u].npm_error=p}}return Dl.info(`finished installModules with response ${o}`),o.warning=t,o}a(sfe,"installModules");function AV(e){let t='"error": {',r=e.indexOf('"error": {'),n=e.indexOf(`}
33
- `);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(AV,"parseNPMStdErr");async function ife(e){Dl.info(`starting auditModules for request: ${e}`);let t=yV(e);if(t)throw $p(t,t.message,Vp.BAD_REQUEST);let{projects:r}=e;await BS(),await RV(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=za.join(Fw,o);n[o]={npm_output:null,npm_error:null};try{let l=await Ud("npm audit --json",c);n[o].npm_output=JSON.parse(l)}catch(l){n[o].npm_error=AV(l.stderr)}}return Dl.info(`finished auditModules with response ${n}`),n}a(ife,"auditModules");async function BS(){return await Ud("npm -v"),!0}a(BS,"checkNPMInstalled");async function RV(e){if(!Array.isArray(e)||e.length===0)throw $p(new Error,"projects argument must be an array with at least 1 element",Vp.BAD_REQUEST,void 0,void 0,!0);let t=[],r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n],o=za.join(Fw,i.toString());if(!await Md.pathExists(o)){t.push(i);continue}let l=za.join(o,"package.json");await Md.pathExists(l)||r.push(i)}if(t.length>0)throw $p(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,Vp.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw $p(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,Vp.BAD_REQUEST,void 0,void 0,!0)}a(RV,"checkProjectPaths");function yV(e){let t=US.object({projects:US.array().min(1).items(US.string()).required(),dry_run:US.boolean().default(!1)});return Xde.validateBySchema(e,t)}a(yV,"modulesValidator")});var qw=w((IMe,PV)=>{"use strict";var Cs=require("fs-extra"),Wp=require("path"),Yp=z(),OV=ie(),{PACKAGE_ROOT:ofe}=st(),Gw=(H(),C(G)),CV=ae(),afe=yt();PV.exports=cfe;async function cfe(){let e=lfe(),t=CV.get(Gw.CONFIG_PARAMS.ROOTPATH),r=Wp.join(t,"package.json"),n={dependencies:{harperdb:"file:"+ofe}},s=Wp.join(t,"node_modules");Cs.ensureDirSync(s);let i,o=!0,c=!1;try{i=Cs.readJsonSync(r)}catch(l){if(OV.isEmptyOrZeroLength(e))return;if(l.code!==Gw.NODE_ERROR_CODES.ENOENT)throw l;o=!1}if(!OV.isEmptyOrZeroLength(e)){for(let{name:l,package:u}of e){let f=wV(u);n.dependencies[l]=f+u}if(!o){Yp.notify("Installing components"),await IV(r,n,null),await NV(t,e);return}for(let{name:l,package:u}of e){let f=i.dependencies[l],d=wV(u);if(f===void 0||f!==d+u){c=!0;break}if(u.startsWith("file:"))try{if(Cs.statSync(new URL(u+"/package.json")).mtimeMs>Cs.statSync(r).mtimeMs){c=!0;break}}catch(p){Yp.info(`Error checking ${u}/package.json modification time`,p);break}}}for(let l in i.dependencies)n.dependencies[l]===void 0&&(Yp.notify("Removing component",l),c=!0);c&&(Yp.notify("Updating components."),await IV(r,n,i),await NV(t,e))}a(cfe,"installComponents");function NV(e,t){return Promise.all(t.map(({name:r})=>{let n=Wp.join(e,"node_modules",r),s=Wp.join(e,"components",r);if(Cs.existsSync(n)&&Cs.lstatSync(n).isDirectory())return Cs.move(n,s,{overwrite:!0}).then(()=>{Cs.symlink(s,n)})}))}a(NV,"moveModuleToComponents");function lfe(){let e=afe.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(lfe,"getComponentsConfig");function wV(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":Wp.extname(e)||Cs.existsSync(e)?"file:":"github:"}a(wV,"getPkgPrefix");async function IV(e,t,r){Yp.trace("npm installing components package.json",t),Cs.writeFileSync(e,JSON.stringify(t,null," "));try{await Kp().installAllRootModules(CV.get(Gw.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?Cs.writeFileSync(e,JSON.stringify(r,null," ")):Cs.unlinkSync(e),n}}a(IV,"installPackages")});var $w={};ve($w,{packageDirectory:()=>ufe});function ufe(e,t={skip_node_modules:!1,skip_symlinks:!1}){return new Promise((r,n)=>{let s=[];LV.default.pack(e,{dereference:!t.skip_symlinks,ignore:t.skip_node_modules?i=>i.includes("node_modules")||i.includes((0,DV.join)("cache","webpack")):void 0}).pipe((0,MV.createGzip)()).on("data",i=>s.push(i)).on("end",()=>{r(Buffer.concat(s))}).on("error",n)})}var DV,LV,MV,Vw=be(()=>{DV=require("path"),LV=M(require("tar-fs")),MV=require("node:zlib");a(ufe,"packageDirectory")});var Ww=w(BV=>{"use strict";var Oe=require("fs-extra"),Kw=require("fast-glob"),we=require("path"),dfe=require("tar-fs"),ffe=require("gunzip-maybe"),Yw=require("normalize-path"),In=gV(),xt=z(),ct=(H(),C(G)),Jt=ae(),HS=yt(),_fe=ie(),{PACKAGE_ROOT:pfe}=st(),{handleHDBError:Bt,hdb_errors:hfe}=pe(),{basename:mfe}=require("path"),Efe=qw(),UV=ae(),{Readable:gfe}=require("stream"),{isMainThread:Sfe}=require("worker_threads"),{HDB_ERROR_MSGS:Ll,HTTP_STATUS_CODES:Ht}=hfe,xV=et(),{replicateOperation:fi}=(Xn(),C(wo)),{packageDirectory:Tfe}=(Vw(),C($w)),vV=Kp(),Afe=we.join(pfe,"application-template"),Rfe=Jt.get(ct.CONFIG_PARAMS.ROOTPATH),ja=we.join(Rfe,"ssh"),ko=we.join(ja,"known_hosts");function yfe(){xt.trace("getting custom api status");let e={};try{e={port:Jt.get(ct.CONFIG_PARAMS.HTTP_PORT),directory:Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw Bt(new Error,Ll.FUNCTION_STATUS,Ht.INTERNAL_SERVER_ERROR,xt.ERR,t)}return e}a(yfe,"customFunctionsStatus");function bfe(){xt.trace("getting custom api endpoints");let e={},t=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT);try{Kw.sync(Yw(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:Kw.sync(Yw(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:Kw.sync(Yw(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw Bt(new Error,Ll.GET_FUNCTIONS,Ht.INTERNAL_SERVER_ERROR,xt.ERR,r)}return e}a(bfe,"getCustomFunctions");function Ofe(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=In.getDropCustomFunctionValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);xt.trace("getting custom api endpoint file content");let r=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=we.join(r,n,s,i+".js");try{return Oe.readFileSync(o,{encoding:"utf8"})}catch(c){throw Bt(new Error,Ll.GET_FUNCTION,Ht.INTERNAL_SERVER_ERROR,xt.ERR,c)}}a(Ofe,"getCustomFunction");async function Nfe(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=In.setCustomFunctionValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);xt.trace("setting custom function file content");let r=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{Oe.outputFileSync(we.join(r,n,s,i+".js"),o);let c=await fi(e);return c.message=`Successfully updated custom function: ${i}.js`,c}catch(c){throw Bt(new Error,Ll.SET_FUNCTION,Ht.INTERNAL_SERVER_ERROR,xt.ERR,c)}}a(Nfe,"setCustomFunction");async function wfe(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=In.getDropCustomFunctionValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);xt.trace("dropping custom function file");let r=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{Oe.unlinkSync(we.join(r,n,s,i+".js"));let o=await fi(e);return o.message=`Successfully deleted custom function: ${i}.js`,o}catch(o){throw Bt(new Error,Ll.DROP_FUNCTION,Ht.INTERNAL_SERVER_ERROR,xt.ERR,o)}}a(wfe,"dropCustomFunction");async function Ife(e){e.project&&(e.project=we.parse(e.project).name);let t=In.addComponentValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);xt.trace("adding component");let r=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=we.join(r,n);Oe.mkdirSync(s,{recursive:!0}),Oe.copySync(Afe,s);let i=await fi(e);return i.message=`Successfully added project: ${n}`,i}catch(s){throw Bt(new Error,Ll.ADD_FUNCTION,Ht.INTERNAL_SERVER_ERROR,xt.ERR,s)}}a(Ife,"addComponent");async function Cfe(e){e.project&&(e.project=we.parse(e.project).name);let t=In.dropCustomFunctionProjectValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);xt.trace("dropping custom function project");let r=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=Jt.get(ct.CONFIG_PARAMS.APPS);if(!_fe.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 HS.updateConfigValue(ct.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=we.join(r,n);Oe.rmSync(i,{recursive:!0});let o=await fi(e);return o.message=`Successfully deleted project: ${n}`,o}catch(i){throw Bt(new Error,Ll.DROP_FUNCTION_PROJECT,Ht.INTERNAL_SERVER_ERROR,xt.ERR,i)}}a(Cfe,"dropCustomFunctionProject");async function Pfe(e){e.project&&(e.project=we.parse(e.project).name);let t=In.packageComponentValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);let r=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;xt.trace("packaging component",n);let s;try{s=await Oe.realpath(we.join(r,n))}catch(o){if(o.code!==ct.NODE_ERROR_CODES.ENOENT)throw o;try{s=await Oe.realpath(we.join(Jt.get(ct.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(c){if(c.code===ct.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}let i=(await Tfe(s,e)).toString("base64");return{project:n,payload:i}}a(Pfe,"packageComponent");async function Dfe(e){e.project?e.project=we.parse(e.project).name:e.package&&(e.project=Lfe(e.package));let t=In.deployComponentValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);let r=Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i,install_command:o}=e;if(xt.trace("deploying component",n),!s&&!i)throw new Error("'payload' or 'package' must be provided");let c;if(s){c=we.join(r,n),i="file:"+c,await Oe.emptyDir(c);let S=gfe.from(s instanceof Buffer?s:Buffer.from(s,"base64"));await new Promise((E,T)=>{S.pipe(ffe()).pipe(dfe.extract(c,{finish:E})).on("error",T)});let g=await Oe.readdir(c);g.length===1&&g[0]==="package"&&(await Oe.copy(we.join(c,"package"),c),await Oe.remove(we.join(c,"package")));let R=we.join(c,"node_modules");o?await vV.runCommand(o,c):Oe.existsSync(R)||await vV.installAllRootModules(!1,c)}else{await HS.addConfig(n,{package:i}),await Efe();let S=UV.get(ct.CONFIG_PARAMS.ROOTPATH);c=we.join(S,"node_modules",n)}if(Sfe)return;let l=new Map;l.isWorker=!0;let u=(jp(),C(zp)),f;u.setErrorReporter(S=>f=S);let d=mfe(c),p=u.component_errors.get(d);try{await u.loadComponent(c,l)}finally{u.component_errors.set(d,p)}if(f)throw f;xt.info("Installed component");let _=e.restart==="rolling";e.restart=_?!1:e.restart;let h=await fi(e);if(e.restart===!0)xV.restartWorkers("http"),h.message=`Successfully deployed: ${n}, restarting HarperDB`;else if(_){let g=await zw().executeJob({operation:"restart_service",service:"http",replicated:!0});h.restartJobId=g.job_id,h.message=`Successfully deployed: ${n}, restarting HarperDB`}else h.message=`Successfully deployed: ${n}`;return h}a(Dfe,"deployComponent");function Lfe(e){if(e.startsWith("git+ssh://"))return we.basename(e.split("#")[0].replace(/\.git$/,""));if(e.startsWith("http://")||e.startsWith("https://"))return we.basename(new URL(e.replace(/\.git$/,"")).pathname);if(e.startsWith("file://"))try{let{name:t}=JSON.parse(Oe.readFileSync(we.join(e,"package.json"),"utf8"));return we.basename(t)}catch{}return we.basename(e)}a(Lfe,"getProjectNameFromPackage");async function Mfe(){let e=a(async(s,i)=>{try{let o=await Oe.readdir(s,{withFileTypes:!0});for(let c of o){let l=c.name;if(l.startsWith(".")||l==="node_modules")continue;let u=we.join(s,l);if(c.isDirectory()||c.isSymbolicLink()){let f={name:l,entries:[]};i.entries.push(f),await e(u,f)}else{let f=await Oe.stat(u),d={name:we.basename(l),mtime:f.mtime,size:f.size};i.entries.push(d)}}return i}catch(o){return xt.warn("Error loading package",o),{error:o.toString(),entries:[]}}},"walkDir"),t=await e(Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),{name:Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT).split(we.sep).slice(-1).pop(),entries:[]}),n=(jp(),C(zp)).component_errors;for(let s of t.entries){let i=n.get(s.name);i?s.error=n.get(s.name):i===void 0&&(s.error="The component has not been loaded yet (may need a restart)")}return t}a(Mfe,"getComponents");async function vfe(e){let t=In.getComponentFileValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);let n=HS.getConfigObj()[e.project]||e.project==="harperdb"?we.join(UV.get(ct.CONFIG_PARAMS.ROOTPATH),"node_modules"):Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await Oe.stat(we.join(n,e.project,e.file));return{message:await Oe.readFile(we.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===ct.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${we.join(e.project,e.file)}'`):i}}a(vfe,"getComponentFile");async function Ufe(e){let t=In.setComponentFileValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=we.join(Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);e.payload!==void 0?(await Oe.ensureFile(n),await Oe.outputFile(n,e.payload,r)):await Oe.ensureDir(n);let s=await fi(e);return s.message="Successfully set component: "+e.file,s}a(Ufe,"setComponentFile");async function xfe(e){let t=In.dropComponentFileValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);let{project:r,file:n}=e,s=e.file?we.join(r,n):r,i=we.join(Jt.get(ct.CONFIG_PARAMS.COMPONENTSROOT),s),o=we.join(Jt.get(ct.CONFIG_PARAMS.ROOTPATH),"node_modules",r);await Oe.pathExists(o)&&await Oe.unlink(o),await Oe.pathExists(i)&&await Oe.remove(i);let c=we.join(Jt.get(ct.CONFIG_PARAMS.ROOTPATH),"package.json");if(await Oe.pathExists(c)){let u=JSON.parse(await Oe.readFile(c,"utf8"));u?.dependencies?.[r]&&delete u.dependencies[r],await Oe.writeFile(c,JSON.stringify(u,null,2),"utf8")}HS.deleteConfigFromFile([r]);let l=await fi(e);return e.restart===!0?(xV.restartWorkers("http"),l.message=`Successfully dropped: ${s}, restarting HarperDB`):l.message=`Successfully dropped: ${s}`,l}a(xfe,"dropComponent");async function Bfe(e){let t=In.addSSHKeyValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);let{name:r,key:n,host:s,hostname:i,known_hosts:o}=e;xt.trace("adding ssh key",r);let c=we.join(ja,r+".key"),l=we.join(ja,"config");if(await Oe.pathExists(c))throw new Error("Key already exists. Use update_ssh_key or delete_ssh_key and then add_ssh_key");await Oe.outputFile(c,n),await Oe.chmod(c,"0600");let u=`#${r}
30
+ `,""):null}catch(_){_.stderr?o[u].npm_error=TV(_.stderr):o[u].npm_error=_.message;continue}try{o[u].npm_output=JSON.parse(d)}catch{o[u].npm_output=d}try{o[u].npm_error=JSON.parse(p)}catch{o[u].npm_error=p}}return Ja.info(`finished installModules with response ${o}`),o.warning=t,o}a(afe,"installModules");function TV(e){let t='"error": {',r=e.indexOf('"error": {'),n=e.indexOf(`}
31
+ `);return r>-1&&n>-1?JSON.parse(e.substring(r+t.length-1,n+1)):e}a(TV,"parseNPMStdErr");async function cfe(e){Ja.info(`starting auditModules for request: ${e}`);let t=RV(e);if(t)throw $p(t,t.message,Vp.BAD_REQUEST);let{projects:r}=e;await HS(),await AV(r);let n={};for(let s=0,i=r.length;s<i;s++){let o=r[s],c=ja.join(Gw,o);n[o]={npm_output:null,npm_error:null};try{let l=await xd("npm audit --json",c);n[o].npm_output=JSON.parse(l)}catch(l){n[o].npm_error=TV(l.stderr)}}return Ja.info(`finished auditModules with response ${n}`),n}a(cfe,"auditModules");async function HS(){return await xd("npm -v"),!0}a(HS,"checkNPMInstalled");async function AV(e){if(!Array.isArray(e)||e.length===0)throw $p(new Error,"projects argument must be an array with at least 1 element",Vp.BAD_REQUEST,void 0,void 0,!0);let t=[],r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n],o=ja.join(Gw,i.toString());if(!await vd.pathExists(o)){t.push(i);continue}let l=ja.join(o,"package.json");await vd.pathExists(l)||r.push(i)}if(t.length>0)throw $p(new Error,`Unable to install project dependencies: custom function projects '${t.join(",")}' does not exist.`,Vp.BAD_REQUEST,void 0,void 0,!0);if(r.length>0)throw $p(new Error,`Unable to install project dependencies: custom function projects '${r.join(",")}' do not have a package.json file.`,Vp.BAD_REQUEST,void 0,void 0,!0)}a(AV,"checkProjectPaths");function RV(e){let t=xS.object({projects:xS.array().min(1).items(xS.string()).required(),dry_run:xS.boolean().default(!1)});return efe.validateBySchema(e,t)}a(RV,"modulesValidator")});var $w=w((DMe,CV)=>{"use strict";var Cs=require("fs-extra"),Wp=require("path"),Yp=z(),bV=ie(),{PACKAGE_ROOT:lfe}=it(),qw=(H(),C(G)),IV=ae(),ufe=yt();CV.exports=dfe;async function dfe(){let e=ffe(),t=IV.get(qw.CONFIG_PARAMS.ROOTPATH),r=Wp.join(t,"package.json"),n={dependencies:{harperdb:"file:"+lfe}},s=Wp.join(t,"node_modules");Cs.ensureDirSync(s);let i,o=!0,c=!1;try{i=Cs.readJsonSync(r)}catch(l){if(bV.isEmptyOrZeroLength(e))return;if(l.code!==qw.NODE_ERROR_CODES.ENOENT)throw l;o=!1}if(!bV.isEmptyOrZeroLength(e)){for(let{name:l,package:u}of e){let f=NV(u);n.dependencies[l]=f+u}if(!o){Yp.notify("Installing components"),await wV(r,n,null),await OV(t,e);return}for(let{name:l,package:u}of e){let f=i.dependencies[l],d=NV(u);if(f===void 0||f!==d+u){c=!0;break}if(u.startsWith("file:"))try{if(Cs.statSync(new URL(u+"/package.json")).mtimeMs>Cs.statSync(r).mtimeMs){c=!0;break}}catch(p){Yp.info(`Error checking ${u}/package.json modification time`,p);break}}}for(let l in i.dependencies)n.dependencies[l]===void 0&&(Yp.notify("Removing component",l),c=!0);c&&(Yp.notify("Updating components."),await wV(r,n,i),await OV(t,e))}a(dfe,"installComponents");function OV(e,t){return Promise.all(t.map(({name:r})=>{let n=Wp.join(e,"node_modules",r),s=Wp.join(e,"components",r);if(Cs.existsSync(n)&&Cs.lstatSync(n).isDirectory())return Cs.move(n,s,{overwrite:!0}).then(()=>{Cs.symlink(s,n)})}))}a(OV,"moveModuleToComponents");function ffe(){let e=ufe.getConfiguration(),t=[];for(let r in e)e[r]?.package&&t.push(Object.assign(e[r],{name:r}));return t}a(ffe,"getComponentsConfig");function NV(e){return e.includes(":")?"":e.startsWith("@")||!e.startsWith("@")&&!e.includes("/")?"npm:":Wp.extname(e)||Cs.existsSync(e)?"file:":"github:"}a(NV,"getPkgPrefix");async function wV(e,t,r){Yp.trace("npm installing components package.json",t),Cs.writeFileSync(e,JSON.stringify(t,null," "));try{await Kp().installAllRootModules(IV.get(qw.CONFIG_PARAMS.IGNORE_SCRIPTS)===!0)}catch(n){throw r?Cs.writeFileSync(e,JSON.stringify(r,null," ")):Cs.unlinkSync(e),n}}a(wV,"installPackages")});var Vw={};ve(Vw,{packageDirectory:()=>_fe});function _fe(e,t={skip_node_modules:!1,skip_symlinks:!1}){return new Promise((r,n)=>{let s=[];DV.default.pack(e,{dereference:!t.skip_symlinks,ignore:t.skip_node_modules?i=>i.includes("node_modules")||i.includes((0,PV.join)("cache","webpack")):void 0}).pipe((0,LV.createGzip)()).on("data",i=>s.push(i)).on("end",()=>{r(Buffer.concat(s))}).on("error",n)})}var PV,DV,LV,Kw=be(()=>{PV=require("path"),DV=M(require("tar-fs")),LV=require("node:zlib");a(_fe,"packageDirectory")});var zw=w(xV=>{"use strict";var Oe=require("fs-extra"),Yw=require("fast-glob"),we=require("path"),pfe=require("tar-fs"),hfe=require("gunzip-maybe"),Ww=require("normalize-path"),Cn=gV(),Bt=z(),lt=(H(),C(G)),Qt=ae(),kS=yt(),mfe=ie(),{PACKAGE_ROOT:Efe}=it(),{handleHDBError:Ht,hdb_errors:gfe}=pe(),{basename:Sfe}=require("path"),Tfe=$w(),vV=ae(),{Readable:Afe}=require("stream"),{isMainThread:Rfe}=require("worker_threads"),{HDB_ERROR_MSGS:Ul,HTTP_STATUS_CODES:kt}=gfe,UV=rt(),{replicateOperation:fi}=(Xn(),C(wo)),{packageDirectory:yfe}=(Kw(),C(Vw)),MV=Kp(),bfe=we.join(Efe,"application-template"),Ofe=Qt.get(lt.CONFIG_PARAMS.ROOTPATH),Qa=we.join(Ofe,"ssh"),ko=we.join(Qa,"known_hosts");function Nfe(){Bt.trace("getting custom api status");let e={};try{e={port:Qt.get(lt.CONFIG_PARAMS.HTTP_PORT),directory:Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),is_enabled:!0}}catch(t){throw Ht(new Error,Ul.FUNCTION_STATUS,kt.INTERNAL_SERVER_ERROR,Bt.ERR,t)}return e}a(Nfe,"customFunctionsStatus");function wfe(){Bt.trace("getting custom api endpoints");let e={},t=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT);try{Yw.sync(Ww(`${t}/*`),{onlyDirectories:!0}).forEach(n=>{let s=n.split("/").pop();e[s]={routes:Yw.sync(Ww(`${n}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:Yw.sync(Ww(`${n}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0])}})}catch(r){throw Ht(new Error,Ul.GET_FUNCTIONS,kt.INTERNAL_SERVER_ERROR,Bt.ERR,r)}return e}a(wfe,"getCustomFunctions");function Ife(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Cn.getDropCustomFunctionValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("getting custom api endpoint file content");let r=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e,o=we.join(r,n,s,i+".js");try{return Oe.readFileSync(o,{encoding:"utf8"})}catch(c){throw Ht(new Error,Ul.GET_FUNCTION,kt.INTERNAL_SERVER_ERROR,Bt.ERR,c)}}a(Ife,"getCustomFunction");async function Cfe(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Cn.setCustomFunctionValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("setting custom function file content");let r=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i,function_content:o}=e;try{Oe.outputFileSync(we.join(r,n,s,i+".js"),o);let c=await fi(e);return c.message=`Successfully updated custom function: ${i}.js`,c}catch(c){throw Ht(new Error,Ul.SET_FUNCTION,kt.INTERNAL_SERVER_ERROR,Bt.ERR,c)}}a(Cfe,"setCustomFunction");async function Pfe(e){e.project&&(e.project=we.parse(e.project).name),e.file&&(e.file=we.parse(e.file).name);let t=Cn.getDropCustomFunctionValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("dropping custom function file");let r=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,type:s,file:i}=e;try{Oe.unlinkSync(we.join(r,n,s,i+".js"));let o=await fi(e);return o.message=`Successfully deleted custom function: ${i}.js`,o}catch(o){throw Ht(new Error,Ul.DROP_FUNCTION,kt.INTERNAL_SERVER_ERROR,Bt.ERR,o)}}a(Pfe,"dropCustomFunction");async function Dfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Cn.addComponentValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("adding component");let r=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;try{let s=we.join(r,n);Oe.mkdirSync(s,{recursive:!0}),Oe.copySync(bfe,s);let i=await fi(e);return i.message=`Successfully added project: ${n}`,i}catch(s){throw Ht(new Error,Ul.ADD_FUNCTION,kt.INTERNAL_SERVER_ERROR,Bt.ERR,s)}}a(Dfe,"addComponent");async function Lfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Cn.dropCustomFunctionProjectValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);Bt.trace("dropping custom function project");let r=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e,s=Qt.get(lt.CONFIG_PARAMS.APPS);if(!mfe.isEmptyOrZeroLength(s)){let i=!1;for(let[o,c]of s.entries())if(c.name===n){s.splice(o,1),i=!0;break}if(i)return kS.updateConfigValue(lt.CONFIG_PARAMS.APPS,s),`Successfully deleted project: ${n}`}try{let i=we.join(r,n);Oe.rmSync(i,{recursive:!0});let o=await fi(e);return o.message=`Successfully deleted project: ${n}`,o}catch(i){throw Ht(new Error,Ul.DROP_FUNCTION_PROJECT,kt.INTERNAL_SERVER_ERROR,Bt.ERR,i)}}a(Lfe,"dropCustomFunctionProject");async function Mfe(e){e.project&&(e.project=we.parse(e.project).name);let t=Cn.packageComponentValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let r=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n}=e;Bt.trace("packaging component",n);let s;try{s=await Oe.realpath(we.join(r,n))}catch(o){if(o.code!==lt.NODE_ERROR_CODES.ENOENT)throw o;try{s=await Oe.realpath(we.join(Qt.get(lt.CONFIG_PARAMS.ROOTPATH),"node_modules",n))}catch(c){if(c.code===lt.NODE_ERROR_CODES.ENOENT)throw new Error(`Unable to locate project '${n}'`)}}let i=(await yfe(s,e)).toString("base64");return{project:n,payload:i}}a(Mfe,"packageComponent");async function vfe(e){e.project?e.project=we.parse(e.project).name:e.package&&(e.project=Ufe(e.package));let t=Cn.deployComponentValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let r=Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{project:n,payload:s,package:i,install_command:o}=e;if(Bt.trace("deploying component",n),!s&&!i)throw new Error("'payload' or 'package' must be provided");let c;if(s){c=we.join(r,n),i="file:"+c,await Oe.emptyDir(c);let S=Afe.from(s instanceof Buffer?s:Buffer.from(s,"base64"));await new Promise((E,T)=>{S.pipe(hfe()).pipe(pfe.extract(c,{finish:E})).on("error",T)});let g=await Oe.readdir(c);g.length===1&&g[0]==="package"&&(await Oe.copy(we.join(c,"package"),c),await Oe.remove(we.join(c,"package")));let R=we.join(c,"node_modules");o?await MV.runCommand(o,c):Oe.existsSync(R)||await MV.installAllRootModules(!1,c)}else{await kS.addConfig(n,{package:i}),await Tfe();let S=vV.get(lt.CONFIG_PARAMS.ROOTPATH);c=we.join(S,"node_modules",n)}if(Rfe)return;let l=new Map;l.isWorker=!0;let u=(jp(),C(zp)),f;u.setErrorReporter(S=>f=S);let d=Sfe(c),p=u.component_errors.get(d);try{await u.loadComponent(c,l)}finally{u.component_errors.set(d,p)}if(f)throw f;Bt.info("Installed component");let _=e.restart==="rolling";e.restart=_?!1:e.restart;let h=await fi(e);if(e.restart===!0)UV.restartWorkers("http"),h.message=`Successfully deployed: ${n}, restarting HarperDB`;else if(_){let g=await jw().executeJob({operation:"restart_service",service:"http",replicated:!0});h.restartJobId=g.job_id,h.message=`Successfully deployed: ${n}, restarting HarperDB`}else h.message=`Successfully deployed: ${n}`;return h}a(vfe,"deployComponent");function Ufe(e){if(e.startsWith("git+ssh://"))return we.basename(e.split("#")[0].replace(/\.git$/,""));if(e.startsWith("http://")||e.startsWith("https://"))return we.basename(new URL(e.replace(/\.git$/,"")).pathname);if(e.startsWith("file://"))try{let{name:t}=JSON.parse(Oe.readFileSync(we.join(e,"package.json"),"utf8"));return we.basename(t)}catch{}return we.basename(e)}a(Ufe,"getProjectNameFromPackage");async function xfe(){let e=a(async(s,i)=>{try{let o=await Oe.readdir(s,{withFileTypes:!0});for(let c of o){let l=c.name;if(l.startsWith(".")||l==="node_modules")continue;let u=we.join(s,l);if(c.isDirectory()||c.isSymbolicLink()){let f={name:l,entries:[]};i.entries.push(f),await e(u,f)}else{let f=await Oe.stat(u),d={name:we.basename(l),mtime:f.mtime,size:f.size};i.entries.push(d)}}return i}catch(o){return Bt.warn("Error loading package",o),{error:o.toString(),entries:[]}}},"walkDir"),t=await e(Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),{name:Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT).split(we.sep).slice(-1).pop(),entries:[]}),n=(jp(),C(zp)).component_errors;for(let s of t.entries){let i=n.get(s.name);i?s.error=n.get(s.name):i===void 0&&(s.error="The component has not been loaded yet (may need a restart)")}return t}a(xfe,"getComponents");async function Bfe(e){let t=Cn.getComponentFileValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let n=kS.getConfigObj()[e.project]||e.project==="harperdb"?we.join(vV.get(lt.CONFIG_PARAMS.ROOTPATH),"node_modules"):Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),s=e.encoding?{encoding:e.encoding}:{encoding:"utf8"};try{let i=await Oe.stat(we.join(n,e.project,e.file));return{message:await Oe.readFile(we.join(n,e.project,e.file),s),size:i.size,birthtime:i.birthtime,mtime:i.mtime}}catch(i){throw i.code===lt.NODE_ERROR_CODES.ENOENT?new Error(`Component file not found '${we.join(e.project,e.file)}'`):i}}a(Bfe,"getComponentFile");async function Hfe(e){let t=Cn.setComponentFileValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let r=e.encoding?{encoding:e.encoding}:{encoding:"utf8"},n=we.join(Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),e.project,e.file);e.payload!==void 0?(await Oe.ensureFile(n),await Oe.outputFile(n,e.payload,r)):await Oe.ensureDir(n);let s=await fi(e);return s.message="Successfully set component: "+e.file,s}a(Hfe,"setComponentFile");async function kfe(e){let t=Cn.dropComponentFileValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let{project:r,file:n}=e,s=e.file?we.join(r,n):r,i=we.join(Qt.get(lt.CONFIG_PARAMS.COMPONENTSROOT),s),o=we.join(Qt.get(lt.CONFIG_PARAMS.ROOTPATH),"node_modules",r);await Oe.pathExists(o)&&await Oe.unlink(o),await Oe.pathExists(i)&&await Oe.remove(i);let c=we.join(Qt.get(lt.CONFIG_PARAMS.ROOTPATH),"package.json");if(await Oe.pathExists(c)){let u=JSON.parse(await Oe.readFile(c,"utf8"));u?.dependencies?.[r]&&delete u.dependencies[r],await Oe.writeFile(c,JSON.stringify(u,null,2),"utf8")}kS.deleteConfigFromFile([r]);let l=await fi(e);return e.restart===!0?(UV.restartWorkers("http"),l.message=`Successfully dropped: ${s}, restarting HarperDB`):l.message=`Successfully dropped: ${s}`,l}a(kfe,"dropComponent");async function Ffe(e){let t=Cn.addSSHKeyValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let{name:r,key:n,host:s,hostname:i,known_hosts:o}=e;Bt.trace("adding ssh key",r);let c=we.join(Qa,r+".key"),l=we.join(Qa,"config");if(await Oe.pathExists(c))throw new Error("Key already exists. Use update_ssh_key or delete_ssh_key and then add_ssh_key");await Oe.outputFile(c,n),await Oe.chmod(c,"0600");let u=`#${r}
34
32
  Host ${s}
35
33
  HostName ${i}
36
34
  User git
37
35
  IdentityFile ${c}
38
36
  IdentitiesOnly yes`;await Oe.pathExists(l)?await Oe.appendFile(l,`
39
37
  `+u):await Oe.outputFile(l,u);let f="";if(await Oe.pathExists(ko)||(await Oe.writeFile(ko,""),await Oe.chmod(ko,"0600")),i=="github.com"&&!(await Oe.readFile(ko,"utf8")).includes("github.com"))try{let S=(await(await fetch("https://api.github.com/meta")).json()).ssh_keys;for(let g of S)Oe.appendFile(ko,"github.com "+g+`
40
- `)}catch{f=". Unable to get known hosts from github.com. Set your known hosts manually using set_ssh_known_hosts."}o&&await Oe.appendFile(ko,o);let d=await fi(e);return d.message=`Added ssh key: ${r}${f}`,d}a(Bfe,"addSSHKey");async function Hfe(e){let t=In.updateSSHKeyValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);let{name:r,key:n}=e;xt.trace("updating ssh key",r);let s=we.join(ja,r+".key");if(!await Oe.pathExists(s))throw new Error("Key does not exist. Use add_ssh_key");await Oe.outputFile(s,n);let i=await fi(e);return i.message=`Updated ssh key: ${r}`,i}a(Hfe,"updateSSHKey");async function kfe(e){let t=In.deleteSSHKeyValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);let{name:r}=e;xt.trace("deleting ssh key",r);let n=we.join(ja,r+".key"),s=we.join(ja,"config");if(!await Oe.pathExists(n))throw new Error("Key does not exist");let i=await Oe.readFile(s,"utf8"),o=new RegExp(`#${r}[\\S\\s]*?IdentitiesOnly yes`,"g");i=i.replace(o,""),await Oe.outputFile(s,i),Oe.removeSync(n);let c=await fi(e);return c.message=`Deleted ssh key: ${r}`,c}a(kfe,"deleteSSHKey");async function Ffe(e){let t=[];return await Oe.pathExists(ja)&&(await Oe.readdir(ja)).forEach(r=>{r!="known_hosts"&&r!="config"&&t.push({name:r.split(".")[0]})}),t}a(Ffe,"listSSHKeys");async function Gfe(e){let t=In.setSSHKnownHostsValidator(e);if(t)throw Bt(t,t.message,Ht.BAD_REQUEST);let{known_hosts:r}=e;await Oe.outputFile(ko,r);let n=await fi(e);return n.message="Known hosts successfully set",n}a(Gfe,"setSSHKnownHosts");async function qfe(e){return await Oe.pathExists(ko)?{known_hosts:await Oe.readFile(ko,"utf8")}:{known_hosts:null}}a(qfe,"getSSHKnownHosts");Object.assign(BV,{customFunctionsStatus:yfe,getCustomFunctions:bfe,getCustomFunction:Ofe,setCustomFunction:Nfe,dropCustomFunction:wfe,addComponent:Ife,dropCustomFunctionProject:Cfe,packageComponent:Pfe,deployComponent:Dfe,getComponents:Mfe,getComponentFile:vfe,setComponentFile:Ufe,dropComponent:xfe,addSSHKey:Bfe,updateSSHKey:Hfe,deleteSSHKey:kfe,listSSHKeys:Ffe,setSSHKnownHosts:Gfe,getSSHKnownHosts:qfe})});var jw=w((MMe,kV)=>{"use strict";var Ps=require("joi"),HV=it();kV.exports={readTransactionLogValidator:$fe,deleteTransactionLogsBeforeValidator:Vfe};function $fe(e){let t=Ps.object({schema:Ps.string(),database:Ps.string(),table:Ps.string().required(),from:Ps.date().timestamp(),to:Ps.date().timestamp(),limit:Ps.number().min(1)});return HV.validateBySchema(e,t)}a($fe,"readTransactionLogValidator");function Vfe(e){let t=Ps.object({schema:Ps.string(),database:Ps.string(),table:Ps.string().required(),timestamp:Ps.date().timestamp().required()});return HV.validateBySchema(e,t)}a(Vfe,"deleteTransactionLogsBeforeValidator")});var GS=w((UMe,KV)=>{"use strict";var Jw=(H(),C(G)),Jp=ir(),FV=ie(),GV=ae(),qV=Eo(),$V=z(),{handleHDBError:kS,hdb_errors:Kfe}=pe(),{HTTP_STATUS_CODES:FS}=Kfe,{readTransactionLogValidator:Yfe,deleteTransactionLogsBeforeValidator:Wfe}=jw(),VV=Vn(),zfe="Logs successfully deleted from transaction log.",jfe="All logs successfully deleted from transaction log.";KV.exports={readTransactionLog:Jfe,deleteTransactionLogsBefore:Xfe};async function Jfe(e){let t=Yfe(e);if(t)throw kS(t,t.message,FS.BAD_REQUEST,void 0,void 0,!0);e.database=e.database??e.schema??"data";let r=FV.checkSchemaTableExist(e.database,e.table);if(r)throw kS(new Error,r,FS.NOT_FOUND,void 0,void 0,!0);return GV.get(Jw.CONFIG_PARAMS.CLUSTERING_ENABLED)?await Qfe(e):($V.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)),VV.readAuditLog(e))}a(Jfe,"readTransactionLog");async function*Qfe(e){let t=qV.createNatsTableStreamName(e.database,e.table),r=await Jp.viewStreamIterator(t,parseInt(e.from),e.limit);for await(let n of r){let s=Math.floor(n?.nats_timestamp/1e6);if(e.to&&s>e.to)break;let i={operation:n?.entry?.operation,user:n?.entry?.__origin?.user,timestamp:s,records:n?.entry?.records,attributes:n?.entry?.attributes};n?.entry?.operation===Jw.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(Qfe,"readTransactionLogNats");async function Xfe(e){let t=Wfe(e);if(t)throw kS(t,t.message,FS.BAD_REQUEST,void 0,void 0,!0);if(e.database=e.database??e.schema??"data",!GV.get(Jw.CONFIG_PARAMS.CLUSTERING_ENABLED))return $V.info("Delete transaction logs called for Plexus"),VV.deleteAuditLogsBefore(e);let{database:r,table:n,timestamp:s}=e,i=FV.checkSchemaTableExist(r,n);if(i)throw kS(new Error,i,FS.NOT_FOUND,void 0,void 0,!0);let o=qV.createNatsTableStreamName(r,n),{jsm:c}=await Jp.getNATSReferences(),l=await Jp.getStreamInfo(o),u=new Date(l.state.first_ts).getTime();if(s<=u)return`No transactions exist before: ${s}`;let f=zfe,d,p=new Date(l.state.last_ts).getTime();return s>p?(d=l.state.last_seq+1,f=jfe):d=(await Jp.viewStream(o,parseInt(s),1))[0].nats_sequence,await Jp.purgeTableStream(r,n,{seq:d}),f}a(Xfe,"deleteTransactionLogsBefore")});var WV=w((BMe,YV)=>{"use strict";var Qw=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}};YV.exports=Qw});var jV=w((kMe,zV)=>{"use strict";var Xw=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};zV.exports=Xw});var eI=w((GMe,QV)=>{"use strict";var JV=WV(),Zfe=jV(),{HDB_ERROR_MSGS:e_e}=Un(),Zw=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=e_e.OP_AUTH_PERMS_ERROR,this.unauthorized_access={},this.invalid_schema_items=[]}handleUnauthorizedItem(t){return this.invalid_schema_items=[],this.unauthorized_access=[t],this}handleInvalidItem(t){return this.invalid_schema_items=[t],this.unauthorized_access=[],this}addInvalidItem(t,r,n){if(r&&n){let s=`${r}_${n}`;if(this.unauthorized_access[s])return}this.invalid_schema_items.push(t)}addUnauthorizedTable(t,r,n){let s=new JV(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let l=new Zfe(c,s[c]);i.push(l)});let o=`${r}_${n}`;if(this.unauthorized_access[o])this.unauthorized_access[o].required_attribute_permissions=i;else{let c=new JV(r,n,[],i);this.unauthorized_access[o]=c}}getPermsResponse(){let t=Object.values(this.unauthorized_access);return t.length>0||this.invalid_schema_items.length>0?(this.unauthorized_access=t,this):null}};QV.exports=Zw});var KS=w((KMe,p1)=>{"use strict";var tI=Rn(),qS=Yr(),Ds=Vg(),Zp=go(),rI=Vc(),t_e=bN(),r_e=dG(),eh=An(),$S=F_(),Sr=z(),n_e=CN(),s_e=gd(),i_e=ew(),o_e=nS(),a_e=nw(),c_e=sw(),l_e=aS(),u_e=lS(),nI=uS(),Fo=ie(),d_e=Vq(),sI=hS(),e1=Wa(),rn=(H(),C(G)),t1=sV(),f_e=Po(),r1=(ju(),C(X_)),n1=(MS(),C(Gp)),s1=yt(),ur=Ww(),__e=require("alasql"),i1=GS(),o1=Kp(),xd=Zn(),a1=(Tl(),C(Sl)),c1=eI(),{handleHDBError:Cn,hdb_errors:l1}=pe(),{addNodeBack:$Me,removeNodeBack:VMe}=(Tl(),C(Sl)),{HDB_ERROR_MSGS:Ur,HTTP_STATUS_CODES:Qp}=l1,X=new Map,u1="delete",Ja="insert",Go="read",Ml="update",Xp="describe",XV=Zp.describeSchema.name,ZV=Zp.describeTable.name,d1={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},p_e={insert:!0,delete:!0,deleteRecord:!0,update:!0,updateData:!0,upsert:!0,upsertData:!0},h_e="catchup",m_e="handleGetJob",E_e="handleGetJobsByStartDate",VS={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},g_e=[Ds.createTable.name,Ds.createAttribute.name,Ds.dropTable.name,Ds.dropAttribute.name],f1={EXPORT_TO_S3:"export_to_s3",EXPORT_LOCAL:"export_local"},re=class{static{a(this,"permission")}constructor(t,r){this.requires_su=t,this.perms=r}};X.set(tI.insert.name,new re(!1,[Ja]));X.set(tI.update.name,new re(!1,[Ml]));X.set(tI.upsert.name,new re(!1,[Ja,Ml]));X.set(qS.searchByConditions.name,new re(!1,[Go]));X.set(qS.searchByHash.name,new re(!1,[Go]));X.set(qS.searchByValue.name,new re(!1,[Go]));X.set(qS.search.name,new re(!1,[Go]));X.set(Ds.createSchema.name,new re(!0,[]));X.set(Ds.createTable.name,new re(!0,[]));X.set(Ds.createAttribute.name,new re(!1,[Ja]));X.set(Ds.dropSchema.name,new re(!0,[]));X.set(Ds.dropTable.name,new re(!0,[]));X.set(Ds.dropAttribute.name,new re(!0,[]));X.set(Zp.describeSchema.name,new re(!1,[Go]));X.set(Zp.describeTable.name,new re(!1,[Go]));X.set(rI.deleteRecord.name,new re(!1,[u1]));X.set(eh.addUser.name,new re(!0,[]));X.set(eh.alterUser.name,new re(!0,[]));X.set(eh.dropUser.name,new re(!0,[]));X.set(eh.listUsersExternal.name,new re(!0,[]));X.set($S.listRoles.name,new re(!0,[]));X.set($S.addRole.name,new re(!0,[]));X.set($S.alterRole.name,new re(!0,[]));X.set($S.dropRole.name,new re(!0,[]));X.set(n_e.name,new re(!0,[]));X.set(s_e.name,new re(!0,[]));X.set(i_e.name,new re(!0,[]));X.set(o_e.name,new re(!0,[]));X.set(a_e.name,new re(!0,[]));X.set(c_e.name,new re(!0,[]));X.set(nI.setRoutes.name,new re(!0,[]));X.set(nI.getRoutes.name,new re(!0,[]));X.set(nI.deleteRoutes.name,new re(!0,[]));X.set(s1.setConfiguration.name,new re(!0,[]));X.set(l_e.clusterStatus.name,new re(!0,[]));X.set(u_e.name,new re(!0,[]));X.set(sI.getFingerprint.name,new re(!0,[]));X.set(sI.setLicense.name,new re(!0,[]));X.set(rI.deleteFilesBefore.name,new re(!0,[]));X.set(rI.deleteAuditLogsBefore.name,new re(!0,[]));X.set(e1.restart.name,new re(!0,[]));X.set(e1.restartService.name,new re(!0,[]));X.set(t_e.name,new re(!0,[]));X.set(r_e.name,new re(!0,[Go]));X.set(f_e.systemInformation.name,new re(!0,[]));X.set(s1.getConfiguration.name,new re(!0,[]));X.set(i1.readTransactionLog.name,new re(!0,[]));X.set(i1.deleteTransactionLogsBefore.name,new re(!0,[]));X.set(o1.installModules.name,new re(!0,[]));X.set(o1.auditModules.name,new re(!0,[]));X.set(xd.createCsr.name,new re(!0,[]));X.set(xd.signCertificate.name,new re(!0,[]));X.set(xd.listCertificates.name,new re(!0,[]));X.set(xd.addCertificate.name,new re(!0,[]));X.set(xd.removeCertificate.name,new re(!0,[]));X.set(xd.getKey.name,new re(!0,[]));X.set(a1.addNodeBack.name,new re(!0,[]));X.set(a1.removeNodeBack.name,new re(!0,[]));X.set(r1.createTokens.name,new re(!1,[]));X.set(r1.refreshOperationToken.name,new re(!1,[]));X.set(n1.login.name,new re(!1,[]));X.set(n1.logout.name,new re(!1,[]));X.set(ur.customFunctionsStatus.name,new re(!0,[]));X.set(ur.getCustomFunctions.name,new re(!0,[]));X.set(ur.getComponents.name,new re(!0,[]));X.set(ur.getComponentFile.name,new re(!0,[]));X.set(ur.setComponentFile.name,new re(!0,[]));X.set(ur.dropComponent.name,new re(!0,[]));X.set(ur.getCustomFunction.name,new re(!0,[]));X.set(ur.setCustomFunction.name,new re(!0,[]));X.set(ur.dropCustomFunction.name,new re(!0,[]));X.set(ur.addComponent.name,new re(!0,[]));X.set(ur.dropCustomFunctionProject.name,new re(!0,[]));X.set(ur.packageComponent.name,new re(!0,[]));X.set(ur.deployComponent.name,new re(!0,[]));X.set(ur.addSSHKey.name,new re(!0,[]));X.set(ur.updateSSHKey.name,new re(!0,[]));X.set(ur.deleteSSHKey.name,new re(!0,[]));X.set(ur.listSSHKeys.name,new re(!0,[]));X.set(ur.setSSHKnownHosts.name,new re(!0,[]));X.set(ur.getSSHKnownHosts.name,new re(!0,[]));X.set(sI.getRegistrationInfo.name,new re(!1,[]));X.set(eh.userInfo.name,new re(!1,[]));X.set(Zp.describeAll.name,new re(!1,[]));X.set(m_e,new re(!1,[]));X.set(E_e,new re(!0,[]));X.set(h_e,new re(!0,[]));X.set(VS.CSV_DATA_LOAD,new re(!1,[Ja,Ml]));X.set(VS.CSV_URL_LOAD,new re(!1,[Ja,Ml]));X.set(VS.CSV_FILE_LOAD,new re(!1,[Ja,Ml]));X.set(VS.IMPORT_FROM_S3,new re(!1,[Ja,Ml]));X.set(f1.EXPORT_TO_S3,new re(!0,[]));X.set(f1.EXPORT_LOCAL,new re(!0,[]));X.set(rn.VALID_SQL_OPS_ENUM.DELETE,new re(!1,[u1]));X.set(rn.VALID_SQL_OPS_ENUM.SELECT,new re(!1,[Go]));X.set(rn.VALID_SQL_OPS_ENUM.INSERT,new re(!1,[Ja]));X.set(rn.VALID_SQL_OPS_ENUM.UPDATE,new re(!1,[Ml]));p1.exports={verifyPerms:T_e,verifyPermsAst:S_e,verifyBulkLoadAttributePerms:R_e};function S_e(e,t,r){if(Fo.isEmptyOrZeroLength(e))throw Sr.info("verify_perms_ast has an empty user parameter"),Cn(new Error);if(Fo.isEmptyOrZeroLength(t))throw Sr.info("verify_perms_ast has an empty user parameter"),Cn(new Error);if(Fo.isEmptyOrZeroLength(r))throw Sr.info("verify_perms_ast has a null operation parameter"),Cn(new Error);try{let n=new c1,s=new d_e(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw Sr.info("No schemas defined in verifyPermsAst(), will not continue."),Cn(new Error);let c=!!t.role.permission.super_user,l=i.includes("system");if(l&&d1[r])throw Cn(new Error,Ur.DROP_SYSTEM,Qp.FORBIDDEN);if(c&&!l)return null;let u=t1.getRolePermissions(t.role);t.role.permission=u,!c&&e instanceof __e.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(u));for(let d=0;d<i.length;d++){let p=s.getTablesBySchemaName(i[d]);p&&o.set(i[d],p)}let f=_1(t,r,o,n);return f||(o.forEach((d,p)=>{for(let _=0;_<d.length;_++){let h=s.getAttributesBySchemaTableName(p,d[_]),S=oI(t.role.permission,p,d[_]);iI(h,S,r,d[_],p,n)}}),n.getPermsResponse())}catch(n){throw Cn(n)}}a(S_e,"verifyPermsAst");function T_e(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw Sr.info("null required parameter in verifyPerms"),Cn(new Error,Ur.DEFAULT_INVALID_REQUEST,Qp.BAD_REQUEST);let r;t instanceof Function?r=t.name:r=t;let n=e.action,s=e.schema??e.database,i=e.table,o=new Map;s&&i&&o.set(s,[i]);let c=new c1;if(Fo.isEmptyOrZeroLength(e.hdb_user?.role)||Fo.isEmptyOrZeroLength(e.hdb_user?.role?.permission))return Sr.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,f=o.has(rn.SYSTEM_SCHEMA_NAME)||s===rn.SYSTEM_SCHEMA_NAME;if(l&&f&&p_e[e.operation]&&(i===rn.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME||i===rn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||i===rn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME))return null;if(f&&d1[r])throw Cn(new Error,Ur.DROP_SYSTEM,Qp.FORBIDDEN);if(l&&!f||u===!0&&(r===Ds.createSchema.name||r===Ds.dropSchema.name))return null;if(g_e.indexOf(r)>=0&&(u===!0||Array.isArray(u)))return u===!0||u.indexOf(s)>=0?null:c.handleUnauthorizedItem(`User does not have access to perform '${e.operation}' against schema '${s}'`);let d=t1.getRolePermissions(e.hdb_user?.role);if(e.hdb_user?.role&&(e.hdb_user.role.permission=d),(r===XV||r===ZV)&&!d.super_user){if(s===rn.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(Ur.SCHEMA_PERM_ERROR(s));if(r===XV&&(!d[s]||!d[s][Xp]))return c.handleInvalidItem(Ur.SCHEMA_NOT_FOUND(s));if(r===ZV&&(!d[s]||!d[s].tables[i]||!d[s].tables[i][Xp]))return c.handleInvalidItem(Ur.TABLE_NOT_FOUND(s,i))}let p=_1(e.hdb_user,r,o,c,n);if(p)return p;if(X.get(r)&&X.get(r).perms.length===0)return null;if(!l&&e.get_attributes&&rn.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let S=[],g=d[s].tables[i];g[rn.PERMS_CRUD_ENUM.READ]&&(g.attribute_permissions.length>0?g.attribute_permissions.filter(E=>E[rn.PERMS_CRUD_ENUM.READ]).forEach(E=>{S.push(E.attribute_name)}):S=global.hdb_schema[s][i].attributes.map(R=>R.attribute),e.get_attributes=S)}let _=A_e(e),h=oI(e.hdb_user?.role?.permission,s,i);return iI(_,h,r,i,s,c,n),c.getPermsResponse()}a(T_e,"verifyPerms");function _1(e,t,r,n,s){if(Fo.arrayHasEmptyValues([e,t,r]))throw Sr.info("hasPermissions has an invalid parameter"),Cn(new Error);let i=r.has("system"),o=e.role.permission;if(o.super_user&&(!i||X.get(t).requires_su))return null;if(!X.get(t))throw Sr.info(`operation ${t} not found.`),Cn(new Error,Ur.OP_NOT_FOUND(t),Qp.BAD_REQUEST);if(X.get(t)&&X.get(t).requires_su)return Sr.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][Xp]===!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 f of u){let d=o[l].tables[f];if(!d||d[Xp]===!1)n.addInvalidItem(Ur.TABLE_NOT_FOUND(l,f));else try{let p=[],_=X.get(t).perms;!Fo.isEmpty(s)&&_.includes(s)&&(_=[s]);for(let h=0;h<_.length;h++){let S=_[h],g=d[S];(g==null||g===!1)&&(Sr.info(`Required ${S} permission not found for ${t} ${s?`${s} `:""}operation in role ${e.role.id}`),p.push(S))}p.length>0&&n.addUnauthorizedTable(l,f,p)}catch(p){let _=Ur.UNKNOWN_OP_AUTH_ERROR(t,l,f);throw Sr.error(_),Sr.error(p),Cn(l1.CHECK_LOGS_WRAPPER(_))}}}return r.size<2?n.getPermsResponse():null}a(_1,"hasPermissions");function iI(e,t,r,n,s,i,o){if(!e||!t)throw Sr.info("no attributes specified in checkAttributePerms."),Cn(new Error);let c=X.get(r).perms;if(!c||c==="")throw Sr.info(`no permissions found for ${r} in checkAttributePerms().`),Cn(new Error);if(Fo.isEmptyOrZeroLength(t))return Sr.info("No role permissions set (this is OK)."),null;o&&c.includes(o)&&(c=[o]);let l={};for(let f of e){let d=t.get(f);if(d){if(d[Xp]===!1){i.addInvalidItem(Ur.ATTR_NOT_FOUND(s,n,f),s,n);continue}if(c)for(let p of c){if(rn.TIME_STAMP_NAMES.includes(d.attribute_name)&&p!==Go)throw Cn(new Error,Ur.SYSTEM_TIMESTAMP_PERMS_ERR,Qp.FORBIDDEN);d[p]===!1&&(l[d.attribute_name]?l[d.attribute_name].push(p):l[d.attribute_name]=[p])}}else i.addInvalidItem(Ur.ATTR_NOT_FOUND(s,n,f),s,n)}let u=Object.keys(l);u.length>0&&i.addUnauthorizedAttributes(u,s,n,l)}a(iI,"checkAttributePerms");function A_e(e){let t=new Set;try{if(e.action)return t;if(e.operation===rn.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS&&e.conditions.forEach(r=>{t.add(r.search_attribute)}),e&&e.search_attribute&&t.add(e.search_attribute),!e.records||e.records.length===0){if(!e.get_attributes||!e.get_attributes.length===0)return t;for(let r=0;r<e.get_attributes.length;r++)t.add(e.get_attributes[r])}else for(let r=0;r<e.records.length;r++){let n=Object.keys(e.records[r]);for(let s=0;s<n.length;s++)t.add(n[s])}}catch(r){Sr.info(r)}return t}a(A_e,"getRecordAttributes");function oI(e,t,r){let n=new Map;if(Fo.isEmpty(e))return Sr.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{Sr.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(oI,"getAttributePermissions");function R_e(e,t,r,n,s,i,o){let c=new Set(i),l=oI(e,n,s);iI(c,l,t,s,n,o,r)}a(R_e,"verifyBulkLoadAttributePerms")});var WS=w((WMe,S1)=>{"use strict";S1.exports={evaluateSQL:U_e,processAST:g1,convertSQLToAST:E1,checkASTPermissions:m1};var y_e=Rn(),h1=require("util"),b_e=h1.callbackify(y_e.insert),O_e=Yr().search,N_e=tk().update,w_e=h1.callbackify(N_e),I_e=nk().convertDelete,Qa=require("alasql"),C_e=KS(),YS=z(),P_e=oE(),D_e=ie(),th=(H(),C(G)),{hdb_errors:L_e,handleHDBError:aI}=pe(),{HTTP_STATUS_CODES:cI}=L_e;P_e(Qa);var M_e=403,v_e="There was a problem performing this insert. Please check the logs and try again.",lI=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function U_e(e,t){let r=e.parsed_sql_object;if(!r){r=E1(e.sql);let n,s=r.ast.statements[0];if(s instanceof Qa.yy.Insert?n=s.into.databaseid:s instanceof Qa.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof Qa.yy.Update||s instanceof Qa.yy.Delete?n=s.table.databaseid:YS.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof Qa.yy.Select)&&D_e.isEmptyOrZeroLength(n))return t("No schema specified",null)}g1(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(U_e,"evaluateSQL");function m1(e,t){let r;try{r=C_e.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(m1,"checkASTPermissions");function E1(e){let t=new lI;if(!e)throw aI(new Error,"The 'sql' parameter is missing from the request body",cI.BAD_REQUEST);try{let r=e.trim(),n=Qa.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
41
- `);throw n[1]?aI(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,cI.BAD_REQUEST):aI(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",cI.BAD_REQUEST)}return t}a(E1,"convertSQLToAST");function g1(e,t,r){try{let n=x_e;if(!e.bypass_auth&&!t.permissions_checked){let i=m1(e,t);if(i&&i.length>0)return r(M_e,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case th.VALID_SQL_OPS_ENUM.SELECT:n=O_e,s=t.ast.statements[0];break;case th.VALID_SQL_OPS_ENUM.INSERT:n=B_e;break;case th.VALID_SQL_OPS_ENUM.UPDATE:n=w_e;break;case th.VALID_SQL_OPS_ENUM.DELETE:n=I_e;break;default:throw new Error(`unsupported SQL type ${t.variant} in SQL: ${e}`)}n(s,(i,o)=>{if(i){r(i);return}r(null,o)})}catch(n){return r(n)}}a(g1,"processAST");function x_e(e,t){YS.info(e),t("unknown sql statement")}a(x_e,"nullFunction");function B_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=H_e(i,e.values)}catch(o){return r(o)}b_e(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(l){YS.error(`Error delete new_attributes from insert response: ${l}`)}r(null,c)})}a(B_e,"convertInsert");function H_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]]=Qa.compile(`SELECT ${s.toString()} AS [${th.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw YS.error(r),new Error(v_e)}}a(H_e,"createDataObjects")});var hI=w((QMe,y1)=>{var QS=require("clone"),XS=it(),k_e=ie(),jS=(H(),C(G)),jMe=z(),uI=require("fs"),fI=require("joi"),{string:JS}=fI.types(),{hdb_errors:F_e,handleHDBError:zS}=pe(),{HDB_ERROR_MSGS:JMe,HTTP_STATUS_CODES:dI}=F_e,{common_validators:Bd}=Di(),T1=" is required",G_e=["insert","update","upsert"],_I={database:{presence:!1,format:Bd.schema_format,length:Bd.schema_length},schema:{presence:!1,format:Bd.schema_format,length:Bd.schema_length},table:{presence:!0,format:Bd.schema_format,length:Bd.schema_length},action:{inclusion:{within:G_e,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},q_e={schema:JS.required(),table:JS.required(),action:JS.valid("insert","update","upsert")},{AWS_ACCESS_KEY:$_e,AWS_SECRET:V_e,AWS_BUCKET:K_e,AWS_FILE_KEY:Y_e,REGION:W_e}=jS.S3_BUCKET_AUTH_KEYS,z_e={s3:{presence:!0},[`s3.${$_e}`]:{presence:!0,type:"String"},[`s3.${V_e}`]:{presence:!0,type:"String"},[`s3.${K_e}`]:{presence:!0,type:"String"},[`s3.${Y_e}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${W_e}`]:{presence:!0,type:"String"}},A1=QS(_I);A1.data.presence={message:T1};var R1=QS(_I);R1.file_path.presence={message:T1};var j_e=Object.assign(QS(_I),z_e),pI=QS(q_e);pI.csv_url=JS.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();pI.passthrough_headers=fI.object();function J_e(e){let t=XS.validateObject(e,A1);return ZS(e,t)}a(J_e,"dataObject");function Q_e(e){let t=XS.validateBySchema(e,fI.object(pI));return ZS(e,t)}a(Q_e,"urlObject");function X_e(e){let t=XS.validateObject(e,R1);return ZS(e,t)}a(X_e,"fileObject");function Z_e(e){let t=XS.validateObject(e,j_e);return ZS(e,t)}a(Z_e,"s3FileObject");function ZS(e,t){if(!t){let r=k_e.checkGlobalSchemaTable(e.schema,e.table);if(r)return zS(new Error,r,dI.BAD_REQUEST);if(e.operation===jS.OPERATIONS_ENUM.CSV_FILE_LOAD)try{uI.accessSync(e.file_path,uI.constants.R_OK|uI.constants.F_OK)}catch(n){return n.code===jS.NODE_ERROR_CODES.ENOENT?zS(n,`No such file or directory ${n.path}`,dI.BAD_REQUEST):n.code===jS.NODE_ERROR_CODES.EACCES?zS(n,`Permission denied ${n.path}`,dI.BAD_REQUEST):zS(n)}}return t}a(ZS,"postValidateChecks");y1.exports={dataObject:J_e,urlObject:Q_e,fileObject:X_e,s3FileObject:Z_e}});var mI=w((ZMe,b1)=>{"use strict";var rh=z(),eT=(H(),C(G));async function epe(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===eT.OPERATIONS_ENUM.INSERT||t.operation===eT.OPERATIONS_ENUM.UPDATE||t.operation===eT.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===eT.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(rh.info(i.message),i):i.http_resp_msg?(rh.error(`Error calling operation: ${e.name}`),rh.error(i.http_resp_msg),i):(rh.error(`Error calling operation: ${e.name}`),rh.error(i),i)}}a(epe,"callOperationFunctionAsAwait");b1.exports={callOperationFunctionAsAwait:epe}});var EI=w((tve,N1)=>{"use strict";var{S3:tpe,GetObjectCommand:rpe}=require("@aws-sdk/client-s3");N1.exports={getFileStreamFromS3:npe,getS3AuthObj:O1};async function npe(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await O1(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new rpe(r))).Body}a(npe,"getFileStreamFromS3");function O1(e,t,r){return new tpe({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(O1,"getS3AuthObj")});var I1=w((nve,w1)=>{"use strict";var gI=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}},SI=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};w1.exports={BulkLoadFileObject:gI,BulkLoadDataObject:SI}});var P1=w((ive,C1)=>{"use strict";var TI=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};C1.exports=TI});var NI=w((dve,W1)=>{"use strict";var tT=Rn(),nT=hI(),spe=require("needle"),_i=(H(),C(G)),ave=Tt(),Hd=ie(),{handleHDBError:kt,hdb_errors:k1}=pe(),{HTTP_STATUS_CODES:xr,HDB_ERROR_MSGS:Tr,CHECK_LOGS_WRAPPER:Ul}=k1,kd=z(),AI=require("papaparse");Hd.promisifyPapaParse();var pi=require("fs-extra"),ipe=require("path"),{chain:D1}=require("stream-chain"),L1=require("stream-json/streamers/StreamArray"),M1=require("stream-json/utils/Batch"),v1=require("stream-chain/utils/comp"),{finished:U1}=require("stream"),ope=ae(),F1=mI(),ape=EI(),{BulkLoadFileObject:yI,BulkLoadDataObject:cpe}=I1(),bI=eI(),{verifyBulkLoadAttributePerms:G1}=KS(),cve=P1(),lve=ir(),uve=Eo(),{databases:lpe}=(Pe(),C(tt)),{coerceType:upe}=(qf(),C(wI)),x1="No records parsed from csv file.",vl=`${ope.get("HDB_ROOT")}/tmp`,{schema_regex:dpe}=Di(),B1=1024*1024*2,H1=5e3,fpe={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};W1.exports={csvDataLoad:_pe,csvURLLoad:ppe,csvFileLoad:hpe,importFromS3:mpe};async function _pe(e,t){let r=nT.dataObject(e);if(r)throw kt(r,r.message,xr.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=V1(e.schema,e.table),i=AI.parse(e.data,{header:!0,skipEmptyLines:!0,transform:RI.bind(null,s),dynamicTyping:!1}),o=new bI;e.hdb_user&&e.hdb_user?.role&&e.hdb_user?.role?.permission&&e.hdb_user?.role?.permission?.super_user!==!0&&G1(e.hdb_user?.role?.permission,this.job_operation_function.name,e.action,e.schema,e.table,i.meta.fields,o);let c=o.getPermsResponse();if(c)throw kt(new Error,c,xr.BAD_REQUEST,void 0,void 0,!0);let l=new cpe(e.action,e.schema,e.table,i.data);return n=await F1.callOperationFunctionAsAwait(K1,l,null),n.message===x1?x1:Y1(n.records,n.number_written)}catch(s){throw xl(s)}}a(_pe,"csvDataLoad");async function ppe(e){let t=nT.urlObject(e);if(t)throw kt(t,t.message,xr.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${vl}/${r}`;try{await Epe(e,r)}catch(s){throw kd.error(Tr.DOWNLOAD_FILE_ERR(r)+" - "+s),kt(s,Ul(Tr.DOWNLOAD_FILE_ERR(r)))}try{let s=new yI(this.job_operation_function.name,e.action,e.schema,e.table,n,_i.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission),i=await OI(s);return await rT(n),i}catch(s){throw await rT(n),xl(s)}}a(ppe,"csvURLLoad");async function hpe(e){let t=nT.fileObject(e);if(t)throw kt(t,t.message,xr.BAD_REQUEST,void 0,void 0,!0);let r=new yI(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,_i.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission);try{return await OI(r)}catch(n){throw xl(n)}}a(hpe,"csvFileLoad");async function mpe(e){let t=nT.s3FileObject(e);if(t)throw kt(t,t.message,xr.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=ipe.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${vl}/${s}`;let i=new yI(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user?.role?.permission);await gpe(s,e);let o=await OI(i);return await rT(r),o}catch(n){throw await rT(r),xl(n)}}a(mpe,"importFromS3");async function Epe(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await spe("get",e.csv_url,n)}catch(n){let s=`Error downloading CSV file from ${e.csv_url}, status code: ${n.statusCode}. Check the log for more information.`;throw kt(n,s,n.statusCode,_i.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}Tpe(r,e.csv_url),await Spe(t,r.raw)}a(Epe,"downloadCSVFile");async function gpe(e,t){try{let r=`${vl}/${e}`;await pi.mkdirp(vl),await pi.writeFile(`${vl}/${e}`,"",{flag:"a+"});let n=await pi.createWriteStream(r),s=await ape.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(){kd.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw kd.error(Tr.S3_DOWNLOAD_ERR+" - "+r),kt(r,Ul(Tr.S3_DOWNLOAD_ERR))}}a(gpe,"downloadFileFromS3");async function Spe(e,t){try{await pi.mkdirp(vl),await pi.writeFile(`${vl}/${e}`,t)}catch(r){throw kd.error(Tr.WRITE_TEMP_FILE_ERR),kt(r,Ul(Tr.DEFAULT_BULK_LOAD_ERR))}}a(Spe,"writeFileToTempFolder");async function rT(e){if(e)try{await pi.access(e),await pi.unlink(e)}catch{kd.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(rT,"deleteTempFile");function Tpe(e,t){if(e.statusCode!==k1.HTTP_STATUS_CODES.OK)throw kt(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,xr.BAD_REQUEST);if(!fpe[e.headers["content-type"]])throw kt(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,xr.BAD_REQUEST);if(!e.raw)throw kt(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,xr.BAD_REQUEST)}a(Tpe,"validateURLResponse");async function OI(e){try{let t;switch(e.file_type){case _i.VALID_S3_FILE_TYPES.CSV:t=await Ape(e);break;case _i.VALID_S3_FILE_TYPES.JSON:t=await Rpe(e);break;default:throw kt(new Error,Tr.DEFAULT_BULK_LOAD_ERR,xr.BAD_REQUEST,_i.LOG_LEVELS.ERROR,Tr.INVALID_FILE_EXT_ERR(e))}return Y1(t.records,t.number_written)}catch(t){throw xl(t)}}a(OI,"fileLoad");async function q1(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 tT.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&G1(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let l=kt(c);r(l)}}a(q1,"validateChunk");async function $1(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;Hd.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!Hd.isEmpty(c)&&!Hd.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 F1.callOperationFunctionAsAwait(K1,c,null);t.records+=l.records,t.number_written+=l.number_written,s&&s.resume()}catch(c){let l=kt(c,Ul(Tr.INSERT_CSV_ERR),xr.INTERNAL_SERVER_ERROR,_i.LOG_LEVELS.ERROR,Tr.INSERT_CSV_ERR+" - "+c);r(l)}}a($1,"insertChunk");async function Ape(e){let t={records:0,number_written:0},r=V1(e.schema,e.table);try{let n=new bI,s=pi.createReadStream(e.file_path,{highWaterMark:B1});s.setEncoding("utf8"),await AI.parsePromise(s,q1.bind(null,e,n),RI.bind(null,r));let i=n.getPermsResponse();if(i)throw kt(new Error,i,xr.BAD_REQUEST);return s=pi.createReadStream(e.file_path,{highWaterMark:B1}),s.setEncoding("utf8"),await AI.parsePromise(s,$1.bind(null,e,t),RI.bind(null,r)),s.destroy(),t}catch(n){throw kt(n,Ul(Tr.PAPA_PARSE_ERR),xr.INTERNAL_SERVER_ERROR,_i.LOG_LEVELS.ERROR,Tr.PAPA_PARSE_ERR+n)}}a(Ape,"callPapaParse");function V1(e,t){let r=lpe[e][t].attributes,n=new Map;for(let s of r)s.type&&!s.computed&&!s.relationship&&n.set(s.name,i=>upe(i,s));return n}a(V1,"createTransformMap");function RI(e,t,r){let n=e.get(r);return n?n(t):Hd.autoCast(t)}a(RI,"typeFunction");async function Rpe(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new bI,s=D1([pi.createReadStream(e.file_path,{encoding:"utf-8"}),L1.withParser(),c=>c.value,new M1({batchSize:H1}),v1(async c=>{await q1(e,n,r,c)})]);await new Promise((c,l)=>{U1(s,u=>{u?l(u):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw kt(new Error,i,xr.BAD_REQUEST);let o=D1([pi.createReadStream(e.file_path,{encoding:"utf-8"}),L1.withParser(),c=>c.value,new M1({batchSize:H1}),v1(async c=>{await $1(e,t,r,c)})]);return await new Promise((c,l)=>{U1(o,u=>{u?l(u):c()}),o.resume()}),t}catch(n){throw kt(n,Ul(Tr.INSERT_JSON_ERR),xr.INTERNAL_SERVER_ERROR,_i.LOG_LEVELS.ERROR,Tr.INSERT_JSON_ERR+n)}}a(Rpe,"insertJson");async function K1(e){let t={};try{e.data&&e.data.length>0&&ype(e.data[0])?t=await bpe(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",kd.info(t.message))}catch(r){throw xl(r)}return t}a(K1,"callBulkFileLoad");function ype(e){let t=Object.keys(e);for(let r of t)if(!dpe.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(ype,"validateColumnNames");async function bpe(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=tT.insert;break;case"update":i=tT.update;break;case"upsert":i=tT.upsert;break;default:throw kt(new Error,Tr.INVALID_ACTION_PARAM_ERR(n),xr.BAD_REQUEST,_i.LOG_LEVELS.ERROR,Tr.INVALID_ACTION_PARAM_ERR(n))}try{let o=await i(s),c;switch(n){case"insert":c=o.inserted_hashes;break;case"update":c=o.update_hashes;break;case"upsert":c=o.upserted_hashes;break;default:break}if(Array.isArray(o.skipped_hashes)&&o.skipped_hashes.length>0){let f=global.hdb_schema[t][r].hash_attribute,d=e.length;for(;d--;)o.skipped_hashes.indexOf(e[d][f])>=0&&e.splice(d,1)}let l=Hd.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw xl(o)}}a(bpe,"bulkFileLoad");function Y1(e,t){return`successfully loaded ${t} of ${e} records`}a(Y1,"buildResponseMsg");function xl(e){return kt(e,Ul(Tr.DEFAULT_BULK_LOAD_ERR),xr.INTERNAL_SERVER_ERROR,_i.LOG_LEVELS.ERROR,Tr.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(xl,"buildTopLevelErrMsg")});var PI=w((_ve,tK)=>{"use strict";var CI=Yr(),Ope=EI(),{AsyncParser:Npe}=require("json2csv"),sT=require("stream"),is=ie(),II=require("fs-extra"),wpe=require("path"),Ls=z(),{promisify:J1}=require("util"),nh=ie(),{handleHDBError:dr,hdb_errors:Ipe}=pe(),{HDB_ERROR_MSGS:Pn,HTTP_STATUS_CODES:fr}=Ipe,{streamAsJSON:Cpe}=(bR(),C(VL)),{Upload:Ppe}=require("@aws-sdk/lib-storage"),{toCsvStream:Dpe}=(ao(),C(uM)),z1=["search_by_value","search_by_hash","sql","search_by_conditions"],j1=["json","csv"],Q1="json",X1="csv",Lpe="Successfully exported JSON locally.",Mpe="Successfully exported CSV locally.",vpe=1e3,Upe=CI.searchByHash,xpe=CI.searchByValue,Bpe=J1(sT.finished);tK.exports={export_to_s3:Gpe,export_local:Hpe};async function Hpe(e){Ls.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=Z1(e);if(!is.isEmpty(t))throw Ls.error(t),dr(new Error,t,fr.BAD_REQUEST,void 0,void 0,!0);if(is.isEmpty(e.path))throw Ls.error(Pn.MISSING_VALUE("path")),dr(new Error,Pn.MISSING_VALUE("path"),fr.BAD_REQUEST,void 0,void 0,!0);let r=(is.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(wpe.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=is.buildFolderPath(e.path,r);await kpe(e.path);let s=await eK(e);return await Fpe(n,e.format,s)}a(Hpe,"export_local");async function kpe(e){if(Ls.trace("in confirmPath"),is.isEmptyOrZeroLength(e))throw dr(new Error,`Invalid path: ${e}`,fr.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await II.stat(e)}catch(r){let n;throw r.code==="ENOENT"?n=`path '${e}' does not exist`:r.code==="EACCES"?n=`access to path '${e}' is denied`:n=r.message,Ls.error(n),dr(new Error,n,fr.BAD_REQUEST,void 0,void 0,!0)}if(!t.isDirectory()){let r=`path '${e}' is not a directory, please supply a valid folder path`;throw Ls.error(r),dr(new Error,r,fr.BAD_REQUEST,void 0,void 0,!0)}return!0}a(kpe,"confirmPath");async function Fpe(e,t,r){if(Ls.trace("in saveToLocal"),nh.isEmptyOrZeroLength(e))throw dr(new Error,Pn.INVALID_VALUE("file_path"),fr.BAD_REQUEST,void 0,void 0,!0);if(nh.isEmptyOrZeroLength(t))throw dr(new Error,Pn.INVALID_VALUE("Source format"),fr.BAD_REQUEST,void 0,void 0,!0);if(nh.isEmpty(r))throw dr(new Error,Pn.NOT_FOUND("Data"),fr.BAD_REQUEST,void 0,void 0,!0);if(t===Q1){let n=II.createWriteStream(e);return Cpe(r).pipe(n),await Bpe(n),{message:Lpe,path:e}}else if(t===X1){let n=II.createWriteStream(e),s=sT.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(f=>({label:f,value:f})));let c={objectMode:!0};return await new Npe(i,c).fromInput(s).toOutput(n).promise(!1),{message:Mpe,path:e}}throw dr(new Error,Pn.INVALID_VALUE("format"),fr.BAD_REQUEST)}a(Fpe,"saveToLocal");async function Gpe(e){if(!e.s3||Object.keys(e.s3).length===0)throw dr(new Error,Pn.MISSING_VALUE("S3 object"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw dr(new Error,Pn.MISSING_VALUE("aws_access_key_id"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw dr(new Error,Pn.MISSING_VALUE("aws_secret_access_key"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.bucket))throw dr(new Error,Pn.MISSING_VALUE("bucket"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.key))throw dr(new Error,Pn.MISSING_VALUE("key"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.region))throw dr(new Error,Pn.MISSING_VALUE("region"),fr.BAD_REQUEST);let t=Z1(e);if(!is.isEmpty(t))throw dr(new Error,t,fr.BAD_REQUEST);Ls.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await eK(e)}catch(l){throw Ls.error(l),l}let n,s=await Ope.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new sT.PassThrough;if(e.format===X1){i=e.s3.key+".csv";let l=Dpe(r,r.getColumns?.());l.on("error",u=>{throw u}),l.pipe(o)}else if(e.format===Q1){i=e.s3.key+".json";let l=new sT.Readable;l.pipe(o),l.on("error",d=>{throw d}),l.push("[");let u=r.length,f="";for(let[d,p]of r.entries()){let _=d===u-1?JSON.stringify(p):JSON.stringify(p)+",";f+=_,d!==0&&d%vpe===0&&(l.push(f),f="")}f.length!==0&&l.push(f),l.push("]"),l.push(null)}else throw dr(new Error,Pn.INVALID_VALUE("format"),fr.BAD_REQUEST);return new Ppe({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(Gpe,"export_to_s3");function Z1(e){if(Ls.trace("in exportCoreValidation"),is.isEmpty(e.format))return"format missing";if(j1.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${j1.join(", ")}`;let t=e.search_operation.operation;if(is.isEmpty(t))return"search_operation.operation missing";if(z1.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${z1.join(", ")}`}a(Z1,"exportCoreValidation");async function eK(e){Ls.trace("in getRecords");let t,r;if(nh.isEmpty(e.search_operation)||nh.isEmptyOrZeroLength(e.search_operation.operation))throw dr(new Error,Pn.INVALID_VALUE("Search operation"),fr.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=xpe;break;case"search_by_hash":t=Upe;break;case"search_by_conditions":t=CI.searchByConditions;break;case"sql":{let n=WS();t=J1(n.evaluateSQL);break}default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,Ls.error(r),dr(new Error,r,fr.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(eK,"getRecords")});var nK=w((hve,rK)=>{"use strict";var DI=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};rK.exports=DI});var oK=w((Eve,iK)=>{"use strict";var qpe=(H(),C(G)),sK=require("moment"),$pe=require("uuid").v4,LI=class{static{a(this,"JobObject")}constructor(){this.id=$pe(),this.type=void 0,this.start_datetime=sK().valueOf(),this.created_datetime=sK().valueOf(),this.end_datetime=void 0,this.status=qpe.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};iK.exports=LI});var MI=w((Sve,pK)=>{"use strict";var Vpe=require("uuid").v4,dK=Rn(),fK=Yr(),Kpe=ni(),Ype=ku(),Wpe=nK(),Ot=(H(),C(G)),zpe=oK(),jpe=rg(),hi=z(),Jpe=Uf(),Fd=ie(),{promisify:Qpe}=require("util"),Bl=require("moment"),Xpe=WS(),iT=hI(),aK=Cy(),{deleteTransactionLogsBeforeValidator:Zpe}=jw(),{handleHDBError:cK,hdb_errors:ehe,ClientError:the}=pe(),{HTTP_STATUS_CODES:lK}=ehe,uK=fK.searchByValue,rhe=fK.searchByHash,nhe=dK.insert,she=Qpe(Xpe.evaluateSQL),ihe=dK.update;pK.exports={addJob:che,updateJob:uhe,handleGetJob:ohe,handleGetJobsByStartDate:ahe,getJobById:_K};async function ohe(e){if(e.id===void 0)throw new the("'id' is required");let t=await _K(e.id);return Fd.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(ohe,"handleGetJob");async function ahe(e){try{let t=await lhe(e);if(hi.trace(`Searching for jobs from ${e.from_date} to ${e.to_date}`),t&&t.length>0)for(let r of t)r.start_datetime&&(r.start_datetime_converted=Bl(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=Bl(r.end_datetime)),r.request!==void 0&&delete r.request,delete r.__createdtime__,delete r.__updatedtime__;return t}catch(t){let r=`There was an error searching jobs by date: ${t}`;throw hi.error(r),new Error(r)}}a(ahe,"handleGetJobsByStartDate");async function che(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||Fd.isEmptyOrZeroLength(e.operation)){let f="job parameter is invalid";return hi.info(f),t.error=f,t}if(!Ot.JOB_TYPE_ENUM[e.operation])return hi.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case Ot.OPERATIONS_ENUM.CSV_FILE_LOAD:n=iT.fileObject(e);break;case Ot.OPERATIONS_ENUM.CSV_URL_LOAD:n=iT.urlObject(e);break;case Ot.OPERATIONS_ENUM.CSV_DATA_LOAD:n=iT.dataObject(e);break;case Ot.OPERATIONS_ENUM.IMPORT_FROM_S3:n=iT.s3FileObject(e);break;case Ot.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case Ot.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=aK(e,"date");break;case Ot.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=aK(e,"timestamp");break;case Ot.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=Zpe(e);break;case Ot.OPERATIONS_ENUM.RESTART_SERVICE:if(Ot.HDB_PROCESS_SERVICES[e.service]===void 0)throw cK(new Error,"Invalid service",lK.BAD_REQUEST,void 0,void 0,!0);break;default:break}if(n)throw cK(n,n.message,lK.BAD_REQUEST,void 0,void 0,!0);let s=new zpe;s.type=e.operation===Ot.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE?Ot.OPERATIONS_ENUM.DELETE_FILES_BEFORE:e.operation,s.type=e.operation,s.user=e.hdb_user?.username;let i=new Kpe(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await uK(i))}catch(f){let d=`There was an error inserting a new job: ${f}`;return hi.error(d),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=Vpe();try{o=await uK(i)}catch(f){let d=`There was an error inserting a new job: ${f}`;return hi.error(d),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return hi.error("Error creating a job, could not find a unique job id."),t}s.request=e;let l=new Jpe(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),u;try{u=await nhe(l)}catch(f){return hi.error(`There was an error inserting a job for job type: ${e.operation} -- ${f}`),t.success=!1,t}if(u.inserted_hashes.length===0)t.message=`Had a problem creating a job with type ${s.operation} and id ${s.id}`;else{let f=`Created a job with type ${s.type} and id ${s.id}`;t.message=f,t.createdJob=s,t.success=!0,hi.trace(f)}return t}a(che,"addJob");async function lhe(e){let t=Bl(e.from_date,Bl.ISO_8601),r=Bl(e.to_date,Bl.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 Wpe(n,e.hdb_user);try{return await she(s)}catch(i){throw hi.error(`there was a problem searching for jobs from date ${e.from_date} to date ${e.to_date} ${i}`),new Error("there was an error searching for jobs. Please check the log for details.")}}a(lhe,"getJobsInDateRange");async function _K(e){if(Fd.isEmptyOrZeroLength(e))return Fd.errorizeMessage("Invalid job ID specified.");let t=new Ype(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await rhe(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return hi.error(n),Fd.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(_K,"getJobById");async function uhe(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(Fd.isEmptyOrZeroLength(e.id))throw new Error("invalid ID passed to updateJob");(e.status===Ot.JOB_STATUS_ENUM.COMPLETE||e.status===Ot.JOB_STATUS_ENUM.ERROR)&&(e.end_datetime=Bl().valueOf());let t=new jpe(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await ihe(t),r}a(uhe,"updateJob")});var RK=w((Ave,AK)=>{"use strict";var hK=ie(),Ar=(H(),C(G)),dhe=require("moment"),oT=NI(),sh=z(),mK=MI(),EK=PI(),gK=Vc(),SK=et(),fhe=GS(),_he=Wa(),{parentPort:phe,isMainThread:TK}=require("worker_threads"),{onMessageByType:hhe}=et(),vI=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function mhe(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(hK.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(hK.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case Ar.JOB_TYPE_ENUM.csv_file_load:await Ki(e,oT.csvFileLoad);break;case Ar.JOB_TYPE_ENUM.csv_url_load:await Ki(e,oT.csvURLLoad);break;case Ar.JOB_TYPE_ENUM.csv_data_load:await Ki(e,oT.csvDataLoad);break;case Ar.JOB_TYPE_ENUM.import_from_s3:await Ki(e,oT.importFromS3);break;case Ar.JOB_TYPE_ENUM.empty_trash:break;case Ar.JOB_TYPE_ENUM.export_local:await Ki(e,EK.export_local);break;case Ar.JOB_TYPE_ENUM.export_to_s3:await Ki(e,EK.export_to_s3);break;case Ar.JOB_TYPE_ENUM.delete_files_before:case Ar.JOB_TYPE_ENUM.delete_records_before:await Ki(e,gK.deleteFilesBefore);break;case Ar.JOB_TYPE_ENUM.delete_audit_logs_before:await Ki(e,gK.deleteAuditLogsBefore);break;case Ar.JOB_TYPE_ENUM.delete_transaction_logs_before:await Ki(e,fhe.deleteTransactionLogsBefore);break;case Ar.JOB_TYPE_ENUM.restart_service:return await Ki(e,_he.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(mhe,"parseMessage");async function Ki(e,t){try{e.job.status=Ar.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=dhe().valueOf(),await mK.updateJob(e.job),await Ehe(e.job.id)}catch(r){let n=r.message!==void 0?r.message:r;typeof n=="string"?(n=`There was an error running ${t.name} job with id ${e.job.id} - ${n}`,r.message=n):sh.error(`There was an error running ${t.name} job with id ${e.job.id}`),sh.error(n),e.job.message=n,e.job.status=Ar.JOB_STATUS_ENUM.ERROR;try{await mK.updateJob(e.job)}catch(s){throw sh.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(Ki,"runJob");async function Ehe(e){sh.trace("launching job thread:",e),TK?SK.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Ar.PROCESS_NAME_ENV_PROP]:`JOB-${e}`}}):phe.postMessage({type:Ar.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(Ehe,"launchJobThread");TK&&hhe(Ar.ITC_EVENT_TYPES.START_JOB,async(e,t)=>{try{SK.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Ar.PROCESS_NAME_ENV_PROP]:`JOB-${e.jobId}`}})}catch(r){sh.error(r)}});AK.exports={parseMessage:mhe,RunnerMessage:vI}});var bK=w((yve,yK)=>{"use strict";var UI=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};yK.exports=UI});var zw=w((Nve,GI)=>{"use strict";var dT=Yr(),HI=WS(),aT=NI(),qo=Vg(),cT=go(),oh=Vc(),ghe=bN(),ih=An(),lT=F_(),Ct=Ww(),uT=z(),She=CN(),The=gd(),OK=ew(),Ahe=nS(),Rhe=nw(),yhe=sw(),bhe=aS(),Ohe=lS(),xI=uS(),NK=PI(),Nhe=KS(),kI=MI(),V=(H(),C(G)),{hdb_errors:ch,handleHDBError:ah}=pe(),{HTTP_STATUS_CODES:wK}=ch,BI=hS(),IK=Wa(),HK=require("util"),qd=Rn(),whe=As(),Ihe=Po(),CK=RK(),PK=(ju(),C(X_)),DK=(MS(),C(Gp)),LK=yt(),MK=GS(),vK=Kp(),{setServerUtilities:Che}=(qf(),C(wI)),{CONTEXT:Ove}=(Ea(),C(ER)),{_assignPackageExport:Phe}=Ti(),{transformReq:Dhe}=ie(),{server:Lhe}=(Vr(),C(Tu)),nn=uT.loggerWithTag("operation"),Gd=Zn(),UK=(Tl(),C(Sl)),Mhe=mI(),xK=dT.searchByHash,vhe=dT.searchByValue,Uhe=HK.promisify(dT.search),xhe=HK.promisify(HI.evaluateSQL),Bhe={[V.OPERATIONS_ENUM.CREATE_ATTRIBUTE]:!0,[V.OPERATIONS_ENUM.CREATE_TABLE]:!0,[V.OPERATIONS_ENUM.CREATE_SCHEMA]:!0,[V.OPERATIONS_ENUM.DROP_ATTRIBUTE]:!0,[V.OPERATIONS_ENUM.DROP_TABLE]:!0,[V.OPERATIONS_ENUM.DROP_SCHEMA]:!0},ee=bK();async function kK(e,t){try{if(e.body.operation!=="read_log"&&(uT.log_level===V.LOG_LEVELS.INFO||uT.log_level===V.LOG_LEVELS.DEBUG||uT.log_level===V.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,payload:o,...c}=e.body;nn.info(c)}}catch(n){nn.error(n)}let r=await Mhe.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return Bhe[e.body.operation]&&whe.setSchemaDataToGlobal(n=>{n&&nn.error(n)}),r}a(kK,"processLocalTransaction");var BK=khe();GI.exports={chooseOperation:FK,getOperationFunction:GK,operation:FI,processLocalTransaction:kK,executeJob:Ms};Che(GI.exports);Lhe.operation=FI;function FK(e){let t;try{t=GK(e)}catch(s){throw nn.error(`Error when selecting operation function - ${s}`),s}let{operation_function:r,job_operation_function:n}=t;try{if(e.operation==="sql"||e.search_operation&&e.search_operation.operation==="sql"){let s=e.operation==="sql"?e.sql:e.search_operation.sql,i=HI.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=HI.checkASTPermissions(e,i);if(o)throw nn.error(`${wK.FORBIDDEN} from operation ${e.operation}`),nn.warn(`User '${e.hdb_user?.username}' is not permitted to ${e.operation}`),ah(new Error,o,ch.HTTP_STATUS_CODES.FORBIDDEN,void 0,void 0,!0)}}else if(!e.bypass_auth&&e.operation!==V.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.operation!==V.OPERATIONS_ENUM.LOGIN&&e.operation!==V.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=Nhe.verifyPerms(i,s);if(o)throw nn.error(`${wK.FORBIDDEN} from operation ${e.operation}`),nn.warn(`User '${i.hdb_user?.username}' is not permitted to ${i.operation}`),ah(new Error,o,ch.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw ah(s,"There was an error when trying to choose an operation path")}return r}a(FK,"chooseOperation");function GK(e){if(nn.trace(`getOperationFunction with operation: ${e.operation}`),BK.has(e.operation))return BK.get(e.operation);throw ah(new Error,ch.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),ch.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(GK,"getOperationFunction");Phe("operation",FI);function FI(e,t,r){e.hdb_user=t?.user,e.bypass_auth=!r;let n=FK(e);return kK({body:e},n)}a(FI,"operation");async function Hhe(e){nn.trace("In serverUtils.catchup");let t=e.transaction,r=t.channel.split(":"),n=r[0],s=r[1];for(let i of t.transactions)try{i.schema=n,i.table=s,i[V.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case V.OPERATIONS_ENUM.INSERT:o=await qd.insert(i);break;case V.OPERATIONS_ENUM.UPDATE:o=await qd.update(i);break;case V.OPERATIONS_ENUM.UPSERT:o=await qd.upsert(i);break;case V.OPERATIONS_ENUM.DELETE:o=await oh.deleteRecord(i);break;default:nn.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){nn.info("Invalid operation in transaction"),nn.error(o)}}a(Hhe,"catchup");async function Ms(e){Dhe(e);let t,r;try{r=await kI.addJob(e),t=r.createdJob,nn.info("addJob result",r);let n=new CK.RunnerMessage(t,e);return{message:await CK.parseMessage(n)??`Starting job with id ${t.id}`,job_id:t.id}}catch(n){let s=`There was an error executing job: ${n.http_resp_msg?n.http_resp_msg:n}`;throw nn.error(s),ah(n,s)}}a(Ms,"executeJob");function khe(){let e=new Map;return e.set(V.OPERATIONS_ENUM.INSERT,new ee(qd.insert)),e.set(V.OPERATIONS_ENUM.UPDATE,new ee(qd.update)),e.set(V.OPERATIONS_ENUM.UPSERT,new ee(qd.upsert)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new ee(dT.searchByConditions)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_HASH,new ee(xK)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_ID,new ee(xK)),e.set(V.OPERATIONS_ENUM.SEARCH_BY_VALUE,new ee(vhe)),e.set(V.OPERATIONS_ENUM.SEARCH,new ee(Uhe)),e.set(V.OPERATIONS_ENUM.SQL,new ee(xhe)),e.set(V.OPERATIONS_ENUM.CSV_DATA_LOAD,new ee(Ms,aT.csvDataLoad)),e.set(V.OPERATIONS_ENUM.CSV_FILE_LOAD,new ee(Ms,aT.csvFileLoad)),e.set(V.OPERATIONS_ENUM.CSV_URL_LOAD,new ee(Ms,aT.csvURLLoad)),e.set(V.OPERATIONS_ENUM.IMPORT_FROM_S3,new ee(Ms,aT.importFromS3)),e.set(V.OPERATIONS_ENUM.CREATE_SCHEMA,new ee(qo.createSchema)),e.set(V.OPERATIONS_ENUM.CREATE_DATABASE,new ee(qo.createSchema)),e.set(V.OPERATIONS_ENUM.CREATE_TABLE,new ee(qo.createTable)),e.set(V.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new ee(qo.createAttribute)),e.set(V.OPERATIONS_ENUM.DROP_SCHEMA,new ee(qo.dropSchema)),e.set(V.OPERATIONS_ENUM.DROP_DATABASE,new ee(qo.dropSchema)),e.set(V.OPERATIONS_ENUM.DROP_TABLE,new ee(qo.dropTable)),e.set(V.OPERATIONS_ENUM.DROP_ATTRIBUTE,new ee(qo.dropAttribute)),e.set(V.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new ee(cT.describeSchema)),e.set(V.OPERATIONS_ENUM.DESCRIBE_DATABASE,new ee(cT.describeSchema)),e.set(V.OPERATIONS_ENUM.DESCRIBE_TABLE,new ee(cT.describeTable)),e.set(V.OPERATIONS_ENUM.DESCRIBE_ALL,new ee(cT.describeAll)),e.set(V.OPERATIONS_ENUM.DELETE,new ee(oh.deleteRecord)),e.set(V.OPERATIONS_ENUM.ADD_USER,new ee(ih.addUser)),e.set(V.OPERATIONS_ENUM.ALTER_USER,new ee(ih.alterUser)),e.set(V.OPERATIONS_ENUM.DROP_USER,new ee(ih.dropUser)),e.set(V.OPERATIONS_ENUM.LIST_USERS,new ee(ih.listUsersExternal)),e.set(V.OPERATIONS_ENUM.LIST_ROLES,new ee(lT.listRoles)),e.set(V.OPERATIONS_ENUM.ADD_ROLE,new ee(lT.addRole)),e.set(V.OPERATIONS_ENUM.ALTER_ROLE,new ee(lT.alterRole)),e.set(V.OPERATIONS_ENUM.DROP_ROLE,new ee(lT.dropRole)),e.set(V.OPERATIONS_ENUM.USER_INFO,new ee(ih.userInfo)),e.set(V.OPERATIONS_ENUM.READ_LOG,new ee(She)),e.set(V.OPERATIONS_ENUM.ADD_NODE,new ee(The)),e.set(V.OPERATIONS_ENUM.UPDATE_NODE,new ee(OK)),e.set(V.OPERATIONS_ENUM.SET_NODE_REPLICATION,new ee(OK)),e.set(V.OPERATIONS_ENUM.REMOVE_NODE,new ee(Ahe)),e.set(V.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new ee(Rhe)),e.set(V.OPERATIONS_ENUM.PURGE_STREAM,new ee(yhe)),e.set(V.OPERATIONS_ENUM.SET_CONFIGURATION,new ee(LK.setConfiguration)),e.set(V.OPERATIONS_ENUM.CLUSTER_STATUS,new ee(bhe.clusterStatus)),e.set(V.OPERATIONS_ENUM.CLUSTER_NETWORK,new ee(Ohe)),e.set(V.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new ee(xI.setRoutes)),e.set(V.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new ee(xI.getRoutes)),e.set(V.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new ee(xI.deleteRoutes)),e.set(V.OPERATIONS_ENUM.EXPORT_TO_S3,new ee(Ms,NK.export_to_s3)),e.set(V.OPERATIONS_ENUM.CREATE_CSR,new ee(Gd.createCsr)),e.set(V.OPERATIONS_ENUM.SIGN_CERTIFICATE,new ee(Gd.signCertificate)),e.set(V.OPERATIONS_ENUM.LIST_CERTIFICATES,new ee(Gd.listCertificates)),e.set(V.OPERATIONS_ENUM.ADD_CERTIFICATES,new ee(Gd.addCertificate)),e.set(V.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new ee(Gd.removeCertificate)),e.set(V.OPERATIONS_ENUM.GET_KEY,new ee(Gd.getKey)),e.set(V.OPERATIONS_ENUM.ADD_NODE_BACK,new ee(UK.addNodeBack)),e.set(V.OPERATIONS_ENUM.REMOVE_NODE_BACK,new ee(UK.removeNodeBack)),e.set(V.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new ee(Ms,oh.deleteFilesBefore)),e.set(V.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new ee(Ms,oh.deleteFilesBefore)),e.set(V.OPERATIONS_ENUM.EXPORT_LOCAL,new ee(Ms,NK.export_local)),e.set(V.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new ee(kI.handleGetJobsByStartDate)),e.set(V.OPERATIONS_ENUM.GET_JOB,new ee(kI.handleGetJob)),e.set(V.OPERATIONS_ENUM.GET_FINGERPRINT,new ee(BI.getFingerprint)),e.set(V.OPERATIONS_ENUM.SET_LICENSE,new ee(BI.setLicense)),e.set(V.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new ee(BI.getRegistrationInfo)),e.set(V.OPERATIONS_ENUM.RESTART,new ee(IK.restart)),e.set(V.OPERATIONS_ENUM.RESTART_SERVICE,new ee(Ms,IK.restartService)),e.set(V.OPERATIONS_ENUM.CATCHUP,new ee(Hhe)),e.set(V.OPERATIONS_ENUM.SYSTEM_INFORMATION,new ee(Ihe.systemInformation)),e.set(V.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new ee(Ms,oh.deleteAuditLogsBefore)),e.set(V.OPERATIONS_ENUM.READ_AUDIT_LOG,new ee(ghe)),e.set(V.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new ee(PK.createTokens)),e.set(V.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new ee(PK.refreshOperationToken)),e.set(V.OPERATIONS_ENUM.LOGIN,new ee(DK.login)),e.set(V.OPERATIONS_ENUM.LOGOUT,new ee(DK.logout)),e.set(V.OPERATIONS_ENUM.GET_CONFIGURATION,new ee(LK.getConfiguration)),e.set(V.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new ee(Ct.customFunctionsStatus)),e.set(V.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new ee(Ct.getCustomFunctions)),e.set(V.OPERATIONS_ENUM.GET_COMPONENT_FILE,new ee(Ct.getComponentFile)),e.set(V.OPERATIONS_ENUM.GET_COMPONENTS,new ee(Ct.getComponents)),e.set(V.OPERATIONS_ENUM.SET_COMPONENT_FILE,new ee(Ct.setComponentFile)),e.set(V.OPERATIONS_ENUM.DROP_COMPONENT,new ee(Ct.dropComponent)),e.set(V.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new ee(Ct.getCustomFunction)),e.set(V.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new ee(Ct.setCustomFunction)),e.set(V.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new ee(Ct.dropCustomFunction)),e.set(V.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new ee(Ct.addComponent)),e.set(V.OPERATIONS_ENUM.ADD_COMPONENT,new ee(Ct.addComponent)),e.set(V.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new ee(Ct.dropCustomFunctionProject)),e.set(V.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new ee(Ct.packageComponent)),e.set(V.OPERATIONS_ENUM.PACKAGE_COMPONENT,new ee(Ct.packageComponent)),e.set(V.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new ee(Ct.deployComponent)),e.set(V.OPERATIONS_ENUM.DEPLOY_COMPONENT,new ee(Ct.deployComponent)),e.set(V.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new ee(MK.readTransactionLog)),e.set(V.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new ee(Ms,MK.deleteTransactionLogsBefore)),e.set(V.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new ee(vK.installModules)),e.set(V.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new ee(vK.auditModules)),e.set(V.OPERATIONS_ENUM.GET_BACKUP,new ee(qo.getBackup)),e.set(V.OPERATIONS_ENUM.ADD_SSH_KEY,new ee(Ct.addSSHKey)),e.set(V.OPERATIONS_ENUM.UPDATE_SSH_KEY,new ee(Ct.updateSSHKey)),e.set(V.OPERATIONS_ENUM.DELETE_SSH_KEY,new ee(Ct.deleteSSHKey)),e.set(V.OPERATIONS_ENUM.LIST_SSH_KEYS,new ee(Ct.listSSHKeys)),e.set(V.OPERATIONS_ENUM.SET_SSH_KNOWN_HOSTS,new ee(Ct.setSSHKnownHosts)),e.set(V.OPERATIONS_ENUM.GET_SSH_KNOWN_HOSTS,new ee(Ct.getSSHKnownHosts)),e}a(khe,"initializeOperationFunctionMap")});var pT=w((Ive,VK)=>{"use strict";var fT=(H(),C(G)),Fhe=ie(),lh=z(),{handleHDBError:qI,hdb_errors:_T}=pe(),{isMainThread:Ghe}=require("worker_threads"),{Readable:qhe}=require("stream"),qK=require("os"),$he=require("util"),Vhe=NO(),Khe=$he.promisify(Vhe.authorize),$K=zw(),{createGzip:Yhe,constants:Whe}=require("zlib"),zhe=[fT.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,fT.OPERATIONS_ENUM.LOGIN,fT.OPERATIONS_ENUM.LOGOUT];function jhe(e){let t=`Found an uncaught exception with message: ${e.message}. ${qK.EOL}Stack: ${e.stack} ${qK.EOL}Terminating ${Ghe?"HDB":"thread"}.`;console.error(t),lh.fatal(t),process.exit(1)}a(jhe,"handleServerUncaughtException");function Jhe(e,t,r){if(lh[e.logLevel||"error"](e),e.statusCode)return typeof e.http_resp_msg!="object"?r.code(e.statusCode).send({error:e.http_resp_msg||e.message}):r.code(e.statusCode).send(e.http_resp_msg);let n=e.statusCode?e.statusCode:_T.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(Jhe,"serverErrorHandler");function Qhe(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=qI(new Error,"Invalid JSON.",_T.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if(Fhe.isEmpty(e.body.operation)){let n=qI(new Error,"Request body must include an 'operation' property.",_T.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(Qhe,"reqBodyValidationHandler");function Xhe(e,t,r){let n;!zhe.includes(e.body.operation)||e.body.operation===fT.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&!e.body.username&&!e.body.password?Khe(e,t).then(i=>{n=i,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(i=>{lh.warn(i),lh.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${i.stack}"`);let o=typeof i=="string"?{error:i}:{error:i.message};r(qI(i,o,_T.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(Xhe,"authHandler");async function Zhe(e,t,r=!1){let n;try{e.body.bypass_auth&&delete e.body.bypass_auth,n=$K.chooseOperation(e.body);let s=await $K.processLocalTransaction(e,n);if(s instanceof qhe&&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(Yhe({level:Whe.Z_BEST_SPEED})))}return s}catch(s){throw lh.error(s),s}}a(Zhe,"handlePostRequest");VK.exports={authHandler:Xhe,handlePostRequest:Zhe,handleServerUncaughtException:jhe,serverErrorHandler:Jhe,reqBodyValidationHandler:Qhe}});var zK=w((Pve,WK)=>{"use strict";var eme=require("fastify-plugin"),{handlePostRequest:KK,authHandler:tme,reqBodyValidationHandler:rme}=pT();async function nme(e){e.decorate("hdbCore",{preValidation:[rme,tme],request:a(t=>YK(KK(t,response)),"request"),requestWithoutAuthentication:a((t,r)=>YK(KK(t,r,!0)),"requestWithoutAuthentication")})}a(nme,"hdbCore");async function YK(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(YK,"convertAsyncIterators");WK.exports=eme(nme)});var JK=w((Mve,jK)=>{"use strict";var Lve=require("fs"),hT=ae();hT.initSync();var{CONFIG_PARAMS:$I}=(H(),C(G)),sme=1024*1024*1024;function ime(e){let t=hT.get($I.HTTP_TIMEOUT),r=hT.get($I.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:sme,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,maxParamLength:hT.get($I.HTTP_MAXPARAMLENGTH)??1e3,https:e}}a(ime,"getServerOptions");jK.exports=ime});var ZK=w((Uve,XK)=>{"use strict";var VI=ae();VI.initSync();var{CONFIG_PARAMS:QK}=(H(),C(G));function ome(){let e=VI.get(QK.HTTP_CORSACCESSLIST),t=VI.get(QK.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(ome,"getCORSOptions");XK.exports=ome});var rY=w((Bve,tY)=>{"use strict";var eY=ae();eY.initSync();var ame=(H(),C(G));function cme(){return eY.get(ame.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(cme,"getHeaderTimeoutConfig");tY.exports=cme});var YI={};ve(YI,{customFunctionsServer:()=>dme,ready:()=>mY,start:()=>ume});function ume(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){$o||($o=hY(t),Ye.http((await $o).server));let o=await $o,c=(0,KI.dirname)(s),l=(0,KI.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!nY.has(c)){nY.add(c);try{o.register(_me(c,l))}catch(u){if(u.message==="Root plugin has already booted")ht.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw u}}},ready:mY}}async function dme(){try{ht.info("In Custom Functions Fastify server"+process.cwd()),ht.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),ht.debug(`Custom Functions server process ${process.pid} starting up.`),await fme();let e=lY.get(B.HTTP_SECUREPORT)>0,t;try{t=$o=await hY(e)}catch(r){throw ht.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw ht.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){ht.error(`Custom Functions ${process.pid} Error: ${e}`),ht.error(e),process.exit(1)}}async function fme(){try{ht.info("Custom Functions starting configuration."),await uY.setUsersWithRolesCache(),ht.info("Custom Functions completed configuration.")}catch(e){ht.error(e)}}function _me(e,t){return async function(r){try{ht.info("Custom Functions starting buildRoutes"),ht.trace("Loading fastify routes folder "+e),(0,sY.existsSync)(e)&&r.register(cY.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:ht.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?ht.error(s.message):s&&ht.error(s),o()})}catch(n){ht.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function hY(e){ht.info("Custom Functions starting buildServer.");let t=(0,dY.default)(e),r=(0,iY.default)(t);r.server.headersTimeout=(0,_Y.default)(),r.setErrorHandler(pY.serverErrorHandler);let n=(0,fY.default)();return n&&r.register(oY.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,l){r.server.emit("unhandled",c.raw,l.raw)}),o()}),r.register(aY.default),await r.register(lme),await r.after(),jf(r),ht.info("Custom Functions completed buildServer."),r}function mY(){if($o)return $o.then?$o.then(e=>e.ready()):$o.ready()}var KI,sY,iY,oY,aY,cY,lY,ht,lme,uY,dY,fY,_Y,pY,$o,nY,EY=be(()=>{KI=require("path"),sY=require("fs"),iY=M(require("fastify")),oY=M(require("@fastify/cors")),aY=M(AO()),cY=M(require("@fastify/autoload")),lY=M(ae());H();ht=M(z()),lme=M(zK()),uY=M(An()),dY=M(JK()),fY=M(ZK()),_Y=M(rY()),pY=M(pT());ao();Vr();nY=new Set;a(ume,"start");a(dme,"customFunctionsServer");a(fme,"setUp");a(_me,"buildRouteFolder");a(hY,"buildServer");a(mY,"ready")});var WI={};ve(WI,{start:()=>pme});function pme(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,RY.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){SY||(SY=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=gY.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,TY.default)(s,(0,AY.realpathSync)(o))}}return i(s)},{runFirst:!0})),gY.set(r,n)}}}var TY,AY,RY,gY,SY,yY=be(()=>{TY=M(require("send")),AY=require("fs"),RY=M(require("serve-static")),gY=new Map;a(pme,"start")});var zI={};ve(zI,{start:()=>hme});function hme({override:e}){return{handleFile:a((t,r,n)=>{mT.default.debug(`Loading env file: ${n}`);for(let[s,i]of Object.entries((0,bY.parse)(t))){if(process.env[s]!==void 0)if(mT.default.warn(`Environment variable conflict: ${s} from ${n} is already set on process.env`),e)mT.default.debug(`override option enabled. overriding environment variable: ${s}`);else continue;process.env[s]=i}},"handleFile")}}var bY,mT,OY=be(()=>{bY=require("dotenv"),mT=M(z());a(hme,"start")});var wY={};ve(wY,{Request:()=>jI,createReuseportFd:()=>ET});var NY,jI,JI,QI,ET,XI=be(()=>{NY=require("os"),jI=class{static{a(this,"Request")}#e;constructor(t,r){this.method=t.method;let n=t.url;this._nodeRequest=t,this._nodeResponse=r,this.url=n,this.headers=new QI(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 JI(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}sendEarlyHints(t,r={}){r.link=t,this._nodeResponse.writeEarlyHints(r)}},JI=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)}},QI=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,NY.platform)()!="win32"&&(ET=require("node-unix-socket").createReuseportFd)});var eC=w((Yve,IY)=>{"use strict";var uh=ae();uh.initSync();var $d=require("fs-extra"),ZI=require("path"),Vd=(H(),C(G)),mme=require("crypto"),Eme=require("uuid").v4;IY.exports=gme;function gme(){if(uh.getHdbBasePath()!==void 0){let e=ZI.join(uh.getHdbBasePath(),Vd.LICENSE_KEY_DIR_NAME,Vd.JWT_ENUM.JWT_PRIVATE_KEY_NAME),t=ZI.join(uh.getHdbBasePath(),Vd.LICENSE_KEY_DIR_NAME,Vd.JWT_ENUM.JWT_PUBLIC_KEY_NAME),r=ZI.join(uh.getHdbBasePath(),Vd.LICENSE_KEY_DIR_NAME,Vd.JWT_ENUM.JWT_PASSPHRASE_NAME);try{$d.accessSync(r),$d.accessSync(e),$d.accessSync(t)}catch(n){if(n.code==="ENOENT"){let s=Eme(),i=mme.generateKeyPairSync("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem",cipher:"aes-256-cbc",passphrase:s}});$d.writeFileSync(r,s),$d.writeFileSync(e,i.privateKey),$d.writeFileSync(t,i.publicKey)}else throw n}}}a(gme,"checkJWTTokenExist")});var PY=w((zve,CY)=>{"use strict";var tC=class{static{a(this,"HdbInfoInsertObject")}constructor(t,r,n){this.info_id=t,this.data_version_num=r,this.hdb_version_num=n}};CY.exports={HdbInfoInsertObject:tC}});var MY=w((Jve,LY)=>{"use strict";var DY=(H(),C(G)),rC=class{static{a(this,"UpgradeObject")}constructor(t,r){this[DY.UPGRADE_JSON_FIELD_NAMES_ENUM.DATA_VERSION]=t,this[DY.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION]=r}};LY.exports={UpgradeObject:rC}});var gT=w((Xve,UY)=>{"use strict";var vs=require("prompt"),Kd=require("chalk"),vY=z(),mi=require("os"),nC=ua(),sC=["yes","y"];async function Sme(e){let t=`${mi.EOL}`+Kd.bold.green("Your current HarperDB version requires that we complete an update process.")+`${mi.EOL}If a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${mi.EOL}${mi.EOL}You can read more about the changes in this upgrade at https://harperdb.io/developers/release-notes/${mi.EOL}`;vs.override=nC(["CONFIRM_UPGRADE"]),vs.start(),vs.message=t;let r={properties:{CONFIRM_UPGRADE:{description:Kd.magenta(`${mi.EOL}[CONFIRM_UPGRADE] Do you want to upgrade your HDB instance now? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"no",required:!0}}},n;try{n=await vs.get([r])}catch(s){return vY.error("There was an error when prompting user about an upgrade."),vY.error(s),!1}return sC.includes(n.CONFIRM_UPGRADE)}a(Sme,"forceUpdatePrompt");async function Tme(e){let t=`${mi.EOL}`+Kd.bold.green(`Your installed HarperDB version is older than the version used to create your data. Downgrading is not recommended as it is not tested and guaranteed to work. However, if you need to downgrade, and a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${mi.EOL}`);vs.override=nC(["CONFIRM_DOWNGRADE"]),vs.start(),vs.message=t;let r={properties:{CONFIRM_DOWNGRADE:{description:Kd.magenta(`${mi.EOL}[CONFIRM_DOWNGRADE] Do you want to proceed with using your downgraded HDB instance now? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"no",required:!0}}},n=await vs.get([r]);return sC.includes(n.CONFIRM_DOWNGRADE)}a(Tme,"forceDowngradePrompt");async function Ame(){let e=`${mi.EOL}`+Kd.bold.green("We now require a Certifacte Authority certificate. HarperDB can generate all new certificates for you (your existing certificates will be backed up) or you can keep any existing certificates and add your own CA certificate. To add your own CA certificate set the <certificateAuthority> parameter in harperdb-config.yaml");vs.override=nC(["GENERATE_CERTS"]),vs.start(),vs.message=e;let t={properties:{GENERATE_CERTS:{description:Kd.magenta(`${mi.EOL}[GENERATE_CERTS] Do you want HarperDB to generate all new certificates? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"yes",required:!0}}},r=await vs.get([t]);return sC.includes(r.GENERATE_CERTS)}a(Ame,"upgradeCertsPrompt");UY.exports={forceUpdatePrompt:Sme,forceDowngradePrompt:Tme,upgradeCertsPrompt:Ame}});var oC=w((eUe,xY)=>{"use strict";var iC=class{static{a(this,"UpgradeDirective")}constructor(t){this.version=t,this.sync_functions=[],this.async_functions=[]}};xY.exports=iC});var HY=w((oUe,BY)=>{"use strict";var Rme=ie(),yme=yt(),rUe=z(),nUe=require("path"),sUe=require("fs"),iUe=(H(),C(G));BY.exports={getOldPropsValue:bme};function bme(e,t,r=!1){let n=t.getRaw(e);return Rme.isNotEmptyAndHasValue(n)?n:r?yme.getDefaultConfig(e):""}a(bme,"getOldPropsValue")});var qY=w((cUe,GY)=>{"use strict";var Xa=require("path"),Za=require("fs-extra"),Ome=require("properties-reader"),Nme=oC(),_r=z(),{getOldPropsValue:mt}=HY(),{HDB_SETTINGS_NAMES:ge,CONFIG_PARAMS:Hl}=(H(),C(G)),kl=yt(),ST=ae(),kY=ie(),Yi=(H(),C(G)),aC=new Nme("3.1.0"),FY=[];function wme(){let e=Ome(ST.get(ge.SETTINGS_PATH_KEY)),t="Updating settings file for version 3.1.0";console.log(t),_r.info(t);let r=` ;Settings for the HarperDB process.
38
+ `)}catch{f=". Unable to get known hosts from github.com. Set your known hosts manually using set_ssh_known_hosts."}o&&await Oe.appendFile(ko,o);let d=await fi(e);return d.message=`Added ssh key: ${r}${f}`,d}a(Ffe,"addSSHKey");async function Gfe(e){let t=Cn.updateSSHKeyValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let{name:r,key:n}=e;Bt.trace("updating ssh key",r);let s=we.join(Qa,r+".key");if(!await Oe.pathExists(s))throw new Error("Key does not exist. Use add_ssh_key");await Oe.outputFile(s,n);let i=await fi(e);return i.message=`Updated ssh key: ${r}`,i}a(Gfe,"updateSSHKey");async function qfe(e){let t=Cn.deleteSSHKeyValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let{name:r}=e;Bt.trace("deleting ssh key",r);let n=we.join(Qa,r+".key"),s=we.join(Qa,"config");if(!await Oe.pathExists(n))throw new Error("Key does not exist");let i=await Oe.readFile(s,"utf8"),o=new RegExp(`#${r}[\\S\\s]*?IdentitiesOnly yes`,"g");i=i.replace(o,""),await Oe.outputFile(s,i),Oe.removeSync(n);let c=await fi(e);return c.message=`Deleted ssh key: ${r}`,c}a(qfe,"deleteSSHKey");async function $fe(e){let t=[];return await Oe.pathExists(Qa)&&(await Oe.readdir(Qa)).forEach(r=>{r!="known_hosts"&&r!="config"&&t.push({name:r.split(".")[0]})}),t}a($fe,"listSSHKeys");async function Vfe(e){let t=Cn.setSSHKnownHostsValidator(e);if(t)throw Ht(t,t.message,kt.BAD_REQUEST);let{known_hosts:r}=e;await Oe.outputFile(ko,r);let n=await fi(e);return n.message="Known hosts successfully set",n}a(Vfe,"setSSHKnownHosts");async function Kfe(e){return await Oe.pathExists(ko)?{known_hosts:await Oe.readFile(ko,"utf8")}:{known_hosts:null}}a(Kfe,"getSSHKnownHosts");Object.assign(xV,{customFunctionsStatus:Nfe,getCustomFunctions:wfe,getCustomFunction:Ife,setCustomFunction:Cfe,dropCustomFunction:Pfe,addComponent:Dfe,dropCustomFunctionProject:Lfe,packageComponent:Mfe,deployComponent:vfe,getComponents:xfe,getComponentFile:Bfe,setComponentFile:Hfe,dropComponent:kfe,addSSHKey:Ffe,updateSSHKey:Gfe,deleteSSHKey:qfe,listSSHKeys:$fe,setSSHKnownHosts:Vfe,getSSHKnownHosts:Kfe})});var Jw=w((xMe,HV)=>{"use strict";var Ps=require("joi"),BV=ot();HV.exports={readTransactionLogValidator:Yfe,deleteTransactionLogsBeforeValidator:Wfe};function Yfe(e){let t=Ps.object({schema:Ps.string(),database:Ps.string(),table:Ps.string().required(),from:Ps.date().timestamp(),to:Ps.date().timestamp(),limit:Ps.number().min(1)});return BV.validateBySchema(e,t)}a(Yfe,"readTransactionLogValidator");function Wfe(e){let t=Ps.object({schema:Ps.string(),database:Ps.string(),table:Ps.string().required(),timestamp:Ps.date().timestamp().required()});return BV.validateBySchema(e,t)}a(Wfe,"deleteTransactionLogsBeforeValidator")});var qS=w((HMe,VV)=>{"use strict";var Qw=(H(),C(G)),Jp=ir(),kV=ie(),FV=ae(),GV=Eo(),qV=z(),{handleHDBError:FS,hdb_errors:zfe}=pe(),{HTTP_STATUS_CODES:GS}=zfe,{readTransactionLogValidator:jfe,deleteTransactionLogsBeforeValidator:Jfe}=Jw(),$V=Vn(),Qfe="Logs successfully deleted from transaction log.",Xfe="All logs successfully deleted from transaction log.";VV.exports={readTransactionLog:Zfe,deleteTransactionLogsBefore:t_e};async function Zfe(e){let t=jfe(e);if(t)throw FS(t,t.message,GS.BAD_REQUEST,void 0,void 0,!0);e.database=e.database??e.schema??"data";let r=kV.checkSchemaTableExist(e.database,e.table);if(r)throw FS(new Error,r,GS.NOT_FOUND,void 0,void 0,!0);return FV.get(Qw.CONFIG_PARAMS.CLUSTERING_ENABLED)?await e_e(e):(qV.info("Reading HarperDB logs used by Plexus"),(e.from||e.to)&&(e.search_type="timestamp",e.search_values=[e.from??0],e.to&&(e.search_values[1]=e.to)),$V.readAuditLog(e))}a(Zfe,"readTransactionLog");async function*e_e(e){let t=GV.createNatsTableStreamName(e.database,e.table),r=await Jp.viewStreamIterator(t,parseInt(e.from),e.limit);for await(let n of r){let s=Math.floor(n?.nats_timestamp/1e6);if(e.to&&s>e.to)break;let i={operation:n?.entry?.operation,user:n?.entry?.__origin?.user,timestamp:s,records:n?.entry?.records,attributes:n?.entry?.attributes};n?.entry?.operation===Qw.OPERATIONS_ENUM.DELETE&&(i.hash_values=n?.entry?.hash_values),yield i}}a(e_e,"readTransactionLogNats");async function t_e(e){let t=Jfe(e);if(t)throw FS(t,t.message,GS.BAD_REQUEST,void 0,void 0,!0);if(e.database=e.database??e.schema??"data",!FV.get(Qw.CONFIG_PARAMS.CLUSTERING_ENABLED))return qV.info("Delete transaction logs called for Plexus"),$V.deleteAuditLogsBefore(e);let{database:r,table:n,timestamp:s}=e,i=kV.checkSchemaTableExist(r,n);if(i)throw FS(new Error,i,GS.NOT_FOUND,void 0,void 0,!0);let o=GV.createNatsTableStreamName(r,n),{jsm:c}=await Jp.getNATSReferences(),l=await Jp.getStreamInfo(o),u=new Date(l.state.first_ts).getTime();if(s<=u)return`No transactions exist before: ${s}`;let f=Qfe,d,p=new Date(l.state.last_ts).getTime();return s>p?(d=l.state.last_seq+1,f=Xfe):d=(await Jp.viewStream(o,parseInt(s),1))[0].nats_sequence,await Jp.purgeTableStream(r,n,{seq:d}),f}a(t_e,"deleteTransactionLogsBefore")});var YV=w((FMe,KV)=>{"use strict";var Xw=class{static{a(this,"PermissionTableResponseObject")}constructor(t,r,n=[],s=[]){this.schema=t,this.table=r,this.required_table_permissions=n,this.required_attribute_permissions=s}};KV.exports=Xw});var zV=w((qMe,WV)=>{"use strict";var Zw=class{static{a(this,"PermissionAttributeResponseObject")}constructor(t,r=[]){this.attribute_name=t,this.required_permissions=r}};WV.exports=Zw});var tI=w((VMe,JV)=>{"use strict";var jV=YV(),r_e=zV(),{HDB_ERROR_MSGS:n_e}=xn(),eI=class{static{a(this,"PermissionResponseObject")}constructor(){this.error=n_e.OP_AUTH_PERMS_ERROR,this.unauthorized_access={},this.invalid_schema_items=[]}handleUnauthorizedItem(t){return this.invalid_schema_items=[],this.unauthorized_access=[t],this}handleInvalidItem(t){return this.invalid_schema_items=[t],this.unauthorized_access=[],this}addInvalidItem(t,r,n){if(r&&n){let s=`${r}_${n}`;if(this.unauthorized_access[s])return}this.invalid_schema_items.push(t)}addUnauthorizedTable(t,r,n){let s=new jV(t,r,n),i=`${t}_${r}`;this.unauthorized_access[i]=s}addUnauthorizedAttributes(t,r,n,s){let i=[];t.forEach(c=>{let l=new r_e(c,s[c]);i.push(l)});let o=`${r}_${n}`;if(this.unauthorized_access[o])this.unauthorized_access[o].required_attribute_permissions=i;else{let c=new jV(r,n,[],i);this.unauthorized_access[o]=c}}getPermsResponse(){let t=Object.values(this.unauthorized_access);return t.length>0||this.invalid_schema_items.length>0?(this.unauthorized_access=t,this):null}};JV.exports=eI});var YS=w((zMe,_1)=>{"use strict";var rI=yn(),$S=Yr(),Ds=Kg(),Zp=go(),nI=zc(),s_e=ON(),i_e=fG(),eh=Rn(),VS=F_(),Tr=z(),o_e=PN(),a_e=Sd(),c_e=tw(),l_e=sS(),u_e=sw(),d_e=iw(),f_e=cS(),__e=uS(),sI=dS(),Fo=ie(),p_e=Vq(),iI=mS(),ZV=za(),rn=(H(),C(G)),e1=sV(),h_e=Po(),t1=(Ju(),C(X_)),r1=(vS(),C(Gp)),n1=yt(),ur=zw(),m_e=require("alasql"),s1=qS(),i1=Kp(),Bd=Zn(),o1=(bl(),C(yl)),a1=tI(),{handleHDBError:Pn,hdb_errors:c1}=pe(),{addNodeBack:YMe,removeNodeBack:WMe}=(bl(),C(yl)),{HDB_ERROR_MSGS:xr,HTTP_STATUS_CODES:Qp}=c1,X=new Map,l1="delete",Xa="insert",Go="read",xl="update",Xp="describe",QV=Zp.describeSchema.name,XV=Zp.describeTable.name,u1={delete:!0,deleteRecord:!0,update:!0,updateData:!0,dropAttribute:!0,dropTable:!0,dropSchema:!0,upsert:!0,upsertData:!0},E_e={insert:!0,delete:!0,deleteRecord:!0,update:!0,updateData:!0,upsert:!0,upsertData:!0},g_e="catchup",S_e="handleGetJob",T_e="handleGetJobsByStartDate",KS={CSV_DATA_LOAD:"csvDataLoad",CSV_URL_LOAD:"csvURLLoad",CSV_FILE_LOAD:"csvFileLoad",IMPORT_FROM_S3:"importFromS3"},A_e=[Ds.createTable.name,Ds.createAttribute.name,Ds.dropTable.name,Ds.dropAttribute.name],d1={EXPORT_TO_S3:"export_to_s3",EXPORT_LOCAL:"export_local"},re=class{static{a(this,"permission")}constructor(t,r){this.requires_su=t,this.perms=r}};X.set(rI.insert.name,new re(!1,[Xa]));X.set(rI.update.name,new re(!1,[xl]));X.set(rI.upsert.name,new re(!1,[Xa,xl]));X.set($S.searchByConditions.name,new re(!1,[Go]));X.set($S.searchByHash.name,new re(!1,[Go]));X.set($S.searchByValue.name,new re(!1,[Go]));X.set($S.search.name,new re(!1,[Go]));X.set(Ds.createSchema.name,new re(!0,[]));X.set(Ds.createTable.name,new re(!0,[]));X.set(Ds.createAttribute.name,new re(!1,[Xa]));X.set(Ds.dropSchema.name,new re(!0,[]));X.set(Ds.dropTable.name,new re(!0,[]));X.set(Ds.dropAttribute.name,new re(!0,[]));X.set(Zp.describeSchema.name,new re(!1,[Go]));X.set(Zp.describeTable.name,new re(!1,[Go]));X.set(nI.deleteRecord.name,new re(!1,[l1]));X.set(eh.addUser.name,new re(!0,[]));X.set(eh.alterUser.name,new re(!0,[]));X.set(eh.dropUser.name,new re(!0,[]));X.set(eh.listUsersExternal.name,new re(!0,[]));X.set(VS.listRoles.name,new re(!0,[]));X.set(VS.addRole.name,new re(!0,[]));X.set(VS.alterRole.name,new re(!0,[]));X.set(VS.dropRole.name,new re(!0,[]));X.set(o_e.name,new re(!0,[]));X.set(a_e.name,new re(!0,[]));X.set(c_e.name,new re(!0,[]));X.set(l_e.name,new re(!0,[]));X.set(u_e.name,new re(!0,[]));X.set(d_e.name,new re(!0,[]));X.set(sI.setRoutes.name,new re(!0,[]));X.set(sI.getRoutes.name,new re(!0,[]));X.set(sI.deleteRoutes.name,new re(!0,[]));X.set(n1.setConfiguration.name,new re(!0,[]));X.set(f_e.clusterStatus.name,new re(!0,[]));X.set(__e.name,new re(!0,[]));X.set(iI.getFingerprint.name,new re(!0,[]));X.set(iI.setLicense.name,new re(!0,[]));X.set(nI.deleteFilesBefore.name,new re(!0,[]));X.set(nI.deleteAuditLogsBefore.name,new re(!0,[]));X.set(ZV.restart.name,new re(!0,[]));X.set(ZV.restartService.name,new re(!0,[]));X.set(s_e.name,new re(!0,[]));X.set(i_e.name,new re(!0,[Go]));X.set(h_e.systemInformation.name,new re(!0,[]));X.set(n1.getConfiguration.name,new re(!0,[]));X.set(s1.readTransactionLog.name,new re(!0,[]));X.set(s1.deleteTransactionLogsBefore.name,new re(!0,[]));X.set(i1.installModules.name,new re(!0,[]));X.set(i1.auditModules.name,new re(!0,[]));X.set(Bd.createCsr.name,new re(!0,[]));X.set(Bd.signCertificate.name,new re(!0,[]));X.set(Bd.listCertificates.name,new re(!0,[]));X.set(Bd.addCertificate.name,new re(!0,[]));X.set(Bd.removeCertificate.name,new re(!0,[]));X.set(Bd.getKey.name,new re(!0,[]));X.set(o1.addNodeBack.name,new re(!0,[]));X.set(o1.removeNodeBack.name,new re(!0,[]));X.set(t1.createTokens.name,new re(!1,[]));X.set(t1.refreshOperationToken.name,new re(!1,[]));X.set(r1.login.name,new re(!1,[]));X.set(r1.logout.name,new re(!1,[]));X.set(ur.customFunctionsStatus.name,new re(!0,[]));X.set(ur.getCustomFunctions.name,new re(!0,[]));X.set(ur.getComponents.name,new re(!0,[]));X.set(ur.getComponentFile.name,new re(!0,[]));X.set(ur.setComponentFile.name,new re(!0,[]));X.set(ur.dropComponent.name,new re(!0,[]));X.set(ur.getCustomFunction.name,new re(!0,[]));X.set(ur.setCustomFunction.name,new re(!0,[]));X.set(ur.dropCustomFunction.name,new re(!0,[]));X.set(ur.addComponent.name,new re(!0,[]));X.set(ur.dropCustomFunctionProject.name,new re(!0,[]));X.set(ur.packageComponent.name,new re(!0,[]));X.set(ur.deployComponent.name,new re(!0,[]));X.set(ur.addSSHKey.name,new re(!0,[]));X.set(ur.updateSSHKey.name,new re(!0,[]));X.set(ur.deleteSSHKey.name,new re(!0,[]));X.set(ur.listSSHKeys.name,new re(!0,[]));X.set(ur.setSSHKnownHosts.name,new re(!0,[]));X.set(ur.getSSHKnownHosts.name,new re(!0,[]));X.set(iI.getRegistrationInfo.name,new re(!1,[]));X.set(eh.userInfo.name,new re(!1,[]));X.set(Zp.describeAll.name,new re(!1,[]));X.set(S_e,new re(!1,[]));X.set(T_e,new re(!0,[]));X.set(g_e,new re(!0,[]));X.set(KS.CSV_DATA_LOAD,new re(!1,[Xa,xl]));X.set(KS.CSV_URL_LOAD,new re(!1,[Xa,xl]));X.set(KS.CSV_FILE_LOAD,new re(!1,[Xa,xl]));X.set(KS.IMPORT_FROM_S3,new re(!1,[Xa,xl]));X.set(d1.EXPORT_TO_S3,new re(!0,[]));X.set(d1.EXPORT_LOCAL,new re(!0,[]));X.set(rn.VALID_SQL_OPS_ENUM.DELETE,new re(!1,[l1]));X.set(rn.VALID_SQL_OPS_ENUM.SELECT,new re(!1,[Go]));X.set(rn.VALID_SQL_OPS_ENUM.INSERT,new re(!1,[Xa]));X.set(rn.VALID_SQL_OPS_ENUM.UPDATE,new re(!1,[xl]));_1.exports={verifyPerms:y_e,verifyPermsAst:R_e,verifyBulkLoadAttributePerms:O_e};function R_e(e,t,r){if(Fo.isEmptyOrZeroLength(e))throw Tr.info("verify_perms_ast has an empty user parameter"),Pn(new Error);if(Fo.isEmptyOrZeroLength(t))throw Tr.info("verify_perms_ast has an empty user parameter"),Pn(new Error);if(Fo.isEmptyOrZeroLength(r))throw Tr.info("verify_perms_ast has a null operation parameter"),Pn(new Error);try{let n=new a1,s=new p_e(e),i=s.getSchemas(),o=new Map;if((!i||i.length===0)&&s.affected_attributes&&s.affected_attributes.size>0)throw Tr.info("No schemas defined in verifyPermsAst(), will not continue."),Pn(new Error);let c=!!t.role.permission.super_user,l=i.includes("system");if(l&&u1[r])throw Pn(new Error,xr.DROP_SYSTEM,Qp.FORBIDDEN);if(c&&!l)return null;let u=e1.getRolePermissions(t.role);t.role.permission=u,!c&&e instanceof m_e.yy.Select&&(e=s.updateAttributeWildcardsForRolePerms(u));for(let d=0;d<i.length;d++){let p=s.getTablesBySchemaName(i[d]);p&&o.set(i[d],p)}let f=f1(t,r,o,n);return f||(o.forEach((d,p)=>{for(let _=0;_<d.length;_++){let h=s.getAttributesBySchemaTableName(p,d[_]),S=aI(t.role.permission,p,d[_]);oI(h,S,r,d[_],p,n)}}),n.getPermsResponse())}catch(n){throw Pn(n)}}a(R_e,"verifyPermsAst");function y_e(e,t){if(e===null||t===null||e.hdb_user===void 0||e.hdb_user===null)throw Tr.info("null required parameter in verifyPerms"),Pn(new Error,xr.DEFAULT_INVALID_REQUEST,Qp.BAD_REQUEST);let r;t instanceof Function?r=t.name:r=t;let n=e.action,s=e.schema??e.database,i=e.table,o=new Map;s&&i&&o.set(s,[i]);let c=new a1;if(Fo.isEmptyOrZeroLength(e.hdb_user?.role)||Fo.isEmptyOrZeroLength(e.hdb_user?.role?.permission))return Tr.info(`User ${e.hdb_user?.username} has no role or permissions. Please assign the user a valid role.`),c.handleUnauthorizedItem(xr.USER_HAS_NO_PERMS(e.hdb_user?.username));let l=!!e.hdb_user?.role?.permission?.super_user,u=e.hdb_user?.role?.permission?.structure_user,f=o.has(rn.SYSTEM_SCHEMA_NAME)||s===rn.SYSTEM_SCHEMA_NAME;if(l&&f&&E_e[e.operation]&&(i===rn.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME||i===rn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||i===rn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME))return null;if(f&&u1[r])throw Pn(new Error,xr.DROP_SYSTEM,Qp.FORBIDDEN);if(l&&!f||u===!0&&(r===Ds.createSchema.name||r===Ds.dropSchema.name))return null;if(A_e.indexOf(r)>=0&&(u===!0||Array.isArray(u)))return u===!0||u.indexOf(s)>=0?null:c.handleUnauthorizedItem(`User does not have access to perform '${e.operation}' against schema '${s}'`);let d=e1.getRolePermissions(e.hdb_user?.role);if(e.hdb_user?.role&&(e.hdb_user.role.permission=d),(r===QV||r===XV)&&!d.super_user){if(s===rn.SYSTEM_SCHEMA_NAME)return c.handleUnauthorizedItem(xr.SCHEMA_PERM_ERROR(s));if(r===QV&&(!d[s]||!d[s][Xp]))return c.handleInvalidItem(xr.SCHEMA_NOT_FOUND(s));if(r===XV&&(!d[s]||!d[s].tables[i]||!d[s].tables[i][Xp]))return c.handleInvalidItem(xr.TABLE_NOT_FOUND(s,i))}let p=f1(e.hdb_user,r,o,c,n);if(p)return p;if(X.get(r)&&X.get(r).perms.length===0)return null;if(!l&&e.get_attributes&&rn.SEARCH_WILDCARDS.includes(e.get_attributes[0])){let S=[],g=d[s].tables[i];g[rn.PERMS_CRUD_ENUM.READ]&&(g.attribute_permissions.length>0?g.attribute_permissions.filter(E=>E[rn.PERMS_CRUD_ENUM.READ]).forEach(E=>{S.push(E.attribute_name)}):S=global.hdb_schema[s][i].attributes.map(R=>R.attribute),e.get_attributes=S)}let _=b_e(e),h=aI(e.hdb_user?.role?.permission,s,i);return oI(_,h,r,i,s,c,n),c.getPermsResponse()}a(y_e,"verifyPerms");function f1(e,t,r,n,s){if(Fo.arrayHasEmptyValues([e,t,r]))throw Tr.info("hasPermissions has an invalid parameter"),Pn(new Error);let i=r.has("system"),o=e.role.permission;if(o.super_user&&(!i||X.get(t).requires_su))return null;if(!X.get(t))throw Tr.info(`operation ${t} not found.`),Pn(new Error,xr.OP_NOT_FOUND(t),Qp.BAD_REQUEST);if(X.get(t)&&X.get(t).requires_su)return Tr.info(`operation ${t} requires SU permissions.`),n.handleUnauthorizedItem(xr.OP_IS_SU_ONLY(t));let c=r.keys();for(let l of c){try{if(l&&!o[l]||o[l][Xp]===!1){n.addInvalidItem(xr.SCHEMA_NOT_FOUND(l));continue}}catch{n.addInvalidItem(xr.SCHEMA_NOT_FOUND(l));continue}let u=r.get(l);for(let f of u){let d=o[l].tables[f];if(!d||d[Xp]===!1)n.addInvalidItem(xr.TABLE_NOT_FOUND(l,f));else try{let p=[],_=X.get(t).perms;!Fo.isEmpty(s)&&_.includes(s)&&(_=[s]);for(let h=0;h<_.length;h++){let S=_[h],g=d[S];(g==null||g===!1)&&(Tr.info(`Required ${S} permission not found for ${t} ${s?`${s} `:""}operation in role ${e.role.id}`),p.push(S))}p.length>0&&n.addUnauthorizedTable(l,f,p)}catch(p){let _=xr.UNKNOWN_OP_AUTH_ERROR(t,l,f);throw Tr.error(_),Tr.error(p),Pn(c1.CHECK_LOGS_WRAPPER(_))}}}return r.size<2?n.getPermsResponse():null}a(f1,"hasPermissions");function oI(e,t,r,n,s,i,o){if(!e||!t)throw Tr.info("no attributes specified in checkAttributePerms."),Pn(new Error);let c=X.get(r).perms;if(!c||c==="")throw Tr.info(`no permissions found for ${r} in checkAttributePerms().`),Pn(new Error);if(Fo.isEmptyOrZeroLength(t))return Tr.info("No role permissions set (this is OK)."),null;o&&c.includes(o)&&(c=[o]);let l={};for(let f of e){let d=t.get(f);if(d){if(d[Xp]===!1){i.addInvalidItem(xr.ATTR_NOT_FOUND(s,n,f),s,n);continue}if(c)for(let p of c){if(rn.TIME_STAMP_NAMES.includes(d.attribute_name)&&p!==Go)throw Pn(new Error,xr.SYSTEM_TIMESTAMP_PERMS_ERR,Qp.FORBIDDEN);d[p]===!1&&(l[d.attribute_name]?l[d.attribute_name].push(p):l[d.attribute_name]=[p])}}else i.addInvalidItem(xr.ATTR_NOT_FOUND(s,n,f),s,n)}let u=Object.keys(l);u.length>0&&i.addUnauthorizedAttributes(u,s,n,l)}a(oI,"checkAttributePerms");function b_e(e){let t=new Set;try{if(e.action)return t;if(e.operation===rn.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS&&e.conditions.forEach(r=>{t.add(r.search_attribute)}),e&&e.search_attribute&&t.add(e.search_attribute),!e.records||e.records.length===0){if(!e.get_attributes||!e.get_attributes.length===0)return t;for(let r=0;r<e.get_attributes.length;r++)t.add(e.get_attributes[r])}else for(let r=0;r<e.records.length;r++){let n=Object.keys(e.records[r]);for(let s=0;s<n.length;s++)t.add(n[s])}}catch(r){Tr.info(r)}return t}a(b_e,"getRecordAttributes");function aI(e,t,r){let n=new Map;if(Fo.isEmpty(e))return Tr.info("no hdb_user specified in getAttributePermissions"),n;if(e.super_user||!t||!r)return n;try{e[t].tables[r].attribute_permissions.forEach(s=>{n.has(s.attribute_name)||n.set(s.attribute_name,s)})}catch{Tr.info(`No attribute permissions found for schema ${t} and table ${r}.`)}return n}a(aI,"getAttributePermissions");function O_e(e,t,r,n,s,i,o){let c=new Set(i),l=aI(e,n,s);oI(c,l,t,s,n,o,r)}a(O_e,"verifyBulkLoadAttributePerms")});var zS=w((JMe,g1)=>{"use strict";g1.exports={evaluateSQL:H_e,processAST:E1,convertSQLToAST:m1,checkASTPermissions:h1};var N_e=yn(),p1=require("util"),w_e=p1.callbackify(N_e.insert),I_e=Yr().search,C_e=rk().update,P_e=p1.callbackify(C_e),D_e=sk().convertDelete,Za=require("alasql"),L_e=YS(),WS=z(),M_e=aE(),v_e=ie(),th=(H(),C(G)),{hdb_errors:U_e,handleHDBError:cI}=pe(),{HTTP_STATUS_CODES:lI}=U_e;M_e(Za);var x_e=403,B_e="There was a problem performing this insert. Please check the logs and try again.",uI=class{static{a(this,"ParsedSQLObject")}constructor(){this.ast=void 0,this.variant=void 0,this.permissions_checked=!1}};function H_e(e,t){let r=e.parsed_sql_object;if(!r){r=m1(e.sql);let n,s=r.ast.statements[0];if(s instanceof Za.yy.Insert?n=s.into.databaseid:s instanceof Za.yy.Select?n=s.from?s.from[0].databaseid:null:s instanceof Za.yy.Update||s instanceof Za.yy.Delete?n=s.table.databaseid:WS.error("AST in evaluateSQL is not a valid SQL type."),!(s instanceof Za.yy.Select)&&v_e.isEmptyOrZeroLength(n))return t("No schema specified",null)}E1(e,r,(n,s)=>{if(n)return t(n);t(null,s)})}a(H_e,"evaluateSQL");function h1(e,t){let r;try{r=L_e.verifyPermsAst(t.ast.statements[0],e.hdb_user,t.variant),t.permissions_checked=!0}catch(n){throw n}return r||null}a(h1,"checkASTPermissions");function m1(e){let t=new uI;if(!e)throw cI(new Error,"The 'sql' parameter is missing from the request body",lI.BAD_REQUEST);try{let r=e.trim(),n=Za.parse(r),s=r.split(" ")[0].toLowerCase();t.ast=n,t.variant=s}catch(r){let n=r.message.split(`
39
+ `);throw n[1]?cI(r,`Invalid SQL at: ${n[1]}. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.`,lI.BAD_REQUEST):cI(r,"We had trouble parsing your request. Please ensure your SQL is valid. Try adding backticks to reserved words and schema table references.",lI.BAD_REQUEST)}return t}a(m1,"convertSQLToAST");function E1(e,t,r){try{let n=k_e;if(!e.bypass_auth&&!t.permissions_checked){let i=h1(e,t);if(i&&i.length>0)return r(x_e,i)}let s={statement:t.ast.statements[0],hdb_user:e.hdb_user};switch(t.variant){case th.VALID_SQL_OPS_ENUM.SELECT:n=I_e,s=t.ast.statements[0];break;case th.VALID_SQL_OPS_ENUM.INSERT:n=F_e;break;case th.VALID_SQL_OPS_ENUM.UPDATE:n=P_e;break;case th.VALID_SQL_OPS_ENUM.DELETE:n=D_e;break;default:throw new Error(`unsupported SQL type ${t.variant} in SQL: ${e}`)}n(s,(i,o)=>{if(i){r(i);return}r(null,o)})}catch(n){return r(n)}}a(E1,"processAST");function k_e(e,t){WS.info(e),t("unknown sql statement")}a(k_e,"nullFunction");function F_e({statement:e,hdb_user:t},r){let n=e.into,s={schema:n.databaseid,table:n.tableid,operation:"insert",hdb_user:t},i=e.columns.map(o=>o.columnid);try{s.records=G_e(i,e.values)}catch(o){return r(o)}w_e(s,(o,c)=>{if(o)return r(o);try{delete c.new_attributes,delete c.txn_time}catch(l){WS.error(`Error delete new_attributes from insert response: ${l}`)}r(null,c)})}a(F_e,"convertInsert");function G_e(e,t){try{return t.map(r=>{if(e.length!==r.length)throw"number of values do not match number of columns in insert";let n={};return r.forEach((s,i)=>{if(s.columnid)throw"cannot use a column in insert value";"value"in s?n[e[i]]=s.value:n[e[i]]=Za.compile(`SELECT ${s.toString()} AS [${th.FUNC_VAL}] FROM ?`)}),n})}catch(r){throw WS.error(r),new Error(B_e)}}a(G_e,"createDataObjects")});var mI=w((eve,R1)=>{var XS=require("clone"),ZS=ot(),q_e=ie(),JS=(H(),C(G)),XMe=z(),dI=require("fs"),_I=require("joi"),{string:QS}=_I.types(),{hdb_errors:$_e,handleHDBError:jS}=pe(),{HDB_ERROR_MSGS:ZMe,HTTP_STATUS_CODES:fI}=$_e,{common_validators:Hd}=Di(),S1=" is required",V_e=["insert","update","upsert"],pI={database:{presence:!1,format:Hd.schema_format,length:Hd.schema_length},schema:{presence:!1,format:Hd.schema_format,length:Hd.schema_length},table:{presence:!0,format:Hd.schema_format,length:Hd.schema_length},action:{inclusion:{within:V_e,message:"is required and must be either insert, update, or upsert"}},file_path:{},csv_url:{url:{allowLocal:!0}},data:{},passthrough_headers:{}},K_e={schema:QS.required(),table:QS.required(),action:QS.valid("insert","update","upsert")},{AWS_ACCESS_KEY:Y_e,AWS_SECRET:W_e,AWS_BUCKET:z_e,AWS_FILE_KEY:j_e,REGION:J_e}=JS.S3_BUCKET_AUTH_KEYS,Q_e={s3:{presence:!0},[`s3.${Y_e}`]:{presence:!0,type:"String"},[`s3.${W_e}`]:{presence:!0,type:"String"},[`s3.${z_e}`]:{presence:!0,type:"String"},[`s3.${j_e}`]:{presence:!0,type:"String",hasValidFileExt:[".csv",".json"]},[`s3.${J_e}`]:{presence:!0,type:"String"}},T1=XS(pI);T1.data.presence={message:S1};var A1=XS(pI);A1.file_path.presence={message:S1};var X_e=Object.assign(XS(pI),Q_e),hI=XS(K_e);hI.csv_url=QS.uri().messages({"string.uri":"'csv_url' must be a valid url"}).required();hI.passthrough_headers=_I.object();function Z_e(e){let t=ZS.validateObject(e,T1);return eT(e,t)}a(Z_e,"dataObject");function epe(e){let t=ZS.validateBySchema(e,_I.object(hI));return eT(e,t)}a(epe,"urlObject");function tpe(e){let t=ZS.validateObject(e,A1);return eT(e,t)}a(tpe,"fileObject");function rpe(e){let t=ZS.validateObject(e,X_e);return eT(e,t)}a(rpe,"s3FileObject");function eT(e,t){if(!t){let r=q_e.checkGlobalSchemaTable(e.schema,e.table);if(r)return jS(new Error,r,fI.BAD_REQUEST);if(e.operation===JS.OPERATIONS_ENUM.CSV_FILE_LOAD)try{dI.accessSync(e.file_path,dI.constants.R_OK|dI.constants.F_OK)}catch(n){return n.code===JS.NODE_ERROR_CODES.ENOENT?jS(n,`No such file or directory ${n.path}`,fI.BAD_REQUEST):n.code===JS.NODE_ERROR_CODES.EACCES?jS(n,`Permission denied ${n.path}`,fI.BAD_REQUEST):jS(n)}}return t}a(eT,"postValidateChecks");R1.exports={dataObject:Z_e,urlObject:epe,fileObject:tpe,s3FileObject:rpe}});var EI=w((rve,y1)=>{"use strict";var rh=z(),tT=(H(),C(G));async function npe(e,t,r,n=void 0){if(!e||typeof e!="function")throw new Error("Invalid function parameter");let s;try{return s=await e(t),r&&await r(t,s,n),t.operation===tT.OPERATIONS_ENUM.INSERT||t.operation===tT.OPERATIONS_ENUM.UPDATE||t.operation===tT.OPERATIONS_ENUM.UPSERT?(delete s.new_attributes,delete s.txn_time):t.operation===tT.OPERATIONS_ENUM.DELETE&&delete s.txn_time,s}catch(i){throw i.message&&typeof i.message=="string"&&i.message.includes("already exists")?(rh.info(i.message),i):i.http_resp_msg?(rh.error(`Error calling operation: ${e.name}`),rh.error(i.http_resp_msg),i):(rh.error(`Error calling operation: ${e.name}`),rh.error(i),i)}}a(npe,"callOperationFunctionAsAwait");y1.exports={callOperationFunctionAsAwait:npe}});var gI=w((sve,O1)=>{"use strict";var{S3:spe,GetObjectCommand:ipe}=require("@aws-sdk/client-s3");O1.exports={getFileStreamFromS3:ope,getS3AuthObj:b1};async function ope(e){let{s3:t}=e,r={Bucket:t.bucket,Key:t.key};return(await b1(t.aws_access_key_id,t.aws_secret_access_key,t.region).send(new ipe(r))).Body}a(ope,"getFileStreamFromS3");function b1(e,t,r){return new spe({credentials:{accessKeyId:e,secretAccessKey:t},region:r})}a(b1,"getS3AuthObj")});var w1=w((ove,N1)=>{"use strict";var SI=class{static{a(this,"BulkLoadFileObject")}constructor(t,r,n,s,i,o,c=null){this.op=t,this.action=r,this.schema=n,this.table=s,this.file_path=i,this.file_type=o,this.role_perms=c}},TI=class{static{a(this,"BulkLoadDataObject")}constructor(t,r,n,s){this.action=t,this.schema=r,this.table=n,this.data=s}};N1.exports={BulkLoadFileObject:SI,BulkLoadDataObject:TI}});var C1=w((cve,I1)=>{"use strict";var AI=class{static{a(this,"ClusteringOriginObject")}constructor(t,r,n){this.timestamp=t,this.user=r,this.node_name=n}};I1.exports=AI});var wI=w((pve,Y1)=>{"use strict";var rT=yn(),sT=mI(),ape=require("needle"),_i=(H(),C(G)),uve=Tt(),kd=ie(),{handleHDBError:Ft,hdb_errors:H1}=pe(),{HTTP_STATUS_CODES:Br,HDB_ERROR_MSGS:Ar,CHECK_LOGS_WRAPPER:Hl}=H1,Fd=z(),RI=require("papaparse");kd.promisifyPapaParse();var pi=require("fs-extra"),cpe=require("path"),{chain:P1}=require("stream-chain"),D1=require("stream-json/streamers/StreamArray"),L1=require("stream-json/utils/Batch"),M1=require("stream-chain/utils/comp"),{finished:v1}=require("stream"),lpe=ae(),k1=EI(),upe=gI(),{BulkLoadFileObject:bI,BulkLoadDataObject:dpe}=w1(),OI=tI(),{verifyBulkLoadAttributePerms:F1}=YS(),dve=C1(),fve=ir(),_ve=Eo(),{databases:fpe}=(De(),C(nt)),{coerceType:_pe}=(qf(),C(II)),U1="No records parsed from csv file.",Bl=`${lpe.get("HDB_ROOT")}/tmp`,{schema_regex:ppe}=Di(),x1=1024*1024*2,B1=5e3,hpe={"text/csv":!0,"application/octet-stream":!0,"text/plain":!0,"application/vnd.ms-excel":!0};Y1.exports={csvDataLoad:mpe,csvURLLoad:Epe,csvFileLoad:gpe,importFromS3:Spe};async function mpe(e,t){let r=sT.dataObject(e);if(r)throw Ft(r,r.message,Br.BAD_REQUEST,void 0,void 0,!0);let n={};try{let s=$1(e.schema,e.table),i=RI.parse(e.data,{header:!0,skipEmptyLines:!0,transform:yI.bind(null,s),dynamicTyping:!1}),o=new OI;e.hdb_user&&e.hdb_user?.role&&e.hdb_user?.role?.permission&&e.hdb_user?.role?.permission?.super_user!==!0&&F1(e.hdb_user?.role?.permission,this.job_operation_function.name,e.action,e.schema,e.table,i.meta.fields,o);let c=o.getPermsResponse();if(c)throw Ft(new Error,c,Br.BAD_REQUEST,void 0,void 0,!0);let l=new dpe(e.action,e.schema,e.table,i.data);return n=await k1.callOperationFunctionAsAwait(V1,l,null),n.message===U1?U1:K1(n.records,n.number_written)}catch(s){throw kl(s)}}a(mpe,"csvDataLoad");async function Epe(e){let t=sT.urlObject(e);if(t)throw Ft(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r=`${Date.now()}.csv`,n=`${Bl}/${r}`;try{await Tpe(e,r)}catch(s){throw Fd.error(Ar.DOWNLOAD_FILE_ERR(r)+" - "+s),Ft(s,Hl(Ar.DOWNLOAD_FILE_ERR(r)))}try{let s=new bI(this.job_operation_function.name,e.action,e.schema,e.table,n,_i.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission),i=await NI(s);return await nT(n),i}catch(s){throw await nT(n),kl(s)}}a(Epe,"csvURLLoad");async function gpe(e){let t=sT.fileObject(e);if(t)throw Ft(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r=new bI(this.job_operation_function.name,e.action,e.schema,e.table,e.file_path,_i.VALID_S3_FILE_TYPES.CSV,e.hdb_user?.role?.permission);try{return await NI(r)}catch(n){throw kl(n)}}a(gpe,"csvFileLoad");async function Spe(e){let t=sT.s3FileObject(e);if(t)throw Ft(t,t.message,Br.BAD_REQUEST,void 0,void 0,!0);let r;try{let n=cpe.extname(e.s3.key),s=`${Date.now()}${n}`;r=`${Bl}/${s}`;let i=new bI(this.job_operation_function.name,e.action,e.schema,e.table,r,n,e.hdb_user?.role?.permission);await Ape(s,e);let o=await NI(i);return await nT(r),o}catch(n){throw await nT(r),kl(n)}}a(Spe,"importFromS3");async function Tpe(e,t){let r;try{let n=e.passthrough_headers?{headers:e.passthrough_headers}:void 0;r=await ape("get",e.csv_url,n)}catch(n){let s=`Error downloading CSV file from ${e.csv_url}, status code: ${n.statusCode}. Check the log for more information.`;throw Ft(n,s,n.statusCode,_i.LOG_LEVELS.ERROR,"Error downloading CSV file - "+n)}ype(r,e.csv_url),await Rpe(t,r.raw)}a(Tpe,"downloadCSVFile");async function Ape(e,t){try{let r=`${Bl}/${e}`;await pi.mkdirp(Bl),await pi.writeFile(`${Bl}/${e}`,"",{flag:"a+"});let n=await pi.createWriteStream(r),s=await upe.getFileStreamFromS3(t);await new Promise((i,o)=>{s.on("error",function(c){o(c)}),s.pipe(n).on("error",function(c){o(c)}).on("close",function(){Fd.info(`${t.s3.key} successfully downloaded to ${r}`),i()})})}catch(r){throw Fd.error(Ar.S3_DOWNLOAD_ERR+" - "+r),Ft(r,Hl(Ar.S3_DOWNLOAD_ERR))}}a(Ape,"downloadFileFromS3");async function Rpe(e,t){try{await pi.mkdirp(Bl),await pi.writeFile(`${Bl}/${e}`,t)}catch(r){throw Fd.error(Ar.WRITE_TEMP_FILE_ERR),Ft(r,Hl(Ar.DEFAULT_BULK_LOAD_ERR))}}a(Rpe,"writeFileToTempFolder");async function nT(e){if(e)try{await pi.access(e),await pi.unlink(e)}catch{Fd.warn(`could not delete temp csv file at ${e}, file does not exist`)}}a(nT,"deleteTempFile");function ype(e,t){if(e.statusCode!==H1.HTTP_STATUS_CODES.OK)throw Ft(new Error,`CSV Load failed from URL: ${t}, status code: ${e.statusCode}, message: ${e.statusMessage}`,Br.BAD_REQUEST);if(!hpe[e.headers["content-type"]])throw Ft(new Error,`CSV Load failed from URL: ${t}, unsupported content type: ${e.headers["content-type"]}`,Br.BAD_REQUEST);if(!e.raw)throw Ft(new Error,`CSV Load failed from URL: ${t}, no csv found at url`,Br.BAD_REQUEST)}a(ype,"validateURLResponse");async function NI(e){try{let t;switch(e.file_type){case _i.VALID_S3_FILE_TYPES.CSV:t=await bpe(e);break;case _i.VALID_S3_FILE_TYPES.JSON:t=await Ope(e);break;default:throw Ft(new Error,Ar.DEFAULT_BULK_LOAD_ERR,Br.BAD_REQUEST,_i.LOG_LEVELS.ERROR,Ar.INVALID_FILE_EXT_ERR(e))}return K1(t.records,t.number_written)}catch(t){throw kl(t)}}a(NI,"fileLoad");async function G1(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;s&&s.pause();let o={operation:e.action,schema:e.schema,table:e.table,records:i};try{let{attributes:c}=await rT.validation(o);e.role_perms&&e.role_perms.super_user!==!0&&F1(e.role_perms,e.op,e.action,e.schema,e.table,c,t),s&&s.resume()}catch(c){let l=Ft(c);r(l)}}a(G1,"validateChunk");async function q1(e,t,r,n,s){let i=n.data?n.data:n;if(i.length===0)return;kd.autoCastJSONDeep(i),s&&s.pause();let o=n.meta?n.meta.fields:null;if(o)i.forEach(c=>{!kd.isEmpty(c)&&!kd.isEmpty(c.__parsed_extra)&&delete c.__parsed_extra});else{let c=new Set;i.forEach(l=>{Object.keys(l).forEach(u=>c.add(u))}),o=[...c]}try{let c={schema:e.schema,table:e.table,action:e.action,data:i},l=await k1.callOperationFunctionAsAwait(V1,c,null);t.records+=l.records,t.number_written+=l.number_written,s&&s.resume()}catch(c){let l=Ft(c,Hl(Ar.INSERT_CSV_ERR),Br.INTERNAL_SERVER_ERROR,_i.LOG_LEVELS.ERROR,Ar.INSERT_CSV_ERR+" - "+c);r(l)}}a(q1,"insertChunk");async function bpe(e){let t={records:0,number_written:0},r=$1(e.schema,e.table);try{let n=new OI,s=pi.createReadStream(e.file_path,{highWaterMark:x1});s.setEncoding("utf8"),await RI.parsePromise(s,G1.bind(null,e,n),yI.bind(null,r));let i=n.getPermsResponse();if(i)throw Ft(new Error,i,Br.BAD_REQUEST);return s=pi.createReadStream(e.file_path,{highWaterMark:x1}),s.setEncoding("utf8"),await RI.parsePromise(s,q1.bind(null,e,t),yI.bind(null,r)),s.destroy(),t}catch(n){throw Ft(n,Hl(Ar.PAPA_PARSE_ERR),Br.INTERNAL_SERVER_ERROR,_i.LOG_LEVELS.ERROR,Ar.PAPA_PARSE_ERR+n)}}a(bpe,"callPapaParse");function $1(e,t){let r=fpe[e][t].attributes,n=new Map;for(let s of r)s.type&&!s.computed&&!s.relationship&&n.set(s.name,i=>_pe(i,s));return n}a($1,"createTransformMap");function yI(e,t,r){let n=e.get(r);return n?n(t):kd.autoCast(t)}a(yI,"typeFunction");async function Ope(e){let t={records:0,number_written:0},r=a(n=>{throw n},"throwErr");try{let n=new OI,s=P1([pi.createReadStream(e.file_path,{encoding:"utf-8"}),D1.withParser(),c=>c.value,new L1({batchSize:B1}),M1(async c=>{await G1(e,n,r,c)})]);await new Promise((c,l)=>{v1(s,u=>{u?l(u):c()}),s.resume()});let i=n.getPermsResponse();if(i)throw Ft(new Error,i,Br.BAD_REQUEST);let o=P1([pi.createReadStream(e.file_path,{encoding:"utf-8"}),D1.withParser(),c=>c.value,new L1({batchSize:B1}),M1(async c=>{await q1(e,t,r,c)})]);return await new Promise((c,l)=>{v1(o,u=>{u?l(u):c()}),o.resume()}),t}catch(n){throw Ft(n,Hl(Ar.INSERT_JSON_ERR),Br.INTERNAL_SERVER_ERROR,_i.LOG_LEVELS.ERROR,Ar.INSERT_JSON_ERR+n)}}a(Ope,"insertJson");async function V1(e){let t={};try{e.data&&e.data.length>0&&Npe(e.data[0])?t=await wpe(e.data,e.schema,e.table,e.action):(t.message="No records parsed from csv file.",Fd.info(t.message))}catch(r){throw kl(r)}return t}a(V1,"callBulkFileLoad");function Npe(e){let t=Object.keys(e);for(let r of t)if(!ppe.test(r))throw new Error(`Invalid column name '${r}', cancelling load operation`);return!0}a(Npe,"validateColumnNames");async function wpe(e,t,r,n){n||(n="insert");let s={operation:n,schema:t,table:r,records:e},i;switch(n){case"insert":i=rT.insert;break;case"update":i=rT.update;break;case"upsert":i=rT.upsert;break;default:throw Ft(new Error,Ar.INVALID_ACTION_PARAM_ERR(n),Br.BAD_REQUEST,_i.LOG_LEVELS.ERROR,Ar.INVALID_ACTION_PARAM_ERR(n))}try{let o=await i(s),c;switch(n){case"insert":c=o.inserted_hashes;break;case"update":c=o.update_hashes;break;case"upsert":c=o.upserted_hashes;break;default:break}if(Array.isArray(o.skipped_hashes)&&o.skipped_hashes.length>0){let f=global.hdb_schema[t][r].hash_attribute,d=e.length;for(;d--;)o.skipped_hashes.indexOf(e[d][f])>=0&&e.splice(d,1)}let l=kd.isEmptyOrZeroLength(c)?0:c.length;return{records:e.length,number_written:l,new_attributes:o.new_attributes}}catch(o){throw kl(o)}}a(wpe,"bulkFileLoad");function K1(e,t){return`successfully loaded ${t} of ${e} records`}a(K1,"buildResponseMsg");function kl(e){return Ft(e,Hl(Ar.DEFAULT_BULK_LOAD_ERR),Br.INTERNAL_SERVER_ERROR,_i.LOG_LEVELS.ERROR,Ar.DEFAULT_BULK_LOAD_ERR+" - "+e)}a(kl,"buildTopLevelErrMsg")});var DI=w((mve,eK)=>{"use strict";var PI=Yr(),Ipe=gI(),{AsyncParser:Cpe}=require("json2csv"),iT=require("stream"),is=ie(),CI=require("fs-extra"),Ppe=require("path"),Ls=z(),{promisify:j1}=require("util"),nh=ie(),{handleHDBError:dr,hdb_errors:Dpe}=pe(),{HDB_ERROR_MSGS:Dn,HTTP_STATUS_CODES:fr}=Dpe,{streamAsJSON:Lpe}=(OR(),C(KL)),{Upload:Mpe}=require("@aws-sdk/lib-storage"),{toCsvStream:vpe}=(ao(),C(dM)),W1=["search_by_value","search_by_hash","sql","search_by_conditions"],z1=["json","csv"],J1="json",Q1="csv",Upe="Successfully exported JSON locally.",xpe="Successfully exported CSV locally.",Bpe=1e3,Hpe=PI.searchByHash,kpe=PI.searchByValue,Fpe=j1(iT.finished);eK.exports={export_to_s3:Vpe,export_local:Gpe};async function Gpe(e){Ls.trace(`export_local request to path: ${e.path}, filename: ${e.filename}, format: ${e.format}`);let t=X1(e);if(!is.isEmpty(t))throw Ls.error(t),dr(new Error,t,fr.BAD_REQUEST,void 0,void 0,!0);if(is.isEmpty(e.path))throw Ls.error(Dn.MISSING_VALUE("path")),dr(new Error,Dn.MISSING_VALUE("path"),fr.BAD_REQUEST,void 0,void 0,!0);let r=(is.isEmpty(e.filename)?new Date().getTime():e.filename)+"."+e.format;e.path.endsWith(Ppe.sep)&&(e.path=e.path.substring(0,e.path.length-1));let n=is.buildFolderPath(e.path,r);await qpe(e.path);let s=await Z1(e);return await $pe(n,e.format,s)}a(Gpe,"export_local");async function qpe(e){if(Ls.trace("in confirmPath"),is.isEmptyOrZeroLength(e))throw dr(new Error,`Invalid path: ${e}`,fr.BAD_REQUEST,void 0,void 0,!0);let t;try{t=await CI.stat(e)}catch(r){let n;throw r.code==="ENOENT"?n=`path '${e}' does not exist`:r.code==="EACCES"?n=`access to path '${e}' is denied`:n=r.message,Ls.error(n),dr(new Error,n,fr.BAD_REQUEST,void 0,void 0,!0)}if(!t.isDirectory()){let r=`path '${e}' is not a directory, please supply a valid folder path`;throw Ls.error(r),dr(new Error,r,fr.BAD_REQUEST,void 0,void 0,!0)}return!0}a(qpe,"confirmPath");async function $pe(e,t,r){if(Ls.trace("in saveToLocal"),nh.isEmptyOrZeroLength(e))throw dr(new Error,Dn.INVALID_VALUE("file_path"),fr.BAD_REQUEST,void 0,void 0,!0);if(nh.isEmptyOrZeroLength(t))throw dr(new Error,Dn.INVALID_VALUE("Source format"),fr.BAD_REQUEST,void 0,void 0,!0);if(nh.isEmpty(r))throw dr(new Error,Dn.NOT_FOUND("Data"),fr.BAD_REQUEST,void 0,void 0,!0);if(t===J1){let n=CI.createWriteStream(e);return Lpe(r).pipe(n),await Fpe(n),{message:Upe,path:e}}else if(t===Q1){let n=CI.createWriteStream(e),s=iT.Readable.from(r),i={},o=r.getColumns?.();o&&(i.fields=o.map(f=>({label:f,value:f})));let c={objectMode:!0};return await new Cpe(i,c).fromInput(s).toOutput(n).promise(!1),{message:xpe,path:e}}throw dr(new Error,Dn.INVALID_VALUE("format"),fr.BAD_REQUEST)}a($pe,"saveToLocal");async function Vpe(e){if(!e.s3||Object.keys(e.s3).length===0)throw dr(new Error,Dn.MISSING_VALUE("S3 object"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.aws_access_key_id))throw dr(new Error,Dn.MISSING_VALUE("aws_access_key_id"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.aws_secret_access_key))throw dr(new Error,Dn.MISSING_VALUE("aws_secret_access_key"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.bucket))throw dr(new Error,Dn.MISSING_VALUE("bucket"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.key))throw dr(new Error,Dn.MISSING_VALUE("key"),fr.BAD_REQUEST);if(is.isEmptyOrZeroLength(e.s3.region))throw dr(new Error,Dn.MISSING_VALUE("region"),fr.BAD_REQUEST);let t=X1(e);if(!is.isEmpty(t))throw dr(new Error,t,fr.BAD_REQUEST);Ls.trace(`called export_to_s3 to bucket: ${e.s3.bucket} and query ${e.search_operation.sql}`);let r;try{r=await Z1(e)}catch(l){throw Ls.error(l),l}let n,s=await Ipe.getS3AuthObj(e.s3.aws_access_key_id,e.s3.aws_secret_access_key,e.s3.region),i,o=new iT.PassThrough;if(e.format===Q1){i=e.s3.key+".csv";let l=vpe(r,r.getColumns?.());l.on("error",u=>{throw u}),l.pipe(o)}else if(e.format===J1){i=e.s3.key+".json";let l=new iT.Readable;l.pipe(o),l.on("error",d=>{throw d}),l.push("[");let u=r.length,f="";for(let[d,p]of r.entries()){let _=d===u-1?JSON.stringify(p):JSON.stringify(p)+",";f+=_,d!==0&&d%Bpe===0&&(l.push(f),f="")}f.length!==0&&l.push(f),l.push("]"),l.push(null)}else throw dr(new Error,Dn.INVALID_VALUE("format"),fr.BAD_REQUEST);return new Mpe({client:s,params:{Bucket:e.s3.bucket,Key:i,Body:o}}).done()}a(Vpe,"export_to_s3");function X1(e){if(Ls.trace("in exportCoreValidation"),is.isEmpty(e.format))return"format missing";if(z1.indexOf(e.format)<0)return`format invalid. must be one of the following values: ${z1.join(", ")}`;let t=e.search_operation.operation;if(is.isEmpty(t))return"search_operation.operation missing";if(W1.indexOf(t)<0)return`search_operation.operation must be one of the following values: ${W1.join(", ")}`}a(X1,"exportCoreValidation");async function Z1(e){Ls.trace("in getRecords");let t,r;if(nh.isEmpty(e.search_operation)||nh.isEmptyOrZeroLength(e.search_operation.operation))throw dr(new Error,Dn.INVALID_VALUE("Search operation"),fr.BAD_REQUEST);switch(e.search_operation.operation){case"search_by_value":t=kpe;break;case"search_by_hash":t=Hpe;break;case"search_by_conditions":t=PI.searchByConditions;break;case"sql":{let n=zS();t=j1(n.evaluateSQL);break}default:throw r=`Operation ${e.search_operation.operation} is not support by export.`,Ls.error(r),dr(new Error,r,fr.BAD_REQUEST)}return e.search_operation.hdb_user=e.hdb_user,t(e.search_operation)}a(Z1,"getRecords")});var rK=w((gve,tK)=>{"use strict";var LI=class{static{a(this,"SqlSearchObject")}constructor(t,r){this.operation="sql",this.sql=t,this.hdb_user=r}};tK.exports=LI});var iK=w((Tve,sK)=>{"use strict";var Kpe=(H(),C(G)),nK=require("moment"),Ype=require("uuid").v4,MI=class{static{a(this,"JobObject")}constructor(){this.id=Ype(),this.type=void 0,this.start_datetime=nK().valueOf(),this.created_datetime=nK().valueOf(),this.end_datetime=void 0,this.status=Kpe.JOB_STATUS_ENUM.CREATED,this.message=void 0,this.user=void 0,this.request=void 0}};sK.exports=MI});var vI=w((Rve,_K)=>{"use strict";var Wpe=require("uuid").v4,uK=yn(),dK=Yr(),zpe=ni(),jpe=Fu(),Jpe=rK(),Ot=(H(),C(G)),Qpe=iK(),Xpe=ng(),hi=z(),Zpe=Uf(),Gd=ie(),{promisify:ehe}=require("util"),Fl=require("moment"),the=zS(),oT=mI(),oK=Py(),{deleteTransactionLogsBeforeValidator:rhe}=Jw(),{handleHDBError:aK,hdb_errors:nhe,ClientError:she}=pe(),{HTTP_STATUS_CODES:cK}=nhe,lK=dK.searchByValue,ihe=dK.searchByHash,ohe=uK.insert,ahe=ehe(the.evaluateSQL),che=uK.update;_K.exports={addJob:dhe,updateJob:_he,handleGetJob:lhe,handleGetJobsByStartDate:uhe,getJobById:fK};async function lhe(e){if(e.id===void 0)throw new she("'id' is required");let t=await fK(e.id);return Gd.isEmptyOrZeroLength(t)||(t[0]={...t[0]},t[0].request!==void 0&&delete t[0].request,delete t[0].__createdtime__,delete t[0].__updatedtime__),t}a(lhe,"handleGetJob");async function uhe(e){try{let t=await fhe(e);if(hi.trace(`Searching for jobs from ${e.from_date} to ${e.to_date}`),t&&t.length>0)for(let r of t)r.start_datetime&&(r.start_datetime_converted=Fl(r.start_datetime)),r.end_datetime&&(r.end_datetime_converted=Fl(r.end_datetime)),r.request!==void 0&&delete r.request,delete r.__createdtime__,delete r.__updatedtime__;return t}catch(t){let r=`There was an error searching jobs by date: ${t}`;throw hi.error(r),new Error(r)}}a(uhe,"handleGetJobsByStartDate");async function dhe(e){let t={message:"",error:"",success:!1,createdJob:void 0};if(!e||Object.keys(e).length===0||Gd.isEmptyOrZeroLength(e.operation)){let f="job parameter is invalid";return hi.info(f),t.error=f,t}if(!Ot.JOB_TYPE_ENUM[e.operation])return hi.info(`invalid job type specified: ${e.operation}.`),t;let r=e.operation,n;switch(r){case Ot.OPERATIONS_ENUM.CSV_FILE_LOAD:n=oT.fileObject(e);break;case Ot.OPERATIONS_ENUM.CSV_URL_LOAD:n=oT.urlObject(e);break;case Ot.OPERATIONS_ENUM.CSV_DATA_LOAD:n=oT.dataObject(e);break;case Ot.OPERATIONS_ENUM.IMPORT_FROM_S3:n=oT.s3FileObject(e);break;case Ot.OPERATIONS_ENUM.DELETE_FILES_BEFORE:case Ot.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE:n=oK(e,"date");break;case Ot.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE:n=oK(e,"timestamp");break;case Ot.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE:n=rhe(e);break;case Ot.OPERATIONS_ENUM.RESTART_SERVICE:if(Ot.HDB_PROCESS_SERVICES[e.service]===void 0)throw aK(new Error,"Invalid service",cK.BAD_REQUEST,void 0,void 0,!0);break;default:break}if(n)throw aK(n,n.message,cK.BAD_REQUEST,void 0,void 0,!0);let s=new Qpe;s.type=e.operation===Ot.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE?Ot.OPERATIONS_ENUM.DELETE_FILES_BEFORE:e.operation,s.type=e.operation,s.user=e.hdb_user?.username;let i=new zpe(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",s.id,"id",["id"]),o;try{o=Array.from(await lK(i))}catch(f){let d=`There was an error inserting a new job: ${f}`;return hi.error(d),t}let c=Array.isArray(o)?o:Object.keys(o);if(c&&c.length>0){s.id=Wpe();try{o=await lK(i)}catch(f){let d=`There was an error inserting a new job: ${f}`;return hi.error(d),t}if(c=Array.isArray(o)?o:Object.keys(o),c&&c.length>0)return hi.error("Error creating a job, could not find a unique job id."),t}s.request=e;let l=new Zpe(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,"id",[s]),u;try{u=await ohe(l)}catch(f){return hi.error(`There was an error inserting a job for job type: ${e.operation} -- ${f}`),t.success=!1,t}if(u.inserted_hashes.length===0)t.message=`Had a problem creating a job with type ${s.operation} and id ${s.id}`;else{let f=`Created a job with type ${s.type} and id ${s.id}`;t.message=f,t.createdJob=s,t.success=!0,hi.trace(f)}return t}a(dhe,"addJob");async function fhe(e){let t=Fl(e.from_date,Fl.ISO_8601),r=Fl(e.to_date,Fl.ISO_8601);if(!t.isValid())throw new Error("Invalid 'from' date, must be in ISO-8601 format (YYYY-MM-DD).");if(!r.isValid())throw new Error("Invalid 'to' date, must be in ISO-8601 format (YYYY-MM-DD)");let n=`select * from system.hdb_job where start_datetime > '${t.valueOf()}' and start_datetime < '${r.valueOf()}'`,s=new Jpe(n,e.hdb_user);try{return await ahe(s)}catch(i){throw hi.error(`there was a problem searching for jobs from date ${e.from_date} to date ${e.to_date} ${i}`),new Error("there was an error searching for jobs. Please check the log for details.")}}a(fhe,"getJobsInDateRange");async function fK(e){if(Gd.isEmptyOrZeroLength(e))return Gd.errorizeMessage("Invalid job ID specified.");let t=new jpe(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e],["*"]);try{return await ihe(t)}catch(r){let n=`There was an error searching for a job by id: ${e} ${r}`;return hi.error(n),Gd.errorizeMessage("there was an error searching for jobs. Please check the log for details.")}}a(fK,"getJobById");async function _he(e){if(Object.keys(e).length===0)throw new Error("invalid job object passed to updateJob");if(Gd.isEmptyOrZeroLength(e.id))throw new Error("invalid ID passed to updateJob");(e.status===Ot.JOB_STATUS_ENUM.COMPLETE||e.status===Ot.JOB_STATUS_ENUM.ERROR)&&(e.end_datetime=Fl().valueOf());let t=new Xpe(Ot.SYSTEM_SCHEMA_NAME,Ot.SYSTEM_TABLE_NAMES.JOB_TABLE_NAME,[e]),r;return r=await che(t),r}a(_he,"updateJob")});var AK=w((bve,TK)=>{"use strict";var pK=ie(),Rr=(H(),C(G)),phe=require("moment"),aT=wI(),sh=z(),hK=vI(),mK=DI(),EK=zc(),gK=rt(),hhe=qS(),mhe=za(),{parentPort:Ehe,isMainThread:SK}=require("worker_threads"),{onMessageByType:ghe}=rt(),UI=class{static{a(this,"RunnerMessage")}constructor(t,r){this.job=t,this.json=r}};async function She(e){if(!e||Object.keys(e).length===0)throw new Error("Empty runner passed to parseMessage");if(!e.json||Object.keys(e.json).length===0)throw new Error("Empty JSON passed to parseMessage");if(!e.job||Object.keys(e.job).length===0)throw new Error("Empty job passed to parseMessage");if(pK.isEmptyOrZeroLength(e.json.operation))throw new Error("Invalid operation");if(pK.isEmptyOrZeroLength(e.job.id))throw new Error("Empty job id specified");switch(e.json.operation){case Rr.JOB_TYPE_ENUM.csv_file_load:await Ki(e,aT.csvFileLoad);break;case Rr.JOB_TYPE_ENUM.csv_url_load:await Ki(e,aT.csvURLLoad);break;case Rr.JOB_TYPE_ENUM.csv_data_load:await Ki(e,aT.csvDataLoad);break;case Rr.JOB_TYPE_ENUM.import_from_s3:await Ki(e,aT.importFromS3);break;case Rr.JOB_TYPE_ENUM.empty_trash:break;case Rr.JOB_TYPE_ENUM.export_local:await Ki(e,mK.export_local);break;case Rr.JOB_TYPE_ENUM.export_to_s3:await Ki(e,mK.export_to_s3);break;case Rr.JOB_TYPE_ENUM.delete_files_before:case Rr.JOB_TYPE_ENUM.delete_records_before:await Ki(e,EK.deleteFilesBefore);break;case Rr.JOB_TYPE_ENUM.delete_audit_logs_before:await Ki(e,EK.deleteAuditLogsBefore);break;case Rr.JOB_TYPE_ENUM.delete_transaction_logs_before:await Ki(e,hhe.deleteTransactionLogsBefore);break;case Rr.JOB_TYPE_ENUM.restart_service:return await Ki(e,mhe.restartService),`Restarting ${e.json.service}`;break;default:return`Invalid operation ${e.json.operation} specified`}}a(She,"parseMessage");async function Ki(e,t){try{e.job.status=Rr.JOB_STATUS_ENUM.IN_PROGRESS,e.job.start_datetime=phe().valueOf(),await hK.updateJob(e.job),await The(e.job.id)}catch(r){let n=r.message!==void 0?r.message:r;typeof n=="string"?(n=`There was an error running ${t.name} job with id ${e.job.id} - ${n}`,r.message=n):sh.error(`There was an error running ${t.name} job with id ${e.job.id}`),sh.error(n),e.job.message=n,e.job.status=Rr.JOB_STATUS_ENUM.ERROR;try{await hK.updateJob(e.job)}catch(s){throw sh.error(`Unable to update job with id ${e.job.id}`),s}throw r}}a(Ki,"runJob");async function The(e){sh.trace("launching job thread:",e),SK?gK.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Rr.PROCESS_NAME_ENV_PROP]:`JOB-${e}`}}):Ehe.postMessage({type:Rr.ITC_EVENT_TYPES.START_JOB,jobId:e})}a(The,"launchJobThread");SK&&ghe(Rr.ITC_EVENT_TYPES.START_JOB,async(e,t)=>{try{gK.startWorker("server/jobs/jobProcess.js",{autoRestart:!1,name:"job",env:{...process.env,[Rr.PROCESS_NAME_ENV_PROP]:`JOB-${e.jobId}`}})}catch(r){sh.error(r)}});TK.exports={parseMessage:She,RunnerMessage:UI}});var yK=w((Nve,RK)=>{"use strict";var xI=class{static{a(this,"OperationFunctionObject")}constructor(t,r=void 0){this.operation_function=t,this.job_operation_function=r}};RK.exports=xI});var jw=w((Cve,qI)=>{"use strict";var fT=Yr(),kI=zS(),cT=wI(),qo=Kg(),lT=go(),oh=zc(),Ahe=ON(),ih=Rn(),uT=F_(),Pt=zw(),dT=z(),Rhe=PN(),yhe=Sd(),bK=tw(),bhe=sS(),Ohe=sw(),Nhe=iw(),whe=cS(),Ihe=uS(),BI=dS(),OK=DI(),Che=YS(),FI=vI(),K=(H(),C(G)),{hdb_errors:ch,handleHDBError:ah}=pe(),{HTTP_STATUS_CODES:NK}=ch,HI=mS(),wK=za(),BK=require("util"),$d=yn(),Phe=As(),Dhe=Po(),IK=AK(),CK=(Ju(),C(X_)),PK=(vS(),C(Gp)),DK=yt(),LK=qS(),MK=Kp(),{setServerUtilities:Lhe}=(qf(),C(II)),{CONTEXT:Ive}=(Ea(),C(gR)),{_assignPackageExport:Mhe}=Ti(),{transformReq:vhe}=ie(),{server:Uhe}=(Vr(),C(Au)),nn=dT.loggerWithTag("operation"),qd=Zn(),vK=(bl(),C(yl)),xhe=EI(),UK=fT.searchByHash,Bhe=fT.searchByValue,Hhe=BK.promisify(fT.search),khe=BK.promisify(kI.evaluateSQL),Fhe={[K.OPERATIONS_ENUM.CREATE_ATTRIBUTE]:!0,[K.OPERATIONS_ENUM.CREATE_TABLE]:!0,[K.OPERATIONS_ENUM.CREATE_SCHEMA]:!0,[K.OPERATIONS_ENUM.DROP_ATTRIBUTE]:!0,[K.OPERATIONS_ENUM.DROP_TABLE]:!0,[K.OPERATIONS_ENUM.DROP_SCHEMA]:!0},ee=yK();async function HK(e,t){try{if(e.body.operation!=="read_log"&&(dT.log_level===K.LOG_LEVELS.INFO||dT.log_level===K.LOG_LEVELS.DEBUG||dT.log_level===K.LOG_LEVELS.TRACE)){let{hdb_user:n,hdb_auth_header:s,password:i,payload:o,...c}=e.body;nn.info(c)}}catch(n){nn.error(n)}let r=await xhe.callOperationFunctionAsAwait(t,e.body,null);if(typeof r!="object"&&(r={message:r}),r instanceof Error)throw r;return Fhe[e.body.operation]&&Phe.setSchemaDataToGlobal(n=>{n&&nn.error(n)}),r}a(HK,"processLocalTransaction");var xK=qhe();qI.exports={chooseOperation:kK,getOperationFunction:FK,operation:GI,processLocalTransaction:HK,executeJob:Ms};Lhe(qI.exports);Uhe.operation=GI;function kK(e){let t;try{t=FK(e)}catch(s){throw nn.error(`Error when selecting operation function - ${s}`),s}let{operation_function:r,job_operation_function:n}=t;try{if(e.operation==="sql"||e.search_operation&&e.search_operation.operation==="sql"){let s=e.operation==="sql"?e.sql:e.search_operation.sql,i=kI.convertSQLToAST(s);if(e.parsed_sql_object=i,!e.bypass_auth){let o=kI.checkASTPermissions(e,i);if(o)throw nn.error(`${NK.FORBIDDEN} from operation ${e.operation}`),nn.warn(`User '${e.hdb_user?.username}' is not permitted to ${e.operation}`),ah(new Error,o,ch.HTTP_STATUS_CODES.FORBIDDEN,void 0,void 0,!0)}}else if(!e.bypass_auth&&e.operation!==K.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&e.operation!==K.OPERATIONS_ENUM.LOGIN&&e.operation!==K.OPERATIONS_ENUM.LOGOUT){let s=n===void 0?r:n,i=e.search_operation?e.search_operation:e;i.hdb_user||(i.hdb_user=e.hdb_user);let o=Che.verifyPerms(i,s);if(o)throw nn.error(`${NK.FORBIDDEN} from operation ${e.operation}`),nn.warn(`User '${i.hdb_user?.username}' is not permitted to ${i.operation}`),ah(new Error,o,ch.HTTP_STATUS_CODES.FORBIDDEN,void 0,!1,!0)}}catch(s){throw ah(s,"There was an error when trying to choose an operation path")}return r}a(kK,"chooseOperation");function FK(e){if(nn.trace(`getOperationFunction with operation: ${e.operation}`),xK.has(e.operation))return xK.get(e.operation);throw ah(new Error,ch.HDB_ERROR_MSGS.OP_NOT_FOUND(e.operation),ch.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}a(FK,"getOperationFunction");Mhe("operation",GI);function GI(e,t,r){e.hdb_user=t?.user,e.bypass_auth=!r;let n=kK(e);return HK({body:e},n)}a(GI,"operation");async function Ghe(e){nn.trace("In serverUtils.catchup");let t=e.transaction,r=t.channel.split(":"),n=r[0],s=r[1];for(let i of t.transactions)try{i.schema=n,i.table=s,i[K.CLUSTERING_FLAG]=!0;let o;switch(i.operation){case K.OPERATIONS_ENUM.INSERT:o=await $d.insert(i);break;case K.OPERATIONS_ENUM.UPDATE:o=await $d.update(i);break;case K.OPERATIONS_ENUM.UPSERT:o=await $d.upsert(i);break;case K.OPERATIONS_ENUM.DELETE:o=await oh.deleteRecord(i);break;default:nn.warn("invalid operation in catchup");break}await transact_to_clustering_utils.postOperationHandler(i,o,e)}catch(o){nn.info("Invalid operation in transaction"),nn.error(o)}}a(Ghe,"catchup");async function Ms(e){vhe(e);let t,r;try{r=await FI.addJob(e),t=r.createdJob,nn.info("addJob result",r);let n=new IK.RunnerMessage(t,e);return{message:await IK.parseMessage(n)??`Starting job with id ${t.id}`,job_id:t.id}}catch(n){let s=`There was an error executing job: ${n.http_resp_msg?n.http_resp_msg:n}`;throw nn.error(s),ah(n,s)}}a(Ms,"executeJob");function qhe(){let e=new Map;return e.set(K.OPERATIONS_ENUM.INSERT,new ee($d.insert)),e.set(K.OPERATIONS_ENUM.UPDATE,new ee($d.update)),e.set(K.OPERATIONS_ENUM.UPSERT,new ee($d.upsert)),e.set(K.OPERATIONS_ENUM.SEARCH_BY_CONDITIONS,new ee(fT.searchByConditions)),e.set(K.OPERATIONS_ENUM.SEARCH_BY_HASH,new ee(UK)),e.set(K.OPERATIONS_ENUM.SEARCH_BY_ID,new ee(UK)),e.set(K.OPERATIONS_ENUM.SEARCH_BY_VALUE,new ee(Bhe)),e.set(K.OPERATIONS_ENUM.SEARCH,new ee(Hhe)),e.set(K.OPERATIONS_ENUM.SQL,new ee(khe)),e.set(K.OPERATIONS_ENUM.CSV_DATA_LOAD,new ee(Ms,cT.csvDataLoad)),e.set(K.OPERATIONS_ENUM.CSV_FILE_LOAD,new ee(Ms,cT.csvFileLoad)),e.set(K.OPERATIONS_ENUM.CSV_URL_LOAD,new ee(Ms,cT.csvURLLoad)),e.set(K.OPERATIONS_ENUM.IMPORT_FROM_S3,new ee(Ms,cT.importFromS3)),e.set(K.OPERATIONS_ENUM.CREATE_SCHEMA,new ee(qo.createSchema)),e.set(K.OPERATIONS_ENUM.CREATE_DATABASE,new ee(qo.createSchema)),e.set(K.OPERATIONS_ENUM.CREATE_TABLE,new ee(qo.createTable)),e.set(K.OPERATIONS_ENUM.CREATE_ATTRIBUTE,new ee(qo.createAttribute)),e.set(K.OPERATIONS_ENUM.DROP_SCHEMA,new ee(qo.dropSchema)),e.set(K.OPERATIONS_ENUM.DROP_DATABASE,new ee(qo.dropSchema)),e.set(K.OPERATIONS_ENUM.DROP_TABLE,new ee(qo.dropTable)),e.set(K.OPERATIONS_ENUM.DROP_ATTRIBUTE,new ee(qo.dropAttribute)),e.set(K.OPERATIONS_ENUM.DESCRIBE_SCHEMA,new ee(lT.describeSchema)),e.set(K.OPERATIONS_ENUM.DESCRIBE_DATABASE,new ee(lT.describeSchema)),e.set(K.OPERATIONS_ENUM.DESCRIBE_TABLE,new ee(lT.describeTable)),e.set(K.OPERATIONS_ENUM.DESCRIBE_ALL,new ee(lT.describeAll)),e.set(K.OPERATIONS_ENUM.DELETE,new ee(oh.deleteRecord)),e.set(K.OPERATIONS_ENUM.ADD_USER,new ee(ih.addUser)),e.set(K.OPERATIONS_ENUM.ALTER_USER,new ee(ih.alterUser)),e.set(K.OPERATIONS_ENUM.DROP_USER,new ee(ih.dropUser)),e.set(K.OPERATIONS_ENUM.LIST_USERS,new ee(ih.listUsersExternal)),e.set(K.OPERATIONS_ENUM.LIST_ROLES,new ee(uT.listRoles)),e.set(K.OPERATIONS_ENUM.ADD_ROLE,new ee(uT.addRole)),e.set(K.OPERATIONS_ENUM.ALTER_ROLE,new ee(uT.alterRole)),e.set(K.OPERATIONS_ENUM.DROP_ROLE,new ee(uT.dropRole)),e.set(K.OPERATIONS_ENUM.USER_INFO,new ee(ih.userInfo)),e.set(K.OPERATIONS_ENUM.READ_LOG,new ee(Rhe)),e.set(K.OPERATIONS_ENUM.ADD_NODE,new ee(yhe)),e.set(K.OPERATIONS_ENUM.UPDATE_NODE,new ee(bK)),e.set(K.OPERATIONS_ENUM.SET_NODE_REPLICATION,new ee(bK)),e.set(K.OPERATIONS_ENUM.REMOVE_NODE,new ee(bhe)),e.set(K.OPERATIONS_ENUM.CONFIGURE_CLUSTER,new ee(Ohe)),e.set(K.OPERATIONS_ENUM.PURGE_STREAM,new ee(Nhe)),e.set(K.OPERATIONS_ENUM.SET_CONFIGURATION,new ee(DK.setConfiguration)),e.set(K.OPERATIONS_ENUM.CLUSTER_STATUS,new ee(whe.clusterStatus)),e.set(K.OPERATIONS_ENUM.CLUSTER_NETWORK,new ee(Ihe)),e.set(K.OPERATIONS_ENUM.CLUSTER_SET_ROUTES,new ee(BI.setRoutes)),e.set(K.OPERATIONS_ENUM.CLUSTER_GET_ROUTES,new ee(BI.getRoutes)),e.set(K.OPERATIONS_ENUM.CLUSTER_DELETE_ROUTES,new ee(BI.deleteRoutes)),e.set(K.OPERATIONS_ENUM.EXPORT_TO_S3,new ee(Ms,OK.export_to_s3)),e.set(K.OPERATIONS_ENUM.CREATE_CSR,new ee(qd.createCsr)),e.set(K.OPERATIONS_ENUM.SIGN_CERTIFICATE,new ee(qd.signCertificate)),e.set(K.OPERATIONS_ENUM.LIST_CERTIFICATES,new ee(qd.listCertificates)),e.set(K.OPERATIONS_ENUM.ADD_CERTIFICATES,new ee(qd.addCertificate)),e.set(K.OPERATIONS_ENUM.REMOVE_CERTIFICATE,new ee(qd.removeCertificate)),e.set(K.OPERATIONS_ENUM.GET_KEY,new ee(qd.getKey)),e.set(K.OPERATIONS_ENUM.ADD_NODE_BACK,new ee(vK.addNodeBack)),e.set(K.OPERATIONS_ENUM.REMOVE_NODE_BACK,new ee(vK.removeNodeBack)),e.set(K.OPERATIONS_ENUM.DELETE_FILES_BEFORE,new ee(Ms,oh.deleteFilesBefore)),e.set(K.OPERATIONS_ENUM.DELETE_RECORDS_BEFORE,new ee(Ms,oh.deleteFilesBefore)),e.set(K.OPERATIONS_ENUM.EXPORT_LOCAL,new ee(Ms,OK.export_local)),e.set(K.OPERATIONS_ENUM.SEARCH_JOBS_BY_START_DATE,new ee(FI.handleGetJobsByStartDate)),e.set(K.OPERATIONS_ENUM.GET_JOB,new ee(FI.handleGetJob)),e.set(K.OPERATIONS_ENUM.GET_FINGERPRINT,new ee(HI.getFingerprint)),e.set(K.OPERATIONS_ENUM.SET_LICENSE,new ee(HI.setLicense)),e.set(K.OPERATIONS_ENUM.GET_REGISTRATION_INFO,new ee(HI.getRegistrationInfo)),e.set(K.OPERATIONS_ENUM.RESTART,new ee(wK.restart)),e.set(K.OPERATIONS_ENUM.RESTART_SERVICE,new ee(Ms,wK.restartService)),e.set(K.OPERATIONS_ENUM.CATCHUP,new ee(Ghe)),e.set(K.OPERATIONS_ENUM.SYSTEM_INFORMATION,new ee(Dhe.systemInformation)),e.set(K.OPERATIONS_ENUM.DELETE_AUDIT_LOGS_BEFORE,new ee(Ms,oh.deleteAuditLogsBefore)),e.set(K.OPERATIONS_ENUM.READ_AUDIT_LOG,new ee(Ahe)),e.set(K.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,new ee(CK.createTokens)),e.set(K.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN,new ee(CK.refreshOperationToken)),e.set(K.OPERATIONS_ENUM.LOGIN,new ee(PK.login)),e.set(K.OPERATIONS_ENUM.LOGOUT,new ee(PK.logout)),e.set(K.OPERATIONS_ENUM.GET_CONFIGURATION,new ee(DK.getConfiguration)),e.set(K.OPERATIONS_ENUM.CUSTOM_FUNCTIONS_STATUS,new ee(Pt.customFunctionsStatus)),e.set(K.OPERATIONS_ENUM.GET_CUSTOM_FUNCTIONS,new ee(Pt.getCustomFunctions)),e.set(K.OPERATIONS_ENUM.GET_COMPONENT_FILE,new ee(Pt.getComponentFile)),e.set(K.OPERATIONS_ENUM.GET_COMPONENTS,new ee(Pt.getComponents)),e.set(K.OPERATIONS_ENUM.SET_COMPONENT_FILE,new ee(Pt.setComponentFile)),e.set(K.OPERATIONS_ENUM.DROP_COMPONENT,new ee(Pt.dropComponent)),e.set(K.OPERATIONS_ENUM.GET_CUSTOM_FUNCTION,new ee(Pt.getCustomFunction)),e.set(K.OPERATIONS_ENUM.SET_CUSTOM_FUNCTION,new ee(Pt.setCustomFunction)),e.set(K.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION,new ee(Pt.dropCustomFunction)),e.set(K.OPERATIONS_ENUM.ADD_CUSTOM_FUNCTION_PROJECT,new ee(Pt.addComponent)),e.set(K.OPERATIONS_ENUM.ADD_COMPONENT,new ee(Pt.addComponent)),e.set(K.OPERATIONS_ENUM.DROP_CUSTOM_FUNCTION_PROJECT,new ee(Pt.dropCustomFunctionProject)),e.set(K.OPERATIONS_ENUM.PACKAGE_CUSTOM_FUNCTION_PROJECT,new ee(Pt.packageComponent)),e.set(K.OPERATIONS_ENUM.PACKAGE_COMPONENT,new ee(Pt.packageComponent)),e.set(K.OPERATIONS_ENUM.DEPLOY_CUSTOM_FUNCTION_PROJECT,new ee(Pt.deployComponent)),e.set(K.OPERATIONS_ENUM.DEPLOY_COMPONENT,new ee(Pt.deployComponent)),e.set(K.OPERATIONS_ENUM.READ_TRANSACTION_LOG,new ee(LK.readTransactionLog)),e.set(K.OPERATIONS_ENUM.DELETE_TRANSACTION_LOGS_BEFORE,new ee(Ms,LK.deleteTransactionLogsBefore)),e.set(K.OPERATIONS_ENUM.INSTALL_NODE_MODULES,new ee(MK.installModules)),e.set(K.OPERATIONS_ENUM.AUDIT_NODE_MODULES,new ee(MK.auditModules)),e.set(K.OPERATIONS_ENUM.GET_BACKUP,new ee(qo.getBackup)),e.set(K.OPERATIONS_ENUM.ADD_SSH_KEY,new ee(Pt.addSSHKey)),e.set(K.OPERATIONS_ENUM.UPDATE_SSH_KEY,new ee(Pt.updateSSHKey)),e.set(K.OPERATIONS_ENUM.DELETE_SSH_KEY,new ee(Pt.deleteSSHKey)),e.set(K.OPERATIONS_ENUM.LIST_SSH_KEYS,new ee(Pt.listSSHKeys)),e.set(K.OPERATIONS_ENUM.SET_SSH_KNOWN_HOSTS,new ee(Pt.setSSHKnownHosts)),e.set(K.OPERATIONS_ENUM.GET_SSH_KNOWN_HOSTS,new ee(Pt.getSSHKnownHosts)),e}a(qhe,"initializeOperationFunctionMap")});var hT=w((Dve,$K)=>{"use strict";var _T=(H(),C(G)),$he=ie(),lh=z(),{handleHDBError:$I,hdb_errors:pT}=pe(),{isMainThread:Vhe}=require("worker_threads"),{Readable:Khe}=require("stream"),GK=require("os"),Yhe=require("util"),Whe=wO(),zhe=Yhe.promisify(Whe.authorize),qK=jw(),{createGzip:jhe,constants:Jhe}=require("zlib"),Qhe=[_T.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS,_T.OPERATIONS_ENUM.LOGIN,_T.OPERATIONS_ENUM.LOGOUT];function Xhe(e){let t=`Found an uncaught exception with message: ${e.message}. ${GK.EOL}Stack: ${e.stack} ${GK.EOL}Terminating ${Vhe?"HDB":"thread"}.`;console.error(t),lh.fatal(t),process.exit(1)}a(Xhe,"handleServerUncaughtException");function Zhe(e,t,r){if(lh[e.logLevel||"error"](e),e.statusCode)return typeof e.http_resp_msg!="object"?r.code(e.statusCode).send({error:e.http_resp_msg||e.message}):r.code(e.statusCode).send(e.http_resp_msg);let n=e.statusCode?e.statusCode:pT.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR;return typeof e=="string"?r.code(n).send({error:e}):r.code(n).send(e.message?{error:e.message}:e)}a(Zhe,"serverErrorHandler");function eme(e,t,r){if(!e.body||Object.keys(e.body).length===0||typeof e.body!="object"){let n=$I(new Error,"Invalid JSON.",pT.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}if($he.isEmpty(e.body.operation)){let n=$I(new Error,"Request body must include an 'operation' property.",pT.HTTP_STATUS_CODES.BAD_REQUEST);r(n,null)}r()}a(eme,"reqBodyValidationHandler");function tme(e,t,r){let n;!Qhe.includes(e.body.operation)||e.body.operation===_T.OPERATIONS_ENUM.CREATE_AUTHENTICATION_TOKENS&&!e.body.username&&!e.body.password?zhe(e,t).then(i=>{n=i,e.body.hdb_user=n,e.body.hdb_auth_header=e.headers.authorization,r()}).catch(i=>{lh.warn(i),lh.warn(`{"ip":"${e.socket.remoteAddress}", "error":"${i.stack}"`);let o=typeof i=="string"?{error:i}:{error:i.message};r($I(i,o,pT.HTTP_STATUS_CODES.UNAUTHORIZED),null)}):(e.body.hdb_user=null,e.body.hdb_auth_header=e.headers.authorization,e.body.baseRequest=e.raw?.baseRequest,e.body.baseResponse=t.raw?.baseResponse,e.body.fastifyResponse=t,r())}a(tme,"authHandler");async function rme(e,t,r=!1){let n;try{e.body.bypass_auth&&delete e.body.bypass_auth,n=qK.chooseOperation(e.body);let s=await qK.processLocalTransaction(e,n);if(s instanceof Khe&&s.headers){for(let[i,o]of s.headers)t.header(i,o);e.headers["accept-encoding"]?.includes("gzip")&&(t.header("content-encoding","gzip"),s=s.pipe(jhe({level:Jhe.Z_BEST_SPEED})))}return s}catch(s){throw lh.error(s),s}}a(rme,"handlePostRequest");$K.exports={authHandler:tme,handlePostRequest:rme,handleServerUncaughtException:Xhe,serverErrorHandler:Zhe,reqBodyValidationHandler:eme}});var WK=w((Mve,YK)=>{"use strict";var nme=require("fastify-plugin"),{handlePostRequest:VK,authHandler:sme,reqBodyValidationHandler:ime}=hT();async function ome(e){e.decorate("hdbCore",{preValidation:[ime,sme],request:a(t=>KK(VK(t,response)),"request"),requestWithoutAuthentication:a((t,r)=>KK(VK(t,r,!0)),"requestWithoutAuthentication")})}a(ome,"hdbCore");async function KK(e){if(e=await e,e?.[Symbol.asyncIterator]&&!e[Symbol.iterator]){let t=[];for await(let r of e)t.push(r);return t}return e}a(KK,"convertAsyncIterators");YK.exports=nme(ome)});var jK=w((xve,zK)=>{"use strict";var Uve=require("fs"),mT=ae();mT.initSync();var{CONFIG_PARAMS:VI}=(H(),C(G)),ame=1024*1024*1024;function cme(e){let t=mT.get(VI.HTTP_TIMEOUT),r=mT.get(VI.HTTP_KEEPALIVETIMEOUT);return{bodyLimit:ame,connectionTimeout:t,keepAliveTimeout:r,return503OnClosing:!1,forceCloseConnections:!0,ignoreTrailingSlash:!0,maxParamLength:mT.get(VI.HTTP_MAXPARAMLENGTH)??1e3,https:e}}a(cme,"getServerOptions");zK.exports=cme});var XK=w((Hve,QK)=>{"use strict";var KI=ae();KI.initSync();var{CONFIG_PARAMS:JK}=(H(),C(G));function lme(){let e=KI.get(JK.HTTP_CORSACCESSLIST),t=KI.get(JK.HTTP_CORS),r;return t&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},e&&e.length>0&&e[0]!==null&&e[0]!=="*"&&(r.origin=(n,s)=>s(null,e.indexOf(n)!==-1))),r}a(lme,"getCORSOptions");QK.exports=lme});var tY=w((Fve,eY)=>{"use strict";var ZK=ae();ZK.initSync();var ume=(H(),C(G));function dme(){return ZK.get(ume.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT)??6e4}a(dme,"getHeaderTimeoutConfig");eY.exports=dme});var WI={};ve(WI,{customFunctionsServer:()=>pme,ready:()=>hY,start:()=>_me});function _me(e){let t=e.securePort>0;return{async handleFile(r,n,s,i){$o||($o=pY(t),We.http((await $o).server));let o=await $o,c=(0,YI.dirname)(s),l=(0,YI.dirname)(n);if(l.startsWith("/")&&(l=l.slice(1)),!rY.has(c)){rY.add(c);try{o.register(mme(c,l))}catch(u){if(u.message==="Root plugin has already booted")ht.warn(`Could not load root fastify route for ${s}, this may require a restart to install properly`);else throw u}}},ready:hY}}async function pme(){try{ht.info("In Custom Functions Fastify server"+process.cwd()),ht.info(`Custom Functions Running with NODE_ENV set as: ${process.env.NODE_ENV}`),ht.debug(`Custom Functions server process ${process.pid} starting up.`),await hme();let e=cY.get(x.HTTP_SECUREPORT)>0,t;try{t=$o=await pY(e)}catch(r){throw ht.error(`Custom Functions buildServer error: ${r}`),r}try{await t.ready()}catch(r){throw ht.error(`Custom Functions server.ready() error: ${r}`),r}t.server.cantCleanupProperly=!0}catch(e){ht.error(`Custom Functions ${process.pid} Error: ${e}`),ht.error(e),process.exit(1)}}async function hme(){try{ht.info("Custom Functions starting configuration."),await lY.setUsersWithRolesCache(),ht.info("Custom Functions completed configuration.")}catch(e){ht.error(e)}}function mme(e,t){return async function(r){try{ht.info("Custom Functions starting buildRoutes"),ht.trace("Loading fastify routes folder "+e),(0,nY.existsSync)(e)&&r.register(aY.default,s=>({dir:e,dirNameRoutePrefix:!1,options:{hdbCore:s.hdbCore,logger:ht.loggerWithTag("custom-function"),prefix:`/${t}`}})).after((s,i,o)=>{s?.message?ht.error(s.message):s&&ht.error(s),o()})}catch(n){ht.error(`Custom Functions errored buildRoutes: ${n}`)}}}async function pY(e){ht.info("Custom Functions starting buildServer.");let t=(0,uY.default)(e),r=(0,sY.default)(t);r.server.headersTimeout=(0,fY.default)(),r.setErrorHandler(_Y.serverErrorHandler);let n=(0,dY.default)();return n&&r.register(iY.default,n),r.register(function(s,i,o){s.setNotFoundHandler(function(c,l){r.server.emit("unhandled",c.raw,l.raw)}),o()}),r.register(oY.default),await r.register(fme),await r.after(),jf(r),ht.info("Custom Functions completed buildServer."),r}function hY(){if($o)return $o.then?$o.then(e=>e.ready()):$o.ready()}var YI,nY,sY,iY,oY,aY,cY,ht,fme,lY,uY,dY,fY,_Y,$o,rY,mY=be(()=>{YI=require("path"),nY=require("fs"),sY=M(require("fastify")),iY=M(require("@fastify/cors")),oY=M(RO()),aY=M(require("@fastify/autoload")),cY=M(ae());H();ht=M(z()),fme=M(WK()),lY=M(Rn()),uY=M(jK()),dY=M(XK()),fY=M(tY()),_Y=M(hT());ao();Vr();rY=new Set;a(_me,"start");a(pme,"customFunctionsServer");a(hme,"setUp");a(mme,"buildRouteFolder");a(pY,"buildServer");a(hY,"ready")});var zI={};ve(zI,{start:()=>Eme});function Eme(e){return{handleDirectory(t,r){if(t==="/"){let n=(0,AY.default)(r,e);return e.server.http(async(s,i)=>{if(!s.isWebSocket)return new Promise(o=>n(s._nodeRequest,s._nodeResponse,()=>{o(i(s))}))}),!0}},handleFile(t,r,n){gY||(gY=!0,e.server.http(async(s,i)=>{if(!s.isWebSocket){let o=EY.get(s.pathname);if(o)return{handlesHeaders:!0,body:(0,SY.default)(s,(0,TY.realpathSync)(o))}}return i(s)},{runFirst:!0})),EY.set(r,n)}}}var SY,TY,AY,EY,gY,RY=be(()=>{SY=M(require("send")),TY=require("fs"),AY=M(require("serve-static")),EY=new Map;a(Eme,"start")});var jI={};ve(jI,{start:()=>gme});function gme({override:e}){return{handleFile:a((t,r,n)=>{ET.default.debug(`Loading env file: ${n}`);for(let[s,i]of Object.entries((0,yY.parse)(t))){if(process.env[s]!==void 0)if(ET.default.warn(`Environment variable conflict: ${s} from ${n} is already set on process.env`),e)ET.default.debug(`override option enabled. overriding environment variable: ${s}`);else continue;process.env[s]=i}},"handleFile")}}var yY,ET,bY=be(()=>{yY=require("dotenv"),ET=M(z());a(gme,"start")});var NY={};ve(NY,{Request:()=>JI,createReuseportFd:()=>gT});var OY,JI,QI,XI,gT,ZI=be(()=>{OY=require("os"),JI=class{static{a(this,"Request")}#e;constructor(t,r){this.method=t.method;let n=t.url;this._nodeRequest=t,this._nodeResponse=r,this.url=n,this.headers=new XI(t.headers)}get absoluteURL(){return this.protocol+"://"+this.host+this.url}get pathname(){let t=this.url.indexOf("?");return t>-1?this.url.slice(0,t):this.url}set pathname(t){let r=this.url.indexOf("?");r>-1?this.url=t+this.url.slice(r):this.url=t}get protocol(){return this._nodeRequest.socket.encrypted?"https":"http"}get ip(){return this._nodeRequest.socket.remoteAddress}get authorized(){return this._nodeRequest.socket.authorized}get peerCertificate(){return this._nodeRequest.socket.getPeerCertificate()}get mtlsConfig(){return this._nodeRequest.socket.server.mtlsConfig}get body(){return this.#e||(this.#e=new QI(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}sendEarlyHints(t,r={}){r.link=t,this._nodeResponse.writeEarlyHints(r)}},QI=class{static{a(this,"RequestBody")}#e;constructor(t){this.#e=t}on(t,r){return this.#e.on(t,r),this}pipe(t,r){return this.#e.pipe(t,r)}},XI=class{constructor(t){this.asObject=t}static{a(this,"Headers")}set(t,r){this.asObject[t.toLowerCase()]=r}get(t){return this.asObject[t.toLowerCase()]}has(t){return this.asObject.hasOwnProperty(t.toLowerCase())}[Symbol.iterator](){return Object.entries(this.asObject)[Symbol.iterator]()}keys(){return Object.keys(this.asObject)}values(){return Object.values(this.asObject)}delete(t){delete this.asObject[t.toLowerCase()]}forEach(t){for(let[r,n]of this)t(n,r,this)}};(0,OY.platform)()!="win32"&&(gT=require("node-unix-socket").createReuseportFd)});var tC=w((jve,wY)=>{"use strict";var uh=ae();uh.initSync();var Vd=require("fs-extra"),eC=require("path"),Kd=(H(),C(G)),Sme=require("crypto"),Tme=require("uuid").v4;wY.exports=Ame;function Ame(){if(uh.getHdbBasePath()!==void 0){let e=eC.join(uh.getHdbBasePath(),Kd.LICENSE_KEY_DIR_NAME,Kd.JWT_ENUM.JWT_PRIVATE_KEY_NAME),t=eC.join(uh.getHdbBasePath(),Kd.LICENSE_KEY_DIR_NAME,Kd.JWT_ENUM.JWT_PUBLIC_KEY_NAME),r=eC.join(uh.getHdbBasePath(),Kd.LICENSE_KEY_DIR_NAME,Kd.JWT_ENUM.JWT_PASSPHRASE_NAME);try{Vd.accessSync(r),Vd.accessSync(e),Vd.accessSync(t)}catch(n){if(n.code==="ENOENT"){let s=Tme(),i=Sme.generateKeyPairSync("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem",cipher:"aes-256-cbc",passphrase:s}});Vd.writeFileSync(r,s),Vd.writeFileSync(e,i.privateKey),Vd.writeFileSync(t,i.publicKey)}else throw n}}}a(Ame,"checkJWTTokenExist")});var CY=w((Qve,IY)=>{"use strict";var rC=class{static{a(this,"HdbInfoInsertObject")}constructor(t,r,n){this.info_id=t,this.data_version_num=r,this.hdb_version_num=n}};IY.exports={HdbInfoInsertObject:rC}});var LY=w((Zve,DY)=>{"use strict";var PY=(H(),C(G)),nC=class{static{a(this,"UpgradeObject")}constructor(t,r){this[PY.UPGRADE_JSON_FIELD_NAMES_ENUM.DATA_VERSION]=t,this[PY.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION]=r}};DY.exports={UpgradeObject:nC}});var ST=w((tUe,vY)=>{"use strict";var vs=require("prompt"),Yd=require("chalk"),MY=z(),mi=require("os"),sC=ua(),iC=["yes","y"];async function Rme(e){let t=`${mi.EOL}`+Yd.bold.green("Your current HarperDB version requires that we complete an update process.")+`${mi.EOL}If a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${mi.EOL}${mi.EOL}You can read more about the changes in this upgrade at https://harperdb.io/developers/release-notes/${mi.EOL}`;vs.override=sC(["CONFIRM_UPGRADE"]),vs.start(),vs.message=t;let r={properties:{CONFIRM_UPGRADE:{description:Yd.magenta(`${mi.EOL}[CONFIRM_UPGRADE] Do you want to upgrade your HDB instance now? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"no",required:!0}}},n;try{n=await vs.get([r])}catch(s){return MY.error("There was an error when prompting user about an upgrade."),MY.error(s),!1}return iC.includes(n.CONFIRM_UPGRADE)}a(Rme,"forceUpdatePrompt");async function yme(e){let t=`${mi.EOL}`+Yd.bold.green(`Your installed HarperDB version is older than the version used to create your data. Downgrading is not recommended as it is not tested and guaranteed to work. However, if you need to downgrade, and a backup of your data has not been created, we recommend you cancel this process and backup before proceeding.${mi.EOL}`);vs.override=sC(["CONFIRM_DOWNGRADE"]),vs.start(),vs.message=t;let r={properties:{CONFIRM_DOWNGRADE:{description:Yd.magenta(`${mi.EOL}[CONFIRM_DOWNGRADE] Do you want to proceed with using your downgraded HDB instance now? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"no",required:!0}}},n=await vs.get([r]);return iC.includes(n.CONFIRM_DOWNGRADE)}a(yme,"forceDowngradePrompt");async function bme(){let e=`${mi.EOL}`+Yd.bold.green("We now require a Certifacte Authority certificate. HarperDB can generate all new certificates for you (your existing certificates will be backed up) or you can keep any existing certificates and add your own CA certificate. To add your own CA certificate set the <certificateAuthority> parameter in harperdb-config.yaml");vs.override=sC(["GENERATE_CERTS"]),vs.start(),vs.message=e;let t={properties:{GENERATE_CERTS:{description:Yd.magenta(`${mi.EOL}[GENERATE_CERTS] Do you want HarperDB to generate all new certificates? (yes/no)`),pattern:/y(es)?$|n(o)?$/,message:"Must respond 'yes' or 'no'",default:"yes",required:!0}}},r=await vs.get([t]);return iC.includes(r.GENERATE_CERTS)}a(bme,"upgradeCertsPrompt");vY.exports={forceUpdatePrompt:Rme,forceDowngradePrompt:yme,upgradeCertsPrompt:bme}});var aC=w((nUe,UY)=>{"use strict";var oC=class{static{a(this,"UpgradeDirective")}constructor(t){this.version=t,this.sync_functions=[],this.async_functions=[]}};UY.exports=oC});var BY=w((lUe,xY)=>{"use strict";var Ome=ie(),Nme=yt(),iUe=z(),oUe=require("path"),aUe=require("fs"),cUe=(H(),C(G));xY.exports={getOldPropsValue:wme};function wme(e,t,r=!1){let n=t.getRaw(e);return Ome.isNotEmptyAndHasValue(n)?n:r?Nme.getDefaultConfig(e):""}a(wme,"getOldPropsValue")});var GY=w((dUe,FY)=>{"use strict";var ec=require("path"),tc=require("fs-extra"),Ime=require("properties-reader"),Cme=aC(),_r=z(),{getOldPropsValue:mt}=BY(),{HDB_SETTINGS_NAMES:Te,CONFIG_PARAMS:Gl}=(H(),C(G)),ql=yt(),TT=ae(),HY=ie(),Yi=(H(),C(G)),cC=new Cme("3.1.0"),kY=[];function Pme(){let e=Ime(TT.get(Te.SETTINGS_PATH_KEY)),t="Updating settings file for version 3.1.0";console.log(t),_r.info(t);let r=` ;Settings for the HarperDB process.
42
40
 
43
41
  ;The directory selected during install where the database files reside.
44
- ${ge.HDB_ROOT_KEY} = ${mt(ge.HDB_ROOT_KEY,e)}
42
+ ${Te.HDB_ROOT_KEY} = ${mt(Te.HDB_ROOT_KEY,e)}
45
43
  ;The port the HarperDB REST interface will listen on.
46
- ${ge.SERVER_PORT_KEY} = ${mt(ge.SERVER_PORT_KEY,e)}
44
+ ${Te.SERVER_PORT_KEY} = ${mt(Te.SERVER_PORT_KEY,e)}
47
45
  ;Set to true to enable HTTPS on the HarperDB REST endpoint. Requires a valid certificate and key.
48
- ${ge.HTTP_SECURE_ENABLED_KEY} = ${mt(ge.HTTP_SECURE_ENABLED_KEY,e)}
46
+ ${Te.HTTP_SECURE_ENABLED_KEY} = ${mt(Te.HTTP_SECURE_ENABLED_KEY,e)}
49
47
  ;The path to the SSL certificate used when running with HTTPS enabled.
50
- ${ge.CERT_KEY} = ${mt(ge.CERT_KEY,e)}
48
+ ${Te.CERT_KEY} = ${mt(Te.CERT_KEY,e)}
51
49
  ;The path to the SSL private key used when running with HTTPS enabled.
52
- ${ge.PRIVATE_KEY_KEY} = ${mt(ge.PRIVATE_KEY_KEY,e)}
50
+ ${Te.PRIVATE_KEY_KEY} = ${mt(Te.PRIVATE_KEY_KEY,e)}
53
51
  ;Set to true to enable Cross Origin Resource Sharing, which allows requests across a domain.
54
- ${ge.CORS_ENABLED_KEY} = ${mt(ge.CORS_ENABLED_KEY,e)}
52
+ ${Te.CORS_ENABLED_KEY} = ${mt(Te.CORS_ENABLED_KEY,e)}
55
53
  ;Allows for setting allowable domains with CORS. Comma separated list.
56
- ${ge.CORS_WHITELIST_KEY} = ${mt(ge.CORS_WHITELIST_KEY,e)}
54
+ ${Te.CORS_WHITELIST_KEY} = ${mt(Te.CORS_WHITELIST_KEY,e)}
57
55
  ;Length of time in milliseconds after which a request will timeout. Defaults to 120,000 ms (2 minutes).
58
- ${ge.SERVER_TIMEOUT_KEY} = ${mt(ge.SERVER_TIMEOUT_KEY,e,!0)}
56
+ ${Te.SERVER_TIMEOUT_KEY} = ${mt(Te.SERVER_TIMEOUT_KEY,e,!0)}
59
57
  ;The number of milliseconds of inactivity a server needs to wait for additional incoming data, after it has finished writing the last response. Defaults to 5,000 ms (5 seconds).
60
- ${ge.SERVER_KEEP_ALIVE_TIMEOUT_KEY} = ${mt(ge.SERVER_KEEP_ALIVE_TIMEOUT_KEY,e,!0)}
58
+ ${Te.SERVER_KEEP_ALIVE_TIMEOUT_KEY} = ${mt(Te.SERVER_KEEP_ALIVE_TIMEOUT_KEY,e,!0)}
61
59
  ;Limit the amount of time the parser will wait to receive the complete HTTP headers.. Defaults to 60,000 ms (1 minute).
62
- ${ge.SERVER_HEADERS_TIMEOUT_KEY} = ${mt(ge.SERVER_HEADERS_TIMEOUT_KEY,e,!0)}
60
+ ${Te.SERVER_HEADERS_TIMEOUT_KEY} = ${mt(Te.SERVER_HEADERS_TIMEOUT_KEY,e,!0)}
63
61
  ;Define whether to log to file or not.
64
- ${ge.LOG_TO_FILE} = ${kl.getDefaultConfig(Hl.LOGGING_FILE)}
62
+ ${Te.LOG_TO_FILE} = ${ql.getDefaultConfig(Gl.LOGGING_FILE)}
65
63
  ;Define whether to log to stdout/stderr or not. NOTE HarperDB must run in foreground in order to receive the std stream from HarperDB.
66
- ${ge.LOG_TO_STDSTREAMS} = ${kl.getDefaultConfig(Hl.LOGGING_STDSTREAMS)}
64
+ ${Te.LOG_TO_STDSTREAMS} = ${ql.getDefaultConfig(Gl.LOGGING_STDSTREAMS)}
67
65
  ;Set to control amount of logging generated. Accepted levels are trace, debug, warn, error, fatal.
68
- ${ge.LOG_LEVEL_KEY} = ${mt(ge.LOG_LEVEL_KEY,e)}
66
+ ${Te.LOG_LEVEL_KEY} = ${mt(Te.LOG_LEVEL_KEY,e)}
69
67
  ;The path where log files will be written. If there is no file name included in the path, the log file will be created by default as 'hdb_log.log'
70
- ${ge.LOG_PATH_KEY} = ${mt(ge.LOG_PATH_KEY,e)}
68
+ ${Te.LOG_PATH_KEY} = ${mt(Te.LOG_PATH_KEY,e)}
71
69
  ;Set to true to enable daily log file rotations - each log file name will be prepended with YYYY-MM-DD.
72
- ${ge.LOG_DAILY_ROTATE_KEY} = ${mt(ge.LOG_DAILY_ROTATE_KEY,e)}
70
+ ${Te.LOG_DAILY_ROTATE_KEY} = ${mt(Te.LOG_DAILY_ROTATE_KEY,e)}
73
71
  ;Set the number of daily log files to maintain when LOG_DAILY_ROTATE is enabled. If no integer value is set, no limit will be set for
74
72
  ;daily log files which may consume a large amount of storage depending on your log settings.
75
- ${ge.LOG_MAX_DAILY_FILES_KEY} = ${mt(ge.LOG_MAX_DAILY_FILES_KEY,e)}
73
+ ${Te.LOG_MAX_DAILY_FILES_KEY} = ${mt(Te.LOG_MAX_DAILY_FILES_KEY,e)}
76
74
  ;The environment used by NodeJS. Setting to production will be the most performant, settings to development will generate more logging.
77
- ${ge.PROPS_ENV_KEY} = ${mt(ge.PROPS_ENV_KEY,e)}
75
+ ${Te.PROPS_ENV_KEY} = ${mt(Te.PROPS_ENV_KEY,e)}
78
76
  ;This allows self signed certificates to be used in clustering. This is a security risk
79
77
  ;as clustering will not validate the cert, so should only be used internally.
80
78
  ;The HDB install creates a self signed certificate, if you use that cert this must be set to true.
81
- ${ge.ALLOW_SELF_SIGNED_SSL_CERTS} = ${mt(ge.ALLOW_SELF_SIGNED_SSL_CERTS,e,!0)}
79
+ ${Te.ALLOW_SELF_SIGNED_SSL_CERTS} = ${mt(Te.ALLOW_SELF_SIGNED_SSL_CERTS,e,!0)}
82
80
  ;Set the max number of processes HarperDB will start. This can also be limited by number of cores and licenses.
83
- ${ge.MAX_HDB_PROCESSES} = ${mt(ge.MAX_HDB_PROCESSES,e)}
81
+ ${Te.MAX_HDB_PROCESSES} = ${mt(Te.MAX_HDB_PROCESSES,e)}
84
82
  ;Set to true to enable clustering. Requires a valid enterprise license.
85
- ${ge.CLUSTERING_ENABLED_KEY} = ${mt(ge.CLUSTERING_ENABLED_KEY,e,!0)}
83
+ ${Te.CLUSTERING_ENABLED_KEY} = ${mt(Te.CLUSTERING_ENABLED_KEY,e,!0)}
86
84
  ;The port that will be used for HarperDB clustering.
87
- ${ge.CLUSTERING_PORT_KEY} = ${mt(ge.CLUSTERING_PORT_KEY,e)}
85
+ ${Te.CLUSTERING_PORT_KEY} = ${mt(Te.CLUSTERING_PORT_KEY,e)}
88
86
  ;The name of this node in your HarperDB cluster topology. This must be a value unique from the rest of your cluster node names.
89
- ${ge.CLUSTERING_NODE_NAME_KEY} = ${mt(ge.CLUSTERING_NODE_NAME_KEY,e)}
87
+ ${Te.CLUSTERING_NODE_NAME_KEY} = ${mt(Te.CLUSTERING_NODE_NAME_KEY,e)}
90
88
  ;The user used to connect to other instances of HarperDB, this user must have a role of cluster_user.
91
- ${ge.CLUSTERING_USER_KEY} = ${mt(ge.CLUSTERING_USER_KEY,e)}
89
+ ${Te.CLUSTERING_USER_KEY} = ${mt(Te.CLUSTERING_USER_KEY,e)}
92
90
  ;Defines if this instance does not record transactions. Note, if Clustering is enabled and Transaction Log is disabled your nodes will not catch up.
93
- ${ge.DISABLE_TRANSACTION_LOG_KEY} = ${mt(ge.DISABLE_TRANSACTION_LOG_KEY,e,!0)}
91
+ ${Te.DISABLE_TRANSACTION_LOG_KEY} = ${mt(Te.DISABLE_TRANSACTION_LOG_KEY,e,!0)}
94
92
  ;Defines the length of time an operation token will be valid until it expires. Example values: https://github.com/vercel/ms
95
- ${ge.OPERATION_TOKEN_TIMEOUT_KEY} = ${mt(ge.OPERATION_TOKEN_TIMEOUT_KEY,e,!0)}
93
+ ${Te.OPERATION_TOKEN_TIMEOUT_KEY} = ${mt(Te.OPERATION_TOKEN_TIMEOUT_KEY,e,!0)}
96
94
  ;Defines the length of time a refresh token will be valid until it expires. Example values: https://github.com/vercel/ms
97
- ${ge.REFRESH_TOKEN_TIMEOUT_KEY} = ${mt(ge.REFRESH_TOKEN_TIMEOUT_KEY,e,!0)}
95
+ ${Te.REFRESH_TOKEN_TIMEOUT_KEY} = ${mt(Te.REFRESH_TOKEN_TIMEOUT_KEY,e,!0)}
98
96
  ;The port the IPC server will run on.
99
- ${ge.IPC_SERVER_PORT} = ${kl.getDefaultConfig(Hl.IPC_NETWORK_PORT)}
97
+ ${Te.IPC_SERVER_PORT} = ${ql.getDefaultConfig(Gl.IPC_NETWORK_PORT)}
100
98
  ;Run HDB in the foreground.
101
- ${ge.RUN_IN_FOREGROUND} = ${kl.getDefaultConfig(Hl.OPERATIONSAPI_FOREGROUND)}
99
+ ${Te.RUN_IN_FOREGROUND} = ${ql.getDefaultConfig(Gl.OPERATIONSAPI_FOREGROUND)}
102
100
  ;Set to true to enable custom API endpoints. Requires a valid enterprise license.
103
- ${ge.CUSTOM_FUNCTIONS_ENABLED_KEY} = ${kl.getDefaultConfig(Hl.CUSTOMFUNCTIONS_ENABLED)}
101
+ ${Te.CUSTOM_FUNCTIONS_ENABLED_KEY} = ${ql.getDefaultConfig(Gl.CUSTOMFUNCTIONS_ENABLED)}
104
102
  ;The port used to access the custom functions server.
105
- ${ge.CUSTOM_FUNCTIONS_PORT_KEY} = ${kl.getDefaultConfig(Hl.HTTP_PORT)}
103
+ ${Te.CUSTOM_FUNCTIONS_PORT_KEY} = ${ql.getDefaultConfig(Gl.HTTP_PORT)}
106
104
  ;The path to the folder containing HarperDB custom function files.
107
- ${ge.CUSTOM_FUNCTIONS_DIRECTORY_KEY} = ${Xa.join(mt(ge.HDB_ROOT_KEY,e),"custom_functions")}
105
+ ${Te.CUSTOM_FUNCTIONS_DIRECTORY_KEY} = ${ec.join(mt(Te.HDB_ROOT_KEY,e),"custom_functions")}
108
106
  ;Set the max number of processes HarperDB will start for the Custom Functions server
109
- ${ge.MAX_CUSTOM_FUNCTION_PROCESSES} = ${kl.getDefaultConfig(Hl.HTTP_THREADS)}
110
- `,n=ST.get("settings_path"),s=Xa.dirname(n),i=Xa.join(s,"3_1_0_upgrade_settings.bak");try{_r.info(`Backing up old settings file to: ${i}`),Za.copySync(n,i)}catch(c){throw _r.error(c),console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),c}try{_r.info("New settings file values for 3.1.0 upgrade:",r),_r.info(`Creating new/upgraded settings file at '${n}'`),Za.writeFileSync(n,r),_r.info("Updating env variables with new settings values")}catch(c){throw console.error("There was a problem writing the new settings file. Please check the log for details."),_r.error("Attempting to reset the settings file to its original state. Use the '.bak' file if this fails."),_r.error(c),Za.copySync(i,n),c}ST.initSync();let o="New settings file for 3.1.0 upgrade successfully created.";return console.log(o),_r.info(o),o}a(wme,"updateSettingsFile_3_1_0");function Ime(){let e=Xa.join(kY.getHomeDir(),Yi.HDB_HOME_DIR_NAME,Yi.LICENSE_KEY_DIR_NAME,Yi.LICENSE_FILE_NAME),t=Xa.join(kY.getHomeDir(),Yi.HDB_HOME_DIR_NAME,Yi.LICENSE_KEY_DIR_NAME,Yi.REG_KEY_FILE_NAME),r=Xa.join(ST.getHdbBasePath(),Yi.LICENSE_KEY_DIR_NAME,Yi.LICENSE_FILE_NAME),n=Xa.join(r,Yi.LICENSE_FILE_NAME),s=Xa.join(r,Yi.REG_KEY_FILE_NAME),i="Move license files for version 3.1.0";console.log(i),_r.info(i);let o="Creating .license directory";console.log(o),_r.info(o),Za.mkdirpSync(r);try{Za.accessSync(e);try{let c="Moving licence file";console.log(c),_r.info(c),Za.moveSync(e,n);let l="License file successfully moved.";console.log(l),_r.info(l)}catch{let l="moving license file failed";console.error(l),_r.error(l)}}catch{let l=`license file '${e}' does not exist.`;console.warn(l),_r.warn(l)}try{Za.accessSync(t);try{let c="Moving registration file";console.log(c),_r.info(c),Za.moveSync(t,s);let l="Registration file successfully moved.";console.log(l),_r.info(l)}catch{let l="moving registration file failed";console.error(l),_r.error(l)}}catch{let l=`registration file '${t}' does not exist.`;console.warn(l),_r.warn(l)}}a(Ime,"moveLicenseFiles");aC.sync_functions.push(wme);aC.sync_functions.push(Ime);FY.push(aC);GY.exports=FY});var WY=w((uUe,YY)=>{"use strict";var os=_t(),{insertRecords:Cme}=Hc(),Pme=_n(),ec=Ut(),Dme=ie(),Vo=z(),Lme=ie(),Wi=require("fs-extra"),Ko=require("path"),Mme=require("cli-progress"),dh=require("assert"),vme=require("pino"),Ume=ae();YY.exports=xme;var TT,$Y,AT,cC,sn,fh=!1;async function xme(e=!0){return TT=Ume.getHdbBasePath(),$Y=Ko.join(TT,"schema"),AT=Ko.join(TT,"4_0_0_upgrade_tmp"),cC=Ko.join(TT,"transactions"),console.info("Reindexing upgrade started for schemas"),Vo.notify("Reindexing upgrade started for schemas"),await VY($Y,!1,e),await Wi.pathExists(cC)&&(console.info(`
107
+ ${Te.MAX_CUSTOM_FUNCTION_PROCESSES} = ${ql.getDefaultConfig(Gl.HTTP_THREADS)}
108
+ `,n=TT.get("settings_path"),s=ec.dirname(n),i=ec.join(s,"3_1_0_upgrade_settings.bak");try{_r.info(`Backing up old settings file to: ${i}`),tc.copySync(n,i)}catch(c){throw _r.error(c),console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),c}try{_r.info("New settings file values for 3.1.0 upgrade:",r),_r.info(`Creating new/upgraded settings file at '${n}'`),tc.writeFileSync(n,r),_r.info("Updating env variables with new settings values")}catch(c){throw console.error("There was a problem writing the new settings file. Please check the log for details."),_r.error("Attempting to reset the settings file to its original state. Use the '.bak' file if this fails."),_r.error(c),tc.copySync(i,n),c}TT.initSync();let o="New settings file for 3.1.0 upgrade successfully created.";return console.log(o),_r.info(o),o}a(Pme,"updateSettingsFile_3_1_0");function Dme(){let e=ec.join(HY.getHomeDir(),Yi.HDB_HOME_DIR_NAME,Yi.LICENSE_KEY_DIR_NAME,Yi.LICENSE_FILE_NAME),t=ec.join(HY.getHomeDir(),Yi.HDB_HOME_DIR_NAME,Yi.LICENSE_KEY_DIR_NAME,Yi.REG_KEY_FILE_NAME),r=ec.join(TT.getHdbBasePath(),Yi.LICENSE_KEY_DIR_NAME,Yi.LICENSE_FILE_NAME),n=ec.join(r,Yi.LICENSE_FILE_NAME),s=ec.join(r,Yi.REG_KEY_FILE_NAME),i="Move license files for version 3.1.0";console.log(i),_r.info(i);let o="Creating .license directory";console.log(o),_r.info(o),tc.mkdirpSync(r);try{tc.accessSync(e);try{let c="Moving licence file";console.log(c),_r.info(c),tc.moveSync(e,n);let l="License file successfully moved.";console.log(l),_r.info(l)}catch{let l="moving license file failed";console.error(l),_r.error(l)}}catch{let l=`license file '${e}' does not exist.`;console.warn(l),_r.warn(l)}try{tc.accessSync(t);try{let c="Moving registration file";console.log(c),_r.info(c),tc.moveSync(t,s);let l="Registration file successfully moved.";console.log(l),_r.info(l)}catch{let l="moving registration file failed";console.error(l),_r.error(l)}}catch{let l=`registration file '${t}' does not exist.`;console.warn(l),_r.warn(l)}}a(Dme,"moveLicenseFiles");cC.sync_functions.push(Pme);cC.sync_functions.push(Dme);kY.push(cC);FY.exports=kY});var YY=w((_Ue,KY)=>{"use strict";var os=_t(),{insertRecords:Lme}=qc(),Mme=_n(),rc=xt(),vme=ie(),Vo=z(),Ume=ie(),Wi=require("fs-extra"),Ko=require("path"),xme=require("cli-progress"),dh=require("assert"),Bme=require("pino"),Hme=ae();KY.exports=kme;var AT,qY,RT,lC,sn,fh=!1;async function kme(e=!0){return AT=Hme.getHdbBasePath(),qY=Ko.join(AT,"schema"),RT=Ko.join(AT,"4_0_0_upgrade_tmp"),lC=Ko.join(AT,"transactions"),console.info("Reindexing upgrade started for schemas"),Vo.notify("Reindexing upgrade started for schemas"),await $Y(qY,!1,e),await Wi.pathExists(lC)&&(console.info(`
111
109
 
112
- Reindexing upgrade started for transaction logs`),Vo.notify("Reindexing upgrade started for transaction logs"),await VY(cC,!0,e)),Vo.notify("Reindexing upgrade complete"),"Reindexing for 4.0.0 upgrade complete"+(fh?", but errors occurred":"")}a(xme,"reindexUpgrade");async function VY(e,t,r){let n=await Wi.readdir(e),s=n.length;for(let i=0;i<s;i++){let o=n[i],c=Ko.join(e,o.toString());if(o===".DS_Store")continue;let l=await Wi.readdir(c),u=l.length;for(let f=0;f<u;f++){let d=l[f];if(d!==".DS_Store"&&Wi.statSync(Ko.join(c,d)).isDirectory())try{await Bme(o,d,t),sn.info(`Reindexing started for ${o}.${d}`),Vo.notify(`${t?"Transaction":"Schema"} reindexing started for ${o}.${d}`),await kme(o,d,c,t,r),sn.info(`Reindexing completed for ${o}.${d}`),Vo.notify(`Reindexing completed for ${o}.${d}`)}catch(p){fh=!0,p.schema_path=c,p.table_name=d,Vo.error("There was an error with the reindex upgrade, check the logs in hdb/3_0_0_upgrade_tmp for more details"),Vo.error(p),sn.error(p),console.error(p)}}}if(!fh)try{await Wi.rm(AT,{recursive:!0})}catch{}}a(VY,"processTables");async function Bme(e,t,r){let s=`${e}_${t}_${r?"transaction_reindex":"schema_reindex"}.log`,i=Ko.join(AT,s);await Wi.ensureDir(AT),await Wi.writeFile(i,""),sn=vme({level:"debug",formatters:{bindings(){}}},i)}a(Bme,"initPinoLogger");var Hme=20;async function kme(e,t,r,n,s){let i;try{i=await os.openEnvironment(r,t,n)}catch(E){if(E.message==="MDB_INVALID: File is not an LMDB file"){Vo.notify(`${e}.${t} file is not from the old environment and has been skipped`),console.info(`${e}.${t} file is not from the old environment and has been skipped`),sn.error(E);return}throw E}let o=qme(i.dbis),c=os.openDBI(i,o),l=Object.keys(i.dbis),u=os.statDBI(i,o);sn.info(`Old environment stats: ${JSON.stringify(u)}`);let f=new Mme.SingleBar({format:`${e}.${t} |{bar}| {percentage}% || {value}/{total} records`,barCompleteChar:"\u2588",barIncompleteChar:"\u2591",hideCursor:!0,clearOnComplete:!1});f.start(u.entryCount,0,{});let d=await os.createEnvironment(r,t,!1);os.createDBI(d,o,!1,!0);let p=[];try{for(let E of c.getRange({start:!1}))E.value={...E.value},p.push(E),n||e==="system"&&(t==="hdb_schema"&&(E.key=E.key.toString(),E.value.name=E.value.name.toString()),t==="hdb_table"&&(E.key=E.key.toString(),E.value.schema=E.value.schema.toString(),E.value.name=E.value.name.toString()),t==="hdb_attribute"&&(E.key=E.key.toString(),E.value.schema=E.value.schema.toString(),E.value.table=E.value.table.toString(),E.value.attribute=E.value.attribute.toString())),p.length>Hme&&await _();await _()}catch(E){throw fh=!0,sn.error(E),E}async function _(){let E,T=p.map(({value:v})=>v);n?E=await Promise.all(T.map(v=>Fme(d,v))):E=await Cme(d,o,l.filter(v=>v!=="__blob__"),T,!1);for(let v=0,F=p.length;v<F;v++){let{key:q,value:Y}=p[v];sn.info(`Record hash value: ${q} hash: ${o}`);let Z;n?Z=E[v]:Z=E.written_hashes.indexOf(q)>-1,dh(Z,!0),Gme(d,o,Y[o],n),sn.info(`Insert success, written hashes: ${E.written_hashes}`),f.increment()}p=[],f.value/f.total*100%10===0&&Vo.notify(`${e}.${t} ${f.value}/${f.total} records inserted`),sn.info(`${f.value}/${f.total} records inserted`)}a(_,"finishOutstanding"),f.stop();let h=os.statDBI(i,o),S=os.statDBI(d,o);if(sn.info(`Old stats entry count: ${h.entryCount}. New stats entry count: ${S.entryCount}`),dh.deepStrictEqual(h.entryCount,S.entryCount),await os.closeEnvironment(i),await os.closeEnvironment(d),delete global.lmdb_map[`${e}.${t}`],s){let E=Ko.join(r,t),T=Ko.join(E,"data.mdb"),b=Ko.join(E,"lock.mdb");await Wi.unlink(T),await Wi.unlink(b),await Wi.rmdir(E),sn.info(`Deleted old environment files from schema folder: ${T}, ${b}`)}let g=await os.openEnvironment(r,t),R=os.statDBI(g,o);sn.info(`New stats: ${JSON.stringify(S)}. New stats after move: ${JSON.stringify(R)}`),dh.deepStrictEqual(R.entryCount,S.entryCount),await os.closeEnvironment(g),delete global.lmdb_map[`${e}.${t}`]}a(kme,"processTable");async function Fme(e,t){os.initializeDBIs(e,ec.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,ec.TRANSACTIONS_DBIS);let r=t.timestamp;return e.dbis[ec.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(r,()=>{e.dbis[ec.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(r,t),Lme.isEmpty(t.user_name)||e.dbis[ec.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(t.user_name,r);for(let n of t.hash_values)e.dbis[ec.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(n,r)})}a(Fme,"insertTransaction");function Gme(e,t,r,n){let i=e.dbis[t].get(r);dh.deepStrictEqual(typeof i,"object");let o;if(n){let c={[ec.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME]:i.user_name,[ec.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&&!Dme.isEmptyOrZeroLength(l))if(n&&c==="hash_value")for(let u=0,f=l.length;u<f;u++){let d=l[u];KY(e,c,d,r)}else KY(e,c,l,r)}a(Gme,"validateIndices");function KY(e,t,r,n){try{let s=!1,i=Pme.getIndexedValues(r);if(!i)return;for(let o of i)s=e.dbis[t].doesExist(o,n),s||sn.info(`Validate indices did not find value in new DBI: ${o}. Hash: ${n}`),dh.deepStrictEqual(s,!0)}catch(s){fh=!0,sn.error(s),console.error(s)}}a(KY,"validateIndex");function qme(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(qme,"getHashDBI")});var XY=w((_Ue,QY)=>{"use strict";var RT=require("path"),tc=require("fs-extra"),$me=oC(),Fl=z(),zY=yt(),lC=ae(),Ei=(H(),C(G)),yT=ie(),Vme=require("properties-reader"),Kme=ni(),Yme=rg(),Wme=Yr(),fUe=require("util"),zme=Wme.searchByValue,jme=Rn(),Jme=uS(),Qme=Tt(),Xme=WY(),jY=Zn(),Zme=gT(),hh=new $me("4.0.0"),JY=[],_h,ph;async function eEe(){try{if(await Zme.upgradeCertsPrompt()){if(console.log("Generating new certificates."),_h){let t=yT.changeExtension(_h,".bak");await tc.move(_h,t)}if(ph){let t=yT.changeExtension(ph,".bak");await tc.move(ph,t)}await jY.generateKeys()}else console.log("Using existing certificates."),jY.updateConfigCert(_h,ph,void 0)}catch(e){throw console.error("There was a problem generating new keys. Please check the log for details."),e}}a(eEe,"generateNewKeys");async function tEe(){console.log("Updating HarperDB nodes."),Fl.info("Updating HarperDB nodes.");let e=[];try{let t=new Kme(Ei.SYSTEM_SCHEMA_NAME,Ei.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*","name",["*"]),r=Array.from(await zme(t)),n=[];for(let i=0,o=r.length;i<o;i++){let c=r[i];if(!Qme.NATS_TERM_CONSTRAINTS_RX.test(c.name)){let f=`Node name '${c.name}' is invalid, must not contain ., * or >. Please change name and try again.`;throw console.error(f),f}let l={host:c.host,port:c.port};e.push(l);let u=[];for(let f=0,d=c.subscriptions.length;f<d;f++){let p=c.subscriptions[f],_=p.channel.split(":");u.push({schema:_[0],table:_[1],publish:p.publish,subscribe:p.subscribe})}n.push({name:c.name,subscriptions:u,system_info:{hdb_version:Ei.PRE_4_0_0_VERSION,node_version:void 0,platform:void 0}})}if(yT.isEmptyOrZeroLength(n))return;let s=new Yme(Ei.SYSTEM_SCHEMA_NAME,Ei.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,n);await jme.update(s)}catch(t){throw console.error("There was a problem updating the hdb_nodes table. Please check the log for details."),t}try{Jme.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(tEe,"updateNodes");async function rEe(){let e=lC.get(Ei.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);if(!e.includes(RT.join("config","settings.js"))){Fl.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),Fl.info(t);let r=RT.dirname(e),n=lC.get(Ei.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),s=RT.join(n,"backup","4_0_0_upgrade_settings.bak"),i=RT.join(n,Ei.HDB_CONFIG_FILE);try{Fl.info(`Backing up old settings file to: ${s}`),console.log(`Backing up old settings file to: ${s}`),tc.copySync(e,s)}catch(d){throw console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),d}try{Fl.info(`Creating new/upgraded settings file at '${i}'`),console.log(`Creating new/upgraded settings file at '${i}'`),Fl.info("Updating env variables with new settings values");let d=zY.initOldConfig(e);_h=d[Ei.CONFIG_PARAMS.TLS_CERTIFICATE.toLowerCase()],ph=d[Ei.CONFIG_PARAMS.TLS_PRIVATEKEY.toLowerCase()],zY.createConfigFile(d)}catch(d){throw console.log("There was a problem creating the new HarperDB config file. Please check the log for details."),d}let o=yT.getPropsFilePath();tc.accessSync(o,tc.constants.F_OK|tc.constants.R_OK);let l=Vme(o).get(Ei.HDB_SETTINGS_NAMES.INSTALL_USER),u=`settings_path = ${i}
113
- install_user = ${l}`;try{tc.writeFileSync(o,u)}catch(d){throw console.log("There was a problem updating the HarperDB boot properties file. Please check the log for details."),d}try{lC.initSync(!0)}catch(d){throw console.error("Unable to initialize new properties. Please check the log for details."),d}let f="New settings file for 4.0.0 upgrade successfully created.";try{tc.removeSync(r),console.log(f),Fl.info(f)}catch(d){throw console.error("There was a problem deleting the old settings file and directory. Please check the log for details."),d}}a(rEe,"updateSettingsFile_4_0_0");hh.async_functions.push(rEe);hh.async_functions.push(eEe);hh.async_functions.push(Xme);hh.async_functions.push(tEe);JY.push(hh);QY.exports=JY});var uC=w((hUe,rW)=>{"use strict";var Gl=ie(),nEe=(H(),C(G)),ZY=z(),{DATA_VERSION:sEe,UPGRADE_VERSION:iEe}=nEe.UPGRADE_JSON_FIELD_NAMES_ENUM,eW=qY(),bT=XY(),ql=new Map;eW&&eW.forEach(e=>{ql.set(e.version,e)});bT&&bT.forEach(e=>{ql.set(e.version,e)});bT&&bT.forEach(e=>{ql.set(e.version,e)});function oEe(){return[...ql.keys()].sort(Gl.compareVersions)}a(oEe,"getSortedVersions");function tW(e){let t=e[sEe],r=e[iEe];return Gl.isEmptyOrZeroLength(t)||Gl.isEmptyOrZeroLength(r)?(ZY.info(`There is an issue with the version data in your instance of HDB. Current version data: ${e}`),ZY.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."),[]):[...ql.keys()].sort(Gl.compareVersions).filter(function(n){return Gl.compareVersions(n,t)>0&&Gl.compareVersions(n,r)<=0})}a(tW,"getVersionsForUpgrade");function aEe(e){return tW(e).length>0}a(aEe,"hasUpgradesRequired");function cEe(e){return Gl.isEmptyOrZeroLength(e)?null:ql.has(e)?ql.get(e):null}a(cEe,"getDirectiveByVersion");rW.exports={getSortedVersions:oEe,getDirectiveByVersion:cEe,getVersionsForUpgrade:tW,hasUpgradesRequired:aEe}});var mh=w((EUe,aW)=>{"use strict";var lEe=require("util"),dC=require("chalk"),uEe=require("os"),sW=Rn(),dEe=Yr(),as=(H(),C(G)),iW=PY(),_C=vy(),{UpgradeObject:nW}=MY(),{forceDowngradePrompt:fEe}=gT(),{packageJson:_Ee}=st(),OT=z(),Yd=ie(),pC=As(),pEe=(Pe(),C(tt)),hEe=uC(),mEe=lEe.promisify(pC.setSchemaDataToGlobal),EEe=dEe.searchByValue,gEe="info_id",SEe="2.9.9",TEe="3.0.0";async function AEe(e){let t=new iW.HdbInfoInsertObject(1,e,e),r=new _C.InsertObject(as.OPERATIONS_ENUM.INSERT,as.SYSTEM_SCHEMA_NAME,as.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,as.INFO_TABLE_HASH_ATTRIBUTE,[t]);return pC.setSchemaDataToGlobal(),sW.insert(r)}a(AEe,"insertHdbInstallInfo");async function fC(e){let t,r=await oW(),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 iW.HdbInfoInsertObject(i,e,e);let o=new _C.InsertObject(as.OPERATIONS_ENUM.INSERT,as.SYSTEM_SCHEMA_NAME,as.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,as.INFO_TABLE_HASH_ATTRIBUTE,[t]);return await mEe(),sW.insert(o)}a(fC,"insertHdbUpgradeInfo");async function oW(){let e=new _C.NoSQLSeachObject(as.SYSTEM_SCHEMA_NAME,as.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,gEe,as.INFO_TABLE_HASH_ATTRIBUTE,["*"],"*"),t=[];try{t=Array.from(await EEe(e))}catch(r){console.error(r)}return t}a(oW,"getAllHdbInfoRecords");async function REe(){let e=await oW();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(REe,"getLatestHdbInfoRecord");async function yEe(){OT.info("Checking if HDB software has been updated");try{let e=_Ee.version;if(!e)throw new Error("Could not find the version number in the package.json file");let t=await REe(),r;if(Yd.isEmpty(t))r=SEe;else if(r=t.data_version_num,Yd.compareVersions(r.toString(),e.toString())>0){if(!Yd.isCompatibleDataVersion(r.toString(),e.toString()))throw console.log(dC.yellow(`This instance's data was last run on version ${r}`)),console.error(dC.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.${uEe.EOL}${as.SUPPORT_HELP_MSG}`)),new Error("Trying to downgrade major HDB versions is not supported.");Yd.isCompatibleDataVersion(r.toString(),e.toString(),!0)||(console.log(dC.yellow(`This instance's data was last run on version ${r}`)),await fEe(new nW(r,e))?await fC(e.toString()):(console.log("Cancelled downgrade, closing HarperDB"),process.exit(0)))}if(pC.setSchemaDataToGlobal(),bEe(r),e.toString()===r.toString())return;let n=new nW(r,e);if(hEe.hasUpgradesRequired(n))return n;Yd.compareVersions(n.data_version.toString(),n.upgrade_version.toString())<0&&(await fC(n.upgrade_version),OT.notify(`HarperDB running on upgraded version: ${n.upgrade_version}`))}catch(e){throw OT.fatal("Error while trying to evaluate the state of hdb data and the installed hdb version"),OT.fatal(e),e}}a(yEe,"getVersionUpdateInfo");function bEe(e){let t=`You are attempting to upgrade from an old instance of HarperDB that is no longer supported. In order to upgrade to this version, you must do a fresh install. If you need support, please contact ${as.HDB_SUPPORT_ADDRESS}`;if(!("hdb_info"in pEe.databases.system))throw console.log(t),new Error(t);if(!Yd.isEmpty(e)&&e<TEe)throw console.log(t),new Error(t)}a(bEe,"checkIfInstallIsSupported");aW.exports={insertHdbInstallInfo:AEe,insertHdbUpgradeInfo:fC,getVersionUpdateInfo:yEe}});var dW=w((SUe,uW)=>{"use strict";var NT=require("joi"),{boolean:OEe,string:hC,number:NEe}=NT.types(),cW=require("fs-extra"),Eh=(H(),C(G)),lW=require("path"),wEe=it();uW.exports=IEe;function IEe(e){let t=hC.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),r=NT.object({[Eh.INSTALL_PROMPTS.ROOTPATH]:NT.custom(CEe),[Eh.INSTALL_PROMPTS.OPERATIONSAPI_NETWORK_PORT]:NT.alternatives([NEe.min(0),hC]).allow("null",null),[Eh.INSTALL_PROMPTS.TC_AGREEMENT]:hC.valid("yes","YES","Yes"),[Eh.INSTALL_PROMPTS.CLUSTERING_NODENAME]:t,[Eh.INSTALL_PROMPTS.CLUSTERING_ENABLED]:OEe});return wEe.validateBySchema(e,r)}a(IEe,"installValidator");function CEe(e,t){if(cW.existsSync(lW.join(e,"system/hdb_user/data.mdb"))||cW.existsSync(lW.join(e,"system/hdb_user.mdb")))return t.message(`'${e}' is already in use. Please enter a different path.`)}a(CEe,"validateRootAvailable")});var gC=w((AUe,fW)=>{"use strict";var{mkdirpSync:PEe,copySync:DEe}=require("fs-extra"),rc=require("path"),gh=(H(),C(G)),{PACKAGE_ROOT:LEe}=st(),EC=z(),MEe=Vn(),mC=po(),vEe=gt();fW.exports=UEe;async function UEe(e){EC.trace("Mounting HarperDB"),$l(e),$l(rc.join(e,"backup")),$l(rc.join(e,"keys")),$l(rc.join(e,"keys",gh.LICENSE_FILE_NAME)),$l(rc.join(e,"log")),$l(rc.join(e,"database")),$l(rc.join(e,"components")),DEe(rc.resolve(LEe,"./utility/install/README.md"),rc.join(e,"README.md")),await xEe()}a(UEe,"mountHdb");async function xEe(){let e=v_(),t=Object.keys(mC);for(let r=0;r<t.length;r++){let n=t[r],s=mC[n].hash_attribute;try{vEe.initSystemSchemaPaths(gh.SYSTEM_SCHEMA_NAME,n);let i=new e(gh.SYSTEM_SCHEMA_NAME,n,s);i.attributes=mC[n].attributes;let o=i.attributes.find(({attribute:c})=>c===s);o.isPrimaryKey=!0,["hdb_user","hdb_role"].includes(n)&&(i.audit=!0),await MEe.createTable(n,i)}catch(i){throw EC.error(`issue creating environment for ${gh.SYSTEM_SCHEMA_NAME}.${n}: ${i}`),i}}}a(xEe,"createLMDBTables");function $l(e){PEe(e,{mode:gh.HDB_FILE_PERMISSIONS}),EC.info(`Directory ${e} created`)}a($l,"makeDirectory")});var CT=w((OUe,OW)=>{"use strict";var TC=require("os"),EW=require("inquirer"),xs=require("fs-extra"),BEe=require("properties-reader"),Kl=require("chalk"),ji=require("path"),HEe=require("human-readable-ids").hri,kEe=require("ora"),FEe=require("yaml"),pr=z(),nc=ae(),Sh=ie(),IT=ua(),gW=mh(),{packageJson:SW}=st(),de=(H(),C(G)),{CONFIG_PARAM_MAP:yUe,CONFIG_PARAMS:Pt}=de,GEe=dW(),qEe=gC(),AC=yt(),$Ee=An(),VEe=F_(),KEe=eC(),YEe=As(),WEe=require("util").promisify,zEe=WEe(YEe.setSchemaDataToGlobal),_W=Zn(),Vl=a(e=>e,"PROMPT_ANSWER_TRANSFORMER"),Hr=a(e=>Kl.magenta.bold(e),"HDB_PROMPT_MSG"),jEe="https://harperdb.io/legal/end-user-license-agreement",sc=TC.EOL,Yo="",JEe="yes",pW="Starting HarperDB install...",hW="HarperDB installation was successful.",mW="Terms & Conditions acceptance is required to proceed with installation. Exiting install...",QEe="An out of date version of HarperDB is already installed.",SC="It appears that HarperDB is already installed. Exiting install...",XEe="Aborting install",bUe=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])$/),ZEe=new RegExp(/^[^\s.,*>]+$/),ege=TC.homedir(),tge=ji.join(ege,de.HDB_ROOT_DIR_NAME),rge="HDB_ADMIN",nge="CLUSTER_USER",sge="dev",ige="localhost",wT={[Pt.HTTP_CORS]:!0,[Pt.HTTP_CORSACCESSLIST]:["*"],[Pt.HTTP_PORT]:9926,[Pt.AUTHENTICATION_AUTHORIZELOCAL]:!0,[Pt.THREADS_COUNT]:1,[Pt.THREADS_DEBUG]:!0,[Pt.LOGGING_STDSTREAMS]:!0,[Pt.LOGGING_LEVEL]:"info",[Pt.OPERATIONSAPI_NETWORK_PORT]:9925,[Pt.LOCALSTUDIO_ENABLED]:!0},Br={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:"},ic=IT([de.INSTALL_PROMPTS.HDB_CONFIG]),zi,TW=!1,RC=!1,AW=!1;OW.exports={install:RW,updateConfigEnv:mge,setIgnoreExisting:Ege};RW.createSuperUser=bW;async function RW(){console.log(Hr(sc+pW+sc)),pr.notify(pW);let e;ic[de.INSTALL_PROMPTS.HDB_CONFIG]&&(e=oge());let t=cge();Object.assign(t,e),t[de.INSTALL_PROMPTS.TC_AGREEMENT]&&t[de.INSTALL_PROMPTS.ROOTPATH]&&t[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME]&&t[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]&&t[de.INSTALL_PROMPTS.DEFAULTS_MODE]===void 0&&(AW=!0,t[de.INSTALL_PROMPTS.DEFAULTS_MODE]="prod");let r=GEe(t);if(r)throw r.message;await lge(),await uge(t);let n=await age(t);zi=n[de.INSTALL_PROMPTS.ROOTPATH],ic[de.INSTALL_PROMPTS.HDB_CONFIG]&&ji.dirname(ic[de.INSTALL_PROMPTS.HDB_CONFIG])===zi&&(TW=!0),!RC&&!ic[de.INSTALL_PROMPTS.HDB_CONFIG]&&await xs.pathExists(ji.join(zi,de.HDB_CONFIG_FILE))&&(console.error(SC),process.exit());let s=kEe({prefixText:Hr("Installing"),color:"magenta",spinner:"simpleDots"});if(s.start(),Sh.isEmpty(zi))throw new Error("Installer should have the HDB root param at the stage it is in but it does not.");nc.setHdbBasePath(zi),await qEe(zi),await dge(),await fge(n),pr.initLogSettings(!0),await bW(n),await pge(n),await _W.updateConfigCert(),await _W.generateCertsKeys(),await hge(),KEe(),s.stop(),console.log(Hr(sc+hW+sc)),pr.notify(hW)}a(RW,"install");function oge(){let e=FEe.parseDocument(xs.readFileSync(ic[de.INSTALL_PROMPTS.HDB_CONFIG],"utf8"),{simpleKeys:!0}),t=AC.flattenConfig(e.toJSON());return t[de.CONFIG_PARAMS.ROOTPATH.toLowerCase()]&&(t.ROOTPATH=t[de.CONFIG_PARAMS.ROOTPATH.toLowerCase()]),t}a(oge,"getConfigFromFile");async function age(e){pr.trace("Getting install prompts and params.");let t,r=[{type:"input",transformer:Vl,when:Wo(e[de.INSTALL_PROMPTS.ROOTPATH],Br.DESTINATION),name:de.INSTALL_PROMPTS.ROOTPATH,prefix:Yo,default:tge,validate:a(async s=>Us(s)?Us(s):await xs.pathExists(ji.join(s,"system","hdb_user.mdb"))?`'${s}' is already in use. Please enter a different path.`:!0,"validate"),message:Hr(Br.DESTINATION)},{type:"input",transformer:Vl,when:Wo(e[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],Br.HDB_USERNAME),name:de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME,prefix:Yo,default:rge,validate:a(s=>Us(s)?Us(s):(t=s,!0),"validate"),message:Hr(Br.HDB_USERNAME)},{type:"password",when:Wo(e[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD],Br.HDB_PASS),name:de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD,prefix:Yo,validate:a(s=>Us(s)?Us(s):!0,"validate"),message:Hr(Br.HDB_PASS)},{type:"input",transformer:Vl,when:Wo(e[de.INSTALL_PROMPTS.DEFAULTS_MODE],Br.DEFAULTS_MODE),name:de.INSTALL_PROMPTS.DEFAULTS_MODE,prefix:Yo,default:sge,validate:a(s=>Us(s)?Us(s):s!=="dev"&&s!=="prod"?`Invalid response '${s}', options are 'dev' or 'prod'.`:!0,"validate"),message:Hr(Br.DEFAULTS_MODE)}];if(AW||r.push({type:"input",name:de.INSTALL_PROMPTS.REPLICATION_HOSTNAME,transformer:Vl,when:Wo(e[de.INSTALL_PROMPTS.REPLICATION_HOSTNAME],Br.REPLICATION_HOSTNAME),prefix:Yo,default:ige,message:Hr(Br.REPLICATION_HOSTNAME)}),Sh.autoCastBoolean(e[de.INSTALL_PROMPTS.CLUSTERING_ENABLED])===!0){let s=[{type:"input",transformer:Vl,when:Wo(e[de.INSTALL_PROMPTS.CLUSTERING_NODENAME],Br.NODE_NAME),name:de.INSTALL_PROMPTS.CLUSTERING_NODENAME,prefix:Yo,default:HEe.random(),validate:a(i=>ZEe.test(i)?!0:"Invalid node name, must not contain ., * or >","validate"),message:Hr(Br.NODE_NAME)},{type:"input",transformer:Vl,when:Wo(e[de.INSTALL_PROMPTS.CLUSTERING_USER],Br.CLUSTER_USERNAME),name:de.INSTALL_PROMPTS.CLUSTERING_USER,prefix:Yo,default:nge,validate:a(i=>Us(i)?Us(i):i.toLowerCase()===t.toLowerCase()?"Username is already in use.":!0,"validate"),message:Hr(Br.CLUSTER_USERNAME)},{type:"password",when:Wo(e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD],Br.CLUSTER_PASS),name:de.INSTALL_PROMPTS.CLUSTERING_PASSWORD,prefix:Yo,validate:a(i=>Us(i)?Us(i):!0,"validate"),message:Hr(Br.CLUSTER_PASS)}];r.push(...s)}let n=await EW.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(age,"installPrompts");function Wo(e,t){return e!==void 0?(t.includes("password")?(console.log(`${Hr(t)} ${Kl.gray("[hidden]")}`),pr.trace(`${Hr(t)} [hidden]`)):(console.log(`${Hr(t)} ${e}`),pr.trace(`${Hr(t)} ${e}`)),!1):!0}a(Wo,"displayCmdEnvVar");function Us(e){let t=e.replace(/ /g,"");if(t===""||t==="''"||t==='""')return"Value cannot be empty."}a(Us,"checkForEmptyValue");function cge(){let e=Object.keys(de.INSTALL_PROMPTS),t=IT(e),r=IT(Object.keys(de.CONFIG_PARAM_MAP),!0),n={};for(let s of e){let i=de.CONFIG_PARAM_MAP[s.toLowerCase()];t[s]?i===void 0?n[s]=t[s]:n[i.toUpperCase()]=t[s]:i!==void 0&&r[i.toLowerCase()]&&(n[s]=r[i.toLowerCase()])}return n}a(cge,"checkForPromptOverride");async function lge(){pr.trace("Checking for existing install.");let e=Sh.getPropsFilePath(),t=await xs.pathExists(e),r;if(t){pr.trace(`Install found an existing boot prop file at:${e}`);let n=BEe(e),s=AC.getConfigValue(de.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)||n.get(de.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY);r=await xs.pathExists(s)}if(!t&&Sh.noBootFile()&&(r=!0),r&&!RC){if(pr.trace(`Install found existing HDB config at:${e}`),await gW.getVersionUpdateInfo()){let s=`Please use \`harperdb upgrade\` to update to ${SW.version}. Exiting install...`;console.log(sc+Kl.magenta.bold(QEe)),console.log(Kl.magenta.bold(s)),pr.error(s)}else console.log(sc+Kl.magenta.bold(SC)),pr.error(SC);process.exit(0)}}a(lge,"checkForExistingInstall");async function uge(e){pr.info("Asking for terms agreement.");let t=`Terms & Conditions can be found at ${jEe}${sc}and can be viewed by typing or copying and pasting the URL into your web browser.${sc}I agree to the HarperDB Terms and Conditions: (yes/no)`,r={prefix:Yo,transformer:Vl,when:Wo(e[de.INSTALL_PROMPTS.TC_AGREEMENT],t),name:de.INSTALL_PROMPTS.TC_AGREEMENT,message:Hr(t),validate:a(s=>s.toLowerCase()==="yes"||s.toLowerCase()==="no"?!0:Kl.yellow("Please enter 'yes' or 'no'"),"validate")},n=await EW.prompt([r]);n[de.INSTALL_PROMPTS.TC_AGREEMENT]&&n[de.INSTALL_PROMPTS.TC_AGREEMENT].toLowerCase()!==JEe&&(console.log(Kl.yellow(mW)),pr.error(mW),process.exit(0))}a(uge,"termsAgreement");async function dge(){let e=ji.join(zi,de.HDB_CONFIG_FILE),t;try{t=TC.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}
114
- install_user = ${t}`,n=Sh.getHomeDir(),s=ji.join(n,de.HDB_HOME_DIR_NAME),i=ji.join(s,de.LICENSE_KEY_DIR_NAME);try{xs.mkdirpSync(s,{mode:de.HDB_FILE_PERMISSIONS}),xs.mkdirpSync(i,{mode:de.HDB_FILE_PERMISSIONS})}catch{console.error(`Could not make settings directory ${de.HDB_HOME_DIR_NAME} in home directory. Please check your permissions and try again.`)}let o=ji.join(s,de.BOOT_PROPS_FILE_NAME);try{await xs.writeFile(o,r)}catch(c){throw pr.error(`There was an error creating the boot file at path: ${o}`),c}nc.setProperty(de.HDB_SETTINGS_NAMES.INSTALL_USER,`${t}`),nc.setProperty(de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,e),nc.setProperty(nc.BOOT_PROPS_FILE_PATH,o)}}a(dge,"createBootPropertiesFile");async function fge(e){pr.trace("Creating HarperDB config file");let t=IT(Object.keys(de.CONFIG_PARAM_MAP),!0);if(Object.assign(t,e),e[de.INSTALL_PROMPTS.DEFAULTS_MODE]==="dev"){process.env.DEV_MODE="true";for(let r in wT){if(r===Pt.HTTP_PORT&&t[Pt.HTTP_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??wT[r],t[Pt.HTTP_SECUREPORT]=null;continue}else if(r===Pt.HTTP_PORT)continue;if(r===Pt.OPERATIONSAPI_NETWORK_PORT&&t[Pt.OPERATIONSAPI_NETWORK_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??wT[r],t[Pt.OPERATIONSAPI_NETWORK_SECUREPORT]=null;continue}else if(r===Pt.OPERATIONSAPI_NETWORK_PORT)continue;t[r.toLowerCase()]===void 0&&(t[r]=wT[r])}}else t[Pt.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]&&(t[Pt.OPERATIONSAPI_NETWORK_SECUREPORT]=null),t[Pt.HTTP_PORT.toLowerCase()]&&(t[Pt.HTTP_SECUREPORT]=null);try{ic[de.INSTALL_PROMPTS.HDB_CONFIG]||AC.createConfigFile(t),nc.initSync()}catch(r){_ge(r)}}a(fge,"createConfigFile");function _ge(e){pr.error(`Error creating HarperDB config file. Rolling back install - ${e}`),console.error(e),console.error(XEe);let t=ji.resolve(nc.get(nc.BOOT_PROPS_FILE_PATH),"../");t&&xs.removeSync(t),zi&&(TW?xs.readdirSync(zi,{withFileTypes:!0}).forEach(n=>{let s=ji.join(n.path,n.name);s!==ic[de.INSTALL_PROMPTS.HDB_CONFIG]&&xs.removeSync(s)}):xs.removeSync(zi)),process.exit(1)}a(_ge,"rollbackInstall");async function yW(e,t){pr.trace("Creating admin user"),await zEe();let r;try{r=await VEe.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 $Ee.addUser(t)}catch(n){throw n.message=`Error creating user - ${n}`,n}}a(yW,"createAdminUser");async function bW(e){pr.trace("Creating Super user.");let t={role:"super_user",permission:{super_user:!0}},r={username:e[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME].toString(),password:e[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD].toString(),active:!0};await yW(t,r),delete e[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],delete e[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]}a(bW,"createSuperUser");async function pge(e){pr.trace("Creating Cluster user.");let t;e[de.INSTALL_PROMPTS.CLUSTERING_USER]&&e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD]&&(t={username:e[de.INSTALL_PROMPTS.CLUSTERING_USER].toString(),password:e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD].toString(),active:!0}),await yW({role:"cluster_user",permission:{cluster_user:!0}},t),delete e[de.INSTALL_PROMPTS.CLUSTERING_USER],delete e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD]}a(pge,"createClusterUser");async function hge(){let e=SW.version;if(e)await gW.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(hge,"insertHdbVersionInfo");function mge(e){ic[de.INSTALL_PROMPTS.HDB_CONFIG]=e}a(mge,"updateConfigEnv");function Ege(e){RC=e}a(Ege,"setIgnoreExisting")});var IW=w((wUe,wW)=>{"use strict";var yC=ie(),cs=z(),NW=uC();wW.exports={processDirectives:gge};async function gge(e){console.log("Starting upgrade process...");let t=NW.getVersionsForUpgrade(e),r=Age(t),n=[],s=r.length;for(let i=0;i<s;i++){let o=r[i],c=`Running upgrade for version ${o.version}`;cs.notify(c),console.log(c);let l=[],u=[];try{l=Sge(o.sync_functions)}catch(f){throw cs.error(`Error while running an upgrade script for ${o.version}`),f}try{u=await Tge(o.async_functions)}catch(f){throw cs.error(`Error while running an upgrade script for ${o.version}`),f}n.push(...l,...u)}return n}a(gge,"processDirectives");function Sge(e){if(yC.isEmptyOrZeroLength(e))return cs.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return cs.info("Passed parameter is not an array"),[];let t=[];for(let r of e){if(cs.info(`Running function ${r.name}`),!(r instanceof Function)){cs.info("Variable being processed is not a function");continue}let n=r();cs.info(n),t.push(n)}return t}a(Sge,"runSyncFunctions");async function Tge(e){if(yC.isEmptyOrZeroLength(e))return cs.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return cs.info("Passed parameter is not an array"),[];let t=[],r=e.length;for(let n=0;n<r;n++){let s=e[n];if(cs.info(`Running function ${s.name}`),!(s instanceof Function)){cs.info("Variable being processed is not a function");continue}let i=await s();cs.info(i),t.push(i)}return t}a(Tge,"runAsyncFunctions");function Age(e){if(yC.isEmptyOrZeroLength(e))return[];let t=[];for(let r of e){let n=NW.getDirectiveByVersion(r);n&&t.push(n)}return t}a(Age,"getUpgradeDirectivesToInstall")});var wC=w((CUe,vW)=>{"use strict";var PT=ae();PT.initSync();var LW=require("chalk"),CW=require("fs-extra"),jo=z(),zo=(H(),C(G)),Rge=IW(),bC=ie(),MW=mh(),yge=gT(),PW=sR(),bge=As(),{packageJson:DW}=st(),Oge=require("util").promisify,Nge=Oge(bge.setSchemaDataToGlobal),OC,{UPGRADE_VERSION:NC}=zo.UPGRADE_JSON_FIELD_NAMES_ENUM;vW.exports={upgrade:wge};async function wge(e){await Nge(),OC===void 0&&(OC=Cd()),CW.existsSync(PT.get(PT.BOOT_PROPS_FILE_PATH))||(Th("The hdb_boot_properties file was not found. Please install HDB.",zo.LOG_LEVELS.ERROR),process.exit(1)),CW.existsSync(PT.get(zo.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))||(Th("The hdb settings file was not found. Please make sure HDB is installed.",zo.LOG_LEVELS.ERROR),process.exit(1));let t=e;t||(t=await MW.getVersionUpdateInfo(),t||(console.log("HarperDB version is current"),process.exit(0))),Th(`This version of HarperDB is ${DW.version}`,zo.LOG_LEVELS.INFO);let r=t[NC]??DW.version;r||(console.log(`Current Version field missing from the package.json file. Cannot continue with upgrade. If you need support, please contact ${zo.HDB_SUPPORT_ADDRESS}`),jo.notify("Missing new version field from upgrade info object"),process.exit(1)),await Ige();let n,s=0;try{n=await yge.forceUpdatePrompt(t)}catch(i){jo.error("There was an error when prompting user about upgrade."),jo.error(i),n=!1,s=1}n||(console.log("Cancelled upgrade, closing HarperDB"),process.exit(s)),jo.info(`Starting upgrade to version ${r}`),await Cge(t),Th(`HarperDB was successfully upgraded to version ${t[NC]}`,zo.LOG_LEVELS.INFO)}a(wge,"upgrade");async function Ige(){let e=!1,t=await PW.findPs(zo.HDB_PROC_NAME);if(bC.isEmptyOrZeroLength(t)||(e=!0),!e){let r=await PW.findPs("hdb_express");bC.isEmptyOrZeroLength(r)||(e=!0)}if(!e){let r=await OC.list();bC.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(LW.red(r)),jo.error(r),process.exit(1)}}a(Ige,"checkIfRunning");async function Cge(e){try{await Rge.processDirectives(e)}catch(t){throw Th("There was an error during the data upgrade. Please check the logs.",zo.LOG_LEVELS.ERROR),t}try{await MW.insertHdbUpgradeInfo(e[NC])}catch(t){jo.error("Error updating the 'hdb_info' system table."),jo.error(t)}}a(Cge,"runUpgrade");function Th(e,t=void 0){t||(t=jo.info),jo[t](e),console.log(LW.magenta(e))}a(Th,"printToLogAndConsole")});var kW={};ve(kW,{onStorageReclamation:()=>Ah,runReclamationHandlers:()=>DC,setAvailableSpaceRatioGetter:()=>Dge});function Ah(e,t,r){(r||(0,LT.getWorkerIndex)()===(0,LT.getWorkerCount)()-1)&&(DT.has(e)||DT.set(e,[]),DT.get(e).push({priority:0,handler:t}),PC||(PC=setTimeout(DC,xW).unref()))}async function DC(){for(let[e,t]of DT)try{let r=await HW(e),n=Pge/r;for(let s of t){let{priority:i,handler:o}=s;if(s.priority=n,n>1||i>1){let c=o(n>1?n:0);c&&(CC.default.info?.(`Running storage reclamation handler for ${e} with priority ${n}`),await c)}}}catch(r){CC.default.error?.("Error running storage reclamation handlers",r)}PC=setTimeout(DC,xW).unref()}function Dge(e){HW=e??BW}var IC,LT,CC,MT,UW,DT,Pge,xW,PC,BW,HW,vT=be(()=>{IC=require("node:fs/promises"),LT=M(et()),CC=M(Ni());H();MT=M(ae()),UW=M(ie());MT.default.initSync();DT=new Map,Pge=MT.default.get(B.STORAGE_RECLAMATION_THRESHOLD)??.4,xW=(0,UW.convertToMS)(MT.default.get(B.STORAGE_RECLAMATION_INTERVAL))||36e5;a(Ah,"onStorageReclamation");BW=a(async e=>{if(IC.statfs){let t=await(0,IC.statfs)(e);return t.bavail/t.blocks}else return new Promise((t,r)=>{import("hdd-space").then(n=>{n.default(s=>{for(let i of s.parts)if(e.startsWith(i.place))return t(i.free/i.size);return t(1)})})})},"defaultGetAvailableSpaceRatio"),HW=BW;a(DC,"runReclamationHandlers");a(Dge,"setAvailableSpaceRatioGetter")});var VW=w((MUe,$W)=>{"use strict";var{promises:Wd,createReadStream:Lge,createWriteStream:Mge}=require("fs"),{createGzip:vge}=require("zlib"),{promisify:Uge}=require("util"),{pipeline:xge}=require("stream"),Bge=Uge(xge),MC=require("path"),ac=ae();ac.initSync();var oc=z(),{CONFIG_PARAMS:zd,ITC_EVENT_TYPES:Hge}=(H(),C(G)),{onMessageFromWorkers:kge}=et(),{convertToMS:Fge}=ie(),{onStorageReclamation:Gge}=(vT(),C(kW)),qge=6e4,$ge="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",Vge="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",LC,GW;$W.exports=qW;kge(e=>{e.type===Hge.RESTART&&(ac.initSync(!0),clearInterval(GW),ac.get(zd.LOGGING_ROTATION_ENABLED)&&qW())});async function qW(){try{let e=oc.getLogFilePath(),t=ac.get(zd.LOGGING_ROTATION_MAXSIZE),r=ac.get(zd.LOGGING_ROTATION_INTERVAL),n=ac.get(zd.LOGGING_ROTATION_RETENTION),s=0;if(Gge(e,l=>{s=l},!0),!t&&!r){oc.error($ge);return}let i=ac.get(zd.LOGGING_ROTATION_PATH);if(!i){oc.error(Vge);return}let o;if(t){let l=t.slice(-1),u=t.slice(0,-1);l==="G"?o=u*1e9:l==="M"?o=u*1e6:o=u*1e3}let c;if(r){let l=r.slice(-1),u=r.slice(0,-1);l==="D"?c=u*1440:l==="H"?c=u*60:c=u}LC=Date.now()/6e4,oc.trace("Log rotate enabled, maxSize:",t,"interval:",r),GW=setInterval(async()=>{if(o){let l;l=await Wd.stat(e),l.size>=o&&await FW(e,i)}if(c&&Date.now()/6e4-LC>=c&&(await FW(e,i),LC=Date.now()/6e4),n||s){let l=Fge(n??"1M")/(1+s);s=0;let u=await Wd.readdir(i);for(let f of u)try{let d=await Wd.stat(MC.join(i,f));Date.now()-d.mtimeMs>l&&await Wd.unlink(MC.join(i,f))}catch(d){oc.error("Error trying to remove log",f,d)}}},qge).unref()}catch(e){oc.error(e)}}a(qW,"logRotator");async function FW(e,t){let r=ac.get(zd.LOGGING_ROTATION_COMPRESS),n=MC.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.log`);await Wd.rename(e,n),r&&(e=n,n+=".gz",await Bge(Lge(e),vge(),Mge(n)),await Wd.unlink(e)),oc.closeLogFile(),oc.notify(`hdb.log rotated, old log moved to ${n}`)}a(FW,"moveLogFile")});var Jd=w(QW=>{"use strict";var Se=ae();Se.initSync();Wa();var Ft=(H(),C(G)),{CONFIG_PARAMS:Ie}=Ft,ls=z(),Jo=require("fs-extra"),Qo=require("path"),Kge=eC(),{install:Yge}=CT(),vC=require("chalk"),{packageJson:Wge,PACKAGE_ROOT:zge}=st(),Xo=ie(),UC=yt(),YW=ua(),KW=SS(),jge=wC(),Jge=VW(),{compactOnStart:Qge}=(wS(),C(NS)),Xge=require("minimist"),Zge=Zn(),{startHTTPThreads:eSe}=(xC(),C(XW)),tSe=mh(),{isMainThread:rSe}=require("worker_threads"),UUe=po(),xUe=go(),BUe=Cb(),HUe=v_(),UT=(H(),C(G)),Ji,jd,WW=!1,nSe="Upgrade complete. Starting HarperDB.",sSe="Got an error while trying to upgrade your HarperDB instance. Exiting HarperDB.",iSe="HarperDB not found, starting install process.",oSe="There was an error during install, check install_log.log for more details. Exiting.",aSe="HarperDB successfully started.";function cSe(){if(!WW){let e=a(()=>{Jo.removeSync(Qo.join(Se.get(Ft.CONFIG_PARAMS.ROOTPATH),Ft.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(cSe,"addExitListeners");async function zW(e=!1,t=!1){if(console.log(vC.magenta("Starting HarperDB...")),ls.suppressLogging?.(()=>{console.log(vC.magenta(""+Jo.readFileSync(Qo.join(zge,"utility/install/ascii_logo.txt"))))}),await JW()===!1){console.log(iSe);try{await Yge()}catch(l){console.error(oSe,l),ls.error(l),process.exit(1)}}if(!e){let l=YW(Object.keys(Ft.CONFIG_PARAM_MAP),!0);!Xo.isEmpty(l)&&!Xo.isEmptyOrZeroLength(Object.keys(l))&&UC.updateConfigValue(void 0,void 0,l,!0,!0)}let r,n=jd?.service==="clustering";jd?.service&&!n&&(console.error("Unrecognized service argument"),process.exit(1));let s=Qo.join(Se.get(Ft.CONFIG_PARAMS.ROOTPATH),Ft.HDB_PID_FILE),i=_Se(s);i&&i!==1&&pSe(i)&&(n?r=!0:(console.error(`Error: HarperDB is already running (pid: ${i})`),process.exit(4))),Ji===void 0&&(Ji=Cd()),n&&(r||(console.error("HarperDB must be running to start clustering."),process.exit()),Se.get(Ft.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY)||(console.error("Clustering must be setup and enabled in harperdb-config."),process.exit()),console.log("Starting clustering."),await KW.generateNatsConfig(),await Ji.startClusteringProcesses(!0),process.exit()),cSe(),await Jo.writeFile(Qo.join(Se.get(UT.CONFIG_PARAMS.ROOTPATH),UT.HDB_PID_FILE),`${process.pid}`),ls.info("HarperDB PID",process.pid);let o;try{let l=await tSe.getVersionUpdateInfo();l!==void 0&&(o=l[Ft.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION],await jge.upgrade(l),console.log(nSe))}catch(l){o?(console.error(`Got an error while trying to upgrade your HarperDB instance to version ${o}. Exiting HarperDB.`,l),ls.error(l)):(console.error(sSe,l),ls.error(l)),process.exit(1)}Kge(),dSe(),await Zge.reviewSelfSignedCert(),Xo.autoCastBoolean(Se.get(Ft.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&rSe&&await KW.generateNatsConfig(t)}a(zW,"initialize");async function lSe(e=!1){try{jd=Xge(process.argv),jd.ROOTPATH&&UC.updateConfigObject("settings_path",Qo.join(jd.ROOTPATH,Ft.HDB_CONFIG_FILE)),await zW(e,!0),Se.get(Ft.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await Qge();let t=process.env.IS_SCRIPTED_SERVICE&&!jd.service;Xo.autoCastBoolean(Se.get(Ft.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&(t||await Ji.startClusteringProcesses(),await Ji.startClusteringThreads()),await eSe(process.env.DEV_MODE?1:Se.get(UT.CONFIG_PARAMS.THREADS_COUNT)??Se.get(UT.CONFIG_PARAMS.THREADS)),Se.get(Ft.CONFIG_PARAMS.LOGGING_ROTATION_ENABLED)&&await Jge(),t||jW()}catch(t){console.error(t),ls.error(t),process.exit(1)}}a(lSe,"main");function jW(){ls.suppressLogging(()=>{console.log(vC.magenta(`HarperDB ${Wge.version} successfully started`))}),ls.notify(aSe)}a(jW,"started");async function uSe(e=!0){WW=!e;try{Ji===void 0&&(Ji=Cd()),Ji.enterPM2Mode(),await zW(),Xo.autoCastBoolean(Se.get(Ft.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&await Ji.startClusteringProcesses(),await Ji.startService(Ft.PROCESS_DESCRIPTORS.HDB),jW(),e&&process.exit(0)}catch(t){console.error(t),ls.error(t),process.exit(1)}}a(uSe,"launch");function dSe(){let e=Qo.join(Se.get(Ft.CONFIG_PARAMS.ROOTPATH),Ft.LICENSE_KEY_DIR_NAME,Ft.LICENSE_FILE_NAME),t=Qo.join(e,Ft.LICENSE_FILE_NAME),r=Qo.join(e,Ft.REG_KEY_FILE_NAME);try{let{HARPERDB_FINGERPRINT:n,HARPERDB_LICENSE:s}=YW(["HARPERDB_FINGERPRINT","HARPERDB_LICENSE"]);if(Xo.isEmpty(n)||Xo.isEmpty(s))return;Jo.mkdirpSync(e),Jo.writeFileSync(r,n),Jo.writeFileSync(t,s)}catch(n){let s=`Failed to write license & fingerprint due to: ${n.message}`;console.error(s),ls.error(s)}}a(dSe,"writeLicenseFromVars");Object.assign(QW,{launch:uSe,main:lSe,isHdbInstalled:JW,startupLog:fSe});async function JW(){try{await Jo.stat(Xo.getPropsFilePath()),await Jo.stat(Se.get(Ft.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}catch(e){if(Xo.noBootFile())return!0;if(e.code==="ENOENT")return!1;throw ls.error(`Error checking for HDB install - ${e}`),e}return!0}a(JW,"isHdbInstalled");function fSe(e){let r=a(_=>_.padEnd(20),"pad"),n=`
115
- `;Se.get(Ie.REPLICATION_HOSTNAME)&&(n+=`${r("Hostname:")}${Se.get(Ie.REPLICATION_HOSTNAME)}
116
- `),Se.get(Ie.REPLICATION_URL)&&(n+=`${r("Replication Url:")}${Se.get(Ie.REPLICATION_URL)}
117
- `),n+=`${r("Worker Threads:")}${Se.get(Ie.THREADS_COUNT)}
118
- `,n+=`${r("Root Path:")}${Se.get(Ie.ROOTPATH)}
119
- `,Se.get(Ie.THREADS_DEBUG)!==!1&&(n+=`${r("Debugging:")}enabled: true`,n+=Se.get(Ie.THREADS_DEBUG_PORT)?`, TCP: ${Se.get(Ie.THREADS_DEBUG_PORT)}
110
+ Reindexing upgrade started for transaction logs`),Vo.notify("Reindexing upgrade started for transaction logs"),await $Y(lC,!0,e)),Vo.notify("Reindexing upgrade complete"),"Reindexing for 4.0.0 upgrade complete"+(fh?", but errors occurred":"")}a(kme,"reindexUpgrade");async function $Y(e,t,r){let n=await Wi.readdir(e),s=n.length;for(let i=0;i<s;i++){let o=n[i],c=Ko.join(e,o.toString());if(o===".DS_Store")continue;let l=await Wi.readdir(c),u=l.length;for(let f=0;f<u;f++){let d=l[f];if(d!==".DS_Store"&&Wi.statSync(Ko.join(c,d)).isDirectory())try{await Fme(o,d,t),sn.info(`Reindexing started for ${o}.${d}`),Vo.notify(`${t?"Transaction":"Schema"} reindexing started for ${o}.${d}`),await qme(o,d,c,t,r),sn.info(`Reindexing completed for ${o}.${d}`),Vo.notify(`Reindexing completed for ${o}.${d}`)}catch(p){fh=!0,p.schema_path=c,p.table_name=d,Vo.error("There was an error with the reindex upgrade, check the logs in hdb/3_0_0_upgrade_tmp for more details"),Vo.error(p),sn.error(p),console.error(p)}}}if(!fh)try{await Wi.rm(RT,{recursive:!0})}catch{}}a($Y,"processTables");async function Fme(e,t,r){let s=`${e}_${t}_${r?"transaction_reindex":"schema_reindex"}.log`,i=Ko.join(RT,s);await Wi.ensureDir(RT),await Wi.writeFile(i,""),sn=Bme({level:"debug",formatters:{bindings(){}}},i)}a(Fme,"initPinoLogger");var Gme=20;async function qme(e,t,r,n,s){let i;try{i=await os.openEnvironment(r,t,n)}catch(E){if(E.message==="MDB_INVALID: File is not an LMDB file"){Vo.notify(`${e}.${t} file is not from the old environment and has been skipped`),console.info(`${e}.${t} file is not from the old environment and has been skipped`),sn.error(E);return}throw E}let o=Kme(i.dbis),c=os.openDBI(i,o),l=Object.keys(i.dbis),u=os.statDBI(i,o);sn.info(`Old environment stats: ${JSON.stringify(u)}`);let f=new xme.SingleBar({format:`${e}.${t} |{bar}| {percentage}% || {value}/{total} records`,barCompleteChar:"\u2588",barIncompleteChar:"\u2591",hideCursor:!0,clearOnComplete:!1});f.start(u.entryCount,0,{});let d=await os.createEnvironment(r,t,!1);os.createDBI(d,o,!1,!0);let p=[];try{for(let E of c.getRange({start:!1}))E.value={...E.value},p.push(E),n||e==="system"&&(t==="hdb_schema"&&(E.key=E.key.toString(),E.value.name=E.value.name.toString()),t==="hdb_table"&&(E.key=E.key.toString(),E.value.schema=E.value.schema.toString(),E.value.name=E.value.name.toString()),t==="hdb_attribute"&&(E.key=E.key.toString(),E.value.schema=E.value.schema.toString(),E.value.table=E.value.table.toString(),E.value.attribute=E.value.attribute.toString())),p.length>Gme&&await _();await _()}catch(E){throw fh=!0,sn.error(E),E}async function _(){let E,T=p.map(({value:v})=>v);n?E=await Promise.all(T.map(v=>$me(d,v))):E=await Lme(d,o,l.filter(v=>v!=="__blob__"),T,!1);for(let v=0,F=p.length;v<F;v++){let{key:q,value:Y}=p[v];sn.info(`Record hash value: ${q} hash: ${o}`);let Z;n?Z=E[v]:Z=E.written_hashes.indexOf(q)>-1,dh(Z,!0),Vme(d,o,Y[o],n),sn.info(`Insert success, written hashes: ${E.written_hashes}`),f.increment()}p=[],f.value/f.total*100%10===0&&Vo.notify(`${e}.${t} ${f.value}/${f.total} records inserted`),sn.info(`${f.value}/${f.total} records inserted`)}a(_,"finishOutstanding"),f.stop();let h=os.statDBI(i,o),S=os.statDBI(d,o);if(sn.info(`Old stats entry count: ${h.entryCount}. New stats entry count: ${S.entryCount}`),dh.deepStrictEqual(h.entryCount,S.entryCount),await os.closeEnvironment(i),await os.closeEnvironment(d),delete global.lmdb_map[`${e}.${t}`],s){let E=Ko.join(r,t),T=Ko.join(E,"data.mdb"),b=Ko.join(E,"lock.mdb");await Wi.unlink(T),await Wi.unlink(b),await Wi.rmdir(E),sn.info(`Deleted old environment files from schema folder: ${T}, ${b}`)}let g=await os.openEnvironment(r,t),R=os.statDBI(g,o);sn.info(`New stats: ${JSON.stringify(S)}. New stats after move: ${JSON.stringify(R)}`),dh.deepStrictEqual(R.entryCount,S.entryCount),await os.closeEnvironment(g),delete global.lmdb_map[`${e}.${t}`]}a(qme,"processTable");async function $me(e,t){os.initializeDBIs(e,rc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,rc.TRANSACTIONS_DBIS);let r=t.timestamp;return e.dbis[rc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(r,()=>{e.dbis[rc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(r,t),Ume.isEmpty(t.user_name)||e.dbis[rc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(t.user_name,r);for(let n of t.hash_values)e.dbis[rc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(n,r)})}a($me,"insertTransaction");function Vme(e,t,r,n){let i=e.dbis[t].get(r);dh.deepStrictEqual(typeof i,"object");let o;if(n){let c={[rc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME]:i.user_name,[rc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE]:i.hash_values};o=Object.entries(c)}else o=Object.entries(i);for(let[c,l]of o)if(c!==t&&e.dbis[c]!==void 0&&!vme.isEmptyOrZeroLength(l))if(n&&c==="hash_value")for(let u=0,f=l.length;u<f;u++){let d=l[u];VY(e,c,d,r)}else VY(e,c,l,r)}a(Vme,"validateIndices");function VY(e,t,r,n){try{let s=!1,i=Mme.getIndexedValues(r);if(!i)return;for(let o of i)s=e.dbis[t].doesExist(o,n),s||sn.info(`Validate indices did not find value in new DBI: ${o}. Hash: ${n}`),dh.deepStrictEqual(s,!0)}catch(s){fh=!0,sn.error(s),console.error(s)}}a(VY,"validateIndex");function Kme(e){let t;for(let[r,n]of Object.entries(e))if(n.__dbi_defintion__.is_hash_attribute===!0){t=r;break}return t}a(Kme,"getHashDBI")});var QY=w((mUe,JY)=>{"use strict";var yT=require("path"),nc=require("fs-extra"),Yme=aC(),$l=z(),WY=yt(),uC=ae(),Ei=(H(),C(G)),bT=ie(),Wme=require("properties-reader"),zme=ni(),jme=ng(),Jme=Yr(),hUe=require("util"),Qme=Jme.searchByValue,Xme=yn(),Zme=dS(),eEe=Tt(),tEe=YY(),zY=Zn(),rEe=ST(),hh=new Yme("4.0.0"),jY=[],_h,ph;async function nEe(){try{if(await rEe.upgradeCertsPrompt()){if(console.log("Generating new certificates."),_h){let t=bT.changeExtension(_h,".bak");await nc.move(_h,t)}if(ph){let t=bT.changeExtension(ph,".bak");await nc.move(ph,t)}await zY.generateKeys()}else console.log("Using existing certificates."),zY.updateConfigCert(_h,ph,void 0)}catch(e){throw console.error("There was a problem generating new keys. Please check the log for details."),e}}a(nEe,"generateNewKeys");async function sEe(){console.log("Updating HarperDB nodes."),$l.info("Updating HarperDB nodes.");let e=[];try{let t=new zme(Ei.SYSTEM_SCHEMA_NAME,Ei.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*","name",["*"]),r=Array.from(await Qme(t)),n=[];for(let i=0,o=r.length;i<o;i++){let c=r[i];if(!eEe.NATS_TERM_CONSTRAINTS_RX.test(c.name)){let f=`Node name '${c.name}' is invalid, must not contain ., * or >. Please change name and try again.`;throw console.error(f),f}let l={host:c.host,port:c.port};e.push(l);let u=[];for(let f=0,d=c.subscriptions.length;f<d;f++){let p=c.subscriptions[f],_=p.channel.split(":");u.push({schema:_[0],table:_[1],publish:p.publish,subscribe:p.subscribe})}n.push({name:c.name,subscriptions:u,system_info:{hdb_version:Ei.PRE_4_0_0_VERSION,node_version:void 0,platform:void 0}})}if(bT.isEmptyOrZeroLength(n))return;let s=new jme(Ei.SYSTEM_SCHEMA_NAME,Ei.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,n);await Xme.update(s)}catch(t){throw console.error("There was a problem updating the hdb_nodes table. Please check the log for details."),t}try{Zme.setRoutes({server:"hub",routes:e})}catch(t){throw console.error("There was a problem setting the clustering routes. Please check the log for details."),t}}a(sEe,"updateNodes");async function iEe(){let e=uC.get(Ei.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);if(!e.includes(yT.join("config","settings.js"))){$l.info("pre 4.0.0 settings.js file not found, skipping settings file update");return}let t="Updating settings file for version 4.0.0";console.log(t),$l.info(t);let r=yT.dirname(e),n=uC.get(Ei.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),s=yT.join(n,"backup","4_0_0_upgrade_settings.bak"),i=yT.join(n,Ei.HDB_CONFIG_FILE);try{$l.info(`Backing up old settings file to: ${s}`),console.log(`Backing up old settings file to: ${s}`),nc.copySync(e,s)}catch(d){throw console.error("There was a problem writing the backup for the old settings file. Please check the log for details."),d}try{$l.info(`Creating new/upgraded settings file at '${i}'`),console.log(`Creating new/upgraded settings file at '${i}'`),$l.info("Updating env variables with new settings values");let d=WY.initOldConfig(e);_h=d[Ei.CONFIG_PARAMS.TLS_CERTIFICATE.toLowerCase()],ph=d[Ei.CONFIG_PARAMS.TLS_PRIVATEKEY.toLowerCase()],WY.createConfigFile(d)}catch(d){throw console.log("There was a problem creating the new HarperDB config file. Please check the log for details."),d}let o=bT.getPropsFilePath();nc.accessSync(o,nc.constants.F_OK|nc.constants.R_OK);let l=Wme(o).get(Ei.HDB_SETTINGS_NAMES.INSTALL_USER),u=`settings_path = ${i}
111
+ install_user = ${l}`;try{nc.writeFileSync(o,u)}catch(d){throw console.log("There was a problem updating the HarperDB boot properties file. Please check the log for details."),d}try{uC.initSync(!0)}catch(d){throw console.error("Unable to initialize new properties. Please check the log for details."),d}let f="New settings file for 4.0.0 upgrade successfully created.";try{nc.removeSync(r),console.log(f),$l.info(f)}catch(d){throw console.error("There was a problem deleting the old settings file and directory. Please check the log for details."),d}}a(iEe,"updateSettingsFile_4_0_0");hh.async_functions.push(iEe);hh.async_functions.push(nEe);hh.async_functions.push(tEe);hh.async_functions.push(sEe);jY.push(hh);JY.exports=jY});var dC=w((gUe,tW)=>{"use strict";var Vl=ie(),oEe=(H(),C(G)),XY=z(),{DATA_VERSION:aEe,UPGRADE_VERSION:cEe}=oEe.UPGRADE_JSON_FIELD_NAMES_ENUM,ZY=GY(),OT=QY(),Kl=new Map;ZY&&ZY.forEach(e=>{Kl.set(e.version,e)});OT&&OT.forEach(e=>{Kl.set(e.version,e)});OT&&OT.forEach(e=>{Kl.set(e.version,e)});function lEe(){return[...Kl.keys()].sort(Vl.compareVersions)}a(lEe,"getSortedVersions");function eW(e){let t=e[aEe],r=e[cEe];return Vl.isEmptyOrZeroLength(t)||Vl.isEmptyOrZeroLength(r)?(XY.info(`There is an issue with the version data in your instance of HDB. Current version data: ${e}`),XY.error("There was an error when trying to evaluate the version information for your instance. Trying to start the server anyways but it may fail. If you continue to have this problem, please contact support@harperdb.io."),[]):[...Kl.keys()].sort(Vl.compareVersions).filter(function(n){return Vl.compareVersions(n,t)>0&&Vl.compareVersions(n,r)<=0})}a(eW,"getVersionsForUpgrade");function uEe(e){return eW(e).length>0}a(uEe,"hasUpgradesRequired");function dEe(e){return Vl.isEmptyOrZeroLength(e)?null:Kl.has(e)?Kl.get(e):null}a(dEe,"getDirectiveByVersion");tW.exports={getSortedVersions:lEe,getDirectiveByVersion:dEe,getVersionsForUpgrade:eW,hasUpgradesRequired:uEe}});var mh=w((TUe,oW)=>{"use strict";var fEe=require("util"),fC=require("chalk"),_Ee=require("os"),nW=yn(),pEe=Yr(),as=(H(),C(G)),sW=CY(),pC=Uy(),{UpgradeObject:rW}=LY(),{forceDowngradePrompt:hEe}=ST(),{packageJson:mEe}=it(),NT=z(),Wd=ie(),hC=As(),EEe=(De(),C(nt)),gEe=dC(),SEe=fEe.promisify(hC.setSchemaDataToGlobal),TEe=pEe.searchByValue,AEe="info_id",REe="2.9.9",yEe="3.0.0";async function bEe(e){let t=new sW.HdbInfoInsertObject(1,e,e),r=new pC.InsertObject(as.OPERATIONS_ENUM.INSERT,as.SYSTEM_SCHEMA_NAME,as.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,as.INFO_TABLE_HASH_ATTRIBUTE,[t]);return hC.setSchemaDataToGlobal(),nW.insert(r)}a(bEe,"insertHdbInstallInfo");async function _C(e){let t,r=await iW(),n=new Map([[0,{}]]);for(let c of r)n.set(c.info_id,c);let i=Math.max.apply(null,[...n.keys()])+1;t=new sW.HdbInfoInsertObject(i,e,e);let o=new pC.InsertObject(as.OPERATIONS_ENUM.INSERT,as.SYSTEM_SCHEMA_NAME,as.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,as.INFO_TABLE_HASH_ATTRIBUTE,[t]);return await SEe(),nW.insert(o)}a(_C,"insertHdbUpgradeInfo");async function iW(){let e=new pC.NoSQLSeachObject(as.SYSTEM_SCHEMA_NAME,as.SYSTEM_TABLE_NAMES.INFO_TABLE_NAME,AEe,as.INFO_TABLE_HASH_ATTRIBUTE,["*"],"*"),t=[];try{t=Array.from(await TEe(e))}catch(r){console.error(r)}return t}a(iW,"getAllHdbInfoRecords");async function OEe(){let e=await iW();if(e.length===0)return;let t,r=new Map;for(let s of e)r.set(s.info_id,s);let n=Math.max.apply(null,[...r.keys()]);return t=r.get(n),t}a(OEe,"getLatestHdbInfoRecord");async function NEe(){NT.info("Checking if HDB software has been updated");try{let e=mEe.version;if(!e)throw new Error("Could not find the version number in the package.json file");let t=await OEe(),r;if(Wd.isEmpty(t))r=REe;else if(r=t.data_version_num,Wd.compareVersions(r.toString(),e.toString())>0){if(!Wd.isCompatibleDataVersion(r.toString(),e.toString()))throw console.log(fC.yellow(`This instance's data was last run on version ${r}`)),console.error(fC.red(`You have installed a version lower than the version that your data was created on or was upgraded to. This may cause issues and is currently not supported.${_Ee.EOL}${as.SUPPORT_HELP_MSG}`)),new Error("Trying to downgrade major HDB versions is not supported.");Wd.isCompatibleDataVersion(r.toString(),e.toString(),!0)||(console.log(fC.yellow(`This instance's data was last run on version ${r}`)),await hEe(new rW(r,e))?await _C(e.toString()):(console.log("Cancelled downgrade, closing HarperDB"),process.exit(0)))}if(hC.setSchemaDataToGlobal(),wEe(r),e.toString()===r.toString())return;let n=new rW(r,e);if(gEe.hasUpgradesRequired(n))return n;Wd.compareVersions(n.data_version.toString(),n.upgrade_version.toString())<0&&(await _C(n.upgrade_version),NT.notify(`HarperDB running on upgraded version: ${n.upgrade_version}`))}catch(e){throw NT.fatal("Error while trying to evaluate the state of hdb data and the installed hdb version"),NT.fatal(e),e}}a(NEe,"getVersionUpdateInfo");function wEe(e){let t=`You are attempting to upgrade from an old instance of HarperDB that is no longer supported. In order to upgrade to this version, you must do a fresh install. If you need support, please contact ${as.HDB_SUPPORT_ADDRESS}`;if(!("hdb_info"in EEe.databases.system))throw console.log(t),new Error(t);if(!Wd.isEmpty(e)&&e<yEe)throw console.log(t),new Error(t)}a(wEe,"checkIfInstallIsSupported");oW.exports={insertHdbInstallInfo:bEe,insertHdbUpgradeInfo:_C,getVersionUpdateInfo:NEe}});var uW=w((RUe,lW)=>{"use strict";var wT=require("joi"),{boolean:IEe,string:mC,number:CEe}=wT.types(),aW=require("fs-extra"),Eh=(H(),C(G)),cW=require("path"),PEe=ot();lW.exports=DEe;function DEe(e){let t=mC.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),r=wT.object({[Eh.INSTALL_PROMPTS.ROOTPATH]:wT.custom(LEe),[Eh.INSTALL_PROMPTS.OPERATIONSAPI_NETWORK_PORT]:wT.alternatives([CEe.min(0),mC]).allow("null",null),[Eh.INSTALL_PROMPTS.TC_AGREEMENT]:mC.valid("yes","YES","Yes"),[Eh.INSTALL_PROMPTS.CLUSTERING_NODENAME]:t,[Eh.INSTALL_PROMPTS.CLUSTERING_ENABLED]:IEe});return PEe.validateBySchema(e,r)}a(DEe,"installValidator");function LEe(e,t){if(aW.existsSync(cW.join(e,"system/hdb_user/data.mdb"))||aW.existsSync(cW.join(e,"system/hdb_user.mdb")))return t.message(`'${e}' is already in use. Please enter a different path.`)}a(LEe,"validateRootAvailable")});var SC=w((bUe,dW)=>{"use strict";var{mkdirpSync:MEe,copySync:vEe}=require("fs-extra"),sc=require("path"),gh=(H(),C(G)),{PACKAGE_ROOT:UEe}=it(),gC=z(),xEe=Vn(),EC=po(),BEe=gt();dW.exports=HEe;async function HEe(e){gC.trace("Mounting HarperDB"),Yl(e),Yl(sc.join(e,"backup")),Yl(sc.join(e,"keys")),Yl(sc.join(e,"keys",gh.LICENSE_FILE_NAME)),Yl(sc.join(e,"log")),Yl(sc.join(e,"database")),Yl(sc.join(e,"components")),vEe(sc.resolve(UEe,"./utility/install/README.md"),sc.join(e,"README.md")),await kEe()}a(HEe,"mountHdb");async function kEe(){let e=v_(),t=Object.keys(EC);for(let r=0;r<t.length;r++){let n=t[r],s=EC[n].hash_attribute;try{BEe.initSystemSchemaPaths(gh.SYSTEM_SCHEMA_NAME,n);let i=new e(gh.SYSTEM_SCHEMA_NAME,n,s);i.attributes=EC[n].attributes;let o=i.attributes.find(({attribute:c})=>c===s);o.isPrimaryKey=!0,["hdb_user","hdb_role"].includes(n)&&(i.audit=!0),await xEe.createTable(n,i)}catch(i){throw gC.error(`issue creating environment for ${gh.SYSTEM_SCHEMA_NAME}.${n}: ${i}`),i}}}a(kEe,"createLMDBTables");function Yl(e){MEe(e,{mode:gh.HDB_FILE_PERMISSIONS}),gC.info(`Directory ${e} created`)}a(Yl,"makeDirectory")});var PT=w((IUe,bW)=>{"use strict";var AC=require("os"),mW=require("inquirer"),xs=require("fs-extra"),FEe=require("properties-reader"),zl=require("chalk"),ji=require("path"),GEe=require("human-readable-ids").hri,qEe=require("ora"),$Ee=require("yaml"),pr=z(),ic=ae(),Sh=ie(),CT=ua(),EW=mh(),{packageJson:gW}=it(),de=(H(),C(G)),{CONFIG_PARAM_MAP:NUe,CONFIG_PARAMS:Dt}=de,VEe=uW(),KEe=SC(),RC=yt(),YEe=Rn(),WEe=F_(),zEe=tC(),jEe=As(),JEe=require("util").promisify,QEe=JEe(jEe.setSchemaDataToGlobal),fW=Zn(),Wl=a(e=>e,"PROMPT_ANSWER_TRANSFORMER"),kr=a(e=>zl.magenta.bold(e),"HDB_PROMPT_MSG"),XEe="https://harperdb.io/legal/end-user-license-agreement",oc=AC.EOL,Yo="",ZEe="yes",_W="Starting HarperDB install...",pW="HarperDB installation was successful.",hW="Terms & Conditions acceptance is required to proceed with installation. Exiting install...",ege="An out of date version of HarperDB is already installed.",TC="It appears that HarperDB is already installed. Exiting install...",tge="Aborting install",wUe=new RegExp(/^([0-9]{1,4}|[1-5][0-9]{4}|6[0-4][0-9]{3}|65[0-4][0-9]{2}|655[0-2][0-9]|6553[0-5])$/),rge=new RegExp(/^[^\s.,*>]+$/),nge=AC.homedir(),sge=ji.join(nge,de.HDB_ROOT_DIR_NAME),ige="HDB_ADMIN",oge="CLUSTER_USER",age="dev",cge="localhost",IT={[Dt.HTTP_CORS]:!0,[Dt.HTTP_CORSACCESSLIST]:["*"],[Dt.HTTP_PORT]:9926,[Dt.AUTHENTICATION_AUTHORIZELOCAL]:!0,[Dt.THREADS_COUNT]:1,[Dt.THREADS_DEBUG]:!0,[Dt.LOGGING_STDSTREAMS]:!0,[Dt.LOGGING_LEVEL]:"info",[Dt.OPERATIONSAPI_NETWORK_PORT]:9925,[Dt.LOCALSTUDIO_ENABLED]:!0},Hr={DESTINATION:"Please enter a destination for HarperDB:",HDB_USERNAME:"Please enter a username for the administrative user:",HDB_PASS:"Please enter a password for the administrative user:",NODE_NAME:"Please enter a unique name for this node:",CLUSTER_USERNAME:"Please enter a username for the CLUSTER_USER:",CLUSTER_PASS:"Please enter a password for the CLUSTER_USER:",DEFAULTS_MODE:"Default Config - dev (easy access/debugging) or prod (security/performance): (dev/prod)",REPLICATION_HOSTNAME:"Please enter the hostname for this server:"},ac=CT([de.INSTALL_PROMPTS.HDB_CONFIG]),zi,SW=!1,yC=!1,TW=!1;bW.exports={install:AW,updateConfigEnv:Sge,setIgnoreExisting:Tge};AW.createSuperUser=yW;async function AW(){console.log(kr(oc+_W+oc)),pr.notify(_W);let e;ac[de.INSTALL_PROMPTS.HDB_CONFIG]&&(e=lge());let t=dge();Object.assign(t,e),t[de.INSTALL_PROMPTS.TC_AGREEMENT]&&t[de.INSTALL_PROMPTS.ROOTPATH]&&t[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME]&&t[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]&&t[de.INSTALL_PROMPTS.DEFAULTS_MODE]===void 0&&(TW=!0,t[de.INSTALL_PROMPTS.DEFAULTS_MODE]="prod");let r=VEe(t);if(r)throw r.message;await fge(),await _ge(t);let n=await uge(t);zi=n[de.INSTALL_PROMPTS.ROOTPATH],ac[de.INSTALL_PROMPTS.HDB_CONFIG]&&ji.dirname(ac[de.INSTALL_PROMPTS.HDB_CONFIG])===zi&&(SW=!0),!yC&&!ac[de.INSTALL_PROMPTS.HDB_CONFIG]&&await xs.pathExists(ji.join(zi,de.HDB_CONFIG_FILE))&&(console.error(TC),process.exit());let s=qEe({prefixText:kr("Installing"),color:"magenta",spinner:"simpleDots"});if(s.start(),Sh.isEmpty(zi))throw new Error("Installer should have the HDB root param at the stage it is in but it does not.");ic.setHdbBasePath(zi),await KEe(zi),await pge(),await hge(n),pr.initLogSettings(!0),await yW(n),await Ege(n),await fW.updateConfigCert(),await fW.generateCertsKeys(),await gge(),zEe(),s.stop(),console.log(kr(oc+pW+oc)),pr.notify(pW)}a(AW,"install");function lge(){let e=$Ee.parseDocument(xs.readFileSync(ac[de.INSTALL_PROMPTS.HDB_CONFIG],"utf8"),{simpleKeys:!0}),t=RC.flattenConfig(e.toJSON());return t[de.CONFIG_PARAMS.ROOTPATH.toLowerCase()]&&(t.ROOTPATH=t[de.CONFIG_PARAMS.ROOTPATH.toLowerCase()]),t}a(lge,"getConfigFromFile");async function uge(e){pr.trace("Getting install prompts and params.");let t,r=[{type:"input",transformer:Wl,when:Wo(e[de.INSTALL_PROMPTS.ROOTPATH],Hr.DESTINATION),name:de.INSTALL_PROMPTS.ROOTPATH,prefix:Yo,default:sge,validate:a(async s=>Us(s)?Us(s):await xs.pathExists(ji.join(s,"system","hdb_user.mdb"))?`'${s}' is already in use. Please enter a different path.`:!0,"validate"),message:kr(Hr.DESTINATION)},{type:"input",transformer:Wl,when:Wo(e[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],Hr.HDB_USERNAME),name:de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME,prefix:Yo,default:ige,validate:a(s=>Us(s)?Us(s):(t=s,!0),"validate"),message:kr(Hr.HDB_USERNAME)},{type:"password",when:Wo(e[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD],Hr.HDB_PASS),name:de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD,prefix:Yo,validate:a(s=>Us(s)?Us(s):!0,"validate"),message:kr(Hr.HDB_PASS)},{type:"input",transformer:Wl,when:Wo(e[de.INSTALL_PROMPTS.DEFAULTS_MODE],Hr.DEFAULTS_MODE),name:de.INSTALL_PROMPTS.DEFAULTS_MODE,prefix:Yo,default:age,validate:a(s=>Us(s)?Us(s):s!=="dev"&&s!=="prod"?`Invalid response '${s}', options are 'dev' or 'prod'.`:!0,"validate"),message:kr(Hr.DEFAULTS_MODE)}];if(TW||r.push({type:"input",name:de.INSTALL_PROMPTS.REPLICATION_HOSTNAME,transformer:Wl,when:Wo(e[de.INSTALL_PROMPTS.REPLICATION_HOSTNAME],Hr.REPLICATION_HOSTNAME),prefix:Yo,default:cge,message:kr(Hr.REPLICATION_HOSTNAME)}),Sh.autoCastBoolean(e[de.INSTALL_PROMPTS.CLUSTERING_ENABLED])===!0){let s=[{type:"input",transformer:Wl,when:Wo(e[de.INSTALL_PROMPTS.CLUSTERING_NODENAME],Hr.NODE_NAME),name:de.INSTALL_PROMPTS.CLUSTERING_NODENAME,prefix:Yo,default:GEe.random(),validate:a(i=>rge.test(i)?!0:"Invalid node name, must not contain ., * or >","validate"),message:kr(Hr.NODE_NAME)},{type:"input",transformer:Wl,when:Wo(e[de.INSTALL_PROMPTS.CLUSTERING_USER],Hr.CLUSTER_USERNAME),name:de.INSTALL_PROMPTS.CLUSTERING_USER,prefix:Yo,default:oge,validate:a(i=>Us(i)?Us(i):i.toLowerCase()===t.toLowerCase()?"Username is already in use.":!0,"validate"),message:kr(Hr.CLUSTER_USERNAME)},{type:"password",when:Wo(e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD],Hr.CLUSTER_PASS),name:de.INSTALL_PROMPTS.CLUSTERING_PASSWORD,prefix:Yo,validate:a(i=>Us(i)?Us(i):!0,"validate"),message:kr(Hr.CLUSTER_PASS)}];r.push(...s)}let n=await mW.prompt(r);if(Object.keys(n).length===0)return e;for(let s in n)e[s]===void 0&&(e[s]=n[s]);return e}a(uge,"installPrompts");function Wo(e,t){return e!==void 0?(t.includes("password")?(console.log(`${kr(t)} ${zl.gray("[hidden]")}`),pr.trace(`${kr(t)} [hidden]`)):(console.log(`${kr(t)} ${e}`),pr.trace(`${kr(t)} ${e}`)),!1):!0}a(Wo,"displayCmdEnvVar");function Us(e){let t=e.replace(/ /g,"");if(t===""||t==="''"||t==='""')return"Value cannot be empty."}a(Us,"checkForEmptyValue");function dge(){let e=Object.keys(de.INSTALL_PROMPTS),t=CT(e),r=CT(Object.keys(de.CONFIG_PARAM_MAP),!0),n={};for(let s of e){let i=de.CONFIG_PARAM_MAP[s.toLowerCase()];t[s]?i===void 0?n[s]=t[s]:n[i.toUpperCase()]=t[s]:i!==void 0&&r[i.toLowerCase()]&&(n[s]=r[i.toLowerCase()])}return n}a(dge,"checkForPromptOverride");async function fge(){pr.trace("Checking for existing install.");let e=Sh.getPropsFilePath(),t=await xs.pathExists(e),r;if(t){pr.trace(`Install found an existing boot prop file at:${e}`);let n=FEe(e),s=RC.getConfigValue(de.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)||n.get(de.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY);r=await xs.pathExists(s)}if(!t&&Sh.noBootFile()&&(r=!0),r&&!yC){if(pr.trace(`Install found existing HDB config at:${e}`),await EW.getVersionUpdateInfo()){let s=`Please use \`harperdb upgrade\` to update to ${gW.version}. Exiting install...`;console.log(oc+zl.magenta.bold(ege)),console.log(zl.magenta.bold(s)),pr.error(s)}else console.log(oc+zl.magenta.bold(TC)),pr.error(TC);process.exit(0)}}a(fge,"checkForExistingInstall");async function _ge(e){pr.info("Asking for terms agreement.");let t=`Terms & Conditions can be found at ${XEe}${oc}and can be viewed by typing or copying and pasting the URL into your web browser.${oc}I agree to the HarperDB Terms and Conditions: (yes/no)`,r={prefix:Yo,transformer:Wl,when:Wo(e[de.INSTALL_PROMPTS.TC_AGREEMENT],t),name:de.INSTALL_PROMPTS.TC_AGREEMENT,message:kr(t),validate:a(s=>s.toLowerCase()==="yes"||s.toLowerCase()==="no"?!0:zl.yellow("Please enter 'yes' or 'no'"),"validate")},n=await mW.prompt([r]);n[de.INSTALL_PROMPTS.TC_AGREEMENT]&&n[de.INSTALL_PROMPTS.TC_AGREEMENT].toLowerCase()!==ZEe&&(console.log(zl.yellow(hW)),pr.error(hW),process.exit(0))}a(_ge,"termsAgreement");async function pge(){let e=ji.join(zi,de.HDB_CONFIG_FILE),t;try{t=AC.userInfo().username}catch{t=process.env.USERNAME||process.env.USER||process.env.LOGNAME||process.env.LNAME||process.env.SUDO_USER}if(t){let r=`settings_path = ${e}
112
+ install_user = ${t}`,n=Sh.getHomeDir(),s=ji.join(n,de.HDB_HOME_DIR_NAME),i=ji.join(s,de.LICENSE_KEY_DIR_NAME);try{xs.mkdirpSync(s,{mode:de.HDB_FILE_PERMISSIONS}),xs.mkdirpSync(i,{mode:de.HDB_FILE_PERMISSIONS})}catch{console.error(`Could not make settings directory ${de.HDB_HOME_DIR_NAME} in home directory. Please check your permissions and try again.`)}let o=ji.join(s,de.BOOT_PROPS_FILE_NAME);try{await xs.writeFile(o,r)}catch(c){throw pr.error(`There was an error creating the boot file at path: ${o}`),c}ic.setProperty(de.HDB_SETTINGS_NAMES.INSTALL_USER,`${t}`),ic.setProperty(de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,e),ic.setProperty(ic.BOOT_PROPS_FILE_PATH,o)}}a(pge,"createBootPropertiesFile");async function hge(e){pr.trace("Creating HarperDB config file");let t=CT(Object.keys(de.CONFIG_PARAM_MAP),!0);if(Object.assign(t,e),e[de.INSTALL_PROMPTS.DEFAULTS_MODE]==="dev"){process.env.DEV_MODE="true";for(let r in IT){if(r===Dt.HTTP_PORT&&t[Dt.HTTP_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??IT[r],t[Dt.HTTP_SECUREPORT]=null;continue}else if(r===Dt.HTTP_PORT)continue;if(r===Dt.OPERATIONSAPI_NETWORK_PORT&&t[Dt.OPERATIONSAPI_NETWORK_SECUREPORT.toLowerCase()]===void 0){t[r]=t[r.toLowerCase()]??IT[r],t[Dt.OPERATIONSAPI_NETWORK_SECUREPORT]=null;continue}else if(r===Dt.OPERATIONSAPI_NETWORK_PORT)continue;t[r.toLowerCase()]===void 0&&(t[r]=IT[r])}}else t[Dt.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]&&(t[Dt.OPERATIONSAPI_NETWORK_SECUREPORT]=null),t[Dt.HTTP_PORT.toLowerCase()]&&(t[Dt.HTTP_SECUREPORT]=null);try{ac[de.INSTALL_PROMPTS.HDB_CONFIG]||RC.createConfigFile(t),ic.initSync()}catch(r){mge(r)}}a(hge,"createConfigFile");function mge(e){pr.error(`Error creating HarperDB config file. Rolling back install - ${e}`),console.error(e),console.error(tge);let t=ji.resolve(ic.get(ic.BOOT_PROPS_FILE_PATH),"../");t&&xs.removeSync(t),zi&&(SW?xs.readdirSync(zi,{withFileTypes:!0}).forEach(n=>{let s=ji.join(n.path,n.name);s!==ac[de.INSTALL_PROMPTS.HDB_CONFIG]&&xs.removeSync(s)}):xs.removeSync(zi)),process.exit(1)}a(mge,"rollbackInstall");async function RW(e,t){pr.trace("Creating admin user"),await QEe();let r;try{r=await WEe.addRole(e)}catch(n){if(n.message.includes("already exists"))t=void 0;else throw n.message+="Error creating role",n}if(t)try{t.role=r.role,await YEe.addUser(t)}catch(n){throw n.message=`Error creating user - ${n}`,n}}a(RW,"createAdminUser");async function yW(e){pr.trace("Creating Super user.");let t={role:"super_user",permission:{super_user:!0}},r={username:e[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME].toString(),password:e[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD].toString(),active:!0};await RW(t,r),delete e[de.INSTALL_PROMPTS.HDB_ADMIN_USERNAME],delete e[de.INSTALL_PROMPTS.HDB_ADMIN_PASSWORD]}a(yW,"createSuperUser");async function Ege(e){pr.trace("Creating Cluster user.");let t;e[de.INSTALL_PROMPTS.CLUSTERING_USER]&&e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD]&&(t={username:e[de.INSTALL_PROMPTS.CLUSTERING_USER].toString(),password:e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD].toString(),active:!0}),await RW({role:"cluster_user",permission:{cluster_user:!0}},t),delete e[de.INSTALL_PROMPTS.CLUSTERING_USER],delete e[de.INSTALL_PROMPTS.CLUSTERING_PASSWORD]}a(Ege,"createClusterUser");async function gge(){let e=gW.version;if(e)await EW.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(gge,"insertHdbVersionInfo");function Sge(e){ac[de.INSTALL_PROMPTS.HDB_CONFIG]=e}a(Sge,"updateConfigEnv");function Tge(e){yC=e}a(Tge,"setIgnoreExisting")});var wW=w((PUe,NW)=>{"use strict";var bC=ie(),cs=z(),OW=dC();NW.exports={processDirectives:Age};async function Age(e){console.log("Starting upgrade process...");let t=OW.getVersionsForUpgrade(e),r=bge(t),n=[],s=r.length;for(let i=0;i<s;i++){let o=r[i],c=`Running upgrade for version ${o.version}`;cs.notify(c),console.log(c);let l=[],u=[];try{l=Rge(o.sync_functions)}catch(f){throw cs.error(`Error while running an upgrade script for ${o.version}`),f}try{u=await yge(o.async_functions)}catch(f){throw cs.error(`Error while running an upgrade script for ${o.version}`),f}n.push(...l,...u)}return n}a(Age,"processDirectives");function Rge(e){if(bC.isEmptyOrZeroLength(e))return cs.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return cs.info("Passed parameter is not an array"),[];let t=[];for(let r of e){if(cs.info(`Running function ${r.name}`),!(r instanceof Function)){cs.info("Variable being processed is not a function");continue}let n=r();cs.info(n),t.push(n)}return t}a(Rge,"runSyncFunctions");async function yge(e){if(bC.isEmptyOrZeroLength(e))return cs.info("No functions found to run for upgrade"),[];if(!Array.isArray(e))return cs.info("Passed parameter is not an array"),[];let t=[],r=e.length;for(let n=0;n<r;n++){let s=e[n];if(cs.info(`Running function ${s.name}`),!(s instanceof Function)){cs.info("Variable being processed is not a function");continue}let i=await s();cs.info(i),t.push(i)}return t}a(yge,"runAsyncFunctions");function bge(e){if(bC.isEmptyOrZeroLength(e))return[];let t=[];for(let r of e){let n=OW.getDirectiveByVersion(r);n&&t.push(n)}return t}a(bge,"getUpgradeDirectivesToInstall")});var IC=w((LUe,MW)=>{"use strict";var DT=ae();DT.initSync();var DW=require("chalk"),IW=require("fs-extra"),jo=z(),zo=(H(),C(G)),Oge=wW(),OC=ie(),LW=mh(),Nge=ST(),CW=iR(),wge=As(),{packageJson:PW}=it(),Ige=require("util").promisify,Cge=Ige(wge.setSchemaDataToGlobal),NC,{UPGRADE_VERSION:wC}=zo.UPGRADE_JSON_FIELD_NAMES_ENUM;MW.exports={upgrade:Pge};async function Pge(e){await Cge(),NC===void 0&&(NC=Pd()),IW.existsSync(DT.get(DT.BOOT_PROPS_FILE_PATH))||(Th("The hdb_boot_properties file was not found. Please install HDB.",zo.LOG_LEVELS.ERROR),process.exit(1)),IW.existsSync(DT.get(zo.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))||(Th("The hdb settings file was not found. Please make sure HDB is installed.",zo.LOG_LEVELS.ERROR),process.exit(1));let t=e;t||(t=await LW.getVersionUpdateInfo(),t||(console.log("HarperDB version is current"),process.exit(0))),Th(`This version of HarperDB is ${PW.version}`,zo.LOG_LEVELS.INFO);let r=t[wC]??PW.version;r||(console.log(`Current Version field missing from the package.json file. Cannot continue with upgrade. If you need support, please contact ${zo.HDB_SUPPORT_ADDRESS}`),jo.notify("Missing new version field from upgrade info object"),process.exit(1)),await Dge();let n,s=0;try{n=await Nge.forceUpdatePrompt(t)}catch(i){jo.error("There was an error when prompting user about upgrade."),jo.error(i),n=!1,s=1}n||(console.log("Cancelled upgrade, closing HarperDB"),process.exit(s)),jo.info(`Starting upgrade to version ${r}`),await Lge(t),Th(`HarperDB was successfully upgraded to version ${t[wC]}`,zo.LOG_LEVELS.INFO)}a(Pge,"upgrade");async function Dge(){let e=!1,t=await CW.findPs(zo.HDB_PROC_NAME);if(OC.isEmptyOrZeroLength(t)||(e=!0),!e){let r=await CW.findPs("hdb_express");OC.isEmptyOrZeroLength(r)||(e=!0)}if(!e){let r=await NC.list();OC.isEmptyOrZeroLength(r)||(e=!0)}if(e){let r="HarperDB is running, please stop all HarperDB services with 'harperdb stop' and run the upgrade command again.";console.log(DW.red(r)),jo.error(r),process.exit(1)}}a(Dge,"checkIfRunning");async function Lge(e){try{await Oge.processDirectives(e)}catch(t){throw Th("There was an error during the data upgrade. Please check the logs.",zo.LOG_LEVELS.ERROR),t}try{await LW.insertHdbUpgradeInfo(e[wC])}catch(t){jo.error("Error updating the 'hdb_info' system table."),jo.error(t)}}a(Lge,"runUpgrade");function Th(e,t=void 0){t||(t=jo.info),jo[t](e),console.log(DW.magenta(e))}a(Th,"printToLogAndConsole")});var HW={};ve(HW,{onStorageReclamation:()=>Ah,runReclamationHandlers:()=>LC,setAvailableSpaceRatioGetter:()=>vge});function Ah(e,t,r){(r||(0,MT.getWorkerIndex)()===(0,MT.getWorkerCount)()-1)&&(LT.has(e)||LT.set(e,[]),LT.get(e).push({priority:0,handler:t}),DC||(DC=setTimeout(LC,UW).unref()))}async function LC(){for(let[e,t]of LT)try{let r=await BW(e),n=Mge/r;for(let s of t){let{priority:i,handler:o}=s;if(s.priority=n,n>1||i>1){let c=o(n>1?n:0);c&&(PC.default.info?.(`Running storage reclamation handler for ${e} with priority ${n}`),await c)}}}catch(r){PC.default.error?.("Error running storage reclamation handlers",r)}DC=setTimeout(LC,UW).unref()}function vge(e){BW=e??xW}var CC,MT,PC,vT,vW,LT,Mge,UW,DC,xW,BW,UT=be(()=>{CC=require("node:fs/promises"),MT=M(rt()),PC=M(Ni());H();vT=M(ae()),vW=M(ie());vT.default.initSync();LT=new Map,Mge=vT.default.get(x.STORAGE_RECLAMATION_THRESHOLD)??.4,UW=(0,vW.convertToMS)(vT.default.get(x.STORAGE_RECLAMATION_INTERVAL))||36e5;a(Ah,"onStorageReclamation");xW=a(async e=>{if(CC.statfs){let t=await(0,CC.statfs)(e);return t.bavail/t.blocks}else return new Promise((t,r)=>{import("hdd-space").then(n=>{n.default(s=>{for(let i of s.parts)if(e.startsWith(i.place))return t(i.free/i.size);return t(1)})})})},"defaultGetAvailableSpaceRatio"),BW=xW;a(LC,"runReclamationHandlers");a(vge,"setAvailableSpaceRatioGetter")});var $W=w((xUe,qW)=>{"use strict";var{promises:zd,createReadStream:Uge,createWriteStream:xge}=require("fs"),{createGzip:Bge}=require("zlib"),{promisify:Hge}=require("util"),{pipeline:kge}=require("stream"),Fge=Hge(kge),vC=require("path"),lc=ae();lc.initSync();var cc=z(),{CONFIG_PARAMS:jd,ITC_EVENT_TYPES:Gge}=(H(),C(G)),{onMessageFromWorkers:qge}=rt(),{convertToMS:$ge}=ie(),{onStorageReclamation:Vge}=(UT(),C(HW)),Kge=6e4,Yge="'interval' and 'maxSize' are both undefined, to enable logging rotation at least one of these values must be defined in harperdb-config.yaml",Wge="'logging.rotation.path' is undefined, to enable logging rotation set this value in harperdb-config.yaml",MC,FW;qW.exports=GW;qge(e=>{e.type===Gge.RESTART&&(lc.initSync(!0),clearInterval(FW),lc.get(jd.LOGGING_ROTATION_ENABLED)&&GW())});async function GW(){try{let e=cc.getLogFilePath(),t=lc.get(jd.LOGGING_ROTATION_MAXSIZE),r=lc.get(jd.LOGGING_ROTATION_INTERVAL),n=lc.get(jd.LOGGING_ROTATION_RETENTION),s=0;if(Vge(e,l=>{s=l},!0),!t&&!r){cc.error(Yge);return}let i=lc.get(jd.LOGGING_ROTATION_PATH);if(!i){cc.error(Wge);return}let o;if(t){let l=t.slice(-1),u=t.slice(0,-1);l==="G"?o=u*1e9:l==="M"?o=u*1e6:o=u*1e3}let c;if(r){let l=r.slice(-1),u=r.slice(0,-1);l==="D"?c=u*1440:l==="H"?c=u*60:c=u}MC=Date.now()/6e4,cc.trace("Log rotate enabled, maxSize:",t,"interval:",r),FW=setInterval(async()=>{if(o){let l;l=await zd.stat(e),l.size>=o&&await kW(e,i)}if(c&&Date.now()/6e4-MC>=c&&(await kW(e,i),MC=Date.now()/6e4),n||s){let l=$ge(n??"1M")/(1+s);s=0;let u=await zd.readdir(i);for(let f of u)try{let d=await zd.stat(vC.join(i,f));Date.now()-d.mtimeMs>l&&await zd.unlink(vC.join(i,f))}catch(d){cc.error("Error trying to remove log",f,d)}}},Kge).unref()}catch(e){cc.error(e)}}a(GW,"logRotator");async function kW(e,t){let r=lc.get(jd.LOGGING_ROTATION_COMPRESS),n=vC.join(t,`HDB-${new Date(Date.now()).toISOString().replaceAll(":","-")}.log`);await zd.rename(e,n),r&&(e=n,n+=".gz",await Fge(Uge(e),Bge(),xge(n)),await zd.unlink(e)),cc.closeLogFile(),cc.notify(`hdb.log rotated, old log moved to ${n}`)}a(kW,"moveLogFile")});var Qd=w(JW=>{"use strict";var Ae=ae();Ae.initSync();za();var Gt=(H(),C(G)),{CONFIG_PARAMS:Ce}=Gt,ls=z(),Jo=require("fs-extra"),Qo=require("path"),zge=tC(),{install:jge}=PT(),UC=require("chalk"),{packageJson:Jge,PACKAGE_ROOT:Qge}=it(),Xo=ie(),xC=yt(),KW=ua(),VW=TS(),Xge=IC(),Zge=$W(),{compactOnStart:eSe}=(IS(),C(wS)),tSe=require("minimist"),rSe=Zn(),{startHTTPThreads:nSe}=(BC(),C(QW)),sSe=mh(),{isMainThread:iSe}=require("worker_threads"),HUe=po(),kUe=go(),FUe=Pb(),GUe=v_(),xT=(H(),C(G)),Ji,Jd,YW=!1,oSe="Upgrade complete. Starting HarperDB.",aSe="Got an error while trying to upgrade your HarperDB instance. Exiting HarperDB.",cSe="HarperDB not found, starting install process.",lSe="There was an error during install, check install_log.log for more details. Exiting.",uSe="HarperDB successfully started.";function dSe(){if(!YW){let e=a(()=>{Jo.removeSync(Qo.join(Ae.get(Gt.CONFIG_PARAMS.ROOTPATH),Gt.HDB_PID_FILE)),process.exit(0)},"remove_hdb_pid");process.on("exit",()=>{e()}),process.on("SIGINT",()=>{e()}),process.on("SIGQUIT",()=>{e()}),process.on("SIGTERM",()=>{e()})}}a(dSe,"addExitListeners");async function WW(e=!1,t=!1){if(console.log(UC.magenta("Starting HarperDB...")),ls.suppressLogging?.(()=>{console.log(UC.magenta(""+Jo.readFileSync(Qo.join(Qge,"utility/install/ascii_logo.txt"))))}),await jW()===!1){console.log(cSe);try{await jge()}catch(l){console.error(lSe,l),ls.error(l),process.exit(1)}}if(!e){let l=KW(Object.keys(Gt.CONFIG_PARAM_MAP),!0);!Xo.isEmpty(l)&&!Xo.isEmptyOrZeroLength(Object.keys(l))&&xC.updateConfigValue(void 0,void 0,l,!0,!0)}let r,n=Jd?.service==="clustering";Jd?.service&&!n&&(console.error("Unrecognized service argument"),process.exit(1));let s=Qo.join(Ae.get(Gt.CONFIG_PARAMS.ROOTPATH),Gt.HDB_PID_FILE),i=mSe(s);i&&i!==1&&ESe(i)&&(n?r=!0:(console.error(`Error: HarperDB is already running (pid: ${i})`),process.exit(4))),Ji===void 0&&(Ji=Pd()),n&&(r||(console.error("HarperDB must be running to start clustering."),process.exit()),Ae.get(Gt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY)||(console.error("Clustering must be setup and enabled in harperdb-config."),process.exit()),console.log("Starting clustering."),await VW.generateNatsConfig(),await Ji.startClusteringProcesses(!0),process.exit()),dSe(),await Jo.writeFile(Qo.join(Ae.get(xT.CONFIG_PARAMS.ROOTPATH),xT.HDB_PID_FILE),`${process.pid}`),ls.info("HarperDB PID",process.pid);let o;try{let l=await sSe.getVersionUpdateInfo();l!==void 0&&(o=l[Gt.UPGRADE_JSON_FIELD_NAMES_ENUM.UPGRADE_VERSION],await Xge.upgrade(l),console.log(oSe))}catch(l){o?(console.error(`Got an error while trying to upgrade your HarperDB instance to version ${o}. Exiting HarperDB.`,l),ls.error(l)):(console.error(aSe,l),ls.error(l)),process.exit(1)}zge(),pSe(),await rSe.reviewSelfSignedCert(),Xo.autoCastBoolean(Ae.get(Gt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&iSe&&await VW.generateNatsConfig(t)}a(WW,"initialize");async function fSe(e=!1){try{Jd=tSe(process.argv),Jd.ROOTPATH&&xC.updateConfigObject("settings_path",Qo.join(Jd.ROOTPATH,Gt.HDB_CONFIG_FILE)),await WW(e,!0),Ae.get(Gt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await eSe();let t=process.env.IS_SCRIPTED_SERVICE&&!Jd.service;Xo.autoCastBoolean(Ae.get(Gt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&(t||await Ji.startClusteringProcesses(),await Ji.startClusteringThreads()),await nSe(process.env.DEV_MODE?1:Ae.get(xT.CONFIG_PARAMS.THREADS_COUNT)??Ae.get(xT.CONFIG_PARAMS.THREADS)),Ae.get(Gt.CONFIG_PARAMS.LOGGING_ROTATION_ENABLED)&&await Zge(),t||zW()}catch(t){console.error(t),ls.error(t),process.exit(1)}}a(fSe,"main");function zW(){ls.suppressLogging(()=>{console.log(UC.magenta(`HarperDB ${Jge.version} successfully started`))}),ls.notify(uSe)}a(zW,"started");async function _Se(e=!0){YW=!e;try{Ji===void 0&&(Ji=Pd()),Ji.enterPM2Mode(),await WW(),Xo.autoCastBoolean(Ae.get(Gt.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY))&&await Ji.startClusteringProcesses(),await Ji.startService(Gt.PROCESS_DESCRIPTORS.HDB),zW(),e&&process.exit(0)}catch(t){console.error(t),ls.error(t),process.exit(1)}}a(_Se,"launch");function pSe(){let e=Qo.join(Ae.get(Gt.CONFIG_PARAMS.ROOTPATH),Gt.LICENSE_KEY_DIR_NAME,Gt.LICENSE_FILE_NAME),t=Qo.join(e,Gt.LICENSE_FILE_NAME),r=Qo.join(e,Gt.REG_KEY_FILE_NAME);try{let{HARPERDB_FINGERPRINT:n,HARPERDB_LICENSE:s}=KW(["HARPERDB_FINGERPRINT","HARPERDB_LICENSE"]);if(Xo.isEmpty(n)||Xo.isEmpty(s))return;Jo.mkdirpSync(e),Jo.writeFileSync(r,n),Jo.writeFileSync(t,s)}catch(n){let s=`Failed to write license & fingerprint due to: ${n.message}`;console.error(s),ls.error(s)}}a(pSe,"writeLicenseFromVars");Object.assign(JW,{launch:_Se,main:fSe,isHdbInstalled:jW,startupLog:hSe});async function jW(){try{await Jo.stat(Xo.getPropsFilePath()),await Jo.stat(Ae.get(Gt.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}catch(e){if(Xo.noBootFile())return!0;if(e.code==="ENOENT")return!1;throw ls.error(`Error checking for HDB install - ${e}`),e}return!0}a(jW,"isHdbInstalled");function hSe(e){let r=a(_=>_.padEnd(20),"pad"),n=`
113
+ `;Ae.get(Ce.REPLICATION_HOSTNAME)&&(n+=`${r("Hostname:")}${Ae.get(Ce.REPLICATION_HOSTNAME)}
114
+ `),Ae.get(Ce.REPLICATION_URL)&&(n+=`${r("Replication Url:")}${Ae.get(Ce.REPLICATION_URL)}
115
+ `),n+=`${r("Worker Threads:")}${Ae.get(Ce.THREADS_COUNT)}
116
+ `,n+=`${r("Root Path:")}${Ae.get(Ce.ROOTPATH)}
117
+ `,Ae.get(Ce.THREADS_DEBUG)!==!1&&(n+=`${r("Debugging:")}enabled: true`,n+=Ae.get(Ce.THREADS_DEBUG_PORT)?`, TCP: ${Ae.get(Ce.THREADS_DEBUG_PORT)}
120
118
  `:`
121
- `);let s=Qo.join(Se.get(Ie.LOGGING_ROOT),"hdb.log");n+=`${r("Logging:")}level: ${Se.get(Ie.LOGGING_LEVEL)}, location: ${s+(Se.get(Ie.LOGGING_STDSTREAMS)?", stdout/err":"")}
122
- `,n+=r("Default:"),n+=Se.get(Ie.HTTP_PORT)?`HTTP (and WS): ${Se.get(Ie.HTTP_PORT)}, `:"",n+=Se.get(Ie.HTTP_SECUREPORT)?`HTTPS (and WS): ${Se.get(Ie.HTTP_SECUREPORT)}, `:"",n+=`CORS: ${Se.get(Ie.HTTP_CORS)?`enabled for ${Se.get(Ie.HTTP_CORSACCESSLIST)}`:"disabled"}
123
- `,n+=r("Operations API:"),n+=Se.get(Ie.OPERATIONSAPI_NETWORK_PORT)?`HTTP: ${Se.get(Ie.OPERATIONSAPI_NETWORK_PORT)}, `:"",n+=Se.get(Ie.OPERATIONSAPI_NETWORK_SECUREPORT)?`HTTPS: ${Se.get(Ie.OPERATIONSAPI_NETWORK_SECUREPORT)}, `:"",n+=`CORS: ${Se.get(Ie.OPERATIONSAPI_NETWORK_CORS)?`enabled for ${Se.get(Ie.OPERATIONSAPI_NETWORK_CORSACCESSLIST)}`:"disabled"}`,n+=`, unix socket: ${Se.get(Ie.OPERATIONSAPI_NETWORK_DOMAINSOCKET)}
124
- `,n+=r("MQTT:"),n+=Se.get(Ie.MQTT_NETWORK_PORT)?`TCP: ${Se.get(Ie.MQTT_NETWORK_PORT)}, `:"",n+=Se.get(Ie.MQTT_NETWORK_SECUREPORT)?`TLS: ${Se.get(Ie.MQTT_NETWORK_SECUREPORT)}`:"",n+=Se.get(Ie.MQTT_WEBSOCKET)&&Se.get(Ie.HTTP_PORT)?`, WS: ${Se.get(Ie.HTTP_PORT)}`:"",n+=Se.get(Ie.MQTT_WEBSOCKET)&&Se.get(Ie.HTTP_SECUREPORT)?`, WSS: ${Se.get(Ie.HTTP_SECUREPORT)}
119
+ `);let s=Qo.join(Ae.get(Ce.LOGGING_ROOT),"hdb.log");n+=`${r("Logging:")}level: ${Ae.get(Ce.LOGGING_LEVEL)}, location: ${s+(Ae.get(Ce.LOGGING_STDSTREAMS)?", stdout/err":"")}
120
+ `,n+=r("Default:"),n+=Ae.get(Ce.HTTP_PORT)?`HTTP (and WS): ${Ae.get(Ce.HTTP_PORT)}, `:"",n+=Ae.get(Ce.HTTP_SECUREPORT)?`HTTPS (and WS): ${Ae.get(Ce.HTTP_SECUREPORT)}, `:"",n+=`CORS: ${Ae.get(Ce.HTTP_CORS)?`enabled for ${Ae.get(Ce.HTTP_CORSACCESSLIST)}`:"disabled"}
121
+ `,n+=r("Operations API:"),n+=Ae.get(Ce.OPERATIONSAPI_NETWORK_PORT)?`HTTP: ${Ae.get(Ce.OPERATIONSAPI_NETWORK_PORT)}, `:"",n+=Ae.get(Ce.OPERATIONSAPI_NETWORK_SECUREPORT)?`HTTPS: ${Ae.get(Ce.OPERATIONSAPI_NETWORK_SECUREPORT)}, `:"",n+=`CORS: ${Ae.get(Ce.OPERATIONSAPI_NETWORK_CORS)?`enabled for ${Ae.get(Ce.OPERATIONSAPI_NETWORK_CORSACCESSLIST)}`:"disabled"}`,n+=`, unix socket: ${Ae.get(Ce.OPERATIONSAPI_NETWORK_DOMAINSOCKET)}
122
+ `,n+=r("MQTT:"),n+=Ae.get(Ce.MQTT_NETWORK_PORT)?`TCP: ${Ae.get(Ce.MQTT_NETWORK_PORT)}, `:"",n+=Ae.get(Ce.MQTT_NETWORK_SECUREPORT)?`TLS: ${Ae.get(Ce.MQTT_NETWORK_SECUREPORT)}`:"",n+=Ae.get(Ce.MQTT_WEBSOCKET)&&Ae.get(Ce.HTTP_PORT)?`, WS: ${Ae.get(Ce.HTTP_PORT)}`:"",n+=Ae.get(Ce.MQTT_WEBSOCKET)&&Ae.get(Ce.HTTP_SECUREPORT)?`, WSS: ${Ae.get(Ce.HTTP_SECUREPORT)}
125
123
  `:`
126
- `;let i=Se.get(Ie.REPLICATION_PORT)??Se.get(Ie.OPERATIONSAPI_NETWORK_PORT),o=Se.get(Ie.REPLICATION_SECUREPORT)??Se.get(Ie.OPERATIONSAPI_NETWORK_SECUREPORT),c=r("Replication:");c+=i?`WS: ${i}, `:"",c+=o?`WSS: ${o} `:"",n+=`${c.slice(0,-2)}
127
- `;let l=[],u=UC.getConfigObj();for(let _ in u)u[_].package&&l.push(_);let f={},d=`${r("REST:")}`;for(let[_,h]of e)for(let S of h){let g=S.name;g==="rest"&&(d+=`${S.protocol_name}: ${_}, `),l.includes(g)&&(f[g]?f[g]+=`${S.protocol_name}: ${_}, `:f[g]=`${S.protocol_name}: ${_}, `)}d.length>21&&(d=d.slice(0,-2),n+=`${d}
128
- `);let p=Se.get(Ie.HTTP_PORT)?`HTTP: ${Se.get(Ie.HTTP_PORT)}, `:"";p+=Se.get(Ie.HTTP_SECUREPORT)?`HTTPS: ${Se.get(Ie.HTTP_SECUREPORT)}, `:"",p.length>21&&(p=p.slice(0,-2));for(let _ of l)f[_]?n+=`${r(_+": ")}${f[_].slice(0,-2)}
124
+ `;let i=Ae.get(Ce.REPLICATION_PORT)??Ae.get(Ce.OPERATIONSAPI_NETWORK_PORT),o=Ae.get(Ce.REPLICATION_SECUREPORT)??Ae.get(Ce.OPERATIONSAPI_NETWORK_SECUREPORT),c=r("Replication:");c+=i?`WS: ${i}, `:"",c+=o?`WSS: ${o} `:"",n+=`${c.slice(0,-2)}
125
+ `;let l=[],u=xC.getConfigObj();for(let _ in u)u[_].package&&l.push(_);let f={},d=`${r("REST:")}`;for(let[_,h]of e)for(let S of h){let g=S.name;g==="rest"&&(d+=`${S.protocol_name}: ${_}, `),l.includes(g)&&(f[g]?f[g]+=`${S.protocol_name}: ${_}, `:f[g]=`${S.protocol_name}: ${_}, `)}d.length>21&&(d=d.slice(0,-2),n+=`${d}
126
+ `);let p=Ae.get(Ce.HTTP_PORT)?`HTTP: ${Ae.get(Ce.HTTP_PORT)}, `:"";p+=Ae.get(Ce.HTTP_SECUREPORT)?`HTTPS: ${Ae.get(Ce.HTTP_SECUREPORT)}, `:"",p.length>21&&(p=p.slice(0,-2));for(let _ of l)f[_]?n+=`${r(_+": ")}${f[_].slice(0,-2)}
129
127
  `:n+=`${r(_+": ")}${p}
130
- `;console.log(n),Se.get(Ie.LOGGING_STDSTREAMS)&&ls.logsAtLevel("info")&&ls.suppressLogging(()=>{console.log(`Note that log messages are being sent to the console (stdout and stderr) in addition to the log file ${s}. This can be disabled by setting logging.stdStreams to false, and the log file can be directly monitored/tailed.`)})}a(fSe,"startupLog");function _Se(e){try{return Number.parseInt(Jo.readFileSync(e,"utf8"),10)}catch{return null}}a(_Se,"readPidFile");function pSe(e){try{return process.kill(e,0),!0}catch(t){return t.code==="EPERM"}}a(pSe,"isProcessRunning")});var YC=w(Zo=>{"use strict";rm();var{isMainThread:BC,parentPort:Oh,threadId:BT,workerData:hSe}=require("node:worker_threads"),{Socket:mSe,createServer:ESe}=require("node:net"),{createServer:gSe,IncomingMessage:SSe}=require("node:http"),{createServer:TSe}=require("node:https"),{createSecureServer:ASe}=require("node:http2"),{Blob:RSe}=(gs(),C(Fm)),{unlinkSync:oz,existsSync:ySe}=require("fs"),Dn=z(),Et=ae(),Qt=(H(),C(G)),{server:Nh}=(Vr(),C(Tu)),{WebSocketServer:bSe}=require("ws"),{createServer:OSe}=require("node:tls"),{getTicketKeys:NSe,restartNumber:wSe,getWorkerIndex:Qd}=et(),{Headers:HC,appendHeader:ISe}=(z_(),C(NH)),{recordAction:Rh,recordActionBinary:ZW}=(ki(),C(W_)),{Request:az,createReuseportFd:bh}=(XI(),C(wY)),{checkMemoryLimit:CSe}=bd(),{createTLSSelector:cz}=Zn(),{resolvePath:lz}=yt(),{startupLog:PSe}=Jd(),{Readable:ez}=require("node:stream"),DSe=Ti(),uz=Et.get(Qt.CONFIG_PARAMS.THREADS_DEBUG);if(uz){let e;if(BC)e=Et.get(Qt.CONFIG_PARAMS.THREADS_DEBUG_PORT)??9229,process.on(["SIGINT","SIGTERM","SIGQUIT","exit"],()=>{try{require("inspector").close()}catch(t){Dn.info("Could not close debugger",t)}});else{let t=Et.get(Qt.CONFIG_PARAMS.THREADS_DEBUG_STARTINGPORT);t&&Qd()>=0&&(e=t+Qd())}if(e){let t=Et.get(Qt.CONFIG_PARAMS.THREADS_DEBUG_HOST),r=Et.get(Qt.CONFIG_PARAMS.THREADS_DEBUG_WAITFORDEBUGGER);try{require("inspector").open(e,t,r)}catch(n){Dn.trace(`Could not start debugging on port ${e}, you may already be debugging:`,n.message)}}}else if(process.env.DEV_MODE&&BC)try{require("inspector").open(9229)}catch(e){wSe<=1&&Dn.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:GUe,CONFIG_PARAMS:LSe}=Qt;Et.initSync();var MSe=Et.get(LSe.HTTP_SESSIONAFFINITY),Qi={},kC=new Map;Zo.registerServer=$C;Zo.httpServer=KC;Zo.deliverSocket=qC;Zo.startServers=dz;Zo.listenOnPorts=fz;Zo.globals=DSe;Zo.when_components_loaded=null;Nh.http=KC;Nh.request=USe;Nh.socket=xSe;Nh.ws=BSe;Nh.upgrade=hz;var yh={},xT={},HT={},FC=[];function dz(){return Zo.when_components_loaded=qT().loadRootComponents(!0).then(()=>{Oh?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)qC(n,r,s);else if(t.requestId)vSe(t);else if(t.type===Qt.ITC_EVENT_TYPES.SHUTDOWN){Dn.trace("received shutdown request",BT);for(let i in Qi){let o=Qi[i],c;if(o.closeIdleConnections){let u=Object.getOwnPropertySymbols(o).find(p=>p.description.includes("connections")),f=0,d=setInterval(()=>{f++;let p=f>=100,_=o[u][p?"all":"idle"]();if(_.length===0){p&&clearInterval(d);return}f===1?Dn.info(`Closing ${_.length} idle connections`):p&&Dn.warn(`Forcefully closing ${_.length} active connections`);for(let h=0,S=_.length;h<S;h++){let g=_[h].socket;g._httpMessage&&!g._httpMessage.finished&&!p||(p?g.destroySoon():g.end(`HTTP/1.1 408 Request Timeout\r
128
+ `;console.log(n),Ae.get(Ce.LOGGING_STDSTREAMS)&&ls.logsAtLevel("info")&&ls.suppressLogging(()=>{console.log(`Note that log messages are being sent to the console (stdout and stderr) in addition to the log file ${s}. This can be disabled by setting logging.stdStreams to false, and the log file can be directly monitored/tailed.`)})}a(hSe,"startupLog");function mSe(e){try{return Number.parseInt(Jo.readFileSync(e,"utf8"),10)}catch{return null}}a(mSe,"readPidFile");function ESe(e){try{return process.kill(e,0),!0}catch(t){return t.code==="EPERM"}}a(ESe,"isProcessRunning")});var WC=w(Zo=>{"use strict";nm();var{isMainThread:HC,parentPort:Oh,threadId:HT,workerData:gSe}=require("node:worker_threads"),{Socket:SSe,createServer:TSe}=require("node:net"),{createServer:ASe,IncomingMessage:RSe}=require("node:http"),{createServer:ySe}=require("node:https"),{createSecureServer:bSe}=require("node:http2"),{Blob:OSe}=(gs(),C(Gm)),{unlinkSync:iz,existsSync:NSe}=require("fs"),Ln=z(),Et=ae(),Xt=(H(),C(G)),{server:Nh}=(Vr(),C(Au)),{WebSocketServer:wSe}=require("ws"),{createServer:ISe}=require("node:tls"),{getTicketKeys:CSe,restartNumber:PSe,getWorkerIndex:Xd}=rt(),{Headers:kC,appendHeader:DSe}=(z_(),C(wH)),{recordAction:Rh,recordActionBinary:XW}=(ki(),C(W_)),{Request:oz,createReuseportFd:bh}=(ZI(),C(NY)),{checkMemoryLimit:LSe}=Od(),{createTLSSelector:az}=Zn(),{resolvePath:cz}=yt(),{startupLog:MSe}=Qd(),{Readable:ZW}=require("node:stream"),vSe=Ti(),lz=Et.get(Xt.CONFIG_PARAMS.THREADS_DEBUG);if(lz){let e;if(HC)e=Et.get(Xt.CONFIG_PARAMS.THREADS_DEBUG_PORT)??9229,process.on(["SIGINT","SIGTERM","SIGQUIT","exit"],()=>{try{require("inspector").close()}catch(t){Ln.info("Could not close debugger",t)}});else{let t=Et.get(Xt.CONFIG_PARAMS.THREADS_DEBUG_STARTINGPORT);t&&Xd()>=0&&(e=t+Xd())}if(e){let t=Et.get(Xt.CONFIG_PARAMS.THREADS_DEBUG_HOST),r=Et.get(Xt.CONFIG_PARAMS.THREADS_DEBUG_WAITFORDEBUGGER);try{require("inspector").open(e,t,r)}catch(n){Ln.trace(`Could not start debugging on port ${e}, you may already be debugging:`,n.message)}}}else if(process.env.DEV_MODE&&HC)try{require("inspector").open(9229)}catch(e){PSe<=1&&Ln.trace("Could not start debugging on port 9229, you may already be debugging:",e.message)}process.on("uncaughtException",e=>{e.isHandled||e.code==="ECONNRESET"||e.code==="ECONNREFUSED"||e.message!=="write EIO"&&console.error("uncaughtException",e)});var{HDB_SETTINGS_NAMES:VUe,CONFIG_PARAMS:USe}=Xt;Et.initSync();var xSe=Et.get(USe.HTTP_SESSIONAFFINITY),Qi={},FC=new Map;Zo.registerServer=VC;Zo.httpServer=YC;Zo.deliverSocket=$C;Zo.startServers=uz;Zo.listenOnPorts=dz;Zo.globals=vSe;Zo.when_components_loaded=null;Nh.http=YC;Nh.request=HSe;Nh.socket=kSe;Nh.ws=FSe;Nh.upgrade=pz;var yh={},BT={},kT={},GC=[];function uz(){return Zo.when_components_loaded=$T().loadRootComponents(!0).then(()=>{Oh?.on("message",t=>{let{port:r,fd:n,data:s}=t;if(n)$C(n,r,s);else if(t.requestId)BSe(t);else if(t.type===Xt.ITC_EVENT_TYPES.SHUTDOWN){Ln.trace("received shutdown request",HT);for(let i in Qi){let o=Qi[i],c;if(o.closeIdleConnections){let u=Object.getOwnPropertySymbols(o).find(p=>p.description.includes("connections")),f=0,d=setInterval(()=>{f++;let p=f>=100,_=o[u][p?"all":"idle"]();if(_.length===0){p&&clearInterval(d);return}f===1?Ln.info(`Closing ${_.length} idle connections`):p&&Ln.warn(`Forcefully closing ${_.length} active connections`);for(let h=0,S=_.length;h<S;h++){let g=_[h].socket;g._httpMessage&&!g._httpMessage.finished&&!p||(p?g.destroySoon():g.end(`HTTP/1.1 408 Request Timeout\r
131
129
  Connection: close\r
132
130
  \r
133
- `))}},25).unref()}o.close?.(()=>{if(Et.get(Qt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&Qd()==0)try{oz(lz(Et.get(Qt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,BT),o.cantCleanupProperly||Dn.warn("Had to forcefully exit the thread",BT),process.exit(0)},5e3).unref()})}if(uz||process.env.DEV_MODE)try{require("inspector").close()}catch(i){Dn.info("Could not close debugger",i)}}}).ref();let e;bh&&!MSe&&(e=fz()),Promise.resolve(e).then(()=>{if(Qd()===0)try{PSe(kC)}catch(t){console.error("Error displaying start-up log",t)}Oh?.postMessage({type:Qt.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(dz,"startServers");function fz(){let e=[];for(let t in Qi){let r=Qi[t];if(t.includes?.("/")&&Qd()==0){ySe(t)&&oz(t),e.push(new Promise((o,c)=>{r.listen({path:t},()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),Dn.info("Domain socket listening on "+t)}).on("error",c)}));continue}let n,s=Et.get(Qt.CONFIG_PARAMS.HTTP_THREADRANGE);if(s){let o=typeof s=="string"?s.split("-"):s,c=Qd();if(c<o[0]||c>o[1])continue}let i;try{let o=t.lastIndexOf(":");o>0?bh?n={fd:bh(+t.slice(o+1).replace(/[\[\]]/g,""),t.slice(0,o))}:n={host:+t.slice(o+1).replace(/[\[\]]/g,""),port:t.slice(0,o)}:bh?n={fd:bh(+t,"::")}:n={port:t}}catch(o){console.error(`Unable to bind to port ${t}`,o);continue}e.push(new Promise((o,c)=>{r.listen(n,()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),Dn.trace("Listening on port "+t,BT)}).on("error",c)}))}return Promise.all(e)}a(fz,"listenOnPorts");!BC&&!hSe?.noServerStart&&dz();function qC(e,t,r){let n=e?.read?e:new mSe({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=Qi[t];if(s.isSecure&&(n.startTime=performance.now()),s)typeof s=="function"?s(n):s.emit("connection",n),r&&n.emit("data",r);else{let i=a(o=>{setTimeout(()=>{let c=Qi[t];c?(typeof c=="function"?c(n):c.emit("connection",n),r&&n.emit("data",r)):o<5?i(o+1):(Dn.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a(qC,"deliverSocket");var tz=new Map;function vSe(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=tz.get(s),r){case"connection":i=qC(void 0,t),tz.set(s,i),i.write=(c,l,u)=>(Oh.postMessage({requestId:s,event:"data",data:c.toString("latin1")}),u&&u(),!0),i.end=(c,l,u)=>(Oh.postMessage({requestId:s,event:"end",data:c?.toString("latin1")}),u&&u(),!0);let o=i.destroy;i.destroy=()=>{o.call(i),Oh.postMessage({requestId:s,event:"destroy"})};break;case"data":i._readableState.destroyed||i.emit("data",Buffer.from(n,"latin1"));break;case"drain":i._readableState.destroyed||i.emit("drain",{});break;case"end":i._readableState.destroyed||i.emit("end",{});break;case"error":i._readableState.destroyed||i.emit("error",{});break}}a(vSe,"proxyRequest");var{getComponentName:kT}=(jp(),C(zp));function $C(e,t,r=!0){t||(t=Et.get(Qt.CONFIG_PARAMS.HTTP_PORT));let n=Qi[t];if(n){let s=n.lastServer||n;if(s===e)throw new Error(`Can not register the same server twice for the same port ${t}`);if(r&&!!s.sessionIdContext!=!!e.sessionIdContext&&+t)throw new Error(`Can not mix secure HTTPS and insecure HTTP on the same port ${t}`);s.off("unhandled",iz),s.on("unhandled",(i,o)=>{e.cantCleanupProperly&&(n.cantCleanupProperly=!0),e.emit("request",i,o)}),n.lastServer=e}else Qi[t]=e;e.on("unhandled",iz)}a($C,"registerServer");function VC(e){let t=[],r=e?.securePort;return r&&t.push({port:r,secure:!0}),r=e?.port,r&&t.push({port:r,secure:!1}),t.length===0&&(t=[],Et.get(Qt.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:Et.get(Qt.CONFIG_PARAMS.HTTP_PORT),secure:Et.get(Qt.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),Et.get(Qt.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:Et.get(Qt.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&Et.get(Qt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:lz(Et.get(Qt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)),secure:!1}),t}a(VC,"getPorts");function KC(e,t){let r=[];for(let{port:n,secure:s}of VC(t))r.push(_z(n,s,t?.isOperationsServer,t?.mtls)),typeof e=="function"?FC[t?.runFirst?"unshift":"push"]({listener:e,port:t?.port||n}):(e.isSecure=s,$C(e,n,!1)),HT[n]=GT(FC,n);return r}a(KC,"httpServer");function FT(e,t){let r=kC.get(e)??[];kC.set(e,[...r,t])}a(FT,"setPortServerMap");function _z(e,t,r,n){if(FT(e,{protocol_name:t?"HTTPS":"HTTP",name:kT()}),!xT[e]){let s=r?"operationsApi_network":"http",i=Et.get(s+"_keepAliveTimeout"),o=Et.get(s+"_timeout"),c=Et.get(s+"_headersTimeout"),l={keepAliveTimeout:i,headersTimeout:c,requestTimeout:o,highWaterMark:128*1024,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,maxHeaderSize:Et.get(Qt.CONFIG_PARAMS.HTTP_MAXHEADERSIZE)},u=Et.get(s+"_mtls"),f=Et.get(s+"_mtls_required"),d;t&&(d=Et.get(s+"_http2"),Object.assign(l,{allowHTTP1:!0,rejectUnauthorized:!!f,requestCert:!!(u||n),ticketKeys:NSe(),SNICallback:cz(r?"operations-api":"server",u)}));let p=CSe(),_=xT[e]=(t?d?ASe:TSe:gSe)(l,async(h,S)=>{try{let R=performance.now(),E=new az(h,S);r&&(E.isOperationsServer=!0);let T=await HT[e](E);if(!T){if(E._nodeResponse.statusCode)return;T=pz(E)}if(T.headers?.set||(T.headers=new HC(T.headers)),p?T.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):T.headers?.set?.("Server","HarperDB"),T.status===-1){for(let ne of T.headers||[])S.setHeader(ne[0],ne[1]);return h.baseRequest=E,S.baseResponse=T,xT[e].emit("unhandled",h,S)}let b=T.status||200,v=performance.now(),F=v-R,q=T.body,Y,Z=!1;if(!T.handlesHeaders){let ne=T.headers||new HC;q?q.length>=0?(typeof q=="string"?ne.set("Content-Length",Buffer.byteLength(q)):ne.set("Content-Length",q.length),Y=!0):q instanceof RSe&&(q.size?ne.set("Content-Length",q.size):q.on&&(Z=!0,q.on("size",he=>{S.headersSent||S.setHeader("Content-Length",he)})),q=q.stream()):(ne.set("Content-Length","0"),Y=!0);let J=`hdb;dur=${F.toFixed(2)}`;if(T.wasCacheMiss&&(J+=", miss"),ISe(ne,"Server-Timing",J,!0),!S.headersSent)if(Z){if(S.statusCode=b,ne)if(ne[Symbol.iterator])for(let[he,Re]of ne)S.setHeader(he,Re);else for(let he in ne)S.setHeader(he,ne[he])}else S.writeHead(b,ne&&(ne[Symbol.iterator]?Array.from(ne):ne));Y&&S.end(q)}let se=E.handlerPath,Q=E.method;if(Rh(F,"duration",se,Q,T.wasCacheMiss==null?void 0:T.wasCacheMiss?"cache-miss":"cache-hit"),ZW(b<400,"success",se,Q),ZW(1,"response_"+b,se,Q),!Y)if(q instanceof ReadableStream&&(q=ez.fromWeb(q)),(q[Symbol.iterator]||q[Symbol.asyncIterator])&&(q=ez.from(q)),q?.pipe){q.pipe(S),q.destroy&&S.on("close",()=>{q.destroy()});let ne=0;q.on("data",J=>{ne+=J.length}),q.on("end",()=>{Rh(performance.now()-v,"transfer",se,Q),Rh(ne,"bytes-sent",se,Q)})}else q?.then?q.then(ne=>{S.end(ne)},g):S.end(q)}catch(R){g(R)}function g(R){let E=R.headers;S.writeHead(R.statusCode||500,E&&(E[Symbol.iterator]?Array.from(E):E)),S.end(R.toString()),R.statusCode?R.statusCode===500?Dn.warn(R):Dn.info(R):Dn.error(R)}a(g,"onError")});i>=0&&(_.keepAliveTimeout=i),c>=0&&(_.headersTimeout=c),t&&(_.ports||(_.ports=[]),_.ports.push(e),l.SNICallback.initialize(_),u&&(_.mtlsConfig=u),_.on("secureConnection",h=>{h._parent.startTime&&Rh(performance.now()-h._parent.startTime,"tls-handshake",e),Rh(h.isSessionReused(),"tls-reused",e)}),_.isSecure=!0),$C(_,e)}return xT[e]}a(_z,"getHTTPServer");function GT(e,t){let r=pz;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(GT,"makeCallbackChain");function pz(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new HC}}a(pz,"unhandled");function USe(e,t){KC(e,{requestOnly:!0,...t})}a(USe,"onRequest");function xSe(e,t){let r;if(t.securePort){FT(t.securePort,{protocol_name:"TLS",name:kT()});let n=cz("server",t.mtls);r=OSe({rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,SNICallback:n},e),n.initialize(r),Qi[t.securePort]=r}return t.port&&(FT(t.port,{protocol_name:"TCP",name:kT()}),r=ESe(e,{noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600}),Qi[t.port]=r),r}a(xSe,"onSocket");Object.defineProperty(SSe.prototype,"upgrade",{get(){return"connection"in this.headers&&"upgrade"in this.headers&&this.headers.connection.toLowerCase().includes("upgrade")&&this.headers.upgrade.toLowerCase()=="websocket"},set(e){}});var rz=[],GC={};function hz(e,t){for(let{port:r}of VC(t))rz[t?.runFirst?"unshift":"push"]({listener:e,port:r}),GC[r]=GT(rz,r)}a(hz,"onUpgrade");var nz=[],sz={};function BSe(e,t){let r=[];for(let{port:n,secure:s}of VC(t)){FT(n,{protocol_name:s?"WSS":"WS",name:kT()});let i=_z(n,s,t?.isOperationsServer,t?.mtls);yh[n]||(yh[n]=new bSe({noServer:!0,maxPayload:t.maxPayload??100*1024*1024}),yh[n].on("connection",(o,c)=>{let l=new az(c);l.isWebSocket=!0;let u=HT[n](l);sz[n](o,l,u)}),hz((o,c,l,u)=>o.__harperdb_request_upgraded?u(o,c,l):yh[n].handleUpgrade(o,c,l,f=>{o.__harperdb_request_upgraded=!0,u(o,c,l),yh[n].emit("connection",f,o)}),{port:n}),i.on("upgrade",(o,c,l)=>{GC[n]&&GC[n](o,c,l)})),r.push(i),nz[t?.runFirst?"unshift":"push"]({listener:e,port:n}),sz[n]=GT(nz,n),HT[n]=GT(FC,n)}return r}a(BSe,"onWebSocket");function iz(e,t){t.writeHead(404),t.end(`Not found
134
- `)}a(iz,"defaultNotFound")});var XW={};ve(XW,{startHTTPThreads:()=>kSe,startSocketServer:()=>QC,updateWorkerIdleness:()=>bz});async function kSe(e=2,t){try{if(t)jC(0,1,!0);else{let{loadRootComponents:r}=qT();if(e===0)return(0,Bs.setMainIsWorker)(!0),await YC().startServers(),Promise.resolve([]);await r()}yz();for(let r=0;r<e;r++)jC(r,e);return Promise.all(Rz)}finally{(0,Bs.threadsHaveStarted)()}}function yz(){let e=(0,Sz.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),zC=setInterval(()=>{KT.notify(e)},HSe).unref())}function jC(e,t=1,r){if(WC++,(0,Bs.startWorker)("server/threads/threadServer.js",{name:XA.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(u){u.type===jA.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});Rz.push(s),await s,Xd.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=VT.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=Xd.indexOf(n);o>-1&&Xd.splice(o,1)}if(a(i,"removeWorker"),Zd){let o=Zd;Zd=[];for(let c of o)Az[c.localPort](null,c)}}}),r){let n=setInterval(()=>{JC?JC=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,Bs.shutdownWorkers)(),WC=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function QC(e=0,t){if(typeof e=="string")try{(0,YT.existsSync)(e)&&(0,YT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=FSe:r=GSe(t):r=XC;let n=(0,ef.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);return n._handle&&(n._handle.onconnection=Az[e]=function(s,i){r.readsData||(i.reading=!1,i.readStop()),JC=!0,r(i,(o,c)=>{if(!o){if(mz){let u=i._socket||new ef.Socket({handle:i,writable:!0,readable:!0});mz.deliverSocket(u,e,c),u.resume()}else WC>0?(Zd.length===0&&setTimeout(()=>{Zd.length>0&&console.warn("Incoming sockets/requests have been queued for workers to start, and no workers have handled them. Check to make sure an error is not preventing workers from starting")},1e4).unref(),i.localPort=e,Zd.push(i)):(console.log("start up a dynamic thread to handle request"),jC(0));sr(!1,"socket-routed");return}o.requests++;let l=i.fd;if(l>=0)o.postMessage({port:e,fd:l,data:c});else{let u=i._socket||new ef.Socket({handle:i,writable:!0,readable:!0});VSe(u,o,e)}sr(!0,"socket-routed")})},KT.info(`HarperDB ${Tz.packageJson.version} Server running on port ${e}`)),n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function XC(e,t){let r,n=0;for(let s of Xd){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=$T)return $T=i,t(r);n=i}$T=0,t(r)}function FSe(e,t){let r={};e.getpeername(r);let n=r.address,s=tf.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);XC(e,o=>{tf.set(n,{worker:o,lastUsed:i}),t(o)})}function GSe(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new ef.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=tf.get(l),f=Date.now();if(u&&u.worker.threadId!==-1)return u.lastUsed=f,s(u.worker);XC(n,d=>{tf.set(l,{worker:d,lastUsed:f}),s(d,o)})})}a(r,"findByHeaderAffinity")}function bz(){$T=0;for(let e of Xd)e.expectedIdle=e.recentELU.idle+qSe,e.requests=1;Xd.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function VSe(e,t,r){let n=$Se++;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(),VT.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")),VT.delete(n)),s.event=="destroy"&&(e.destroy(),VT.delete(n))})}var Bs,ef,KT,YT,gz,Sz,Tz,Xd,Zd,Az,mz,WC,Rz,zC,HSe,JC,$T,Ez,tf,qSe,VT,$Se,xC=be(()=>{Bs=M(et()),ef=require("net");H();KT=M(z()),YT=require("fs");ki();gz=require("worker_threads"),Sz=M(bd()),Tz=M(st()),Xd=[],Zd=[],Az=[],WC=0,Rz=[];gz.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,Bs.onMessageFromWorkers)(e=>{e.type===QA.RESTART&&zC&&(clearInterval(zC),yz())}));HSe=6e5;a(kSe,"startHTTPThreads");a(yz,"licenseWarning");a(jC,"startHTTPWorker");a(QC,"startSocketServer");$T=0;a(XC,"findMostIdleWorker");Ez=36e5,tf=new Map;a(FSe,"findByRemoteAddressAffinity");a(GSe,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of tf)r.lastUsed+Ez<e&&tf.delete(t)},Ez).unref();qSe=1e3;a(bz,"updateWorkerIdleness");(0,Bs.setMonitorListener)(bz);VT=new Map,$Se=1;a(VSe,"proxySocket")});var kz=w((jUe,Hz)=>{var Nz=M(require("cluster")),cc=M(ae());H();var Xi=M(z()),wz=M(require("fastify")),Iz=M(require("@fastify/cors")),Cz=M(require("@fastify/compress")),Pz=M(require("@fastify/static")),Dz=M(AO()),Lz=M(require("path")),Mz=M(st()),vz=M(As()),Uz=M(ie()),xz=M(An()),Bz=M(bd());Vr();var lc=M(pT());ao();cc.default.initSync();var KSe=6e4,YSe=1024*1024*1024,WSe="TRUE",{CONFIG_PARAMS:wh}=G,rf;Hz.exports={hdbServer:Oz,start:Oz};async function Oz(e){try{Xi.default.debug("In Fastify server"+process.cwd()),Xi.default.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Xi.default.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=Nz.default.isMaster,await zSe();let t=e.securePort>0;rf=jSe(t),await rf.ready(),e||(e={}),e.isOperationsServer=!0;try{Ye.http(rf.server,e),rf.server.closeIdleConnections||await rf.listen({port:0,host:"::"})}catch(r){throw rf.close(),Xi.default.error(r),Xi.default.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),Xi.default.fatal(t),process.exit(1)}}a(Oz,"operationsServer");async function zSe(){Xi.default.trace("Configuring HarperDB process."),vz.default.setSchemaDataToGlobal(),await xz.default.setUsersWithRolesCache(),await Bz.default.getLicense()}a(zSe,"setUp");function jSe(e){Xi.default.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=JSe(e),r=(0,wz.default)(t);r.server.headersTimeout=XSe(),r.setErrorHandler(lc.serverErrorHandler);let n=QSe();n&&r.register(Iz.default,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,u){r.server.emit("unhandled",l.raw,u.raw)}),c()}),r.register(Dz.default),r.register(Cz.default),r.register(Pz.default,{root:Lz.default.join(Mz.PACKAGE_ROOT,"studio/build-local")}),jf(r);let s=cc.default.get(zA.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!Uz.default.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[lc.reqBodyValidationHandler,lc.authHandler],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),(0,lc.handlePostRequest)(i,o)}),r.get("/health",()=>"HarperDB is running."),Xi.default.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(jSe,"buildServer");function JSe(e){let t=cc.default.get(wh.OPERATIONSAPI_NETWORK_TIMEOUT),r=cc.default.get(wh.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:YSe,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(JSe,"getServerOptions");function QSe(){let e=cc.default.get(wh.OPERATIONSAPI_NETWORK_CORS),t=cc.default.get(wh.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===WSe)&&(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(QSe,"getCORSOpts");function XSe(){return cc.default.get(wh.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??KSe}a(XSe,"getHeaderTimeoutConfig")});var sP={};ve(sP,{disableNATS:()=>eTe,publishToStream:()=>jT,setNATSReplicator:()=>ZC,setPublishToStream:()=>tTe,setSubscription:()=>nP,start:()=>ZSe});function ZSe(){Ih.default.get(B.CLUSTERING_ENABLED)&&nTe()}function eTe(e=!0){Vz=e}function tTe(e,t){jT=e,nP=t}function nTe(){if(Vz||process.env._DISABLE_NATS)return;let e=Qe(),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];ZC(s,r,i)}}ml((r,n)=>{ZC(r.tableName,r.databaseName,r),n&&Yz(r)}),!Fz&&(Fz=!0)}function ZC(e,t,r){if(t==="system"&&sTe.includes(e))return;if(!r)return console.error(`Attempt to replicate non-existent table ${e} from database ${t}`);if(r.sources.some(s=>s?.isNATSReplicator))return;r.sourcedFrom(class extends $r{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this.getId(),record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this.getId()})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this.getId(),record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this.getId(),record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this.getId()})}static defineSchema(i){Yz(i)}static subscribe(){let i=new xn;return nP(t,e,i),i}static subscribeOnThisThread(i){return i<(Ih.default.get(B.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??rTe)}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 WT(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=Kz;return i}a(n,"getNATSTransaction")}function Yz(e){let t=Ih.default.get(B.CLUSTERING_NODENAME);jT(`${tP.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,rP.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 Gz,tP,rP,qz,$z,Ih,zT,Vz,jT,nP,rTe,Kz,Fz,sTe,WT,eP,Wz=be(()=>{Pe();Ea();Gz=M(ir()),tP=M(Tt()),rP=M(Eo());_u();qz=M(UO()),$z=M(_n()),Ih=M(ae());H();zT=M(z());a(ZSe,"start");a(eTe,"disableNATS");jT=Gz.publishToStream,nP=qz.setSubscription;a(tTe,"setPublishToStream");rTe=2;a(nTe,"assignReplicationSource");sTe=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(ZC,"setNATSReplicator");a(Yz,"publishSchema");WT=class{constructor(t,r){this.transaction=t;this.options=r}static{a(this,"NATSTransaction")}user;writes_by_db=new Map;addWrite(t,r){r.expiresAt=this.context?.expiresAt;let n=this.writes_by_db.get(t);n||this.writes_by_db.set(t,n=[]),n.push(r)}commit({timestamp:t}){let r=Ih.default.get(B.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],l,u;for(let f of i){let d=f.table,p=f.operation=="put"?"upsert":f.operation;l||(zT.trace(`Sending transaction event ${p}`),u=l={operation:p,schema:s,table:d,__origin:{user:this.user?.username,timestamp:t,node_name:r}},l.hash_values=c,p!=="delete"&&p!=="invalidate"&&(l.records=o)),l.table===d&&l.operation===p?(o.push(f.record),c.push(f.id)):u=u.next={operation:p,table:d,id:f.id,record:f.record},f.expiresAt&&(u.expiresAt=f.expiresAt)}l&&n.push(jT(`${tP.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,rP.createNatsTableStreamName)(s,l.table),void 0,l)?.catch(f=>{throw zT.error("An error has occurred trying to replicate transaction",l,f),f.statusCode=504,f}))}return Promise.all(n)}},eP=class extends WT{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,$z.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};Kz=new eP});async function Xz({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await iP.get(e,{returnNonexistent:!0});i=new cP(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await iP.get(e);o&&o.delete()}i=new QT(e,t)}return n&&(n.id=e,n.user={username:t?.username},Ch.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function oP(){return JT++,JT>65500&&(JT=1),JT}function aP(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=Oi.getMatch(n,"mqtt");if(!i)throw new Error(`Can not publish to topic ${n} as it does not exist, no resource has been defined to handle this topic`);e.url=i.relativeURL;let o=i.Resource;return Nt(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var jz,uc,Jz,Qz,zz,iP,Ch,JT,QT,cP,Zz=be(()=>{Pe();Su();jz=M(_n()),uc=M(z());bc();Jz=M(et()),Qz=M(YC());Vr();zz=100,iP=ft({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),Ch=ft({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,Jz.getWorkerIndex)()===0&&(async()=>{await Qz.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of Ch.search({})){let t=e.data,r={...e};r.user?.username&&(r.user=await Ye.getUser(r.user.username));try{await aP(r,t,r)}catch{(0,uc.warn)("Failed to publish will",t)}Ch.delete(e.id)}})();a(Xz,"getSession");JT=1;a(oP,"getNextMessageId");QT=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;request;socket;subscriptions=[];awaitingAcks;sessionWasPresent;keepalive;keepaliveTimer;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),l,u;if(c>-1?(l=s.slice(c),u=s.slice(0,c)):u=s,!u)throw new Error("No topic provided");if(u.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let f=this.subscriptions.find(R=>R.topic===s),d;f?(d=i>0,f.end(),this.subscriptions.splice(this.subscriptions.indexOf(f),1)):d=i===2;let p={search:l,async:!0,user:this.user,startTime:o,omitCurrent:d,url:""};o&&(0,uc.trace)("Resuming subscription from",s,"from",o);let _=Oi.getMatch(u,"mqtt");if(!_){let R=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw R.statusCode=404,R}if(p.url=_.relativeURL,p.url.indexOf("+")>-1||p.url.indexOf("#")>-1){let R=p.url.slice(1);if(R.indexOf("#")>-1&&R.indexOf("#")!==R.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(p.isCollection=!0,R.indexOf("+")===R.length-1)p.onlyChildren=!0,p.url="/"+R.slice(0,R.length-1);else{let E=R.split("/"),T;for(let F=0;F<E.length;F++)if(E[F].indexOf("+")>-1)if(E[F]==="+")T=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&T)throw new Error("Filters can not be combined");let b=!0;E[E.length-1]==="#"&&(E.length--,b=!1),T&&(n=a(F=>{let q=F.id;if(!Array.isArray(q))if(q?.indexOf?.("/")>-1)q=q.split("/");else return!1;if(b&&q.length!==E.length)return!1;for(let Y=0;Y<E.length;Y++)if(E[Y]!=="+"&&E[Y]!==q[Y])return!1;return!0},"filter"));let v=E.indexOf("+");p.url="/"+(v>-1?E.slice(0,v):E).concat("").join("/")}}let h=_.path,S=_.Resource,g=await Nt(p,async()=>{let R=this.createContext();R.topic=s,R.retainHandling=i;let E=await S.subscribe(p,R);if(!E)return;if(!E[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let T=(async()=>{for await(let b of E)try{let v;if(b.type&&b.type!=="put"&&b.type!=="delete"&&b.type!=="message"&&b.type!=="patch"||n&&!n(b))continue;r?(b.topic=s,v=this.needsAcknowledge(b)):(b.acknowledge?.(),v=oP());let F=b.id;if(Array.isArray(F)&&(F=gu(F)),F==null&&(F=""),await this.listener(h+"/"+F,b.value,v,t)===!1)break;this.awaitingAcks?.size>zz?await new Promise(Y=>setTimeout(Y,this.awaitingAcks.size-zz)):await new Promise(setImmediate)}catch(v){(0,uc.warn)(v)}})();return E});if(g)return g.topic=s,g.qos=t.qos,this.subscriptions.push(g),g}resume(){}needsAcknowledge(t){let r=oP();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 aP(t,r,this.createContext())}createContext(){let t={session:this,socket:this.socket,user:this.user,authorize:!0};return this.request&&(t.request=this.request,t.url=this.request.url,t.headers=this.request.headers),t}setListener(t){this.listener=t}disconnect(t){this.keepaliveTimer&&clearTimeout(this.keepaliveTimer);let r=this.createContext();Nt(r,async()=>{try{if(!t){let n=await Ch.get(this.sessionId);n?.doesExist()&&await aP(n,n.data,r)}}finally{await Ch.delete(this.sessionId)}}).catch(n=>{(0,uc.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(aP,"publish");cP=class extends QT{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=oP(),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,uc.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,jz.getNextMonotonicTime)()),(0,uc.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),iP.put(this.sessionRecord)}}});var uP={};ve(uP,{bypassAuth:()=>iTe,start:()=>oTe});function iTe(){sj=!0}function oTe({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new nj.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c=[],l=r?.mtls;return n&&(c=e.ws((u,f,d,p)=>{if(f.headers.get("sec-websocket-protocol")!=="mqtt")return p(u,f,d);o.events.emit("connection",u),hr.debug?.("Received WebSocket connection for MQTT from",u._socket.remoteAddress);let{onMessage:_,onClose:h}=tj(u,S=>{u.send(S)},f,Promise.resolve(d).then(()=>f?.user),o);u.on("message",_),u.on("close",h),u.on("error",S=>{hr.info?.("WebSocket error",S)})},{...n})),(t||s)&&c.push(e.socket(async u=>{let f;if(o.events.emit("connection",u),hr.debug?.(`Received ${u.getCertificate?"SSL":"TCP"} connection for MQTT from ${u.remoteAddress}`),l){if(u.authorized)try{let _=l.user;if(_!==null){(_===void 0||_==="Common Name"||_==="CN")&&(_=u.getPeerCertificate().subject.CN);try{f=await e.getUser(_,null,null),(0,nf.get)(B.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ZT.notify?.({username:f?.username,status:Ys.SUCCESS,type:la.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:u.remoteAddress})}catch(h){throw(0,nf.get)(B.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ZT.error?.({username:_,status:Ys.FAILURE,type:la.AUTHENTICATION,auth_strategy:"mqtt",remote_address:u.remoteAddress}),h}}else hr.debug?.("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",u.remoteAddress)}catch(_){o.events.emit("error",_,u),hr.error?.(_)}else if(l.required)return hr.info?.(`Unauthorized connection attempt, no authorized client certificate provided, error: ${u.authorizationError}`),u.end()}!f&&sj&&u.remoteAddress.includes("127.0.0.1")&&(f=await(0,rj.getSuperUser)(),hr.debug?.("Auto-authorizing local connection",f?.username));let{onMessage:d,onClose:p}=tj(u,_=>u.write(_),null,f,o);u.on("data",d),u.on("close",p),u.on("error",_=>{hr.info?.("Socket error",_)})},{port:t,securePort:s,mtls:l})),c}function tj(e,t,r,n,s){ej||(ej=!0,Y_(d=>{XT>0&&d.push({metric:"mqtt-connections",connections:XT,byThread:!0})}));let i;XT++;let o,c={protocolVersion:4},l=(0,eA.parser)({protocolVersion:5});function u(d){l.parse(d)}a(u,"onMessage");function f(){XT--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),Qn(!1,"connection","mqtt","disconnect"),hr.debug?.("MQTT connection was closed",e.remoteAddress))}return a(f,"onClose"),l.on("packet",async d=>{n?.then&&(n=await n);let p=d.cmd;if(o)o.then&&await o;else if(p!=="connect"){hr.info?.("Received packet before connection was established, closing connection"),e?.destroy?e.destroy():e?.terminate();return}let _=d.topic,h=_?.indexOf("/",1),S=h>0?_.slice(0,h):_;sr(d.length,"bytes-received",S,R(d),"mqtt");try{switch(o?.receivedPacket?.(),p){case"connect":if(c.protocolVersion=d.protocolVersion,d.username)try{n=await Ye.getUser(d.username,d.password.toString(),r),(0,nf.get)(B.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ZT.notify?.({username:n?.username,status:Ys.SUCCESS,type:la.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(se){return(0,nf.get)(B.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ZT.error?.({username:d.username,status:Ys.FAILURE,type:la.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",d,e,se),Qn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",d,e),Qn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(d,n),d.will){let se=e.deserialize||(e.deserialize=uo(r?.headers.get?.("content-type")));d.will.data=d.will.payload?.length>0?se(d.will.payload):void 0,delete d.will.payload}o=Xz({user:n,...d}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(se){return hr.error?.(se),s.events.emit("auth-failed",d,e,se),Qn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:se.code||5,returnCode:se.code||128})}s.events.emit("connected",o,e),Qn(!0,"connection","mqtt","connect"),g({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0});let T=a(async(se,Q,ne,J)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",se);let he=se.indexOf("/",1),Re=he>0?se.slice(0,he):se;g({cmd:"publish",topic:se,payload:await E(Q),messageId:ne||Math.floor(Math.random()*1e8),qos:J.qos},Re);let Ce=e._socket??e;return Ce.writableNeedDrain?new Promise(me=>Ce.once("drain",me)):!Ce.closed}catch(he){return hr.error?.(he),o?.disconnect(),s.sessions.delete(o),!1}},"listener");o.setListener(T),o.sessionWasPresent&&await o.resume();break;case"subscribe":let b=[];for(let se of d.subscriptions){let Q;try{let ne=await o.addSubscription(se,se.qos>=1);Q=ne?ne.qos||0:c.protocolVersion<5?128:143}catch(ne){s.events.emit("error",ne,e,se,o),ne.statusCode?ne.statusCode===500?hr.warn?.(ne):hr.info?.(ne):hr.error?.(ne),Q=c.protocolVersion<5?128:ne.statusCode===403?135:ne.statusCode===404?143:128}b.push(Q)}await o.committed,g({cmd:"suback",granted:b,messageId:d.messageId});break;case"unsubscribe":{let se=[];for(let Q of d.unsubscriptions)se.push(o.removeSubscription(Q)?0:17);g({cmd:"unsuback",granted:se,messageId:d.messageId});break}case"pubrel":g({cmd:"pubcomp",messageId:d.messageId,reasonCode:0});return;case"publish":let v=d.qos===2?"pubrec":"puback",F=e.deserialize||(e.deserialize=uo(r?.headers.get?.("content-type"))),Y=(d.payload?.length||0)>0?F(d.payload):void 0,Z;try{Z=await o.publish(d,Y)}catch(se){s.events.emit("error",se,e,d,o),hr.warn?.(se),d.qos>0&&g({cmd:v,messageId:d.messageId,reasonCode:128},d.topic);break}d.qos>0&&g({cmd:v,messageId:d.messageId,reasonCode:Z===!1?144:0},d.topic);break;case"pubrec":g({cmd:"pubrel",messageId:d.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(d.messageId);break;case"pingreq":g({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),Qn(!0,"connection","mqtt","disconnect"),hr.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(T){s.events.emit("error",T,e,d,o),hr.error?.(T),g({cmd:"disconnect"})}function g(T,b){let v=(0,eA.generate)(T,c);t(v),sr(v.length,"bytes-sent",b,R(T),"mqtt")}a(g,"sendPacket");function R(T){return T.qos>0?T.cmd+",qos="+T.qos:T.cmd}a(R,"packetMethodName");function E(T){return Aa(T,r)}a(E,"serialize")}),l.on("error",d=>{hr.warn("MQTT parsing error, closing connection:",d.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:u,onClose:f}}var eA,rj,nf,lP,nj,ZT,hr,sj,ej,XT,ij=be(()=>{eA=require("mqtt-packet");Zz();rj=M(An());ao();ki();Vr();nf=M(ae());H();lP=M(Ni()),nj=require("events"),ZT=(0,lP.loggerWithTag)("auth-event"),hr=(0,lP.loggerWithTag)("mqtt"),sj=(0,nf.get)(B.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(iTe,"bypassAuth");a(oTe,"start");XT=0;a(tj,"onSocket")});var zp={};ve(zp,{component_errors:()=>of,getComponentName:()=>dTe,loadComponent:()=>nA,loadComponentDirectories:()=>uj,setErrorReporter:()=>uTe});function uj(e,t){t&&(fP=t),e&&(mP=e);let r=[];if((0,lt.existsSync)(dP)){let s=(0,lt.readdirSync)(dP,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,St.join)(dP,o);r.push(nA(c,fP,VA,!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(nA(n,fP,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{lj=!0})}function uTe(e){Ph=e}async function nA(e,t,r,n,s,i){let o=(0,lt.realpathSync)(e);if(tA.has(o))return tA.get(o);tA.set(o,!0),s&&(mP=s);try{let c;n&&(of=new Map);let l=(0,St.join)(e,"harperdb-config.yaml");(0,lt.existsSync)(l)?c=n?(0,sA.getConfigObj)():(0,_P.parseDocument)((0,lt.readFileSync)(l,"utf8")).toJSON():!n&&(0,lt.existsSync)(l=(0,St.join)(e,"config.yaml"))?c=(0,_P.parseDocument)((0,lt.readFileSync)(l,"utf8")).toJSON():c=EP;let u=(0,St.join)(e,"node_modules","harperdb");try{Yl.isMainThread&&(n||((0,lt.existsSync)(u)||!e.startsWith((0,hP.getHdbBasePath)()))&&(!(0,lt.existsSync)(u)||(0,lt.realpathSync)(pP.PACKAGE_ROOT)!==(0,lt.realpathSync)(u)))&&((0,lt.rmSync)(u,{recursive:!0,force:!0}),(0,lt.existsSync)((0,St.join)(e,"node_modules"))||(0,lt.mkdirSync)((0,St.join)(e,"node_modules")),(0,lt.symlinkSync)(pP.PACKAGE_ROOT,u,"dir"))}catch(p){sf.default.error("Error symlinking harperdb module",p)}let f=rA,d=n;for(let p in c){rA=p;let _=c[p];if(of.set(n?p:(0,St.basename)(e),!1),!_)continue;let h,S=_.package;try{if(S){let b=e,v;for(;!(0,lt.existsSync)(v=(0,St.join)(b,"node_modules",p));)if(b=(0,St.dirname)(b),b.length<(0,hP.getHdbBasePath)().length){v=null;break}if(v)h=await nA(v,t,r,!1),d=!0;else throw new Error(`Unable to find package ${p}:${S}`)}else h=lTe[p];if(!h)continue;let g=a(b=>(b.origin=r,ft(b)),"ensureTable"),R=_.network||(_.port||_.securePort)&&_,E=R?.securePort||R?.https&&R.port,T=!R?.https&&R?.port;if(Yl.isMainThread&&(h=await h.startOnMainThread?.({server:Ye,ensureTable:g,port:T,securePort:E,resources:t,..._})||h,n&&R))for(let b of[T,E])try{if(+b&&!oj.includes(b)){let v=gP.get(B.HTTP_SESSIONAFFINITY);v&&sf.default.warn("Session affinity is not recommended and may cause memory leaks"),(v||!ET)&&(oj.push(b),QC(b,v))}}catch(v){console.error("Error listening on socket",b,v,p)}if(t.isWorker&&(h=await h.start?.({server:Ye,ensureTable:g,port:T,securePort:E,resources:t,..._})||h),mP.set(h,!0),(h.handleFile||h.handleDirectory||h.setupFile||h.setupDirectory)&&_.files!=null){if(_.files.includes(".."))throw(0,cj.handleHDBError)("Can not reference parent directories");let b=(0,St.join)(e,_.files).replace(/\\/g,"/"),v=b.indexOf("/*");if(v>-1&&_.files!==EP[p]?.files&&!(0,lt.existsSync)(b.slice(0,v)))throw new Error(`The path '${b.slice(0,v)}' does not exist and cannot be used as the base of the resolved 'files' path value '${_.files}'`);let F=(0,St.basename)(e),q=_.path||"/";q=q.startsWith("/")?q:q.startsWith("./")?"/"+F+q.slice(2):q==="."?"/"+F:"/"+F+"/"+q;let Y,Z,se;if(_.root){let ne=_.root;ne.startsWith("/")&&(ne=ne.slice(1)),ne.endsWith("/")&&(ne=ne.slice(0,-1)),ne+="/",Z=(0,St.join)(e,ne)}else(se=b.indexOf("/*"))>-1?(Z=b.slice(0,se+1),Y=(0,St.relative)(e,Z)):_.files.indexOf("/")>-1&&(Z=b.slice(0,b.lastIndexOf("/")+1),Y=(0,St.relative)(e,Z));let Q=!1;if(Yl.isMainThread&&h.setupDirectory&&(Q=await h.setupDirectory?.(q,Z,t)),t.isWorker&&h.handleDirectory&&(Q=await h.handleDirectory?.(q,Z,t)),Q){d=!0;continue}for(let ne of await(0,aj.default)(b,{onlyFiles:!1,objectMode:!0})){let{path:J,dirent:he}=ne;d=!0;let Re=(0,St.relative)(e,J).replace(/\\/g,"/");if(Y)if(Re.startsWith(Y))Re=Re.slice(Y.length+1);else throw new Error(`The root path '${_.root}' does not reference a valid part of the file path '${Re}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let Ce=q+(q.endsWith("/")?"":"/")+Re;try{if(he.isFile()){let me=await cTe(J);Yl.isMainThread&&await h.setupFile?.(me,Ce,J,t),t.isWorker&&await h.handleFile?.(me,Ce,J,t)}else Yl.isMainThread&&await h.setupDirectory?.(Ce,J,t),t.isWorker&&await h.handleDirectory?.(Ce,J,t)}catch(me){me.message=`Could not load ${he.isFile()?"file":"directory"} '${J}'${_.module?" using '"+_.module+"'":""} for application '${e}' due to: ${me.message}`,Ph?.(me),((0,af.getWorkerIndex)()===0?console:sf.default).error(me),t.set(_.path||"/",new ga(me)),of.set(n?p:(0,St.basename)(e),me.message)}}}}catch(g){g.message=`Could not load component '${p}' for application '${(0,St.basename)(e)}' due to: ${g.message}`,Ph?.(g),((0,af.getWorkerIndex)()===0?console:sf.default).error(g),t.set(_.path||"/",new ga(g),null,!0),of.set(n?p:(0,St.basename)(e),g.message)}}if(rA=f,Yl.isMainThread&&!lj&&i&&(0,af.watchDir)(e,async()=>uj()),c.extensionModule){let p=await zE((0,St.join)(e,c.extensionModule));return tA.set(o,p),p}if(!d&&t.isWorker){let p=`${e} did not load any modules, resources, or files, is this a valid component?`;Ph?.(new Error(p)),((0,af.getWorkerIndex)()===0?console:sf.default).error(p),of.set((0,St.basename)(e),p)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,Ph?.(c),t.set("",new ga(c))}}var lt,St,Yl,_P,gP,pP,aj,af,sf,cj,hP,aTe,sA,cTe,dP,mP,lj,fP,of,lTe,EP,oj,tA,Ph,rA,dTe,jp=be(()=>{lt=require("fs"),St=require("path"),Yl=require("worker_threads"),_P=require("yaml"),gP=M(ae()),pP=M(st());H();BL();TM();jB();ZB();eH();xH();EY();yY();OY();aj=M(require("fast-glob")),af=M(et()),sf=M(z());iO();Vr();cj=M(pe());Pe();xC();hP=M(ae()),aTe=M(kz());MS();Wz();Xn();ij();sA=M(yt());XI();gR();({readFile:cTe}=lt.promises),dP=(0,sA.resolvePath)(gP.get(B.COMPONENTSROOT)),mP=new Map,of=new Map;a(uj,"loadComponentDirectories");lTe={REST:eg,rest:eg,graphql:BR,graphqlSchema:AR,roles:sO,jsResource:aO,fastifyRoutes:YI,login:lO,static:WI,operationsApi:aTe,customFunctions:{},http:{},clustering:sP,replication:wo,authentication:Gp,mqtt:uP,loadEnv:zI},EP={rest:!0,graphqlSchema:{files:"*.graphql"},roles:{files:"roles.yaml"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(EP,"static",{value:{files:"web/**"}});oj=[],tA=new Map;a(uTe,"setErrorReporter");dTe=a(()=>rA,"getComponentName");a(nA,"loadComponent")});var qT=w((O0e,fj)=>{var{isMainThread:dj}=require("worker_threads"),{getTables:fTe,getDatabases:y0e,table:b0e}=(Pe(),C(tt)),{loadComponentDirectories:_Te,loadComponent:pTe}=(jp(),C(zp)),{resetResources:hTe}=(Su(),C(ML)),mTe=qw(),ETe=yt(),{dirname:gTe}=require("path"),{getConnection:STe}=ir(),TTe=ae(),{CONFIG_PARAMS:ATe}=(H(),C(G)),{loadCertificates:RTe}=Zn(),SP=new Map;async function yTe(e=!1){!dj&&TTe.get(ATe.CLUSTERING_ENABLED)&&STe();try{dj&&await mTe()}catch(n){console.error(n)}let t=hTe();fTe(),t.isWorker=e,await RTe(),await pTe(gTe(ETe.getConfigFilePath()),t,"hdb",!0,SP),await _Te(SP,t);let r=[];for(let[n]of SP)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(yTe,"loadRootComponents");fj.exports.loadRootComponents=yTe});var et=w((w0e,Si)=>{"use strict";rm();var{Worker:bTe,MessageChannel:OTe,parentPort:Zi,isMainThread:bP,threadId:NTe,workerData:eo}=require("worker_threads"),{PACKAGE_ROOT:wTe}=st(),{join:mj,isAbsolute:ITe,extname:CTe}=require("path"),{server:Ej}=(Vr(),C(Tu)),{watch:PTe,readdir:DTe}=require("fs/promises"),{totalmem:_j}=require("os"),cf=(H(),C(G)),gj=ae(),gi=z(),{randomBytes:LTe}=require("crypto"),{_assignPackageExport:MTe}=Ti(),pj=1024*1024,dc=[],Hs=[],vTe=50,OP=1e4,UTe="restart",Sj="request_thread_info",Tj="resource_report",Aj="thread_info",Rj="added-port",xTe="ack",TP;MTe("threads",Hs);Si.exports={startWorker:AP,restartWorkers:wP,shutdownWorkers:GTe,workers:dc,setMonitorListener:jTe,onMessageFromWorkers:qTe,onMessageByType:Cj,broadcast:VTe,broadcastWithAcknowledgement:YTe,setChildListenerByType:FTe,getWorkerIndex:yj,getWorkerCount:bj,getTicketKeys:Nj,setMainIsWorker:HTe,setTerminateTimeout:BTe,restartNumber:eo?.restartNumber||1};Hs.onMessageByType=Cj;Hs.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=Hs.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};Si.exports.whenThreadsStarted=new Promise(e=>{Si.exports.threadsHaveStarted=e});var NP;function BTe(e){OP=e}a(BTe,"setTerminateTimeout");function yj(){return eo?eo.workerIndex:NP?0:void 0}a(yj,"getWorkerIndex");function bj(){return eo?eo.workerCount:NP?1:void 0}a(bj,"getWorkerCount");function HTe(e){NP=e,Si.exports.threadsHaveStarted()}a(HTe,"setMainIsWorker");var Oj=1,iA;function Nj(){return iA||(iA=bP?LTe(48):eo.ticketKeys,iA)}a(Nj,"getTicketKeys");Object.defineProperty(Ej,"workerIndex",{get(){return yj()}});Object.defineProperty(Ej,"workerCount",{get(){return bj()}});var wj={[Sj](e,t){WTe(t)},[Tj](e,t){zTe(t,e)}};function AP(e,t={}){let r=process.constrainedMemory?.()||_j();r=Math.min(r,_j(),2e4*pj);let n=gj.get(cf.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/pj/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let l of Hs){let u=new OTe;u.existingPort=l,i.push(u),o.push(u.port2)}CTe(e)||(e+=".js");let c=new bTe(ITe(e)?e:mj(wTe,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:Oj=t.threadCount,name:t.name,restartNumber:Si.exports.restartNumber,ticketKeys:Nj()},transferList:o,...t});for(let{port1:l,existingPort:u}of i)u.postMessage({type:Rj,port:l,threadId:c.threadId},[l]);return aA(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>AP(e,t),c.on("error",l=>{gi.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{dc.splice(dc.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<vTe?(t.unexpectedRestarts=c.unexpectedRestarts+1,AP(e,t)):gi.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{wj[l.type]?.(l,c)}),dc.push(c),QTe(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(AP,"startWorker");var kTe=[cf.THREAD_TYPES.HTTP];async function wP(e=null,t=Math.max(Oj>3,1),r=!0){if(bP){try{process.chdir(process.cwd())}catch(o){gi.error("Unable to reestablish current working directory",o)}if(r){let{loadRootComponents:o}=qT();await o()}Si.exports.restartNumber++,t<1&&(t=t*dc.length);let n=[],s=[];for(let o of dc.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;gi.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:Si.exports.restartNumber,type:cf.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=kTe.indexOf(o.name)>-1,l=new Promise(u=>{let f=setTimeout(()=>{gi.warn("Thread did not voluntarily terminate, terminating from the outside",o.threadId),o.terminate()},OP*2).unref();o.on("exit",()=>{clearTimeout(f),n.splice(n.indexOf(l)),!c&&r&&o.startCopy(),u()})});if(n.push(l),c&&r){let u=o.startCopy(),f=new Promise(d=>{let p=a(_=>{_.type===cf.ITC_EVENT_TYPES.CHILD_STARTED&&(gi.trace("Worker has started",u.threadId),d(),s.splice(s.indexOf(f)),u.off("message",p))},"startListener");gi.trace("Waiting for worker to start",u.threadId),u.on("message",p)});s.push(f),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=Wa();r&&(e==="http"||!e)&&gj.get(cf.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else Zi.postMessage({type:UTe,workerType:e})}a(wP,"restartWorkers");function FTe(e,t){wj[e]=t}a(FTe,"setChildListenerByType");function GTe(e){return wP(e,1/0,!1)}a(GTe,"shutdownWorkers");var Ij=[];function qTe(e){Ij.push(e)}a(qTe,"onMessageFromWorkers");var RP=new Map;function Cj(e,t){let r=RP.get(e);r||RP.set(e,r=[]),r.push(t)}a(Cj,"onMessageByType");var $Te=10;async function VTe(e,t){let r=0;for(let n of Hs)try{n.postMessage(e),r++>$Te&&(r=0,await new Promise(setImmediate))}catch(s){gi.error("Unable to send message to worker",s)}t&&Dj(e,null)}a(VTe,"broadcast");var oA=new Map,KTe=1;function YTe(e){return new Promise(t=>{let r=0;for(let n of Hs)try{let s=KTe++,i=a(()=>{oA.delete(s),--r===0&&t(),n!==Zi&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,oA.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of oA)o.port===n&&o()})),n.postMessage(e),r++}catch(s){gi.error("Unable to send message to worker",s)}r===0&&t()})}a(YTe,"broadcastWithAcknowledgement");function WTe(e){e.postMessage({type:Aj,workers:Pj()})}a(WTe,"sendThreadInfo");function Pj(){let e=Date.now();return dc.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(Pj,"getChildWorkerInfo");function zTe(e,t){e.resources=t,e.resources.updated=Date.now()}a(zTe,"recordResourceReport");var yP;function jTe(e){yP=e}a(jTe,"setMonitorListener");var JTe=1e3,hj=!1;function QTe(){hj||(hj=!0,setInterval(()=>{for(let e of dc){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}yP&&yP()},JTe).unref())}a(QTe,"startMonitoring");var XTe=1e3;if(Zi&&eo?.addPorts){aA(Zi);for(let e=0,t=eo.addPorts.length;e<t;e++){let r=eo.addPorts[e];r.threadId=eo.addThreadIds[e],aA(r)}setInterval(()=>{let e=process.memoryUsage();Zi.postMessage({type:Tj,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},XTe).unref(),TP=a(()=>new Promise((e,t)=>{Zi.on("message",r),Zi.postMessage({type:Sj});function r(n){n.type===Aj&&(Zi.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else TP=Pj;Si.exports.getThreadInfo=TP;function aA(e,t){Hs.push(e),e.on("message",r=>{if(r.type===Rj)r.port.threadId=r.threadId,aA(r.port);else if(r.type===xTe){let n=oA.get(r.id);n&&n()}else Dj(r,e)}).on("close",()=>{Hs.splice(Hs.indexOf(e),1)}).on("exit",()=>{Hs.splice(Hs.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(aA,"addPort");function Dj(e,t){for(let n of Ij)n(e,t);let r=RP.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){gi.error(s)}}a(Dj,"notifyMessageListeners");if(bP){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await DTe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(mj(s,o.name));try{for await(let{filename:o}of PTe(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await wP(),console.log("Reloaded HarperDB components, changed files:",Array.from(r)),r.clear()},100)}catch(o){console.warn("Error trying to watch component directory",s,o)}},"watch_dir");Si.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else Zi.on("message",async e=>{let{type:t}=e;t===cf.ITC_EVENT_TYPES.SHUTDOWN&&(Si.exports.restartNumber=e.restartNumber,Zi.unref(),setTimeout(()=>{gi.warn("Thread did not voluntarily terminate",NTe),process.exit(0)},OP).unref())})});var pB={};ve(pB,{ACTION_32_BIT:()=>Wm,ACTION_64_BIT:()=>tAe,AUDIT_STORE_OPTIONS:()=>xp,Decoder:()=>hl,HAS_BLOBS:()=>Fn,HAS_CURRENT_RESIDENCY_ID:()=>Uc,HAS_EXPIRATION_EXTENDED_TYPE:()=>n_,HAS_ORIGINATING_OPERATION:()=>r_,HAS_PREVIOUS_RESIDENCY_ID:()=>xc,REMOTE_SEQUENCE_UPDATE:()=>Mg,createAuditEntry:()=>Ou,getLastRemoved:()=>SN,openAuditStore:()=>uA,readAuditEntry:()=>wt,removeAuditEntry:()=>dA,setAuditRetention:()=>eAe,transactionKeyEncoder:()=>Fj});function uA(e){let t=e.auditStore=e.openDB(IP.AUDIT_STORE_NAME,{create:!1,...xp});t||(t=e.auditStore=e.openDB(IP.AUDIT_STORE_NAME,xp),Mj(t,1)),t.rootStore=e,t.tableStores=[];let r=[];t.addDeleteRemovalCallback=function(l,u,f){return r[l]=f,t.tableStores[l]=u,t.deleteCallbacks=r,{remove(){delete r[l]}}};let n=null,s,i=0,o=PP;Ah(t.env.path,l=>{if(i=l,l)return c(100)});function c(l){l&&(o=l),clearTimeout(n);let u=new Promise(f=>{n=setTimeout(async()=>{if(await s,s=u,t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let d=0,p,_;try{for(let{key:h,value:S}of t.getRange({start:1,snapshot:!1,end:Date.now()-CP/(1+i*i)})){try{p=dA(t,h,S)}catch(g){lf.warn("Error removing audit entry",g)}if(_=h,await new Promise(setImmediate),++d>=ZTe){o=10;break}}await p}finally{d===0?o=Math.min(o<<1,CP/10):(Mj(t,_),o>100&&(o=o>>1)),f(void 0),c()}},o).unref()});return u}if(a(c,"scheduleAuditCleanup"),t.scheduleAuditCleanup=c,(0,Lh.getWorkerIndex)()===(0,Lh.getWorkerCount)()-1&&c(),(0,Lh.getWorkerIndex)()===0&&!Lj)for(let l of t.getKeys({reverse:!0,limit:1}))l>Date.now()&&(Lj=!0,lf.error("The current time is before the last recorded entry in the audit log. Time reversal can undermine the integrity of data tracking and certificate validation and the time must be corrected."));return t}function dA(e,t,r){let n=rAe(r),s;if(n&Fn){s=wt(r);let i=e.tableStores[s.tableId],o=i.getEntry(s.recordId);(!o||o.version!==s.version||!o.value)&&Pc(()=>Ta(s.getValue(i)),i.rootStore)}if((n&15)===DP){s=s||wt(r);let i=s.tableId;e.tableStores[s.tableId].getEntry(s.recordId).version===s.version&&e.deleteCallbacks?.[i]?.(s.recordId,s.version)}return e.remove(t)}function Mj(e,t){LP[0]=t,e.put(Symbol.for("last-removed"),Gj)}function SN(e){let t=e.get(Symbol.for("last-removed"));if(t)return Gj.set(t),LP[0]}function eAe(e,t=PP){CP=e,PP=t}function Ou(e,t,r,n,s,i,o,c,l,u,f,d,p){let _=qj[o];if(!_)throw new Error(`Invalid audit entry type ${o}`);let h=1;if(n&&(n>1?fc.setFloat64(0,n):ks.set(WR),h=9),l){if(l&255)throw new Error("Illegal extended type");h+=3}R(s),R(t),g(r),fc.setFloat64(h,e),h+=8,l&Uc&&R(u),l&xc&&R(f),l&n_&&(fc.setFloat64(h,d),h+=8),l&r_&&R($j[p]),i?g(i):ks[h++]=0,l?fc.setUint32(n?8:0,_|l|3221225472):ks[n?8:0]=_;let S=ks.subarray(0,h);if(c)return Buffer.concat([S,c]);return S;function g(E){let T=h;h+=1,h=(0,Wl.writeKey)(E,ks,h);let b=h-T-1;b>127?b>16383?(lf.error("Key or username was too large for audit entry",E),h=T+1,ks[T]=0):(ks.copyWithin(T+2,T+1,h),fc.setUint16(T,b|32768),h++):ks[T]=b}function R(E){E<128?ks[h++]=E:E<16384?(fc.setUint16(h,E|32768),h+=2):E<1056964608?(fc.setUint32(h,E|3221225472),h+=4):(ks[h]=255,fc.setUint32(h+1,E),h+=5)}}function rAe(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 hl(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function wt(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new hl(e.buffer,e.byteOffset,e.byteLength));n.position=t;let s;e[n.position]==66&&(s=n.readFloat64());let i=n.readInt(),o=n.readInt(),c=n.readInt(),l=n.readInt(),u=n.position,f=n.position+=l,d=n.readFloat64(),p,_,h,S;if(i&Uc&&(p=n.readInt()),i&xc&&(_=n.readInt()),i&n_&&(h=n.readFloat64()),i&r_){let T=n.readInt();S=$j[T]}l=n.readInt();let g=n.position,R=n.position+=l,E;return{type:qj[i&7],tableId:c,nodeId:o,get recordId(){return(0,Wl.readKey)(e,u,f)},getBinaryRecordId(){return e.subarray(u,f)},version:d,previousLocalTime:s,get user(){return R>g?(0,Wl.readKey)(e,g,R):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(T,b,v){if(i&cA||i&Dh&&!b)return E||(E=Pc(()=>T.decoder.decode(e.subarray(n.position,r)),T.rootStore)),E;if(i&Dh&&v)return $b(T.getEntry(this.recordId),v,T)},getBinaryValue(){return i&(cA|Dh)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:p,previousResidencyId:_,expiresAt:h,originatingOperation:S}}catch(n){return lf.error("Reading audit entry error",n,e),{}}}var Wl,lA,IP,Lh,kj,lf,ks,fc,Fj,xp,CP,ZTe,LP,Gj,PP,Lj,cA,Dh,vj,DP,Uj,xj,Bj,Hj,Wm,tAe,Mg,Uc,xc,r_,n_,Fn,qj,$j,hl,fo=be(()=>{Wl=require("ordered-binary"),lA=M(ae()),IP=M(Ut());H();Lh=M(et()),kj=M(ie());Nu();lf=M(z());UE();gs();vT();(0,lA.initSync)();ks=Buffer.alloc(2816),fc=new DataView(ks.buffer,ks.byteOffset,2816),Fj={writeKey(e,t,r){return e===t_?(t.set(t_,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,Wl.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,Wl.readKey)(e,t,r)}},xp={encoding:"binary",keyEncoder:Fj},CP=(0,kj.convertToMS)((0,lA.get)(B.LOGGING_AUDITRETENTION))||86400*3,ZTe=1e3,LP=new Float64Array(1),Gj=new Uint8Array(LP.buffer),PP=1e4,Lj=!1;a(uA,"openAuditStore");a(dA,"removeAuditEntry");a(Mj,"updateLastRemoved");a(SN,"getLastRemoved");a(eAe,"setAuditRetention");cA=16,Dh=32,vj=1,DP=2,Uj=3,xj=4,Bj=5,Hj=6,Wm=14,tAe=15,Mg=11,Uc=512,xc=1024,r_=2048,n_=4096,Fn=8192,qj={put:vj|cA,[vj]:"put",delete:DP,[DP]:"delete",message:Uj|cA,[Uj]:"message",invalidate:xj|Dh,[xj]:"invalidate",patch:Bj|Dh,[Bj]:"patch",relocate:Hj,[Hj]:"relocate"},$j={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};a(Ou,"createAuditEntry");a(rAe,"readAction");a(wt,"readAuditEntry");hl=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t;return t=this.getUint8(this.position++),t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch(t){throw t.message=`Error reading float64: ${t.message} at position ${this.position}`,t}}}});function UP(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=Kj,nAe(e.primaryStore,e.auditStore)):(c=Vj,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{Yj(Vj[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=gu(t);let f=new vP(r);f.startTime=n;let d=u.get(t);return d?d.push(f):(u.set(t,d=[f]),d.tables=u,d.key=t),f.subscriptions=d,f}function Yj(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),Wj(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=wt(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,l=gu(c),u=0;do{let f=o.get(l);if(f){for(let p of f)if(!(u>0&&!(p.includeDescendants&&!(p.onlyChildren&&u>1)))){if(p.startTime>=n){(0,MP.info)("omitting",c,p.startTime,n);continue}try{let _;p.supportsTransactions&&p.txnInProgress!==i.version&&(_=!0,p.txnInProgress||(r?r.push(p):r=[p]),p.txnInProgress=i.version),p.listener(c,i,n,_)}catch(_){console.error(_),(0,MP.info)(_)}}}if(l==null)break;let d=l.lastIndexOf?.("/",l.length-2);d!==l.length-1&&u++,d>-1?l=l.slice(0,d+1):l=null}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function nAe(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=Kj[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{Yj(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function Wj(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function BF(e){return e.nextTransaction||(UP({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),Wj(e)),e.nextTransaction}var MP,Vj,Kj,vP,TN=be(()=>{MP=M(z());_u();Su();fo();Vj=Object.create(null),Kj=Object.create(null);a(UP,"addSubscription");vP=class extends xn{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(Yj,"notifyFromTransactionData");a(nAe,"listenToCommits");a(Wj,"nextTransaction");a(BF,"whenNextTransaction")});var wI={};ve(wI,{EVICTED:()=>ma,INVALIDATED:()=>Bn,coerceType:()=>pA,makeTable:()=>mA,setServerUtilities:()=>dAe});function mA(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:l,schemaDefined:u,dbisDB:f,sealed:d,splitSegments:p,replicate:_}=e,{expirationMS:h,evictionMS:S,audit:g,trackDeletes:R}=e;S??=0;let{attributes:E}=e;E||(E=[]);let T=JR(i,n,l),b,v,F={},q=Promise.resolve(),Y,Z,se;for(let K of E)(K.assignCreatedTime||K.name==="__createdtime__")&&(Y=K),(K.assignUpdatedTime||K.name==="__updatedtime__")&&(Z=K),K.expiresAt&&(se=K),K.isPrimaryKey&&(F=K);let Q,ne=[],J=[],he=1,Re=2,Ce={},me={},Zt=864e5,ut=0,yr,hs,vn,nu=!1,su,BA=new Map,HA=new Map,Mt,Ef,jh=jl.get(B.REPLICATION_DATABASES);if(Array.isArray(jh)){for(let K of jh)if(K.name===c&&K.replicateTo>=0){Ef=K.replicateTo;break}}let Jh=i.getRange({start:!1,end:!1}).constructor,gf=10,Qh=6;g&&Af(),Ah(i.env.path,K=>{if(v)return aa(K)});class De extends $r{#e;#t;#n;#r;#s;#i;static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=g;static databasePath=o;static databaseName=c;static attributes=E;static replicate=_;static sealed=d;static splitSegments=p??!0;static createdTimeProperty=Y;static updatedTimeProperty=Z;static propertyResolvers;static userResolvers={};static sources=[];static getResidencyById;static get expirationMS(){return h}static dbisDB=f;static schemaDefined=u;static sourcedFrom(m,A){if(A&&(this.sourceOptions=A,(A.expiration||A.eviction||A.scanInterval)&&this.setTTLExpiration(A)),A?.intermediateSource)m.intermediateSource=!0,this.sources.unshift(m);else{if(this.sources.some(N=>!N.intermediateSource)){if(this.sources.some(N=>N.name===m.name))return;throw new Error("Can not have multiple canonical (non-intermediate) sources")}this.sources.push(m)}v=v||m.get&&(!m.get.reliesOnPrototype||m.prototype.get),b=b||m.load;let I=a(N=>{let L=this.sources;if(L=L.filter(k=>k.intermediateSource&&k[N]&&(!k[N].reliesOnPrototype||k.prototype[N])),L.length>0)if(L.length===1){let k=L[0];return(D,x,$)=>{if(D?.source!==k)return k[N](x,$,D)}}else return(k,D,x)=>{let $=[];for(let j of L){if(k?.source===j)break;$.push(j[N](D,x,k))}return Promise.all($)}},"getApplyToIntermediateSource"),y=this.sources[this.sources.length-1];y.intermediateSource&&(y={});let O=a(N=>{if(y[N]&&(!y[N].reliesOnPrototype||y.prototype[N]))return(L,k,D)=>{if(!L?.source)return y[N](k,D,L)}},"getApplyToCanonicalSource");Ce={put:O("put"),patch:O("patch"),delete:O("delete"),publish:O("publish")},me={put:I("put"),patch:I("patch"),delete:I("delete"),publish:I("publish"),invalidate:I("invalidate")};let P=y.shouldRevalidateEvents;return(async()=>{let N=!1,L,k=a(async(D,x)=>{let $=D.value,j=D.table?qe[c][D.table]:De;if(c===bf&&(D.table===du.ROLE_TABLE_NAME||D.table===du.USER_TABLE_NAME)&&(N=!0),D.id===void 0&&(D.id=$[j.primaryKey],D.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(D));D.source=m;let oe={residencyId:uu(D.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:D.nodeId},U=await j.getResource(D.id,x,oe);switch(D.finished&&await D.finished,D.type){case"put":return P?U._writeInvalidate($,oe):U._writeUpdate($,!0,oe);case"patch":return P?U._writeInvalidate($,oe):U._writeUpdate($,!1,oe);case"delete":return U._writeDelete(oe);case"publish":return U._writePublish($,oe);case"invalidate":return U._writeInvalidate($,oe);case"relocate":return U._writeRelocate(oe);default:xe.default.error?.("Unknown operation",D.type,D.id)}},"writeUpdate");try{let D=m.subscribe;D&&R==null&&(R=!0);let x={crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0},$=m.subscribeOnThisThread?m.subscribeOnThisThread((0,zl.getWorkerIndex)(),x):(0,zl.getWorkerIndex)()===0,j=D&&$&&await m.subscribe?.(x);if(j){let oe;for await(let U of j)try{if(!(U.type==="transaction"?U.writes[0]:U)){xe.default.error?.("Bad subscription event",U);continue}if(U.source=m,U.type==="end_txn"){if(oe?.resolve(),U.localTime&&L!==U.localTime){if(U.remoteNodeIds?.length>0){let fe=[Symbol.for("seq"),U.remoteNodeIds[0]],te=f.get(fe),W=te?.nodes;W||(W=[]);for(let Ae of U.remoteNodeIds.slice(1)){let ye=W.find(dt=>dt.id===Ae);W=W.filter(dt=>dt.id!==Ae||dt===ye),ye||(ye={id:Ae,seqId:0},W.push(ye)),ye.seqId=Math.max(te?.seqId??1,U.localTime),Ae===oe?.nodeId&&(ye.lastTxnTime=U.timestamp)}let _e=Math.max(te?.seqId??1,U.localTime);xe.default.trace?.("Received txn",c,new Date(_e),new Date(U.localTime),U.remoteNodeIds),f.put(fe,{seqId:_e,nodes:W})}L=U.localTime}U.onCommit&&oe?.committed.then(U.onCommit);continue}if(oe)if(U.beginTxn)oe.resolve();else{oe.write_promises.push(k(U,oe));continue}!U.timestamp&&U.version&&(U.timestamp=U.version);let ce=Nt(U,()=>{if(U.type==="transaction"){let fe=[];for(let te of U.writes)try{fe.push(k(te,U))}catch(W){throw W.message+=" writing "+JSON.stringify(te)+" of event "+JSON.stringify(U),W}return Promise.all(fe)}else if(U.type==="define_schema"){let fe=this.attributes.slice(0),te;for(let W of U.attributes)fe.find(_e=>_e.name===W.name)||(fe.push(W),te=!0);te&&(ft({table:s,database:c,attributes:fe,origin:"cluster"}),vh.signalSchemaChange(new Uh.SchemaEventMsg(process.pid,Kt.CREATE_TABLE,c,s)))}else return U.beginTxn?(oe=U,oe.write_promises=[k(U,U)],new Promise(fe=>{oe.resolve=()=>fe(Promise.all(oe.write_promises))})):k(U,U)});oe&&(oe.committed=ce),N&&ce&&!ce?.waitingForUserChange&&(ce.then(()=>vh.signalUserChange(new Uh.UserEventMsg(process.pid))),ce.waitingForUserChange=!0),U.onCommit&&(ce?ce.then(U.onCommit):U.onCommit())}catch(ue){xe.default.error?.("error in subscription handler",ue)}}}catch(D){xe.default.error?.(D)}})(),this}static get isCaching(){return v}static get shouldRevalidateEvents(){return this.prototype.get!==De.prototype.get}static getResource(m,A,I){let y=super.getResource(m,A,I);if(m!=null){Ir(m);try{if(y.getRecord?.())return y;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let O=!I?.async||i.cache?.get?.(m),P=Fr(A),N=P.getReadTxn();if(N?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return iu(m,A,{transaction:N,ensureLoaded:I?.ensureLoaded},O,L=>{if(L?De._updateResource(y,L):y.#e=null,A.onlyIfCached&&A.noCacheStore){if(!y.doesExist())throw new wr.ServerError("Entry is not cached",504)}else if(I?.ensureLoaded){let k=un(m,L,A,y);if(k)return P?.disregardReadTxn(),y.#i=!0,BP(k,D=>(De._updateResource(y,D),y))}return y})}catch(O){throw O.message.includes("Unable to serialize object")&&(O.message+=": "+JSON.stringify(m)),O}}return y}static _updateResource(m,A){m.#r=A,m.#e=A?.value??null,m.#n=A?.version}ensureLoaded(){let m=un(this.getId(),this.#r,this.getContext());if(m)return this.#i=!0,BP(m,A=>{this.#r=A,this.#e=A.value,this.#n=A.version})}static getNewId(){let m=F?.type;if(m==="String"||m==="ID")return super.getNewId();if(!Mt){let O=i.getEntry(Symbol.for("id_allocation")),P=O?.value,N;if(P&&P.nodeName===server.hostname&&(!_Ae(i)||P.pid===process.pid)){let L=P.start,k=P.end;N=L;for(let D of i.getKeys({start:k,end:L,limit:1,reverse:!0}))N=D}else P=y(O?.version??null),N=P.start;Mt=new BigInt64Array([BigInt(N)+1n]),Mt=new BigInt64Array(i.getUserSharedBuffer("id",Mt.buffer)),Mt.maxSafeId=P.end}let A=Number(Atomics.add(Mt,0,1n)),I=m==="Int"?512:1048576;if(A+I>=Mt.maxSafeId){let O=a(P=>{Mt.maxSafeId=A+(m==="Int"?1023:4194303);let N=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,L=P?void 0:i.useReadTransaction(),k=Number(Mt[0]);for(let $ of i.getKeys({start:k+1,end:N,limit:1,transaction:L}))N=$;L?.done();let{value:D,version:x}=i.getEntry(Symbol.for("id_allocation"));if(Mt.maxSafeId<N){if(D.end>Mt.maxSafeId-100)return;xe.default.info?.("New id allocation",A,Mt.maxSafeId,x),i.put(Symbol.for("id_allocation"),{start:D.start,end:Mt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),x)}else{xe.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${Mt.maxSafeId}, but id of ${N} detected`);let $=y(x);$.alreadyUpdated||Atomics.store(Mt,0,BigInt($.start+1)),Mt.maxSafeId=$.end}},"updateEnd");A+I===Mt.maxSafeId?setImmediate(O):A+100>=Mt.maxSafeId&&(xe.default.warn?.(`Synchronous id allocation required on table ${s}${m=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>O(!0)))}return A;function y(O){let P=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,N=P/4,L,k,D=!1,x,$;do{x=Math.floor(Math.random()*P),$={start:x,end:x+(m==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},L=0;for(let j of i.getKeys({start:x,limit:1,reverse:!0}))L=j;k=P;for(let j of i.getKeys({start:x+1,end:P,limit:1}))k=j;N*=.875,N<1e3&&!D&&(D=!0,xe.default.error?.(`Id allocation in table ${s} is very dense, limited safe range of numbers to allocate ids in${m==="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`,x,L,k,N))}while(!(N<k-x&&(N<x-L||L===0)));return i.transactionSync(()=>{let j=i.getEntry(Symbol.for("id_allocation"));return(j?.version??null)==O?(xe.default.info?.("Allocated new id range",$),i.put(Symbol.for("id_allocation"),$,Date.now()),$):(xe.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...j.value})})}}static setTTLExpiration(m){if(typeof m=="number")h=m*1e3,S||(S=0);else if(m&&typeof m=="object")h=m.expiration*1e3,S=(m.eviction||0)*1e3,Zt=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(h<0)throw new Error("Expiration can not be negative");Zt=Zt||(h+S)/4,aa()}static getResidencyRecord(m){return f.get([Symbol.for("residency_by_id"),m])}static setResidency(m){De.getResidency=m}static setResidencyById(m){De.getResidencyById=m}static getResidency(m,A){if(De.getResidencyById)return De.getResidencyById(m[t]);let I=Ef;if(A.replicateTo!=null){if(Array.isArray(A.replicateTo))return A.replicateTo.includes(server.hostname)?A.replicateTo:[server.hostname,...A.replicateTo];A.replicateTo>=0&&(I=A.replicateTo)}if(I>=0&&server.nodes){let y=[server.hostname];if(A.previousResidency)y.push(...A.previousResidency.slice(0,I));else{let O=server.nodes.map(L=>L.name),P=Math.floor(O.length*Math.random());y.push(...O.slice(P,P+I));let N=P+I-O.length;N>0&&y.push(...O.slice(0,N))}return y}}static enableAuditing(m=!0){g=m,m&&Af(),De.audit=m}static coerceId(m){return m===""?null:pA(m,F)}static async dropTable(){delete qe[c][s];for(let m of i.getRange({versions:!0,snapshot:!1,lazy:!0}))m.metadataFlags&Fn&&m.value&&Ta(m.value);if(c===o){for(let m of E)f.remove(De.tableName+"/"+m.name),r[m.name]?.drop();f.remove(De.tableName+"/"),i.drop(),await f.committed}else console.log("legacy dropTable"),await i.close(),await _A.default.remove(data_path),await _A.default.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));vh.signalSchemaChange(new Uh.SchemaEventMsg(process.pid,Kt.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this.isCollection)return this.search(m);if(this.getId()===null)return m?.conditions?this.search(m):{records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:E};if(m?.property)return this.getProperty(m.property);if(this.doesExist()||m?.ensureLoaded===!1||this.getContext()?.returnNonexistent)return this}allowRead(m,A){let I=Tf(m);if(I?.read){if(I.isSuperUser)return!0;let y=I.attribute_permissions,O=A?.select;if(y?.length>0||nu&&O){if(A||(A={}),O){let P=y?.length>0&&xP(y,"read");A.select=O.map(N=>{let L=N.name||N;if(!P||P[L]){let k=vn[L]?.definition?.tableClass;if(k){if(N.name||(N={name:N}),!k.prototype.allowRead.call(null,m,N))return!1;if(!N.select)return N.name}return N}}).filter(Boolean)}else A.select=y.filter(P=>P.read&&!vn[P.attribute_name]).map(P=>P.attribute_name);return A}else return!0}}allowUpdate(m,A){let I=Tf(m);if(I?.update){let y=I.attribute_permissions;if(y?.length>0){let O=xP(y,"update");for(let P in A)if(!O[P])return!1;for(let P of y){let N=P.attribute_name;!P.update&&!(N in A)&&(A[N]=this.getProperty(N))}}return oa(this.getContext())}}allowCreate(m,A){if(this.isCollection){let I=Tf(m);if(I?.insert){let y=I.attribute_permissions;if(y?.length>0){let O=xP(y,"insert");for(let P in A)if(!O[P])return!1;return oa(this.getContext())}else return oa(this.getContext())}}else return this.allowUpdate(m,{})}allowDelete(m){return Tf(m)?.delete&&oa(this.getContext())}update(m,A){if(!Fr(this.getContext()))throw new Error("Can not update a table resource outside of a transaction");if(m===!1)return this;let y;return typeof m=="object"&&m&&(A?(Object.isFrozen(m)&&(m={...m}),this.#e={},this.#t=m):(y=this.#t,y&&(m=Object.assign(y,m)),this.#t=m)),this._writeUpdate(this.#t,A),this}addTo(m,A){if(typeof A=="number"||typeof A=="bigint")this.#s===jj?this.set(m,(+this.getProperty(m)||0)+A):(this.#s||this.update(),this.set(m,new HE(A)));else throw new Error("Can not add a non-numeric value")}subtractFrom(m,A){if(typeof A=="number")return this.addTo(m,-A);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this.#r}getRecord(){return this.#e}getChanges(){return this.#t}_setChanges(m){this.#t=m}setRecord(m){this.#e=m}invalidate(){this._writeInvalidate()}_writeInvalidate(m,A){let I=this.getContext(),y=this.getId();Ir(y),Fr(this.getContext()).addWrite({key:y,store:i,invalidated:!0,entry:this.#r,before:Ce.invalidate?.bind(this,I,y),beforeIntermediate:me.invalidate?.bind(this,I,y),commit:a((P,N)=>{if(!(ia(P,N,A?.nodeId)<=0)){m??=null;for(let L in r)m||(m={}),m[L]===void 0&&(m[L]=this.getProperty(L));xe.default.trace?.(`Invalidating entry id: ${y}, timestamp: ${new Date(P).toISOString()}`),T(y,m,this.#r,P,Bn,g,{user:I?.user,residencyId:A?.residencyId,nodeId:A?.nodeId},"invalidate")}},"commit")})}_writeRelocate(m){let A=this.getContext(),I=this.getId();Ir(I),Fr(this.getContext()).addWrite({key:I,store:i,invalidated:!0,entry:this.#r,before:Ce.relocate?.bind(this,A,I),beforeIntermediate:me.relocate?.bind(this,A,I),commit:a((O,P)=>{if(ia(O,P,m?.nodeId)<=0)return;let N=De.getResidencyRecord(m.residencyId),L=0,k=null,D=P?.value;if(N&&!N.includes(server.hostname)){for(let x in r)k||(k={}),k[x]=D(x);L=Bn}else k=D;xe.default.trace?.(`Relocating entry id: ${I}, timestamp: ${new Date(O).toISOString()}`),T(I,k,this.#r,O,L,g,{user:A.user,residencyId:m.residencyId,nodeId:m.nodeId,expiresAt:m.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(m,A){let I={previousResidency:this.getResidencyRecord(m.residencyId),isRelocation:!0},y=lu(this.getResidency(A.value,I)),O;if(y){if(!y.includes(server.hostname))return;O=uu(y)}let N=T(m.key,A.value,m,m.version,0,!0,{residencyId:O,expiresAt:A.expiresAt},"relocate",!1,null)}static evict(m,A,I){let y=this.Source,O;if(!((v||g)&&(!A||(O=i.getEntry(m),!O||!A)||O.version!==I))){if(v){if(i.hasLock(m,O.version))return;let P;for(let N in r)P||(P={}),P[N]=A[N];if(P)return T(m,P,O,I,ma,null,null,null,!0)}if(i.ifVersion(m,I,()=>{ln(m,A,null)}),g)return T(m,null,O,I,ma,null,null,null,!0);vc(i,O??i.getEntry(m),I)}}lock(){throw new Error("Not yet implemented")}static operation(m,A){return m.table||=s,m.schema||=c,nJ.operation(m,A)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,A,I){let y=this.getContext(),O=Fr(y),P=this.getId();Ir(P);let N=this.#r;this.#s=A?jj:cAe;let L={key:P,store:i,entry:N,nodeName:y?.nodeName,validate:a(k=>{m||(m=this.#t),A||m&&xE(this.#t===m?this:m)?y?.source||(O.checkOverloaded(),this.validate(m,!A),Z&&(m[Z.name]=Z.type==="Date"?new Date(k):Z.type==="String"?new Date(k).toISOString():k),A&&(t&&m[t]!==P&&(m[t]=P),Y&&(N?.value?m[Y.name]=N?.value[Y.name]:m[Y.name]=Y.type==="Date"?new Date(k):Y.type==="String"?new Date(k).toISOString():k),m=el(m))):O.removeWrite(L)},"validate"),before:A?Ce.put?()=>Ce.put(y,P,m):null:Ce.patch?()=>Ce.patch(y,P,m):Ce.put?()=>Ce.put(y,P,el(this)):null,beforeIntermediate:A?me.put?()=>me.put(y,P,m):null:me.patch?()=>me.patch(y,P,m):me.put?()=>me.put(y,P,el(this)):null,commit:a((k,D,x)=>{if(x){if(y&&D?.version>(y.lastModified||0)&&(y.lastModified=D.version),this.#r=D,D?.value&&D.value.getRecord)throw new Error("Can not assign a record to a record, check for circular references");A||(this.#e=D?.value??null)}this.#t=void 0,this.#n=k;let $=D?.value,j=m;this.#s=0;let oe=!1,U=ia(k,D,I?.nodeId),ue;if(U<=0)if(g){let _e=D.localTime,Ae=D.version;xe.default.trace?.("Applying CRDT update to record with id: ",P,"applying later update:",Ae);let ye=[];for(;_e>k||Ae>=k&&_e>0;){let dt=l.get(_e);if(!dt)break;let rt=wt(dt);if(Ae=rt.version,Ae>=k){if(Ae===k){if(U=ia(k,{version:Ae,localTime:_e},I?.nodeId),U===0)return;if(U>0)continue}if(rt.type==="patch")ye.push(rt),ue=m;else if(rt.type==="put"||rt.type==="delete")return}_e=rt.previousLocalTime}ye.sort((dt,rt)=>dt.version-rt.version);for(let dt of ye){let rt=dt.getValue(i);if(j=vE(j,rt,A),xe.default.debug?.("Rebuilding update with future patch:",j),!j)return}}else{if(A)return;j=vE(j,$,A),xe.default.debug?.("Rebuilding update without audit:",j)}let ce;if(A?ce=j:(this.#e=$,ce=el(this,j)),this.#e=ce,ce&&ce.getRecord)throw new Error("Can not assign a record to a record, check for circular references");let fe;if(I?.residencyId!=null)fe=I.residencyId;else{N?.residencyId&&(y.previousResidency=De.getResidencyRecord(N.residencyId));let _e=lu(De.getResidency(ce,y));if(_e&&!_e.includes(server.hostname))if(ue??=ce,oe=!0,De.getResidencyById)ce=void 0;else{ce=null;for(let Ae in r)ce||(ce={}),ce[Ae]=ue[Ae]}fe=uu(_e)}A||(ue=m);let te=y?.expiresAt??(h?h+Date.now():-1);xe.default.trace?.(`Saving record with id: ${P}, timestamp: ${new Date(k).toISOString()}${te?", expires at: "+new Date(te).toISOString():""}${D?", replaces entry from: "+new Date(D.version).toISOString():", new entry"}`,(()=>{try{return JSON.stringify(ce).slice(0,100)}catch{return""}})()),ln(P,$,ce);let W=A?"put":"patch";T(P,ce,D,k,oe?Bn:0,g,{omitLocalRecord:oe,user:y?.user,residencyId:fe,expiresAt:te,nodeId:I?.nodeId,originatingOperation:y?.originatingOperation},W,!1,ue),y.expiresAt&&aa()},"commit")};O.addWrite(L)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this.isCollection){for await(let A of this.search(m))(await De.getResource(A[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this.#e?this._writeDelete(m):!1}_writeDelete(m){let A=Fr(this.getContext()),I=this.getId();Ir(I);let y=this.getContext();return A.addWrite({key:I,store:i,entry:this.#r,nodeName:y?.nodeName,before:Ce.delete?.bind(this,y,I),beforeIntermediate:me.delete?.bind(this,y,I),commit:a((O,P,N)=>{let L=P?.value;N&&(y&&P?.version>(y.lastModified||0)&&(y.lastModified=P.version),De._updateResource(this,P)),!(ia(O,P,m?.nodeId)<=0)&&(ln(this.getId(),L),xe.default.trace?.(`Deleting record with id: ${I}, txn timestamp: ${new Date(O).toISOString()}`),g||R?(T(I,null,this.#r,O,0,g,{user:y?.user,nodeId:m?.nodeId},"delete"),g||aa()):vc(i,P))},"commit")}),!0}search(m){let A=this.getContext(),I=Fr(A);if(!m)throw new Error("No query provided");let y=m.conditions;y?y.length===void 0&&(y=y[Symbol.iterator]?Array.from(y):[y]):y=Array.isArray(m)?m:m[Symbol.iterator]?Array.from(m):[],this.getId()&&(y=[{attribute:null,comparator:Array.isArray(this.getId())?"prefix":"starts_with",value:this.getId()}].concat(y));let O,P={};function N(W,_e){let Ae;switch(_e){case"and":case void 0:if(W.length<1)throw new Error('An "and" operator requires at least one condition');Ae=!0;break;case"or":if(W.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+_e)}for(let ye of W){if(ye.conditions){ye.conditions=N(ye.conditions,ye.operator);continue}let dt=ye[0]??ye.attribute,rt=dt==null?F:bi(E,dt);if(rt)(rt.type||_R[ye.comparator])&&(ye[1]===void 0?ye.value=k(ye.value,rt):ye[1]=k(ye[1],rt));else if(dt!=null)throw(0,wr.handleHDBError)(new Error,`${dt} is not a defined attribute`,404);if(ye.chainedConditions)if(ye.chainedConditions.length===1&&(!ye.operator||ye.operator=="and")){let Gr=ye.chainedConditions[0],Ee,Je;if(Gr.comparator==="gt"||Gr.comparator==="greater_than"||Gr.comparator==="ge"||Gr.comparator==="greater_than_equal"?(Ee=ye,Je=Gr):(Ee=Gr,Je=ye),Ee.comparator!=="lt"&&Ee.comparator!=="less_than"&&Ee.comparator!=="le"&&Ee.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let nt=Je.comparator==="ge"||Je.comparator==="greater_than_equal",$t=Ee.comparator==="le"||Ee.comparator==="less_than_equal";ye.comparator=(nt?"ge":"gt")+($t?"le":"lt"),ye.value=[Je.value,Ee.value]}else throw new Error("Multiple chained conditions are not currently supported")}return W}a(N,"prepareConditions");function L(W,_e){if(m.enforceExecutionOrder)return W;for(let Ae of W)Ae.conditions&&(Ae.conditions=L(Ae.conditions,Ae.operator));return W.length>1&&_e!=="or"?(0,tJ.sortBy)(W,ym(De)):W}a(L,"orderConditions");function k(W,_e){return Array.isArray(W)?W.map(Ae=>pA(Ae,_e)):pA(W,_e)}a(k,"coerceTypedValues");let D=m.operator;(y.length>0||D)&&(y=N(y,D));let x=typeof m.sort=="object"&&m.sort,$;if(x&&D!=="or"){let W=x.attribute;if(W==null)throw new wr.ClientError("Sort requires an attribute");if(O=y.find(_e=>Eu(_e.attribute)===Eu(W)),!O){let _e=bi(E,W);if(!_e)throw(0,wr.handleHDBError)(new Error,`${Array.isArray(W)?W.join("."):W} is not a defined attribute`,404);if(_e.indexed)O={attribute:W,comparator:"sort"},y.push(O);else if(y.length===0&&!m.allowFullScan)throw(0,wr.handleHDBError)(new Error,`${Array.isArray(W)?W.join("."):W} is not indexed and not combined with any other conditions`,404)}O&&(O.descending=!!x.descending)}y=L(y,D),x&&(O&&y[0]===O?x.next&&($={dbOrderedAttribute:x.attribute,attribute:x.next.attribute,descending:x.next.descending,next:x.next.next}):(O&&y.splice(y.indexOf(O),1),$=x));let j=m.select;if(y.length===0&&(y=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:y,operator:D,postOrdering:$,selectApplied:!!j};let oe=I.useReadTxn(),U=pR(y,D,De,oe,m,A,(W,_e)=>au(W,j,A,oe,_e),P),ue=m.ensureLoaded!==!1;$||(U=te(U));let ce=De.transformEntryForSelect(j,A,oe,P,ue,!0),fe=De.transformToOrderedSelect(U,j,$,oe,A,ce);function te(W){return m.offset||m.limit!==void 0?W.slice(m.offset,m.limit!==void 0?(m.offset||0)+m.limit:void 0):W}return a(te,"applyOffset"),$&&(fe=te(fe)),fe.onDone=()=>{fe.onDone=null,I.doneReadTxn()},fe.selectApplied=!0,fe.getColumns=()=>{if(j){let W=[];for(let _e of j)_e==="*"?W.push(...E.map(Ae=>Ae.name)):W.push(_e.name||_e);return W}return E.filter(W=>!W.computed&&!W.relationship).map(W=>W.name)},fe}static transformToOrderedSelect(m,A,I,y,O,P){let N=new Jh;if(I){m=au(m,A,y,O,null);let L;N.iterate=function(){let D,x=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),$,j=I.dbOrderedAttribute,oe,U,ue=!0;function ce(te){let W=te.next&&ce(te.next),_e=te.descending;return(Ae,ye)=>{let dt=ou(Ae,te.attribute,y),rt=ou(ye,te.attribute,y),Gr=_e?(0,Jl.compareKeys)(rt,dt):(0,Jl.compareKeys)(dt,rt);return Gr===0?W?.(Ae,ye)||0:Gr}}a(ce,"createComparator");let fe=ce(I);return{async next(){let te;if(D)if(te=D.next(),te.done){if($)return N.onDone&&N.onDone(),te}else return{value:await P.call(this,te.value)};L=[],oe&&L.push(oe);do if(te=await x.next(),te.done){if($=!0,L.length)break;return N.onDone&&N.onDone(),te}else{let W=te.value;if(W?.then&&(W=await W),j){let _e=ou(W,j,y);if(ue)ue=!1,U=_e;else if(_e!==U){U=_e,oe=W;break}}L.push(W)}while(!0);return I.isGrouped,L.sort(fe),D=L[Symbol.iterator](),te=D.next(),te.done?(N.onDone&&N.onDone(),te):{value:await P.call(this,te.value)}},return(){N.onDone&&N.onDone(),x.return()},throw(){N.onDone&&N.onDone(),x.throw()}}};let k=a(D=>{if(typeof A=="object"&&Array.isArray(D.attribute))for(let x=0;x<A.length;x++){let $=A[x],j;if($.name===D.attribute[0]){for(j=$.sort||($.sort={});j.next;)j=j.next;j.attribute=D.attribute.slice(1),j.descending=D.descending}else $===D.attribute[0]&&(A[x]=j={name:$,sort:{attribute:D.attribute.slice(1),descending:D.descending}})}D.next&&k(D.next)},"applySortingOnSelect");k(I)}else N.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),N=N.map(function(L){try{let k=P.call(this,L);return typeof k?.catch=="function"?k.catch(D=>{throw D.partialObject={[t]:L.key},D}):k}catch(k){throw k.partialObject={[t]:L.key},k}});return N}static transformEntryForSelect(m,A,I,y,O,P){if(m&&(m===t||m?.length===1&&m[0]===t&&Array.isArray(m))){let D=a(x=>(A?.transaction?.stale&&(A.transaction.stale=!1),x?.key??x),"transform");return m===t?D:m.asArray?x=>[D(x)]:x=>({[t]:D(x)})}let N;O&&v&&!(typeof m=="string"?[m]:m)?.every(D=>{let x;return typeof D=="object"?x=D.name:x=D,r[x]||x===t})&&(N=!0);let L,k=a(function(D){let x;if(A?.transaction?.stale&&(A.transaction.stale=!1),D!=null){if(x=D.value||D.deref?.()?.value,!x&&(D.key===void 0||D.deref)||D.metadataFlags&Bn){if(D.metadataFlags&Bn&&A.replicateFrom===!1&&P&&D.residencyId)return pc.SKIP;if(D=iu(D.key??D,A,{transaction:I,lazy:m?.length<4,ensureLoaded:O},this?.isSync,$=>$),D?.then)return D.then(k.bind(this));x=D?.value}if(N&&D?.metadataFlags&(Bn|ma)||D?.expiresAt!=null&&D?.expiresAt<Date.now()){if(A.onlyIfCached&&A.noCacheStore)return{[t]:D.key,message:"This entry has expired"};let $=un(D.key??D,D,A);if($?.then)return $.then(k)}}if(x==null)return P?pc.SKIP:x;if(m&&!(m[0]==="*"&&m.length===1)){let $,j=a((U,ue)=>{let ce;typeof U=="object"?ce=U.name:ce=U;let fe=vn?.[ce],te;if(fe){let W=y?.[ce];if(W)if(W.hasMappings){let Ae=fe.from?x[fe.from]:Eu(D.key);te=W.get(Ae),te||(te=[])}else te=W.fromRecord?.(x);else te=fe(x,A,D);let _e=a(Ae=>{if(Ae&&typeof Ae=="object"){let ye=fe.definition?.tableClass||De;L||(L={});let dt=L[ce]||(L[ce]=ye.transformEntryForSelect(ce===U?null:U.select||(Array.isArray(U)?U:null),A,I,W,O));if(Array.isArray(Ae)){let rt=[],Gr=ye.transformToOrderedSelect(Ae,U.select,typeof U.sort=="object"&&U.sort,A,I,dt)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),Ee=a(nt=>{for(;!nt.done;){if(nt?.then)return nt.then(Ee);rt.push(nt.value),nt=Gr.next()}ue(rt,ce)},"nextValue"),Je=Ee(Gr.next());Je&&($||($=[]),$.push(Je));return}else if(Ae=dt.call(this,Ae),Ae?.then){$||($=[]),$.push(Ae.then(rt=>ue(rt,ce)));return}}ue(Ae,ce)},"handleResolvedValue");te?.then?($||($=[]),$.push(te.then(_e))):_e(te);return}else te=x[ce],te&&typeof te=="object"&&ce!==U&&(te=De.transformEntryForSelect(U.select||U,A,I,null)({value:te}));ue(te,ce)},"selectAttribute"),oe;if(typeof m=="string")j(m,U=>{oe=U});else if(Array.isArray(m))if(m.asArray)oe=[],m.forEach((U,ue)=>{U==="*"?m[ue]=x:j(U,ce=>oe[ue]=ce)});else{oe={};let U=m.forceNulls;for(let ue of m)if(ue==="*")for(let ce in x)oe[ce]=x[ce];else j(ue,(ce,fe)=>{ce===void 0&&U&&(ce=null),oe[fe]=ce})}else throw new wr.ClientError("Invalid select"+m);return $?Promise.all($).then(()=>oe):oe}return x},"transform");return k}async subscribe(m){if(!l)throw new Error("Can not subscribe to a table without an audit log");g||ft({table:s,database:c,schemaDefined:u,attributes:E,audit:!0}),m||(m={});let A=!m.rawEvents,I=[],y=this,O=UP(De,this.getId()??null,function(N,L,k,D){try{let x=L.getValue?.(i,A),$=L.type;if(!x&&$==="patch"&&A){let oe=i.getEntry(N);oe?.version===L.version?x=oe.value:x=L.getValue?.(i,!0,k),$="put"}let j={id:N,localTime:k,value:x,version:L.version,type:$,beginTxn:D};I?I.push(j):this.send(j)}catch(x){xe.default.error?.(x)}},m.startTime||0,m),P=(async()=>{this.isCollection&&(O.includeDescendants=!0,m.onlyChildren&&(O.onlyChildren=!0)),m.supportsTransactions&&(O.supportsTransactions=!0);let N=this.getId(),L=m.previousCount;L>1e3&&(L=1e3);let k=m.startTime;if(this.isCollection){if(k){if(L)throw new wr.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:D,value:x}of l.getRange({start:k,exclusiveStart:!0,snapshot:!1})){let $=wt(x);if($.tableId!==n)continue;let j=$.recordId;if(N==null||Zj(N,j)){let oe=$.getValue(i,A,D);if(O.send({id:j,localTime:D,value:oe,version:$.version,type:$.type}),O.queue?.length>Qj&&await O.waitForDrain()===!1)return}O.startTime=D}}else if(L){let D=[];for(let{key:x,value:$}of l.getRange({start:"z",end:!1,reverse:!0}))try{let j=wt($);if(j.tableId!==n)continue;let oe=j.recordId;if(N==null||Zj(N,oe)){let U=j.getValue(i,A,x);if(D.push({id:oe,localTime:x,value:U,version:j.version,type:j.type}),--L<=0)break}}catch(j){xe.default.error("Error getting history entry",x,j)}for(let x=D.length;x>0;)O.send(D[--x]);D[0]&&(O.startTime=D[0].localTime)}else if(!m.omitCurrent){for(let{key:D,value:x,version:$,localTime:j}of i.getRange({start:N??!1,end:N==null?void 0:[N,Jl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(x&&(O.send({id:D,localTime:j,value:x,version:$,type:"put"}),O.queue?.length>Qj&&await O.waitForDrain()===!1))return}}else{L&&!k&&(k=0);let D=this.#r?.localTime;if(D===jR&&(i.cache?.delete(N),this.#r=i.getEntry(N),xe.default.trace?.("re-retrieved record",D,this.#r?.localTime),D=this.#r?.localTime),xe.default.trace?.("Subscription from",k,"from",N,D),k<D){let x=[],$=D;do{let j=l.get($);if(j){m.omitCurrent=!0;let oe=wt(j),U=oe.getValue(i,A,$);A&&(oe.type="put"),x.push({id:N,value:U,localTime:$,...oe}),$=oe.previousLocalTime}else break;L&&L--}while($>k&&L!==0);for(let j=x.length;j>0;)O.send(x[--j]);O.startTime=D}!m.omitCurrent&&this.doesExist()&&O.send({id:N,localTime:D,value:this.#e,version:this.#n,type:"put"})}for(let D of I)O.send(D);I=null})();return m.listener&&O.on("data",m.listener),O}static subscribeOnThisThread(m,A){return m===0||A?.crossThreads===!1}doesExist(){return!!(this.#e||this.#s)}publish(m,A){this._writePublish(m,A)}_writePublish(m,A){let I=Fr(this.getContext()),y=this.getId()||null;y!=null&&Ir(y);let O=this.getContext();I.addWrite({key:y,store:i,entry:this.#r,nodeName:O?.nodeName,validate:a(()=>{O?.source||(I.checkOverloaded(),this.validate(m))},"validate"),before:Ce.publish?.bind(this,O,y,m),beforeIntermediate:me.publish?.bind(this,O,y,m),commit:a((P,N,L)=>{N===void 0&&R&&!g&&aa(),xe.default.trace?.(`Publishing message to id: ${y}, timestamp: ${new Date(P).toISOString()}`),T(y,N?.value??null,N,N?.version||P,0,!0,{user:O?.user,residencyId:A?.residencyId,expiresAt:O?.expiresAt,nodeId:A?.nodeId},"message",!1,m)},"commit")})}validate(m,A){let I,y=a((O,P,N)=>{if(P.type&&O!=null)if(A&&O.__op__&&(O=O.value),P.properties){typeof O!="object"&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be an object${P.type?" ("+P.type+")":""}`);let L=P.properties;for(let k=0,D=L.length;k<D;k++){let x=L[k],$=y(O[x.name],x,N+"."+x.name);$&&(O[x.name]=$)}if(P.sealed&&O!=null&&typeof O=="object")for(let k in O)L.find(D=>D.name===k)||(I||(I=[])).push(`Property ${k} is not allowed within object in property ${N}`)}else switch(P.type){case"Int":(typeof O!="number"||O>>0!==O)&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof O!="number"||!(Math.floor(O)===O&&Math.abs(O)<=9007199254740992))&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof O!="number"&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a number`);break;case"ID":typeof O=="string"||O?.length>0&&O.every?.(L=>typeof L=="string")||(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a string, or an array of strings`);break;case"String":typeof O!="string"&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a string`);break;case"Boolean":typeof O!="boolean"&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a boolean`);break;case"Date":if(!(O instanceof Date)){if(typeof O=="string"||typeof O=="number")return new Date(O);(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a Date`)}break;case"BigInt":if(typeof O!="bigint"){if(typeof O=="string"||typeof O=="number")return BigInt(O);(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a bigint`)}break;case"Bytes":if(!(O instanceof Uint8Array)){if(typeof O=="string")return Buffer.from(O);(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a Buffer or Uint8Array`)}break;case"Blob":if(!(O instanceof wi)){if(typeof O=="string"&&(O=Buffer.from(O)),O instanceof Buffer)return createBlob(O,{type:"text/plain"});(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a Blob`)}break;case"array":if(Array.isArray(O)){if(P.elements)for(let L=0,k=O.length;L<k;L++){let D=O[L],x=y(D,P.elements,N+"[*]");x&&(O[L]=x)}}else(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be an Array`);break}P.nullable===!1&&O==null&&(I||(I=[])).push(`Property ${N} is required (and not does not allow null values)`)},"validateValue");for(let O=0,P=E.length;O<P;O++){let N=E[O];if(!(N.relationship||N.computed)&&(!A||N.name in m)){let L=y(m[N.name],N,N.name);L&&(m[N.name]=L)}}if(d)for(let O in m)E.find(P=>P.name===O)||(I||(I=[])).push(`Property ${O} is not allowed`);if(I)throw new wr.ClientError(I.join(". "))}getUpdatedTime(){return this.#n}wasLoadedFromSource(){return v?!!this.#i:void 0}static async addAttributes(m){let A=E.slice(0);for(let I of m){if(!I.name)throw new wr.ClientError("Attribute name is required");if(I.name.match(/[`/]/))throw new wr.ClientError("Attribute names cannot include backticks or forward slashes");(0,rJ.validateAttribute)(I.name),A.push(I)}return ft({table:s,database:c,schemaDefined:u,attributes:A}),De.indexingOperation}static async removeAttributes(m){let A=E.filter(I=>!m.includes(I.name));return ft({table:s,database:c,schemaDefined:u,attributes:A}),De.indexingOperation}static getSize(){let m=i.getStats();return(m.treeBranchPageCount+m.treeLeafPageCount+m.overflowPages)*m.pageSize}static getAuditSize(){let m=l?.getStats();return m&&(m.treeBranchPageCount+m.treeLeafPageCount+m.overflowPages)*m.pageSize}static getStorageStats(){let m=i.env.path,A=_A.default.statfsSync?.(m)??{};return{available:A.bavail*A.bsize,free:A.bfree*A.bsize,size:A.blocks*A.bsize}}static async getRecordCount(m){let A=i.getStats().entryCount,I=1e3/2,y=performance.now(),O=Math.floor(A/2),P=m?.exactCount,N=0,L=0,k;for(let{value:D}of i.getRange({start:!0,lazy:!0,snapshot:!1}))if(D!=null&&N++,L++,await _c(),!P&&L<O&&performance.now()-y>I){k=L;break}if(k){let D=N;N=0;for(let{value:te}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:k,snapshot:!1}))te!=null&&N++,await _c();let x=k*2,$=(N+D)/x,j=Math.pow((N-D+1)/k/2,2)+$*(1-$)/x,oe=Math.max(Math.sqrt(j)*A,1),U=Math.round($*A),ue=Math.max(U-1.96*oe,N+D),ce=Math.min(U+1.96*oe,A),fe=Math.pow(10,Math.round(Math.log10(oe)));return fe>U&&(fe=fe/10),N=Math.round(U/fe)*fe,{recordCount:N,estimatedRange:[Math.round(ue),Math.round(ce)]}}return{recordCount:N}}static updatedAttributes(){vn=this.propertyResolvers={$id:a((m,A,I)=>({value:I.key}),"$id"),$updatedtime:a((m,A,I)=>I.version,"$updatedtime"),$record:a((m,A,I)=>I?{value:m}:m,"$record")};for(let m of this.attributes){m.resolve=null;let A=m.relationship,I=m.computed;if(A)if(m.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),I&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),nu=!0,A.to)m.elements?.definition?(vn[m.name]=m.resolve=(y,O,P)=>{let N=y[A.from?A.from:t],L=m.elements.definition.tableClass;return P?mu({attribute:A.to,value:N},Fr(O).getReadTxn(),!1,L,!1).asArray:L.search([{attribute:A.to,value:N}],O).asArray},m.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},m.resolve.definition=m.elements.definition,A.from&&(m.resolve.from=A.from)):console.error(`The one-to-many/many-to-many relationship property "${m.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(A.from){let y=m.definition||m.elements?.definition;y?(vn[m.name]=m.resolve=(O,P,N)=>{let L=O[A.from];if(L!==void 0){if(m.elements){let k,D=L?.map(x=>{let $=N?y.tableClass.primaryStore.getEntry(x,{transaction:Fr(P).getReadTxn()}):y.tableClass.get(x,P);return $?.then&&(k=!0),$});return A.filterMissing?k?Promise.all(D).then(x=>x.filter(eJ)):D.filter(eJ):k?Promise.all(D):D}return N?y.tableClass.primaryStore.getEntry(L,{transaction:Fr(P).getReadTxn()}):y.tableClass.get(L,P)}},m.set=(O,P)=>{if(Array.isArray(P)){let N=P.map(L=>L.getId?.()||L[y.tableClass.primaryKey]);O[A.from]=N}else{let N=P.getId?.()||P[y.tableClass.primaryKey];O[A.from]=N}},m.resolve.definition=m.definition||m.elements?.definition,m.resolve.from=A.from):console.error(`The relationship property "${m.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${m.name}" in table "${s}" must use either "from" or "to" arguments`);else I&&(typeof I.from=="function"&&this.setComputedAttribute(m.name,I.from),vn[m.name]=m.resolve=(y,O,P)=>{let N=typeof I.from=="string"?y[I.from]:y,L=this.userResolvers[m.name];if(L)return L(N,O,P);xe.default.warn(`Computed attribute "${m.name}" does not have a function assigned to it. Please use setComputedAttribute('${m.name}', resolver) to assign a resolver function.`),this.userResolvers[m.name]=()=>{}})}kE(this,this)}static setComputedAttribute(m,A){let I=bi(E,m);if(!I){console.error(`The attribute "${m}" does not exist in the table "${s}"`);return}if(!I.computed){console.error(`The attribute "${m}" is not defined as computed in the table "${s}"`);return}this.userResolvers[m]=A}static async deleteHistory(m=0,A=!1){let I;for(let{key:y,value:O}of l.getRange({start:0,end:m}))await _c(),wt(O).tableId===n&&(I=dA(l,y,O));if(A)for(let y of i.getRange({start:0,versions:!0})){let{key:O,value:P,localTime:N}=y;await _c(),P===null&&N<m&&(I=vc(i,y))}await I}static async*getHistory(m=0,A=1/0){for(let{key:I,value:y}of l.getRange({start:m||1,end:A})){await _c();let O=wt(y);O.tableId===n&&(yield{id:O.recordId,localTime:I,version:O.version,type:O.type,value:O.getValue(i,!0,I),user:O.user,operation:O.originatingOperation})}}static async getHistoryOfRecord(m){let A=[];if(m==null)throw new Error("An id is required");let I=i.getEntry(m);if(!I)return A;let y=I.localTime;if(!y)throw new Error("The entry does not have a local audit time");let O=0;do{await _c();let P=l.get(y);if(P){let N=wt(P);A.push({id:N.recordId,localTime:y,version:N.version,type:N.type,value:N.getValue(i,!0,y),user:N.user}),y=N.previousLocalTime}else break}while(O<1e3&&y);return A.reverse()}static cleanup(){Q?.remove()}}De.updatedAttributes();let Sf=De.prototype;return h&&De.setTTLExpiration(h/1e3),se&&cu(),De;function ln(K,m,A){let I;for(let y in r){let O=r[y],P=O.isIndexing,N=vn[y],L=A&&(N?N(A):A[y]),k=m&&(N?N(m):m[y]);if(L===k&&!P)continue;I=!0;let D=O.indexNulls,x=(0,Mh.getIndexedValues)(L,D),$=(0,Mh.getIndexedValues)(k,D);if($?.length>0){let j=new Set($);if(x=x?x.filter(oe=>{if(j.has(oe))j.delete(oe);else return!0}):[],$=Array.from(j),($.length>0||x.length>0)&&zj){let oe=$.concat(x).map(U=>({key:U,value:K}));O.prefetch(oe,Xj)}for(let oe=0,U=$.length;oe<U;oe++)O.remove($[oe],K)}else x?.length>0&&zj&&O.prefetch(x.map(j=>({key:j,value:K})),Xj);if(x)for(let j=0,oe=x.length;j<oe;j++)O.put(x[j],K)}return I}a(ln,"updateIndices");function Ir(K){switch(typeof K){case"number":return!0;case"string":if(K.length<659)return!0;if(K.length>Jj)throw new Error("Primary key size is too large: "+K.length);break;case"object":if(K===null)throw new Error("Invalid primary key of null");break;case"bigint":if(K<2n**64n&&K>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof K)}if((0,Jl.writeKey)(K,lAe,0)>Jj)throw new Error("Primary key size is too large: "+K.length);return!0}a(Ir,"checkValidId");function iu(K,m,A,I,y){if(De.getResidencyById&&A.ensureLoaded&&m?.replicateFrom!==!1){let P=lu(De.getResidencyById(K));if(P&&!P.includes(server.hostname)&&b)return b({key:K,residency:P}).then(y)}let O=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),A.transaction?.isDone)return y(null,K);let P=i.getEntry(K,A);return P?.residencyId&&P.metadataFlags&Bn&&b&&A.ensureLoaded&&m?.replicateFrom!==!1?b(P).then(N=>y(N,K),N=>(xe.default.error?.("Error loading remote record",K,P,A,N),y(null,K))):(P&&m&&(P?.version>(m.lastModified||0)&&(m.lastModified=P.version),P?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=P.localTime)),y(P,K))},"whenPrefetched");return I?O():he>0?(he--,O()):new Promise((P,N)=>{he===0?(he--,i.prefetch([K],()=>{L(),k()})):(ne.push(K),J.push(k),ne.length>Qh&&(he--,L()));function L(){if(ne.length>0){let D=J;i.prefetch(ne,()=>{he===-1?L():he++;for(let x of D)x()}),ne=[],J=[],Re>2&&Re--}else he=Re,Re<gf&&Re++}a(L,"prefetch");function k(){try{P(O())}catch(D){N(D)}}a(k,"load")})}a(iu,"loadLocalRecord");function Tf(K){if(!K?.role)return;let m=K.role.permission;if(m.super_user)return uAe;let A=m[c],I,y=A?.tables;if(y)return y[s];if(c==="data"&&(I=m[s])&&!I.tables)return I}a(Tf,"getTablePermissions");function un(K,m,A,I){if(v){let y=!1;if(A.noCache?y=!0:(m?(!m.value||m.metadataFlags&(Bn|ma)||m.expiresAt!=null&&m.expiresAt<Date.now())&&(y=!0):y=!0,Qn(!y,"cache-hit",s)),y){let O=Xh(K,m,A).then(P=>(P?.value&&P?.value.getRecord?.()&&xe.default.error?.("Can not assign a record that is already a resource"),A&&(P?.version>(A.lastModified||0)&&(A.lastModified=P.version),A.lastRefreshed=Date.now()),P));if(A?.onlyIfCached||m?.value&&I?.allowStaleWhileRevalidate?.(m,K)){if(O.catch(P=>xe.default.warn?.(P)),A?.onlyIfCached&&!I.doesExist())throw new wr.ServerError("Entry is not cached",504);return}else return O}}else if(m?.value&&m.expiresAt!=null&&m.expiresAt<Date.now())return De.evict(m.key,m.value,m.version),m.value=null,{then(y){return y(m)}}}a(un,"ensureLoadedFromSource");function Fr(K){let m=K?.transaction;if(m){if(!m.lmdbDb)return m.lmdbDb=i,m;do{if(m.lmdbDb?.path===i.path)return m;let A=m.next;if(!A)return m=m.next=new yc,m.lmdbDb=i,m;m=A}while(!0)}else return new Tm}a(Fr,"txnForContext");function ou(K,m,A){if(!K)return;let I=K.value||i.getEntry(K.key)?.value;if(typeof m=="object"){let O=vn,P=I;for(let N=0,L=m.length;N<L;N++){let k=m[N],D=O?.[k];P=D&&P?D(P,A,!0)?.value:P?.[k],O=D?.definition?.tableClass?.propertyResolvers}return P}let y=vn[m];return y?y(I,A):I[m]}a(ou,"getAttributeValue");function au(K,m,A,I,y){let O=y?.length,P={transaction:I,lazy:O>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},N;function L(k,D){let x=k?.value;if(!x)return pc.SKIP;for(let $=0;$<O;$++)if(!N?.includes($)&&!y[$](x,k))return pc.SKIP;return D!==void 0&&(k.key=D),k}if(a(L,"processEntry"),O>0||!K.hasEntries){let k=K.map(D=>{if(N=null,typeof D=="object"&&D?.key!==void 0)return O>0?L(D):D;if(D==null)return pc.SKIP;for(let x=0;x<O;x++){let j=y[x].idFilter;if(j){if(!j(D))return pc.SKIP;N||(N=[]),N.push(x)}}return iu(D,A,P,!1,L)});return Array.isArray(K)&&(k=k.filter(D=>D!==pc.SKIP)),k.hasEntries=!0,k}return K}a(au,"transformToEntries");function ia(K,m,A=server.replication?.getThisNodeId(l)){if(K<=m?.version){if(m?.version===K&&A!==void 0){let I=server.replication?.exportIdMapping(l),y=m.localTime,O=y&&l.get(y);if(O){let P,N,L=wt(O);for(let k in I)I[k]===A&&(P=k),I[k]===L.nodeId&&(N=k);if(P>N)return 1;if(P===N)return 0}}return-1}return 1}a(ia,"precedesExistingVersion");async function Xh(K,m,A){let I=m?.metadataFlags,y=m?.version,O,P;if(!i.attemptLock(K,y,()=>{clearTimeout(P);let D=i.getEntry(K);!D||!D.value||D.metadataFlags&(Bn|ma)?O(Xh(K,i.getEntry(K),A)):O(D)}))return new Promise(D=>{O=D,P=setTimeout(()=>{i.unlock(K,y)},aAe)});let N=m?.value,L={requestContext:A,replacingRecord:N,replacingEntry:m,replacingVersion:y,noCacheStore:!1,source:null,resourceCache:A?.resourceCache},k=A?.responseHeaders;return new Promise((D,x)=>{let $;BP(Nt(L,async j=>{let oe=performance.now(),U,ue,ce;try{for(let _e of De.sources)if(_e.get&&(!_e.get.reliesOnPrototype||_e.prototype.get)){if(_e.available?.(m)===!1)continue;if(L.source=_e,U=await _e.get(K,L),U)break}ce=I&Bn;let te=L.lastModified||ce&&y;ue=ce||te>y||!N,te||(te=(0,Mh.getNextMonotonicTime)());let W=performance.now()-oe;if(sr(W,"cache-resolution",s,null,"success"),k&&XE(k,"Server-Timing",`cache-resolve;dur=${W.toFixed(2)}`,!0),j.timestamp=te,h&&L.expiresAt==null&&(L.expiresAt=Date.now()+h),U){if(typeof U!="object")throw new Error("Only objects can be cached and stored in tables");if(U.status>0&&U.headers)if(U.status>=300)if(U.status===304)U=N,te=y;else throw new wr.ServerError(U.body||"Error from source",U.status);else U=U.body;typeof U.toJSON=="function"&&(U=U.toJSON()),t&&U[t]!==K&&(U[t]=K)}$=!0,D({key:K,version:te,value:U})}catch(te){te.message+=` while resolving record ${K} for ${s}`,N&&((te.code==="ECONNRESET"||te.code==="ECONNREFUSED"||te.code==="EAI_AGAIN")&&!A?.mustRevalidate||A?.staleIfError&&(te.statusCode===500||te.statusCode===502||te.statusCode===503||te.statusCode===504))?(D({key:K,version:y,value:N}),xe.default.trace?.(te.message,"(returned stale record)")):x(te);let W=performance.now()-oe;sr(W,"cache-resolution",s,null,"fail"),k&&XE(k,"Server-Timing",`cache-resolve;dur=${W.toFixed(2)}`,!0),L.transaction.abort();return}if(A?.noCacheStore||L.noCacheStore){L.transaction.abort();return}Fr(L).addWrite({key:K,store:i,entry:m,nodeName:"source",commit:a((te,W)=>{if(W?.version!==y)return;let _e=ln(K,N,U);U?(me.put?.(L,K,U),xe.default.trace?.(`Writing resolved record from source with id: ${K}, timestamp: ${new Date(te).toISOString()}`),T(K,U,W,te,0,g&&ue||null,{user:L?.user,expiresAt:L.expiresAt},"put",!!ce)):W&&(me.delete?.(L,K),xe.default.trace?.(`Deleting resolved record from source with id: ${K}, timestamp: ${new Date(te).toISOString()}`),g||R?T(K,null,W,te,0,g&&ue||null,{user:L?.user},"delete",!!ce):vc(i,W,y))},"commit")})}),()=>{i.unlock(K,y)},j=>{i.unlock(K,y),$&&xe.default.error?.("Error committing cache update",j)})})}a(Xh,"getFromSource");function oa(K){if(!K||K.user?.role?.permission?.super_user)return!0;if(K.replicateTo)throw new wr.ClientError("Can not specify replication parameters without super user permissions",403);if(K.replicatedConfirmation)throw new wr.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}a(oa,"checkContextPermissions");function aa(K){let m=!1;if(K&&(K-ut>1&&(m=!0),ut=K),!(Zt===yr&&!m)&&(yr=Zt,(0,zl.getWorkerIndex)()===(0,zl.getWorkerCount)()-1))return hs&&clearTimeout(hs),Zt?new Promise(A=>{let I=new Date;I.setMonth(0),I.setDate(1),I.setHours(0),I.setMinutes(0),I.setSeconds(0);let y=Zt/(1+ut),O=m?Date.now():Math.ceil((Date.now()-I.getTime())/y)*y+I.getTime(),P=a(N=>{xe.default.trace?.(`Scheduled next cleanup scan at ${new Date(N)}`),hs=setTimeout(()=>q=q.then(async()=>{if(P(Math.max(N+Zt,Date.now())),i.rootStore.status!=="open"){clearTimeout(hs);return}let L=50,k=new Array(L),D=0,x=Math.pow(ut,8)*(jl.get(B.STORAGE_RECLAMATION_EVICTIONFACTOR)??1e5),$=S/Math.pow(Math.max(ut,1),4);xe.default.info?.(`Starting cleanup scan for ${s}, evict threshold ${x}, adjusted eviction ${$}ms`);function j(oe,U,ue,ce){let fe=oe+$-Date.now();if(fe<0)return!0;if(ut){let te=i.lastSize;return ue&Fn&&Ru(ce,W=>{W.size&&(te+=W.size)}),xe.default.trace?.(`shouldEvict adjusted ${fe} ${te}, ${fe*(oe-U)/te} < ${x}`),fe*(oe-U)/te<x}return!1}a(j,"shouldEvict");try{let oe=0;for(let U of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let{key:ue,value:ce,version:fe,expiresAt:te,metadataFlags:W}=U,_e;ce===null&&!g&&fe+oAe<Date.now()?_e=vc(i,U,fe):te!=null&&j(te,fe,W,ce)&&(_e=De.evict(ue,ce,fe),oe++),_e&&(await k[D],k[D]=_e.catch(Ae=>{xe.default.error?.("Cleanup error",Ae)}),++D>=L&&(D=0)),await _c()}xe.default.info?.(`Finished cleanup scan for ${s}, evicted ${oe} entries`)}catch(oe){xe.default.warn?.(`Error in cleanup scan for ${s}:`,oe)}A(void 0),ut=0}),Math.min(N-Date.now(),2147483647)).unref()},"startNextTimer");P(O)}):void 0}a(aa,"scheduleCleanup");function Af(){Q=l?.addDeleteRemovalCallback(n,i,(K,m)=>{i.remove(K,m)})}a(Af,"addDeleteRemoval");function cu(){(0,zl.getWorkerIndex)()===0&&setInterval(async()=>{if(!su){su=!0;try{let K=se.name,m=r[K];if(!m)throw new Error(`expiresAt attribute ${se} must be indexed`);for(let A of m.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let I of m.getValues(A)){let y=i.getEntry(I);y?.value?y.value[K]<Date.now()&&De.evict(I,y.value,y.version):i.ifVersion(I,y?.version,()=>m.remove(A,I))}await _c()}}catch(K){xe.default.error?.("Error in evicting old records",K)}finally{su=!1}}},iAe).unref()}a(cu,"runRecordExpirationEviction");function lu(K){if(K!=null){if(Array.isArray(K))return K;if(typeof K=="number"){if(K>=65536)throw new Error(`Shard id ${K} must be below 65536`);let m=server.shards.get?.(K);if(m)return m.map(A=>A.name);throw new Error(`Shard ${K} is not defined`)}throw new Error(`Shard or residency list ${K} is not a valid type, must be a shard number or residency list of node hostnames`)}}a(lu,"residencyFromFunction");function uu(K){if(K){let m=K.join(","),A=f.get([Symbol.for("residency_by_set"),m]);return A||(f.put([Symbol.for("residency_by_set"),m],A=Math.floor(Math.random()*2147418112)+65535),f.put([Symbol.for("residency_by_id"),A],K),A)}}a(uu,"getResidencyId")}function xP(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 Xj(){}function dAe(e){nJ=e}function pA(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 fA(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return fA(+e);case"Float":return e==="null"?null:fA(+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;fAe.test(e)||(e+="Z");let n=new Date(e);return fA(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,hA.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function fA(e){if(isNaN(e))throw new SyntaxError;return e}function Zj(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 BP(e,t,r){return e?.then?e.then(t,r):t(e)}function eJ(e){return e!=null}function Fs(e){try{return JSON.stringify(e)}catch{return e}}function _Ae(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var pc,Mh,tJ,rJ,jl,wr,vh,Uh,xe,Jl,zl,hA,_A,sAe,nJ,iAe,oAe,zj,aAe,jj,cAe,Bn,ma,lAe,Jj,Qj,uAe,sxe,fAe,_c,qf=be(()=>{H();pc=require("lmdb"),Mh=M(_n()),tJ=require("lodash"),rJ=M(xf());Ea();Am();jl=M(ae());TN();wr=M(pe()),vh=M(To()),Uh=M(ri());Pe();Gf();xe=M(Ni());Yb();bc();Jl=require("ordered-binary"),zl=M(et());fo();hA=M(ie());Nu();ki();UE();z_();_A=M(require("node:fs"));gs();vT();sAe=new Uint8Array(9);sAe[8]=192;iAe=6e4,oAe=864e5;jl.initSync();zj=jl.get(B.STORAGE_PREFETCHWRITES),aAe=1e4,jj=1,cAe=2,Bn=1,ma=8,lAe=Buffer.allocUnsafeSlow(8192),Jj=1978,Qj=100,uAe={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},sxe=(0,hA.convertToMS)(jl.get(B.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(mA,"makeTable");a(xP,"attributesAsObject");a(Xj,"noop");a(dAe,"setServerUtilities");fAe=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(pA,"coerceType");a(fA,"rejectNaN");a(Zj,"isDescendantId");_c=a(()=>new Promise(setImmediate),"rest");a(BP,"when");a(eJ,"exists");a(Fs,"stringify");a(_Ae,"hasOtherProcesses")});var tt={};ve(tt,{database:()=>Gu,database_envs:()=>ea,databases:()=>qe,dropDatabase:()=>Qb,dropTableMeta:()=>gAe,getDatabases:()=>Qe,getDefaultCompression:()=>IS,getTables:()=>pAe,onRemovedDB:()=>pp,onUpdatedTable:()=>ml,readMetaDb:()=>xh,resetDatabases:()=>Pd,table:()=>ft,tables:()=>Jn});function pAe(){return TA||Qe(),Jn||{}}function Qe(){if(TA)return qe;TA=!0,ff=new Map;let e=(0,Xt.getHdbBasePath)()&&(0,Dt.join)((0,Xt.getHdbBasePath)(),Rc),t=(0,Xt.get)(B.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,Xt.get)(B.STORAGE_PATH)||e&&((0,us.existsSync)(e)?e:(0,Dt.join)((0,Xt.getHdbBasePath)(),im)),!e)return;if((0,us.existsSync)(e))for(let n of(0,us.readdirSync)(e,{withFileTypes:!0})){let s=(0,Dt.basename)(n.name,".mdb");n.isFile()&&(0,Dt.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&xh((0,Dt.join)(e,n.name),null,s)}if((0,us.existsSync)((0,df.getBaseSchemaPath)())){for(let n of(0,us.readdirSync)((0,df.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,Dt.join)((0,df.getBaseSchemaPath)(),n.name),i=(0,Dt.join)((0,df.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,us.readdirSync)(s,{withFileTypes:!0}))if(o.isFile()&&(0,Dt.extname)(o.name).toLowerCase()===".mdb"){let c=(0,Dt.join)(i,o.name);xh((0,Dt.join)(s,o.name),(0,Dt.basename)(o.name,".mdb"),n.name,c,!0)}}}if(t)for(let n in t){let s=t[n],i=s.path;if((0,us.existsSync)(i))for(let c of(0,us.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,Dt.extname)(c.name).toLowerCase()===".mdb"&&xh((0,Dt.join)(i,c.name),(0,Dt.basename)(c.name,".mdb"),n);let o=s.tables;if(o)for(let c in o){let l=o[c],u=(0,Dt.join)(l.path,(0,Dt.basename)(c+".mdb"));(0,us.existsSync)(u)&&xh(u,c,n,null,!0)}}for(let n in qe){let s=ff.get(n);if(s){let i=qe[n];n.includes("delete")&&Gt.trace(`defined tables ${Array.from(s.keys())}`);for(let o in i)s.has(o)||(Gt.trace(`delete table class ${o}`),delete i[o])}else if(delete qe[n],n==="data"){for(let i in Jn)delete Jn[i];delete Jn[AA]}}let r=["hdb_temp","hdb_certificate","hdb_analytics","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if(qe.system)for(let n of r)qe.system[n]&&(qe.system[n].replicate=!1);return ff=null,qe}function Pd(){TA=!1;for(let[,e]of ea)e.needsDeletion=!0;Qe();for(let[e,t]of ea)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),ea.delete(e),delete qe[t.databaseName],Hh.forEach(r=>r(t.databaseName)));return qe}function xh(e,t,r=FP,n,s){let i=new HP.default(e,!1);try{let o=ea.get(e);o?o.needsDeletion=!1:(o=(0,_f.open)(i),ea.set(e,o));let c=new Ql.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(EA.INTERNAL_DBIS_NAME,c)),u=o.auditStore;u||(n?(0,us.existsSync)(n)&&(i.path=n,u=(0,_f.open)(i),u.isLegacy=!0):u=uA(o));let f=aJ(r),d=f[AA],p=new Map;for(let{key:_,value:h}of l.getRange({start:!1})){let[S,g]=_.toString().split("/");g===""?g=h.name:g||(g=S,S=t,h.name||(h.name=g,h.indexed=!h.is_hash_attribute)),d?.add(S);let R=p.get(S);R||p.set(S,R={attributes:[]}),(g==null||h.is_hash_attribute)&&(R.primary=h),g!=null&&R.attributes.push(h),Object.defineProperty(h,"key",{value:_,configurable:!0})}for(let[_,h]of p){let{attributes:S,primary:g}=h;if(!g){for(let J of S)if(J.is_hash_attribute||J.isPrimaryKey){g=J;break}if(!g){Gt.warn(`Unable to find a primary key attribute on table ${_}, with attributes: ${JSON.stringify(S)}`);continue}}let R=f[_],E={},T=[],b,v,F=typeof g.audit=="boolean"?g.audit:(0,Xt.get)(B.LOGGING_AUDITLOG),q=g.trackDeletes,Y=g.expiration,Z=g.eviction,se=g.sealed,Q=g.splitSegments,ne=g.replicate;if(R)E=R.indices,T=R.attributes,R.schemaVersion++;else{b=g.tableId,b?b>=(l.get(uf)||0)&&(l.putSync(uf,b+1),Gt.info(`Updating next table id (it was out of sync) to ${b+1} for ${_}`)):(g.tableId=b=l.get(uf),b||(b=1),Gt.debug("Table {table_name} missing an id, assigning {table_id}"),l.putSync(uf,b+1),l.putSync(g.key,g));let J=new Ql.default(!g.is_hash_attribute,g.is_hash_attribute);if(J.compression=g.compression,J.compression){let he=(0,Xt.get)(B.STORAGE_COMPRESSION_THRESHOLD)||oJ;J.compression.threshold=he}v=jm(o.openDB(g.key,J),o),o.databaseName=r,v.tableId=b}for(let J of S){J.attribute=J.name;try{if(!J.is_hash_attribute&&(J.indexed||J.attribute&&!J.name)){if(!E[J.name]){let Re=new Ql.default(!J.is_hash_attribute,J.is_hash_attribute);E[J.name]=o.openDB(J.key,Re),E[J.name].indexNulls=J.indexNulls}let he=T.find(Re=>Re.name===J.name);he?T.splice(T.indexOf(he),1,J):T.push(J)}}catch(he){Gt.error("Error trying to update attribute",J,T,E,he)}}if(!R){R=cJ(f,_,mA({primaryStore:v,auditStore:u,audit:F,sealed:se,splitSegments:Q,replicate:ne,expirationMS:Y&&Y*1e3,evictionMS:Z&&Z*1e3,trackDeletes:q,tableName:_,tableId:b,primaryKey:g.name,databasePath:s?r+"/"+_:r,databaseName:r,indices:E,attributes:S,schemaDefined:g.schemaDefined,dbisDB:l})),R.schemaVersion=1;for(let J of Bh)J(R)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function aJ(e){let t=qe[e];if(t||(e==="data"?t=qe[e]=Jn:e==="system"?Object.defineProperty(qe,"system",{value:t=Object.create(null),configurable:!0}):t=qe[e]=Object.create(null)),ff&&!ff.has(e)){let r=new Set;t[AA]=r,ff.set(e,r)}return t}function cJ(e,t,r){return e[t]=r,r}function Gu({database:e,table:t}){e||(e=FP),Qe();let r=aJ(e),n=(0,Dt.join)((0,Xt.getHdbBasePath)(),Rc),s=(0,Xt.get)(B.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,Xt.get)(B.STORAGE_PATH)||((0,us.existsSync)(n)?n:(0,Dt.join)((0,Xt.getHdbBasePath)(),im));let o=(0,Dt.join)(n,(i?t:e)+".mdb"),c=ea.get(o);if(!c||c.status==="closed"){let l=new HP.default(o,!1);c=(0,_f.open)(l),ea.set(o,c)}return c.auditStore||(c.auditStore=uA(c)),c}async function Qb(e){if(!qe[e])throw new Error("Schema does not exist");let t=qe[e],r;for(let n in t)r=t[n].primaryStore.rootStore,ea.delete(r.path),r.status==="open"&&(await r.close(),await kh.remove(r.path));if(r||(r=Gu({database:e,table:null}),r.status==="open"&&(await r.close(),await kh.remove(r.path))),e==="data"){for(let n in Jn)delete Jn[n];delete Jn[AA]}delete qe[e],Hh.forEach(n=>n(e)),await wR(r)}function ft(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:o,audit:c,sealed:l,splitSegments:u,replicate:f,trackDeletes:d,schemaDefined:p,origin:_}=e;r||(r=FP);let h=Gu({database:r,table:t}),S=qe[r];Gt.trace(`Defining ${t} in ${r}`);let g=S?.[t];if(h.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let R,E,T;p==null&&(p=!0);let b=new Ql.default(!1);for(let Q of o)Q.attribute&&!Q.name?(Q.name=Q.attribute,Q.indexed=!0):Q.attribute=Q.name,Q.expiresAt&&(Q.indexed=!0);let v,F;if(g){if(R=g.primaryKey,g.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);u==null&&(u=g.splitSegments),g.attributes.splice(0,g.attributes.length,...o)}else{let Q=h.auditStore;E=o.find(Re=>Re.isPrimaryKey)||{},R=E.name,E.is_hash_attribute=E.isPrimaryKey=!0,E.schemaDefined=p,E.compression=IS(),d&&(E.trackDeletes=!0),c=E.audit=typeof c=="boolean"?c:(0,Xt.get)(B.LOGGING_AUDITLOG),n&&(E.expiration=n),s&&(E.eviction=s),u??=!1,E.splitSegments=u,typeof l=="boolean"&&(E.sealed=l),typeof f=="boolean"&&(E.replicate=f),_&&(E.origins?E.origins.includes(_)||E.origins.push(_):E.origins=[_]),Gt.trace(`${t} table loading, opening primary store`);let ne=new Ql.default(!1,!0);ne.compression=E.compression;let J=t+"/";if(T=h.dbisDb=h.openDB(EA.INTERNAL_DBIS_NAME,b),se(),T.get(J))return F&&F(),Pd(),ft(e);let he=jm(h.openDB(J,ne),h);h.databaseName=r,he.tableId=T.get(uf),Gt.trace(`Assigning new table id ${he.tableId} for ${t}`),he.tableId||(he.tableId=1),T.put(uf,he.tableId+1),E.tableId=he.tableId,g=cJ(S,t,mA({primaryStore:he,auditStore:Q,audit:c,sealed:l,splitSegments:u,replicate:f,trackDeletes:d,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:R,tableName:t,tableId:he.tableId,databasePath:r,databaseName:r,indices:{},attributes:o,schemaDefined:p,dbisDB:T})),g.schemaVersion=1,v=!0,T.put(J,E)}let q=g.indices;T=T||(h.dbisDb=h.openDB(EA.INTERNAL_DBIS_NAME,b)),g.dbisDB=T;let Y=[];for(let{key:Q,value:ne}of T.getRange({start:!0})){let[J,he]=Q.toString().split("/");if(he===""&&(he=ne.name),he){if(J!==t)continue}else continue;let Re=o.find(me=>me.name===he),Ce=!Re?.indexed&&ne.indexed&&!ne.isPrimaryKey;if((!Re||Ce)&&(se(),v=!0,Re||T.remove(Q),Ce)){let me=g.indices[J];me&&Y.push(me)}}let Z=[];try{for(let Q of o||[]){if((Q.relationship||Q.computed)&&(v=!0,Q.relationship))continue;let ne=t+"/"+(Q.name||"");Object.defineProperty(Q,"key",{value:ne,configurable:!0});let J=T.get(ne);if(Q.isPrimaryKey){if(J=J||T.get(ne=t+"/")||{},c!==void 0&&c!==g.audit||l!==void 0&&l!==g.sealed||f!==void 0&&f!==g.replicate||(+n||void 0)!==(+J.expiration||void 0)||(+s||void 0)!==(+J.eviction||void 0)){let Re={...J};typeof c=="boolean"&&(c&&g.enableAuditing(c),Re.audit=c),n&&(Re.expiration=+n),s&&(Re.eviction=+s),l!==void 0&&(Re.sealed=l),f!==void 0&&(Re.replicate=f),v=!0,se(),T.put(ne,Re)}continue}J?.attribute&&!J.name&&(J.indexed=!0);let he=!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 Re=new Ql.default(!0,!1),Ce=h.openDB(ne,Re);(he||J.indexingPID&&J.indexingPID!==process.pid||J.restartNumber<Fh.workerData?.restartNumber)&&(v=!0,se(),J=T.get(ne),(he||J.indexingPID&&J.indexingPID!==process.pid||J.restartNumber<Fh.workerData?.restartNumber)&&(v=!0,Q.indexNulls===void 0&&(Q.indexNulls=!0),g.primaryStore.getStats().entryCount>0&&(Q.lastIndexedKey=J?.lastIndexedKey??void 0,Q.indexingPID=process.pid,Ce.isIndexing=!0,Object.defineProperty(Q,"dbi",{value:Ce}),Z.push(Q))),T.put(ne,Q)),J?.indexNulls&&Q.indexNulls===void 0&&(Q.indexNulls=!0),Ce.indexNulls=Q.indexNulls,q[Q.name]=Ce}else he&&(v=!0,se(),T.put(ne,Q))}}finally{F&&F()}if(v&&(g.schemaVersion++,g.updatedAttributes()),Gt.trace(`${t} table loading, running index`),Z.length>0||Y.length>0?g.indexingOperation=EAe(g,Z,Y):v&&gA.signalSchemaChange(new SA.SchemaEventMsg(process.pid,"schema-change",g.databaseName,g.tableName)),g.origin=_,v)for(let Q of Bh)Q(g,_!=="cluster");return(n||s||i)&&g.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),Gt.trace(`${t} table loaded`),g;function se(){F||h.transactionSync(()=>({then(Q){F=Q}}))}a(se,"startTxn")}async function EAe(e,t,r){try{Gt.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await gA.signalSchemaChange(new SA.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o={},c=0,l=t.length;if(await new Promise(u=>setImmediate(u)),l>0){let u;for(let d of t)(0,_f.compareKeys)(d.lastIndexedKey,u)<0&&(u=d.lastIndexedKey),d.lastIndexedKey==null&&d.dbi.clearAsync();let f=0;for(let{key:d,value:p,version:_}of e.primaryStore.getRange({start:u,lazy:l<4,versions:!0,snapshot:!1}))if(p){if(f++,s=e.primaryStore.ifVersion(d,_,()=>{for(let h=0;h<l;h++){let S=t[h],g=S.name;try{let R=S.resolve,E=p&&(R?R(p):p[g]),T=(0,sJ.getIndexedValues)(E);if(T)for(let b=0,v=T.length;b<v;b++)S.dbi.put(T[b],d)}catch(R){o[g]||(o[g]=!0,Gt.error(`Error indexing attribute ${g}`,R))}}}),s.then(()=>f--,h=>{f--,Gt.error(h)}),Fh.workerData&&Fh.workerData.restartNumber!==iJ.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=d,e.dbisDB.put(h.key,h);if(i)return}f>hAe?await s:f>mAe&&await new Promise(h=>setImmediate(h))}for(let d of t)delete d.lastIndexedKey,delete d.indexingPID,d.dbi.isIndexing=!1,s=e.dbisDB.put(d.key,d)}await s,await gA.signalSchemaChange(new SA.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),Gt.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){Gt.error("Error in indexing",n)}}function gAe({table:e,database:t}){let r=Gu({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 ml(e){return Bh.push(e),{remove(){let t=Bh.indexOf(e);t>-1&&Bh.splice(t,1)}}}function pp(e){return Hh.push(e),{remove(){let t=Hh.indexOf(e);t>-1&&Hh.splice(t,1)}}}function IS(){let e=(0,Xt.get)(B.STORAGE_COMPRESSION),t=(0,Xt.get)(B.STORAGE_COMPRESSION_DICTIONARY),r=(0,Xt.get)(B.STORAGE_COMPRESSION_THRESHOLD)||oJ,n={startingOffset:32};return t&&(n.dictionary=kh.readFileSync(t)),r&&(n.threshold=r),e&&n}var Xt,EA,_f,Dt,us,df,Ql,HP,kh,kP,sJ,gA,SA,Fh,Gt,iJ,FP,AA,oJ,Jn,qe,uf,Bh,Hh,TA,ea,ff,hAe,mAe,Pe=be(()=>{Xt=M(ae()),EA=M(Ut()),_f=require("lmdb"),Dt=require("path"),us=require("fs"),df=M(gt());qf();Ql=M(s_()),HP=M(i_());H();kh=M(require("fs-extra")),kP=M(Ti()),sJ=M(_n()),gA=M(To()),SA=M(ri()),Fh=require("worker_threads"),Gt=M(z()),iJ=M(et());fo();Nu();gs();FP="data",AA=Symbol("defined-tables"),oJ=((0,Xt.get)(B.STORAGE_PAGESIZE)||4096)-60;(0,Xt.initSync)();Jn=Object.create(null),qe=Object.create(null);(0,kP._assignPackageExport)("databases",qe);(0,kP._assignPackageExport)("tables",Jn);uf=Symbol.for("next-table-id"),Bh=[],Hh=[],ea=new Map;a(pAe,"getTables");a(Qe,"getDatabases");a(Pd,"resetDatabases");a(xh,"readMetaDb");a(aJ,"ensureDB");a(cJ,"setTable");a(Gu,"database");a(Qb,"dropDatabase");a(ft,"table");hAe=1e3,mAe=10;a(EAe,"runIndexing");a(gAe,"dropTableMeta");a(ml,"onUpdatedTable");a(pp,"onRemovedDB");a(IS,"getDefaultCompression")});var ie=w((hxe,RJ)=>{"use strict";var hc=require("path"),_J=require("fs-extra"),Ln=z(),lJ=require("fs-extra"),RA=require("os"),SAe=require("net"),TAe=require("recursive-iterator"),Rr=(H(),C(G)),{PACKAGE_ROOT:AAe}=st(),RAe=sR(),uJ=require("papaparse"),yA=require("moment"),{inspect:yAe}=require("util"),dJ=require("is-number"),pxe=require("lodash"),bAe=require("minimist"),OAe=require("https"),NAe=require("http"),{hdb_errors:bA}=pe(),wAe=/^((\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)))$/,pJ=require("util").promisify(setTimeout),IAe=100,CAe=5,PAe="",DAe=4,fJ={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};RJ.exports={isEmpty:ds,isEmptyOrZeroLength:to,arrayHasEmptyValues:vAe,arrayHasEmptyOrZeroLengthValues:UAe,buildFolderPath:xAe,isBoolean:hJ,errorizeMessage:LAe,stripFileExtension:HAe,autoCast:kAe,autoCastJSON:mJ,autoCastJSONDeep:qP,removeDir:FAe,compareVersions:GAe,isCompatibleDataVersion:qAe,escapeRawValue:$Ae,unescapeValue:VAe,stringifyProps:KAe,timeoutPromise:WAe,isClusterOperation:jAe,getClusterUser:QAe,checkGlobalSchemaTable:JAe,getHomeDir:gJ,getPropsFilePath:YAe,promisifyPapaParse:XAe,removeBOM:SJ,createEventPromise:ZAe,checkProcessRunning:eRe,checkSchemaTableExist:tRe,checkSchemaExists:TJ,checkTableExists:AJ,getStartOfTomorrowInSeconds:rRe,getLimitKey:nRe,isObject:BAe,isNotEmptyAndHasValue:MAe,autoCasterIsNumberCheck:EJ,backtickASTSchemaItems:sRe,isPortTaken:zAe,createForkArgs:iRe,autoCastBoolean:oRe,async_set_timeout:pJ,getTableHashAttribute:aRe,doesSchemaExist:cRe,doesTableExist:lRe,stringifyObj:uRe,ms_to_time:dRe,changeExtension:fRe,getEnvCliRootPath:$P,noBootFile:_Re,httpRequest:pRe,transformReq:hRe,convertToMS:mRe,PACKAGE_ROOT:AAe};function LAe(e){return e instanceof Error?e:new Error(e)}a(LAe,"errorizeMessage");function ds(e){return e==null}a(ds,"isEmpty");function MAe(e){return!ds(e)&&(e||e===0||e===""||hJ(e))}a(MAe,"isNotEmptyAndHasValue");function to(e){return ds(e)||e.length===0||e.size===0}a(to,"isEmptyOrZeroLength");function vAe(e){if(ds(e))return!0;for(let t=0;t<e.length;t++)if(ds(e[t]))return!0;return!1}a(vAe,"arrayHasEmptyValues");function UAe(e){if(to(e))return!0;for(let t=0;t<e.length;t++)if(to(e[t]))return!0;return!1}a(UAe,"arrayHasEmptyOrZeroLengthValues");function xAe(...e){try{return e.join(hc.sep)}catch{console.error(e)}}a(xAe,"buildFolderPath");function hJ(e){return ds(e)?!1:e===!0||e===!1}a(hJ,"isBoolean");function BAe(e){return ds(e)?!1:typeof e=="object"}a(BAe,"isObject");function HAe(e){return to(e)?PAe:e.slice(0,-DAe)}a(HAe,"stripFileExtension");function kAe(e){return ds(e)||e===""||typeof e!="string"?e:fJ[e]!==void 0?fJ[e]:EJ(e)===!0?Number(e):wAe.test(e)?new Date(e):e}a(kAe,"autoCast");function mJ(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(mJ,"autoCastJSON");function qP(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=qP(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=qP(r);n!==r&&(e[t]=n)}return e}else return mJ(e)}a(qP,"autoCastJSONDeep");function EJ(e){if(e.startsWith("0.")&&dJ(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&dJ(e))}a(EJ,"autoCasterIsNumberCheck");async function FAe(e){if(to(e))throw new Error(`Directory path: ${e} does not exist`);try{await lJ.emptyDir(e),await lJ.remove(e)}catch(t){throw Ln.error(`Error removing files in ${e} -- ${t}`),t}}a(FAe,"removeDir");function GAe(e,t){if(to(e)){Ln.info("Invalid current version sent as parameter.");return}if(to(t)){Ln.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(GAe,"compareVersions");function qAe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(qAe,"isCompatibleDataVersion");function $Ae(e){if(ds(e))return e;let t=String(e);return t==="."?Rr.UNICODE_PERIOD:t===".."?Rr.UNICODE_PERIOD+Rr.UNICODE_PERIOD:t.replace(Rr.FORWARD_SLASH_REGEX,Rr.UNICODE_FORWARD_SLASH)}a($Ae,"escapeRawValue");function VAe(e){if(ds(e))return e;let t=String(e);return t===Rr.UNICODE_PERIOD?".":t===Rr.UNICODE_PERIOD+Rr.UNICODE_PERIOD?"..":String(e).replace(Rr.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(VAe,"unescapeValue");function KAe(e,t){if(ds(e))return Ln.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+RA.EOL}!to(n)&&n[0]===";"?r+=" "+n+s+RA.EOL:to(n)||(r+=n+"="+s+RA.EOL)}catch{Ln.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(KAe,"stringifyProps");function gJ(){let e;try{e=RA.homedir()}catch{e=process.env.HOME}return e}a(gJ,"getHomeDir");function YAe(){let e=hc.join(gJ(),Rr.HDB_HOME_DIR_NAME,Rr.BOOT_PROPS_FILE_NAME);return _J.existsSync(e)||(e=hc.join(__dirname,"../","hdb_boot_properties.file")),e}a(YAe,"getPropsFilePath");function WAe(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(WAe,"timeoutPromise");async function zAe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=SAe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(zAe,"isPortTaken");function jAe(e){try{return Rr.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){Ln.error(`Error checking operation against cluster ops ${t}`)}return!1}a(jAe,"isClusterOperation");function JAe(e,t){let r=(Pe(),C(tt)).getDatabases();if(!r[e])return bA.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return bA.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(JAe,"checkGlobalSchemaTable");function QAe(e,t){if(ds(t)){Ln.warn("No CLUSTERING_USER defined, clustering disabled");return}if(ds(e)||to(e)){Ln.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){Ln.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){Ln.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(QAe,"getClusterUser");function XAe(){uJ.parsePromise=function(e,t,r){return new Promise(function(n,s){uJ.parse(e,{header:!0,transformHeader:SJ,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(XAe,"promisifyPapaParse");function SJ(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(SJ,"removeBOM");function ZAe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;Ln.info(`Got cluster status event response: ${yAe(s)}`);try{i.cancel()}catch{Ln.error("Error trying to cancel timeout.")}n(s)})})}a(ZAe,"createEventPromise");async function eRe(e){let t=!0,r=0;do await pJ(IAe*r++),(await RAe.findPs(e)).length>0&&(t=!1);while(t&&r<CAe);if(t)throw new Error(`process ${e} was not started`)}a(eRe,"checkProcessRunning");function tRe(e,t){let r=TJ(e);if(r)return r;let n=AJ(e,t);if(n)return n}a(tRe,"checkSchemaTableExist");function TJ(e){let{getDatabases:t}=(Pe(),C(tt));if(!t()[e])return bA.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(TJ,"checkSchemaExists");function AJ(e,t){let{getDatabases:r}=(Pe(),C(tt));if(!r()[e][t])return bA.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(AJ,"checkTableExists");function rRe(){let e=yA().utc().add(1,"d").startOf("d").unix(),t=yA().utc().unix();return e-t}a(rRe,"getStartOfTomorrowInSeconds");function nRe(){return yA().utc().format("DD-MM-YYYY")}a(nRe,"getLimitKey");function sRe(e){try{let t=new TAe(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){Ln.error("Got an error back ticking items."),Ln.error(t)}}a(sRe,"backtickASTSchemaItems");function iRe(e){return[e]}a(iRe,"createForkArgs");function oRe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(oRe,"autoCastBoolean");function aRe(e,t){let{getDatabases:r}=(Pe(),C(tt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(aRe,"getTableHashAttribute");function cRe(e){let{getDatabases:t}=(Pe(),C(tt));return t()[e]!==void 0}a(cRe,"doesSchemaExist");function lRe(e,t){let{getDatabases:r}=(Pe(),C(tt));return r()[e]?.[t]!==void 0}a(lRe,"doesTableExist");function uRe(e){try{return JSON.stringify(e)}catch{return e}}a(uRe,"stringifyObj");function dRe(e){let t=yA.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(dRe,"ms_to_time");function fRe(e,t){let r=hc.basename(e,hc.extname(e));return hc.join(hc.dirname(e),r+t)}a(fRe,"changeExtension");function $P(){if(process.env[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=bAe(process.argv);if(e[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[Rr.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a($P,"getEnvCliRootPath");var GP;function _Re(){if(GP)return GP;let e=$P();if($P()&&_J.pathExistsSync(hc.join(e,Rr.HDB_CONFIG_FILE)))return GP=!0,!0}a(_Re,"noBootFile");function pRe(e,t){let r;return e.protocol==="http:"?r=NAe:r=OAe,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(pRe,"httpRequest");function hRe(e){if(!e.schema&&!e.database){e.schema=Rr.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(hRe,"transformReq");function mRe(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(mRe,"convertToMS")});var ae=w((wJ,IJ)=>{"use strict";var VP=require("fs-extra"),Xl=require("path"),yJ=require("os"),ERe=require("properties-reader"),qh=z(),Gh=ie(),Me=(H(),C(G)),OA=yt(),gRe="Error initializing environment manager",NA="BOOT_PROPS_FILE_PATH",bJ=!1,SRe={[Me.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},ta={};Object.assign(wJ,IJ.exports={BOOT_PROPS_FILE_PATH:NA,getHdbBasePath:TRe,setHdbBasePath:ARe,get:OJ,initSync:yRe,setProperty:Ke,initTestEnvironment:ORe,setCloneVar:bRe});function TRe(){return ta[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(TRe,"getHdbBasePath");function ARe(e){ta[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(ARe,"setHdbBasePath");function OJ(e){let t=OA.getConfigValue(e);return t===void 0?ta[e]:t}a(OJ,"get");function Ke(e,t){SRe[e]&&(ta[e]=t),OA.updateConfigObject(e,t)}a(Ke,"setProperty");function RRe(){let e;try{e=Gh.getPropsFilePath(),VP.accessSync(e,VP.constants.F_OK|VP.constants.R_OK),bJ=!0;let t=ERe(e);return ta[Me.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(Me.HDB_SETTINGS_NAMES.INSTALL_USER),ta[Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),ta[NA]=e,!0}catch{return qh.trace(`Environment manager found no properties file at ${e}`),!1}}a(RRe,"doesPropFileExist");function yRe(e=!1){try{((bJ||RRe()||Gh.noBootFile())&&!NJ||e)&&(OA.initConfig(e),ta[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=OA.getConfigValue(Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){qh.error(gRe),qh.error(t),console.error(t),process.exit(1)}}a(yRe,"initSync");var NJ=!1;function bRe(e){NJ=e}a(bRe,"setCloneVar");function ORe(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=Xl.join(__dirname,"../../","unitTests");ta[NA]=Xl.join(l,"hdb_boot_properties.file"),Ke(Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Xl.join(l,"settings.test")),Ke(Me.HDB_SETTINGS_NAMES.INSTALL_USER,yJ.userInfo()?yJ.userInfo().username:void 0),Ke(Me.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Ke(Me.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Xl.join(l,"envDir","log")),Ke(Me.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Ke(Me.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Ke(Me.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Ke(Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Xl.join(l,"envDir")),Ke(Me.CONFIG_PARAMS.STORAGE_PATH,Xl.join(l,"envDir")),s&&(Ke(Me.CONFIG_PARAMS.HTTP_SECUREPORT,OJ(Me.CONFIG_PARAMS.HTTP_PORT)),Ke(Me.CONFIG_PARAMS.HTTP_PORT,null)),Ke(Me.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Ke(Me.CONFIG_PARAMS.HTTP_PORT,9926),Ke(Me.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Ke(Me.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),Ke(Me.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,Gh.isEmpty(i)?!1:i),Ke(Me.CONFIG_PARAMS.HTTP_CORS,Gh.isEmpty(i)?!1:i),Ke(Me.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Ke(Me.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Ke(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Ke(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Ke(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Xl.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Ke(Me.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,Gh.isEmpty(c)?!1:c),o&&(Ke("CORS_ACCESSLIST",o),Ke(Me.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Ke(Me.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Ke(Me.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Ke(Me.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Ke(Me.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Ke(Me.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Ke(Me.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${NA}. Please check your boot props and settings files`;qh.fatal(r),qh.error(t)}}a(ORe,"initTestEnvironment")});var MJ=w((gxe,LJ)=>{"use strict";var IA=ae();IA.initSync();var wA=(H(),C(G)),{httpRequest:NRe}=ie(),DJ=require("path"),CJ=require("fs-extra"),wRe=require("yaml"),{packageDirectory:IRe}=(Vw(),C($w)),{encode:CRe}=require("cbor-x"),PRe=["describe_table","describe_all","describe_database","list_users","list_roles","drop_role","add_user","alter_user","drop_user","restart_service","restart","create_database","drop_database","create_table","drop_table","create_attribute","drop_attribute","search_by_id","insert","update","upsert","delete","search_by_value","csv_file_load","csv_url_load","cluster_get_routes","cluster_network","cluster_status","remove_node","add_component","deploy_component","package_component","drop_component","get_components","get_component_file","set_component_file","registration_info","get_fingerprint","set_license","get_job","search_jobs_by_start_date","read_log","read_transaction_log","read_audit_log","delete_transaction_logs_before","purge_stream","delete_records_before","install_node_modules","set_configuration","get_configuration","create_authentication_tokens","refresh_operation_token","system_information","sql","create_csr","sign_certificate","list_certificates","add_certificate","remove_certificate","add_ssh_key","update_ssh_key","delete_ssh_key","list_ssh_keys","set_ssh_known_hosts","get_ssh_known_hosts"],PJ={deploy:"deploy_component",package:"package_component"};LJ.exports={cliOperations:MRe,buildRequest:LRe};var DRe={deploy_component:a(async e=>{if(e.package)return;let t=process.cwd();e.payload=await IRe(t,{skip_node_modules:!0,...e}),e.cborEncode=!0,e.project||(e.project=DJ.basename(t))},"deploy_component")};function LRe(){let e={};for(let t of process.argv.slice(2))if(PRe.includes(t))e.operation=t;else if(PJ.hasOwnProperty(t))e.operation=PJ[t];else if(t.includes("=")){let[r,...n]=t.split("=");n=n.join("=");try{n=JSON.parse(n)}catch{}e[r]=n}return e}a(LRe,"buildRequest");async function MRe(e){e.target||(e.target=process.env.CLI_TARGET);let t;if(e.target){try{t=new URL(e.target)}catch(r){try{t=new URL(`https://${e.target}:9925`)}catch{throw r}}t={protocol:t.protocol,hostname:t.hostname,port:t.port,username:e.username||t.username||process.env.CLI_TARGET_USERNAME,password:e.password||t.password||process.env.CLI_TARGET_PASSWORD,rejectUnauthorized:e.rejectUnauthorized}}else CJ.existsSync(DJ.join(IA.get(wA.CONFIG_PARAMS.ROOTPATH),wA.HDB_PID_FILE))||(console.error("HarperDB must be running to perform this operation"),process.exit()),CJ.existsSync(IA.get(wA.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET))||(console.error("No domain socket found, unable to perform this operation"),process.exit());await DRe[e.operation]?.(e);try{let r=t??{protocol:"http:",socketPath:IA.get(wA.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)};r.method="POST",r.headers={"Content-Type":"application/json"},t?.username&&(r.headers.Authorization=`Basic ${Buffer.from(`${t.username}:${t.password}`).toString("base64")}`),e.cborEncode&&(r.headers["Content-Type"]="application/cbor",e=CRe(e));let n=await NRe(r,e),s;try{s=JSON.parse(n.body)}catch{s={status:n.statusCode+" "+(n.statusMessage||"Unknown"),body:n.body}}e.json?console.log(JSON.stringify(s,null,2)):console.log(wRe.stringify(s).trim())}catch(r){let n="Error: ";if(r?.response?.data?.error)n+=r.response.data.error;else if(r?.response?.data)n+=r?.response?.data;else return console.error(r);console.error(n)}}a(MRe,"cliOperations")});var xJ=w((Txe,UJ)=>{"use strict";var vJ=require("semver/functions/major"),{packageJson:vRe}=st(),KP=process.versions&&process.versions.node?process.versions.node:void 0;UJ.exports=URe;function URe(){let e=vRe.engines["minimum-node"];if(KP&&vJ(KP)<vJ(e))return{error:`The minimum version of Node.js HarperDB supports is: ${e}, the currently installed Node.js version is: ${KP}. Please install a version of Node.js that is withing the defined range.`}}a(URe,"checkNodeVersion")});var XP=w((yxe,n2)=>{"use strict";var BJ=require("os"),CA=require("https"),HJ=require("http"),qt=require("fs-extra"),kJ=require("yaml"),{pipeline:FJ}=require("stream/promises"),{createWriteStream:PA,ensureDir:$h,writeFileSync:GJ}=require("fs-extra"),{join:$s}=require("path"),KJ=require("lodash"),xRe=require("minimist"),ra=require("path"),BRe=require("node:crypto"),HRe=require("properties-reader"),qs=ae(),kRe=Po(),jP=z(),DA=yt(),{restart:FRe}=Wa(),LA=ie(),GRe=ua(),qRe=As(),{main:MA,launch:$Re}=Jd(),{install:YJ,updateConfigEnv:VRe,setIgnoreExisting:UA}=CT(),WJ=gC(),an=(H(),C(G)),{packageJson:KRe}=st(),YRe=mh(),{sendOperationToNode:zP}=(Xn(),C(wo)),{updateConfigCert:WRe}=Zn(),{restartWorkers:zRe}=et(),{databases:jRe}=(Pe(),C(tt)),{SYSTEM_TABLE_NAMES:YP,SYSTEM_SCHEMA_NAME:Rxe,CONFIG_PARAMS:Vh,OPERATIONS_ENUM:ps}=an,JRe=1e4,QRe="clone-node-config.yaml",zJ=[YP.ROLE_TABLE_NAME,YP.USER_TABLE_NAME,YP.NODE_TABLE_NAME],XRe={clustering_nodename:!0,clustering_leafserver_streams_path:!0,clustering_tls_certificate:!0,clustering_tls_privatekey:!0,clustering_tls_certificateauthority:!0,logging_file:!0,logging_root:!0,logging_rotation_path:!0,operationsapi_network_domainsocket:!0,operationsapi_tls_certificate:!0,operationsapi_tls_privatekey:!0,operationsapi_tls_certificateauthority:!0,rootpath:!0,storage_path:!0,storage_audit_path:!0,databases:!0,mqtt_network_mtls_certificateauthority:!0,componentsroot:!0,tls_certificate:!0,tls_privatekey:!0,tls_certificateauthority:!0,replication_hostname:!0,replication_url:!0,cloned:!0},kr={HDB_LEADER_USERNAME:"HDB_LEADER_USERNAME",HDB_LEADER_PASSWORD:"HDB_LEADER_PASSWORD",HDB_LEADER_URL:"HDB_LEADER_URL",REPLICATION_HOSTNAME:"REPLICATION_HOSTNAME",HDB_CLONE_OVERTOP:"HDB_CLONE_OVERTOP",CLONE_KEYS:"CLONE_KEYS",CLONE_USING_WS:"CLONE_USING_WS",NO_START:"NO_START"},sa=xRe(process.argv),pf=sa[kr.HDB_LEADER_USERNAME]??process.env[kr.HDB_LEADER_USERNAME],hf=sa[kr.HDB_LEADER_PASSWORD]??process.env[kr.HDB_LEADER_PASSWORD],eu=sa[kr.HDB_LEADER_URL]??process.env[kr.HDB_LEADER_URL],na=sa[kr.REPLICATION_HOSTNAME]??process.env[kr.REPLICATION_HOSTNAME],jJ,JJ;na&&([jJ,JJ]=na.split(":"));var JP=(sa[kr.HDB_CLONE_OVERTOP]??process.env[kr.HDB_CLONE_OVERTOP])==="true",QJ=sa[Vh.CLONED.toUpperCase()]??process.env[Vh.CLONED.toUpperCase()],ZRe=sa[kr.CLONE_KEYS]!=="false"&&process.env[kr.CLONE_KEYS]!=="false",XJ=(sa[kr.CLONE_USING_WS]??process.env[kr.CLONE_USING_WS])==="true",ZJ=(sa[kr.NO_START]??process.env[kr.NO_START])==="true",_s,mc={},qJ,$J,Zl={},on,Lt,Gs,ro,tu=!1,QP=!1,fs,mf;n2.exports=a(async function(t=!1,r=!1){if(console.info(`Starting clone node from leader node: ${eu}`),delete process.env.HDB_LEADER_URL,Lt=LA.getEnvCliRootPath(),!Lt)try{let i=$s(BJ.homedir(),an.HDB_HOME_DIR_NAME,an.BOOT_PROPS_FILE_NAME);if(await qt.pathExists(i)){let o=HRe(i);Lt=ra.parse(o.get(an.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)).dir}}catch{throw new Error("There was an error setting the clone default root path. Please set ROOTPATH using an environment or CLI variable.")}Lt?await qt.pathExists(Lt)?console.log(`Existing HarperDB install found at ${Lt}. Clone node will only clone items that do not already exist on clone.`):(console.log(`No HarperDB install found at ${Lt} starting fresh clone`),tu=!0):(console.log("No HarperDB install found, starting fresh clone"),tu=!0),Lt||(Lt=$s(BJ.homedir(),an.HDB_ROOT_DIR_NAME),console.log("Using default root path",Lt));let n;try{n=$s(Lt,QRe),_s=kJ.parseDocument(await qt.readFile(n,"utf8"),{simpleKeys:!0}).toJSON(),console.log("Clone config file found")}catch{}let s=$s(Lt,an.HDB_CONFIG_FILE);if(await qt.pathExists(s))try{qJ=kJ.parseDocument(await qt.readFile(s,"utf8"),{simpleKeys:!0}).toJSON(),mc=DA.flattenConfig(qJ)}catch(i){console.error("Error reading existing harperdb-config.yaml on clone",i)}if(na){let i=new URL(eu);mf=`${i.protocol==="https:"?"wss://":"ws://"}${i.hostname}:${JJ||9933}`}if(XJ){await eye();return}if(mc?.cloned&&QJ!=="false")return console.log("Instance marked as cloned, clone will not run"),qs.setCloneVar(!1),qs.initSync(),MA();on=await vA({operation:ps.DESCRIBE_ALL}),await t2(),qs.setCloneVar(!1),qs.setHdbBasePath(Lt),qt.ensureDir(qs.get(an.CONFIG_PARAMS.LOGGING_ROOT)),jP.initLogSettings(),await rye(),QP||await nye(),await oye(t,r),na&&(await cye(),await e2()),console.info(`
135
- Successfully cloned node: `+eu),(t||ZJ)&&process.exit()},"cloneNode");async function eye(){if(mc?.cloned&&QJ!=="false")return console.log("Instance marked as cloned, clone will not run"),qs.setCloneVar(!1),qs.initSync(),MA();console.log("Cloning using WebSockets");let e=Ec("system"),t=$s(e,"system.mdb"),r=qt.existsSync(t);tu||!r||JP?(console.info("Clone node installing HarperDB"),process.env.TC_AGREEMENT="yes",process.env.ROOTPATH=Lt,process.env.HDB_ADMIN_USERNAME="clone-temp-admin",process.env.HDB_ADMIN_PASSWORD=BRe.randomBytes(10).toString("base64").slice(0,10),UA(!0),await YJ()):(qs.setCloneVar(!1),qs.initSync()),await MA(),await t2(!0),await WRe(),r||await jRe.system.hdb_user.delete({username:"clone-temp-admin"}),await zRe(),await tye(),console.log("Adding node to the cluster");let s=await gd()({operation:ps.ADD_NODE,url:mf});console.log("Add node response: ",s),await e2(),console.log(`Successfully cloned node: ${eu} using WebSockets`),DA.updateConfigValue(Vh.CLONED,!0),ZJ&&process.exit()}a(eye,"cloneUsingWS");async function tye(){let e=a(i=>{let o=0;for(let c in i){let l=i[c];typeof l=="object"&&l.last_updated_record>o&&(o=l.last_updated_record)}return o},"findMostRecentTimestamp");console.log("Getting last updated record timestamp for all database");let t={},r=await vA({operation:"describe_database",database:"system"});t.system=e(r);let n=await vA({operation:"describe_all"});for(let i in n)typeof n[i]=="object"&&(t[i]=e(n[i]));let s=$s(Lt,"tmp","lastUpdated.json");console.log("Writing last updated database timestamps to:",s),await qt.outputJson(s,t)}a(tye,"getLastUpdatedRecord");async function vA(e){return XJ?zP({url:mf},e,{rejectUnauthorized:!1}):JSON.parse((await lye(e)).body)}a(vA,"leaderReq");async function e2(){try{if(ZRe!==!1){console.log("Cloning JWT keys");let e=ra.join(Lt,an.LICENSE_KEY_DIR_NAME),t=await zP({url:mf},{operation:ps.GET_KEY,name:".jwtPublic"},{rejectUnauthorized:!1});GJ(ra.join(e,an.JWT_ENUM.JWT_PUBLIC_KEY_NAME),t.message);let r=await zP({url:mf},{operation:ps.GET_KEY,name:".jwtPrivate"},{rejectUnauthorized:!1});GJ(ra.join(e,an.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r.message)}}catch(e){console.error("Error cloning JWT keys",e)}}a(e2,"cloneKeys");async function t2(e=!1){console.info("Cloning configuration"),$J=await vA({operation:ps.GET_CONFIGURATION}),Zl=DA.flattenConfig($J);let t=_s?.componentConfig?.exclude,r={rootpath:Lt};na&&(r.replication_hostname=jJ);for(let i in Zl)if(!(Zl[i]!==null&&typeof Zl[i]=="object"&&!(Zl[i]instanceof Array)||XRe[i])){if(i.includes("_package")||i.includes("_port")){if(Zl[i]?.includes?.("hdb/components"))continue;if(t){let o=!1;for(let c of t)if(i.includes(c.name)){o=!0;break}if(o)continue}}mc[i]||(r[i]=Zl[i])}for(let i in mc)i!=="databases"&&typeof mc[i]=="object"&&!(mc[i]instanceof Array)||(r[i]=mc[i]);let n={};if(_s?.databaseConfig?.excludeDatabases&&_s.databaseConfig.excludeDatabases.forEach(i=>{n[i.database]=!0}),_s?.clusteringConfig?.excludeDatabases&&_s.clusteringConfig.excludeDatabases.forEach(i=>{n[i.database]=!0}),Object.keys(n).length>0){r.replication_databases=[],n.system||r.replication_databases.push("system");for(let i in on)n[i]||r.replication_databases.push(i)}let s=GRe(Object.keys(an.CONFIG_PARAM_MAP),!0);Object.assign(r,s),e||(r.cloned=!0),DA.createConfigFile(r,!0)}a(t2,"cloneConfig");async function rye(){process.env.HDB_FETCH==="true"?(await iye(),process.env.NODE_TLS_REJECT_UNAUTHORIZED&&delete process.env.NODE_TLS_REJECT_UNAUTHORIZED):await sye()}a(rye,"cloneDatabases");async function nye(){if(console.info("Clone node installing HarperDB."),process.env.TC_AGREEMENT="yes",process.env.ROOTPATH=Lt,!pf)throw new Error("HDB_LEADER_USERNAME is undefined.");if(process.env.HDB_ADMIN_USERNAME=pf,!hf)throw new Error("HDB_LEADER_PASSWORD is undefined.");process.env.HDB_ADMIN_PASSWORD=hf,process.env.OPERATIONSAPI_NETWORK_PORT=qs.get(Vh.OPERATIONSAPI_NETWORK_PORT),VRe(ra.join(Lt,an.HDB_CONFIG_FILE)),UA(!0),await YJ()}a(nye,"installHDB");function Ec(e){return qs.get(an.CONFIG_PARAMS.DATABASES)?.[e]?.path||qs.get(Vh.STORAGE_PATH)||ra.join(Lt,an.DATABASES_DIR_NAME)}a(Ec,"getDBPath");async function sye(){let e=Ec("system"),t=$s(e,"system.mdb");if(await $h(e),tu||!await qt.exists(t)||JP){if(!na){console.info("Cloning system database"),await $h(e);let r=PA(t,{overwrite:!0}),n={operation:ps.GET_BACKUP,database:"system",tables:zJ},s=await VJ(n,r),i=new Date(s.date);(!fs||i<fs)&&(fs=i),await qt.utimes(t,Date.now(),i)}tu||(await WJ(Lt),await r2(),UA(!0))}else QP=!0,console.log("Not cloning system database due to it already existing on clone");Gs=_s?.databaseConfig?.excludeDatabases,Gs=Gs?Gs.reduce((r,n)=>({...r,[n.database]:!0}),{}):{};for(let r in on)await qt.exists(ra.join(Ec(r),r+".mdb"))&&(console.log(`Not cloning database ${r} due to it already existing on clone`),Gs[r]=!0);ro=_s?.databaseConfig?.excludeTables,ro=ro?ro.reduce((r,n)=>({...r,[n.database==null?null:n.database+n.table]:!0}),{}):{};for(let r in on){if(Gs[r]){on[r]="excluded";continue}if(KJ.isEmpty(on[r]))continue;let n=[],s=!1;for(let d in on[r])ro[r+d]?(s=!0,on[r][d]="excluded"):n.push(on[r][d]);if(n.length===0)continue;if(na){jP.debug("Setting up tables for #{db}");let d=(Pe(),C(tt)).table;for(let p of n){for(let _ of p.attributes)(_.is_hash_attribute||_.is_primary_key)&&(_.isPrimaryKey=!0);d({database:r,table:p.name,attributes:p.attributes})}continue}n=n.map(d=>d.name);let i;s?(console.info(`Cloning database: ${r} tables: ${n}`),i={operation:ps.GET_BACKUP,database:r,tables:n}):(console.info(`Cloning database: ${r}`),i={operation:ps.GET_BACKUP,database:r});let o=Ec(r);await $h(o);let c=$s(o,r+".mdb"),l=PA(c,{overwrite:!0}),u=await VJ(i,l),f=new Date(u.date);(!fs||f<fs)&&(fs=f),await qt.utimes(c,Date.now(),f)}}a(sye,"cloneTablesHttp");async function iye(){let e=Ec("system"),t=$s(e,"system.mdb");if(tu||!await qt.exists(t)||JP){if(!na){console.info("Cloning system database using fetch");let r={operation:ps.GET_BACKUP,database:"system",tables:zJ},n=await WP(r,!0),s=Ec("system");await $h(s);let i=$s(s,"system.mdb");await FJ(n.body,PA(i,{overwrite:!0}));let o=new Date(n.headers.get("date"));(!fs||o<fs)&&(fs=o),await qt.utimes(i,Date.now(),new Date(n.headers.get("date")))}tu||(await WJ(Lt),await r2(),UA(!0))}else QP=!0,console.log("Not cloning system database due to it already existing on clone");if(na){jP.info("Replication hostname set, not using backup to clone databases, replication will clone");return}Gs=_s?.databaseConfig?.excludeDatabases,Gs=Gs?Gs.reduce((r,n)=>({...r,[n.database]:!0}),{}):{};for(let r in on)await qt.exists(ra.join(Ec(r),r+".mdb"))&&(console.log(`Not cloning database ${r} due to it already existing on clone`),Gs[r]=!0);ro=_s?.databaseConfig?.excludeTables,ro=ro?ro.reduce((r,n)=>({...r,[n.database==null?null:n.database+n.table]:!0}),{}):{};for(let r in on){if(Gs[r]){on[r]="excluded";continue}if(KJ.isEmpty(on[r]))continue;let n=[],s=!1;for(let f in on[r])ro[r+f]?(s=!0,on[r][f]="excluded"):n.push(f);if(n.length===0)return;let i;s?(console.info(`Cloning database: ${r} tables: ${n}`),i=await WP({operation:ps.GET_BACKUP,database:r,tables:n},!0)):(console.info(`Cloning database: ${r}`),i=await WP({operation:ps.GET_BACKUP,database:r},!0));let o=Ec(r);await $h(o);let c=new Date(i.headers.get("date")),l=$s(o,`${c.getTime()}-${r}.mdb`);await FJ(i.body,PA(l,{overwrite:!0}));let u=$s(o,r+".mdb");await qt.rename(l,u),(!fs||c<fs)&&(fs=c),await qt.utimes(u,Date.now(),c)}}a(iye,"cloneTablesFetch");async function WP(e,t=!1){let r=_s?.httpsRejectUnauthorized??!1,n=new CA.Agent({rejectUnauthorized:r});r||(process.env.NODE_TLS_REJECT_UNAUTHORIZED="0");let i={Authorization:"Basic "+Buffer.from(pf+":"+hf).toString("base64"),"Content-Type":"application/json"};t&&(i["Accept-Encoding"]="gzip");let o=await fetch(eu,{method:"POST",headers:i,body:JSON.stringify(e),agent:n,compress:!0});if(o.ok)return o;throw console.error(`HTTP Error Response: ${o.status} ${o.statusText}`),new Error(await o.text())}a(WP,"leaderHttpReqFetch");async function oye(e,t=!1){let r=await kRe.getHDBProcessInfo();r.clustering.length===0||r.core.length===0?e?await $Re(!1):(t&&await aye(),await MA()):(console.info(await FRe({operation:ps.RESTART})),await LA.async_set_timeout(JRe)),e&&await LA.async_set_timeout(2e3)}a(oye,"startHDB");async function aye(){let e=process.argv[3];e&&e[0]!=="-"&&(await qt.exists(e)||console.error(`The folder ${e} does not exist`),qt.statSync(e).isDirectory()||console.error(`The path ${e} is not a folder`),e=await qt.realpath(e),await qt.exists(ra.join(e,an.HDB_CONFIG_FILE))?process.env.ROOTPATH=e:process.env.RUN_HDB_APP=e)}a(aye,"setAppPath");async function cye(){console.info("Setting up replication"),await qRe.setSchemaDataToGlobalAsync();let t=await gd()({operation:ps.ADD_NODE,verify_tls:!1,url:mf,start_time:fs,authorization:{username:pf,password:hf}},!0);console.log("Add node response: ",t)}a(cye,"setupReplication");async function lye(e){let t=new CA.Agent({rejectUnauthorized:_s?.httpsRejectUnauthorized??!1}),n={Authorization:"Basic "+Buffer.from(pf+":"+hf).toString("base64"),"Content-Type":"application/json"},s=new URL(eu),i={protocol:s.protocol,host:s.hostname,method:"POST",headers:n};return s.protocol==="https:"&&(i.agent=t),s.port&&(i.port=s.port),await LA.httpRequest(i,e)}a(lye,"leaderHttpReq");async function VJ(e,t){let r=new CA.Agent({rejectUnauthorized:_s?.httpsRejectUnauthorized??!1}),s={Authorization:"Basic "+Buffer.from(pf+":"+hf).toString("base64"),"Content-Type":"application/json"},i=new URL(eu),o={protocol:i.protocol,host:i.hostname,method:"POST",headers:s};return i.protocol==="https:"&&(o.agent=r,HJ=CA),i.port&&(o.port=i.port),new Promise((c,l)=>{let u=HJ.request(o,f=>{f.statusCode!==200&&l("Request to leader node failed with code: "+f.statusCode),f.pipe(t),f.on("end",()=>{t.close(),c(f.headers)})});u.on("error",f=>{l(f)}),u.write(JSON.stringify(e)),u.end()})}a(VJ,"leaderHttpStream");async function r2(){let e=KRe.version;if(e)await YRe.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(r2,"insertHdbVersionInfo")});var i2=w((Oxe,s2)=>{var uye=CT(),dye=z();s2.exports=fye;async function fye(){try{await uye.install()}catch(e){console.error("There was an error during the install."),console.error(e),dye.error(e),process.exit(1)}}a(fye,"install")});var c2=w((wxe,a2)=>{"use strict";var _ye=hS(),pye=z(),o2="Registration failed.";async function hye(){let e;try{e=await _ye.register()}catch(t){return pye.error(`Registration error ${t}`),o2}return e||o2}a(hye,"register");a2.exports={register:hye}});var f2=w((Cxe,d2)=>{"use strict";var mye=z(),Eye=(H(),C(G)),gye=require("util"),Sye=require("child_process"),l2=gye.promisify(Sye.exec),Tye=Po(),Kh=Cd(),u2="Stopping HarperDB.";d2.exports=Aye;async function Aye(){if(console.log(u2),mye.notify(u2),await Kh.isServiceRegistered(Eye.PROCESS_DESCRIPTORS.HDB)){Kh.enterPM2Mode();let r=await Kh.getUniqueServicesList();for(let n in r)await Kh.stop(n)}await Kh.kill();let t=await Tye.getHDBProcessInfo();t.clustering.forEach(r=>{l2(`kill ${r.pid}`)}),t.core.forEach(r=>{l2(`kill ${r.pid}`)})}a(Aye,"stop")});var h2=w((Dxe,p2)=>{"use strict";var eD=require("fs-extra"),tD=require("path"),ZP=require("yaml"),Yh=ir(),gc=(H(),C(G)),_2=Tt(),rD=z(),Rye=An(),yye=lS(),bye=aS(),Oye=Po(),Wh=ae(),Nye=Jd(),wye=ie();Wh.initSync();var Vs={RUNNING:"running",STOPPED:"stopped",ERRORED:"errored",NOT_INSTALLED:"not installed"},Mn={LEAF:"leaf server",HUB:"hub server"},xA;p2.exports=Iye;async function Iye(){let e={harperdb:{status:Vs.STOPPED}};if(!await Nye.isHdbInstalled()){e.harperdb.status=Vs.NOT_INSTALLED,console.log(ZP.stringify(e));return}xA=Wh.get(gc.CONFIG_PARAMS.ROOTPATH);let t;try{t=Number.parseInt(await eD.readFile(tD.join(xA,gc.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===gc.NODE_ERROR_CODES.ENOENT){rD.info("`harperdb status` did not find a hdb.pid file"),e.harperdb.status=Vs.STOPPED,console.log(ZP.stringify(e));return}throw n}let r=await Oye.getHDBProcessInfo();for(let n of r.core)if(n.pid===t){e.harperdb.status=Vs.RUNNING,e.harperdb.pid=t;break}if((Wh.get(gc.CONFIG_PARAMS.REPLICATION_URL)||Wh.get(gc.CONFIG_PARAMS.REPLICATION_HOSTNAME))&&(e.replication=await Pye()),e.clustering=await Cye(r),e.clustering[Mn.HUB].status===Vs.RUNNING&&e.clustering[Mn.LEAF].status===Vs.RUNNING){let n=[],s=await yye({});for(let o of s.nodes){let c={};for(let l in o)c[l.replace("_"," ")]=o[l];n.push(c)}e.clustering.network=n;let i=await bye.clusterStatus();e.clustering.replication={"node name":i.node_name,"is enabled":i.is_enabled,connections:[]};for(let o of i.connections){let c={};c["node name"]=o?.node_name,c.status=o?.status,c.ports={clustering:o?.ports?.clustering,"operations api":o?.ports?.operations_api},c["latency ms"]=o?.latency_ms,c.uptime=o?.uptime,c.subscriptions=o?.subscriptions,c["system info"]={"hdb version":o?.system_info?.hdb_version,"node version":o?.system_info?.node_version,platform:o?.system_info?.platform},e.clustering.replication.connections.push(c)}await Yh.closeConnection()}console.log(ZP.stringify(e)),process.exit()}a(Iye,"status");async function Cye(e){let t={[Mn.HUB]:{},[Mn.LEAF]:{}};if(e.clustering.length===0)return t[Mn.HUB].status=Vs.STOPPED,t[Mn.LEAF].status=Vs.STOPPED,t;let{port:r}=Yh.getServerConfig(gc.PROCESS_DESCRIPTORS.CLUSTERING_HUB),{username:n,decrypt_hash:s}=await Rye.getClusterUser();try{(await Yh.createConnection(r,n,s,!1)).close(),t[Mn.HUB].status=Vs.RUNNING}catch{t[Mn.HUB].status=Vs.ERRORED}let{port:i}=Yh.getServerConfig(gc.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);try{(await Yh.createConnection(i,n,s,!1)).close(),t[Mn.LEAF].status=Vs.RUNNING}catch{t[Mn.LEAF].status=Vs.ERRORED}try{t[Mn.HUB].pid=Number.parseInt(await eD.readFile(tD.join(xA,"clustering",_2.PID_FILES.HUB),"utf8"))}catch(o){rD.error(o),t[Mn.HUB].pid=void 0}try{t[Mn.LEAF].pid=Number.parseInt(await eD.readFile(tD.join(xA,"clustering",_2.PID_FILES.LEAF),"utf8"))}catch(o){rD.error(o),t[Mn.LEAF].pid=void 0}return t}a(Cye,"getHubLeafStatus");async function Pye(){let e=await wye.httpRequest({method:"POST",protocol:"http:",socketPath:Wh.get(gc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET),headers:{"Content-Type":"application/json"}},{operation:"cluster_status"});e=JSON.parse(e.body);let t={"node name":e.node_name,"is enabled":e.is_enabled,connections:[]};for(let r of e.connections)t.connections.push({"node name":r.name,url:r.url,subscriptions:r.subscriptions,replicates:r.replicates,"database sockets":r.database_sockets.map(n=>({database:n.database,connected:n.connected,latency:n.latency,"catching up from":n.catching_up_from,"thread id":n.thread_id,nodes:n.nodes}))});return t}a(Pye,"getReplicationStatus")});rm();var nD=process.env.HDB_LEADER_URL||process.argv.includes("--HDB_LEADER_URL");nD&&ae().setCloneVar(!0);var zh=require("node:fs"),m2=require("node:path"),ru=z(),E2=MJ(),{packageJson:Dye,PACKAGE_ROOT:g2}=st(),Lye=xJ(),sD=(H(),C(G)),{SERVICE_ACTIONS_ENUM:cn}=sD,Mye=`
131
+ `))}},25).unref()}o.close?.(()=>{if(Et.get(Xt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&Xd()==0)try{iz(cz(Et.get(Xt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,HT),o.cantCleanupProperly||Ln.warn("Had to forcefully exit the thread",HT),process.exit(0)},5e3).unref()})}if(lz||process.env.DEV_MODE)try{require("inspector").close()}catch(i){Ln.info("Could not close debugger",i)}}}).ref();let e;bh&&!xSe&&(e=dz()),Promise.resolve(e).then(()=>{if(Xd()===0)try{MSe(FC)}catch(t){console.error("Error displaying start-up log",t)}Oh?.postMessage({type:Xt.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(uz,"startServers");function dz(){let e=[];for(let t in Qi){let r=Qi[t];if(t.includes?.("/")&&Xd()==0){NSe(t)&&iz(t),e.push(new Promise((o,c)=>{r.listen({path:t},()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),Ln.info("Domain socket listening on "+t)}).on("error",c)}));continue}let n,s=Et.get(Xt.CONFIG_PARAMS.HTTP_THREADRANGE);if(s){let o=typeof s=="string"?s.split("-"):s,c=Xd();if(c<o[0]||c>o[1])continue}let i;try{let o=t.lastIndexOf(":");o>0?bh?n={fd:bh(+t.slice(o+1).replace(/[\[\]]/g,""),t.slice(0,o))}:n={host:+t.slice(o+1).replace(/[\[\]]/g,""),port:t.slice(0,o)}:bh?n={fd:bh(+t,"::")}:n={port:t}}catch(o){console.error(`Unable to bind to port ${t}`,o);continue}e.push(new Promise((o,c)=>{r.listen(n,()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),Ln.trace("Listening on port "+t,HT)}).on("error",c)}))}return Promise.all(e)}a(dz,"listenOnPorts");!HC&&!gSe?.noServerStart&&uz();function $C(e,t,r){let n=e?.read?e:new SSe({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=Qi[t];if(s.isSecure&&(n.startTime=performance.now()),s)typeof s=="function"?s(n):s.emit("connection",n),r&&n.emit("data",r);else{let i=a(o=>{setTimeout(()=>{let c=Qi[t];c?(typeof c=="function"?c(n):c.emit("connection",n),r&&n.emit("data",r)):o<5?i(o+1):(Ln.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a($C,"deliverSocket");var ez=new Map;function BSe(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=ez.get(s),r){case"connection":i=$C(void 0,t),ez.set(s,i),i.write=(c,l,u)=>(Oh.postMessage({requestId:s,event:"data",data:c.toString("latin1")}),u&&u(),!0),i.end=(c,l,u)=>(Oh.postMessage({requestId:s,event:"end",data:c?.toString("latin1")}),u&&u(),!0);let o=i.destroy;i.destroy=()=>{o.call(i),Oh.postMessage({requestId:s,event:"destroy"})};break;case"data":i._readableState.destroyed||i.emit("data",Buffer.from(n,"latin1"));break;case"drain":i._readableState.destroyed||i.emit("drain",{});break;case"end":i._readableState.destroyed||i.emit("end",{});break;case"error":i._readableState.destroyed||i.emit("error",{});break}}a(BSe,"proxyRequest");var{getComponentName:FT}=(jp(),C(zp));function VC(e,t,r=!0){t||(t=Et.get(Xt.CONFIG_PARAMS.HTTP_PORT));let n=Qi[t];if(n){let s=n.lastServer||n;if(s===e)throw new Error(`Can not register the same server twice for the same port ${t}`);if(r&&!!s.sessionIdContext!=!!e.sessionIdContext&&+t)throw new Error(`Can not mix secure HTTPS and insecure HTTP on the same port ${t}`);s.off("unhandled",sz),s.on("unhandled",(i,o)=>{e.cantCleanupProperly&&(n.cantCleanupProperly=!0),e.emit("request",i,o)}),n.lastServer=e}else Qi[t]=e;e.on("unhandled",sz)}a(VC,"registerServer");function KC(e){let t=[],r=e?.securePort;return r&&t.push({port:r,secure:!0}),r=e?.port,r&&t.push({port:r,secure:!1}),t.length===0&&(t=[],Et.get(Xt.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:Et.get(Xt.CONFIG_PARAMS.HTTP_PORT),secure:Et.get(Xt.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),Et.get(Xt.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:Et.get(Xt.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&Et.get(Xt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:cz(Et.get(Xt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)),secure:!1}),t}a(KC,"getPorts");function YC(e,t){let r=[];for(let{port:n,secure:s}of KC(t))r.push(fz(n,s,t?.isOperationsServer,t?.mtls)),typeof e=="function"?GC[t?.runFirst?"unshift":"push"]({listener:e,port:t?.port||n}):(e.isSecure=s,VC(e,n,!1)),kT[n]=qT(GC,n);return r}a(YC,"httpServer");function GT(e,t){let r=FC.get(e)??[];FC.set(e,[...r,t])}a(GT,"setPortServerMap");function fz(e,t,r,n){if(GT(e,{protocol_name:t?"HTTPS":"HTTP",name:FT()}),!BT[e]){let s=r?"operationsApi_network":"http",i=Et.get(s+"_keepAliveTimeout"),o=Et.get(s+"_timeout"),c=Et.get(s+"_headersTimeout"),l={keepAliveTimeout:i,headersTimeout:c,requestTimeout:o,highWaterMark:128*1024,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,maxHeaderSize:Et.get(Xt.CONFIG_PARAMS.HTTP_MAXHEADERSIZE)},u=Et.get(s+"_mtls"),f=Et.get(s+"_mtls_required"),d;t&&(d=Et.get(s+"_http2"),Object.assign(l,{allowHTTP1:!0,rejectUnauthorized:!!f,requestCert:!!(u||n),ticketKeys:CSe(),SNICallback:az(r?"operations-api":"server",u)}));let p=LSe(),_=BT[e]=(t?d?bSe:ySe:ASe)(l,async(h,S)=>{try{let R=performance.now(),E=new oz(h,S);r&&(E.isOperationsServer=!0);let T=await kT[e](E);if(!T){if(E._nodeResponse.statusCode)return;T=_z(E)}if(T.headers?.set||(T.headers=new kC(T.headers)),p?T.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):T.headers?.set?.("Server","HarperDB"),T.status===-1){for(let ne of T.headers||[])S.setHeader(ne[0],ne[1]);return h.baseRequest=E,S.baseResponse=T,BT[e].emit("unhandled",h,S)}let b=T.status||200,v=performance.now(),F=v-R,q=T.body,Y,Z=!1;if(!T.handlesHeaders){let ne=T.headers||new kC;q?q.length>=0?(typeof q=="string"?ne.set("Content-Length",Buffer.byteLength(q)):ne.set("Content-Length",q.length),Y=!0):q instanceof OSe&&(q.size?ne.set("Content-Length",q.size):q.on&&(Z=!0,q.on("size",me=>{S.headersSent||S.setHeader("Content-Length",me)})),q=q.stream()):(ne.set("Content-Length","0"),Y=!0);let J=`hdb;dur=${F.toFixed(2)}`;if(T.wasCacheMiss&&(J+=", miss"),DSe(ne,"Server-Timing",J,!0),!S.headersSent)if(Z){if(S.statusCode=b,ne)if(ne[Symbol.iterator])for(let[me,ye]of ne)S.setHeader(me,ye);else for(let me in ne)S.setHeader(me,ne[me])}else S.writeHead(b,ne&&(ne[Symbol.iterator]?Array.from(ne):ne));Y&&S.end(q)}let se=E.handlerPath,Q=E.method;if(Rh(F,"duration",se,Q,T.wasCacheMiss==null?void 0:T.wasCacheMiss?"cache-miss":"cache-hit"),XW(b<400,"success",se,Q),XW(1,"response_"+b,se,Q),!Y)if(q instanceof ReadableStream&&(q=ZW.fromWeb(q)),(q[Symbol.iterator]||q[Symbol.asyncIterator])&&(q=ZW.from(q)),q?.pipe){q.pipe(S),q.destroy&&S.on("close",()=>{q.destroy()});let ne=0;q.on("data",J=>{ne+=J.length}),q.on("end",()=>{Rh(performance.now()-v,"transfer",se,Q),Rh(ne,"bytes-sent",se,Q)})}else q?.then?q.then(ne=>{S.end(ne)},g):S.end(q)}catch(R){g(R)}function g(R){let E=R.headers;S.writeHead(R.statusCode||500,E&&(E[Symbol.iterator]?Array.from(E):E)),S.end(R.toString()),R.statusCode?R.statusCode===500?Ln.warn(R):Ln.info(R):Ln.error(R)}a(g,"onError")});i>=0&&(_.keepAliveTimeout=i),c>=0&&(_.headersTimeout=c),t&&(_.ports||(_.ports=[]),_.ports.push(e),l.SNICallback.initialize(_),u&&(_.mtlsConfig=u),_.on("secureConnection",h=>{h._parent.startTime&&Rh(performance.now()-h._parent.startTime,"tls-handshake",e),Rh(h.isSessionReused(),"tls-reused",e)}),_.isSecure=!0),VC(_,e)}return BT[e]}a(fz,"getHTTPServer");function qT(e,t){let r=_z;for(let n=e.length;n>0;){let{listener:s,port:i}=e[--n];if(i===t||i==="all"){let o=r;r=a((...c)=>s(...c,o),"next_callback")}}return r}a(qT,"makeCallbackChain");function _z(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new kC}}a(_z,"unhandled");function HSe(e,t){YC(e,{requestOnly:!0,...t})}a(HSe,"onRequest");function kSe(e,t){let r;if(t.securePort){GT(t.securePort,{protocol_name:"TLS",name:FT()});let n=az("server",t.mtls);r=ISe({rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,SNICallback:n},e),n.initialize(r),Qi[t.securePort]=r}return t.port&&(GT(t.port,{protocol_name:"TCP",name:FT()}),r=TSe(e,{noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600}),Qi[t.port]=r),r}a(kSe,"onSocket");Object.defineProperty(RSe.prototype,"upgrade",{get(){return"connection"in this.headers&&"upgrade"in this.headers&&this.headers.connection.toLowerCase().includes("upgrade")&&this.headers.upgrade.toLowerCase()=="websocket"},set(e){}});var tz=[],qC={};function pz(e,t){for(let{port:r}of KC(t))tz[t?.runFirst?"unshift":"push"]({listener:e,port:r}),qC[r]=qT(tz,r)}a(pz,"onUpgrade");var rz=[],nz={};function FSe(e,t){let r=[];for(let{port:n,secure:s}of KC(t)){GT(n,{protocol_name:s?"WSS":"WS",name:FT()});let i=fz(n,s,t?.isOperationsServer,t?.mtls);yh[n]||(yh[n]=new wSe({noServer:!0,maxPayload:t.maxPayload??100*1024*1024}),yh[n].on("connection",(o,c)=>{let l=new oz(c);l.isWebSocket=!0;let u=kT[n](l);nz[n](o,l,u)}),pz((o,c,l,u)=>o.__harperdb_request_upgraded?u(o,c,l):yh[n].handleUpgrade(o,c,l,f=>{o.__harperdb_request_upgraded=!0,u(o,c,l),yh[n].emit("connection",f,o)}),{port:n}),i.on("upgrade",(o,c,l)=>{qC[n]&&qC[n](o,c,l)})),r.push(i),rz[t?.runFirst?"unshift":"push"]({listener:e,port:n}),nz[n]=qT(rz,n),kT[n]=qT(GC,n)}return r}a(FSe,"onWebSocket");function sz(e,t){t.writeHead(404),t.end(`Not found
132
+ `)}a(sz,"defaultNotFound")});var QW={};ve(QW,{startHTTPThreads:()=>qSe,startSocketServer:()=>XC,updateWorkerIdleness:()=>yz});async function qSe(e=2,t){try{if(t)JC(0,1,!0);else{let{loadRootComponents:r}=$T();if(e===0)return(0,Bs.setMainIsWorker)(!0),await WC().startServers(),Promise.resolve([]);await r()}Rz();for(let r=0;r<e;r++)JC(r,e);return Promise.all(Az)}finally{(0,Bs.threadsHaveStarted)()}}function Rz(){let e=(0,gz.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),jC=setInterval(()=>{YT.notify(e)},GSe).unref())}function JC(e,t=1,r){if(zC++,(0,Bs.startWorker)("server/threads/threadServer.js",{name:ZA.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(u){u.type===JA.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});Az.push(s),await s,Zd.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=KT.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=Zd.indexOf(n);o>-1&&Zd.splice(o,1)}if(a(i,"removeWorker"),ef){let o=ef;ef=[];for(let c of o)Tz[c.localPort](null,c)}}}),r){let n=setInterval(()=>{QC?QC=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,Bs.shutdownWorkers)(),zC=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function XC(e=0,t){if(typeof e=="string")try{(0,WT.existsSync)(e)&&(0,WT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=$Se:r=VSe(t):r=ZC;let n=(0,tf.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);return n._handle&&(n._handle.onconnection=Tz[e]=function(s,i){r.readsData||(i.reading=!1,i.readStop()),QC=!0,r(i,(o,c)=>{if(!o){if(hz){let u=i._socket||new tf.Socket({handle:i,writable:!0,readable:!0});hz.deliverSocket(u,e,c),u.resume()}else zC>0?(ef.length===0&&setTimeout(()=>{ef.length>0&&console.warn("Incoming sockets/requests have been queued for workers to start, and no workers have handled them. Check to make sure an error is not preventing workers from starting")},1e4).unref(),i.localPort=e,ef.push(i)):(console.log("start up a dynamic thread to handle request"),JC(0));sr(!1,"socket-routed");return}o.requests++;let l=i.fd;if(l>=0)o.postMessage({port:e,fd:l,data:c});else{let u=i._socket||new tf.Socket({handle:i,writable:!0,readable:!0});WSe(u,o,e)}sr(!0,"socket-routed")})},YT.info(`HarperDB ${Sz.packageJson.version} Server running on port ${e}`)),n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function ZC(e,t){let r,n=0;for(let s of Zd){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=VT)return VT=i,t(r);n=i}VT=0,t(r)}function $Se(e,t){let r={};e.getpeername(r);let n=r.address,s=rf.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);ZC(e,o=>{rf.set(n,{worker:o,lastUsed:i}),t(o)})}function VSe(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new tf.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let l=o.toString("latin1").match(t)?.[1],u=rf.get(l),f=Date.now();if(u&&u.worker.threadId!==-1)return u.lastUsed=f,s(u.worker);ZC(n,d=>{rf.set(l,{worker:d,lastUsed:f}),s(d,o)})})}a(r,"findByHeaderAffinity")}function yz(){VT=0;for(let e of Zd)e.expectedIdle=e.recentELU.idle+KSe,e.requests=1;Zd.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function WSe(e,t,r){let n=YSe++;t.postMessage({port:r,requestId:n,event:"connection"}),e.on("data",s=>{let i=s.toString("latin1");t.postMessage({port:r,requestId:n,data:i,event:"data"})}).on("close",s=>{t.postMessage({port:r,requestId:n,event:"close",hadError:s})}).on("error",s=>{t.postMessage({port:r,requestId:n,event:"error",error:s})}).on("drain",s=>{t.postMessage({port:r,requestId:n,event:"drain",error:s})}).on("end",()=>{t.postMessage({port:r,requestId:n,event:"end"})}).resume(),KT.set(n,s=>{s.event=="data"&&e.write(Buffer.from(s.data,"latin1")),s.event=="end"&&(e.end(s.data&&Buffer.from(s.data,"latin1")),KT.delete(n)),s.event=="destroy"&&(e.destroy(),KT.delete(n))})}var Bs,tf,YT,WT,Ez,gz,Sz,Zd,ef,Tz,hz,zC,Az,jC,GSe,QC,VT,mz,rf,KSe,KT,YSe,BC=be(()=>{Bs=M(rt()),tf=require("net");H();YT=M(z()),WT=require("fs");ki();Ez=require("worker_threads"),gz=M(Od()),Sz=M(it()),Zd=[],ef=[],Tz=[],zC=0,Az=[];Ez.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,Bs.onMessageFromWorkers)(e=>{e.type===XA.RESTART&&jC&&(clearInterval(jC),Rz())}));GSe=6e5;a(qSe,"startHTTPThreads");a(Rz,"licenseWarning");a(JC,"startHTTPWorker");a(XC,"startSocketServer");VT=0;a(ZC,"findMostIdleWorker");mz=36e5,rf=new Map;a($Se,"findByRemoteAddressAffinity");a(VSe,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of rf)r.lastUsed+mz<e&&rf.delete(t)},mz).unref();KSe=1e3;a(yz,"updateWorkerIdleness");(0,Bs.setMonitorListener)(yz);KT=new Map,YSe=1;a(WSe,"proxySocket")});var Hz=w((XUe,Bz)=>{var Oz=M(require("cluster")),uc=M(ae());H();var Xi=M(z()),Nz=M(require("fastify")),wz=M(require("@fastify/cors")),Iz=M(require("@fastify/compress")),Cz=M(require("@fastify/static")),Pz=M(RO()),Dz=M(require("path")),Lz=M(it()),Mz=M(As()),vz=M(ie()),Uz=M(Rn()),xz=M(Od());Vr();var dc=M(hT());ao();uc.default.initSync();var zSe=6e4,jSe=1024*1024*1024,JSe="TRUE",{CONFIG_PARAMS:wh}=G,nf;Bz.exports={hdbServer:bz,start:bz};async function bz(e){try{Xi.default.debug("In Fastify server"+process.cwd()),Xi.default.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Xi.default.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=Oz.default.isMaster,await QSe();let t=e.securePort>0;nf=XSe(t),await nf.ready(),e||(e={}),e.isOperationsServer=!0;try{We.http(nf.server,e),nf.server.closeIdleConnections||await nf.listen({port:0,host:"::"})}catch(r){throw nf.close(),Xi.default.error(r),Xi.default.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),Xi.default.fatal(t),process.exit(1)}}a(bz,"operationsServer");async function QSe(){Xi.default.trace("Configuring HarperDB process."),Mz.default.setSchemaDataToGlobal(),await Uz.default.setUsersWithRolesCache(),await xz.default.getLicense()}a(QSe,"setUp");function XSe(e){Xi.default.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=ZSe(e),r=(0,Nz.default)(t);r.server.headersTimeout=tTe(),r.setErrorHandler(dc.serverErrorHandler);let n=eTe();n&&r.register(wz.default,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,u){r.server.emit("unhandled",l.raw,u.raw)}),c()}),r.register(Pz.default),r.register(Iz.default),r.register(Cz.default,{root:Dz.default.join(Lz.PACKAGE_ROOT,"studio/build-local")}),jf(r);let s=uc.default.get(jA.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!vz.default.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[dc.reqBodyValidationHandler,dc.authHandler],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),(0,dc.handlePostRequest)(i,o)}),r.get("/health",()=>"HarperDB is running."),Xi.default.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(XSe,"buildServer");function ZSe(e){let t=uc.default.get(wh.OPERATIONSAPI_NETWORK_TIMEOUT),r=uc.default.get(wh.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:jSe,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(ZSe,"getServerOptions");function eTe(){let e=uc.default.get(wh.OPERATIONSAPI_NETWORK_CORS),t=uc.default.get(wh.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===JSe)&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},t&&t.length>0&&t[0]!==null&&t[0]!=="*"&&(r.origin=(n,s)=>s(null,t.indexOf(n)!==-1))),r}a(eTe,"getCORSOpts");function tTe(){return uc.default.get(wh.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??zSe}a(tTe,"getHeaderTimeoutConfig")});var iP={};ve(iP,{disableNATS:()=>nTe,publishToStream:()=>JT,setNATSReplicator:()=>eP,setPublishToStream:()=>sTe,setSubscription:()=>sP,start:()=>rTe});function rTe(){Ih.default.get(x.CLUSTERING_ENABLED)&&oTe()}function nTe(e=!0){$z=e}function sTe(e,t){JT=e,sP=t}function oTe(){if($z||process.env._DISABLE_NATS)return;let e=Xe(),t=Object.keys(e);t.push("system");for(let r of t){let n=e[r];for(let s in n){let i=n[s];eP(s,r,i)}}Tl((r,n)=>{eP(r.tableName,r.databaseName,r),n&&Kz(r)}),!kz&&(kz=!0)}function eP(e,t,r){if(t==="system"&&aTe.includes(e))return;if(!r)return console.error(`Attempt to replicate non-existent table ${e} from database ${t}`);if(r.sources.some(s=>s?.isNATSReplicator))return;r.sourcedFrom(class extends $r{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this.getId(),record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this.getId()})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this.getId(),record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this.getId(),record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this.getId()})}static defineSchema(i){Kz(i)}static subscribe(){let i=new Bn;return sP(t,e,i),i}static subscribeOnThisThread(i){return i<(Ih.default.get(x.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??iTe)}static isEqual(i){return i.isNATSReplicator}static isNATSReplicator=!0;static shouldReceiveInvalidations=!0},{intermediateSource:!0});function n(s){let i=s?.transaction?.nats;if(!i)if(s?.transaction){s.transaction.nats=i=new zT(s.transaction,s);let o=s.transaction;for(;o.next;)o=o.next;o.next=s.transaction.nats,i.user=s.user,i.context=s}else i=Vz;return i}a(n,"getNATSTransaction")}function Kz(e){let t=Ih.default.get(x.CLUSTERING_NODENAME);JT(`${rP.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,nP.createNatsTableStreamName)(e.databaseName,e.tableName),void 0,{operation:"define_schema",schema:e.databaseName,table:e.tableName,attributes:e.attributes,__origin:{timestamp:Date.now(),node_name:t}})}var Fz,rP,nP,Gz,qz,Ih,jT,$z,JT,sP,iTe,Vz,kz,aTe,zT,tP,Yz=be(()=>{De();Ea();Fz=M(ir()),rP=M(Tt()),nP=M(Eo());pu();Gz=M(xO()),qz=M(_n()),Ih=M(ae());H();jT=M(z());a(rTe,"start");a(nTe,"disableNATS");JT=Fz.publishToStream,sP=Gz.setSubscription;a(sTe,"setPublishToStream");iTe=2;a(oTe,"assignReplicationSource");aTe=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(eP,"setNATSReplicator");a(Kz,"publishSchema");zT=class{constructor(t,r){this.transaction=t;this.options=r}static{a(this,"NATSTransaction")}user;writes_by_db=new Map;addWrite(t,r){r.expiresAt=this.context?.expiresAt;let n=this.writes_by_db.get(t);n||this.writes_by_db.set(t,n=[]),n.push(r)}commit({timestamp:t}){let r=Ih.default.get(x.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],l,u;for(let f of i){let d=f.table,p=f.operation=="put"?"upsert":f.operation;l||(jT.trace(`Sending transaction event ${p}`),u=l={operation:p,schema:s,table:d,__origin:{user:this.user?.username,timestamp:t,node_name:r}},l.hash_values=c,p!=="delete"&&p!=="invalidate"&&(l.records=o)),l.table===d&&l.operation===p?(o.push(f.record),c.push(f.id)):u=u.next={operation:p,table:d,id:f.id,record:f.record},f.expiresAt&&(u.expiresAt=f.expiresAt)}l&&n.push(JT(`${rP.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,nP.createNatsTableStreamName)(s,l.table),void 0,l)?.catch(f=>{throw jT.error("An error has occurred trying to replicate transaction",l,f),f.statusCode=504,f}))}return Promise.all(n)}},tP=class extends zT{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,qz.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};Vz=new tP});async function Qz({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await oP.get(e,{returnNonexistent:!0});i=new lP(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await oP.get(e);o&&o.delete()}i=new XT(e,t)}return n&&(n.id=e,n.user={username:t?.username},Ch.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function aP(){return QT++,QT>65500&&(QT=1),QT}function cP(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=Oi.getMatch(n,"mqtt");if(!i)throw new Error(`Can not publish to topic ${n} as it does not exist, no resource has been defined to handle this topic`);e.url=i.relativeURL;let o=i.Resource;return wt(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var zz,fc,jz,Jz,Wz,oP,Ch,QT,XT,lP,Xz=be(()=>{De();Tu();zz=M(_n()),fc=M(z());Ic();jz=M(rt()),Jz=M(WC());Vr();Wz=100,oP=ft({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),Ch=ft({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,jz.getWorkerIndex)()===0&&(async()=>{await Jz.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of Ch.search({})){let t=e.data,r={...e};r.user?.username&&(r.user=await We.getUser(r.user.username));try{await cP(r,t,r)}catch{(0,fc.warn)("Failed to publish will",t)}Ch.delete(e.id)}})();a(Qz,"getSession");QT=1;a(aP,"getNextMessageId");XT=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;request;socket;subscriptions=[];awaitingAcks;sessionWasPresent;keepalive;keepaliveTimer;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),l,u;if(c>-1?(l=s.slice(c),u=s.slice(0,c)):u=s,!u)throw new Error("No topic provided");if(u.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let f=this.subscriptions.find(R=>R.topic===s),d;f?(d=i>0,f.end(),this.subscriptions.splice(this.subscriptions.indexOf(f),1)):d=i===2;let p={search:l,async:!0,user:this.user,startTime:o,omitCurrent:d,url:""};o&&(0,fc.trace)("Resuming subscription from",s,"from",o);let _=Oi.getMatch(u,"mqtt");if(!_){let R=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw R.statusCode=404,R}if(p.url=_.relativeURL,p.url.indexOf("+")>-1||p.url.indexOf("#")>-1){let R=p.url.slice(1);if(R.indexOf("#")>-1&&R.indexOf("#")!==R.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(p.isCollection=!0,R.indexOf("+")===R.length-1)p.onlyChildren=!0,p.url="/"+R.slice(0,R.length-1);else{let E=R.split("/"),T;for(let F=0;F<E.length;F++)if(E[F].indexOf("+")>-1)if(E[F]==="+")T=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&T)throw new Error("Filters can not be combined");let b=!0;E[E.length-1]==="#"&&(E.length--,b=!1),T&&(n=a(F=>{let q=F.id;if(!Array.isArray(q))if(q?.indexOf?.("/")>-1)q=q.split("/");else return!1;if(b&&q.length!==E.length)return!1;for(let Y=0;Y<E.length;Y++)if(E[Y]!=="+"&&E[Y]!==q[Y])return!1;return!0},"filter"));let v=E.indexOf("+");p.url="/"+(v>-1?E.slice(0,v):E).concat("").join("/")}}let h=_.path,S=_.Resource,g=await wt(p,async()=>{let R=this.createContext();R.topic=s,R.retainHandling=i;let E=await S.subscribe(p,R);if(!E)return;if(!E[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let T=(async()=>{for await(let b of E)try{let v;if(b.type&&b.type!=="put"&&b.type!=="delete"&&b.type!=="message"&&b.type!=="patch"||n&&!n(b))continue;r?(b.topic=s,v=this.needsAcknowledge(b)):(b.acknowledge?.(),v=aP());let F=b.id;if(Array.isArray(F)&&(F=Su(F)),F==null&&(F=""),await this.listener(h+"/"+F,b.value,v,t)===!1)break;this.awaitingAcks?.size>Wz?await new Promise(Y=>setTimeout(Y,this.awaitingAcks.size-Wz)):await new Promise(setImmediate)}catch(v){(0,fc.warn)(v)}})();return E});if(g)return g.topic=s,g.qos=t.qos,this.subscriptions.push(g),g}resume(){}needsAcknowledge(t){let r=aP();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,{acknowledge:t.acknowledge})),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r.acknowledge())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),this.subscriptions.splice(this.subscriptions.indexOf(r),1),!0}async publish(t,r){return cP(t,r,this.createContext())}createContext(){let t={session:this,socket:this.socket,user:this.user,authorize:!0};return this.request&&(t.request=this.request,t.url=this.request.url,t.headers=this.request.headers),t}setListener(t){this.listener=t}disconnect(t){this.keepaliveTimer&&clearTimeout(this.keepaliveTimer);let r=this.createContext();wt(r,async()=>{try{if(!t){let n=await Ch.get(this.sessionId);n?.doesExist()&&await cP(n,n.data,r)}}finally{await Ch.delete(this.sessionId)}}).catch(n=>{(0,fc.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}receivedPacket(){this.keepalive&&(clearTimeout(this.keepaliveTimer),this.keepaliveTimer=setTimeout(()=>{this.socket?.destroy?this.socket.destroy(new Error("Keepalive timeout")):this.socket?.terminate()},this.keepalive*1500))}};a(cP,"publish");lP=class extends XT{static{a(this,"DurableSubscriptionsSession")}sessionRecord;constructor(t,r,n){super(t,r),this.sessionRecord=n||{id:t,subscriptions:[]}}async resume(){for(let t of this.sessionRecord.subscriptions||[])await this.resumeSubscription({omitCurrent:!0,topic:t.topic,qos:t.qos,startTime:t.startTime},!0,t.acks?r=>!t.acks.includes(r.localTime):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=aP(),n={topic:t.topic,timestamp:t.localTime};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks?.get(t);if(!r)return;this.awaitingAcks?.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,fc.trace)("Received ack",n,r.timestamp),this.sessionRecord.update();return}}for(let s of this.sessionRecord.subscriptions)s.topic===n&&(s.startTime=r.timestamp);this.sessionRecord.update()}async addSubscription(t,r){await this.resumeSubscription(t,r);let{qos:n,startTime:s}=t;return n>0&&!s&&this.saveSubscriptions(),t.qos}removeSubscription(t){let r=this.subscriptions.find(s=>s.topic===t),n=super.removeSubscription(t);return r.qos>0&&this.saveSubscriptions(),n}saveSubscriptions(){this.sessionRecord.subscriptions=this.subscriptions.map(t=>{let r=t.startTime;return r||(r=t.startTime=(0,zz.getNextMonotonicTime)()),(0,fc.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),oP.put(this.sessionRecord)}}});var dP={};ve(dP,{bypassAuth:()=>cTe,start:()=>lTe});function cTe(){nj=!0}function lTe({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new rj.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c=[],l=r?.mtls;return n&&(c=e.ws((u,f,d,p)=>{if(f.headers.get("sec-websocket-protocol")!=="mqtt")return p(u,f,d);o.events.emit("connection",u),hr.debug?.("Received WebSocket connection for MQTT from",u._socket.remoteAddress);let{onMessage:_,onClose:h}=ej(u,S=>{u.send(S)},f,Promise.resolve(d).then(()=>f?.user),o);u.on("message",_),u.on("close",h),u.on("error",S=>{hr.info?.("WebSocket error",S)})},{...n})),(t||s)&&c.push(e.socket(async u=>{let f;if(o.events.emit("connection",u),hr.debug?.(`Received ${u.getCertificate?"SSL":"TCP"} connection for MQTT from ${u.remoteAddress}`),l){if(u.authorized)try{let _=l.user;if(_!==null){(_===void 0||_==="Common Name"||_==="CN")&&(_=u.getPeerCertificate().subject.CN);try{f=await e.getUser(_,null,null),(0,sf.get)(x.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&eA.notify?.({username:f?.username,status:Ys.SUCCESS,type:la.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:u.remoteAddress})}catch(h){throw(0,sf.get)(x.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&eA.error?.({username:_,status:Ys.FAILURE,type:la.AUTHENTICATION,auth_strategy:"mqtt",remote_address:u.remoteAddress}),h}}else hr.debug?.("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",u.remoteAddress)}catch(_){o.events.emit("error",_,u),hr.error?.(_)}else if(l.required)return hr.info?.(`Unauthorized connection attempt, no authorized client certificate provided, error: ${u.authorizationError}`),u.end()}!f&&nj&&u.remoteAddress.includes("127.0.0.1")&&(f=await(0,tj.getSuperUser)(),hr.debug?.("Auto-authorizing local connection",f?.username));let{onMessage:d,onClose:p}=ej(u,_=>u.write(_),null,f,o);u.on("data",d),u.on("close",p),u.on("error",_=>{hr.info?.("Socket error",_)})},{port:t,securePort:s,mtls:l})),c}function ej(e,t,r,n,s){Zz||(Zz=!0,Y_(d=>{ZT>0&&d.push({metric:"mqtt-connections",connections:ZT,byThread:!0})}));let i;ZT++;let o,c={protocolVersion:4},l=(0,tA.parser)({protocolVersion:5});function u(d){l.parse(d)}a(u,"onMessage");function f(){ZT--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),Qn(!1,"connection","mqtt","disconnect"),hr.debug?.("MQTT connection was closed",e.remoteAddress))}return a(f,"onClose"),l.on("packet",async d=>{n?.then&&(n=await n);let p=d.cmd;if(o)o.then&&await o;else if(p!=="connect"){hr.info?.("Received packet before connection was established, closing connection"),e?.destroy?e.destroy():e?.terminate();return}let _=d.topic,h=_?.indexOf("/",1),S=h>0?_.slice(0,h):_;sr(d.length,"bytes-received",S,R(d),"mqtt");try{switch(o?.receivedPacket?.(),p){case"connect":if(c.protocolVersion=d.protocolVersion,d.username)try{n=await We.getUser(d.username,d.password.toString(),r),(0,sf.get)(x.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&eA.notify?.({username:n?.username,status:Ys.SUCCESS,type:la.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(se){return(0,sf.get)(x.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&eA.error?.({username:d.username,status:Ys.FAILURE,type:la.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",d,e,se),Qn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",d,e),Qn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(d,n),d.will){let se=e.deserialize||(e.deserialize=uo(r?.headers.get?.("content-type")));d.will.data=d.will.payload?.length>0?se(d.will.payload):void 0,delete d.will.payload}o=Qz({user:n,...d}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(se){return hr.error?.(se),s.events.emit("auth-failed",d,e,se),Qn(!1,"connection","mqtt","connect"),g({cmd:"connack",reasonCode:se.code||5,returnCode:se.code||128})}s.events.emit("connected",o,e),Qn(!0,"connection","mqtt","connect"),g({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0});let T=a(async(se,Q,ne,J)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",se);let me=se.indexOf("/",1),ye=me>0?se.slice(0,me):se;g({cmd:"publish",topic:se,payload:await E(Q),messageId:ne||Math.floor(Math.random()*1e8),qos:J.qos},ye);let Pe=e._socket??e;return Pe.writableNeedDrain?new Promise(he=>Pe.once("drain",he)):!Pe.closed}catch(me){return hr.error?.(me),o?.disconnect(),s.sessions.delete(o),!1}},"listener");o.setListener(T),o.sessionWasPresent&&await o.resume();break;case"subscribe":let b=[];for(let se of d.subscriptions){let Q;try{let ne=await o.addSubscription(se,se.qos>=1);Q=ne?ne.qos||0:c.protocolVersion<5?128:143}catch(ne){s.events.emit("error",ne,e,se,o),ne.statusCode?ne.statusCode===500?hr.warn?.(ne):hr.info?.(ne):hr.error?.(ne),Q=c.protocolVersion<5?128:ne.statusCode===403?135:ne.statusCode===404?143:128}b.push(Q)}await o.committed,g({cmd:"suback",granted:b,messageId:d.messageId});break;case"unsubscribe":{let se=[];for(let Q of d.unsubscriptions)se.push(o.removeSubscription(Q)?0:17);g({cmd:"unsuback",granted:se,messageId:d.messageId});break}case"pubrel":g({cmd:"pubcomp",messageId:d.messageId,reasonCode:0});return;case"publish":let v=d.qos===2?"pubrec":"puback",F=e.deserialize||(e.deserialize=uo(r?.headers.get?.("content-type"))),Y=(d.payload?.length||0)>0?F(d.payload):void 0,Z;try{Z=await o.publish(d,Y)}catch(se){s.events.emit("error",se,e,d,o),hr.warn?.(se),d.qos>0&&g({cmd:v,messageId:d.messageId,reasonCode:128},d.topic);break}d.qos>0&&g({cmd:v,messageId:d.messageId,reasonCode:Z===!1?144:0},d.topic);break;case"pubrec":g({cmd:"pubrel",messageId:d.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(d.messageId);break;case"pingreq":g({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),Qn(!0,"connection","mqtt","disconnect"),hr.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(T){s.events.emit("error",T,e,d,o),hr.error?.(T),g({cmd:"disconnect"})}function g(T,b){let v=(0,tA.generate)(T,c);t(v),sr(v.length,"bytes-sent",b,R(T),"mqtt")}a(g,"sendPacket");function R(T){return T.qos>0?T.cmd+",qos="+T.qos:T.cmd}a(R,"packetMethodName");function E(T){return Aa(T,r)}a(E,"serialize")}),l.on("error",d=>{hr.warn("MQTT parsing error, closing connection:",d.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:u,onClose:f}}var tA,tj,sf,uP,rj,eA,hr,nj,Zz,ZT,sj=be(()=>{tA=require("mqtt-packet");Xz();tj=M(Rn());ao();ki();Vr();sf=M(ae());H();uP=M(Ni()),rj=require("events"),eA=(0,uP.loggerWithTag)("auth-event"),hr=(0,uP.loggerWithTag)("mqtt"),nj=(0,sf.get)(x.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(cTe,"bypassAuth");a(lTe,"start");ZT=0;a(ej,"onSocket")});var zp={};ve(zp,{component_errors:()=>af,getComponentName:()=>pTe,loadComponent:()=>sA,loadComponentDirectories:()=>lj,setErrorReporter:()=>_Te});function lj(e,t){t&&(_P=t),e&&(EP=e);let r=[];if((0,ut.existsSync)(fP)){let s=(0,ut.readdirSync)(fP,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,St.join)(fP,o);r.push(sA(c,_P,KA,!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(sA(n,_P,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{cj=!0})}function _Te(e){Ph=e}async function sA(e,t,r,n,s,i){let o=(0,ut.realpathSync)(e);if(rA.has(o))return rA.get(o);rA.set(o,!0),s&&(EP=s);try{let c;n&&(af=new Map);let l=(0,St.join)(e,"harperdb-config.yaml");(0,ut.existsSync)(l)?c=n?(0,iA.getConfigObj)():(0,pP.parseDocument)((0,ut.readFileSync)(l,"utf8")).toJSON():!n&&(0,ut.existsSync)(l=(0,St.join)(e,"config.yaml"))?c=(0,pP.parseDocument)((0,ut.readFileSync)(l,"utf8")).toJSON():c=gP;let u=(0,St.join)(e,"node_modules","harperdb");try{jl.isMainThread&&(n||((0,ut.existsSync)(u)||!e.startsWith((0,mP.getHdbBasePath)()))&&(!(0,ut.existsSync)(u)||(0,ut.realpathSync)(hP.PACKAGE_ROOT)!==(0,ut.realpathSync)(u)))&&((0,ut.rmSync)(u,{recursive:!0,force:!0}),(0,ut.existsSync)((0,St.join)(e,"node_modules"))||(0,ut.mkdirSync)((0,St.join)(e,"node_modules")),(0,ut.symlinkSync)(hP.PACKAGE_ROOT,u,"dir"))}catch(p){of.default.error("Error symlinking harperdb module",p)}let f=nA,d=n;for(let p in c){nA=p;let _=c[p];if(af.set(n?p:(0,St.basename)(e),!1),!_)continue;let h,S=_.package;try{if(S){let b=e,v;for(;!(0,ut.existsSync)(v=(0,St.join)(b,"node_modules",p));)if(b=(0,St.dirname)(b),b.length<(0,mP.getHdbBasePath)().length){v=null;break}if(v)h=await sA(v,t,r,!1),d=!0;else throw new Error(`Unable to find package ${p}:${S}`)}else h=fTe[p];if(!h)continue;let g=a(b=>(b.origin=r,ft(b)),"ensureTable"),R=_.network||(_.port||_.securePort)&&_,E=R?.securePort||R?.https&&R.port,T=!R?.https&&R?.port;if(jl.isMainThread&&(h=await h.startOnMainThread?.({server:We,ensureTable:g,port:T,securePort:E,resources:t,..._})||h,n&&R))for(let b of[T,E])try{if(+b&&!ij.includes(b)){let v=SP.get(x.HTTP_SESSIONAFFINITY);v&&of.default.warn("Session affinity is not recommended and may cause memory leaks"),(v||!gT)&&(ij.push(b),XC(b,v))}}catch(v){console.error("Error listening on socket",b,v,p)}if(t.isWorker&&(h=await h.start?.({server:We,ensureTable:g,port:T,securePort:E,resources:t,..._})||h),EP.set(h,!0),(h.handleFile||h.handleDirectory||h.setupFile||h.setupDirectory)&&_.files!=null){if(_.files.includes(".."))throw(0,aj.handleHDBError)("Can not reference parent directories");let b=(0,St.join)(e,_.files).replace(/\\/g,"/"),v=b.indexOf("/*");if(v>-1&&_.files!==gP[p]?.files&&!(0,ut.existsSync)(b.slice(0,v)))throw new Error(`The path '${b.slice(0,v)}' does not exist and cannot be used as the base of the resolved 'files' path value '${_.files}'`);let F=(0,St.basename)(e),q=_.path||"/";q=q.startsWith("/")?q:q.startsWith("./")?"/"+F+q.slice(2):q==="."?"/"+F:"/"+F+"/"+q;let Y,Z,se;if(_.root){let ne=_.root;ne.startsWith("/")&&(ne=ne.slice(1)),ne.endsWith("/")&&(ne=ne.slice(0,-1)),ne+="/",Z=(0,St.join)(e,ne)}else(se=b.indexOf("/*"))>-1?(Z=b.slice(0,se+1),Y=(0,St.relative)(e,Z)):_.files.indexOf("/")>-1&&(Z=b.slice(0,b.lastIndexOf("/")+1),Y=(0,St.relative)(e,Z));let Q=!1;if(jl.isMainThread&&h.setupDirectory&&(Q=await h.setupDirectory?.(q,Z,t)),t.isWorker&&h.handleDirectory&&(Q=await h.handleDirectory?.(q,Z,t)),Q){d=!0;continue}for(let ne of await(0,oj.default)(b,{onlyFiles:!1,objectMode:!0})){let{path:J,dirent:me}=ne;d=!0;let ye=(0,St.relative)(e,J).replace(/\\/g,"/");if(Y)if(ye.startsWith(Y))ye=ye.slice(Y.length+1);else throw new Error(`The root path '${_.root}' does not reference a valid part of the file path '${ye}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let Pe=q+(q.endsWith("/")?"":"/")+ye;try{if(me.isFile()){let he=await dTe(J);jl.isMainThread&&await h.setupFile?.(he,Pe,J,t),t.isWorker&&await h.handleFile?.(he,Pe,J,t)}else jl.isMainThread&&await h.setupDirectory?.(Pe,J,t),t.isWorker&&await h.handleDirectory?.(Pe,J,t)}catch(he){let Nt=`Could not load ${me.isFile()?"file":"directory"} '${J}'${_.module?` using '${_.module}'`:""} for application '${e}' due to:
133
+ `;he.message=`${Nt}${he.message}`,he.stack=`${Nt}${he.stack}`,Ph?.(he),of.default.error(he),t.set(_.path||"/",new ga(he)),af.set(n?p:(0,St.basename)(e),he.message)}}}}catch(g){g.message=`Could not load component '${p}' for application '${(0,St.basename)(e)}' due to: ${g.message}`,Ph?.(g),((0,Dh.getWorkerIndex)()===0?console:of.default).error(g),t.set(_.path||"/",new ga(g),null,!0),af.set(n?p:(0,St.basename)(e),g.message)}}if(nA=f,jl.isMainThread&&!cj&&i&&(0,Dh.watchDir)(e,async()=>lj()),c.extensionModule){let p=await jE((0,St.join)(e,c.extensionModule));return rA.set(o,p),p}if(!d&&t.isWorker){let p=`${e} did not load any modules, resources, or files, is this a valid component?`;Ph?.(new Error(p)),((0,Dh.getWorkerIndex)()===0?console:of.default).error(p),af.set((0,St.basename)(e),p)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,Ph?.(c),t.set("",new ga(c))}}var ut,St,jl,pP,SP,hP,oj,Dh,of,aj,mP,uTe,iA,dTe,fP,EP,cj,_P,af,fTe,gP,ij,rA,Ph,nA,pTe,jp=be(()=>{ut=require("fs"),St=require("path"),jl=require("worker_threads"),pP=require("yaml"),SP=M(ae()),hP=M(it());H();HL();AM();JB();eH();tH();BH();mY();RY();bY();oj=M(require("fast-glob")),Dh=M(rt()),of=M(z());oO();Vr();aj=M(pe());De();BC();mP=M(ae()),uTe=M(Hz());vS();Yz();Xn();sj();iA=M(yt());ZI();SR();({readFile:dTe}=ut.promises),fP=(0,iA.resolvePath)(SP.get(x.COMPONENTSROOT)),EP=new Map,af=new Map;a(lj,"loadComponentDirectories");fTe={REST:tg,rest:tg,graphql:HR,graphqlSchema:RR,roles:iO,jsResource:cO,fastifyRoutes:WI,login:uO,static:zI,operationsApi:uTe,customFunctions:{},http:{},clustering:iP,replication:wo,authentication:Gp,mqtt:dP,loadEnv:jI},gP={rest:!0,graphqlSchema:{files:"*.graphql"},roles:{files:"roles.yaml"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(gP,"static",{value:{files:"web/**"}});ij=[],rA=new Map;a(_Te,"setErrorReporter");pTe=a(()=>nA,"getComponentName");a(sA,"loadComponent")});var $T=w((I0e,dj)=>{var{isMainThread:uj}=require("worker_threads"),{getTables:hTe,getDatabases:N0e,table:w0e}=(De(),C(nt)),{loadComponentDirectories:mTe,loadComponent:ETe}=(jp(),C(zp)),{resetResources:gTe}=(Tu(),C(vL)),STe=$w(),TTe=yt(),{dirname:ATe}=require("path"),{getConnection:RTe}=ir(),yTe=ae(),{CONFIG_PARAMS:bTe}=(H(),C(G)),{loadCertificates:OTe}=Zn(),TP=new Map;async function NTe(e=!1){!uj&&yTe.get(bTe.CLUSTERING_ENABLED)&&RTe();try{uj&&await STe()}catch(n){console.error(n)}let t=gTe();hTe(),t.isWorker=e,await OTe(),await ETe(ATe(TTe.getConfigFilePath()),t,"hdb",!0,TP),await mTe(TP,t);let r=[];for(let[n]of TP)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(NTe,"loadRootComponents");dj.exports.loadRootComponents=NTe});var rt=w((P0e,Si)=>{"use strict";nm();var{Worker:wTe,MessageChannel:ITe,parentPort:Zi,isMainThread:OP,threadId:CTe,workerData:eo}=require("worker_threads"),{PACKAGE_ROOT:PTe}=it(),{join:hj,isAbsolute:DTe,extname:LTe}=require("path"),{server:mj}=(Vr(),C(Au)),{watch:MTe,readdir:vTe}=require("fs/promises"),{totalmem:fj}=require("os"),cf=(H(),C(G)),Ej=ae(),gi=z(),{randomBytes:UTe}=require("crypto"),{_assignPackageExport:xTe}=Ti(),_j=1024*1024,_c=[],Hs=[],BTe=50,NP=1e4,HTe="restart",gj="request_thread_info",Sj="resource_report",Tj="thread_info",Aj="added-port",kTe="ack",AP;xTe("threads",Hs);Si.exports={startWorker:RP,restartWorkers:IP,shutdownWorkers:VTe,workers:_c,setMonitorListener:XTe,onMessageFromWorkers:KTe,onMessageByType:Ij,broadcast:WTe,broadcastWithAcknowledgement:jTe,setChildListenerByType:$Te,getWorkerIndex:Rj,getWorkerCount:yj,getTicketKeys:Oj,setMainIsWorker:GTe,setTerminateTimeout:FTe,restartNumber:eo?.restartNumber||1};Hs.onMessageByType=Ij;Hs.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=Hs.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};Si.exports.whenThreadsStarted=new Promise(e=>{Si.exports.threadsHaveStarted=e});var wP;function FTe(e){NP=e}a(FTe,"setTerminateTimeout");function Rj(){return eo?eo.workerIndex:wP?0:void 0}a(Rj,"getWorkerIndex");function yj(){return eo?eo.workerCount:wP?1:void 0}a(yj,"getWorkerCount");function GTe(e){wP=e,Si.exports.threadsHaveStarted()}a(GTe,"setMainIsWorker");var bj=1,oA;function Oj(){return oA||(oA=OP?UTe(48):eo.ticketKeys,oA)}a(Oj,"getTicketKeys");Object.defineProperty(mj,"workerIndex",{get(){return Rj()}});Object.defineProperty(mj,"workerCount",{get(){return yj()}});var Nj={[gj](e,t){JTe(t)},[Sj](e,t){QTe(t,e)}};function RP(e,t={}){let r=process.constrainedMemory?.()||fj();r=Math.min(r,fj(),2e4*_j);let n=Ej.get(cf.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/_j/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let l of Hs){let u=new ITe;u.existingPort=l,i.push(u),o.push(u.port2)}LTe(e)||(e+=".js");let c=new wTe(DTe(e)?e:hj(PTe,e),{resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps","--expose-internals"],argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(l=>l.existingPort.threadId),workerIndex:t.workerIndex,workerCount:bj=t.threadCount,name:t.name,restartNumber:Si.exports.restartNumber,ticketKeys:Oj()},transferList:o,...t});for(let{port1:l,existingPort:u}of i)u.postMessage({type:Aj,port:l,threadId:c.threadId},[l]);return cA(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>RP(e,t),c.on("error",l=>{gi.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{_c.splice(_c.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<BTe?(t.unexpectedRestarts=c.unexpectedRestarts+1,RP(e,t)):gi.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{Nj[l.type]?.(l,c)}),_c.push(c),eAe(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(RP,"startWorker");var qTe=[cf.THREAD_TYPES.HTTP];async function IP(e=null,t=Math.max(bj>3,1),r=!0){if(OP){try{process.chdir(process.cwd())}catch(o){gi.error("Unable to reestablish current working directory",o)}if(r){let{loadRootComponents:o}=$T();await o()}Si.exports.restartNumber++,t<1&&(t=t*_c.length);let n=[],s=[];for(let o of _c.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;gi.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:Si.exports.restartNumber,type:cf.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=qTe.indexOf(o.name)>-1,l=new Promise(u=>{let f=setTimeout(()=>{gi.warn("Thread did not voluntarily terminate, terminating from the outside",o.threadId),o.terminate()},NP*2).unref();o.on("exit",()=>{clearTimeout(f),n.splice(n.indexOf(l)),!c&&r&&o.startCopy(),u()})});if(n.push(l),c&&r){let u=o.startCopy(),f=new Promise(d=>{let p=a(_=>{_.type===cf.ITC_EVENT_TYPES.CHILD_STARTED&&(gi.trace("Worker has started",u.threadId),d(),s.splice(s.indexOf(f)),u.off("message",p))},"startListener");gi.trace("Waiting for worker to start",u.threadId),u.on("message",p)});s.push(f),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=za();r&&(e==="http"||!e)&&Ej.get(cf.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else Zi.postMessage({type:HTe,workerType:e})}a(IP,"restartWorkers");function $Te(e,t){Nj[e]=t}a($Te,"setChildListenerByType");function VTe(e){return IP(e,1/0,!1)}a(VTe,"shutdownWorkers");var wj=[];function KTe(e){wj.push(e)}a(KTe,"onMessageFromWorkers");var yP=new Map;function Ij(e,t){let r=yP.get(e);r||yP.set(e,r=[]),r.push(t)}a(Ij,"onMessageByType");var YTe=10;async function WTe(e,t){let r=0;for(let n of Hs)try{n.postMessage(e),r++>YTe&&(r=0,await new Promise(setImmediate))}catch(s){gi.error("Unable to send message to worker",s)}t&&Pj(e,null)}a(WTe,"broadcast");var aA=new Map,zTe=1;function jTe(e){return new Promise(t=>{let r=0;for(let n of Hs)try{let s=zTe++,i=a(()=>{aA.delete(s),--r===0&&t(),n!==Zi&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,aA.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of aA)o.port===n&&o()})),n.postMessage(e),r++}catch(s){gi.error("Unable to send message to worker",s)}r===0&&t()})}a(jTe,"broadcastWithAcknowledgement");function JTe(e){e.postMessage({type:Tj,workers:Cj()})}a(JTe,"sendThreadInfo");function Cj(){let e=Date.now();return _c.map(t=>({threadId:t.threadId,name:t.name,heapTotal:t.resources?.heapTotal,heapUsed:t.resources?.heapUsed,externalMemory:t.resources?.external,arrayBuffers:t.resources?.arrayBuffers,sinceLastUpdate:e-t.resources?.updated,...t.recentELU}))}a(Cj,"getChildWorkerInfo");function QTe(e,t){e.resources=t,e.resources.updated=Date.now()}a(QTe,"recordResourceReport");var bP;function XTe(e){bP=e}a(XTe,"setMonitorListener");var ZTe=1e3,pj=!1;function eAe(){pj||(pj=!0,setInterval(()=>{for(let e of _c){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}bP&&bP()},ZTe).unref())}a(eAe,"startMonitoring");var tAe=1e3;if(Zi&&eo?.addPorts){cA(Zi);for(let e=0,t=eo.addPorts.length;e<t;e++){let r=eo.addPorts[e];r.threadId=eo.addThreadIds[e],cA(r)}setInterval(()=>{let e=process.memoryUsage();Zi.postMessage({type:Sj,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},tAe).unref(),AP=a(()=>new Promise((e,t)=>{Zi.on("message",r),Zi.postMessage({type:gj});function r(n){n.type===Tj&&(Zi.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else AP=Cj;Si.exports.getThreadInfo=AP;function cA(e,t){Hs.push(e),e.on("message",r=>{if(r.type===Aj)r.port.threadId=r.threadId,cA(r.port);else if(r.type===kTe){let n=aA.get(r.id);n&&n()}else Pj(r,e)}).on("close",()=>{Hs.splice(Hs.indexOf(e),1)}).on("exit",()=>{Hs.splice(Hs.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(cA,"addPort");function Pj(e,t){for(let n of wj)n(e,t);let r=yP.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){gi.error(s)}}a(Pj,"notifyMessageListeners");if(OP){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await vTe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(hj(s,o.name));try{for await(let{filename:o}of MTe(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await IP(),console.log("Reloaded HarperDB components, changed files:",Array.from(r)),r.clear()},100)}catch(o){console.warn("Error trying to watch component directory",s,o)}},"watch_dir");Si.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else Zi.on("message",async e=>{let{type:t}=e;t===cf.ITC_EVENT_TYPES.SHUTDOWN&&(Si.exports.restartNumber=e.restartNumber,Zi.unref(),setTimeout(()=>{gi.warn("Thread did not voluntarily terminate",CTe),process.exit(0)},NP).unref())})});var hB={};ve(hB,{ACTION_32_BIT:()=>zm,ACTION_64_BIT:()=>sAe,AUDIT_STORE_OPTIONS:()=>xp,Decoder:()=>Sl,HAS_BLOBS:()=>Fn,HAS_CURRENT_RESIDENCY_ID:()=>kc,HAS_EXPIRATION_EXTENDED_TYPE:()=>n_,HAS_ORIGINATING_OPERATION:()=>r_,HAS_PREVIOUS_RESIDENCY_ID:()=>Fc,REMOTE_SEQUENCE_UPDATE:()=>vg,createAuditEntry:()=>Nu,getLastRemoved:()=>TN,openAuditStore:()=>dA,readAuditEntry:()=>It,removeAuditEntry:()=>fA,setAuditRetention:()=>nAe,transactionKeyEncoder:()=>kj});function dA(e){let t=e.auditStore=e.openDB(CP.AUDIT_STORE_NAME,{create:!1,...xp});t||(t=e.auditStore=e.openDB(CP.AUDIT_STORE_NAME,xp),Lj(t,1)),t.rootStore=e,t.tableStores=[];let r=[];t.addDeleteRemovalCallback=function(l,u,f){return r[l]=f,t.tableStores[l]=u,t.deleteCallbacks=r,{remove(){delete r[l]}}};let n=null,s,i=0,o=DP;Ah(t.env.path,l=>{if(i=l,l)return c(100)});function c(l){l&&(o=l),clearTimeout(n);let u=new Promise(f=>{n=setTimeout(async()=>{if(await s,s=u,t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let d=0,p,_;try{for(let{key:h,value:S}of t.getRange({start:1,snapshot:!1,end:Date.now()-PP/(1+i*i)})){try{p=fA(t,h,S)}catch(g){lf.warn("Error removing audit entry",g)}if(_=h,await new Promise(setImmediate),++d>=rAe){o=10;break}}await p}finally{d===0?o=Math.min(o<<1,PP/10):(Lj(t,_),o>100&&(o=o>>1)),f(void 0),c()}},o).unref()});return u}if(a(c,"scheduleAuditCleanup"),t.scheduleAuditCleanup=c,(0,Mh.getWorkerIndex)()===(0,Mh.getWorkerCount)()-1&&c(),(0,Mh.getWorkerIndex)()===0&&!Dj)for(let l of t.getKeys({reverse:!0,limit:1}))l>Date.now()&&(Dj=!0,lf.error("The current time is before the last recorded entry in the audit log. Time reversal can undermine the integrity of data tracking and certificate validation and the time must be corrected."));return t}function fA(e,t,r){let n=iAe(r),s;if(n&Fn){s=It(r);let i=e.tableStores[s.tableId],o=i?.getEntry(s.recordId);(!o||o.version!==s.version||!o.value)&&vc(()=>Ta(s.getValue(i)),i.rootStore)}if((n&15)===LP){s=s||It(r);let i=s.tableId;e.tableStores[s.tableId]?.getEntry(s.recordId).version===s.version&&e.deleteCallbacks?.[i]?.(s.recordId,s.version)}return e.remove(t)}function Lj(e,t){MP[0]=t,e.put(Symbol.for("last-removed"),Fj)}function TN(e){let t=e.get(Symbol.for("last-removed"));if(t)return Fj.set(t),MP[0]}function nAe(e,t=DP){PP=e,DP=t}function Nu(e,t,r,n,s,i,o,c,l,u,f,d,p){let _=Gj[o];if(!_)throw new Error(`Invalid audit entry type ${o}`);let h=1;if(n&&(n>1?pc.setFloat64(0,n):ks.set(zR),h=9),l){if(l&255)throw new Error("Illegal extended type");h+=3}R(s),R(t),g(r),pc.setFloat64(h,e),h+=8,l&kc&&R(u),l&Fc&&R(f),l&n_&&(pc.setFloat64(h,d),h+=8),l&r_&&R(qj[p]),i?g(i):ks[h++]=0,l?pc.setUint32(n?8:0,_|l|3221225472):ks[n?8:0]=_;let S=ks.subarray(0,h);if(c)return Buffer.concat([S,c]);return S;function g(E){let T=h;h+=1,h=(0,Jl.writeKey)(E,ks,h);let b=h-T-1;b>127?b>16383?(lf.error("Key or username was too large for audit entry",E),h=T+1,ks[T]=0):(ks.copyWithin(T+2,T+1,h),pc.setUint16(T,b|32768),h++):ks[T]=b}function R(E){E<128?ks[h++]=E:E<16384?(pc.setUint16(h,E|32768),h+=2):E<1056964608?(pc.setUint32(h,E|3221225472),h+=4):(ks[h]=255,pc.setUint32(h+1,E),h+=5)}}function iAe(e){let t=0;e[0]==66&&(t=8);let r=e[t];if(r<128)return r;let n=e.dataView||(e.dataView=new Sl(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function It(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new Sl(e.buffer,e.byteOffset,e.byteLength));n.position=t;let s;e[n.position]==66&&(s=n.readFloat64());let i=n.readInt(),o=n.readInt(),c=n.readInt(),l=n.readInt(),u=n.position,f=n.position+=l,d=n.readFloat64(),p,_,h,S;if(i&kc&&(p=n.readInt()),i&Fc&&(_=n.readInt()),i&n_&&(h=n.readFloat64()),i&r_){let T=n.readInt();S=qj[T]}l=n.readInt();let g=n.position,R=n.position+=l,E;return{type:Gj[i&7],tableId:c,nodeId:o,get recordId(){return(0,Jl.readKey)(e,u,f)},getBinaryRecordId(){return e.subarray(u,f)},version:d,previousLocalTime:s,get user(){return R>g?(0,Jl.readKey)(e,g,R):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(T,b,v){if(i&lA||i&Lh&&!b)return E||(E=vc(()=>T.decoder.decode(e.subarray(n.position,r)),T.rootStore)),E;if(i&Lh&&v)return Vb(T.getEntry(this.recordId),v,T)},getBinaryValue(){return i&(lA|Lh)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:p,previousResidencyId:_,expiresAt:h,originatingOperation:S}}catch(n){return lf.error("Reading audit entry error",n,e),{}}}var Jl,uA,CP,Mh,Hj,lf,ks,pc,kj,xp,PP,rAe,MP,Fj,DP,Dj,lA,Lh,Mj,LP,vj,Uj,xj,Bj,zm,sAe,vg,kc,Fc,r_,n_,Fn,Gj,qj,Sl,fo=be(()=>{Jl=require("ordered-binary"),uA=M(ae()),CP=M(xt());H();Mh=M(rt()),Hj=M(ie());wu();lf=M(z());xE();gs();UT();(0,uA.initSync)();ks=Buffer.alloc(2816),pc=new DataView(ks.buffer,ks.byteOffset,2816),kj={writeKey(e,t,r){return e===t_?(t.set(t_,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,Jl.writeKey)(e,t,r)},readKey(e,t,r){return e[t]===66?(e.dataView||(e.dataView=new DataView(e.buffer,e.byteOffset,e.byteLength))).getFloat64(t):(0,Jl.readKey)(e,t,r)}},xp={encoding:"binary",keyEncoder:kj},PP=(0,Hj.convertToMS)((0,uA.get)(x.LOGGING_AUDITRETENTION))||86400*3,rAe=1e3,MP=new Float64Array(1),Fj=new Uint8Array(MP.buffer),DP=1e4,Dj=!1;a(dA,"openAuditStore");a(fA,"removeAuditEntry");a(Lj,"updateLastRemoved");a(TN,"getLastRemoved");a(nAe,"setAuditRetention");lA=16,Lh=32,Mj=1,LP=2,vj=3,Uj=4,xj=5,Bj=6,zm=14,sAe=15,vg=11,kc=512,Fc=1024,r_=2048,n_=4096,Fn=8192,Gj={put:Mj|lA,[Mj]:"put",delete:LP,[LP]:"delete",message:vj|lA,[vj]:"message",invalidate:Uj|Lh,[Uj]:"invalidate",patch:xj|Lh,[xj]:"patch",relocate:Bj,[Bj]:"relocate"},qj={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};a(Nu,"createAuditEntry");a(iAe,"readAction");a(It,"readAuditEntry");Sl=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t;return t=this.getUint8(this.position++),t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch(t){throw t.message=`Error reading float64: ${t.message} at position ${this.position}`,t}}}});function xP(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=Vj,oAe(e.primaryStore,e.auditStore)):(c=$j,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{Kj($j[i])})));let l=c[i]||(c[i]=[]);if(l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now()),s?.scope==="full-database")return;let u=l[o];u||(u=l[o]=new Map,u.envs=l,u.tableId=o,u.store=e.primaryStore),t=Su(t);let f=new UP(r);f.startTime=n;let d=u.get(t);return d?d.push(f):(u.set(t,d=[f]),d.tables=u,d.key=t),f.subscriptions=d,f}function Kj(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),Yj(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=It(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,l=Su(c),u=0;do{let f=o.get(l);if(f){for(let p of f)if(!(u>0&&!(p.includeDescendants&&!(p.onlyChildren&&u>1)))){if(p.startTime>=n){(0,vP.info)("omitting",c,p.startTime,n);continue}try{let _;p.supportsTransactions&&p.txnInProgress!==i.version&&(_=!0,p.txnInProgress||(r?r.push(p):r=[p]),p.txnInProgress=i.version),p.listener(c,i,n,_)}catch(_){console.error(_),(0,vP.info)(_)}}}if(l==null)break;let d=l.lastIndexOf?.("/",l.length-2);d!==l.length-1&&u++,d>-1?l=l.slice(0,d+1):l=null}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function oAe(e,t){let r=t||e,n=r.env;if(!n.hasAfterCommitListener){n.hasAfterCommitListener=!0;let s=n.path;r.on("aftercommit",({next:i,last:o,txnId:c})=>{let l=Vj[s];if(!l)return;let u=a(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),l.txnTime=r.threadLocalWrites[0]||Date.now();try{Kj(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function Yj(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function HF(e){return e.nextTransaction||(xP({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),Yj(e)),e.nextTransaction}var vP,$j,Vj,UP,AN=be(()=>{vP=M(z());pu();Tu();fo();$j=Object.create(null),Vj=Object.create(null);a(xP,"addSubscription");UP=class extends Bn{static{a(this,"Subscription")}listener;subscriptions;startTime;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;if(t){let r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};a(Kj,"notifyFromTransactionData");a(oAe,"listenToCommits");a(Yj,"nextTransaction");a(HF,"whenNextTransaction")});var II={};ve(II,{EVICTED:()=>ma,INVALIDATED:()=>mn,coerceType:()=>hA,makeTable:()=>EA,setServerUtilities:()=>pAe});function EA(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:l,schemaDefined:u,dbisDB:f,sealed:d,splitSegments:p,replicate:_}=e,{expirationMS:h,evictionMS:S,audit:g,trackDeletes:R}=e;S??=0;let{attributes:E}=e;E||(E=[]);let T=QR(i,n,l),b,v,F={},q=Promise.resolve(),Y,Z,se;for(let V of E)(V.assignCreatedTime||V.name==="__createdtime__")&&(Y=V),(V.assignUpdatedTime||V.name==="__updatedtime__")&&(Z=V),V.expiresAt&&(se=V),V.isPrimaryKey&&(F=V);let Q,ne=[],J=[],me=1,ye=2,Pe={},he={},Nt=864e5,dt=0,br,hs,Un,ou=!1,au,HA=new Map,kA=new Map,vt,Ef,Jh=Xl.get(x.REPLICATION_DATABASES);if(Array.isArray(Jh)){for(let V of Jh)if(V.name===c&&V.replicateTo>=0){Ef=V.replicateTo;break}}let Qh=i.getRange({start:!1,end:!1}).constructor,gf=10,Xh=6;g&&Af(),Ah(i.env.path,V=>{if(v)return aa(V)});class Ie extends $r{#e;#t;#n;#r;#s;#i;static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=g;static databasePath=o;static databaseName=c;static attributes=E;static replicate=_;static sealed=d;static splitSegments=p??!0;static createdTimeProperty=Y;static updatedTimeProperty=Z;static propertyResolvers;static userResolvers={};static sources=[];static getResidencyById;static get expirationMS(){return h}static dbisDB=f;static schemaDefined=u;static sourcedFrom(m,A){if(A&&(this.sourceOptions=A,(A.expiration||A.eviction||A.scanInterval)&&this.setTTLExpiration(A)),A?.intermediateSource)m.intermediateSource=!0,this.sources.unshift(m);else{if(this.sources.some(N=>!N.intermediateSource)){if(this.sources.some(N=>N.name===m.name))return;throw new Error("Can not have multiple canonical (non-intermediate) sources")}this.sources.push(m)}v=v||m.get&&(!m.get.reliesOnPrototype||m.prototype.get),b=b||m.load;let I=a(N=>{let L=this.sources;if(L=L.filter(k=>k.intermediateSource&&k[N]&&(!k[N].reliesOnPrototype||k.prototype[N])),L.length>0)if(L.length===1){let k=L[0];return(D,B,$)=>{if(D?.source!==k)return k[N](B,$,D)}}else return(k,D,B)=>{let $=[];for(let j of L){if(k?.source===j)break;$.push(j[N](D,B,k))}return Promise.all($)}},"getApplyToIntermediateSource"),y=this.sources[this.sources.length-1];y.intermediateSource&&(y={});let O=a(N=>{if(y[N]&&(!y[N].reliesOnPrototype||y.prototype[N]))return(L,k,D)=>{if(!L?.source)return y[N](k,D,L)}},"getApplyToCanonicalSource");Pe={put:O("put"),patch:O("patch"),delete:O("delete"),publish:O("publish")},he={put:I("put"),patch:I("patch"),delete:I("delete"),publish:I("publish"),invalidate:I("invalidate")};let P=y.shouldRevalidateEvents;return(async()=>{let N=!1,L,k=a(async(D,B)=>{let $=D.value,j=D.table?qe[c][D.table]:Ie;if(c===bf&&(D.table===fu.ROLE_TABLE_NAME||D.table===fu.USER_TABLE_NAME)&&(N=!0),D.id===void 0&&(D.id=$[j.primaryKey],D.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(D));D.source=m;let oe={residencyId:Rc(D.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:D.nodeId},U=await j.getResource(D.id,B,oe);switch(D.finished&&await D.finished,D.type){case"put":return P?U._writeInvalidate($,oe):U._writeUpdate($,!0,oe);case"patch":return P?U._writeInvalidate($,oe):U._writeUpdate($,!1,oe);case"delete":return U._writeDelete(oe);case"publish":return U._writePublish($,oe);case"invalidate":return U._writeInvalidate($,oe);case"relocate":return U._writeRelocate(oe);default:Ue.default.error?.("Unknown operation",D.type,D.id)}},"writeUpdate");try{let D=m.subscribe;D&&R==null&&(R=!0);let B={crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0},$=m.subscribeOnThisThread?m.subscribeOnThisThread((0,Ql.getWorkerIndex)(),B):(0,Ql.getWorkerIndex)()===0,j=D&&$&&await m.subscribe?.(B);if(j){let oe;for await(let U of j)try{if(!(U.type==="transaction"?U.writes[0]:U)){Ue.default.error?.("Bad subscription event",U);continue}if(U.source=m,U.type==="end_txn"){if(oe?.resolve(),U.localTime&&L!==U.localTime){if(U.remoteNodeIds?.length>0){let fe=[Symbol.for("seq"),U.remoteNodeIds[0]],te=f.get(fe),W=te?.nodes;W||(W=[]);for(let Ee of U.remoteNodeIds.slice(1)){let Se=W.find(tt=>tt.id===Ee);W=W.filter(tt=>tt.id!==Ee||tt===Se),Se||(Se={id:Ee,seqId:0},W.push(Se)),Se.seqId=Math.max(te?.seqId??1,U.localTime),Ee===oe?.nodeId&&(Se.lastTxnTime=U.timestamp)}let _e=Math.max(te?.seqId??1,U.localTime);Ue.default.trace?.("Received txn",c,new Date(_e),new Date(U.localTime),U.remoteNodeIds),f.put(fe,{seqId:_e,nodes:W})}L=U.localTime}U.onCommit&&oe?.committed.then(U.onCommit);continue}if(oe)if(U.beginTxn)oe.resolve();else{oe.write_promises.push(k(U,oe));continue}!U.timestamp&&U.version&&(U.timestamp=U.version);let ce=wt(U,()=>{if(U.type==="transaction"){let fe=[];for(let te of U.writes)try{fe.push(k(te,U))}catch(W){throw W.message+=" writing "+JSON.stringify(te)+" of event "+JSON.stringify(U),W}return Promise.all(fe)}else if(U.type==="define_schema"){let fe=this.attributes.slice(0),te;for(let W of U.attributes)fe.find(_e=>_e.name===W.name)||(fe.push(W),te=!0);te&&(ft({table:s,database:c,attributes:fe,origin:"cluster"}),Uh.signalSchemaChange(new xh.SchemaEventMsg(process.pid,Yt.CREATE_TABLE,c,s)))}else return U.beginTxn?(oe=U,oe.write_promises=[k(U,U)],new Promise(fe=>{oe.resolve=()=>fe(Promise.all(oe.write_promises))})):k(U,U)});oe&&(oe.committed=ce),N&&ce&&!ce?.waitingForUserChange&&(ce.then(()=>Uh.signalUserChange(new xh.UserEventMsg(process.pid))),ce.waitingForUserChange=!0),U.onCommit&&(ce?ce.then(U.onCommit):U.onCommit())}catch(ue){Ue.default.error?.("error in subscription handler",ue)}}}catch(D){Ue.default.error?.(D)}})(),this}static get isCaching(){return v}static get shouldRevalidateEvents(){return this.prototype.get!==Ie.prototype.get}static getResource(m,A,I){let y=super.getResource(m,A,I);if(m!=null){Cr(m);try{if(y.getRecord?.())return y;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let O=!I?.async||i.cache?.get?.(m),P=Gr(A),N=P.getReadTxn();if(N?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return cu(m,A,{transaction:N,ensureLoaded:I?.ensureLoaded},O,L=>{if(L?Ie._updateResource(y,L):y.#e=null,A.onlyIfCached&&A.noCacheStore){if(!y.doesExist())throw new Ir.ServerError("Entry is not cached",504)}else if(I?.ensureLoaded){let k=un(m,L,A,y);if(k)return P?.disregardReadTxn(),y.#i=!0,HP(k,D=>(Ie._updateResource(y,D),y))}return y})}catch(O){throw O.message.includes("Unable to serialize object")&&(O.message+=": "+JSON.stringify(m)),O}}return y}static _updateResource(m,A){m.#r=A,m.#e=A?.value??null,m.#n=A?.version}ensureLoaded(){let m=un(this.getId(),this.#r,this.getContext());if(m)return this.#i=!0,HP(m,A=>{this.#r=A,this.#e=A.value,this.#n=A.version})}static getNewId(){let m=F?.type;if(m==="String"||m==="ID")return super.getNewId();if(!vt){let O=i.getEntry(Symbol.for("id_allocation")),P=O?.value,N;if(P&&P.nodeName===server.hostname&&(!mAe(i)||P.pid===process.pid)){let L=P.start,k=P.end;N=L;for(let D of i.getKeys({start:k,end:L,limit:1,reverse:!0}))N=D}else P=y(O?.version??null),N=P.start;vt=new BigInt64Array([BigInt(N)+1n]),vt=new BigInt64Array(i.getUserSharedBuffer("id",vt.buffer)),vt.maxSafeId=P.end}let A=Number(Atomics.add(vt,0,1n)),I=m==="Int"?512:1048576;if(A+I>=vt.maxSafeId){let O=a(P=>{vt.maxSafeId=A+(m==="Int"?1023:4194303);let N=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,L=P?void 0:i.useReadTransaction(),k=Number(vt[0]);for(let $ of i.getKeys({start:k+1,end:N,limit:1,transaction:L}))N=$;L?.done();let{value:D,version:B}=i.getEntry(Symbol.for("id_allocation"));if(vt.maxSafeId<N){if(D.end>vt.maxSafeId-100)return;Ue.default.info?.("New id allocation",A,vt.maxSafeId,B),i.put(Symbol.for("id_allocation"),{start:D.start,end:vt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),B)}else{Ue.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${vt.maxSafeId}, but id of ${N} detected`);let $=y(B);$.alreadyUpdated||Atomics.store(vt,0,BigInt($.start+1)),vt.maxSafeId=$.end}},"updateEnd");A+I===vt.maxSafeId?setImmediate(O):A+100>=vt.maxSafeId&&(Ue.default.warn?.(`Synchronous id allocation required on table ${s}${m=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>O(!0)))}return A;function y(O){let P=(m==="Int"?Math.pow(2,31):Math.pow(2,49))-1,N=P/4,L,k,D=!1,B,$;do{B=Math.floor(Math.random()*P),$={start:B,end:B+(m==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},L=0;for(let j of i.getKeys({start:B,limit:1,reverse:!0}))L=j;k=P;for(let j of i.getKeys({start:B+1,end:P,limit:1}))k=j;N*=.875,N<1e3&&!D&&(D=!0,Ue.default.error?.(`Id allocation in table ${s} is very dense, limited safe range of numbers to allocate ids in${m==="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`,B,L,k,N))}while(!(N<k-B&&(N<B-L||L===0)));return i.transactionSync(()=>{let j=i.getEntry(Symbol.for("id_allocation"));return(j?.version??null)==O?(Ue.default.info?.("Allocated new id range",$),i.put(Symbol.for("id_allocation"),$,Date.now()),$):(Ue.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...j.value})})}}static setTTLExpiration(m){if(typeof m=="number")h=m*1e3,S||(S=0);else if(m&&typeof m=="object")h=m.expiration*1e3,S=(m.eviction||0)*1e3,Nt=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(h<0)throw new Error("Expiration can not be negative");Nt=Nt||(h+S)/4,aa()}static getResidencyRecord(m){return f.get([Symbol.for("residency_by_id"),m])}static setResidency(m){Ie.getResidency=m}static setResidencyById(m){Ie.getResidencyById=m}static getResidency(m,A){if(Ie.getResidencyById)return Ie.getResidencyById(m[t]);let I=Ef;if(A.replicateTo!=null){if(Array.isArray(A.replicateTo))return A.replicateTo.includes(server.hostname)?A.replicateTo:[server.hostname,...A.replicateTo];A.replicateTo>=0&&(I=A.replicateTo)}if(I>=0&&server.nodes){let y=[server.hostname];if(A.previousResidency)y.push(...A.previousResidency.slice(0,I));else{let O=server.nodes.map(L=>L.name),P=Math.floor(O.length*Math.random());y.push(...O.slice(P,P+I));let N=P+I-O.length;N>0&&y.push(...O.slice(0,N))}return y}}static enableAuditing(m=!0){g=m,m&&Af(),Ie.audit=m}static coerceId(m){return m===""?null:hA(m,F)}static async dropTable(){delete qe[c][s];for(let m of i.getRange({versions:!0,snapshot:!1,lazy:!0}))m.metadataFlags&Fn&&m.value&&Ta(m.value);if(c===o){for(let m of E)f.remove(Ie.tableName+"/"+m.name),r[m.name]?.drop();f.remove(Ie.tableName+"/"),i.drop(),await f.committed}else console.log("legacy dropTable"),await i.close(),await pA.default.remove(data_path),await pA.default.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));Uh.signalSchemaChange(new xh.SchemaEventMsg(process.pid,Yt.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this.isCollection)return this.search(m);if(this.getId()===null)return m?.conditions?this.search(m):{records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:E};if(m?.property)return this.getProperty(m.property);if(this.doesExist()||m?.ensureLoaded===!1||this.getContext()?.returnNonexistent)return this}allowRead(m,A){let I=Tf(m);if(I?.read){if(I.isSuperUser)return!0;let y=I.attribute_permissions,O=A?.select;if(y?.length>0||ou&&O){if(A||(A={}),O){let P=y?.length>0&&BP(y,"read");A.select=O.map(N=>{let L=N.name||N;if(!P||P[L]){let k=Un[L]?.definition?.tableClass;if(k){if(N.name||(N={name:N}),!k.prototype.allowRead.call(null,m,N))return!1;if(!N.select)return N.name}return N}}).filter(Boolean)}else A.select=y.filter(P=>P.read&&!Un[P.attribute_name]).map(P=>P.attribute_name);return A}else return!0}}allowUpdate(m,A){let I=Tf(m);if(I?.update){let y=I.attribute_permissions;if(y?.length>0){let O=BP(y,"update");for(let P in A)if(!O[P])return!1;for(let P of y){let N=P.attribute_name;!P.update&&!(N in A)&&(A[N]=this.getProperty(N))}}return oa(this.getContext())}}allowCreate(m,A){if(this.isCollection){let I=Tf(m);if(I?.insert){let y=I.attribute_permissions;if(y?.length>0){let O=BP(y,"insert");for(let P in A)if(!O[P])return!1;return oa(this.getContext())}else return oa(this.getContext())}}else return this.allowUpdate(m,{})}allowDelete(m){return Tf(m)?.delete&&oa(this.getContext())}update(m,A){if(!Gr(this.getContext()))throw new Error("Can not update a table resource outside of a transaction");if(m===!1)return this;let y;return typeof m=="object"&&m&&(A?(Object.isFrozen(m)&&(m={...m}),this.#e={},this.#t=m):(y=this.#t,y&&(m=Object.assign(y,m)),this.#t=m)),this._writeUpdate(this.#t,A),this}addTo(m,A){if(typeof A=="number"||typeof A=="bigint")this.#s===zj?this.set(m,(+this.getProperty(m)||0)+A):(this.#s||this.update(),this.set(m,new kE(A)));else throw new Error("Can not add a non-numeric value")}subtractFrom(m,A){if(typeof A=="number")return this.addTo(m,-A);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this.#r}getRecord(){return this.#e}getChanges(){return this.#t}_setChanges(m){this.#t=m}setRecord(m){this.#e=m}invalidate(){this._writeInvalidate()}_writeInvalidate(m,A){let I=this.getContext(),y=this.getId();Cr(y),Gr(this.getContext()).addWrite({key:y,store:i,invalidated:!0,entry:this.#r,before:Pe.invalidate?.bind(this,I,y),beforeIntermediate:he.invalidate?.bind(this,I,y),commit:a((P,N)=>{if(!(ia(P,N,A?.nodeId)<=0)){m??=null;for(let L in r)m||(m={}),m[L]===void 0&&(m[L]=this.getProperty(L));Ue.default.trace?.(`Invalidating entry id: ${y}, timestamp: ${new Date(P).toISOString()}`),T(y,m,this.#r,P,mn,g,{user:I?.user,residencyId:A?.residencyId,nodeId:A?.nodeId},"invalidate")}},"commit")})}_writeRelocate(m){let A=this.getContext(),I=this.getId();Cr(I),Gr(this.getContext()).addWrite({key:I,store:i,invalidated:!0,entry:this.#r,before:Pe.relocate?.bind(this,A,I),beforeIntermediate:he.relocate?.bind(this,A,I),commit:a((O,P)=>{if(ia(O,P,m?.nodeId)<=0)return;let N=Ie.getResidencyRecord(m.residencyId),L=0,k=null,D=P?.value;if(N&&!N.includes(server.hostname)){for(let B in r)k||(k={}),k[B]=D(B);L=mn}else k=D;Ue.default.trace?.(`Relocating entry id: ${I}, timestamp: ${new Date(O).toISOString()}`),T(I,k,this.#r,O,L,g,{user:A.user,residencyId:m.residencyId,nodeId:m.nodeId,expiresAt:m.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(m,A){let I={previousResidency:this.getResidencyRecord(m.residencyId),isRelocation:!0},y=Ac(this.getResidency(A.value,I)),O;if(y){if(!y.includes(server.hostname))return;O=Rc(y)}let N=T(m.key,A.value,m,m.version,0,!0,{residencyId:O,expiresAt:A.expiresAt},"relocate",!1,null)}static evict(m,A,I){let y=this.Source,O;if(!((v||g)&&(!A||(O=i.getEntry(m),!O||!A)||O.version!==I))){if(v){if(i.hasLock(m,O.version))return;let P;for(let N in r)P||(P={}),P[N]=A[N];if(P)return T(m,P,O,I,ma,null,null,null,!0)}if(i.ifVersion(m,I,()=>{ln(m,A,null)}),g)return T(m,null,O,I,ma,null,null,null,!0);Hc(i,O??i.getEntry(m),I)}}lock(){throw new Error("Not yet implemented")}static operation(m,A){return m.table||=s,m.schema||=c,rJ.operation(m,A)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,A,I){let y=this.getContext(),O=Gr(y),P=this.getId();Cr(P);let N=this.#r;this.#s=A?zj:dAe;let L={key:P,store:i,entry:N,nodeName:y?.nodeName,validate:a(k=>{m||(m=this.#t),A||m&&BE(this.#t===m?this:m)?y?.source||(O.checkOverloaded(),this.validate(m,!A),Z&&(m[Z.name]=Z.type==="Date"?new Date(k):Z.type==="String"?new Date(k).toISOString():k),A&&(t&&m[t]!==P&&(m[t]=P),Y&&(N?.value?m[Y.name]=N?.value[Y.name]:m[Y.name]=Y.type==="Date"?new Date(k):Y.type==="String"?new Date(k).toISOString():k),m=sl(m))):O.removeWrite(L)},"validate"),before:A?Pe.put?()=>Pe.put(y,P,m):null:Pe.patch?()=>Pe.patch(y,P,m):Pe.put?()=>Pe.put(y,P,sl(this)):null,beforeIntermediate:A?he.put?()=>he.put(y,P,m):null:he.patch?()=>he.patch(y,P,m):he.put?()=>he.put(y,P,sl(this)):null,commit:a((k,D,B)=>{if(B){if(y&&D?.version>(y.lastModified||0)&&(y.lastModified=D.version),this.#r=D,D?.value&&D.value.getRecord)throw new Error("Can not assign a record to a record, check for circular references");A||(this.#e=D?.value??null)}this.#t=void 0,this.#n=k;let $=D?.value,j=m;this.#s=0;let oe=!1,U=ia(k,D,I?.nodeId),ue;if(U<=0)if(g){let _e=D.localTime,Ee=D.version;Ue.default.trace?.("Applying CRDT update to record with id: ",P,"applying later update:",Ee);let Se=[];for(;_e>k||Ee>=k&&_e>0;){let tt=l.get(_e);if(!tt)break;let Ye=It(tt);if(Ee=Ye.version,Ee>=k){if(Ee===k){if(U=ia(k,{version:Ee,localTime:_e},I?.nodeId),U===0)return;if(U>0)continue}if(Ye.type==="patch")Se.push(Ye),ue=m;else if(Ye.type==="put"||Ye.type==="delete")return}_e=Ye.previousLocalTime}Se.sort((tt,Ye)=>tt.version-Ye.version);for(let tt of Se){let Ye=tt.getValue(i);if(j=UE(j,Ye,A),Ue.default.debug?.("Rebuilding update with future patch:",j),!j)return}}else{if(A)return;j=UE(j,$,A),Ue.default.debug?.("Rebuilding update without audit:",j)}let ce;if(A?ce=j:(this.#e=$,ce=sl(this,j)),this.#e=ce,ce&&ce.getRecord)throw new Error("Can not assign a record to a record, check for circular references");let fe;if(I?.residencyId!=null)fe=I.residencyId;else{N?.residencyId&&(y.previousResidency=Ie.getResidencyRecord(N.residencyId));let _e=Ac(Ie.getResidency(ce,y));if(_e&&!_e.includes(server.hostname))if(ue??=ce,oe=!0,Ie.getResidencyById)ce=void 0;else{ce=null;for(let Ee in r)ce||(ce={}),ce[Ee]=ue[Ee]}fe=Rc(_e)}A||(ue=m);let te=y?.expiresAt??(h?h+Date.now():-1);Ue.default.trace?.(`Saving record with id: ${P}, timestamp: ${new Date(k).toISOString()}${te?", expires at: "+new Date(te).toISOString():""}${D?", replaces entry from: "+new Date(D.version).toISOString():", new entry"}`,(()=>{try{return JSON.stringify(ce).slice(0,100)}catch{return""}})()),ln(P,$,ce);let W=A?"put":"patch";T(P,ce,D,k,oe?mn:0,g,{omitLocalRecord:oe,user:y?.user,residencyId:fe,expiresAt:te,nodeId:I?.nodeId,originatingOperation:y?.originatingOperation},W,!1,ue),y.expiresAt&&aa()},"commit")};O.addWrite(L)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this.isCollection){for await(let A of this.search(m))(await Ie.getResource(A[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this.#e?this._writeDelete(m):!1}_writeDelete(m){let A=Gr(this.getContext()),I=this.getId();Cr(I);let y=this.getContext();return A.addWrite({key:I,store:i,entry:this.#r,nodeName:y?.nodeName,before:Pe.delete?.bind(this,y,I),beforeIntermediate:he.delete?.bind(this,y,I),commit:a((O,P,N)=>{let L=P?.value;N&&(y&&P?.version>(y.lastModified||0)&&(y.lastModified=P.version),Ie._updateResource(this,P)),!(ia(O,P,m?.nodeId)<=0)&&(ln(this.getId(),L),Ue.default.trace?.(`Deleting record with id: ${I}, txn timestamp: ${new Date(O).toISOString()}`),g||R?(T(I,null,this.#r,O,0,g,{user:y?.user,nodeId:m?.nodeId},"delete"),g||aa()):Hc(i,P))},"commit")}),!0}search(m){let A=this.getContext(),I=Gr(A);if(!m)throw new Error("No query provided");let y=m.conditions;y?y.length===void 0&&(y=y[Symbol.iterator]?Array.from(y):[y]):y=Array.isArray(m)?m:m[Symbol.iterator]?Array.from(m):[],this.getId()&&(y=[{attribute:null,comparator:Array.isArray(this.getId())?"prefix":"starts_with",value:this.getId()}].concat(y));let O,P={};function N(W,_e){let Ee;switch(_e){case"and":case void 0:if(W.length<1)throw new Error('An "and" operator requires at least one condition');Ee=!0;break;case"or":if(W.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+_e)}for(let Se of W){if(Se.conditions){Se.conditions=N(Se.conditions,Se.operator);continue}let tt=Se[0]??Se.attribute,Ye=tt==null?F:bi(E,tt);if(Ye)(Ye.type||pR[Se.comparator])&&(Se[1]===void 0?Se.value=k(Se.value,Ye):Se[1]=k(Se[1],Ye));else if(tt!=null)throw(0,Ir.handleHDBError)(new Error,`${tt} is not a defined attribute`,404);if(Se.chainedConditions)if(Se.chainedConditions.length===1&&(!Se.operator||Se.operator=="and")){let mr=Se.chainedConditions[0],ge,Qe;if(mr.comparator==="gt"||mr.comparator==="greater_than"||mr.comparator==="ge"||mr.comparator==="greater_than_equal"?(ge=Se,Qe=mr):(ge=mr,Qe=Se),ge.comparator!=="lt"&&ge.comparator!=="less_than"&&ge.comparator!=="le"&&ge.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let st=Qe.comparator==="ge"||Qe.comparator==="greater_than_equal",Vt=ge.comparator==="le"||ge.comparator==="less_than_equal";Se.comparator=(st?"ge":"gt")+(Vt?"le":"lt"),Se.value=[Qe.value,ge.value]}else throw new Error("Multiple chained conditions are not currently supported")}return W}a(N,"prepareConditions");function L(W,_e){if(m.enforceExecutionOrder)return W;for(let Ee of W)Ee.conditions&&(Ee.conditions=L(Ee.conditions,Ee.operator));return W.length>1&&_e!=="or"?(0,eJ.sortBy)(W,bm(Ie)):W}a(L,"orderConditions");function k(W,_e){return Array.isArray(W)?W.map(Ee=>hA(Ee,_e)):hA(W,_e)}a(k,"coerceTypedValues");let D=m.operator;(y.length>0||D)&&(y=N(y,D));let B=typeof m.sort=="object"&&m.sort,$;if(B&&D!=="or"){let W=B.attribute;if(W==null)throw new Ir.ClientError("Sort requires an attribute");if(O=y.find(_e=>gu(_e.attribute)===gu(W)),!O){let _e=bi(E,W);if(!_e)throw(0,Ir.handleHDBError)(new Error,`${Array.isArray(W)?W.join("."):W} is not a defined attribute`,404);if(_e.indexed)O={attribute:W,comparator:"sort"},y.push(O);else if(y.length===0&&!m.allowFullScan)throw(0,Ir.handleHDBError)(new Error,`${Array.isArray(W)?W.join("."):W} is not indexed and not combined with any other conditions`,404)}O&&(O.descending=!!B.descending)}y=L(y,D),B&&(O&&y[0]===O?B.next&&($={dbOrderedAttribute:B.attribute,attribute:B.next.attribute,descending:B.next.descending,next:B.next.next}):(O&&y.splice(y.indexOf(O),1),$=B));let j=m.select;if(y.length===0&&(y=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:y,operator:D,postOrdering:$,selectApplied:!!j};let oe=I.useReadTxn(),U=hR(y,D,Ie,oe,m,A,(W,_e)=>uu(W,j,A,oe,_e),P),ue=m.ensureLoaded!==!1;$||(U=te(U));let ce=Ie.transformEntryForSelect(j,A,oe,P,ue,!0),fe=Ie.transformToOrderedSelect(U,j,$,oe,A,ce);function te(W){return m.offset||m.limit!==void 0?W.slice(m.offset,m.limit!==void 0?(m.offset||0)+m.limit:void 0):W}return a(te,"applyOffset"),$&&(fe=te(fe)),fe.onDone=()=>{fe.onDone=null,I.doneReadTxn()},fe.selectApplied=!0,fe.getColumns=()=>{if(j){let W=[];for(let _e of j)_e==="*"?W.push(...E.map(Ee=>Ee.name)):W.push(_e.name||_e);return W}return E.filter(W=>!W.computed&&!W.relationship).map(W=>W.name)},fe}static transformToOrderedSelect(m,A,I,y,O,P){let N=new Qh;if(I){m=uu(m,A,y,O,null);let L;N.iterate=function(){let D,B=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),$,j=I.dbOrderedAttribute,oe,U,ue=!0;function ce(te){let W=te.next&&ce(te.next),_e=te.descending;return(Ee,Se)=>{let tt=lu(Ee,te.attribute,y),Ye=lu(Se,te.attribute,y),mr=_e?(0,Zl.compareKeys)(Ye,tt):(0,Zl.compareKeys)(tt,Ye);return mr===0?W?.(Ee,Se)||0:mr}}a(ce,"createComparator");let fe=ce(I);return{async next(){let te;if(D)if(te=D.next(),te.done){if($)return N.onDone&&N.onDone(),te}else return{value:await P.call(this,te.value)};L=[],oe&&L.push(oe);do if(te=await B.next(),te.done){if($=!0,L.length)break;return N.onDone&&N.onDone(),te}else{let W=te.value;if(W?.then&&(W=await W),j){let _e=lu(W,j,y);if(ue)ue=!1,U=_e;else if(_e!==U){U=_e,oe=W;break}}L.push(W)}while(!0);return I.isGrouped,L.sort(fe),D=L[Symbol.iterator](),te=D.next(),te.done?(N.onDone&&N.onDone(),te):{value:await P.call(this,te.value)}},return(){N.onDone&&N.onDone(),B.return()},throw(){N.onDone&&N.onDone(),B.throw()}}};let k=a(D=>{if(typeof A=="object"&&Array.isArray(D.attribute))for(let B=0;B<A.length;B++){let $=A[B],j;if($.name===D.attribute[0]){for(j=$.sort||($.sort={});j.next;)j=j.next;j.attribute=D.attribute.slice(1),j.descending=D.descending}else $===D.attribute[0]&&(A[B]=j={name:$,sort:{attribute:D.attribute.slice(1),descending:D.descending}})}D.next&&k(D.next)},"applySortingOnSelect");k(I)}else N.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),N=N.map(function(L){try{let k=P.call(this,L);return typeof k?.catch=="function"?k.catch(D=>{throw D.partialObject={[t]:L.key},D}):k}catch(k){throw k.partialObject={[t]:L.key},k}});return N}static transformEntryForSelect(m,A,I,y,O,P){if(m&&(m===t||m?.length===1&&m[0]===t&&Array.isArray(m))){let D=a(B=>(A?.transaction?.stale&&(A.transaction.stale=!1),B?.key??B),"transform");return m===t?D:m.asArray?B=>[D(B)]:B=>({[t]:D(B)})}let N;O&&v&&!(typeof m=="string"?[m]:m)?.every(D=>{let B;return typeof D=="object"?B=D.name:B=D,r[B]||B===t})&&(N=!0);let L,k=a(function(D){let B;if(A?.transaction?.stale&&(A.transaction.stale=!1),D!=null){if(B=D.value||D.deref?.()?.value,!B&&(D.key===void 0||D.deref)||D.metadataFlags&mn){if(D.metadataFlags&mn&&A.replicateFrom===!1&&P&&D.residencyId)return mc.SKIP;if(D=cu(D.key??D,A,{transaction:I,lazy:m?.length<4,ensureLoaded:O},this?.isSync,$=>$),D?.then)return D.then(k.bind(this));B=D?.value}if(N&&D?.metadataFlags&(mn|ma)||D?.expiresAt!=null&&D?.expiresAt<Date.now()){if(A.onlyIfCached&&A.noCacheStore)return{[t]:D.key,message:"This entry has expired"};let $=un(D.key??D,D,A);if($?.then)return $.then(k)}}if(B==null)return P?mc.SKIP:B;if(m&&!(m[0]==="*"&&m.length===1)){let $,j=a((U,ue)=>{let ce;typeof U=="object"?ce=U.name:ce=U;let fe=Un?.[ce],te;if(fe){let W=y?.[ce];if(W)if(W.hasMappings){let Ee=fe.from?B[fe.from]:gu(D.key);te=W.get(Ee),te||(te=[])}else te=W.fromRecord?.(B);else te=fe(B,A,D);let _e=a(Ee=>{if(Ee&&typeof Ee=="object"){let Se=fe.definition?.tableClass||Ie;L||(L={});let tt=L[ce]||(L[ce]=Se.transformEntryForSelect(ce===U?null:U.select||(Array.isArray(U)?U:null),A,I,W,O));if(Array.isArray(Ee)){let Ye=[],mr=Se.transformToOrderedSelect(Ee,U.select,typeof U.sort=="object"&&U.sort,A,I,tt)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),ge=a(st=>{for(;!st.done;){if(st?.then)return st.then(ge);Ye.push(st.value),st=mr.next()}ue(Ye,ce)},"nextValue"),Qe=ge(mr.next());Qe&&($||($=[]),$.push(Qe));return}else if(Ee=tt.call(this,Ee),Ee?.then){$||($=[]),$.push(Ee.then(Ye=>ue(Ye,ce)));return}}ue(Ee,ce)},"handleResolvedValue");te?.then?($||($=[]),$.push(te.then(_e))):_e(te);return}else te=B[ce],te&&typeof te=="object"&&ce!==U&&(te=Ie.transformEntryForSelect(U.select||U,A,I,null)({value:te}));ue(te,ce)},"selectAttribute"),oe;if(typeof m=="string")j(m,U=>{oe=U});else if(Array.isArray(m))if(m.asArray)oe=[],m.forEach((U,ue)=>{U==="*"?m[ue]=B:j(U,ce=>oe[ue]=ce)});else{oe={};let U=m.forceNulls;for(let ue of m)if(ue==="*")for(let ce in B)oe[ce]=B[ce];else j(ue,(ce,fe)=>{ce===void 0&&U&&(ce=null),oe[fe]=ce})}else throw new Ir.ClientError("Invalid select"+m);return $?Promise.all($).then(()=>oe):oe}return B},"transform");return k}async subscribe(m){if(!l)throw new Error("Can not subscribe to a table without an audit log");g||ft({table:s,database:c,schemaDefined:u,attributes:E,audit:!0}),m||(m={});let A=!m.rawEvents,I=[],y=this,O=xP(Ie,this.getId()??null,function(N,L,k,D){try{let B=L.getValue?.(i,A),$=L.type;if(!B&&$==="patch"&&A){let oe=i.getEntry(N);oe?.version===L.version?B=oe.value:B=L.getValue?.(i,!0,k),$="put"}let j={id:N,localTime:k,value:B,version:L.version,type:$,beginTxn:D};I?I.push(j):this.send(j)}catch(B){Ue.default.error?.(B)}},m.startTime||0,m),P=(async()=>{this.isCollection&&(O.includeDescendants=!0,m.onlyChildren&&(O.onlyChildren=!0)),m.supportsTransactions&&(O.supportsTransactions=!0);let N=this.getId(),L=m.previousCount;L>1e3&&(L=1e3);let k=m.startTime;if(this.isCollection){if(k){if(L)throw new Ir.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:D,value:B}of l.getRange({start:k,exclusiveStart:!0,snapshot:!1})){let $=It(B);if($.tableId!==n)continue;let j=$.recordId;if(N==null||Xj(N,j)){let oe=$.getValue(i,A,D);if(O.send({id:j,localTime:D,value:oe,version:$.version,type:$.type}),O.queue?.length>Jj&&await O.waitForDrain()===!1)return}O.startTime=D}}else if(L){let D=[];for(let{key:B,value:$}of l.getRange({start:"z",end:!1,reverse:!0}))try{let j=It($);if(j.tableId!==n)continue;let oe=j.recordId;if(N==null||Xj(N,oe)){let U=j.getValue(i,A,B);if(D.push({id:oe,localTime:B,value:U,version:j.version,type:j.type}),--L<=0)break}}catch(j){Ue.default.error("Error getting history entry",B,j)}for(let B=D.length;B>0;)O.send(D[--B]);D[0]&&(O.startTime=D[0].localTime)}else if(!m.omitCurrent){for(let{key:D,value:B,version:$,localTime:j}of i.getRange({start:N??!1,end:N==null?void 0:[N,Zl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(B&&(O.send({id:D,localTime:j,value:B,version:$,type:"put"}),O.queue?.length>Jj&&await O.waitForDrain()===!1))return}}else{L&&!k&&(k=0);let D=this.#r?.localTime;if(D===JR&&(i.cache?.delete(N),this.#r=i.getEntry(N),Ue.default.trace?.("re-retrieved record",D,this.#r?.localTime),D=this.#r?.localTime),Ue.default.trace?.("Subscription from",k,"from",N,D),k<D){let B=[],$=D;do{let j=l.get($);if(j){m.omitCurrent=!0;let oe=It(j),U=oe.getValue(i,A,$);A&&(oe.type="put"),B.push({id:N,value:U,localTime:$,...oe}),$=oe.previousLocalTime}else break;L&&L--}while($>k&&L!==0);for(let j=B.length;j>0;)O.send(B[--j]);O.startTime=D}!m.omitCurrent&&this.doesExist()&&O.send({id:N,localTime:D,value:this.#e,version:this.#n,type:"put"})}for(let D of I)O.send(D);I=null})();return m.listener&&O.on("data",m.listener),O}static subscribeOnThisThread(m,A){return m===0||A?.crossThreads===!1}doesExist(){return!!(this.#e||this.#s)}publish(m,A){this._writePublish(m,A)}_writePublish(m,A){let I=Gr(this.getContext()),y=this.getId()||null;y!=null&&Cr(y);let O=this.getContext();I.addWrite({key:y,store:i,entry:this.#r,nodeName:O?.nodeName,validate:a(()=>{O?.source||(I.checkOverloaded(),this.validate(m))},"validate"),before:Pe.publish?.bind(this,O,y,m),beforeIntermediate:he.publish?.bind(this,O,y,m),commit:a((P,N,L)=>{N===void 0&&R&&!g&&aa(),Ue.default.trace?.(`Publishing message to id: ${y}, timestamp: ${new Date(P).toISOString()}`),T(y,N?.value??null,N,N?.version||P,0,!0,{user:O?.user,residencyId:A?.residencyId,expiresAt:O?.expiresAt,nodeId:A?.nodeId},"message",!1,m)},"commit")})}validate(m,A){let I,y=a((O,P,N)=>{if(P.type&&O!=null)if(A&&O.__op__&&(O=O.value),P.properties){typeof O!="object"&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be an object${P.type?" ("+P.type+")":""}`);let L=P.properties;for(let k=0,D=L.length;k<D;k++){let B=L[k],$=y(O[B.name],B,N+"."+B.name);$&&(O[B.name]=$)}if(P.sealed&&O!=null&&typeof O=="object")for(let k in O)L.find(D=>D.name===k)||(I||(I=[])).push(`Property ${k} is not allowed within object in property ${N}`)}else switch(P.type){case"Int":(typeof O!="number"||O>>0!==O)&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof O!="number"||!(Math.floor(O)===O&&Math.abs(O)<=9007199254740992))&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof O!="number"&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a number`);break;case"ID":typeof O=="string"||O?.length>0&&O.every?.(L=>typeof L=="string")||(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a string, or an array of strings`);break;case"String":typeof O!="string"&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a string`);break;case"Boolean":typeof O!="boolean"&&(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a boolean`);break;case"Date":if(!(O instanceof Date)){if(typeof O=="string"||typeof O=="number")return new Date(O);(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a Date`)}break;case"BigInt":if(typeof O!="bigint"){if(typeof O=="string"||typeof O=="number")return BigInt(O);(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a bigint`)}break;case"Bytes":if(!(O instanceof Uint8Array)){if(typeof O=="string")return Buffer.from(O);(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a Buffer or Uint8Array`)}break;case"Blob":if(!(O instanceof wi)){if(typeof O=="string"&&(O=Buffer.from(O)),O instanceof Buffer)return createBlob(O,{type:"text/plain"});(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be a Blob`)}break;case"array":if(Array.isArray(O)){if(P.elements)for(let L=0,k=O.length;L<k;L++){let D=O[L],B=y(D,P.elements,N+"[*]");B&&(O[L]=B)}}else(I||(I=[])).push(`Value ${Fs(O)} in property ${N} must be an Array`);break}P.nullable===!1&&O==null&&(I||(I=[])).push(`Property ${N} is required (and not does not allow null values)`)},"validateValue");for(let O=0,P=E.length;O<P;O++){let N=E[O];if(!(N.relationship||N.computed)&&(!A||N.name in m)){let L=y(m[N.name],N,N.name);L&&(m[N.name]=L)}}if(d)for(let O in m)E.find(P=>P.name===O)||(I||(I=[])).push(`Property ${O} is not allowed`);if(I)throw new Ir.ClientError(I.join(". "))}getUpdatedTime(){return this.#n}wasLoadedFromSource(){return v?!!this.#i:void 0}static async addAttributes(m){let A=E.slice(0);for(let I of m){if(!I.name)throw new Ir.ClientError("Attribute name is required");if(I.name.match(/[`/]/))throw new Ir.ClientError("Attribute names cannot include backticks or forward slashes");(0,tJ.validateAttribute)(I.name),A.push(I)}return ft({table:s,database:c,schemaDefined:u,attributes:A}),Ie.indexingOperation}static async removeAttributes(m){let A=E.filter(I=>!m.includes(I.name));return ft({table:s,database:c,schemaDefined:u,attributes:A}),Ie.indexingOperation}static getSize(){let m=i.getStats();return(m.treeBranchPageCount+m.treeLeafPageCount+m.overflowPages)*m.pageSize}static getAuditSize(){let m=l?.getStats();return m&&(m.treeBranchPageCount+m.treeLeafPageCount+m.overflowPages)*m.pageSize}static getStorageStats(){let m=i.env.path,A=pA.default.statfsSync?.(m)??{};return{available:A.bavail*A.bsize,free:A.bfree*A.bsize,size:A.blocks*A.bsize}}static async getRecordCount(m){let A=i.getStats().entryCount,I=1e3/2,y=performance.now(),O=Math.floor(A/2),P=m?.exactCount,N=0,L=0,k;for(let{value:D}of i.getRange({start:!0,lazy:!0,snapshot:!1}))if(D!=null&&N++,L++,await hc(),!P&&L<O&&performance.now()-y>I){k=L;break}if(k){let D=N;N=0;for(let{value:te}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:k,snapshot:!1}))te!=null&&N++,await hc();let B=k*2,$=(N+D)/B,j=Math.pow((N-D+1)/k/2,2)+$*(1-$)/B,oe=Math.max(Math.sqrt(j)*A,1),U=Math.round($*A),ue=Math.max(U-1.96*oe,N+D),ce=Math.min(U+1.96*oe,A),fe=Math.pow(10,Math.round(Math.log10(oe)));return fe>U&&(fe=fe/10),N=Math.round(U/fe)*fe,{recordCount:N,estimatedRange:[Math.round(ue),Math.round(ce)]}}return{recordCount:N}}static updatedAttributes(){Un=this.propertyResolvers={$id:a((m,A,I)=>({value:I.key}),"$id"),$updatedtime:a((m,A,I)=>I.version,"$updatedtime"),$record:a((m,A,I)=>I?{value:m}:m,"$record")};for(let m of this.attributes){m.resolve=null;let A=m.relationship,I=m.computed;if(A)if(m.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),I&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),ou=!0,A.to)m.elements?.definition?(Un[m.name]=m.resolve=(y,O,P)=>{let N=y[A.from?A.from:t],L=m.elements.definition.tableClass;return P?Eu({attribute:A.to,value:N},Gr(O).getReadTxn(),!1,L,!1).asArray:L.search([{attribute:A.to,value:N}],O).asArray},m.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},m.resolve.definition=m.elements.definition,A.from&&(m.resolve.from=A.from)):console.error(`The one-to-many/many-to-many relationship property "${m.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(A.from){let y=m.definition||m.elements?.definition;y?(Un[m.name]=m.resolve=(O,P,N)=>{let L=O[A.from];if(L!==void 0){if(m.elements){let k,D=L?.map(B=>{let $=N?y.tableClass.primaryStore.getEntry(B,{transaction:Gr(P).getReadTxn()}):y.tableClass.get(B,P);return $?.then&&(k=!0),$});return A.filterMissing?k?Promise.all(D).then(B=>B.filter(Zj)):D.filter(Zj):k?Promise.all(D):D}return N?y.tableClass.primaryStore.getEntry(L,{transaction:Gr(P).getReadTxn()}):y.tableClass.get(L,P)}},m.set=(O,P)=>{if(Array.isArray(P)){let N=P.map(L=>L.getId?.()||L[y.tableClass.primaryKey]);O[A.from]=N}else{let N=P.getId?.()||P[y.tableClass.primaryKey];O[A.from]=N}},m.resolve.definition=m.definition||m.elements?.definition,m.resolve.from=A.from):console.error(`The relationship property "${m.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${m.name}" in table "${s}" must use either "from" or "to" arguments`);else I&&(typeof I.from=="function"&&this.setComputedAttribute(m.name,I.from),Un[m.name]=m.resolve=(y,O,P)=>{let N=typeof I.from=="string"?y[I.from]:y,L=this.userResolvers[m.name];if(L)return L(N,O,P);Ue.default.warn(`Computed attribute "${m.name}" does not have a function assigned to it. Please use setComputedAttribute('${m.name}', resolver) to assign a resolver function.`),this.userResolvers[m.name]=()=>{}})}FE(this,this)}static setComputedAttribute(m,A){let I=bi(E,m);if(!I){console.error(`The attribute "${m}" does not exist in the table "${s}"`);return}if(!I.computed){console.error(`The attribute "${m}" is not defined as computed in the table "${s}"`);return}this.userResolvers[m]=A}static async deleteHistory(m=0,A=!1){let I;for(let{key:y,value:O}of l.getRange({start:0,end:m}))await hc(),It(O).tableId===n&&(I=fA(l,y,O));if(A)for(let y of i.getRange({start:0,versions:!0})){let{key:O,value:P,localTime:N}=y;await hc(),P===null&&N<m&&(I=Hc(i,y))}await I}static async*getHistory(m=0,A=1/0){for(let{key:I,value:y}of l.getRange({start:m||1,end:A})){await hc();let O=It(y);O.tableId===n&&(yield{id:O.recordId,localTime:I,version:O.version,type:O.type,value:O.getValue(i,!0,I),user:O.user,operation:O.originatingOperation})}}static async getHistoryOfRecord(m){let A=[];if(m==null)throw new Error("An id is required");let I=i.getEntry(m);if(!I)return A;let y=I.localTime;if(!y)throw new Error("The entry does not have a local audit time");let O=0;do{await hc();let P=l.get(y);if(P){let N=It(P);A.push({id:N.recordId,localTime:y,version:N.version,type:N.type,value:N.getValue(i,!0,y),user:N.user}),y=N.previousLocalTime}else break}while(O<1e3&&y);return A.reverse()}static cleanup(){Q?.remove()}}Ie.updatedAttributes();let Sf=Ie.prototype;return h&&Ie.setTTLExpiration(h/1e3),se&&du(),Ie;function ln(V,m,A){let I;for(let y in r){let O=r[y],P=O.isIndexing,N=Un[y],L=A&&(N?N(A):A[y]),k=m&&(N?N(m):m[y]);if(L===k&&!P)continue;I=!0;let D=O.indexNulls,B=(0,vh.getIndexedValues)(L,D),$=(0,vh.getIndexedValues)(k,D);if($?.length>0){let j=new Set($);if(B=B?B.filter(oe=>{if(j.has(oe))j.delete(oe);else return!0}):[],$=Array.from(j),($.length>0||B.length>0)&&Wj){let oe=$.concat(B).map(U=>({key:U,value:V}));O.prefetch(oe,Qj)}for(let oe=0,U=$.length;oe<U;oe++)O.remove($[oe],V)}else B?.length>0&&Wj&&O.prefetch(B.map(j=>({key:j,value:V})),Qj);if(B)for(let j=0,oe=B.length;j<oe;j++)O.put(B[j],V)}return I}a(ln,"updateIndices");function Cr(V){switch(typeof V){case"number":return!0;case"string":if(V.length<659)return!0;if(V.length>jj)throw new Error("Primary key size is too large: "+V.length);break;case"object":if(V===null)throw new Error("Invalid primary key of null");break;case"bigint":if(V<2n**64n&&V>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof V)}if((0,Zl.writeKey)(V,fAe,0)>jj)throw new Error("Primary key size is too large: "+V.length);return!0}a(Cr,"checkValidId");function cu(V,m,A,I,y){if(Ie.getResidencyById&&A.ensureLoaded&&m?.replicateFrom!==!1){let P=Ac(Ie.getResidencyById(V));if(P&&!P.includes(server.hostname)&&b)return b({key:V,residency:P}).then(y)}let O=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),A.transaction?.isDone)return y(null,V);let P=i.getEntry(V,A);return P?.residencyId&&P.metadataFlags&mn&&b&&A.ensureLoaded&&m?.replicateFrom!==!1?b(P).then(N=>y(N,V),N=>(Ue.default.error?.("Error loading remote record",V,P,A,N),y(null,V))):(P&&m&&(P?.version>(m.lastModified||0)&&(m.lastModified=P.version),P?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=P.localTime)),y(P,V))},"whenPrefetched");return I?O():me>0?(me--,O()):new Promise((P,N)=>{me===0?(me--,i.prefetch([V],()=>{L(),k()})):(ne.push(V),J.push(k),ne.length>Xh&&(me--,L()));function L(){if(ne.length>0){let D=J;i.prefetch(ne,()=>{me===-1?L():me++;for(let B of D)B()}),ne=[],J=[],ye>2&&ye--}else me=ye,ye<gf&&ye++}a(L,"prefetch");function k(){try{P(O())}catch(D){N(D)}}a(k,"load")})}a(cu,"loadLocalRecord");function Tf(V){if(!V?.role)return;let m=V.role.permission;if(m.super_user)return _Ae;let A=m[c],I,y=A?.tables;if(y)return y[s];if(c==="data"&&(I=m[s])&&!I.tables)return I}a(Tf,"getTablePermissions");function un(V,m,A,I){if(v){let y=!1;if(A.noCache?y=!0:(m?(!m.value||m.metadataFlags&(mn|ma)||m.expiresAt!=null&&m.expiresAt<Date.now())&&(y=!0):y=!0,Qn(!y,"cache-hit",s)),y){let O=Zh(V,m,A).then(P=>(P?.value&&P?.value.getRecord?.()&&Ue.default.error?.("Can not assign a record that is already a resource"),A&&(P?.version>(A.lastModified||0)&&(A.lastModified=P.version),A.lastRefreshed=Date.now()),P));if(A?.onlyIfCached||m?.value&&I?.allowStaleWhileRevalidate?.(m,V)){if(O.catch(P=>Ue.default.warn?.(P)),A?.onlyIfCached&&!I.doesExist())throw new Ir.ServerError("Entry is not cached",504);return}else return O}}else if(m?.value&&m.expiresAt!=null&&m.expiresAt<Date.now())return Ie.evict(m.key,m.value,m.version),m.value=null,{then(y){return y(m)}}}a(un,"ensureLoadedFromSource");function Gr(V){let m=V?.transaction;if(m){if(!m.lmdbDb)return m.lmdbDb=i,m;do{if(m.lmdbDb?.path===i.path)return m;let A=m.next;if(!A)return m=m.next=new wc,m.lmdbDb=i,m;m=A}while(!0)}else return new Am}a(Gr,"txnForContext");function lu(V,m,A){if(!V)return;let I=V.value||i.getEntry(V.key)?.value;if(typeof m=="object"){let O=Un,P=I;for(let N=0,L=m.length;N<L;N++){let k=m[N],D=O?.[k];P=D&&P?D(P,A,!0)?.value:P?.[k],O=D?.definition?.tableClass?.propertyResolvers}return P}let y=Un[m];return y?y(I,A):I[m]}a(lu,"getAttributeValue");function uu(V,m,A,I,y){let O=y?.length,P={transaction:I,lazy:O>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},N;function L(k,D){let B=k?.value;if(!B)return mc.SKIP;for(let $=0;$<O;$++)if(!N?.includes($)&&!y[$](B,k))return mc.SKIP;return D!==void 0&&(k.key=D),k}if(a(L,"processEntry"),O>0||!V.hasEntries){let k=V.map(D=>{if(N=null,typeof D=="object"&&D?.key!==void 0)return O>0?L(D):D;if(D==null)return mc.SKIP;for(let B=0;B<O;B++){let j=y[B].idFilter;if(j){if(!j(D))return mc.SKIP;N||(N=[]),N.push(B)}}return cu(D,A,P,!1,L)});return Array.isArray(V)&&(k=k.filter(D=>D!==mc.SKIP)),k.hasEntries=!0,k}return V}a(uu,"transformToEntries");function ia(V,m,A=server.replication?.getThisNodeId(l)){if(V<=m?.version){if(m?.version===V&&A!==void 0){let I=server.replication?.exportIdMapping(l),y=m.localTime,O=y&&l.get(y);if(O){let P,N,L=It(O);for(let k in I)I[k]===A&&(P=k),I[k]===L.nodeId&&(N=k);if(P>N)return 1;if(P===N)return 0}}return-1}return 1}a(ia,"precedesExistingVersion");async function Zh(V,m,A){let I=m?.metadataFlags,y=m?.version,O,P;if(!i.attemptLock(V,y,()=>{clearTimeout(P);let D=i.getEntry(V);!D||!D.value||D.metadataFlags&(mn|ma)?O(Zh(V,i.getEntry(V),A)):O(D)}))return new Promise(D=>{O=D,P=setTimeout(()=>{i.unlock(V,y)},uAe)});let N=m?.value,L={requestContext:A,replacingRecord:N,replacingEntry:m,replacingVersion:y,noCacheStore:!1,source:null,resourceCache:A?.resourceCache},k=A?.responseHeaders;return new Promise((D,B)=>{let $;HP(wt(L,async j=>{let oe=performance.now(),U,ue,ce;try{for(let _e of Ie.sources)if(_e.get&&(!_e.get.reliesOnPrototype||_e.prototype.get)){if(_e.available?.(m)===!1)continue;if(L.source=_e,U=await _e.get(V,L),U)break}ce=I&mn;let te=L.lastModified||ce&&y;ue=ce||te>y||!N,te||(te=(0,vh.getNextMonotonicTime)());let W=performance.now()-oe;if(sr(W,"cache-resolution",s,null,"success"),k&&ZE(k,"Server-Timing",`cache-resolve;dur=${W.toFixed(2)}`,!0),j.timestamp=te,h&&L.expiresAt==null&&(L.expiresAt=Date.now()+h),U){if(typeof U!="object")throw new Error("Only objects can be cached and stored in tables");if(U.status>0&&U.headers)if(U.status>=300)if(U.status===304)U=N,te=y;else throw new Ir.ServerError(U.body||"Error from source",U.status);else U=U.body;typeof U.toJSON=="function"&&(U=U.toJSON()),t&&U[t]!==V&&(U[t]=V)}$=!0,D({key:V,version:te,value:U})}catch(te){te.message+=` while resolving record ${V} for ${s}`,N&&((te.code==="ECONNRESET"||te.code==="ECONNREFUSED"||te.code==="EAI_AGAIN")&&!A?.mustRevalidate||A?.staleIfError&&(te.statusCode===500||te.statusCode===502||te.statusCode===503||te.statusCode===504))?(D({key:V,version:y,value:N}),Ue.default.trace?.(te.message,"(returned stale record)")):B(te);let W=performance.now()-oe;sr(W,"cache-resolution",s,null,"fail"),k&&ZE(k,"Server-Timing",`cache-resolve;dur=${W.toFixed(2)}`,!0),L.transaction.abort();return}if(A?.noCacheStore||L.noCacheStore){L.transaction.abort();return}Gr(L).addWrite({key:V,store:i,entry:m,nodeName:"source",commit:a((te,W)=>{if(W?.version!==y)return;let _e=ln(V,N,U);if(U){he.put?.(L,V,U),W&&(A.previousResidency=Ie.getResidencyRecord(W.residencyId));let Ee,Se=!1,tt,Ye=Ac(Ie.getResidency(U,A));if(Ye){if(!Ye.includes(server.hostname))if(Ee=U,Se=!0,Ie.getResidencyById)U=void 0;else{U=null;for(let mr in r)U||(U={}),U[mr]=Ee[mr]}tt=Rc(Ye)}Ue.default.trace?.(`Writing resolved record from source with id: ${V}, timestamp: ${new Date(te).toISOString()}`),T(V,U,W,te,Se?mn:0,g&&(ue||Se)||null,{user:L?.user,expiresAt:L.expiresAt,residencyId:tt},"put",!!ce,Ee)}else W&&(he.delete?.(L,V),Ue.default.trace?.(`Deleting resolved record from source with id: ${V}, timestamp: ${new Date(te).toISOString()}`),g||R?T(V,null,W,te,0,g&&ue||null,{user:L?.user},"delete",!!ce):Hc(i,W,y))},"commit")})}),()=>{i.unlock(V,y)},j=>{i.unlock(V,y),$&&Ue.default.error?.("Error committing cache update",j)})})}a(Zh,"getFromSource");function oa(V){if(!V||V.user?.role?.permission?.super_user)return!0;if(V.replicateTo)throw new Ir.ClientError("Can not specify replication parameters without super user permissions",403);if(V.replicatedConfirmation)throw new Ir.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}a(oa,"checkContextPermissions");function aa(V){let m=!1;if(V&&(V-dt>1&&(m=!0),dt=V),!(Nt===br&&!m)&&(br=Nt,(0,Ql.getWorkerIndex)()===(0,Ql.getWorkerCount)()-1))return hs&&clearTimeout(hs),Nt?new Promise(A=>{let I=new Date;I.setMonth(0),I.setDate(1),I.setHours(0),I.setMinutes(0),I.setSeconds(0);let y=Nt/(1+dt),O=m?Date.now():Math.ceil((Date.now()-I.getTime())/y)*y+I.getTime(),P=a(N=>{Ue.default.trace?.(`Scheduled next cleanup scan at ${new Date(N)}`),hs=setTimeout(()=>q=q.then(async()=>{if(P(Math.max(N+Nt,Date.now())),i.rootStore.status!=="open"){clearTimeout(hs);return}let L=50,k=new Array(L),D=0,B=Math.pow(dt,8)*(Xl.get(x.STORAGE_RECLAMATION_EVICTIONFACTOR)??1e5),$=S/Math.pow(Math.max(dt,1),4);Ue.default.info?.(`Starting cleanup scan for ${s}, evict threshold ${B}, adjusted eviction ${$}ms`);function j(oe,U,ue,ce){let fe=oe+$-Date.now();if(fe<0)return!0;if(dt){let te=i.lastSize;return ue&Fn&&yu(ce,W=>{W.size&&(te+=W.size)}),Ue.default.trace?.(`shouldEvict adjusted ${fe} ${te}, ${fe*(oe-U)/te} < ${B}`),fe*(oe-U)/te<B}return!1}a(j,"shouldEvict");try{let oe=0;for(let U of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let{key:ue,value:ce,version:fe,expiresAt:te,metadataFlags:W}=U,_e;ce===null&&!g&&fe+lAe<Date.now()?_e=Hc(i,U,fe):te!=null&&j(te,fe,W,ce)&&(_e=Ie.evict(ue,ce,fe),oe++),_e&&(await k[D],k[D]=_e.catch(Ee=>{Ue.default.error?.("Cleanup error",Ee)}),++D>=L&&(D=0)),await hc()}Ue.default.info?.(`Finished cleanup scan for ${s}, evicted ${oe} entries`)}catch(oe){Ue.default.warn?.(`Error in cleanup scan for ${s}:`,oe)}A(void 0),dt=0}),Math.min(N-Date.now(),2147483647)).unref()},"startNextTimer");P(O)}):void 0}a(aa,"scheduleCleanup");function Af(){Q=l?.addDeleteRemovalCallback(n,i,(V,m)=>{i.remove(V,m)})}a(Af,"addDeleteRemoval");function du(){(0,Ql.getWorkerIndex)()===0&&setInterval(async()=>{if(!au){au=!0;try{let V=se.name,m=r[V];if(!m)throw new Error(`expiresAt attribute ${se} must be indexed`);for(let A of m.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let I of m.getValues(A)){let y=i.getEntry(I);y?.value?y.value[V]<Date.now()&&Ie.evict(I,y.value,y.version):i.ifVersion(I,y?.version,()=>m.remove(A,I))}await hc()}}catch(V){Ue.default.error?.("Error in evicting old records",V)}finally{au=!1}}},cAe).unref()}a(du,"runRecordExpirationEviction");function Ac(V){if(V!=null){if(Array.isArray(V))return V;if(typeof V=="number"){if(V>=65536)throw new Error(`Shard id ${V} must be below 65536`);let m=server.shards?.get?.(V);if(m)return Ue.default.trace?.(`Shard ${V} mapped to ${m.map(A=>A.name).join(", ")}`),m.map(A=>A.name);throw new Error(`Shard ${V} is not defined`)}throw new Error(`Shard or residency list ${V} is not a valid type, must be a shard number or residency list of node hostnames`)}}a(Ac,"residencyFromFunction");function Rc(V){if(V){let m=V.join(","),A=f.get([Symbol.for("residency_by_set"),m]);return A||(f.put([Symbol.for("residency_by_set"),m],A=Math.floor(Math.random()*2147418112)+65535),f.put([Symbol.for("residency_by_id"),A],V),A)}}a(Rc,"getResidencyId")}function BP(e,t){let r=e.attr_object||(e.attr_object={}),n=r[t];if(n)return n;n=r[t]=Object.create(null);for(let s of e)n[s.attribute_name]=s[t];return n}function Qj(){}function pAe(e){rJ=e}function hA(e,t){let r=t?.type;if(e===null)return e;if(e===""&&r&&r!=="String"&&r!=="Any")return null;try{switch(r){case"Int":case"Long":if(e[0]==="$")return _A(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return _A(+e);case"Float":return e==="null"?null:_A(+e);case"BigInt":return e==="null"?null:BigInt(e);case"Boolean":return e==="true"?!0:e==="false"?!1:e;case"Date":if(isNaN(e)){if(e==="null")return null;hAe.test(e)||(e+="Z");let n=new Date(e);return _A(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,mA.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function _A(e){if(isNaN(e))throw new SyntaxError;return e}function Xj(e,t){if(e==null)return!0;if(!Array.isArray(t))return e===t||t.startsWith?.(e);if(Array.isArray(e)){let r=e.length;if(e[r-1]===null&&r--,t.length>=r){for(let n=0;n<r;n++)if(t[n]!==e[n])return!1;return!0}return!1}else if(t[0]===e)return!0}function HP(e,t,r){return e?.then?e.then(t,r):t(e)}function Zj(e){return e!=null}function Fs(e){try{return JSON.stringify(e)}catch{return e}}function mAe(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var mc,vh,eJ,tJ,Xl,Ir,Uh,xh,Ue,Zl,Ql,mA,pA,aAe,rJ,cAe,lAe,Wj,uAe,zj,dAe,mn,ma,fAe,jj,Jj,_Ae,axe,hAe,hc,qf=be(()=>{H();mc=require("lmdb"),vh=M(_n()),eJ=require("lodash"),tJ=M(xf());Ea();Rm();Xl=M(ae());AN();Ir=M(pe()),Uh=M(To()),xh=M(ri());De();Gf();Ue=M(Ni());Wb();Ic();Zl=require("ordered-binary"),Ql=M(rt());fo();mA=M(ie());wu();ki();xE();z_();pA=M(require("node:fs"));gs();UT();aAe=new Uint8Array(9);aAe[8]=192;cAe=6e4,lAe=864e5;Xl.initSync();Wj=Xl.get(x.STORAGE_PREFETCHWRITES),uAe=1e4,zj=1,dAe=2,mn=1,ma=8,fAe=Buffer.allocUnsafeSlow(8192),jj=1978,Jj=100,_Ae={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},axe=(0,mA.convertToMS)(Xl.get(x.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(EA,"makeTable");a(BP,"attributesAsObject");a(Qj,"noop");a(pAe,"setServerUtilities");hAe=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(hA,"coerceType");a(_A,"rejectNaN");a(Xj,"isDescendantId");hc=a(()=>new Promise(setImmediate),"rest");a(HP,"when");a(Zj,"exists");a(Fs,"stringify");a(mAe,"hasOtherProcesses")});var nt={};ve(nt,{database:()=>qu,database_envs:()=>ea,databases:()=>qe,dropDatabase:()=>Xb,dropTableMeta:()=>AAe,getDatabases:()=>Xe,getDefaultCompression:()=>CS,getTables:()=>EAe,onRemovedDB:()=>pp,onUpdatedTable:()=>Tl,readMetaDb:()=>Bh,resetDatabases:()=>Dd,table:()=>ft,tables:()=>Jn});function EAe(){return AA||Xe(),Jn||{}}function Xe(){if(AA)return qe;AA=!0,ff=new Map;let e=(0,Zt.getHdbBasePath)()&&(0,Lt.join)((0,Zt.getHdbBasePath)(),Nc),t=(0,Zt.get)(x.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,Zt.get)(x.STORAGE_PATH)||e&&((0,us.existsSync)(e)?e:(0,Lt.join)((0,Zt.getHdbBasePath)(),om)),!e)return;if((0,us.existsSync)(e))for(let n of(0,us.readdirSync)(e,{withFileTypes:!0})){let s=(0,Lt.basename)(n.name,".mdb");n.isFile()&&(0,Lt.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&Bh((0,Lt.join)(e,n.name),null,s)}if((0,us.existsSync)((0,df.getBaseSchemaPath)())){for(let n of(0,us.readdirSync)((0,df.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,Lt.join)((0,df.getBaseSchemaPath)(),n.name),i=(0,Lt.join)((0,df.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,us.readdirSync)(s,{withFileTypes:!0}))if(o.isFile()&&(0,Lt.extname)(o.name).toLowerCase()===".mdb"){let c=(0,Lt.join)(i,o.name);Bh((0,Lt.join)(s,o.name),(0,Lt.basename)(o.name,".mdb"),n.name,c,!0)}}}if(t)for(let n in t){let s=t[n],i=s.path;if((0,us.existsSync)(i))for(let c of(0,us.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,Lt.extname)(c.name).toLowerCase()===".mdb"&&Bh((0,Lt.join)(i,c.name),(0,Lt.basename)(c.name,".mdb"),n);let o=s.tables;if(o)for(let c in o){let l=o[c],u=(0,Lt.join)(l.path,(0,Lt.basename)(c+".mdb"));(0,us.existsSync)(u)&&Bh(u,c,n,null,!0)}}for(let n in qe){let s=ff.get(n);if(s){let i=qe[n];n.includes("delete")&&qt.trace(`defined tables ${Array.from(s.keys())}`);for(let o in i)s.has(o)||(qt.trace(`delete table class ${o}`),delete i[o])}else if(delete qe[n],n==="data"){for(let i in Jn)delete Jn[i];delete Jn[RA]}}let r=["hdb_temp","hdb_certificate","hdb_analytics","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if(qe.system)for(let n of r)qe.system[n]&&(qe.system[n].replicate=!1);return ff=null,qe}function Dd(){AA=!1;for(let[,e]of ea)e.needsDeletion=!0;Xe();for(let[e,t]of ea)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),ea.delete(e),delete qe[t.databaseName],kh.forEach(r=>r(t.databaseName)));return qe}function Bh(e,t,r=GP,n,s){let i=new kP.default(e,!1);try{let o=ea.get(e);o?o.needsDeletion=!1:(o=(0,_f.open)(i),ea.set(e,o));let c=new eu.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(gA.INTERNAL_DBIS_NAME,c)),u=o.auditStore;u||(n?(0,us.existsSync)(n)&&(i.path=n,u=(0,_f.open)(i),u.isLegacy=!0):u=dA(o));let f=oJ(r),d=f[RA],p=new Map;for(let{key:_,value:h}of l.getRange({start:!1})){let[S,g]=_.toString().split("/");g===""?g=h.name:g||(g=S,S=t,h.name||(h.name=g,h.indexed=!h.is_hash_attribute)),d?.add(S);let R=p.get(S);R||p.set(S,R={attributes:[]}),(g==null||h.is_hash_attribute)&&(R.primary=h),g!=null&&R.attributes.push(h),Object.defineProperty(h,"key",{value:_,configurable:!0})}for(let[_,h]of p){let{attributes:S,primary:g}=h;if(!g){for(let J of S)if(J.is_hash_attribute||J.isPrimaryKey){g=J;break}if(!g){qt.warn(`Unable to find a primary key attribute on table ${_}, with attributes: ${JSON.stringify(S)}`);continue}}let R=f[_],E={},T=[],b,v,F=typeof g.audit=="boolean"?g.audit:(0,Zt.get)(x.LOGGING_AUDITLOG),q=g.trackDeletes,Y=g.expiration,Z=g.eviction,se=g.sealed,Q=g.splitSegments,ne=g.replicate;if(R)E=R.indices,T=R.attributes,R.schemaVersion++;else{b=g.tableId,b?b>=(l.get(uf)||0)&&(l.putSync(uf,b+1),qt.info(`Updating next table id (it was out of sync) to ${b+1} for ${_}`)):(g.tableId=b=l.get(uf),b||(b=1),qt.debug("Table {table_name} missing an id, assigning {table_id}"),l.putSync(uf,b+1),l.putSync(g.key,g));let J=new eu.default(!g.is_hash_attribute,g.is_hash_attribute);if(J.compression=g.compression,J.compression){let me=(0,Zt.get)(x.STORAGE_COMPRESSION_THRESHOLD)||iJ;J.compression.threshold=me}v=Jm(o.openDB(g.key,J),o),o.databaseName=r,v.tableId=b}for(let J of S){J.attribute=J.name;try{if(!J.is_hash_attribute&&(J.indexed||J.attribute&&!J.name)){if(!E[J.name]){let ye=new eu.default(!J.is_hash_attribute,J.is_hash_attribute);E[J.name]=o.openDB(J.key,ye),E[J.name].indexNulls=J.indexNulls}let me=T.find(ye=>ye.name===J.name);me?T.splice(T.indexOf(me),1,J):T.push(J)}}catch(me){qt.error("Error trying to update attribute",J,T,E,me)}}if(!R){R=aJ(f,_,EA({primaryStore:v,auditStore:u,audit:F,sealed:se,splitSegments:Q,replicate:ne,expirationMS:Y&&Y*1e3,evictionMS:Z&&Z*1e3,trackDeletes:q,tableName:_,tableId:b,primaryKey:g.name,databasePath:s?r+"/"+_:r,databaseName:r,indices:E,attributes:S,schemaDefined:g.schemaDefined,dbisDB:l})),R.schemaVersion=1;for(let J of Hh)J(R)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function oJ(e){let t=qe[e];if(t||(e==="data"?t=qe[e]=Jn:e==="system"?Object.defineProperty(qe,"system",{value:t=Object.create(null),configurable:!0}):t=qe[e]=Object.create(null)),ff&&!ff.has(e)){let r=new Set;t[RA]=r,ff.set(e,r)}return t}function aJ(e,t,r){return e[t]=r,r}function qu({database:e,table:t}){e||(e=GP),Xe();let r=oJ(e),n=(0,Lt.join)((0,Zt.getHdbBasePath)(),Nc),s=(0,Zt.get)(x.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,Zt.get)(x.STORAGE_PATH)||((0,us.existsSync)(n)?n:(0,Lt.join)((0,Zt.getHdbBasePath)(),om));let o=(0,Lt.join)(n,(i?t:e)+".mdb"),c=ea.get(o);if(!c||c.status==="closed"){let l=new kP.default(o,!1);c=(0,_f.open)(l),ea.set(o,c)}return c.auditStore||(c.auditStore=dA(c)),c}async function Xb(e){if(!qe[e])throw new Error("Schema does not exist");let t=qe[e],r;for(let n in t)r=t[n].primaryStore.rootStore,ea.delete(r.path),r.status==="open"&&(await r.close(),await Fh.remove(r.path));if(r||(r=qu({database:e,table:null}),r.status==="open"&&(await r.close(),await Fh.remove(r.path))),e==="data"){for(let n in Jn)delete Jn[n];delete Jn[RA]}delete qe[e],kh.forEach(n=>n(e)),await IR(r)}function ft(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:o,audit:c,sealed:l,splitSegments:u,replicate:f,trackDeletes:d,schemaDefined:p,origin:_}=e;r||(r=GP);let h=qu({database:r,table:t}),S=qe[r];qt.trace(`Defining ${t} in ${r}`);let g=S?.[t];if(h.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let R,E,T;p==null&&(p=!0);let b=new eu.default(!1);for(let Q of o)Q.attribute&&!Q.name?(Q.name=Q.attribute,Q.indexed=!0):Q.attribute=Q.name,Q.expiresAt&&(Q.indexed=!0);let v,F;if(g){if(R=g.primaryKey,g.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);u==null&&(u=g.splitSegments),g.attributes.splice(0,g.attributes.length,...o)}else{let Q=h.auditStore;E=o.find(ye=>ye.isPrimaryKey)||{},R=E.name,E.is_hash_attribute=E.isPrimaryKey=!0,E.schemaDefined=p,E.compression=CS(),d&&(E.trackDeletes=!0),c=E.audit=typeof c=="boolean"?c:(0,Zt.get)(x.LOGGING_AUDITLOG),n&&(E.expiration=n),s&&(E.eviction=s),u??=!1,E.splitSegments=u,typeof l=="boolean"&&(E.sealed=l),typeof f=="boolean"&&(E.replicate=f),_&&(E.origins?E.origins.includes(_)||E.origins.push(_):E.origins=[_]),qt.trace(`${t} table loading, opening primary store`);let ne=new eu.default(!1,!0);ne.compression=E.compression;let J=t+"/";if(T=h.dbisDb=h.openDB(gA.INTERNAL_DBIS_NAME,b),se(),T.get(J))return F&&F(),Dd(),ft(e);let me=Jm(h.openDB(J,ne),h);h.databaseName=r,me.tableId=T.get(uf),qt.trace(`Assigning new table id ${me.tableId} for ${t}`),me.tableId||(me.tableId=1),T.put(uf,me.tableId+1),E.tableId=me.tableId,g=aJ(S,t,EA({primaryStore:me,auditStore:Q,audit:c,sealed:l,splitSegments:u,replicate:f,trackDeletes:d,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:R,tableName:t,tableId:me.tableId,databasePath:r,databaseName:r,indices:{},attributes:o,schemaDefined:p,dbisDB:T})),g.schemaVersion=1,v=!0,T.put(J,E)}let q=g.indices;T=T||(h.dbisDb=h.openDB(gA.INTERNAL_DBIS_NAME,b)),g.dbisDB=T;let Y=[];for(let{key:Q,value:ne}of T.getRange({start:!0})){let[J,me]=Q.toString().split("/");if(me===""&&(me=ne.name),me){if(J!==t)continue}else continue;let ye=o.find(he=>he.name===me),Pe=!ye?.indexed&&ne.indexed&&!ne.isPrimaryKey;if((!ye||Pe)&&(se(),v=!0,ye||T.remove(Q),Pe)){let he=g.indices[J];he&&Y.push(he)}}let Z=[];try{for(let Q of o||[]){if((Q.relationship||Q.computed)&&(v=!0,Q.relationship))continue;let ne=t+"/"+(Q.name||"");Object.defineProperty(Q,"key",{value:ne,configurable:!0});let J=T.get(ne);if(Q.isPrimaryKey){if(J=J||T.get(ne=t+"/")||{},c!==void 0&&c!==g.audit||l!==void 0&&l!==g.sealed||f!==void 0&&f!==g.replicate||(+n||void 0)!==(+J.expiration||void 0)||(+s||void 0)!==(+J.eviction||void 0)){let ye={...J};typeof c=="boolean"&&(c&&g.enableAuditing(c),ye.audit=c),n&&(ye.expiration=+n),s&&(ye.eviction=+s),l!==void 0&&(ye.sealed=l),f!==void 0&&(ye.replicate=f),v=!0,se(),T.put(ne,ye)}continue}J?.attribute&&!J.name&&(J.indexed=!0);let me=!J||J.type!==Q.type||J.indexed!==Q.indexed||J.nullable!==Q.nullable||J.version!==Q.version||JSON.stringify(J.properties)!==JSON.stringify(Q.properties)||JSON.stringify(J.elements)!==JSON.stringify(Q.elements);if(Q.indexed){let ye=new eu.default(!0,!1),Pe=h.openDB(ne,ye);(me||J.indexingPID&&J.indexingPID!==process.pid||J.restartNumber<Gh.workerData?.restartNumber)&&(v=!0,se(),J=T.get(ne),(me||J.indexingPID&&J.indexingPID!==process.pid||J.restartNumber<Gh.workerData?.restartNumber)&&(v=!0,Q.indexNulls===void 0&&(Q.indexNulls=!0),g.primaryStore.getStats().entryCount>0&&(Q.lastIndexedKey=J?.lastIndexedKey??void 0,Q.indexingPID=process.pid,Pe.isIndexing=!0,Object.defineProperty(Q,"dbi",{value:Pe}),Z.push(Q))),T.put(ne,Q)),J?.indexNulls&&Q.indexNulls===void 0&&(Q.indexNulls=!0),Pe.indexNulls=Q.indexNulls,q[Q.name]=Pe}else me&&(v=!0,se(),T.put(ne,Q))}}finally{F&&F()}if(v&&(g.schemaVersion++,g.updatedAttributes()),qt.trace(`${t} table loading, running index`),Z.length>0||Y.length>0?g.indexingOperation=TAe(g,Z,Y):v&&SA.signalSchemaChange(new TA.SchemaEventMsg(process.pid,"schema-change",g.databaseName,g.tableName)),g.origin=_,v)for(let Q of Hh)Q(g,_!=="cluster");return(n||s||i)&&g.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),qt.trace(`${t} table loaded`),g;function se(){F||h.transactionSync(()=>({then(Q){F=Q}}))}a(se,"startTxn")}async function TAe(e,t,r){try{qt.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await SA.signalSchemaChange(new TA.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o={},c=0,l=t.length;if(await new Promise(u=>setImmediate(u)),l>0){let u;for(let d of t)(0,_f.compareKeys)(d.lastIndexedKey,u)<0&&(u=d.lastIndexedKey),d.lastIndexedKey==null&&d.dbi.clearAsync();let f=0;for(let{key:d,value:p,version:_}of e.primaryStore.getRange({start:u,lazy:l<4,versions:!0,snapshot:!1}))if(p){if(f++,s=e.primaryStore.ifVersion(d,_,()=>{for(let h=0;h<l;h++){let S=t[h],g=S.name;try{let R=S.resolve,E=p&&(R?R(p):p[g]),T=(0,nJ.getIndexedValues)(E);if(T)for(let b=0,v=T.length;b<v;b++)S.dbi.put(T[b],d)}catch(R){o[g]||(o[g]=!0,qt.error(`Error indexing attribute ${g}`,R))}}}),s.then(()=>f--,h=>{f--,qt.error(h)}),Gh.workerData&&Gh.workerData.restartNumber!==sJ.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=d,e.dbisDB.put(h.key,h);if(i)return}f>gAe?await s:f>SAe&&await new Promise(h=>setImmediate(h))}for(let d of t)delete d.lastIndexedKey,delete d.indexingPID,d.dbi.isIndexing=!1,s=e.dbisDB.put(d.key,d)}await s,await SA.signalSchemaChange(new TA.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),qt.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){qt.error("Error in indexing",n)}}function AAe({table:e,database:t}){let r=qu({database:t,table:e}),n=[],s=r.dbisDb;for(let i of s.getKeys({start:e+"/",end:e+"0"}))n.push(s.remove(i));return Promise.all(n)}function Tl(e){return Hh.push(e),{remove(){let t=Hh.indexOf(e);t>-1&&Hh.splice(t,1)}}}function pp(e){return kh.push(e),{remove(){let t=kh.indexOf(e);t>-1&&kh.splice(t,1)}}}function CS(){let e=(0,Zt.get)(x.STORAGE_COMPRESSION),t=(0,Zt.get)(x.STORAGE_COMPRESSION_DICTIONARY),r=(0,Zt.get)(x.STORAGE_COMPRESSION_THRESHOLD)||iJ,n={startingOffset:32};return t&&(n.dictionary=Fh.readFileSync(t)),r&&(n.threshold=r),e&&n}var Zt,gA,_f,Lt,us,df,eu,kP,Fh,FP,nJ,SA,TA,Gh,qt,sJ,GP,RA,iJ,Jn,qe,uf,Hh,kh,AA,ea,ff,gAe,SAe,De=be(()=>{Zt=M(ae()),gA=M(xt()),_f=require("lmdb"),Lt=require("path"),us=require("fs"),df=M(gt());qf();eu=M(s_()),kP=M(i_());H();Fh=M(require("fs-extra")),FP=M(Ti()),nJ=M(_n()),SA=M(To()),TA=M(ri()),Gh=require("worker_threads"),qt=M(z()),sJ=M(rt());fo();wu();gs();GP="data",RA=Symbol("defined-tables"),iJ=((0,Zt.get)(x.STORAGE_PAGESIZE)||4096)-60;(0,Zt.initSync)();Jn=Object.create(null),qe=Object.create(null);(0,FP._assignPackageExport)("databases",qe);(0,FP._assignPackageExport)("tables",Jn);uf=Symbol.for("next-table-id"),Hh=[],kh=[],ea=new Map;a(EAe,"getTables");a(Xe,"getDatabases");a(Dd,"resetDatabases");a(Bh,"readMetaDb");a(oJ,"ensureDB");a(aJ,"setTable");a(qu,"database");a(Xb,"dropDatabase");a(ft,"table");gAe=1e3,SAe=10;a(TAe,"runIndexing");a(AAe,"dropTableMeta");a(Tl,"onUpdatedTable");a(pp,"onRemovedDB");a(CS,"getDefaultCompression")});var ie=w((gxe,AJ)=>{"use strict";var Ec=require("path"),fJ=require("fs-extra"),Mn=z(),cJ=require("fs-extra"),yA=require("os"),RAe=require("net"),yAe=require("recursive-iterator"),yr=(H(),C(G)),{PACKAGE_ROOT:bAe}=it(),OAe=iR(),lJ=require("papaparse"),bA=require("moment"),{inspect:NAe}=require("util"),uJ=require("is-number"),Exe=require("lodash"),wAe=require("minimist"),IAe=require("https"),CAe=require("http"),{hdb_errors:OA}=pe(),PAe=/^((\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d\.\d+([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z)))$/,_J=require("util").promisify(setTimeout),DAe=100,LAe=5,MAe="",vAe=4,dJ={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};AJ.exports={isEmpty:ds,isEmptyOrZeroLength:to,arrayHasEmptyValues:BAe,arrayHasEmptyOrZeroLengthValues:HAe,buildFolderPath:kAe,isBoolean:pJ,errorizeMessage:UAe,stripFileExtension:GAe,autoCast:qAe,autoCastJSON:hJ,autoCastJSONDeep:$P,removeDir:$Ae,compareVersions:VAe,isCompatibleDataVersion:KAe,escapeRawValue:YAe,unescapeValue:WAe,stringifyProps:zAe,timeoutPromise:JAe,isClusterOperation:XAe,getClusterUser:eRe,checkGlobalSchemaTable:ZAe,getHomeDir:EJ,getPropsFilePath:jAe,promisifyPapaParse:tRe,removeBOM:gJ,createEventPromise:rRe,checkProcessRunning:nRe,checkSchemaTableExist:sRe,checkSchemaExists:SJ,checkTableExists:TJ,getStartOfTomorrowInSeconds:iRe,getLimitKey:oRe,isObject:FAe,isNotEmptyAndHasValue:xAe,autoCasterIsNumberCheck:mJ,backtickASTSchemaItems:aRe,isPortTaken:QAe,createForkArgs:cRe,autoCastBoolean:lRe,async_set_timeout:_J,getTableHashAttribute:uRe,doesSchemaExist:dRe,doesTableExist:fRe,stringifyObj:_Re,ms_to_time:pRe,changeExtension:hRe,getEnvCliRootPath:VP,noBootFile:mRe,httpRequest:ERe,transformReq:gRe,convertToMS:SRe,PACKAGE_ROOT:bAe};function UAe(e){return e instanceof Error?e:new Error(e)}a(UAe,"errorizeMessage");function ds(e){return e==null}a(ds,"isEmpty");function xAe(e){return!ds(e)&&(e||e===0||e===""||pJ(e))}a(xAe,"isNotEmptyAndHasValue");function to(e){return ds(e)||e.length===0||e.size===0}a(to,"isEmptyOrZeroLength");function BAe(e){if(ds(e))return!0;for(let t=0;t<e.length;t++)if(ds(e[t]))return!0;return!1}a(BAe,"arrayHasEmptyValues");function HAe(e){if(to(e))return!0;for(let t=0;t<e.length;t++)if(to(e[t]))return!0;return!1}a(HAe,"arrayHasEmptyOrZeroLengthValues");function kAe(...e){try{return e.join(Ec.sep)}catch{console.error(e)}}a(kAe,"buildFolderPath");function pJ(e){return ds(e)?!1:e===!0||e===!1}a(pJ,"isBoolean");function FAe(e){return ds(e)?!1:typeof e=="object"}a(FAe,"isObject");function GAe(e){return to(e)?MAe:e.slice(0,-vAe)}a(GAe,"stripFileExtension");function qAe(e){return ds(e)||e===""||typeof e!="string"?e:dJ[e]!==void 0?dJ[e]:mJ(e)===!0?Number(e):PAe.test(e)?new Date(e):e}a(qAe,"autoCast");function hJ(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(hJ,"autoCastJSON");function $P(e){if(e&&typeof e=="object"){if(Array.isArray(e))for(let t=0,r=e.length;t<r;t++){let n=e[t],s=$P(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=$P(r);n!==r&&(e[t]=n)}return e}else return hJ(e)}a($P,"autoCastJSONDeep");function mJ(e){if(e.startsWith("0.")&&uJ(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&uJ(e))}a(mJ,"autoCasterIsNumberCheck");async function $Ae(e){if(to(e))throw new Error(`Directory path: ${e} does not exist`);try{await cJ.emptyDir(e),await cJ.remove(e)}catch(t){throw Mn.error(`Error removing files in ${e} -- ${t}`),t}}a($Ae,"removeDir");function VAe(e,t){if(to(e)){Mn.info("Invalid current version sent as parameter.");return}if(to(t)){Mn.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,o=s.replace(n,"").split("."),c=i.replace(n,"").split("."),l=Math.min(o.length,c.length);for(let u=0;u<l;u++)if(r=parseInt(o[u],10)-parseInt(c[u],10),r)return r;return o.length-c.length}a(VAe,"compareVersions");function KAe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(KAe,"isCompatibleDataVersion");function YAe(e){if(ds(e))return e;let t=String(e);return t==="."?yr.UNICODE_PERIOD:t===".."?yr.UNICODE_PERIOD+yr.UNICODE_PERIOD:t.replace(yr.FORWARD_SLASH_REGEX,yr.UNICODE_FORWARD_SLASH)}a(YAe,"escapeRawValue");function WAe(e){if(ds(e))return e;let t=String(e);return t===yr.UNICODE_PERIOD?".":t===yr.UNICODE_PERIOD+yr.UNICODE_PERIOD?"..":String(e).replace(yr.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(WAe,"unescapeValue");function zAe(e,t){if(ds(e))return Mn.info("Properties object is null"),"";let r="";return e.each(function(n,s){try{if(t&&t[n]){let i=t[n];for(let o of i)r+=";"+o+yA.EOL}!to(n)&&n[0]===";"?r+=" "+n+s+yA.EOL:to(n)||(r+=n+"="+s+yA.EOL)}catch{Mn.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(zAe,"stringifyProps");function EJ(){let e;try{e=yA.homedir()}catch{e=process.env.HOME}return e}a(EJ,"getHomeDir");function jAe(){let e=Ec.join(EJ(),yr.HDB_HOME_DIR_NAME,yr.BOOT_PROPS_FILE_NAME);return fJ.existsSync(e)||(e=Ec.join(__dirname,"../","hdb_boot_properties.file")),e}a(jAe,"getPropsFilePath");function JAe(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:a(function(){clearTimeout(r)},"cancel")}}a(JAe,"timeoutPromise");async function QAe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=RAe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(QAe,"isPortTaken");function XAe(e){try{return yr.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){Mn.error(`Error checking operation against cluster ops ${t}`)}return!1}a(XAe,"isClusterOperation");function ZAe(e,t){let r=(De(),C(nt)).getDatabases();if(!r[e])return OA.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return OA.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(ZAe,"checkGlobalSchemaTable");function eRe(e,t){if(ds(t)){Mn.warn("No CLUSTERING_USER defined, clustering disabled");return}if(ds(e)||to(e)){Mn.warn("No users to search.");return}let r;try{let n=e.get(t);n&&n.role.permission.cluster_user===!0&&n.active===!0&&(r=n)}catch(n){Mn.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){Mn.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(eRe,"getClusterUser");function tRe(){lJ.parsePromise=function(e,t,r){return new Promise(function(n,s){lJ.parse(e,{header:!0,transformHeader:gJ,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(tRe,"promisifyPapaParse");function gJ(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(gJ,"removeBOM");function rRe(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;Mn.info(`Got cluster status event response: ${NAe(s)}`);try{i.cancel()}catch{Mn.error("Error trying to cancel timeout.")}n(s)})})}a(rRe,"createEventPromise");async function nRe(e){let t=!0,r=0;do await _J(DAe*r++),(await OAe.findPs(e)).length>0&&(t=!1);while(t&&r<LAe);if(t)throw new Error(`process ${e} was not started`)}a(nRe,"checkProcessRunning");function sRe(e,t){let r=SJ(e);if(r)return r;let n=TJ(e,t);if(n)return n}a(sRe,"checkSchemaTableExist");function SJ(e){let{getDatabases:t}=(De(),C(nt));if(!t()[e])return OA.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(SJ,"checkSchemaExists");function TJ(e,t){let{getDatabases:r}=(De(),C(nt));if(!r()[e][t])return OA.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(TJ,"checkTableExists");function iRe(){let e=bA().utc().add(1,"d").startOf("d").unix(),t=bA().utc().unix();return e-t}a(iRe,"getStartOfTomorrowInSeconds");function oRe(){return bA().utc().format("DD-MM-YYYY")}a(oRe,"getLimitKey");function aRe(e){try{let t=new yAe(e);for(let{node:r}of t)r&&(r.columnid&&typeof r.columnid!="string"&&(r.columnid=r.columnid.toString()),r.columnid&&!r.columnid.startsWith("`")&&(r.columnid_orig=r.columnid,r.columnid=`\`${r.columnid}\``),r.tableid&&!r.tableid.startsWith("`")&&(r.tableid_orig=r.tableid,r.tableid=`\`${r.tableid}\``),r.databaseid&&!r.databaseid.startsWith("`")&&(r.databaseid_orig=r.databaseid,r.databaseid=`\`${r.databaseid}\``),r.as&&typeof r.as=="string"&&!r.as.startsWith("[")&&(r.as_orig=r.as,r.as=`\`${r.as}\``))}catch(t){Mn.error("Got an error back ticking items."),Mn.error(t)}}a(aRe,"backtickASTSchemaItems");function cRe(e){return[e]}a(cRe,"createForkArgs");function lRe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(lRe,"autoCastBoolean");function uRe(e,t){let{getDatabases:r}=(De(),C(nt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(uRe,"getTableHashAttribute");function dRe(e){let{getDatabases:t}=(De(),C(nt));return t()[e]!==void 0}a(dRe,"doesSchemaExist");function fRe(e,t){let{getDatabases:r}=(De(),C(nt));return r()[e]?.[t]!==void 0}a(fRe,"doesTableExist");function _Re(e){try{return JSON.stringify(e)}catch{return e}}a(_Re,"stringifyObj");function pRe(e){let t=bA.duration(e),r=t.seconds()>0?t.seconds()+"s":"",n=t.minutes()>0?t.minutes()+"m ":"",s=t.hours()>0?t.hours()+"h ":"",i=t.days()>0?t.days()+"d ":"";return(t.years()>0?t.years()+"y ":"")+i+s+n+r}a(pRe,"ms_to_time");function hRe(e,t){let r=Ec.basename(e,Ec.extname(e));return Ec.join(Ec.dirname(e),r+t)}a(hRe,"changeExtension");function VP(){if(process.env[yr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[yr.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=wAe(process.argv);if(e[yr.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[yr.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(VP,"getEnvCliRootPath");var qP;function mRe(){if(qP)return qP;let e=VP();if(VP()&&fJ.pathExistsSync(Ec.join(e,yr.HDB_CONFIG_FILE)))return qP=!0,!0}a(mRe,"noBootFile");function ERe(e,t){let r;return e.protocol==="http:"?r=CAe:r=IAe,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8"),o.body="",o.on("data",c=>{o.body+=c}),o.on("end",()=>{n(o)})});i.on("error",o=>{s(o)}),i.write(t instanceof Buffer?t:JSON.stringify(t)),i.end()})}a(ERe,"httpRequest");function gRe(e){if(!e.schema&&!e.database){e.schema=yr.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(gRe,"transformReq");function SRe(e){let t=0;if(typeof e=="number"&&(t=e),typeof e=="string")switch(t=parseFloat(e),e.slice(-1)){case"M":t*=86400*30;break;case"D":case"d":t*=86400;break;case"H":case"h":t*=3600;break;case"m":t*=60;break}return t*1e3}a(SRe,"convertToMS")});var ae=w((NJ,wJ)=>{"use strict";var KP=require("fs-extra"),tu=require("path"),RJ=require("os"),TRe=require("properties-reader"),$h=z(),qh=ie(),Me=(H(),C(G)),NA=yt(),ARe="Error initializing environment manager",wA="BOOT_PROPS_FILE_PATH",yJ=!1,RRe={[Me.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},ta={};Object.assign(NJ,wJ.exports={BOOT_PROPS_FILE_PATH:wA,getHdbBasePath:yRe,setHdbBasePath:bRe,get:bJ,initSync:NRe,setProperty:Ke,initTestEnvironment:IRe,setCloneVar:wRe});function yRe(){return ta[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(yRe,"getHdbBasePath");function bRe(e){ta[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(bRe,"setHdbBasePath");function bJ(e){let t=NA.getConfigValue(e);return t===void 0?ta[e]:t}a(bJ,"get");function Ke(e,t){RRe[e]&&(ta[e]=t),NA.updateConfigObject(e,t)}a(Ke,"setProperty");function ORe(){let e;try{e=qh.getPropsFilePath(),KP.accessSync(e,KP.constants.F_OK|KP.constants.R_OK),yJ=!0;let t=TRe(e);return ta[Me.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(Me.HDB_SETTINGS_NAMES.INSTALL_USER),ta[Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),ta[wA]=e,!0}catch{return $h.trace(`Environment manager found no properties file at ${e}`),!1}}a(ORe,"doesPropFileExist");function NRe(e=!1){try{((yJ||ORe()||qh.noBootFile())&&!OJ||e)&&(NA.initConfig(e),ta[Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=NA.getConfigValue(Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){$h.error(ARe),$h.error(t),console.error(t),process.exit(1)}}a(NRe,"initSync");var OJ=!1;function wRe(e){OJ=e}a(wRe,"setCloneVar");function IRe(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:n,https_enabled:s,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,l=tu.join(__dirname,"../../","unitTests");ta[wA]=tu.join(l,"hdb_boot_properties.file"),Ke(Me.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,tu.join(l,"settings.test")),Ke(Me.HDB_SETTINGS_NAMES.INSTALL_USER,RJ.userInfo()?RJ.userInfo().username:void 0),Ke(Me.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Ke(Me.HDB_SETTINGS_NAMES.LOG_PATH_KEY,tu.join(l,"envDir","log")),Ke(Me.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Ke(Me.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Ke(Me.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Ke(Me.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,tu.join(l,"envDir")),Ke(Me.CONFIG_PARAMS.STORAGE_PATH,tu.join(l,"envDir")),s&&(Ke(Me.CONFIG_PARAMS.HTTP_SECUREPORT,bJ(Me.CONFIG_PARAMS.HTTP_PORT)),Ke(Me.CONFIG_PARAMS.HTTP_PORT,null)),Ke(Me.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Ke(Me.CONFIG_PARAMS.HTTP_PORT,9926),Ke(Me.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Ke(Me.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),Ke(Me.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,qh.isEmpty(i)?!1:i),Ke(Me.CONFIG_PARAMS.HTTP_CORS,qh.isEmpty(i)?!1:i),Ke(Me.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Ke(Me.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Ke(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Ke(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Ke(Me.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,tu.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Ke(Me.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,qh.isEmpty(c)?!1:c),o&&(Ke("CORS_ACCESSLIST",o),Ke(Me.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Ke(Me.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Ke(Me.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Ke(Me.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Ke(Me.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Ke(Me.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Ke(Me.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${wA}. Please check your boot props and settings files`;$h.fatal(r),$h.error(t)}}a(IRe,"initTestEnvironment")});var LJ=w((Axe,DJ)=>{"use strict";var CA=ae();CA.initSync();var IA=(H(),C(G)),{httpRequest:CRe}=ie(),PJ=require("path"),IJ=require("fs-extra"),PRe=require("yaml"),{packageDirectory:DRe}=(Kw(),C(Vw)),{encode:LRe}=require("cbor-x"),MRe=["describe_table","describe_all","describe_database","list_users","list_roles","drop_role","add_user","alter_user","drop_user","restart_service","restart","create_database","drop_database","create_table","drop_table","create_attribute","drop_attribute","search_by_id","insert","update","upsert","delete","search_by_value","csv_file_load","csv_url_load","cluster_get_routes","cluster_network","cluster_status","remove_node","add_component","deploy_component","package_component","drop_component","get_components","get_component_file","set_component_file","registration_info","get_fingerprint","set_license","get_job","search_jobs_by_start_date","read_log","read_transaction_log","read_audit_log","delete_transaction_logs_before","purge_stream","delete_records_before","install_node_modules","set_configuration","get_configuration","create_authentication_tokens","refresh_operation_token","system_information","sql","create_csr","sign_certificate","list_certificates","add_certificate","remove_certificate","add_ssh_key","update_ssh_key","delete_ssh_key","list_ssh_keys","set_ssh_known_hosts","get_ssh_known_hosts"],CJ={deploy:"deploy_component",package:"package_component"};DJ.exports={cliOperations:xRe,buildRequest:URe};var vRe={deploy_component:a(async e=>{if(e.package)return;let t=process.cwd();e.payload=await DRe(t,{skip_node_modules:!0,...e}),e.cborEncode=!0,e.project||(e.project=PJ.basename(t))},"deploy_component")};function URe(){let e={};for(let t of process.argv.slice(2))if(MRe.includes(t))e.operation=t;else if(CJ.hasOwnProperty(t))e.operation=CJ[t];else if(t.includes("=")){let[r,...n]=t.split("=");n=n.join("=");try{n=JSON.parse(n)}catch{}e[r]=n}return e}a(URe,"buildRequest");async function xRe(e){e.target||(e.target=process.env.CLI_TARGET);let t;if(e.target){try{t=new URL(e.target)}catch(r){try{t=new URL(`https://${e.target}:9925`)}catch{throw r}}t={protocol:t.protocol,hostname:t.hostname,port:t.port,username:e.username||t.username||process.env.CLI_TARGET_USERNAME,password:e.password||t.password||process.env.CLI_TARGET_PASSWORD,rejectUnauthorized:e.rejectUnauthorized}}else IJ.existsSync(PJ.join(CA.get(IA.CONFIG_PARAMS.ROOTPATH),IA.HDB_PID_FILE))||(console.error("HarperDB must be running to perform this operation"),process.exit()),IJ.existsSync(CA.get(IA.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET))||(console.error("No domain socket found, unable to perform this operation"),process.exit());await vRe[e.operation]?.(e);try{let r=t??{protocol:"http:",socketPath:CA.get(IA.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)};r.method="POST",r.headers={"Content-Type":"application/json"},t?.username&&(r.headers.Authorization=`Basic ${Buffer.from(`${t.username}:${t.password}`).toString("base64")}`),e.cborEncode&&(r.headers["Content-Type"]="application/cbor",e=LRe(e));let n=await CRe(r,e),s;try{s=JSON.parse(n.body)}catch{s={status:n.statusCode+" "+(n.statusMessage||"Unknown"),body:n.body}}e.json?console.log(JSON.stringify(s,null,2)):console.log(PRe.stringify(s).trim())}catch(r){let n="Error: ";if(r?.response?.data?.error)n+=r.response.data.error;else if(r?.response?.data)n+=r?.response?.data;else return console.error(r);console.error(n)}}a(xRe,"cliOperations")});var UJ=w((yxe,vJ)=>{"use strict";var MJ=require("semver/functions/major"),{packageJson:BRe}=it(),YP=process.versions&&process.versions.node?process.versions.node:void 0;vJ.exports=HRe;function HRe(){let e=BRe.engines["minimum-node"];if(YP&&MJ(YP)<MJ(e))return{error:`The minimum version of Node.js HarperDB supports is: ${e}, the currently installed Node.js version is: ${YP}. Please install a version of Node.js that is withing the defined range.`}}a(HRe,"checkNodeVersion")});var ZP=w((Nxe,r2)=>{"use strict";var xJ=require("os"),PA=require("https"),BJ=require("http"),$t=require("fs-extra"),HJ=require("yaml"),{pipeline:kJ}=require("stream/promises"),{createWriteStream:DA,ensureDir:Vh,writeFileSync:FJ}=require("fs-extra"),{join:$s}=require("path"),VJ=require("lodash"),kRe=require("minimist"),ra=require("path"),FRe=require("node:crypto"),GRe=require("properties-reader"),qs=ae(),qRe=Po(),JP=z(),LA=yt(),{restart:$Re}=za(),MA=ie(),VRe=ua(),KRe=As(),{main:vA,launch:YRe}=Qd(),{install:KJ,updateConfigEnv:WRe,setIgnoreExisting:xA}=PT(),YJ=SC(),an=(H(),C(G)),{packageJson:zRe}=it(),jRe=mh(),{sendOperationToNode:jP}=(Xn(),C(wo)),{updateConfigCert:JRe}=Zn(),{restartWorkers:QRe}=rt(),{databases:XRe}=(De(),C(nt)),{SYSTEM_TABLE_NAMES:WP,SYSTEM_SCHEMA_NAME:Oxe,CONFIG_PARAMS:Kh,OPERATIONS_ENUM:ps}=an,ZRe=1e4,eye="clone-node-config.yaml",WJ=[WP.ROLE_TABLE_NAME,WP.USER_TABLE_NAME,WP.NODE_TABLE_NAME],tye={clustering_nodename:!0,clustering_leafserver_streams_path:!0,clustering_tls_certificate:!0,clustering_tls_privatekey:!0,clustering_tls_certificateauthority:!0,logging_file:!0,logging_root:!0,logging_rotation_path:!0,operationsapi_network_domainsocket:!0,operationsapi_tls_certificate:!0,operationsapi_tls_privatekey:!0,operationsapi_tls_certificateauthority:!0,rootpath:!0,storage_path:!0,storage_audit_path:!0,databases:!0,mqtt_network_mtls_certificateauthority:!0,componentsroot:!0,tls_certificate:!0,tls_privatekey:!0,tls_certificateauthority:!0,replication_hostname:!0,replication_url:!0,cloned:!0},Fr={HDB_LEADER_USERNAME:"HDB_LEADER_USERNAME",HDB_LEADER_PASSWORD:"HDB_LEADER_PASSWORD",HDB_LEADER_URL:"HDB_LEADER_URL",REPLICATION_HOSTNAME:"REPLICATION_HOSTNAME",HDB_CLONE_OVERTOP:"HDB_CLONE_OVERTOP",CLONE_KEYS:"CLONE_KEYS",CLONE_USING_WS:"CLONE_USING_WS",NO_START:"NO_START"},sa=kRe(process.argv),pf=sa[Fr.HDB_LEADER_USERNAME]??process.env[Fr.HDB_LEADER_USERNAME],hf=sa[Fr.HDB_LEADER_PASSWORD]??process.env[Fr.HDB_LEADER_PASSWORD],nu=sa[Fr.HDB_LEADER_URL]??process.env[Fr.HDB_LEADER_URL],na=sa[Fr.REPLICATION_HOSTNAME]??process.env[Fr.REPLICATION_HOSTNAME],zJ,jJ;na&&([zJ,jJ]=na.split(":"));var QP=(sa[Fr.HDB_CLONE_OVERTOP]??process.env[Fr.HDB_CLONE_OVERTOP])==="true",JJ=sa[Kh.CLONED.toUpperCase()]??process.env[Kh.CLONED.toUpperCase()],rye=sa[Fr.CLONE_KEYS]!=="false"&&process.env[Fr.CLONE_KEYS]!=="false",QJ=(sa[Fr.CLONE_USING_WS]??process.env[Fr.CLONE_USING_WS])==="true",XJ=(sa[Fr.NO_START]??process.env[Fr.NO_START])==="true",_s,gc={},GJ,qJ,ru={},on,Mt,Gs,ro,su=!1,XP=!1,fs,mf;r2.exports=a(async function(t=!1,r=!1){if(console.info(`Starting clone node from leader node: ${nu}`),delete process.env.HDB_LEADER_URL,Mt=MA.getEnvCliRootPath(),!Mt)try{let i=$s(xJ.homedir(),an.HDB_HOME_DIR_NAME,an.BOOT_PROPS_FILE_NAME);if(await $t.pathExists(i)){let o=GRe(i);Mt=ra.parse(o.get(an.BOOT_PROP_PARAMS.SETTINGS_PATH_KEY)).dir}}catch{throw new Error("There was an error setting the clone default root path. Please set ROOTPATH using an environment or CLI variable.")}Mt?await $t.pathExists(Mt)?console.log(`Existing HarperDB install found at ${Mt}. Clone node will only clone items that do not already exist on clone.`):(console.log(`No HarperDB install found at ${Mt} starting fresh clone`),su=!0):(console.log("No HarperDB install found, starting fresh clone"),su=!0),Mt||(Mt=$s(xJ.homedir(),an.HDB_ROOT_DIR_NAME),console.log("Using default root path",Mt));let n;try{n=$s(Mt,eye),_s=HJ.parseDocument(await $t.readFile(n,"utf8"),{simpleKeys:!0}).toJSON(),console.log("Clone config file found")}catch{}let s=$s(Mt,an.HDB_CONFIG_FILE);if(await $t.pathExists(s))try{GJ=HJ.parseDocument(await $t.readFile(s,"utf8"),{simpleKeys:!0}).toJSON(),gc=LA.flattenConfig(GJ)}catch(i){console.error("Error reading existing harperdb-config.yaml on clone",i)}if(na){let i=new URL(nu);mf=`${i.protocol==="https:"?"wss://":"ws://"}${i.hostname}:${jJ||9933}`}if(QJ){await nye();return}if(gc?.cloned&&JJ!=="false")return console.log("Instance marked as cloned, clone will not run"),qs.setCloneVar(!1),qs.initSync(),vA();on=await UA({operation:ps.DESCRIBE_ALL}),await e2(),qs.setCloneVar(!1),qs.setHdbBasePath(Mt),$t.ensureDir(qs.get(an.CONFIG_PARAMS.LOGGING_ROOT)),JP.initLogSettings(),await iye(),XP||await oye(),await lye(t,r),na&&(await dye(),await ZJ()),console.info(`
134
+ Successfully cloned node: `+nu),(t||XJ)&&process.exit()},"cloneNode");async function nye(){if(gc?.cloned&&JJ!=="false")return console.log("Instance marked as cloned, clone will not run"),qs.setCloneVar(!1),qs.initSync(),vA();console.log("Cloning using WebSockets");let e=Sc("system"),t=$s(e,"system.mdb"),r=$t.existsSync(t);su||!r||QP?(console.info("Clone node installing HarperDB"),process.env.TC_AGREEMENT="yes",process.env.ROOTPATH=Mt,process.env.HDB_ADMIN_USERNAME="clone-temp-admin",process.env.HDB_ADMIN_PASSWORD=FRe.randomBytes(10).toString("base64").slice(0,10),xA(!0),await KJ()):(qs.setCloneVar(!1),qs.initSync()),await vA(),await e2(!0),await JRe(),r||await XRe.system.hdb_user.delete({username:"clone-temp-admin"}),await QRe(),await sye(),console.log("Adding node to the cluster");let s=await Sd()({operation:ps.ADD_NODE,url:mf});console.log("Add node response: ",s),await ZJ(),console.log(`Successfully cloned node: ${nu} using WebSockets`),LA.updateConfigValue(Kh.CLONED,!0),XJ&&process.exit()}a(nye,"cloneUsingWS");async function sye(){let e=a(i=>{let o=0;for(let c in i){let l=i[c];typeof l=="object"&&l.last_updated_record>o&&(o=l.last_updated_record)}return o},"findMostRecentTimestamp");console.log("Getting last updated record timestamp for all database");let t={},r=await UA({operation:"describe_database",database:"system"});t.system=e(r);let n=await UA({operation:"describe_all"});for(let i in n)typeof n[i]=="object"&&(t[i]=e(n[i]));let s=$s(Mt,"tmp","lastUpdated.json");console.log("Writing last updated database timestamps to:",s),await $t.outputJson(s,t)}a(sye,"getLastUpdatedRecord");async function UA(e){return QJ?jP({url:mf},e,{rejectUnauthorized:!1}):JSON.parse((await fye(e)).body)}a(UA,"leaderReq");async function ZJ(){try{if(rye!==!1){console.log("Cloning JWT keys");let e=ra.join(Mt,an.LICENSE_KEY_DIR_NAME),t=await jP({url:mf},{operation:ps.GET_KEY,name:".jwtPublic"},{rejectUnauthorized:!1});FJ(ra.join(e,an.JWT_ENUM.JWT_PUBLIC_KEY_NAME),t.message);let r=await jP({url:mf},{operation:ps.GET_KEY,name:".jwtPrivate"},{rejectUnauthorized:!1});FJ(ra.join(e,an.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r.message)}}catch(e){console.error("Error cloning JWT keys",e)}}a(ZJ,"cloneKeys");async function e2(e=!1){console.info("Cloning configuration"),qJ=await UA({operation:ps.GET_CONFIGURATION}),ru=LA.flattenConfig(qJ);let t=_s?.componentConfig?.exclude,r={rootpath:Mt};na&&(r.replication_hostname=zJ);for(let i in ru)if(!(ru[i]!==null&&typeof ru[i]=="object"&&!(ru[i]instanceof Array)||tye[i])){if(i.includes("_package")||i.includes("_port")){if(ru[i]?.includes?.("hdb/components"))continue;if(t){let o=!1;for(let c of t)if(i.includes(c.name)){o=!0;break}if(o)continue}}gc[i]||(r[i]=ru[i])}for(let i in gc)i!=="databases"&&typeof gc[i]=="object"&&!(gc[i]instanceof Array)||(r[i]=gc[i]);let n={};if(_s?.databaseConfig?.excludeDatabases&&_s.databaseConfig.excludeDatabases.forEach(i=>{n[i.database]=!0}),_s?.clusteringConfig?.excludeDatabases&&_s.clusteringConfig.excludeDatabases.forEach(i=>{n[i.database]=!0}),Object.keys(n).length>0){r.replication_databases=[],n.system||r.replication_databases.push("system");for(let i in on)n[i]||r.replication_databases.push(i)}let s=VRe(Object.keys(an.CONFIG_PARAM_MAP),!0);Object.assign(r,s),e||(r.cloned=!0),LA.createConfigFile(r,!0)}a(e2,"cloneConfig");async function iye(){process.env.HDB_FETCH==="true"?(await cye(),process.env.NODE_TLS_REJECT_UNAUTHORIZED&&delete process.env.NODE_TLS_REJECT_UNAUTHORIZED):await aye()}a(iye,"cloneDatabases");async function oye(){if(console.info("Clone node installing HarperDB."),process.env.TC_AGREEMENT="yes",process.env.ROOTPATH=Mt,!pf)throw new Error("HDB_LEADER_USERNAME is undefined.");if(process.env.HDB_ADMIN_USERNAME=pf,!hf)throw new Error("HDB_LEADER_PASSWORD is undefined.");process.env.HDB_ADMIN_PASSWORD=hf,process.env.OPERATIONSAPI_NETWORK_PORT=qs.get(Kh.OPERATIONSAPI_NETWORK_PORT),WRe(ra.join(Mt,an.HDB_CONFIG_FILE)),xA(!0),await KJ()}a(oye,"installHDB");function Sc(e){return qs.get(an.CONFIG_PARAMS.DATABASES)?.[e]?.path||qs.get(Kh.STORAGE_PATH)||ra.join(Mt,an.DATABASES_DIR_NAME)}a(Sc,"getDBPath");async function aye(){let e=Sc("system"),t=$s(e,"system.mdb");if(await Vh(e),su||!await $t.exists(t)||QP){if(!na){console.info("Cloning system database"),await Vh(e);let r=DA(t,{overwrite:!0}),n={operation:ps.GET_BACKUP,database:"system",tables:WJ},s=await $J(n,r),i=new Date(s.date);(!fs||i<fs)&&(fs=i),await $t.utimes(t,Date.now(),i)}su||(await YJ(Mt),await t2(),xA(!0))}else XP=!0,console.log("Not cloning system database due to it already existing on clone");Gs=_s?.databaseConfig?.excludeDatabases,Gs=Gs?Gs.reduce((r,n)=>({...r,[n.database]:!0}),{}):{};for(let r in on)await $t.exists(ra.join(Sc(r),r+".mdb"))&&(console.log(`Not cloning database ${r} due to it already existing on clone`),Gs[r]=!0);ro=_s?.databaseConfig?.excludeTables,ro=ro?ro.reduce((r,n)=>({...r,[n.database==null?null:n.database+n.table]:!0}),{}):{};for(let r in on){if(Gs[r]){on[r]="excluded";continue}if(VJ.isEmpty(on[r]))continue;let n=[],s=!1;for(let d in on[r])ro[r+d]?(s=!0,on[r][d]="excluded"):n.push(on[r][d]);if(n.length===0)continue;if(na){JP.debug("Setting up tables for #{db}");let d=(De(),C(nt)).table;for(let p of n){for(let _ of p.attributes)(_.is_hash_attribute||_.is_primary_key)&&(_.isPrimaryKey=!0);d({database:r,table:p.name,attributes:p.attributes})}continue}n=n.map(d=>d.name);let i;s?(console.info(`Cloning database: ${r} tables: ${n}`),i={operation:ps.GET_BACKUP,database:r,tables:n}):(console.info(`Cloning database: ${r}`),i={operation:ps.GET_BACKUP,database:r});let o=Sc(r);await Vh(o);let c=$s(o,r+".mdb"),l=DA(c,{overwrite:!0}),u=await $J(i,l),f=new Date(u.date);(!fs||f<fs)&&(fs=f),await $t.utimes(c,Date.now(),f)}}a(aye,"cloneTablesHttp");async function cye(){let e=Sc("system"),t=$s(e,"system.mdb");if(su||!await $t.exists(t)||QP){if(!na){console.info("Cloning system database using fetch");let r={operation:ps.GET_BACKUP,database:"system",tables:WJ},n=await zP(r,!0),s=Sc("system");await Vh(s);let i=$s(s,"system.mdb");await kJ(n.body,DA(i,{overwrite:!0}));let o=new Date(n.headers.get("date"));(!fs||o<fs)&&(fs=o),await $t.utimes(i,Date.now(),new Date(n.headers.get("date")))}su||(await YJ(Mt),await t2(),xA(!0))}else XP=!0,console.log("Not cloning system database due to it already existing on clone");if(na){JP.info("Replication hostname set, not using backup to clone databases, replication will clone");return}Gs=_s?.databaseConfig?.excludeDatabases,Gs=Gs?Gs.reduce((r,n)=>({...r,[n.database]:!0}),{}):{};for(let r in on)await $t.exists(ra.join(Sc(r),r+".mdb"))&&(console.log(`Not cloning database ${r} due to it already existing on clone`),Gs[r]=!0);ro=_s?.databaseConfig?.excludeTables,ro=ro?ro.reduce((r,n)=>({...r,[n.database==null?null:n.database+n.table]:!0}),{}):{};for(let r in on){if(Gs[r]){on[r]="excluded";continue}if(VJ.isEmpty(on[r]))continue;let n=[],s=!1;for(let f in on[r])ro[r+f]?(s=!0,on[r][f]="excluded"):n.push(f);if(n.length===0)return;let i;s?(console.info(`Cloning database: ${r} tables: ${n}`),i=await zP({operation:ps.GET_BACKUP,database:r,tables:n},!0)):(console.info(`Cloning database: ${r}`),i=await zP({operation:ps.GET_BACKUP,database:r},!0));let o=Sc(r);await Vh(o);let c=new Date(i.headers.get("date")),l=$s(o,`${c.getTime()}-${r}.mdb`);await kJ(i.body,DA(l,{overwrite:!0}));let u=$s(o,r+".mdb");await $t.rename(l,u),(!fs||c<fs)&&(fs=c),await $t.utimes(u,Date.now(),c)}}a(cye,"cloneTablesFetch");async function zP(e,t=!1){let r=_s?.httpsRejectUnauthorized??!1,n=new PA.Agent({rejectUnauthorized:r});r||(process.env.NODE_TLS_REJECT_UNAUTHORIZED="0");let i={Authorization:"Basic "+Buffer.from(pf+":"+hf).toString("base64"),"Content-Type":"application/json"};t&&(i["Accept-Encoding"]="gzip");let o=await fetch(nu,{method:"POST",headers:i,body:JSON.stringify(e),agent:n,compress:!0});if(o.ok)return o;throw console.error(`HTTP Error Response: ${o.status} ${o.statusText}`),new Error(await o.text())}a(zP,"leaderHttpReqFetch");async function lye(e,t=!1){let r=await qRe.getHDBProcessInfo();r.clustering.length===0||r.core.length===0?e?await YRe(!1):(t&&await uye(),await vA()):(console.info(await $Re({operation:ps.RESTART})),await MA.async_set_timeout(ZRe)),e&&await MA.async_set_timeout(2e3)}a(lye,"startHDB");async function uye(){let e=process.argv[3];e&&e[0]!=="-"&&(await $t.exists(e)||console.error(`The folder ${e} does not exist`),$t.statSync(e).isDirectory()||console.error(`The path ${e} is not a folder`),e=await $t.realpath(e),await $t.exists(ra.join(e,an.HDB_CONFIG_FILE))?process.env.ROOTPATH=e:process.env.RUN_HDB_APP=e)}a(uye,"setAppPath");async function dye(){console.info("Setting up replication"),await KRe.setSchemaDataToGlobalAsync();let t=await Sd()({operation:ps.ADD_NODE,verify_tls:!1,url:mf,start_time:fs,authorization:{username:pf,password:hf}},!0);console.log("Add node response: ",t)}a(dye,"setupReplication");async function fye(e){let t=new PA.Agent({rejectUnauthorized:_s?.httpsRejectUnauthorized??!1}),n={Authorization:"Basic "+Buffer.from(pf+":"+hf).toString("base64"),"Content-Type":"application/json"},s=new URL(nu),i={protocol:s.protocol,host:s.hostname,method:"POST",headers:n};return s.protocol==="https:"&&(i.agent=t),s.port&&(i.port=s.port),await MA.httpRequest(i,e)}a(fye,"leaderHttpReq");async function $J(e,t){let r=new PA.Agent({rejectUnauthorized:_s?.httpsRejectUnauthorized??!1}),s={Authorization:"Basic "+Buffer.from(pf+":"+hf).toString("base64"),"Content-Type":"application/json"},i=new URL(nu),o={protocol:i.protocol,host:i.hostname,method:"POST",headers:s};return i.protocol==="https:"&&(o.agent=r,BJ=PA),i.port&&(o.port=i.port),new Promise((c,l)=>{let u=BJ.request(o,f=>{f.statusCode!==200&&l("Request to leader node failed with code: "+f.statusCode),f.pipe(t),f.on("end",()=>{t.close(),c(f.headers)})});u.on("error",f=>{l(f)}),u.write(JSON.stringify(e)),u.end()})}a($J,"leaderHttpStream");async function t2(){let e=zRe.version;if(e)await jRe.insertHdbInstallInfo(e);else throw new Error("The version is missing/removed from HarperDB package.json")}a(t2,"insertHdbVersionInfo")});var s2=w((Ixe,n2)=>{var _ye=PT(),pye=z();n2.exports=hye;async function hye(){try{await _ye.install()}catch(e){console.error("There was an error during the install."),console.error(e),pye.error(e),process.exit(1)}}a(hye,"install")});var a2=w((Pxe,o2)=>{"use strict";var mye=mS(),Eye=z(),i2="Registration failed.";async function gye(){let e;try{e=await mye.register()}catch(t){return Eye.error(`Registration error ${t}`),i2}return e||i2}a(gye,"register");o2.exports={register:gye}});var d2=w((Lxe,u2)=>{"use strict";var Sye=z(),Tye=(H(),C(G)),Aye=require("util"),Rye=require("child_process"),c2=Aye.promisify(Rye.exec),yye=Po(),Yh=Pd(),l2="Stopping HarperDB.";u2.exports=bye;async function bye(){if(console.log(l2),Sye.notify(l2),await Yh.isServiceRegistered(Tye.PROCESS_DESCRIPTORS.HDB)){Yh.enterPM2Mode();let r=await Yh.getUniqueServicesList();for(let n in r)await Yh.stop(n)}await Yh.kill();let t=await yye.getHDBProcessInfo();t.clustering.forEach(r=>{c2(`kill ${r.pid}`)}),t.core.forEach(r=>{c2(`kill ${r.pid}`)})}a(bye,"stop")});var p2=w((vxe,_2)=>{"use strict";var tD=require("fs-extra"),rD=require("path"),eD=require("yaml"),Wh=ir(),Tc=(H(),C(G)),f2=Tt(),nD=z(),Oye=Rn(),Nye=uS(),wye=cS(),Iye=Po(),zh=ae(),Cye=Qd(),Pye=ie();zh.initSync();var Vs={RUNNING:"running",STOPPED:"stopped",ERRORED:"errored",NOT_INSTALLED:"not installed"},vn={LEAF:"leaf server",HUB:"hub server"},BA;_2.exports=Dye;async function Dye(){let e={harperdb:{status:Vs.STOPPED}};if(!await Cye.isHdbInstalled()){e.harperdb.status=Vs.NOT_INSTALLED,console.log(eD.stringify(e));return}BA=zh.get(Tc.CONFIG_PARAMS.ROOTPATH);let t;try{t=Number.parseInt(await tD.readFile(rD.join(BA,Tc.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Tc.NODE_ERROR_CODES.ENOENT){nD.info("`harperdb status` did not find a hdb.pid file"),e.harperdb.status=Vs.STOPPED,console.log(eD.stringify(e));return}throw n}let r=await Iye.getHDBProcessInfo();for(let n of r.core)if(n.pid===t){e.harperdb.status=Vs.RUNNING,e.harperdb.pid=t;break}if((zh.get(Tc.CONFIG_PARAMS.REPLICATION_URL)||zh.get(Tc.CONFIG_PARAMS.REPLICATION_HOSTNAME))&&(e.replication=await Mye()),e.clustering=await Lye(r),e.clustering[vn.HUB].status===Vs.RUNNING&&e.clustering[vn.LEAF].status===Vs.RUNNING){let n=[],s=await Nye({});for(let o of s.nodes){let c={};for(let l in o)c[l.replace("_"," ")]=o[l];n.push(c)}e.clustering.network=n;let i=await wye.clusterStatus();e.clustering.replication={"node name":i.node_name,"is enabled":i.is_enabled,connections:[]};for(let o of i.connections){let c={};c["node name"]=o?.node_name,c.status=o?.status,c.ports={clustering:o?.ports?.clustering,"operations api":o?.ports?.operations_api},c["latency ms"]=o?.latency_ms,c.uptime=o?.uptime,c.subscriptions=o?.subscriptions,c["system info"]={"hdb version":o?.system_info?.hdb_version,"node version":o?.system_info?.node_version,platform:o?.system_info?.platform},e.clustering.replication.connections.push(c)}await Wh.closeConnection()}console.log(eD.stringify(e)),process.exit()}a(Dye,"status");async function Lye(e){let t={[vn.HUB]:{},[vn.LEAF]:{}};if(e.clustering.length===0)return t[vn.HUB].status=Vs.STOPPED,t[vn.LEAF].status=Vs.STOPPED,t;let{port:r}=Wh.getServerConfig(Tc.PROCESS_DESCRIPTORS.CLUSTERING_HUB),{username:n,decrypt_hash:s}=await Oye.getClusterUser();try{(await Wh.createConnection(r,n,s,!1)).close(),t[vn.HUB].status=Vs.RUNNING}catch{t[vn.HUB].status=Vs.ERRORED}let{port:i}=Wh.getServerConfig(Tc.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);try{(await Wh.createConnection(i,n,s,!1)).close(),t[vn.LEAF].status=Vs.RUNNING}catch{t[vn.LEAF].status=Vs.ERRORED}try{t[vn.HUB].pid=Number.parseInt(await tD.readFile(rD.join(BA,"clustering",f2.PID_FILES.HUB),"utf8"))}catch(o){nD.error(o),t[vn.HUB].pid=void 0}try{t[vn.LEAF].pid=Number.parseInt(await tD.readFile(rD.join(BA,"clustering",f2.PID_FILES.LEAF),"utf8"))}catch(o){nD.error(o),t[vn.LEAF].pid=void 0}return t}a(Lye,"getHubLeafStatus");async function Mye(){let e=await Pye.httpRequest({method:"POST",protocol:"http:",socketPath:zh.get(Tc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET),headers:{"Content-Type":"application/json"}},{operation:"cluster_status"});e=JSON.parse(e.body);let t={"node name":e.node_name,"is enabled":e.is_enabled,connections:[]};for(let r of e.connections)t.connections.push({"node name":r.name,url:r.url,subscriptions:r.subscriptions,replicates:r.replicates,"database sockets":r.database_sockets.map(n=>({database:n.database,connected:n.connected,latency:n.latency,"catching up from":n.catching_up_from,"thread id":n.thread_id,nodes:n.nodes}))});return t}a(Mye,"getReplicationStatus")});nm();var sD=process.env.HDB_LEADER_URL||process.argv.includes("--HDB_LEADER_URL");sD&&ae().setCloneVar(!0);var jh=require("node:fs"),h2=require("node:path"),iu=z(),m2=LJ(),{packageJson:vye,PACKAGE_ROOT:E2}=it(),Uye=UJ(),iD=(H(),C(G)),{SERVICE_ACTIONS_ENUM:cn}=iD,xye=`
136
135
  Usage: harperdb [command]
137
136
 
138
137
  With no command, harperdb will simply run HarperDB (in the foreground)
@@ -154,4 +153,4 @@ stop - Stop the harperdb background process
154
153
  help - Display this output
155
154
  upgrade - Upgrade harperdb
156
155
  version - Print the version
157
- `;async function vye(){let e=Lye();if(e)if(e.error){console.error(e.error),ru.error(e.error);return}else e.warn&&(console.warn(e.warn),ru.warn(e.warn));let t;zh.existsSync(m2.join(g2,"bin"))||(ru.error(`Missing \`bin\` directory at ${g2}`),process.exit(0)),process.argv&&process.argv[2]&&!process.argv[2].startsWith("-")&&(t=process.argv[2].toLowerCase());let r=E2.buildRequest();switch(r.operation&&(t=cn.OPERATION),t){case cn.OPERATION:return ru.trace("calling cli operations with:",r),E2.cliOperations(r);case cn.START:return nD?XP()(!0):Jd().launch();case cn.INSTALL:return i2()();case cn.REGISTER:return c2().register();case cn.STOP:return f2()().then(()=>{process.exit(0)});case cn.RESTART:return Wa().restart({});case cn.VERSION:return Dye.version;case cn.UPGRADE:return ru.setLogLevel(sD.LOG_LEVELS.INFO),wC().upgrade(null).then(()=>"Your instance of HarperDB is up to date!");case cn.STATUS:return h2()();case cn.RENEWCERTS:return Zn().renewSelfSigned().then(()=>"Successfully renewed self-signed certificates");case cn.COPYDB:{let n=process.argv[3],s=process.argv[4];return(wS(),C(NS)).copyDb(n,s)}case cn.DEV:process.env.DEV_MODE=!0;case cn.RUN:{let n=process.argv[3];if(n&&n[0]!=="-"){if(!zh.existsSync(n))throw new Error(`The folder ${n} does not exist`);if(!zh.statSync(n).isDirectory())throw new Error(`The path ${n} is not a folder`);n=zh.realpathSync(n),zh.existsSync(m2.join(n,sD.HDB_CONFIG_FILE))?process.env.ROOTPATH=n:process.env.RUN_HDB_APP=n}}case void 0:return nD?XP()():Jd().main();default:console.warn(`The "${t}" command is not understood.`);case cn.HELP:return Mye}}a(vye,"harperdb");vye().then(e=>{e&&(console.log(e),ru.notify(e))}).catch(e=>{e&&(console.error(e),ru.error(e)),process.exit(1)});
156
+ `;async function Bye(){let e=Uye();if(e)if(e.error){console.error(e.error),iu.error(e.error);return}else e.warn&&(console.warn(e.warn),iu.warn(e.warn));let t;jh.existsSync(h2.join(E2,"bin"))||(iu.error(`Missing \`bin\` directory at ${E2}`),process.exit(0)),process.argv&&process.argv[2]&&!process.argv[2].startsWith("-")&&(t=process.argv[2].toLowerCase());let r=m2.buildRequest();switch(r.operation&&(t=cn.OPERATION),t){case cn.OPERATION:return iu.trace("calling cli operations with:",r),m2.cliOperations(r);case cn.START:return sD?ZP()(!0):Qd().launch();case cn.INSTALL:return s2()();case cn.REGISTER:return a2().register();case cn.STOP:return d2()().then(()=>{process.exit(0)});case cn.RESTART:return za().restart({});case cn.VERSION:return vye.version;case cn.UPGRADE:return iu.setLogLevel(iD.LOG_LEVELS.INFO),IC().upgrade(null).then(()=>"Your instance of HarperDB is up to date!");case cn.STATUS:return p2()();case cn.RENEWCERTS:return Zn().renewSelfSigned().then(()=>"Successfully renewed self-signed certificates");case cn.COPYDB:{let n=process.argv[3],s=process.argv[4];return(IS(),C(wS)).copyDb(n,s)}case cn.DEV:process.env.DEV_MODE=!0;case cn.RUN:{let n=process.argv[3];if(n&&n[0]!=="-"){if(!jh.existsSync(n))throw new Error(`The folder ${n} does not exist`);if(!jh.statSync(n).isDirectory())throw new Error(`The path ${n} is not a folder`);n=jh.realpathSync(n),jh.existsSync(h2.join(n,iD.HDB_CONFIG_FILE))?process.env.ROOTPATH=n:process.env.RUN_HDB_APP=n}}case void 0:return sD?ZP()():Qd().main();default:console.warn(`The "${t}" command is not understood.`);case cn.HELP:return xye}}a(Bye,"harperdb");Bye().then(e=>{e&&(console.log(e),iu.notify(e))}).catch(e=>{e&&(console.error(e),iu.error(e)),process.exit(1)});